| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245 |
- <template>
- <a-modal
- :title="title"
- :width="800"
- :visible="visible"
- :confirmLoading="confirmLoading"
- :footer="null"
- @cancel="handleCancel">
-
- <a-spin :spinning="confirmLoading">
- <a-form :form="form">
-
- <a-form-item
- :labelCol="labelCol"
- :wrapperCol="wrapperCol"
- label="职位名称">
- <a-input placeholder="" v-decorator="['positionName', validatorRules.positionName ]" :readOnly="!!model.id" />
- </a-form-item>
- <a-form-item
- :labelCol="labelCol"
- :wrapperCol="wrapperCol"
- label="职位描述">
- <a-textarea :rows="5" placeholder="" v-decorator="[ 'positionDetail', {} ]" :readOnly="!!model.id" />
- </a-form-item>
- <a-form-item
- :labelCol="labelCol"
- :wrapperCol="wrapperCol"
- label="招聘人数">
- <a-input v-decorator="[ 'recruitNumber', {}]" :readOnly="!!model.id" />
- </a-form-item>
- <a-form-item
- :labelCol="labelCol"
- :wrapperCol="wrapperCol"
- label="基础薪资">
- <j-dict-select-tag :triggerChange="true" dictCode="basic_salary" v-decorator="[ 'basicSalary', {}]" :readOnly="!!model.id" >
- </j-dict-select-tag> </a-form-item>
- <a-form-item
- :labelCol="labelCol"
- :wrapperCol="wrapperCol"
- label="备注">
- <a-input v-decorator="[ 'otherSalary', {}]" :readOnly="!!model.id" />
- </a-form-item>
- <a-form-item
- :labelCol="labelCol"
- :wrapperCol="wrapperCol"
- label="岗位福利">
- <j-multi-select-tag dictCode="welfare" v-decorator="[ 'welfare', {}]"/>
- <!--<j-dict-select-tag :triggerChange="true" dictCode="welfare" v-decorator="[ 'welfare', {}]" :readOnly="!!model.id">-->
- <!--</j-dict-select-tag>-->
- </a-form-item>
- <a-form-item
- :labelCol="labelCol"
- :wrapperCol="wrapperCol"
- label="结算方式">
- <j-dict-select-tag :triggerChange="true" dictCode="settlement_method" v-decorator="[ 'settlementMethod', {}]" :readOnly="!!model.id" >
- </j-dict-select-tag> </a-form-item>
- <a-form-item
- :labelCol="labelCol"
- :wrapperCol="wrapperCol"
- label="是否需要打工团队">
- <j-dict-select-tag :triggerChange="true" dictCode="require_group" v-decorator="[ 'requireGroup', {}]" :readOnly="!!model.id" >
- </j-dict-select-tag> </a-form-item>
- <a-form-item
- :labelCol="labelCol"
- :wrapperCol="wrapperCol"
- label="工作日期">
- <a-input placeholder="" v-decorator="['workDate', validatorRules.workDate ]" :readOnly="!!model.id" />
- </a-form-item>
- <a-form-item label="工作时段" :labelCol="{span: 5}" :wrapperCol="{span: 16, offset: 0}">
- <a-input v-decorator="[ 'startWorkTime', {}]" :readOnly="!!model.id" />
- <span style="width: 10px;">~</span>
- <a-input v-decorator="[ 'endWordTime', {}]" :readOnly="!!model.id" />
- </a-form-item>
- <a-form-item
- :labelCol="labelCol"
- :wrapperCol="wrapperCol"
- label="学历要求">
- <j-dict-select-tag :triggerChange="true" dictCode="qualification" v-decorator="[ 'qualification', {}]" :readOnly="!!model.id">
- </j-dict-select-tag>
- </a-form-item>
- <a-form-item
- :labelCol="labelCol"
- :wrapperCol="wrapperCol"
- label="性别要求">
- <j-dict-select-tag :triggerChange="true" dictCode=" gender" v-decorator="[ 'gender', {}]" :readOnly="!!model.id">
- </j-dict-select-tag>
- </a-form-item>
- <a-form-item
- :labelCol="labelCol"
- :wrapperCol="wrapperCol"
- label="截止时间">
- <a-date-picker showTime format='YYYY-MM-DD HH:mm:ss' v-decorator="[ 'endDate', {}]" :readOnly="!!model.id"/>
- </a-form-item>
- <a-form-item
- :labelCol="labelCol"
- :wrapperCol="wrapperCol"
- label="联系人">
- <a-input placeholder="" v-decorator="['contactPerson', {}]" :readOnly="!!model.id"/>
- </a-form-item>
- <a-form-item
- :labelCol="labelCol"
- :wrapperCol="wrapperCol"
- label="联系电话">
- <a-input placeholder="" v-decorator="['contactPhone', {}]" :readOnly="!!model.id"/>
- </a-form-item>
-
- </a-form>
- </a-spin>
- </a-modal>
- </template>
- <script>
- import { httpAction } from '@/api/manage'
- import pick from 'lodash.pick'
- import moment from "moment"
- import JMultiSelectTag from '../../../components/dict/JMultiSelectTag'
- export default {
- name: "PositionModal",
- components: { JMultiSelectTag },
- data () {
- return {
- title:"操作",
- visible: false,
- model: {},
- labelCol: {
- xs: { span: 24 },
- sm: { span: 5 },
- },
- wrapperCol: {
- xs: { span: 24 },
- sm: { span: 16 },
- },
- confirmLoading: false,
- form: this.$form.createForm(this),
- validatorRules:{
- userId:{rules: [{ required: true, message: '请输入用户!' }]},
- positionName:{rules: [{ required: true, message: '请输入岗位标题!' }]},
- enterpriseName:{rules: [{ required: true, message: '请输入所属公司!' }]},
- positionDetail:{rules: [{ required: true, message: '请输入职位描述!' }]},
- positionCategory:{rules: [{ required: true, message: '请输入职位类型(0:全职 1:兼职)!' }]},
- fulltimePositionType:{rules: [{ required: true, message: '请输入全职职位类别(0:服务员 1:校园活动 2:实习 3:调研 4:送餐员 5:导购 6:网络编辑 7:普工 8:设计 9:文员助理 10:派单 11:销售 12:安保 13:礼仪 14:促销 15:翻译 16:客服 17:演出 18:家教导师 19:模特 20:快递分拣 21:厨师 22:物流仓储 23:贸易采购 24:技工 25:保洁 26:才艺技能 27:其它)!' }]},
- parttimePositionType:{rules: [{ required: true, message: '请输入兼职职位类别(0:文员助理 1:市场推广 2:家教培训 3:餐饮服务 4:促销导购 5:物流仓储 6:展会演出 7:才艺技能 8:客服话务 9:代驾司机 10:app试玩 11:线上推广 12:编辑 13:模特 14:技工 15:保洁 16:其它)!' }]},
- delFlag:{rules: [{ required: true, message: '请输入是否删除(0:上架 1:下架)!' }]},
- },
- url: {
- add: "/hpposition/position/add",
- edit: "/hpposition/position/edit",
- },
- }
- },
- created () {
- },
- methods: {
- add () {
- this.edit({});
- },
- edit (record) {
- this.form.resetFields();
- this.model = Object.assign({}, record);
- this.visible = true;
- this.$nextTick(() => {
- this.form.setFieldsValue(pick(this.model,'userId','positionName','enterpriseName','positionDetail','positionCategory','fulltimePositionType','parttimePositionType','recruitNumber','salary','otherSalary','salaryStructure','hasRegularBus','ageRange','workExperience','isHealthCertification','workDate','startWorkTime','endWordTime','isPublishNationwide','contactPerson','contactPhone','isPause','delFlag'))
- //时间格式化
- this.form.setFieldsValue({endDate:this.model.endDate?moment(this.model.endDate):null})
- this.form.setFieldsValue({basicSalary:String(this.model.basicSalary)})
- this.form.setFieldsValue({welfare:String(this.model.welfare)})
- this.form.setFieldsValue({qualification:String(this.model.qualification)})
- this.form.setFieldsValue({gender:String(this.model.gender)})
- this.form.setFieldsValue({salaryPeriod:String(this.model.salaryPeriod)})
- this.form.setFieldsValue({settlementMethod:String(this.model.settlementMethod)})
- this.form.setFieldsValue({recruitNumber:this.model.recruitNumber?this.model.recruitNumber:"若干"})
- this.form.setFieldsValue({requireGroup:this.model.requireGroup?String(this.model.requireGroup):""})
- });
- },
- close () {
- this.$emit('close');
- this.visible = false;
- },
- handleOk () {
- const that = this;
- // 触发表单验证
- this.form.validateFields((err, values) => {
- if (!err) {
- that.confirmLoading = true;
- let httpurl = '';
- let method = '';
- if(!this.model.id){
- httpurl+=this.url.add;
- method = 'post';
- }else{
- httpurl+=this.url.edit;
- method = 'put';
- }
- let formData = Object.assign(this.model, values);
- //时间格式化
- formData.endDate = formData.endDate?formData.endDate.format('YYYY-MM-DD HH:mm:ss'):null;
-
- console.log(formData)
- httpAction(httpurl,formData,method).then((res)=>{
- if(res.success){
- that.$message.success(res.message);
- that.$emit('ok');
- }else{
- that.$message.warning(res.message);
- }
- }).finally(() => {
- that.confirmLoading = false;
- that.close();
- })
- }
- })
- },
- handleCancel () {
- this.close()
- },
- }
- }
- </script>
- <style lang="less" scoped>
- </style>
|