<template>
	<el-card class="hl-card">
		<template #header>
			<span><span v-html="dialogTitle"></span>页</span>
		</template>
		<el-form ref="formRef" label-width="140px" :rules="formRules" :model="formData" v-loading="formLoading">
			<!-- 基础信息  横向布局 -->
			<el-card class="hl-card-info" v-if="dispatchType == 'PRODUCTION'">
				<template #header>
					<div class="hl-card-info-icona"></div><span class="hl-card-info-text">基础信息</span>
				</template>
				<el-row>
					<el-col :span="6">
						<el-form-item label="生产派工单号" prop="code">
							<el-input class="!w-260px" v-model="formData.code" :disabled="true" />
						</el-form-item>
					</el-col>
					<el-col :span="6">
						<el-form-item label="生产任务单号" prop="code">
							<el-input class="!w-260px" v-model="formData.taskCode" :disabled="true" />
						</el-form-item>
					</el-col>
					<el-col :span="6">
						<el-form-item label="项目编号" prop="projectCode">
							<el-input class="!w-260px" v-model="formData.projectCode" :disabled="true" />
						</el-form-item>
					</el-col>
					<el-col :span="6">
						<el-form-item label="客户名称" prop="customerName">
							<el-input class="!w-260px" v-model="formData.customerName" :disabled="true" />
						</el-form-item>
					</el-col>
				</el-row>
				<el-row>
					<el-col :span="6">
						<el-form-item label="项目名称" prop="projectName">
							<el-input class="!w-260px" v-model="formData.projectName" :disabled="true" />
						</el-form-item>
					</el-col>
					<el-col :span="6">
						<el-form-item label="项目结束日期" prop="projectEndTime">
							<el-date-picker
class="!w-260px" v-model="formData.projectEndTime" type="date" value-format="x"
								placeholder="项目结束日期" disabled />
						</el-form-item>
					</el-col>
					<el-col :span="6">
						<el-form-item label="子项目名称" prop="projectSubName">
							<el-input class="!w-260px" v-model="formData.projectSubName" :disabled="true" />
						</el-form-item>
					</el-col>
					<el-col :span="6">
						<el-form-item label="子项目编号" prop="projectSubCode">
							<el-input class="!w-260px" v-model="formData.projectSubCode" :disabled="true" />
						</el-form-item>
					</el-col>
				</el-row>
				<el-row>
					<el-col :span="6">
						<el-form-item label="零件名称" prop="materialName">
							<el-input class="!w-260px" v-model="formData.materialName" :disabled="true" />
						</el-form-item>
					</el-col>
					<el-col :span="6">
						<el-form-item label="材质" prop="compositionName">
							<el-input class="!w-260px" v-model="formData.compositionName" :disabled="true" />
						</el-form-item>
					</el-col>
					<el-col :span="6">
						<el-form-item label="规格型号" prop="spec">
							<el-input class="!w-260px" v-model="formData.spec" :disabled="true" />
						</el-form-item>
					</el-col>
					<el-col :span="6">
						<el-form-item label="图号" prop="blueprintNo">
							<el-input class="!w-260px" v-model="formData.blueprintNo" :disabled="true" />
						</el-form-item>
					</el-col>
				</el-row>
				<el-row>
					<el-col :span="6">
						<el-form-item label="零件数量" prop="amount">
							<el-input class="!w-260px" v-model="formData.amount" :disabled="true" />
						</el-form-item>
					</el-col>
					<el-col :span="6">
						<el-form-item label="系统单位" prop="unit">
							<el-select disabled v-model="formData.unit" clearable placeholder="请选择系统单位" class="!w-260px">
								<el-option
v-for="dict in getStrDictOptions(DICT_TYPE.HELI_MATERIAL_UNIT)" :key="dict.value"
									:label="dict.label" :value="dict.value" />
							</el-select>
						</el-form-item>
					</el-col>
					<el-col :span="6">
						<el-form-item label="任务负责人" prop="ownerName">
							<el-input class="!w-260px" v-model="formData.ownerName" :disabled="true" />
						</el-form-item>
					</el-col>
					<el-col :span="6">
						<el-form-item label="要求完成时间" prop="requiredCompletedDate">
							<el-date-picker
class="!w-260px" v-model="formData.requiredCompletedDate" type="date" value-format="x"
								placeholder="要求完成时间" disabled />
						</el-form-item>
					</el-col>
				</el-row>
				<el-row>
					<el-col :span="12">
						<el-form-item label="备注" prop="remark">
							<el-input type="textarea" v-model="formData.remark" :disabled="true" />
						</el-form-item>
					</el-col>
					<el-col :span="6">
						<el-form-item label="创建时间" prop="createTime">
							<el-date-picker
