create.vue 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. <template>
  2. <div class="app-container">
  3. <!-- 对话框(添加 / 修改) -->
  4. <el-form ref="form" :model="form" :rules="rules" label-width="80px">
  5. <el-form-item label="开始时间" prop="startTime">
  6. <el-date-picker clearable size="small" v-model="form.startTime" type="date" value-format="timestamp" placeholder="选择开始时间" />
  7. </el-form-item>
  8. <el-form-item label="结束时间" prop="endTime">
  9. <el-date-picker clearable size="small" v-model="form.endTime" type="date" value-format="timestamp" placeholder="选择结束时间" />
  10. </el-form-item>
  11. <el-form-item label="请假类型" prop="type">
  12. <el-select v-model="form.type" placeholder="请选择">
  13. <el-option v-for="dict in typeDictData" :key="parseInt(dict.value)" :label="dict.label" :value="parseInt(dict.value)"/>
  14. </el-select>
  15. </el-form-item>
  16. <el-form-item label="原因" prop="reason">
  17. <el-col :span="10">
  18. <el-input type="textarea" :rows="3" v-model="form.reason" placeholder="请输入原因" />
  19. </el-col>
  20. </el-form-item>
  21. <el-form-item>
  22. <el-button type="primary" @click="submitForm">提 交</el-button>
  23. </el-form-item>
  24. </el-form>
  25. </div>
  26. </template>
  27. <script>
  28. import { createLeave} from "@/api/bpm/leave"
  29. import { getDictDatas, DICT_TYPE } from '@/utils/dict'
  30. export default {
  31. name: "BpmOALeaveCreate",
  32. components: {
  33. },
  34. data() {
  35. return {
  36. // 表单参数
  37. form: {
  38. startTime: undefined,
  39. endTime: undefined,
  40. type: undefined,
  41. reason: undefined,
  42. },
  43. // 表单校验
  44. rules: {
  45. startTime: [{ required: true, message: "开始时间不能为空", trigger: "blur" }],
  46. endTime: [{ required: true, message: "结束时间不能为空", trigger: "blur" }],
  47. type: [{ required: true, message: "请假类型不能为空", trigger: "change" }],
  48. reason: [{ required: true, message: "请假原因不能为空", trigger: "change" }],
  49. },
  50. typeDictData: getDictDatas(DICT_TYPE.BPM_OA_LEAVE_TYPE),
  51. };
  52. },
  53. created() {
  54. },
  55. methods: {
  56. /** 提交按钮 */
  57. submitForm() {
  58. this.$refs["form"].validate(valid => {
  59. if (!valid) {
  60. return;
  61. }
  62. // 添加的提交
  63. createLeave(this.form).then(response => {
  64. this.$modal.msgSuccess("发起成功");
  65. this.$tab.closeOpenPage({ path: "/bpm/oa/leave" });
  66. });
  67. });
  68. }
  69. }
  70. };
  71. </script>