MyLeave.vue 9.4 KB

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