class="!w-260px" v-model="formData.createTime" type="date" value-format="x"
								placeholder="创建时间" disabled />
						</el-form-item>
					</el-col>
					<el-col :span="6">
						<el-form-item label="单据状态" prop="dispatchStatus">
							<el-select v-model="formData.dispatchStatus" placeholder="请选择单据状态" clearable class="!w-260px" disabled>
								<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HELI_DISPATCH_STATUS)" :key="dict.value"
									:label="dict.label" :value="dict.value" />
							</el-select>
						</el-form-item>

					</el-col>
				</el-row>
			</el-card>
			<el-card class="hl-card-info" v-if="dispatchType == 'ASSEMBLE'">
				<template #header>
					<div class="hl-card-info-icona"></div><span class="hl-card-info-text">基础信息</span>
				</template>
				<el-row>
					<el-col :span="6">
						<el-form-item label="装配派工单号" prop="code">
							<el-input class="!w-260px" v-model="formData.code" :disabled="true" />
						</el-form-item>
					</el-col>
					<el-col :span="6">
						<el-form-item label="生产计划单号" prop="code">
							<el-input class="!w-260px" v-model="formData.planCode" :disabled="true" />
						</el-form-item>
					</el-col>
					<el-col :span="6">
						<el-form-item label="项目编号" prop="projectCode">
							<el-input class="!w-260px" v-model="formData.projectCode" :disabled="true" />
						</el-form-item>
					</el-col>
					<el-col :span="6">
						<el-form-item label="客户名称" prop="customerName">
							<el-input class="!w-260px" v-model="formData.customerName" :disabled="true" />
						</el-form-item>
					</el-col>
				</el-row>
				<el-row>
					<el-col :span="6">
						<el-form-item label="项目名称" prop="projectName">
							<el-input class="!w-260px" v-model="formData.projectName" :disabled="true" />
						</el-form-item>
					</el-col>
					<el-col :span="6">
						<el-form-item label="子项目名称" prop="projectSubName">
							<el-input class="!w-260px" v-model="formData.projectSubName" :disabled="true" />
						</el-form-item>
					</el-col>
					<el-col :span="6">
						<el-form-item label="子项目编号" prop="projectSubCode">
							<el-input class="!w-260px" v-model="formData.projectSubCode" :disabled="true" />
						</el-form-item>
					</el-col>
					<el-col :span="6">
						<el-form-item label="BOM清单号" prop="bomCode">
							<el-input class="!w-260px" v-model="formData.bomCode" :disabled="true" />
						</el-form-item>
					</el-col>
				</el-row>
				<el-row>
					<el-col :span="6">
						<el-form-item label="数量" prop="amount">
							<el-input class="!w-260px" v-model="formData.projectSubAmount" :disabled="true" />
						</el-form-item>
					</el-col>
					<el-col :span="6">
						<el-form-item label="单位" prop="unit">
							<el-select disabled v-model="formData.unit" clearable placeholder="请选择单位" class="!w-260px">
								<el-option
v-for="dict in getStrDictOptions(DICT_TYPE.HELI_MATERIAL_UNIT)" :key="dict.value"
									:label="dict.label" :value="dict.value" />
							</el-select>
						</el-form-item>
					</el-col>
					<el-col :span="6">
						<el-form-item label="任务负责人" prop="ownerName">
							<el-input class="!w-260px" v-model="formData.ownerName" :disabled="true" />
						</el-form-item>
					</el-col>
					<el-col :span="6">
						<el-form-item label="单据状态" prop="dispatchStatus">
							<el-select v-model="formData.dispatchStatus" placeholder="请选择单据状态" clearable class="!w-260px" disabled>
								<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HELI_DISPATCH_STATUS)" :key="dict.value"
									:label="dict.label" :value="dict.value" />
							</el-select>
						</el-form-item>
					</el-col>
				</el-row>
				<el-row>
					<el-col :span="6">
						<el-form-item label="要求开始日期" prop="requiredStartDate">
							<el-date-picker
class="!w-260px" v-model="formData.requiredStartDate" type="date" value-format="x"
								placeholder="要求开始日期" disabled />
						</el-form-item>
					</el-col>
					<el-col :span="6">
						<el-form-item label="要求完成日期" prop="requiredStartDate">
							<el-date-picker
