init:first commit of plus-ui
This commit is contained in:
		
							
								
								
									
										103
									
								
								src/views/safety/safetyLog/component/SafetyLogDetailDialog.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										103
									
								
								src/views/safety/safetyLog/component/SafetyLogDetailDialog.vue
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,103 @@
 | 
			
		||||
<template>
 | 
			
		||||
  <el-card v-loading="loading">
 | 
			
		||||
    <h2 style="text-align: center; margin-top: 5px; font-weight: bold">安全日志</h2>
 | 
			
		||||
    <el-row>
 | 
			
		||||
      <el-col :span="12" style="text-align: left">记录人:{{ safetyLogDetail?.creator?.name }}</el-col>
 | 
			
		||||
      <el-col :span="12" style="text-align: right">记录时间:{{ safetyLogDetail?.createTime }}</el-col>
 | 
			
		||||
    </el-row>
 | 
			
		||||
    <el-descriptions :column="3" border style="margin-top: 8px">
 | 
			
		||||
      <el-descriptions-item label-align="center" width="160px" label="项目名称" :span="3">{{ currentProject?.name }} </el-descriptions-item>
 | 
			
		||||
      <el-descriptions-item label-align="center" label="发生日期">{{ safetyLogDetail?.dateOfOccurrence }} </el-descriptions-item>
 | 
			
		||||
      <el-descriptions-item label-align="center" label="气温">
 | 
			
		||||
        <span>最高:{{ safetyLogDetail?.airTemperatureMax }}(℃)</span>
 | 
			
		||||
        <span>最低:{{ safetyLogDetail?.airTemperatureMin }}(℃)</span>
 | 
			
		||||
      </el-descriptions-item>
 | 
			
		||||
      <el-descriptions-item label-align="center" label="气候">
 | 
			
		||||
        <dict-tag :value="safetyLogDetail?.weather" :options="weather_type" />
 | 
			
		||||
      </el-descriptions-item>
 | 
			
		||||
      <el-descriptions-item label-align="center" label="工程施工部位及施工进展情况" :span="3">
 | 
			
		||||
        {{ safetyLogDetail?.progress }}
 | 
			
		||||
      </el-descriptions-item>
 | 
			
		||||
      <el-descriptions-item label-align="center" label="当日主要危险性项目作业内容" :span="3">
 | 
			
		||||
        {{ safetyLogDetail?.jobContent }}
 | 
			
		||||
      </el-descriptions-item>
 | 
			
		||||
      <el-descriptions-item label-align="center" label="施工项目安全教育与安全交底情况" :span="3">
 | 
			
		||||
        {{ safetyLogDetail?.discloseCondition }}
 | 
			
		||||
      </el-descriptions-item>
 | 
			
		||||
      <el-descriptions-item label-align="center" label="施工作业队伍班前施工安全活动情况" :span="3">
 | 
			
		||||
        {{ safetyLogDetail?.activityCondition }}
 | 
			
		||||
      </el-descriptions-item>
 | 
			
		||||
      <el-descriptions-item label-align="center" label="现场施工安全巡视与检查情况" :span="3">
 | 
			
		||||
        {{ safetyLogDetail?.examineCondition }}
 | 
			
		||||
      </el-descriptions-item>
 | 
			
		||||
      <el-descriptions-item label-align="center" label="季节施工防寒、防暑等措施实施情况" :span="3">
 | 
			
		||||
        {{ safetyLogDetail?.implementCondition }}
 | 
			
		||||
      </el-descriptions-item>
 | 
			
		||||
      <el-descriptions-item label-align="center" label="监理通知有关部门安全检查情况" :span="3">
 | 
			
		||||
        {{ safetyLogDetail?.safetyInspectionCondition }}
 | 
			
		||||
      </el-descriptions-item>
 | 
			
		||||
      <el-descriptions-item label-align="center" label="停工、加班情况" :span="3">{{ safetyLogDetail?.stoppageOrOvertime }} </el-descriptions-item>
 | 
			
		||||
      <el-descriptions-item label-align="center" label="其他应记录的安全与文明施工事项" :span="3">
 | 
			
		||||
        {{ safetyLogDetail?.otherCondition }}
 | 
			
		||||
      </el-descriptions-item>
 | 
			
		||||
      <el-descriptions-item label-align="center" label="附件" :span="3">
 | 
			
		||||
        <el-space direction="vertical">
 | 
			
		||||
          <el-link v-for="item in fileList" :key="item.ossId" :href="`${item.url}`" type="primary" :underline="false" target="_blank">
 | 
			
		||||
            <span> {{ item.originalName }} </span>
 | 
			
		||||
          </el-link>
 | 
			
		||||
        </el-space>
 | 
			
		||||
      </el-descriptions-item>
 | 
			
		||||
      <el-descriptions-item label-align="center" label="备注" :span="3">{{ safetyLogDetail?.remark }} </el-descriptions-item>
 | 
			
		||||
    </el-descriptions>
 | 
			
		||||
  </el-card>
 | 
			
		||||
