123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752 |
- <script setup lang="ts">
- defineOptions({
- name: "evaluateChangeManageObject"
- });
- import { getState, getStateType, assessmentStatus } from "@/config/tag";
- import { ref, reactive, onMounted } from "vue";
- import {
- getAssessmentQuotaDetails,
- delAssessmentObject,
- getAssessmentObjectDetails,
- postAddAssessmentObject,
- updateAssessmentQuotaDetails
- } from "@/api/assessment";
- import { getTemplateInfoList } from "@/api/templateInfo";
- import { useRouter } from "vue-router";
- import { ElMessage, ElMessageBox } from "element-plus";
- import {
- treeDept,
- postListTreeWithUserApi,
- postListTree
- } from "@/api/department";
- import { Search } from "@element-plus/icons-vue";
- import messagePerson from "./message.vue";
- import dayjs from "dayjs";
- import {
- postUserList,
- postOrganizationUserPage,
- getLeaderList
- } from "@/api/userSetting";
- import { postPageGroup } from "@/api/userGroup";
- const $props = defineProps({
- message: {
- type: Object
- }
- });
- const valSelection = ref(false);
- const messageData = ref({});
- const initParams = reactive({
- params: {
- pageNumber: 1,
- pageSize: 10,
- userName: "",
- modelName: "",
- quotaName: "",
- assessmentId: "",
- orderField: "",
- orderType: ""
- },
- objParams: {
- pageNumber: 1,
- pageSize: 10,
- userName: "",
- modelName: "",
- quotaName: "",
- assessmentId: "",
- orderField: "",
- orderType: ""
- },
- indexParams: {
- pageNumber: 1,
- pageSize: 10,
- userName: "",
- modelName: "",
- quotaName: "",
- assessmentId: "",
- orderField: "",
- orderType: ""
- },
- tmpParams: {
- page: 1,
- pageSize: 100
- },
- total: 0,
- total1: 0,
- list: [],
- Indexlist: [],
- tmpList: []
- });
- const state = reactive({
- tableType: 0
- });
- const convertDepartmentDataRecursive_Person = data => {
- return data.map(department => {
- const { userNameNew, userCodeNew, children } = department;
- return {
- value: userCodeNew,
- label: userNameNew,
- children:
- children.length > 0
- ? children.map(
- child => convertDepartmentDataRecursive_Person([child])[0]
- )
- : []
- };
- });
- };
- const convertDepartmentDataRecursive = data => {
- return data.map(department => {
- const { deptCode, deptName, childrenRes } = department;
- return {
- value: deptCode,
- label: deptName,
- children:
- childrenRes.length > 0
- ? childrenRes.map(child => convertDepartmentDataRecursive([child])[0])
- : []
- };
- });
- };
- const dpetTree = ref([]);
- onMounted(() => {
- Object.assign(messageData.value, $props.message);
- switch (messageData.value.assessmentType) {
- case 0:
- initParams.assessmentType = "员工";
- break;
- case 1:
- initParams.assessmentType = "部门";
- break;
- case 2:
- initParams.assessmentType = "医疗组";
- break;
- case 3:
- initParams.assessmentType = "员工";
- }
- assessmentTypeApi(messageData.value.assessmentType);
- initParams.params.assessmentId = $props.message.id;
- initParams.objParams.assessmentId = $props.message.id;
- initParams.indexParams.assessmentId = $props.message.id;
- state.tableType = $props.message.assessmentType;
- getAssessmentQuotaDetailsApi();
- getTemplateInfoListApi();
- getAssessmentObjectDetailsApi();
- });
- const treeDeptList = ref([]);
- const assessmentTypeApi = async value => {
- switch (value) {
- case 0:
- postListTreeWithUserApi();
- break;
- case 1:
- const { data, code } = await postListTree();
- dpetTree.value = convertDepartmentDataRecursive(data);
- break;
- case 2:
- const yiliao = await postPageGroup({
- pageNumber: 1,
- pageSize: 1000
- });
- treeDeptList.value = yiliao.data.records;
- break;
- case 3:
- const fuzhere = await getLeaderList();
- console.log(fuzhere);
- treeDeptList.value = fuzhere.data;
- }
- };
- const getAssessmentQuotaDetailsApi = async () => {
- const res = await getAssessmentQuotaDetails(initParams.indexParams);
- if (res.code === 200) {
- console.log("指标分页查询", res);
- initParams.Indexlist = res.data.records;
- initParams.total1 = res.data.totalRow;
- }
- };
- const getTemplateInfoListApi = async () => {
- const { data, code } = await getTemplateInfoList(initParams.params);
- if (code == 200) {
- initParams.tmpList = data.records;
- }
- };
- const delParams = reactive({
- assessmentId: "",
- objectAddVoList: []
- });
- const addPersonParams = reactive({
- assessmentId: "",
- objectAddVoList: []
- });
- const value1 = ref();
- const delAssessmentObjectApi = async () => {
- if (valSelection.value) {
- ElMessageBox.confirm(
- "该员工考核删除后不可恢复,请谨慎操作!",
- "确定删除该员工考核吗?",
- {
- confirmButtonText: "确定",
- cancelButtonText: "取消",
- type: "warning"
- }
- ).then(async () => {
- const { code, msg } = await delAssessmentObject(delParams);
- if (code === 200) {
- getAssessmentObjectDetailsApi();
- ElMessage.success("删除成功");
- } else {
- ElMessage.error(msg);
- }
- });
- } else {
- ElMessage.warning("请选择要删除的考核对象");
- }
- };
- const changeSelection = val => {
- if (val) {
- valSelection.value = true;
- delParams.objectAddVoList = [];
- delParams.assessmentId = messageData.value.id;
- addPersonParams.assessmentId = messageData.value.id;
- let assessmentObjectId;
- let assessmentObjectName;
- val.forEach((item, index) => {
- const obj = {
- assessmentObjectId: item.assessmentObjectId,
- assessmentObjectName: item.assessmentObjectName
- };
-
-
-
-
- delParams.objectAddVoList.push(obj);
-
-
- });
- }
- };
- const router = useRouter();
- const activeName = ref("first");
- const addsImport = () => {
- router.push({ name: "importIndex", query: { ...messageData.value } });
- };
- const publishShow = ref(true);
- const publish = () => {
- publishShow.value = false;
- ElMessage({
- message: "成功",
- type: "success"
- });
- };
- const dialogVisibleAdd = ref(false);
- const assessmentTypeRef = ref();
- const transformArrayFormat = data => {
- return data.assessmentObjectId
- .map((item, index) => {
- return {
- assessmentObjectId: item,
- assessmentObjectName: data.assessmentObjectName[index]
- };
- })
- .flat();
- };
- const handleRreeSelect = data => {
- const list = ref({});
- const arr = assessmentTypeRef.value.getCheckedNodes().filter(item => {
- return item.children.length == 0;
- });
- list.value.assessmentObjectId = arr.map(item => item.value);
- list.value.assessmentObjectName = arr.map(item => item.label);
- addPersonParams.objectAddVoList = transformArrayFormat(list);
- };
- const handChange = () => {
- const list = ref({});
- const arr = treeDeptList.value.filter(item => {
- return value1.value.includes(item.groupCode);
- });
- list.value.assessmentObjectId = arr.map(item => item.groupCode);
- list.value.assessmentObjectName = arr.map(item => item.groupName);
- addPersonParams.objectAddVoList = transformArrayFormat(list);
- };
- const dialogVisibleAddShow = () => {
- dialogVisibleAdd.value = true;
- };
- const GoView = row => {
- console.log(row, "路由跳转信息展示", messageData.value);
- const arr = {
- "0": "/draw/children/worker/workerDrak",
- "1": "/draw/children/department/departmentDrank",
- "2": "/draw/children/health/healthDrank",
- "3": "/draw/children/head/headDrank"
- };
- for (let key in arr) {
- if ($props.message.assessmentType == key) {
- router.push({
- path: arr[key],
- query: {
- assessmentId: messageData.value.id,
- assessmentModelId: row.assessmentModelId,
- assessmentObjectId: row.assessmentObjectId,
- assessmentName: row.assessmentModelName,
- assessmentModelName: row.assessmentModelName,
- assessmentName: messageData.value.name,
- assessmentObjectName: row.assessmentObjectName
- }
- });
- return;
- }
- }
- };
- const objList = ref([]);
- const getAssessmentObjectDetailsApi = async () => {
- const { data, msg, code } = await getAssessmentObjectDetails(
- initParams.objParams
- );
- if (code === 200) {
- objList.value = data.records;
- initParams.total = data.totalRow;
- }
- };
- const handleSizeChange = (val: number) => {
- initParams.objParams.pageSize = val;
- getAssessmentObjectDetailsApi();
- };
- const handleCurrentChange = (val: number) => {
- initParams.objParams.pageNumber = val;
- getAssessmentObjectDetailsApi();
- };
- const handleSizeIndexChange = (val: number) => {
- initParams.indexParams.pageSize = val;
- getAssessmentQuotaDetailsApi();
- };
- const handleCurrentIndexChange = (val: number) => {
- initParams.indexParams.pageNumber = val;
- getAssessmentQuotaDetailsApi();
- };
- const updateAssessmentQuotaDetailsApi = async row => {
- const { msg, code } = await updateAssessmentQuotaDetails({
- relationId: row.relationId,
- id: row.id,
- dimId: row.dimId,
- assessmentObjectId: row.assessmentObjectId,
- assessmentModelId: row.assessmentModelId,
- score: row.score,
- finalValue: row.finalValue,
- assessmentId: messageData.value.id
- });
- if (code === 200) {
- ElMessage.success("修改成功");
- } else {
- ElMessage.error(msg);
- }
- };
- const tableVxeRef = ref();
- const editConfig = ref({
- trigger: "click",
- mode: "cell"
- });
- const editClosedEvent = ({ row, column }) => {
- const $table = tableVxeRef.value;
- if ($table) {
- console.log(111);
- updateAssessmentQuotaDetailsApi(row);
-
-
- }
- };
- const closePerson = () => {
- Object.assign(addPersonParams, {
- assessmentId: "",
- objectAddVoList: []
- });
- value1.value = [];
- dialogVisibleAdd.value = false;
- };
- const addPerson = async () => {
- addPersonParams.assessmentId = $props.message.id;
- const { data, msg, code } = await postAddAssessmentObject(addPersonParams);
- if (code === 200) {
- ElMessage.success("添加成功");
- dialogVisibleAdd.value = false;
- getAssessmentObjectDetailsApi();
- closePerson();
- }
- };
- const changTitle = () => {
- const obj = {
- 0: "添加被考核人",
- 1: "添加被考核科室",
- 2: "添加被考核医疗组",
- 3: "添加被考核部门负责人"
- };
- return obj[$props.message.assessmentType];
- };
- </script>
- <template>
- <div class="w-full">
- <div class="w-full flex items-center justify-between">
- <div class="flex items-center justify-between mt-2">
- <div class="bg-icon">
- <div>
- <el-icon>
- <Tickets />
- </el-icon>
- </div>
- </div>
- <div>
- <div class="flex items-center justify-between">
- <h5>{{ messageData.name }}</h5>
- <el-tag :type="getStateType(messageData.assessmentStatus)">
- {{ assessmentStatus(messageData.assessmentStatus) }}
- </el-tag>
- </div>
- <el-text type="info" class="text-xs">
- {{ messageData.cycleValue }}
- </el-text>
- </div>
- </div>
- <div class="mr-10">
- <Auth :value="['公布考核结果']">
- <el-button v-if="publishShow" type="primary" @click="publish"
- >公布考核结果</el-button
- >
- </Auth>
- </div>
- </div>
- <el-tabs v-model="activeName" class="demo-tabs">
- <el-tab-pane label="考核对象" name="first">
- <div class="w-full flex items-center justify-between">
- <div class="w-1/2 flex items-center justify-between">
- <el-text class="w-1/5">考核模板</el-text>
- <el-select
- v-model="initParams.objParams.modelName"
- placeholder="请选择"
- filterable
- clearable
- style="width: 250px"
- @change="getAssessmentObjectDetailsApi"
- >
- <el-option
- v-for="itemTmp in initParams.tmpList"
- :key="itemTmp.id"
- :label="itemTmp.tpName"
- :value="itemTmp.tpName"
- />
- </el-select>
- <el-input
- v-model="initParams.objParams.userName"
- class="ml-2"
- clearable
- placeholder="搜索人员"
- :prefix-icon="Search"
- @change="getAssessmentObjectDetailsApi"
- />
- </div>
- <div class="mr-10">
-
- <Auth :value="['批量删除']">
- <el-button type="primary" plain @click="delAssessmentObjectApi">
- 批量删除
- </el-button>
- </Auth>
- <Auth :value="['添加被考核人']">
- <el-button type="primary" plain @click="dialogVisibleAddShow">{{
- changTitle()
- }}</el-button>
- </Auth>
- </div>
- </div>
- <el-table
- :data="objList"
- style="width: 100%"
- @selection-change="changeSelection"
- >
- <el-table-column type="selection" width="55" />
- <el-table-column
- v-if="state.tableType == 0 || state.tableType == 3"
- prop="realName"
- label="人员"
- width="100"
- />
- <el-table-column
- v-if="state.tableType == 2"
- prop="assessmentObjectName"
- label="医疗组"
- width="100"
- />
- <el-table-column
- v-if="state.tableType == 0 || state.tableType == 3"
- prop="userName"
- label="工号"
- width="180"
- />
- <el-table-column
- v-if="state.tableType != 2"
- prop="deptName"
- label="科室"
- width="180"
- />
- <el-table-column
- prop="assessmentModelName"
- label="考核模板"
- width="300"
- />
- <el-table-column prop="name" label="更新时间" width="150" sortable>
- <template #default="{ row }">
- {{ dayjs(row.updateTime).format("YYYY-MM-DD HH:mm:ss") }}
- </template>
- </el-table-column>
- <el-table-column label="操作" width="200" fixed="right">
- <template #default="{ row }">
-
- <el-icon @click="GoView(row)">
- <View />
- </el-icon>
- </template>
- </el-table-column>
- </el-table>
- <div class="flex justify-between item-center">
- <div class="float-left mt-5 ml-2 total">
- {{ initParams.total }}
- </div>
- <div class="float-right mt-5 mr-8">
- <el-pagination
- v-model:current-page="initParams.objParams.pageNumber"
- v-model:page-size="initParams.objParams.pageSize"
- background
- layout="total, sizes, prev, pager, next, jumper"
- :total="initParams.total"
- @size-change="handleSizeChange"
- @current-change="handleCurrentChange"
- />
- </div>
- </div>
- </el-tab-pane>
- <el-tab-pane label="考核指标" name="second">
- <div class="w-full flex items-center justify-between">
- <div class="w-1/2 flex items-center justify-between">
- <el-text class="w-1/5">考核模板</el-text>
- <el-input
- v-model="initParams.indexParams.userName"
- class="ml-1"
- placeholder="搜索人员"
- @change="getAssessmentQuotaDetailsApi"
- />
- <el-input
- v-model="initParams.indexParams.quotaName"
- class="ml-2"
- placeholder="搜索指标名称"
- :prefix-icon="Search"
- @change="getAssessmentQuotaDetailsApi"
- />
- </div>
- <div class="mr-10">
- <Auth :value="['批量导入指标']">
- <el-button type="primary" plain @click="addsImport"
- >批量导入</el-button
- >
- </Auth>
- </div>
- </div>
- <vxe-table
- ref="tableVxeRef"
- class="mt-3"
- show-overflow
- :edit-config="editConfig"
- :data="initParams.Indexlist"
- @edit-closed="editClosedEvent"
- @selection-change="changeSelection"
- >
- <vxe-column type="checkbox" width="60" />
- <vxe-column field="realName" fixed title="人员" width="100" />
- <vxe-column field="userName" fixed title="工号" width="180" />
- <vxe-column field="deptName" fixed title="部门" width="180" />
- <vxe-column field="name" fixed title="指标名称" width="180" />
- <vxe-column field="scoreRule" fixed title="评价标准" width="180" />
- <vxe-column field="source" fixed title="数据来源" width="180" />
- <vxe-column field="targetValue" fixed title="目标值" width="180" />
- <vxe-column
- field="finalValue"
- fixed
- title="完成值"
- :edit-render="{ name: 'input' }"
- width="180"
- />
- <vxe-column
- field="score"
- fixed
- title="得分"
- :edit-render="{ name: 'input' }"
- width="180"
- />
- <vxe-column field="updateTime" title="更新时间" sortable width="180">
- <template #default="{ row }">
- {{ dayjs(row.updateTime).format("YYYY-MM-DD HH:mm:ss") }}
- </template>
- </vxe-column>
- <vxe-column field="updateTime" title="操作" fixed="right" width="180">
- <template #default> - </template>
- </vxe-column>
- </vxe-table>
-
- {{ dayjs(row.updateTime).format("YYYY-MM-DD HH:mm:ss") }}
- <div class="flex justify-between item-center">
- <div class="float-left mt-5 ml-2 total">
- {{ initParams.total1 }}
- </div>
- <div class="float-right mt-5 mr-8">
- <el-pagination
- v-model:current-page="initParams.indexParams.pageNumber"
- v-model:page-size="initParams.indexParams.pageSize"
- background
- layout="total, sizes, prev, pager, next, jumper"
- :total="initParams.total1"
- @size-change="handleSizeIndexChange"
- @current-change="handleCurrentIndexChange"
- />
- </div>
- </div>
- </el-tab-pane>
-
- <el-tab-pane label="基础信息" name="fourth">
-
- <messagePerson v-if="messageData.id" :id="messageData.id" />
- </el-tab-pane>
- </el-tabs>
-
- <el-dialog v-model="dialogVisibleAdd" :title="changTitle()" width="500">
- <div>
- <el-form
- ref="ruleFormRef"
- label-position="top"
- label-width="auto"
- :model="addPersonParams"
- >
- <el-form-item label="" label-position="top">
- <el-tree-select
- v-if="$props.message.assessmentType == 0"
- ref="assessmentTypeRef"
- v-model="value1"
- :data="convertDepartmentDataRecursive_Person(treeDept)"
- multiple
- :render-after-expand="false"
- show-checkbox
- style="width: 240px"
- @check-change="handleRreeSelect"
- />
- <el-tree-select
- v-if="$props.message.assessmentType == 1"
- ref="assessmentTypeRef"
- v-model="value1"
- :data="dpetTree"
- multiple
- :render-after-expand="false"
- show-checkbox
- style="width: 240px"
- @check-change="handleRreeSelect"
- />
- <el-select
- v-if="
- $props.message.assessmentType != 0 &&
- $props.message.assessmentType != 1
- "
- ref="selectRefs"
- v-model="value1"
- multiple
- @change="handChange"
- >
- <el-option
- v-for="(it, id) in treeDeptList"
- :key="id"
- :label="it.groupName"
- :value="it.groupCode"
- />
- </el-select>
- </el-form-item>
- </el-form>
- </div>
- <template #footer>
- <div class="dialog-footer w-full flex justify-between mt-4">
- <div>
- <el-button @click="closePerson">取消</el-button>
- <el-button type="primary" @click="addPerson"> 确认 </el-button>
- </div>
- </div>
- </template>
- </el-dialog>
- </div>
- </template>
- <style lang="scss" scoped>
- .bg-icon {
- display: flex;
- align-items: center;
- justify-content: center;
- width: 45px;
- height: 45px;
- margin-right: 5px;
- background: #00a870;
- border-radius: 5px;
- div {
- // border: 1px solid red;
- display: flex;
- align-items: center;
- justify-content: center;
- width: 60%;
- height: 60%;
- color: #00a870;
- background: #fff;
- border-radius: 2px;
- }
- }
- </style>
|