class="!w-260px" v-model="formData.requiredEndDate" type="date" value-format="x"
								placeholder="要求完成日期" disabled />
						</el-form-item>
					</el-col>
					<el-col :span="6">
						<el-form-item label="创建时间" prop="createTime">
							<el-date-picker
class="!w-260px" v-model="formData.createTime" type="date" value-format="x"
								placeholder="创建时间" disabled />
						</el-form-item>
					</el-col>
				</el-row>
				<el-row>
					<el-col :span="12">
						<el-form-item label="备注" prop="remark">
							<el-input type="textarea" v-model="formData.remark" :disabled="true" />
						</el-form-item>
					</el-col>
				</el-row>
			</el-card>
			<!-- 表格类信息 -->
			<el-card class="hl-card-info">
				<template #header>
					<div class="hl-card-info-icona"></div><span class="hl-card-info-text">派工明细</span>
				</template>
				<el-row>
					<el-col v-if=" (formData.dispatchStatus != 2 && active != 'detail')  || !detailDisabled">
						<el-button class="hl-addbutton" type="primary" size="large" @click="onAddItem">新增</el-button>
					</el-col>
					<el-col>
						<el-card class="hl-incard">
							<el-form
ref="subFormRef" :model="formData.taskDispatchDetails" :rules="subFormRules"
								v-loading="subFormLoading" label-width="0">
								<el-table :data="formData.taskDispatchDetails" class="hl-table">
									<el-table-column fixed label="序号" align="center" type="index" width="80" />
									<el-table-column fixed label="工序名称" align="center" prop="procedureId" width="180">
										<template #header> <span class="hl-table_header">*</span>工序名称</template>
										<template #default="{ row, $index }">
											<el-form-item :prop="`${$index}.procedureId`" :rules="subFormRules.procedureId" class="mb-0px!">
												<ProcedureSelect
:disabled="detailDisabled  || row.procedureStatus != 0"
													v-model="row.procedureId"
													@update:new-value="(val) => { handleSelectedProcedure(row, val); }" />
											</el-form-item>
										</template>
									</el-table-column>
									<el-table-column label="是否报工" prop="isReport" width="100">
										<template #default="scope">
											{{ getDictLabel(DICT_TYPE.HELI_COMMON_IS_OR_NOT, scope.row.isReport) }}
										</template>
									</el-table-column>
									<el-table-column label="顺序号" align="center" prop="sort" width="160">
										<template #default="{ row, $index }">
											<el-form-item :prop="`${$index}.sort`" :rules="subFormRules.sort" class="mb-0px!">
												<el-input-number
min="0" :precision="0" class="!w-240px"
													:disabled="detailDisabled || (row.beginProduce != 0  && row.procedureStatus != 0)" v-model="row.sort"
													placeholder="请输入顺序号" />
											</el-form-item>
										</template>
									</el-table-column>
									<el-table-column label="负责人" align="center" prop="owner" width="180">
										<template #header> <span class="hl-table_header">*</span>负责人</template>
										<template #default="{ row, $index }">
											<el-form-item :prop="`${$index}.owner`" :rules="subFormRules.owner" class="mb-0px!">
<!--												<UserSelect-->
<!--v-model="row.owner" :disabled="detailDisabled || row.procedureStatus != 0"-->
<!--													@update:new-value="handleSelectedUser($index, $event)" />-->
                        <el-select v-model="row.owner" :disabled="detailDisabled || (row.beginProduce != 0 && row.procedureStatus != 0)"  @update:new-value="handleSelectedUser($index, $event)">
                          <el-option
v-for="dict in userInit" :key="dict.id"
                                     :label="dict.username+' '+dict.nickname" :value="dict.id" />
                        </el-select>
											</el-form-item>
										</template>
									</el-table-column>
									<el-table-column label="预计开始时间" min-width="180">
										<template #header> <span class="hl-table_header">*</span>预计开始时间</template>
										<template #default="{ row, $index }">
											<el-form-item :prop="`${$index}.startTime`" :rules="subFormRules.startTime" class="mb-0px!">
												<el-date-picker
:disabled="detailDisabled " v-model="row.startTime"
													type="date" value-format="x" placeholder="选择预计开始日期" />
											</el-form-item>
										</template>
									</el-table-column>
									<el-table-column label="预计结束时间" min-width="180">
										<template #header> <span class="hl-table_header">*</span>预计结束时间</template>
										<template #default="{ row, $index }">
											<el-form-item :prop="`${$index}.endTime`" :rules="subFormRules.endTime" class="mb-0px!">
												<el-date-picker