</template>
 | 
			
		||||
 | 
			
		||||
<script setup lang="ts">
 | 
			
		||||
import { SafetyLogVO } from '@/api/safety/safetyLog/types';
 | 
			
		||||
import { getSafetyLog } from '@/api/safety/safetyLog';
 | 
			
		||||
import { useUserStoreHook } from '@/store/modules/user';
 | 
			
		||||
import { listByIds } from '@/api/system/oss';
 | 
			
		||||
import { OssVO } from '@/api/system/oss/types';
 | 
			
		||||
 | 
			
		||||
interface Props {
 | 
			
		||||
  safetyLogId?: string | number;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
const { proxy } = getCurrentInstance() as ComponentInternalInstance;
 | 
			
		||||
const { weather_type } = toRefs<any>(proxy?.useDict('weather_type'));
 | 
			
		||||
 | 
			
		||||
// 获取用户 store
 | 
			
		||||
const userStore = useUserStoreHook();
 | 
			
		||||
// 从 store 中获取项目列表和当前选中的项目
 | 
			
		||||
const currentProject = computed(() => userStore.selectedProject);
 | 
			
		||||
const props = defineProps<Props>();
 | 
			
		||||
const loading = ref<boolean>(false);
 | 
			
		||||
const safetyLogDetail = ref<SafetyLogVO>();
 | 
			
		||||
const fileList = ref<Array<OssVO>>([]);
 | 
			
