MyLeave.vue 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282
  1. <script setup lang="ts">
  2. import { ref, reactive, onMounted, nextTick } from 'vue'
  3. import { Leave_User_list, LeaveType_List, Leave_Add, Leave_Edit, Leave_Del } from '@/api/workAttendance/index'
  4. import { User_List } from '@/api/user/index'
  5. import TableBase from '@/components/TableBase/index.vue'
  6. import Drawer from '@/components/Drawer/index.vue'
  7. import Dialog from '@/components/dialog/Dialog.vue'
  8. import { ColumnProps } from '@/components/TableBase/interface/index'
  9. import { GlobalStore } from '@/stores/index'
  10. import { Edit, Delete } from '@element-plus/icons-vue'
  11. import type { FormInstance, FormRules } from 'element-plus'
  12. import { ElMessageBox, ElMessage } from 'element-plus'
  13. const globalStore = GlobalStore()
  14. const TableRef = ref()
  15. const columns: ColumnProps[] = [
  16. { prop: 'T_type_name', label: '请假类型' },
  17. { prop: 'T_start_time', label: '开始时间' },
  18. { prop: 'T_end_time', label: '结束时间' },
  19. { prop: 'T_duration', label: '请假时长', name: 'T_duration' },
  20. { prop: 'T_text', label: '理由' },
  21. { prop: 'T_State', label: '审核', name: 'T_State' },
  22. { prop: 'operation', label: '操作', width: 200, fixed: 'right' }
  23. ]
  24. const initParam = {
  25. User_tokey: globalStore.GET_User_tokey
  26. }
  27. //drawer
  28. const drawerRef = ref()
  29. const ruleFormRef = ref<FormInstance>()
  30. type Fn = () => void
  31. const callbackDrawer = (done: Fn) => {
  32. resetForm(ruleFormRef.value)
  33. done()
  34. }
  35. const resetForm = (formEl: FormInstance | undefined) => {
  36. if (!formEl) return
  37. formEl.resetFields()
  38. }
  39. const openDrawerLeave = (str: string, row: any) => {
  40. drawerRef.value.openDrawer()
  41. if (str === 'edit') {
  42. isNew = false
  43. nextTick(() => {
  44. form.value = { ...row }
  45. uuid = row.T_approver
  46. form.value.T_approver = row.T_user_name
  47. form.value.T_id = row.Id
  48. })
  49. }
  50. }
  51. const LeaveDelete = (row: any) => {
  52. ElMessageBox.confirm('您确定要删除请假申请吗?', '警告', {
  53. confirmButtonText: '确定',
  54. cancelButtonText: '取消',
  55. type: 'warning'
  56. })
  57. .then(async () => {
  58. const res: any = await Leave_Del({ User_tokey: globalStore.GET_User_tokey, T_id: row.Id })
  59. if (res.Code === 200) {
  60. ElMessage({
  61. type: 'success',
  62. message: '删除成功!'
  63. })
  64. nextTick(() => {
  65. TableRef.value.getTableList()
  66. })
  67. }
  68. })
  69. .catch(() => {
  70. ElMessage({
  71. type: 'warning',
  72. message: '取消成功!'
  73. })
  74. })
  75. }
  76. const AddLeave = (formEl: FormInstance | undefined) => {
  77. if (!formEl) return
  78. formEl.validate(async valid => {
  79. if (valid) {
  80. let res: any = {}
  81. form.value.T_duration = form.value.T_duration * 60
  82. if (isNew) {
  83. res = await Leave_Add({ ...form.value, T_approver: uuid })
  84. } else {
  85. res = await Leave_Edit({ ...form.value, T_approver: uuid })
  86. }
  87. if (res.Code === 200) {
  88. ElMessage({
  89. type: 'success',
  90. message: `${isNew ? '申请' : '修改'}成功!`
  91. })
  92. nextTick(() => {
  93. drawerRef.value.closeDrawer()
  94. TableRef.value.getTableList()
  95. resetForm(ruleFormRef.value)
  96. isNew = true
  97. })
  98. }
  99. } else {
  100. return false
  101. }
  102. })
  103. }
  104. const rules = reactive<FormRules>({
  105. T_type: [{ required: true, message: '请选择请假类型', trigger: 'blur' }],
  106. T_start_time: [{ required: true, message: '请选择开始时间', trigger: 'blur' }],
  107. T_end_time: [{ required: true, message: '请选择结束时间', trigger: 'blur' }],
  108. T_duration: [
  109. { required: true, message: '请输入请假时长', trigger: 'blur' },
  110. { type: 'number', message: '必须是整数' }
  111. ],
  112. T_approver: [{ required: true, message: '请选择审批人', trigger: 'blur' }]
  113. })
  114. let uuid = ''
  115. const form = ref({
  116. T_type: '',
  117. T_start_time: '',
  118. T_end_time: '',
  119. T_duration: 0,
  120. T_text: '',
  121. T_approver: '',
  122. T_id: ''
  123. })
  124. const LeaveType = ref<any>([])
  125. const getLeaveTypeList = async () => {
  126. const res: any = await LeaveType_List({ User_tokey: globalStore.GET_User_tokey, page: 1, page_z: 999 })
  127. if (res.Code === 200) {
  128. LeaveType.value = res.Data
  129. }
  130. }
  131. const formLabelWidth = ref('100px')
  132. let isNew = true
  133. const selectApprover = () => {
  134. dialog.value.DialogOpen()
  135. }
  136. // dialog
  137. const dialog = ref()
  138. const search = ref('')
  139. const tableApproverRef = ref()
  140. const Dialogcolumns: ColumnProps[] = [{ prop: 'T_name', label: '名字', name: 'T_name' }]
  141. const approverInitParam = {
  142. User_tokey: globalStore.GET_User_tokey,
  143. T_name: '',
  144. T_dept_leader: 1
  145. }
  146. const searchHandle = () => {
  147. approverInitParam.T_name = search.value
  148. tableApproverRef.value.searchTable()
  149. }
  150. const getApproverInfo = (row: any) => {
  151. uuid = row.T_uuid
  152. form.value.T_approver = row.T_name
  153. dialog.value.DialogClose()
  154. }
  155. const onResize = () => {
  156. const height = document.documentElement.clientHeight
  157. return height / 2
  158. }
  159. onMounted(() => {
  160. getLeaveTypeList()
  161. })
  162. </script>
  163. <template>
  164. <div>
  165. <TableBase ref="TableRef" :columns="columns" :requestApi="Leave_User_list" :initParam="initParam">
  166. <template #table-header>
  167. <el-row :gutter="24" class="input-suffix">
  168. <el-col :span="8" :offset="16" class="d-flex padding-right-0">
  169. <el-button type="primary" @click="openDrawerLeave">请假申请</el-button>
  170. </el-col>
  171. </el-row>
  172. </template>
  173. <template #T_State="{ row }">
  174. <el-tag v-if="row.T_State === 1" type="success">通过</el-tag>
  175. <el-tag v-else-if="row.T_State === 2" type="warning">未通过</el-tag>
  176. <el-tag v-else type="danger">待审核</el-tag>
  177. </template>
  178. <template #T_duration="{ row }">
  179. <el-tag effect="dark"> {{ row.T_duration }}分钟 </el-tag>
  180. </template>
  181. <template #right="{ row }">
  182. <el-button link type="primary" size="small" :icon="Edit" @click="openDrawerLeave('edit', row)">编辑</el-button>
  183. <el-button link type="danger" size="small" :icon="Delete" @click="LeaveDelete(row)">删除</el-button>
  184. </template>
  185. </TableBase>
  186. <Drawer ref="drawerRef" :handleClose="callbackDrawer">
  187. <template #header="{ params }">
  188. <h4 :id="params.titleId" :class="params.titleClass">{{ isNew ? '添加' : '编辑' }} - 角色</h4>
  189. </template>
  190. <el-form ref="ruleFormRef" :model="form" :rules="rules">
  191. <el-form-item label="请假类型:" :label-width="formLabelWidth" prop="T_type">
  192. <el-select v-model="form.T_type" placeholder="请选择类型">
  193. <el-option v-for="item in LeaveType" :key="item.Id" :label="item.T_name" :value="item.Id" />
  194. </el-select>
  195. </el-form-item>
  196. <el-form-item label="开始时间:" :label-width="formLabelWidth" prop="T_start_time">
  197. <el-date-picker
  198. style="width: 100%"
  199. class="my-date-picker"
  200. v-model="form.T_start_time"
  201. type="datetime"
  202. placeholder="选择开始时间"
  203. format="YYYY-MM-DD hh:mm:ss"
  204. value-format="YYYY-MM-DD hh:mm:ss"
  205. />
  206. </el-form-item>
  207. <el-form-item label="结束时间:" :label-width="formLabelWidth" prop="T_end_time">
  208. <el-date-picker
  209. style="width: 100%"
  210. class="my-date-picker"
  211. v-model="form.T_end_time"
  212. type="datetime"
  213. placeholder="选择结束时间"
  214. format="YYYY-MM-DD hh:mm:ss"
  215. value-format="YYYY-MM-DD hh:mm:ss"
  216. />
  217. </el-form-item>
  218. <el-form-item label="请假时长:" :label-width="formLabelWidth" prop="T_duration">
  219. <el-input v-model.number="form.T_duration" autocomplete="off" placeholder="请假时长" />
  220. </el-form-item>
  221. <el-form-item label="内容:" :label-width="formLabelWidth">
  222. <el-input
  223. v-model="form.T_text"
  224. autocomplete="off"
  225. type="textarea"
  226. :autosize="{ minRows: 4, maxRows: 6 }"
  227. placeholder="请输入内容"
  228. />
  229. </el-form-item>
  230. <el-form-item label="审批:" :label-width="formLabelWidth" prop="T_approver">
  231. <el-input v-model="form.T_approver" autocomplete="off" placeholder="审批人" @focus="selectApprover" />
  232. </el-form-item>
  233. <el-form-item :label-width="formLabelWidth">
  234. <el-button v-if="isNew" color="#626aef" @click="AddLeave(ruleFormRef)">添加</el-button>
  235. <el-button v-else color="#626aef" @click="AddLeave(ruleFormRef)">修改</el-button>
  236. </el-form-item>
  237. </el-form>
  238. </Drawer>
  239. <Dialog ref="dialog" width="30%">
  240. <template #header>
  241. <h3>选择审批人</h3>
  242. </template>
  243. <TableBase
  244. ref="tableApproverRef"
  245. :columns="Dialogcolumns"
  246. :initParam="approverInitParam"
  247. :requestApi="User_List"
  248. layout="total, prev, pager, next"
  249. :onResize="onResize"
  250. >
  251. <template #table-header>
  252. <el-row :gutter="20">
  253. <el-col :span="20" class="d-flex">
  254. <span class="inline-flex">账户查询:</span>
  255. <el-input v-model="search" type="text" class="w-50 m-2" />
  256. <el-button type="primary" @click="searchHandle">搜索</el-button>
  257. </el-col>
  258. </el-row>
  259. </template>
  260. <template #T_name="{ row }">
  261. <el-button type="primary" link @click="getApproverInfo(row)">{{ row.T_name }}</el-button>
  262. </template>
  263. </TableBase>
  264. </Dialog>
  265. </div>
  266. </template>
  267. <style scoped lang="scss">
  268. .input-suffix {
  269. width: 100%;
  270. }
  271. .inline-flex {
  272. white-space: nowrap;
  273. }
  274. .d-flex {
  275. display: flex;
  276. align-items: center;
  277. }
  278. </style>