:disabled="detailDisabled " v-model="row.endTime"
													type="date" value-format="x" placeholder="选择预计结束日期" />
											</el-form-item>
										</template>
									</el-table-column>
									<el-table-column label="预计工时" align="center" prop="workTime" width="180">
										<template #header> <span class="hl-table_header">*</span>预计工时</template>
										<template #default="{ row, $index }">
											<el-form-item :prop="`${$index}.workTime`" :rules="subFormRules.workTime" class="mb-0px!">
												<el-input-number
min="0" :precision="2" class="!w-240px"
													:disabled="detailDisabled" v-model="row.workTime"
													placeholder="请输入预计工时" />
											</el-form-item>
										</template>
									</el-table-column>
									<el-table-column label="派工数量" align="center" prop="amount" width="180">
										<template #header> <span class="hl-table_header">*</span>派工数量</template>
										<template #default="{ row, $index }">
											<el-form-item :prop="`${$index}.amount`" :rules="subFormRules.amount" class="mb-0px!">
												<el-input-number
						min="0" :max="formData.amount" :precision="0" class="!w-240px"
																			:disabled="detailDisabled" v-model="row.amount"
													placeholder="请输入派工数量" />
											</el-form-item>
										</template>
									</el-table-column>
                  <el-table-column label="制造设备" min-width="180" align="center">
                    <template #default="{ row, $index }">
                      <el-form-item :prop="`${$index}.deviceModel`" :rules="subFormRules.deviceModel" class="mb-0px!">
                        <EquipmentSelect
                          v-model="row.deviceModel"
                          @update:new-value="handleSelectedequip($index, $event)"
                          :disabled="detailDisabled || (row.beginProduce != 0 && row.procedureStatus != 0)" />
                      </el-form-item>
                    </template>
                  </el-table-column>
                  <el-table-column label="工序要点" prop="summary" min-width="160">
                    <template #default="{ row, $index }">
                      <el-form-item :prop="`${$index}.summary`" class="mb-0px!">
                        <el-input
                          :disabled="detailDisabled ||(row.beginProduce != 0 && row.procedureStatus != 0)" v-model="row.summary"
                          placeholder="请输入工序要点" />
                      </el-form-item>
                    </template>
                  </el-table-column>
									<el-table-column label="系统单位" align="center" prop="unit" width="120">
										<template #default>
											{{ getDictLabel(DICT_TYPE.HELI_MATERIAL_UNIT, formData.unit) }}
										</template>
									</el-table-column>
                  <el-table-column label="工序编号" prop="procedureCode" width="140" />
									<el-table-column fixed="right" label="操作" align="center" min-width="100">
										<template #default="scope">
											<el-button
v-if="'detail' != active && (scope.row.beginProduce == 0 && scope.row.procedureStatus == 0)" link type="danger"
												size="small" @click.prevent="onDeleteItem(scope.$index)">
												删除
											</el-button>
										</template>
									</el-table-column>
								</el-table>
							</el-form>
						</el-card>
					</el-col>
				</el-row>
			</el-card>

			<el-card class="hl-card-info">
				<template #header>
					<div class="hl-card-info-icona"></div><span class="hl-card-info-text">操作日志</span>
				</template>
				<el-row>
					<el-col>
						<el-card class="hl-incard">
							<el-table
:data="formData.operateLogs" class="hl-table"
								:style="{ height: formData.operateLogs && formData.operateLogs.length > 10 ? '450px' : '' }">
								<el-table-column prop="type" label="操作" align="center">
									<template #default="scope">
										{{ getDictLabel(DICT_TYPE.SYSTEM_OPERATE_TYPE, scope.row.type) }}
									</template>
								</el-table-column>
								<el-table-column prop="userNickname" label="操作人" align="center" />
								<el-table-column label="操作时间" align="center" prop="startTime" :formatter="dateFormatter" />
							</el-table>
						</el-card>
					</el-col>
				</el-row>
			</el-card>
		</el-form>
		<div class="hl-footer text-center">
			<el-button @click="goback" size="large">取 消</el-button>
			<el-button
v-if="active != 'detail' && formData.dispatchStatus == 1" @click="submitForm('SAVE')" type="primary"
				:disabled="formLoading" size="large">保 存</el-button>
			<el-button
v-if="active != 'detail' && formData.dispatchStatus == 1" @click="submitForm('SUBMIT')" type="success"
				:disabled="formLoading" size="large">提 交</el-button>
			<el-button
