guhongwei 4 anos atrás
pai
commit
a6445b0e4c

+ 18 - 0
src/router/index.js

@@ -229,6 +229,24 @@ const web = [
         meta: { title: '企业基本信息' },
         component: () => import('../views/adminCenter/company/basic/index.vue'),
       },
+      {
+        path: '/adminCenter/company/policy',
+        name: 'company_policy_index',
+        meta: { title: '政策服务管理' },
+        component: () => import('../views/adminCenter/company/policy/index.vue'),
+      },
+      {
+        path: '/adminCenter/company/policy/detail',
+        name: 'company_policy_detail',
+        meta: { title: '政策服务申请' },
+        component: () => import('../views/adminCenter/company/policy/detail.vue'),
+      },
+      {
+        path: '/adminCenter/company/ticket',
+        name: 'company_ticket_index',
+        meta: { title: '创新券管理' },
+        component: () => import('../views/adminCenter/company/ticket/index.vue'),
+      },
       // 中介机构
       {
         path: '/adminCenter/inter/basic',

+ 69 - 6
src/views/adminCenter/company/basic/index.vue

@@ -1,22 +1,64 @@
 <template>
   <div id="index">
     <el-row>
-      <el-col :span="24" class="main"> 基本信息 </el-col>
+      <el-col :span="24" class="main">
+        <el-col :span="24" class="one">
+          <el-col :span="24" class="text"> 基本信息 </el-col>
+          <el-col :span="24" class="form"> <one :form="form" :rules="rules"></one> </el-col>
+          <el-col :span="24" class="text"> 详细信息 </el-col>
+          <el-col :span="24" class="form"> <two :form="form" :rules="rules"></two> </el-col>
+          <el-col :span="24" class="btn">
+            <el-button type="primary" @click="onSubmit">保存信息</el-button>
+          </el-col>
+        </el-col>
+      </el-col>
     </el-row>
   </div>
 </template>
 
 <script>
+import one from './parts/one.vue';
+import two from './parts/two.vue';
 import { mapState, createNamespacedHelpers } from 'vuex';
+const { mapActions: organization } = createNamespacedHelpers('organization');
 export default {
   name: 'index',
   props: {},
-  components: {},
+  components: {
+    one,
+    two,
+  },
   data: function () {
-    return {};
+    return {
+      form: {},
+      rules: {},
+    };
+  },
+  async created() {
+    await this.search();
+  },
+  methods: {
+    ...organization(['fetch', 'update']),
+    async search() {
+      if (this.user.id) {
+        let res = await this.fetch(this.user.id);
+        if (this.$checkRes(res)) {
+          this.$set(this, `form`, res.data);
+        }
+      }
+    },
+    async onSubmit() {
+      let data = this.form;
+      let res = await this.update(data);
+      if (this.$checkRes(res)) {
+        this.$message({
+          message: '修改信息成功',
+          type: 'success',
+        });
+        this.search();
+      }
+    },
   },
-  created() {},
-  methods: {},
   computed: {
     ...mapState(['user']),
   },
@@ -33,4 +75,25 @@ export default {
 };
 </script>
 
-<style lang="less" scoped></style>
+<style lang="less" scoped>
+.main {
+  border-radius: 10px;
+  box-shadow: 0 0 5px #cccccc;
+  padding: 20px;
+  .one {
+    .text {
+      height: 40px;
+      line-height: 40px;
+      border-bottom: 1px dashed #000;
+      margin: 0 0 10px 0;
+    }
+    .btn {
+      text-align: center;
+      padding: 15px 0;
+    }
+  }
+}
+.main:hover {
+  box-shadow: 0 0 5px #409eff;
+}
+</style>

+ 81 - 0
src/views/adminCenter/company/basic/parts/one.vue

@@ -0,0 +1,81 @@
+<template>
+  <div id="one">
+    <el-row>
+      <el-col :span="24" class="main">
+        <el-form :model="form" :rules="rules" ref="form" label-width="100px">
+          <el-col :span="12">
+            <el-form-item label="企业名称" prop="name">
+              <el-input v-model="form.name" placeholder="请输入企业名称"></el-input>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="机构代码" prop="institution_code">
+              <el-input v-model="form.institution_code" placeholder="请输入机构代码" disabled></el-input>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="手机号" prop="phone">
+              <el-input v-model="form.phone" placeholder="请输入手机号"></el-input>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="电子邮箱" prop="email">
+              <el-input v-model="form.email" placeholder="请输入电子邮箱"></el-input>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="联系地址" prop="addr">
+              <el-input v-model="form.addr" placeholder="请输入联系地址"></el-input>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="办公电话" prop="office_phone">
+              <el-input v-model="form.office_phone" placeholder="请输入办公电话"></el-input>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="所属行业" prop="profession">
+              <el-input v-model="form.profession" placeholder="请输入所属行业"></el-input>
+            </el-form-item>
+          </el-col>
+        </el-form>
+      </el-col>
+    </el-row>
+  </div>
+</template>
+
+<script>
+import { mapState, createNamespacedHelpers } from 'vuex';
+export default {
+  name: 'one',
+  props: {
+    form: { type: Object },
+    rules: { type: Object },
+  },
+  components: {},
+  data: function () {
+    return {};
+  },
+  created() {},
+  methods: {},
+  computed: {
+    ...mapState(['user']),
+  },
+  metaInfo() {
+    return { title: this.$route.meta.title };
+  },
+  watch: {
+    test: {
+      deep: true,
+      immediate: true,
+      handler(val) {},
+    },
+  },
+};
+</script>
+
+<style lang="less" scoped>
+/deep/.el-input__inner {
+  border: 1px solid #333;
+}
+</style>

+ 125 - 0
src/views/adminCenter/company/basic/parts/two.vue

@@ -0,0 +1,125 @@
+<template>
+  <div id="one">
+    <el-row>
+      <el-col :span="24" class="main">
+        <el-form :model="form" :rules="rules" ref="form" label-width="100px">
+          <el-col :span="12">
+            <el-form-item label="注册类型" prop="companytype">
+              <el-input v-model="form.companytype" placeholder="请输入注册类型"></el-input>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="注册时间" prop="companydate">
+              <el-date-picker v-model="form.companydate" placeholder="请选择" value-format="yyyy-MM-dd" format="yyyy-MM-dd" type="date"> </el-date-picker>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="注册资金" prop="companycapital">
+              <el-input v-model="form.companycapital" placeholder="请输入注册资金"></el-input>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="企业法人" prop="companyperson">
+              <el-input v-model="form.companyperson" placeholder="请输入企业法人"></el-input>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="企业总收入" prop="sndqyzsr">
+              <el-input v-model="form.sndqyzsr" placeholder="请输入上年度企业总收入"></el-input>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="研发费用" prop="sndyffy">
+              <el-input v-model="form.sndyffy" placeholder="请输入上年度研发费用"></el-input>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="企业总人数" prop="companytotal">
+              <el-input v-model="form.companytotal" placeholder="请输入企业总人数"></el-input>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="研发人数" prop="zjzyfrs">
+              <el-input v-model="form.zjzyfrs" placeholder="请输入专&兼职研发人数"></el-input>
+            </el-form-item>
+          </el-col>
+          <el-col :span="24">
+            <el-form-item label="企业简介" prop="companybrief">
+              <el-input
+                v-model="form.companybrief"
+                placeholder="请输入企业简介"
+                type="textarea"
+                maxlength="300"
+                :autosize="{ minRows: 4, maxRows: 6 }"
+                show-word-limit
+              ></el-input>
+            </el-form-item>
+          </el-col>
+          <el-col :span="24">
+            <el-form-item label="主要产品" prop="mainproduct">
+              <el-input
+                v-model="form.mainproduct"
+                placeholder="请输入主要产品"
+                type="textarea"
+                maxlength="300"
+                :autosize="{ minRows: 4, maxRows: 6 }"
+                show-word-limit
+              ></el-input>
+            </el-form-item>
+          </el-col>
+          <el-col :span="24">
+            <el-form-item label="资质&荣誉" prop="qualifications">
+              <el-input
+                v-model="form.qualifications"
+                placeholder="请输入企业资质&荣誉"
+                type="textarea"
+                maxlength="300"
+                :autosize="{ minRows: 4, maxRows: 6 }"
+                show-word-limit
+              ></el-input>
+            </el-form-item>
+          </el-col>
+        </el-form>
+      </el-col>
+    </el-row>
+  </div>
+</template>
+
+<script>
+import { mapState, createNamespacedHelpers } from 'vuex';
+export default {
+  name: 'one',
+  props: {
+    form: { type: Object },
+    rules: { type: Object },
+  },
+  components: {},
+  data: function () {
+    return {};
+  },
+  created() {},
+  methods: {},
+  computed: {
+    ...mapState(['user']),
+  },
+  metaInfo() {
+    return { title: this.$route.meta.title };
+  },
+  watch: {
+    test: {
+      deep: true,
+      immediate: true,
+      handler(val) {},
+    },
+  },
+};
+</script>
+
+<style lang="less" scoped>
+/deep/.el-input__inner {
+  border: 1px solid #333;
+}
+/deep/.el-textarea__inner {
+  border: 1px solid #333;
+}
+</style>

+ 123 - 0
src/views/adminCenter/company/policy/detail.vue

@@ -0,0 +1,123 @@
+<template>
+  <div id="detail">
+    <el-row>
+      <el-col :span="24" class="main">
+        <el-col :span="24" class="one">
+          <el-col :span="24" class="top">
+            <el-button type="primary" size="mini" @click="back">返回</el-button>
+          </el-col>
+          <el-col :span="24" class="down">
+            <el-form :model="form" :rules="rules" ref="form" label-width="100px">
+              <el-form-item label="服务类型">
+                <el-radio-group v-model="form.type">
+                  <el-radio label="研发补贴"></el-radio>
+                  <el-radio label="奖励兑现"></el-radio>
+                </el-radio-group>
+              </el-form-item>
+              <el-form-item label="申请单位" prop="company">
+                <el-input v-model="form.company" placeholder="请输入申请单位"></el-input>
+              </el-form-item>
+              <el-form-item label="申请人" prop="apply_personal">
+                <el-input v-model="form.apply_personal" placeholder="请输入申请人"></el-input>
+              </el-form-item>
+              <el-form-item label="联系电话" prop="phone">
+                <el-input v-model="form.phone" placeholder="请输入联系电话"></el-input>
+              </el-form-item>
+              <el-form-item label="法人复印件" prop="qyfr">
+                <e-upload url="/files/cysci/qyfr_file/upload" :limit="1" v-model="form.qyfr" type="text"></e-upload>
+              </el-form-item>
+              <el-form-item label="企业营业执照" prop="yyzz">
+                <e-upload url="/files/cysci/yyzz_file/upload" :limit="1" v-model="form.yyzz" type="text"></e-upload>
+              </el-form-item>
+              <el-form-item label="企业利润表" prop="qylr">
+                <e-upload url="/files/cysci/qylr_file/upload" :limit="1" v-model="form.qylr" type="text"></e-upload>
+              </el-form-item>
+              <el-col :span="24" class="formBtn">
+                <el-button type="danger" size="mini" @click="back">取消注册</el-button>
+                <el-button type="primary" size="mini" @click="onSubmit('form')">提交注册</el-button>
+              </el-col>
+            </el-form>
+          </el-col>
+        </el-col>
+      </el-col>
+    </el-row>
+  </div>
+</template>
+
+<script>
+const _ = require('lodash');
+const { policyType, policyStatus } = require('@common/dict/index');
+import { mapState, createNamespacedHelpers } from 'vuex';
+const { mapActions: policy } = createNamespacedHelpers('policy');
+export default {
+  name: 'detail',
+  props: {},
+  components: {},
+  data: function () {
+    return {
+      form: {},
+      rules: {},
+    };
+  },
+  created() {
+    if (this.id) this.search();
+  },
+  methods: {
+    ...policy(['fetch', 'create']),
+    async search() {
+      const res = await this.fetch(this.id);
+      if (this.$checkRes(res)) {
+        this.$set(this, `data`, res.data);
+      }
+    },
+    onSubmit(formName) {
+      this.$refs[formName].validate(async (valid) => {
+        if (valid) {
+          let data = this.form;
+          let res = await this.create(data);
+          if (this.$checkRes(res)) {
+            this.$message({
+              message: '政策服务申报成功,请耐心等待结果',
+              type: 'success',
+            });
+            this.back;
+          }
+        } else {
+          console.log('error submit!!');
+          return false;
+        }
+      });
+    },
+    back() {
+      this.$router.push({ path: '/adminCenter/company/policy' });
+    },
+  },
+  computed: {
+    ...mapState(['user']),
+    id() {
+      return this.$route.query.id;
+    },
+  },
+  metaInfo() {
+    return { title: this.$route.meta.title };
+  },
+  watch: {
+    test: {
+      deep: true,
+      immediate: true,
+      handler(val) {},
+    },
+  },
+};
+</script>
+
+<style lang="less" scoped>
+.main {
+  border-radius: 10px;
+  box-shadow: 0 0 5px #cccccc;
+  padding: 20px;
+}
+.main:hover {
+  box-shadow: 0 0 5px #409eff;
+}
+</style>

+ 105 - 0
src/views/adminCenter/company/policy/index.vue

@@ -0,0 +1,105 @@
+<template>
+  <div id="index">
+    <el-row>
+      <el-col :span="24" class="main">
+        <el-col :span="24" class="one">
+          <data-table :fields="fields" :opera="opera" :data="list" :total="total" @query="search" @view="toView">
+            <template #selfbtn>
+              <el-button type="primary" size="mini" @click="toAdd">申请政策服务</el-button>
+            </template>
+            <template #options="{ item }">
+              <template v-if="item.prop === 'type'">
+                <el-option v-for="(i, index) in typeList" :key="`type-${index}`" :label="i" :value="i"></el-option>
+              </template>
+            </template>
+          </data-table>
+        </el-col>
+      </el-col>
+    </el-row>
+  </div>
+</template>
+
+<script>
+const { policyType, policyStatus } = require('@common/dict/index');
+import { mapState, createNamespacedHelpers } from 'vuex';
+const { mapActions: policy } = createNamespacedHelpers('policy');
+export default {
+  name: 'index',
+  props: {},
+  components: {},
+  data: function () {
+    return {
+      list: [],
+      total: 0,
+      opera: [
+        {
+          label: '查看',
+          method: 'view',
+        },
+      ],
+      fields: [
+        { label: '申请单位', prop: 'company' },
+        { label: '申请类型', prop: 'type', filter: 'select' },
+        { label: '申请人', prop: 'apply_personal' },
+        { label: '联系电话', prop: 'phone' },
+        {
+          label: '审核状态',
+          prop: 'status',
+          format: (i) => {
+            const r = policyStatus.find((f) => f.value === i);
+            if (r) return r.label;
+            else return '';
+          },
+        },
+        { label: '建议', prop: 'desc', showTip: true },
+      ],
+      typeList: policyType,
+    };
+  },
+  created() {
+    this.search();
+  },
+  methods: {
+    ...policy(['query', 'delete']),
+    async search({ skip = 0, limit = 10, ...info } = {}) {
+      const res = await this.query({ skip, limit, ...info });
+      if (this.$checkRes(res)) {
+        this.$set(this, `list`, res.data);
+        this.$set(this, `total`, res.total);
+      }
+    },
+    // 申请政策服务
+    toAdd() {
+      this.$router.push({ path: '/adminCenter/company/policy/detail' });
+    },
+    // 查看政策服务
+    toView({ data }) {
+      this.$router.push({ path: '/adminCenter/company/policy/detail', query: { id: data._id } });
+    },
+  },
+  computed: {
+    ...mapState(['user']),
+  },
+  metaInfo() {
+    return { title: this.$route.meta.title };
+  },
+  watch: {
+    test: {
+      deep: true,
+      immediate: true,
+      handler(val) {},
+    },
+  },
+};
+</script>
+
+<style lang="less" scoped>
+.main {
+  border-radius: 10px;
+  box-shadow: 0 0 5px #cccccc;
+  padding: 20px;
+}
+.main:hover {
+  box-shadow: 0 0 5px #409eff;
+}
+</style>

+ 36 - 0
src/views/adminCenter/company/ticket/index.vue

@@ -0,0 +1,36 @@
+<template>
+  <div id="index">
+    <el-row>
+      <el-col :span="24" class="main"> test </el-col>
+    </el-row>
+  </div>
+</template>
+
+<script>
+import { mapState, createNamespacedHelpers } from 'vuex';
+export default {
+  name: 'index',
+  props: {},
+  components: {},
+  data: function () {
+    return {};
+  },
+  created() {},
+  methods: {},
+  computed: {
+    ...mapState(['user']),
+  },
+  metaInfo() {
+    return { title: this.$route.meta.title };
+  },
+  watch: {
+    test: {
+      deep: true,
+      immediate: true,
+      handler(val) {},
+    },
+  },
+};
+</script>
+
+<style lang="less" scoped></style>