		||||
const get = async () => {
 | 
			
		||||
  loading.value = true;
 | 
			
		||||
  const res = await getSafetyLog(props.safetyLogId);
 | 
			
		||||
  if (res.data && res.code === 200) {
 | 
			
		||||
    safetyLogDetail.value = res.data;
 | 
			
		||||
    if (res.data.fileId) {
 | 
			
		||||
      const fileRes = await listByIds(res.data.fileId.split(','));
 | 
			
		||||
      fileList.value = fileRes.data;
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
  loading.value = false;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
onMounted(() => {
 | 
			
		||||
  get();
 | 
			
		||||
});
 | 
			
		||||
 | 
			
		||||
watch(
 | 
			
		||||
  () => props.safetyLogId,
 | 
			
		||||
  (newId, oldId) => {
 | 
			
		||||
    if (newId !== oldId) {
 | 
			
		||||
      fileList.value = undefined;
 | 
			
		||||
      get();
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
);
 | 
			
		||||
</script>
 | 
			
		||||
							
								
								
									
										336
									
								
								src/views/safety/safetyLog/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										336
									
								
								src/views/safety/safetyLog/index.vue
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,336 @@
 | 
			
		||||
<template>
 | 
			
		||||
  <div class="p-2">
 | 
			
		||||
    <transition :enter-active-class="proxy?.animate.searchAnimate.enter" :leave-active-class="proxy?.animate.searchAnimate.leave">
 | 
			
		||||
      <div v-show="showSearch" class="mb-[10px]">
 | 
			
		||||
        <el-card shadow="hover">
 | 
			
		||||
          <el-form ref="queryFormRef" :model="queryParams" :inline="true">
 | 
			
		||||
            <el-form-item label="发生日期" prop="dateOfOccurrence">
 | 
			
		||||
              <el-date-picker clearable v-model="queryParams.dateOfOccurrence" type="date" value-format="YYYY-MM-DD" placeholder="请选择发生日期" />
 | 
			
		||||
            </el-form-item>
 | 
			
		||||
            <el-form-item label="录入人" prop="creatorName">
 | 
			
		||||
              <el-input clearable v-model="queryParams.creatorName" placeholder="请输入录入人" />
 | 
			
		||||
            </el-form-item>
 | 
			
		||||
            <el-form-item>
 | 
			
		||||
              <el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button>
 | 
			
		||||
              <el-button icon="Refresh" @click="resetQuery">重置</el-button>
 | 
			
		||||
            </el-form-item>
 | 
			
		||||
          </el-form>
 | 
			
		||||
        </el-card>
 | 
			
		||||
      </div>
 | 
			
		||||
    </transition>
 | 
			
		||||
 | 
			
		||||
    <el-card shadow="never">
 | 
			
		||||
      <template #header>
 | 
			
		||||
        <el-row :gutter="10" class="mb8">
 | 
			
		||||
          <el-col :span="1.5">
 | 
			
		||||
            <el-button type="primary" plain icon="Plus" @click="handleAdd" v-hasPermi="['safety:safetyLog:add']">新增 </el-button>
 | 
			
		||||
          </el-col>
 | 
			
		||||
          <el-col :span="1.5">
 | 
			
		||||
            <el-button type="danger" plain icon="Delete" :disabled="multiple" @click="handleDelete()" v-hasPermi="['safety:safetyLog:remove']">
 | 
			
		||||
              批量删除
 | 
			
		||||
            </el-button>
 | 
			
		||||
          </el-col>
 | 
			
		||||
          <el-col :span="1.5">
 | 
			
		||||
            <el-button type="warning" plain icon="Download" @click="handleExport" v-hasPermi="['safety:safetyLog:export']">导出 </el-button>
 | 
			
		||||
          </el-col>
 | 
			
		||||
          <right-toolbar v-model:showSearch="showSearch" @queryTable="getList"></right-toolbar>
 | 
			
		||||
        </el-row>
 | 
			
		||||
      </template>
 | 
			
		||||
 | 
			
		||||
      <el-table v-loading="loading" :data="safetyLogList" @selection-change="handleSelectionChange">
 | 
			
		||||
        <el-table-column type="selection" width="55" align="center" />
 | 
			
		||||
        <el-table-column label="序号" type="index" width="60" align="center" />
 | 
			
		||||
        <el-table-column label="日志名称" align="center">
 | 
			
		||||
          <template #default="scope">
 | 
			
		||||
            <span>{{ dayjs(scope.row.dateOfOccurrence).format('YYYY 年 MM 月 DD 日') }}安全日志</span>
 | 
			
		||||
          </template>
 | 
			
		||||
        </el-table-column>
 | 
			
		||||
        <el-table-column label="发生日期" align="center" prop="dateOfOccurrence" width="180">
 | 
			
		||||
          <template #default="scope">
 | 
			
		||||
            <span>{{ parseTime(scope.row.dateOfOccurrence, '{y}-{m}-{d}') }}</span>
 | 
			
		||||
          </template>
 | 
			
		||||
        </el-table-column>
 | 
			
		||||
        <el-table-column label="录入时间" align="center" prop="createTime" />
 | 
			
		||||
        <el-table-column label="录入人" align="center" prop="creatorName" />
 | 
			
		||||
        <el-table-column label="备注" align="center" prop="remark" />
 | 
			
		||||
        <el-table-column label="操作" align="center" class-name="small-padding fixed-width">
 | 
			
		||||
          <template #default="scope">
 | 
			
		||||
            <el-space>
 | 
			
		||||
              <el-button link type="primary" icon="View" @click="handleShowDialog(scope.row)" v-hasPermi="['safety:safetyLog:query']">
 | 
			
		||||
                详情
 | 
			
		||||
              </el-button>
 | 
			
		||||
              <!-- <el-button link type="success" icon="Edit" @click="handleUpdate(scope.row)" v-hasPermi="['safety:safetyLog:edit']"> 修改 </el-button> -->
 | 
			
		||||
              <el-button link type="danger" icon="Delete" @click="handleDelete(scope.row)" v-hasPermi="['safety:safetyLog:remove']"> 删除 </el-button>
 | 
			
		||||
            </el-space>
 | 
			
		||||
          </template>
 | 
			
		||||
        </el-table-column>
 | 
			
		||||
      </el-table>
 | 
			
		||||
 | 
			
		||||
      <pagination v-show="total > 0" :total="total" v-model:page="queryParams.pageNum" v-model:limit="queryParams.pageSize" @pagination="getList" />
 | 
			
		||||
    </el-card>
 | 
			
		||||
    <!-- 添加或修改安全日志对话框 -->
 | 
			
		||||
    <el-dialog :title="dialog.title" v-model="dialog.visible" width="950px" append-to-body>
 | 
			
		||||
      <el-form ref="safetyLogFormRef" :model="form" :rules="rules" label-width="250px">
 | 
			
		||||
        <el-form-item label="发生日期" prop="dateOfOccurrence">
 | 
			
		||||
          <el-date-picker clearable v-model="form.dateOfOccurrence" type="date" value-format="YYYY-MM-DD" placeholder="请选择发生日期">
 | 
			
		||||
          </el-date-picker>
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
        <el-form-item label="最高气温" prop="airTemperatureMax">
 | 
			
		||||
          <el-input v-model="form.airTemperatureMax" placeholder="请输入最高气温" />
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
        <el-form-item label="最低气温" prop="airTemperatureMin">
 | 
			
		||||
          <el-input v-model="form.airTemperatureMin" placeholder="请输入最低气温" />
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
        <el-form-item label="气候" prop="weather">
 | 
			
		||||
          <el-select v-model="form.weather" placeholder="请选择气候">
 | 
			
		||||
            <el-option v-for="dict in weather_type" :key="dict.value" :label="dict.label" :value="dict.value"></el-option>
 | 
			
		||||
          </el-select>
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
        <el-form-item label="工程施工部位及施工进展情况" prop="progress">
 | 
			
		||||
          <el-input v-model="form.progress" type="textarea" placeholder="请输入内容" />
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
        <el-form-item label="当日主要危险性项目作业内容">
 | 
			
		||||
          <editor v-model="form.jobContent" :min-height="192" />
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
        <el-form-item label="施工项目安全教育与安全交底情况">
 | 
			
		||||
          <editor v-model="form.discloseCondition" :min-height="192" />
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
        <el-form-item label="施工作业队伍班前施工安全活动情况">
 | 
			
		||||
          <editor v-model="form.activityCondition" :min-height="192" />
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
        <el-form-item label="现场施工安全巡视与检查情况">
 | 
			
		||||
          <editor v-model="form.examineCondition" :min-height="192" />
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
        <el-form-item label="季节施工防寒、防暑等措施实施情况">
 | 
			
		||||
          <editor v-model="form.implementCondition" :min-height="192" />
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
        <el-form-item label="监理通知有关部门安全检查情况">
 | 
			
		||||
          <editor v-model="form.safetyInspectionCondition" :min-height="192" />
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
        <el-form-item label="停工、加班情况">
 | 
			
		||||
          <editor v-model="form.stoppageOrOvertime" :min-height="192" />
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
        <el-form-item label="其他应记录的安全与文明施工事项">
 | 
			
		||||
          <editor v-model="form.otherCondition" :min-height="192" />
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
        <el-form-item label="附件" prop="fileId">
 | 
			
		||||
          <file-upload v-model="form.fileId" />
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
        <el-form-item label="备注" prop="remark">
 | 
			
		||||
          <el-input v-model="form.remark" type="textarea" placeholder="请输入内容" />
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
      </el-form>
 | 
			
		||||
      <template #footer>
 | 
			
		||||
        <div class="dialog-footer">
 | 
			
		||||
          <el-button :loading="buttonLoading" type="primary" @click="submitForm">确 定</el-button>
 | 
			
		||||
          <el-button @click="cancel">取 消</el-button>
 | 
			
		||||
        </div>
 | 
			
		||||
      </template>
 | 
			
		||||
    </el-dialog>
 | 
			
		||||
    <el-dialog title="安全日志详情" v-model="showDetailDialog">
 | 
			
		||||
      <safety-log-detail-dialog :safety-log-id="currentSafetyLogId" />
 | 
			
		||||
    </el-dialog>
 | 
			
		||||
  </div>
 | 
			
		||||
</template>
 | 
			
		||||
 | 
			
		||||
<script setup name="SafetyLog" lang="ts">
 | 
			
		||||
import { addSafetyLog, delSafetyLog, getSafetyLog, listSafetyLog, updateSafetyLog } from '@/api/safety/safetyLog';
 | 
			
		||||
import { SafetyLogForm, SafetyLogQuery, SafetyLogVO } from '@/api/safety/safetyLog/types';
 | 
			
		||||
import { useUserStoreHook } from '@/store/modules/user';
 | 
			
		||||
import dayjs from 'dayjs';
 | 
			
		||||
import SafetyLogDetailDialog from '@/views/safety/safetyLog/component/SafetyLogDetailDialog.vue';
 | 
			
		||||
 | 
			
		||||
const { proxy } = getCurrentInstance() as ComponentInternalInstance;
 | 
			
		||||
const { weather_type } = toRefs<any>(proxy?.useDict('weather_type'));
 | 
			
		||||
// 获取用户 store
 | 
			
		||||
const userStore = useUserStoreHook();
 | 
			
		||||
// 从 store 中获取项目列表和当前选中的项目
 | 
			
		||||
const currentProject = computed(() => userStore.selectedProject);
 | 
			
		||||
const safetyLogList = ref<SafetyLogVO[]>([]);
 | 
			
		||||
const buttonLoading = ref(false);
 | 
			
		||||
const loading = ref(true);
 | 
			
		||||
const showSearch = ref(true);
 | 
			
		||||
const ids = ref<Array<string | number>>([]);
 | 
			
		||||
const single = ref(true);
 | 
			
		||||
const multiple = ref(true);
 | 
			
		||||
const total = ref(0);
 | 
			
		||||
const queryFormRef = ref<ElFormInstance>();
 | 
			
		||||
const safetyLogFormRef = ref<ElFormInstance>();
 | 
			
		||||
 | 
			
		||||
const dialog = reactive<DialogOption>({
 | 
			
		||||
  visible: false,
 | 
			
		||||
  title: ''
 | 
			
		||||
});
 | 
			
		||||
 | 
			
		||||
const initFormData: SafetyLogForm = {
 | 
			
		||||
  id: undefined,
 | 
			
		||||
  projectId: currentProject.value.id,
 | 
			
		||||
  dateOfOccurrence: undefined,
 | 
			
		||||
  airTemperatureMax: undefined,
 | 
			
		||||
  airTemperatureMin: undefined,
 | 
			
		||||
  weather: undefined,
 | 
			
		||||
  progress: undefined,
 | 
			
		||||
  jobContent: undefined,
 | 
			
		||||
  discloseCondition: undefined,
 | 
			
		||||
  activityCondition: undefined,
 | 
			
		||||
  examineCondition: undefined,
 | 
			
		||||
  implementCondition: undefined,
 | 
			
		||||
  safetyInspectionCondition: undefined,
 | 
			
		||||
  stoppageOrOvertime: undefined,
 | 
			
		||||
  otherCondition: undefined,
 | 
			
		||||
  fileId: undefined,
 | 
			
		||||
  creatorName: undefined,
 | 
			
		||||
  remark: undefined
 | 
			
		||||
};
 | 
			
		||||
const data = reactive<PageData<SafetyLogForm, SafetyLogQuery>>({
 | 
			
		||||
  form: { ...initFormData },
 | 
			
		||||
  queryParams: {
 | 
			
		||||
    pageNum: 1,
 | 
			
		||||
    pageSize: 10,
 | 
			
		||||
    projectId: currentProject.value.id,
 | 
			
		||||
    dateOfOccurrence: undefined,
 | 
			
		||||
    airTemperatureMax: undefined,
 | 
			
		||||
    airTemperatureMin: undefined,
 | 
			
		||||
    weather: undefined,
 | 
			
		||||
    progress: undefined,
 | 
			
		||||
    jobContent: undefined,
 | 
			
		||||
    discloseCondition: undefined,
 | 
			
		||||
    activityCondition: undefined,
 | 
			
		||||
    examineCondition: undefined,
 | 
			
		||||
    implementCondition: undefined,
 | 
			
		||||
    safetyInspectionCondition: undefined,
 | 
			
		||||
    stoppageOrOvertime: undefined,
 | 
			
		||||
    otherCondition: undefined,
 | 
			
		||||
    remark: undefined,
 | 
			
		||||
    creatorName: undefined,
 | 
			
		||||
    params: {}
 | 
			
		||||
  },
 | 
			
		||||
  rules: {
 | 
			
		||||
    id: [{ required: true, message: '主键id不能为空', trigger: 'blur' }],
 | 
			
		||||
    projectId: [{ required: true, message: '项目id不能为空', trigger: 'blur' }]
 | 
			
		||||
  }
 | 
			
		||||
});
 | 
			
		||||
 | 
			
		||||
const { queryParams, form, rules } = toRefs(data);
 | 
			
		||||
 | 
			
		||||
/** 查询安全日志列表 */
 | 
			
		||||
const getList = async () => {
 | 
			
		||||
  loading.value = true;
 | 
			
		||||
  const res = await listSafetyLog(queryParams.value);
 | 
			
		||||
  safetyLogList.value = res.rows;
 | 
			
		||||
  total.value = res.total;
 | 
			
		||||
  loading.value = false;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
/** 取消按钮 */
 | 
			
		||||
const cancel = () => {
 | 
			
		||||
  reset();
 | 
			
		||||
  dialog.visible = false;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
/** 表单重置 */
 | 
			
		||||
const reset = () => {
 | 
			
		||||
  form.value = { ...initFormData };
 | 
			
		||||
  safetyLogFormRef.value?.resetFields();
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
/** 搜索按钮操作 */
 | 
			
		||||
const handleQuery = () => {
 | 
			
		||||
  queryParams.value.pageNum = 1;
 | 
			
		||||
  getList();
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
/** 重置按钮操作 */
 | 
			
		||||
const resetQuery = () => {
 | 
			
		||||
  queryFormRef.value?.resetFields();
 | 
			
		||||
  handleQuery();
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
/** 多选框选中数据 */
 | 
			
		||||
const handleSelectionChange = (selection: SafetyLogVO[]) => {
 | 
			
		||||
  ids.value = selection.map((item) => item.id);
 | 
			
		||||
  single.value = selection.length != 1;
 | 
			
		||||
  multiple.value = !selection.length;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
/** 展开安全日志详情对话框操作 */
 | 
			
		||||
const currentSafetyLogId = ref<string | number>();
 | 
			
		||||
const showDetailDialog = ref<boolean>(false);
 | 
			
		||||
const handleShowDialog = (row?: SafetyLogVO) => {
 | 
			
		||||
  currentSafetyLogId.value = row.id;
 | 
			
		||||
  showDetailDialog.value = true;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
/** 新增按钮操作 */
 | 
			
		||||
const handleAdd = () => {
 | 
			
		||||
  reset();
 | 
			
		||||
  dialog.visible = true;
 | 
			
		||||
  dialog.title = '添加安全日志';
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
/** 修改按钮操作 */
 | 
			
		||||
const handleUpdate = async (row?: SafetyLogVO) => {
 | 
			
		||||
  reset();
 | 
			
		||||
  const _id = row?.id || ids.value[0];
 | 
			
		||||
  const res = await getSafetyLog(_id);
 | 
			
		||||
  Object.assign(form.value, res.data);
 | 
			
		||||
  dialog.visible = true;
 | 
			
		||||
  dialog.title = '修改安全日志';
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
/** 提交按钮 */
 | 
			
		||||
const submitForm = () => {
 | 
			
		||||
  safetyLogFormRef.value?.validate(async (valid: boolean) => {
 | 
			
		||||
    if (valid) {
 | 
			
		||||
      buttonLoading.value = true;
 | 
			
		||||
      form.value.projectId = currentProject.value.id;
 | 
			
		||||
      if (form.value.id) {
 | 
			
		||||
        await updateSafetyLog(form.value).finally(() => (buttonLoading.value = false));
 | 
			
		||||
      } else {
 | 
			
		||||
        await addSafetyLog(form.value).finally(() => (buttonLoading.value = false));
 | 
			
		||||
      }
 | 
			
		||||
      proxy?.$modal.msgSuccess('操作成功');
 | 
			
		||||
      dialog.visible = false;
 | 
			
		||||
      await getList();
 | 
			
		||||
    }
 | 
			
		||||
  });
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
/** 删除按钮操作 */
 | 
			
		||||
const handleDelete = async (row?: SafetyLogVO) => {
 | 
			
		||||
  const _ids = row?.id || ids.value;
 | 
			
		||||
  await proxy?.$modal.confirm('是否确认删除安全日志编号为"' + _ids + '"的数据项?').finally(() => (loading.value = false));
 | 
			
		||||
  await delSafetyLog(_ids);
 | 
			
		||||
  proxy?.$modal.msgSuccess('删除成功');
 | 
			
		||||
  await getList();
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
/** 导出按钮操作 */
 | 
			
		||||
const handleExport = () => {
 | 
			
		||||
  proxy?.download(
 | 
			
		||||
    'safety/safetyLog/export',
 | 
			
		||||
    {
 | 
			
		||||
      ...queryParams.value
 | 
			
		||||
    },
 | 
			
		||||
    `safetyLog_${new Date().getTime()}.xlsx`
 | 
			
		||||
  );
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
//监听项目id刷新数据
 | 
			
		||||
const listeningProject = watch(
 | 
			
		||||
  () => currentProject.value.id,
 | 
			
		||||
  (nid, oid) => {
 | 
			
		||||
    queryParams.value.projectId = nid;
 | 
			
		||||
    form.value.projectId = nid;
 | 
			
		||||
    getList();
 | 
			
		||||
  }
 | 
			
		||||
);
 | 
			
		||||
 | 
			
		||||
onUnmounted(() => {
 | 
			
		||||
  listeningProject();
 | 
			
		||||
});
 | 
			
		||||
 | 
			
		||||
onMounted(() => {
 | 
			
		||||
  getList();
 | 
			
		||||
});
 | 
			
		||||
</script>
 | 
			
		||||
		Reference in New Issue
	
	Block a user