v-if="active != 'detail' && formData.dispatchStatus == 2" @click="submitForm('CANCEL_SUBMIT')"
				type="danger" :disabled="formLoading" size="large">取消提交</el-button>
			<el-button
v-if="formData.dispatchStatus == 2" @click="printHandle(formData.id)" :disabled="formLoading"
				size="large" type="primary">打印流程卡</el-button>
		</div>
		<div>
			<!-- 排产弹框 -->
			<el-dialog v-model="dialogTableVisible" title="dialogTitle" width="1000">
				<template #title>
					<div class="dialog-title">
						提示
					</div>
					<!-- 介绍文本 -->
					<p class="introduction-text">
						当前选择设备经过计算,无法满足当前填写预计日期范围的预计工时,请修改!
					</p>
				</template>
				<span v-if="taskDD">如下为当前设备的历史预计日期范围,含有在{{ formatDateT(taskDD) }}前后七天的排产日历如下:</span>
				<el-table :data="dataList">
					<el-table-column property="projectName" label="项目名称" width="150" />
					<el-table-column property="projectSubName" label="子项目名称" width="150" />
					<el-table-column label="预计开始日期" width="150">
						<template #default="scope">
							{{ formatDateT(scope.row.startTime) }}
						</template>
					</el-table-column>
					<el-table-column label="预计结束日期">
						<template #default="scope">
							{{ formatDateT(scope.row.endTime) }}
						</template>
					</el-table-column>
					<el-table-column property="workTime" label="预计工时" width="150" />
					<el-table-column property="maxLongTime" label="每日最大运行时长" width="200" />
				</el-table>
			</el-dialog>
						<!-------------取消提交弹框---------------->
						<el-dialog v-model="centerDialogVisible" title="提示" width="30%" center>
						<span>
							该派工单,存在报工完数据,是否继续?
						</span>
						<template #footer>
							<span class="dialog-footer">
								<el-button type="primary" @click="sureToCancle()">
									确认
								</el-button>
								<el-button @click="centerDialogVisible = false">取消</el-button>
							</span>
						</template>
					</el-dialog>
		</div>
	</el-card>

	<!-- 【打印发货单】 - 弹框-->
	<ProductProcessPrint ref="ProductProcessPrintRef" :info="dialogInfo" />
</template>
<script setup lang="ts">
import {
	getIntDictOptions,
	getStrDictOptions,
	DICT_TYPE,
	getDictLabel
} from '@/utils/dict'
import {
	dateFormatter,
	formatDate
} from "@/utils/formatTime";
import {
	ref,
	watch
} from "vue";
import * as TaskDispatchApi from '@/api/heli/taskdispatch'
import {
	inject
} from 'vue'
import {
	useUserStore
} from "@/store/modules/user";
import {
	useCommonStore
} from "@/store/modules/common";
import {
	getOperateLogPage
} from "@/api/system/operatelog";
import ProcedureSelect from "@/views/heli/hlvuestyle/procedureSelect.vue";
import UserSelect from '@/views/heli/hlvuestyle/userSelect.vue'
import EquipSelect from "@/views/heli/hlvuestyle/equipSelect.vue";
import EquipmentSelect from "@/views/heli/hlvuestyle/equipmentSelect.vue";
import ProductProcessPrint from "./ProductProcessPrint.vue";
import * as EquipManufactureApi from '@/api/heli/equipmanufacture';
import {
	ElDialog,
	ElTable,
	ElTableColumn,
	ElButton
} from 'element-plus';
import * as UserApi from "@/api/system/user";
import * as ProcedureApi from "@/api/heli/procedure";


defineOptions({
	name: 'TaskDispatchDetail'
})

const reload = inject('reload')
const {
	t
} = useI18n() // 国际化
const message = useMessage() // 消息弹窗
const commonStore = useCommonStore()
const userStore = useUserStore()
const router = useRouter()

const active = toRef(commonStore.getStore('active'))
const currentId = toRef(commonStore.getStore('id'))
const dispatchType = toRef(commonStore.getStore("dispatchType"));


const formLoading = ref(false)
const dialogTitle = ref('')
const detailDisabled = ref(false)


const formatDateT = (timestamp) => {
	const date = new Date(timestamp);
	const year = date.getFullYear();
	const month = String(date.getMonth() + 1).padStart(2, '0');
	const day = String(date.getDate()).padStart(2, '0');
	return `${year}-${month}-${day}`; // 返回 YYYY-MM-DD 格式
}

