ZhangWenQiang 6 éve
szülő
commit
b96b5daacd

+ 1 - 1
public/index.html

@@ -243,7 +243,7 @@
   <script>
     window._CONFIG = {};
     // 本地
-    window._CONFIG['domianURL'] = 'http://127.0.0.1:8089/powerjob';
+    window._CONFIG['domianURL'] = 'http://127.0.0.1:8090/powerjob';
     //测试服
     // window._CONFIG['domianURL'] = 'https://hw.hap-job.com/powerjob';
     //正式服

+ 184 - 0
src/views/hlgplatform/HlgPlatformList.vue

@@ -0,0 +1,184 @@
+<template>
+  <page-layout>
+    <a-card :bordered="false">
+    <!-- 查询区域 -->
+    <div class="table-page-search-wrapper">
+      <a-form layout="inline" @keyup.enter.native="searchQuery">
+        <a-row :gutter="24">
+          <a-col :md="6" :sm="8">
+            <a-form-item label="平台名称">
+              <a-input placeholder="请输入平台名称" v-model="queryParam.platformName"></a-input>
+            </a-form-item>
+          </a-col>
+          <a-col :md="6" :sm="8">
+            <a-form-item label="企业名称">
+              <a-input placeholder="请输入企业名称" v-model="queryParam.enterpriseName"></a-input>
+            </a-form-item>
+          </a-col>
+          <a-col :md="6" :sm="8" >
+            <span style="float: left;overflow: hidden;" class="table-page-search-submitButtons">
+              <a-button type="primary" @click="searchQuery" icon="search">查询</a-button>
+              <a-button type="primary" @click="searchReset" icon="reload" style="margin-left: 8px">重置</a-button>
+              <a @click="handleToggleSearch" style="margin-left: 8px">
+                {{ toggleSearchStatus ? '收起' : '展开' }}
+                <a-icon :type="toggleSearchStatus ? 'up' : 'down'"/>
+              </a>
+            </span>
+          </a-col>
+
+        </a-row>
+      </a-form>
+    </div>
+    <!-- 查询区域-END -->
+    
+    <!-- 操作按钮区域 -->
+    <div class="table-operator">
+      <a-button @click="handleAdd" type="primary" icon="plus">新增</a-button>
+    </div>
+
+    <!-- table区域-begin -->
+    <div>
+
+      <a-table
+        ref="table"
+        size="middle"
+        bordered
+        rowKey="id"
+        :columns="columns"
+        :dataSource="dataSource"
+        :pagination="ipagination"
+        :loading="loading"
+        :rowSelection="{selectedRowKeys: selectedRowKeys, onChange: onSelectChange}"
+        @change="handleTableChange">
+
+        <span slot="action" slot-scope="text, record">
+          <a @click="handleSubcontractor(record)" v-has="'platform:subcontractor'">服务商</a>
+          <a-divider type="vertical" v-has="'platform:subcontractor'"/>
+          <a @click="handleEdit(record)" v-has="'platform:edit'">编辑</a>
+          <a-divider type="vertical" v-if="record.isLock == 0" v-has="'platform:lock'"/>
+          <a-divider type="vertical" v-if="record.isLock == 1" v-has="'platform:unlock'"/>
+          <a @click="handleLock(record)" v-if="record.isLock == 0" v-has="'platform:lock'">锁定</a>
+          <a @click="handleLock(record)" v-if="record.isLock == 1" v-has="'platform:unlock'">解锁</a>
+          <a-divider type="vertical" v-has="'platform:del'" />
+          <a @click="handleDel(record)" v-has="'platform:del'">删除</a>
+        </span>
+
+      </a-table>
+    </div>
+
+    <hlgPlatform-modal ref="modalForm" @ok="modalFormOk"></hlgPlatform-modal>
+  </a-card>
+  </page-layout>
+</template>
+
+<script>
+
+  import { JeecgListMixin } from '@/mixins/JeecgListMixin'
+  import HlgPlatformModal from './modules/HlgPlatformModal'
+  import JDate from '@/components/jeecg/JDate.vue'
+  import PageLayout from '@/components/page/PageLayout'
+  const lockPlatform = (params) => putAction('/hlgplatform/hlgPlatform/lockPlatform', params)
+
+  export default {
+    name: "HlgPlatformList",
+    mixins:[JeecgListMixin],
+    components: {
+      JDate,
+      HlgPlatformModal,
+      PageLayout
+    },
+    data () {
+      return {
+        description: '平台信息表管理页面',
+        // 表头
+        columns: [
+          {
+            title:'平台名称',
+            align:"left",
+            dataIndex: 'platformName'
+          },
+          {
+            title:'企业名称',
+            align:"left",
+            dataIndex: 'enterpriseName'
+          },
+          {
+            title:'状态',
+            align:"left",
+            dataIndex: 'isLock_dictText'
+          },
+          {
+            title: '操作',
+            dataIndex: 'action',
+            align:"left",
+            scopedSlots: { customRender: 'action' },
+          }
+        ],
+        url: {
+          list: "/hlgplatform/hlgPlatform/list",
+          delete: "/hlgplatform/hlgPlatform/delete",
+          deleteBatch: "/hlgplatform/hlgPlatform/deleteBatch",
+          exportXlsUrl: "/hlgplatform/hlgPlatform/exportXls",
+          importExcelUrl: "hlgplatform/hlgPlatform/importExcel",
+        },
+        dictOptions:{
+        } 
+      }
+    },
+    computed: {
+      importExcelUrl: function(){
+        return `${window._CONFIG['domianURL']}/${this.url.importExcelUrl}`;
+      }
+    },
+    methods: {
+      initDictConfig(){
+      },
+      //查看服务商
+      handleSubcontractor(record){
+
+      },
+      //锁定/解锁
+      handleLock(record){
+        let content = ''
+        let title = ''
+        if (record.status == 0) {
+          content = '确定要锁定该平台吗?'
+          title = '锁定企业'
+        } else {
+          content = '确定要解锁该平台吗?'
+          title = '解锁企业'
+        }
+        let that = this
+        const modal = that.$confirm({
+          title: title,
+          closable: true,
+          keyboard: false,
+          maskClosable: true,
+          content: content,
+          okText: '确定',
+          cancelText: '取消',
+          onOk: function() {
+            lockPlatform({ id: record.id, isLock: record.isLock == 0 ? 1 : 0 }).then((res) => {
+              if (res.success) {
+                that.$message.success(res.message)
+                that.loadData()
+              } else {
+                that.$message.warning(res.message)
+              }
+            })
+          },
+          onCancel(e) {
+            modal.destroy()
+          }
+        })
+      },
+      //删除
+      handleDel(record){
+
+      }
+    }
+  }
+</script>
+<style scoped>
+  @import '~@assets/less/common.less'
+</style>

