UserContractModal.vue 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216
  1. <template>
  2. <j-modal
  3. :title="title"
  4. :width="800"
  5. :visible="visible"
  6. :confirmLoading="confirmLoading"
  7. switchFullscreen
  8. @ok="handleOk"
  9. @cancel="handleCancel"
  10. cancelText="关闭">
  11. <a-spin :spinning="confirmLoading">
  12. <a-form :form="form">
  13. <a-form-item
  14. :labelCol="labelCol"
  15. :wrapperCol="wrapperCol"
  16. label="员工姓名">
  17. <j-select-user-by-dep v-decorator="['userId', validatorRules.realname]"/>
  18. </a-form-item>
  19. <a-form-item
  20. :labelCol="labelCol"
  21. :wrapperCol="wrapperCol"
  22. label="部门名称">
  23. <a-input :disabled="true" placeholder="请输入部门名称" v-decorator="['deptNames', validatorRules.deptname ]" />
  24. </a-form-item>
  25. <a-form-item
  26. <a-form-item
  27. :labelCol="labelCol"
  28. :wrapperCol="wrapperCol"
  29. label="合同类型">
  30. <j-dict-select-tag v-decorator="['contractType', validatorRules.type]" :triggerChange="true" placeholder="请选择合同类型"
  31. dictCode="contract_type" />
  32. </a-form-item>
  33. <a-form-item
  34. :labelCol="labelCol"
  35. :wrapperCol="wrapperCol"
  36. label="开始时间">
  37. <a-date-picker showTime format='YYYY-MM-DD' v-decorator="[ 'startDate', validatorRules.startDate]" />
  38. </a-form-item>
  39. <a-form-item
  40. :labelCol="labelCol"
  41. :wrapperCol="wrapperCol"
  42. label="结束时间">
  43. <a-date-picker showTime format='YYYY-MM-DD' v-decorator="[ 'endDate', validatorRules.endDate]" />
  44. </a-form-item>
  45. </a-form>
  46. </a-spin>
  47. </j-modal>
  48. </template>
  49. <script>
  50. import { httpAction,getAction } from '@/api/manage'
  51. import pick from 'lodash.pick'
  52. import moment from "moment"
  53. import JSelectMultiUser from '@/components/jeecgbiz/JSelectMultiUser'
  54. import JSelectUserByDep from '@/components/jeecgbiz/JSelectUserByDep'
  55. export default {
  56. name: "UserContractModal",
  57. components: {JSelectMultiUser,JSelectUserByDep},
  58. data () {
  59. return {
  60. title:"操作",
  61. visible: false,
  62. model: {},
  63. userid:"",
  64. deptid:"",
  65. labelCol: {
  66. xs: { span: 24 },
  67. sm: { span: 5 },
  68. },
  69. wrapperCol: {
  70. xs: { span: 24 },
  71. sm: { span: 16 },
  72. },
  73. confirmLoading: false,
  74. form: this.$form.createForm(this),
  75. validatorRules:{
  76. realname:{rules: [{ required: true, message: '请输入员工名称!' },{
  77. validator: this.validateRealname
  78. }]},
  79. deptname:{rules: [{ required: true, message: '请输入部门名称!' },
  80. ]},
  81. type:{rules: [{ required: true, message: '请选择合同类型' }]},
  82. startDate:{rules: [{ required: true, message: '请选择合同开始日期' }]},
  83. endDate:{rules: [{ required: true, message: '请选择合同结束日期' }]},
  84. },
  85. url: {
  86. add: "/usercontract/userContract/add",
  87. edit: "/usercontract/userContract/edit",
  88. dept:"/sys/user/queryUsersByusername"
  89. },
  90. }
  91. },
  92. created () {
  93. },
  94. methods: {
  95. add () {
  96. this.edit({});
  97. },
  98. edit (record) {
  99. this.form.resetFields();
  100. this.model = Object.assign({}, record);
  101. this.visible = true;
  102. this.deptid=record.deptId;
  103. this.$nextTick(() => {
  104. this.form.setFieldsValue(pick(this.model,'userId','contractType','deptNames'))
  105. //时间格式化
  106. this.form.setFieldsValue({startDate:this.model.startDate?moment(this.model.startDate):null})
  107. this.form.setFieldsValue({endDate:this.model.endDate?moment(this.model.endDate):null})
  108. });
  109. },
  110. close () {
  111. this.$emit('close');
  112. this.visible = false;
  113. },
  114. handleOk () {
  115. const that = this;
  116. // 触发表单验证
  117. this.form.validateFields((err, values) => {
  118. if (!err) {
  119. that.confirmLoading = true;
  120. let httpurl = '';
  121. let method = '';
  122. if(!this.model.id){
  123. httpurl+=this.url.add;
  124. method = 'post';
  125. }else{
  126. httpurl+=this.url.edit;
  127. method = 'put';
  128. }
  129. let formData = Object.assign(this.model, values);
  130. formData.deptId=this.deptid;
  131. //时间格式化
  132. formData.startDate = formData.startDate?formData.startDate.format('YYYY-MM-DD HH:mm:ss'):null;
  133. formData.endDate = formData.endDate?formData.endDate.format('YYYY-MM-DD HH:mm:ss'):null;
  134. console.log(formData)
  135. httpAction(httpurl,formData,method).then((res)=>{
  136. if(res.success){
  137. that.$message.success(res.message);
  138. that.$emit('ok');
  139. }else{
  140. that.$message.warning(res.message);
  141. }
  142. }).finally(() => {
  143. that.confirmLoading = false;
  144. that.close();
  145. })
  146. }
  147. })
  148. },
  149. handleCancel () {
  150. this.close()
  151. },
  152. validateRealname(rule, value, callback) {
  153. if (!value) {
  154. callback()
  155. this.deptid="";
  156. this.form.setFieldsValue({
  157. deptNames:""
  158. })
  159. } else {
  160. this.queryDeptName(value);
  161. callback()
  162. }
  163. },
  164. queryDeptName(e){
  165. getAction(this.url.dept,{id:e}).then((res)=>{
  166. if(res.success){
  167. if(res.result.length>0){
  168. var list=res.result;
  169. var deptids=[];
  170. var deptname=[];
  171. for(var i=0;i<list.length;i++){
  172. deptids.push(list[i].deptid);
  173. deptname.push(list[i].deptname);
  174. }
  175. this.deptid=deptids.join(",");
  176. this.form.setFieldsValue({
  177. deptNames:deptname.join(",")
  178. })
  179. }else{
  180. this.deptid="";
  181. this.form.setFieldsValue({
  182. deptNames:""
  183. })
  184. }
  185. }
  186. }).finally(() => {
  187. this.form.setFieldsValue({
  188. userId:e
  189. })
  190. })
  191. }
  192. }
  193. }
  194. </script>
  195. <style lang="less" scoped>
  196. </style>