const formData = ref({
	id: undefined,
	code: undefined,
	amount: undefined,
	projectSubAmount:undefined,
	dispatchType: undefined,
	taskId: undefined,
	planId: undefined,
	projectId: undefined,
	projectSubId: undefined,
	bomDetailId: undefined,
	dispatchStatus: undefined,
	remark: undefined,
	status: 1,
	taskDispatchDetails: [],
	operateLogs: [],
	active: undefined,
	activeOpinion: ''
})

const formRef = ref() // 表单 Ref
const subFormRef = ref()
const formRules = reactive({
	code: [{
		required: true,
		message: '单号不能为空',
		trigger: 'blur'
	}],
	planCode: [{
		required: true,
		message: '生产计划单号不能为空',
		trigger: 'blur'
	}],
	taskCode: [{
		required: true,
		message: '生产任务单号不能为空',
		trigger: 'blur'
	}],
	customerName: [{
		required: true,
		message: '客户名称不能为空',
		trigger: 'blur'
	}],
	projectCode: [{
		required: true,
		message: '项目编号不能为空',
		trigger: 'blur'
	}],
	projectName: [{
		required: true,
		message: '项目名称不能为空',
		trigger: 'blur'
	}],
	projectSubCode: [{
		required: true,
		message: '子项目编号不能为空',
		trigger: 'blur'
	}],
	projectSubName: [{
		required: true,
		message: '子项目名称不能为空',
		trigger: 'blur'
	}],
	projectEndTime: [{
		required: true,
		message: '项目结束日期不能为空',
		trigger: 'blur'
	}],
	materialName: [{
		required: true,
		message: '零件名称不能为空',
		trigger: 'blur'
	}],
	compositionName: [{
		required: true,
		message: '材质不能为空',
		trigger: 'blur'
	}],
	blueprintNo: [{
		required: true,
		message: '图号不能为空',
		trigger: 'blur'
	}],
	bomCode: [{
		required: true,
		message: 'BOM清单号不能为空',
		trigger: 'blur'
	}],
	amount: [{
		required: true,
		message: '数量不能为空',
		trigger: 'blur'
	}],
	unit: [{
		required: true,
		message: '单位不能为空',
		trigger: 'blur'
	}],
	ownerName: [{
		required: true,
		message: '任务负责人不能为空',
		trigger: 'blur'
	}],
	requiredCompletedDate: [{
		required: true,
		message: '要求完成时间不能为空',
		trigger: 'blur'
	}],
	requiredStartDate: [{
		required: true,
		message: '要求开始日期不能为空',
		trigger: 'blur'
	}],
	requiredEndDate: [{
		required: true,
		message: '要求完成日期不能为空',
		trigger: 'blur'
	}],
	dispatchStatus: [{
		required: true,
		message: '单据状态不能为空',
		trigger: 'blur'
	}],
	status: [{
		required: true,
		message: '状态,1表示正常,2表示禁用不能为空',
		trigger: 'blur'
	}],
})

const dataList = ref([]);
const dialogTableVisible = ref(false)
const taskDD = ref(null);
//let manufactuId = null;
//let maxLongtime = null;
const userInit = ref()
let watches = [];

// 清理所有监听器
const clearWatches = () => {
	watches.forEach(unwatch => unwatch());
	watches = []; // 重新初始化
};

watch(
	() => formData.value.taskDispatchDetails,
	(newDetails) => {
		// 检查 newDetails 是否为有效数组
		if (!Array.isArray(newDetails)) {
			return; // 直接返回,不继续执行
		}

		// 清除之前的监听器
		clearWatches()
		newDetails.forEach((detail, index) => {
			// 监听每个工序的预计工时
			const unwatch = watch(
				() => detail.workTime,
				(newWorkTime) => {
					if (typeof newWorkTime !== 'number') {
						console.warn(`第 ${index + 1} 行的预计工时不是有效数字: ${newWorkTime}`);
						return;
					}
					console.log(`第 ${index + 1} 行的预计工时变化为: ${newWorkTime}`);
					console.log("detail==", detail)
					if(detail.startTime){
						openDialogWT(detail);
					}
				}
			);
			watches.push(unwatch); // 存储当前的取消监听函数
		});
	}, {
	deep: true
} // 深度监听
);
const openDialogWT = async (dataParam) => {
	taskDD.value = null;
	taskDD.value = dataParam.startTime;
	const data = await TaskDispatchApi.getTaskDispatchDetailListByWorkTime(dataParam);
	//debugger
	dataList.value = [];
	if (data.total !== 0) {
		dataList.value = data.list; // 将获取到的数据存储到 dataList
		console.log("dataList.value==", dataList.value)
		dialogTableVisible.value = true; // 打开弹框
	} else {
		console.warn("没有获取到数据");
	}
};