+ 285 - 0
src/views/hlgplatform/modules/HlgPlatformModal.vue

@@ -0,0 +1,285 @@
+<template>
+  <a-modal
+    :title="title"
+    :width="width"
+    :visible="visible"
+    :bodyStyle="bodyStyle"
+    :confirmLoading="confirmLoading"
+    @ok="handleOk"
+    @cancel="handleCancel"
+    :maskClosable="false"
+    :footer="null"
+    cancelText="关闭">
+    <a-spin :spinning="confirmLoading">
+      <a-form :form="form">
+
+        <a-form-item label="平台名称" :labelCol="labelCol" :wrapperCol="wrapperCol">
+          <a-input v-decorator="[ 'platformName', validatorRules.platformName]" placeholder="请输入平台名称"></a-input>
+        </a-form-item>
+          
+        <a-form-item label="企业名称" :labelCol="labelCol" :wrapperCol="wrapperCol">
+          <a-input v-decorator="[ 'enterpriseName', validatorRules.enterpriseName]" placeholder="请输入企业名称"></a-input>
+        </a-form-item>
+
+        <a-form-item label="所在地区" :labelCol="labelCol" :wrapperCol="wrapperCol" :required="true">
+          <a-cascader :options="options"  :value="arr" @change="onChange" placeholder="请选择所在地区"
+                      changeOnSelect/>
+        </a-form-item>
+          
+        <a-form-item label="详细地址" :labelCol="labelCol" :wrapperCol="wrapperCol">
+          <a-input v-decorator="[ 'address', validatorRules.address]" placeholder="请输入详细地址"></a-input>
+        </a-form-item>
+          
+        <a-form-item label="联系人" :labelCol="labelCol" :wrapperCol="wrapperCol">
+          <a-input v-decorator="[ 'contactPerson', validatorRules.contactPerson]" placeholder="请输入联系人"></a-input>
+        </a-form-item>
+          
+        <a-form-item label="手机号" :labelCol="labelCol" :wrapperCol="wrapperCol">
+          <a-input v-decorator="[ 'mobilePhone', validatorRules.mobilePhone]" placeholder="请输入手机号"></a-input>
+        </a-form-item>
+          
+        <a-form-item label="固定电话" :labelCol="labelCol" :wrapperCol="wrapperCol">
+          <a-input v-decorator="[ 'phone', validatorRules.phone]" placeholder="请输入固定电话"></a-input>
+        </a-form-item>
+        
+      </a-form>
+    </a-spin>
+    <div class="drawer-bootom-button" v-show="!disableSubmit">
+      <a-button class="ant-btn"  @click="handleCancel">取消</a-button>
+      <a-button class="ant-btn ant-btn-primary" style="margin-left: 8px"  @click="handleOk">确定</a-button>
+    </div>
+  </a-modal>
+</template>
+
+<script>
+
+  import { httpAction } from '@/api/manage'
+  import pick from 'lodash.pick'
+  import JDate from '@/components/jeecg/JDate'
+  import data1 from '../../tools/area.json'
+  import { duplicateCheck } from '@/api/api'
+  
+  export default {
+    name: "HlgPlatformModal",
+    components: { 
+      JDate,
+    },
+    data () {
+      return {
+        form: this.$form.createForm(this),
+        title:"操作",
+        width:800,
+        bodyStyle: {
+          paddingTop: '20px',
+          paddingBottom:'50px',
+          height: (window.innerHeight * 0.62) + 'px',
+          'overflow-y': 'auto'
+        },
+        visible: false,
+        model: {},
+        disableSubmit:false,
+        arr:[],  //存放回显默认省市区code
+        provArray: [], //存放省
+        cityArray: [],   //存放市
+        countryArray:[],  //存放区
+        labelCol: {
+          xs: { span: 24 },
+          sm: { span: 5 },
+        },
+        wrapperCol: {
+          xs: { span: 24 },
+          sm: { span: 16 },
+        },
+        options: [{
+          value: '',
+          label: '',
+          isLeaf: false
+        }],
+        confirmLoading: false,
+        validatorRules:{
+        platformName:{rules: [{ required: true, message: '请输入平台名称!' },{
+            validator: this.validateCompanyAbbreviation
+          }]},
+        enterpriseName:{rules: [{ required: true, message: '请输入企业名称!' }]},
+        address:{},
+        contactPerson:{},
+        mobilePhone:{rules: [{ validator: this.validatePhone }] },
+        phone:{},
+        },
+        url: {
+          add: "/hlgplatform/hlgPlatform/add",
+          edit: "/hlgplatform/hlgPlatform/edit",
+        }
+     
+      }
+    },
+    created () {
+      //省市区options完全拼接
+      for (var i = 0; i < data1.length; i++) {
+        this.cityArray=[]
+        for (let j = 0; j < data1[i].cityList.length; j++) {
+          this.countryArray=[]
+          for (let k = 0; k < data1[i].cityList[j].areaList.length; k++) {
+            var country = {
+              value: data1[i].cityList[j].areaList[k].code,
+              label: data1[i].cityList[j].areaList[k].name,
+            }
+            this.countryArray.push(country)
+          }
+          var city = {
+            value: data1[i].cityList[j].code,
+            label: data1[i].cityList[j].name,
+            children: this.countryArray
+          }
+          this.cityArray.push(city)
+        }
+        var prov = {
+          value: data1[i].code,
+          label: data1[i].name,
+          children:this.cityArray,
+        }
+        this.provArray.push(prov)
+        this.options=this.provArray
+      }
+    },
+    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,'platformName','enterpriseName','provinceCode','cityCode','countryCode','provinceCityCountry','address','contactPerson','mobilePhone','phone','sysOrgCode','createTime','createBy','updateTime','updateBy','isLock'))
+        })
+        //回显省市区
+        this.arr=[]
+        this.arr.push(String(this.model.provinceCode))
+        this.arr.push(String(this.model.cityCode))
+        this.arr.push(String(this.model.countryCode))
+      },
+      close () {
+        this.$emit('close');
+        this.visible = false;
+      },
+      handleOk () {
+        const that = this;
+        if(this.arr.length!=3||this.arr[0]=="undefined"){
+          this.$message.warning("请选择所在地区");
+          return
+        }
+        // 触发表单验证
+        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);
+            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()
+      },
+      popupCallback(row){
+        this.form.setFieldsValue(pick(row,'platformName','enterpriseName','provinceCode','cityCode','countryCode','provinceCityCountry','address','contactPerson','mobilePhone','phone','sysOrgCode','createTime','createBy','updateTime','updateBy','isLock'))
+      },
+
+      //校验平台名称重复
+      validateCompanyAbbreviation(rule, value, callback) {
+        var params = {
+          tableName: 'hlg_platform',
+          fieldName: 'platform_name',
+          fieldVal: value,
+          dataId: this.model.id
+        }
+        duplicateCheck(params).then((res) => {
+          if (res.success) {
+            callback()
+          } else {
+            callback('平台名称已存在!')
+          }
+        })
+      },
+      //校验手机号
+      validatePhone(rule, value, callback) {
+        if (!value) {
+          callback()
+        } else {
+          if (new RegExp(/^1[3|4|5|7|8][0-9]\d{8}$/).test(value)) {
+            callback()
+          } else {
+            callback('请输入正确格式的手机号码!')
+          }
+        }
+      },
+
+      //省市区改变
+      onChange(value,label) {
+        this.arr=value
+        this.model.provinceCode=value[0];
+        this.model.cityCode=value[1];
+        this.model.countryCode=value[2];
+        this.$nextTick(() => {
+          this.form.setFieldsValue({ provinceCode: this.model.provinceCode })
+          this.form.setFieldsValue({ cityCode: this.model.cityCode })
+          this.form.setFieldsValue({ countryCode: this.model.countryCode })
+          if(label.length==3){
+            this.model.provinceCityCountry=label[0].label+"-"+label[1].label+"-"+label[2].label
+            this.form.setFieldsValue({ provinceCityCountry: this.model.provinceCityCountry })
+          }
+        })
+
+      },
+      
+    }
+  }
+</script>
+<style>
+  .drawer-bootom-button {
+    position: absolute;
+    bottom: -8px;
+    width: 100%;
+    border-top: 1px solid #e8e8e8;
+    padding: 10px 16px;
+    text-align: right;
+    left: 0;
+    background: #fff;
+    border-radius: 0 0 2px 2px;
+  }
+  .avatar-uploader > .ant-upload {
+    width: 104px;
+    height: 104px;
+  }
+
+  .ant-upload-select-picture-card i {
+    font-size: 49px;
+    color: #999;
+  }
+
+  .ant-upload-select-picture-card .ant-upload-text {
+    margin-top: 8px;
+    color: #666;
+  }
+</style>