/** 查询计算提示 */
const calculationPrompt = async (dataParam) => {
	formLoading.value = true;
	try {
		//debugger
		const data = await TaskDispatchApi.getTaskDispatchDetailListByWorkTime(dataParam);
		if (data.total != 0) {
			//如果data.total!=0也就是当data.list有数据的时候,去做个弹框在弹框中用列表展示data.lidt的数据
			console.log("data==", data.list);
		} else {
			console.warn("获取的数据中没有 maxlongtime");
		}
	} catch (error) {
		console.error("获取设备制造信息失败:", error);
	} finally {
		formLoading.value = false;
	}
}

// /** 查询每日最大运行时长 */
// const getEquipMfMaxlt = async () => {
//   formLoading.value = true;
//   try {
//     console.log("manufactuId==", manufactuId);
//     const data = await EquipManufactureApi.getEquipManufacture(manufactuId);

//     // 确保 data 和 maxlongtime 存在
//     if (data && typeof data.maxlongtime !== 'undefined') {
//       maxLongtime = data.maxlongtime;
//       console.log("maxLongtime==", maxLongtime);
//     } else {
//       console.warn("获取的数据中没有 maxlongtime");
//     }
//   } catch (error) {
//     console.error("获取设备制造信息失败:", error);
//   } finally {
//     formLoading.value = false;
//   }
// }

/** 重置表单 */
const resetForm = () => {
	formData.value = {
		id: undefined,
		code: undefined,
		amount: undefined,
		projectSubAmount:undefined,
		dispatchType: undefined,
		taskId: undefined,
		planId: undefined,
		projectId: undefined,
		projectSubId: undefined,
		bomDetailId: undefined,
		dispatchStatus: undefined,
		remark: undefined,
		status: 1,
		taskDispatchDetails: [],
		operateLogs: [],
		active: undefined,
		activeOpinion: ''
	}
	formRef.value?.resetFields()
}
const subFormLoading = ref(false) // 子表单的加载中
const subFormRules = reactive({
	procedureId: [{
		required: true,
		message: '工序不能为空',
		trigger: 'blur'
	}],
	owner: [{
		required: true,
		message: '负责人不能为空',
		trigger: 'blur'
	}],
	workTime: [{
		required: true,
		message: '预计工时不能为空',
		trigger: 'blur'
	}],
	amount: [{
		required: true,
		message: '派工数量不能为空',
		trigger: 'blur'
	}],
	startTime: [{
		required: true,
		message: '预计开始日期不能为空',
		trigger: 'blur'
	}],
	endTime: [{
		required: true,
		message: '预计结束日期不能为空',
		trigger: 'blur'
	}],
})

const queryData = async (id?: number) => {
	resetForm()
	// 修改时,设置数据
	if (id) {
		formLoading.value = true
		try {
			formData.value = await TaskDispatchApi.getTaskDispatch(id)
			formData.value.taskDispatchDetails = await TaskDispatchApi.getTaskDispatchDetailListByDispatchId(id)
      formData.value.bomCode = 'BOM-' + formData.value.projectSubCode
			if (formData.value.dispatchStatus == 2) {
				detailDisabled.value = true
			}

			// 操作日志
			let logParams = {
				pageNo: 1,
				pageSize: 99,
				businessId: id,
				businessType: 'TASK_DISPATCH'
			}
			formData.value.operateLogs = (await getOperateLogPage(logParams)).list
		} finally {
			formLoading.value = false
		}
	}
}
const centerDialogVisible = ref(false);
const isSureCancle = ref(false)
const sureToCancle = () =>{
	isSureCancle.value = true;
	centerDialogVisible.value = false;
	submitForm('CANCEL_SUBMIT');
}
const submitForm = async (operate) => {
	formData.value.active = operate
	// 校验子表单
	await subFormRef.value.validate()
	// 提交请求
	formLoading.value = true
	try {
		if(operate == 'CANCEL_SUBMIT'){
			//如果是取消提交
			 if(!isSureCancle.value){
				//如果没确认过//判断是否存在已报工完的派工
				 var hasOver =  await TaskDispatchApi.judgeHasOver(formData.value.id);
				 if(hasOver){
					centerDialogVisible.value = true;
					return;
				 }
			 }
		}
		isSureCancle.value  = false
		// 提交明细不能为空
		if (operate == 'SUBMIT') {
			if (!formData.value.taskDispatchDetails || formData.value.taskDispatchDetails.length == 0) {
				message.error('派工明细不能为空')
				return
			}
		}

    for (let i = 0; i < formData.value.taskDispatchDetails.length; i++) {
      let name
      if (formData.value.taskDispatchDetails[i].amount<formData.value.taskDispatchDetails[i].numAmount){
        for (let j = 0; j < procedureSelectList.value.list.length; j++) {
          if (procedureSelectList.value.list[j].id==formData.value.taskDispatchDetails[i].procedureId){
            name=procedureSelectList.value.list[j].name
            message.error("工序"+name+"")
            return
          }
        }
      }



    }
      for (let i = 0; i < formData.value.taskDispatchDetails.length-1; i++) {
      for (let j = i+1; j < formData.value.taskDispatchDetails.length; j++) {
        if (formData.value.taskDispatchDetails[i].sort==formData.value.taskDispatchDetails[j].sort){
          message.error("派工工序的顺序号重复,请确认!")
          return
        }
      }
    }
		const data = formData.value as unknown as TaskDispatchApi.TaskDispatchVO
		let dataId = await TaskDispatchApi.operateTaskDispatch(data)
		message.success(t('common.operationSuccess'))

		let jumpActive = 'update'
		if (operate == 'SUBMIT') {
			jumpActive = 'detail'
		}
		commonStore.setStore('active', jumpActive)
		commonStore.setStore('id', dataId)
		reload()
	} finally {
		formLoading.value = false
	}
}
const procedureSelectList = ref<ProcedureApi.ProcedureVO[]>([])
const queryParams = {
  pageNo: 1,
  pageSize: 10,
  code: undefined,
  name: undefined,
  description: undefined,
  status: 1,
  creator: undefined,
  createTime: [],
  updater: undefined,
  updateTime: [],
  deleted: undefined,
  tenantId: undefined,
  isReport: undefined,
  wid: undefined
}
/** 新增按钮操作 */
const onAddItem = () => {
	const row = {
		id: undefined,
		procedureId: undefined,
		sort: undefined,
		owner: undefined,
		workTime: undefined,
		amount: undefined,
		summary: undefined,
		status: 1,
		procedureStatus: 0,
		dispatchId: undefined,
	}
	row.amount = formData.value.projectSubAmount
	row.dispatchId = formData.value.id
	formData.value.taskDispatchDetails.push(row)
}

const goback = () => {
	router.back()
}

/** 删除子项操作 */
const onDeleteItem = async (index) => {
	let deletedItems = formData.value.taskDispatchDetails.splice(index, 1)
	let id = deletedItems[0].id
	if (id) await TaskDispatchApi.deleteTaskDispatchDetail(id)
	message.success(t('common.delSuccess'))
}

const handleSelectedProcedure = async (row: any, newValue: any) => {
	if (newValue) {
		row.procedureId = newValue.id
		row.procedureCode = newValue.code
		row.isReport = newValue.isReport
	} else {
		row.procedureId = undefined
		row.procedureCode = undefined
		row.isReport = undefined
	}
}

const handleSelectedUser = (currentIndex, newValue: any) => {
	formData.value.taskDispatchDetails[currentIndex].owner = newValue?.id
}

const handleSelectedequip = (currentIndex: number, newValue: any) => {
	formData.value.taskDispatchDetails[currentIndex].deviceModel = newValue?.id
}
const ProductProcessPrintRef = ref() // 打印弹框
const printHandle = (id) => {
	ProductProcessPrintRef.value.open(id)
}

onMounted(async () => {
	dialogTitle.value = t('action.' + active.value)
	if ('detail' == active.value) {
		detailDisabled.value = true
	}
  userInit.value = await UserApi.getDeptName("生产部")
	queryData(currentId.value)
  const data = await ProcedureApi.getProcedurePage(queryParams)
  procedureSelectList.value=data

})
</script>
<style scoped lang="less">
.dialog-title {
	font-size: 40px;
	/* 调整字体大小 */
	font-weight: bold;
	/* 加粗 */
	text-align: center;
	/* 居中对齐 */
	margin: 0;
	/* 去掉默认外边距 */
	margin-bottom: 5px;
	/* 如果需要,可以设置标题底部的间距 */
}

.introduction-text {
	margin: 0;
	/* 去掉默认的外边距 */
	padding: 0;
	/* 去掉内边距,如果有的话 */
}

.el-dialog {
	padding: 10px;
	/* 调整为合适的值 */
}
</style>