Browse Source

展会管理

YY 1 year ago
parent
commit
4bf71629a9

+ 2 - 20
src/views/dock/next/detail.vue

@@ -3,10 +3,10 @@
     <el-row>
     <el-row>
       <el-col :span="24" class="main animate__animated animate__backInRight" v-loading="loading">
       <el-col :span="24" class="main animate__animated animate__backInRight" v-loading="loading">
         <el-col :span="24" class="one">
         <el-col :span="24" class="one">
-          <cSearch :is_back="true" @toBack="toBack"></cSearch>
+          <cSearch :is_title="false" :is_back="true" @toBack="toBack"></cSearch>
         </el-col>
         </el-col>
         <el-col :span="24" class="two">
         <el-col :span="24" class="two">
-          <cForm :span="24" :fields="formFields" :form="form" :rules="rules" @save="onSubmit" @dataChange="dataChange">
+          <cForm :span="24" :fields="formFields" :form="form" :rules="rules" :disabled="true" :isSave="false">
             <template #province>
             <template #province>
               <el-option v-for="(i, index) in provinceList" :key="index" :label="i.label" :value="i.value"></el-option>
               <el-option v-for="(i, index) in provinceList" :key="index" :label="i.label" :value="i.value"></el-option>
             </template>
             </template>
@@ -27,7 +27,6 @@
 import type { Ref } from 'vue';
 import type { Ref } from 'vue';
 import { ref, reactive, onMounted } from 'vue';
 import { ref, reactive, onMounted } from 'vue';
 import { useRoute } from 'vue-router';
 import { useRoute } from 'vue-router';
-import { ElMessage } from 'element-plus';
 import type { FormRules } from 'element-plus';
 import type { FormRules } from 'element-plus';
 import store from '@/stores/counter';
 import store from '@/stores/counter';
 // 接口
 // 接口
@@ -77,23 +76,6 @@ const search = async () => {
     if (res.errcode == 0) form.value = res.data as {};
     if (res.errcode == 0) form.value = res.data as {};
   } else form.value = { type: '7', status: '0', user_id: user.value._id };
   } else form.value = { type: '7', status: '0', user_id: user.value._id };
 };
 };
-const dataChange = (e: { model: string; value: any }) => {
-  const { model, value } = e;
-  if (model == 'province') {
-    let data = provinceList.value.find((i) => i.value == value);
-    if (data && data.children.length > 0) cityList.value = data.children;
-  }
-};
-// 提交
-const onSubmit = async (data) => {
-  let res: IQueryResult;
-  if (data._id) res = await dock.update(data);
-  else res = await dock.create(data);
-  if (res.errcode == 0) {
-    ElMessage({ type: `success`, message: `维护信息成功` });
-    toBack();
-  }
-};
 
 
 // 返回上一页
 // 返回上一页
 const toBack = () => {
 const toBack = () => {

+ 84 - 26
src/views/dock/next/index.vue

@@ -9,35 +9,53 @@
             </template>
             </template>
           </cSearch>
           </cSearch>
         </el-col>
         </el-col>
-        <el-col :span="24" class="two">
-          <cButton @toAdd="toAdd()"> </cButton>
-        </el-col>
         <el-col :span="24" class="thr">
         <el-col :span="24" class="thr">
-          <cTable :fields="fields" :opera="opera" :list="list" @query="search" :total="total" @edit="toEdit" @del="toDel"> </cTable>
+          <cTable :fields="fields" :opera="opera" :list="list" @query="search" :total="total" @apply="toApply" @view="toView"> </cTable>
         </el-col>
         </el-col>
       </el-col>
       </el-col>
     </el-row>
     </el-row>
+    <cDialog :dialog="dialog" @handleClose="toClose">
+      <template v-slot:info>
+        <el-col :span="24" class="dialog_one" v-if="dialog.type == '1'">
+          <cForm :fields="infofields" :form="form" labelWidth="auto" @save="toSave">
+            <template #status>
+              <el-option v-for="i in common_statusList" :key="i.value" :label="i.label" :value="i.value"></el-option>
+            </template>
+            <template #productList>
+              <el-select v-model="form.productList" value-key="_id" clearable filterable multiple placeholder="请选择参展项目" style="width: 100%">
+                <el-option v-for="item in productList" :key="item._id" :label="item.name" :value="item" />
+              </el-select>
+            </template>
+          </cForm>
+        </el-col>
+      </template>
+    </cDialog>
   </div>
   </div>
 </template>
 </template>
 <script lang="ts" setup>
 <script lang="ts" setup>
+import moment from 'moment';
 import _ from 'lodash';
 import _ from 'lodash';
 import type { Ref } from 'vue';
 import type { Ref } from 'vue';
 import { ref, onMounted, getCurrentInstance } from 'vue';
 import { ref, onMounted, getCurrentInstance } from 'vue';
 import { useRouter } from 'vue-router';
 import { useRouter } from 'vue-router';
 import { ElMessage } from 'element-plus';
 import { ElMessage } from 'element-plus';
-
+import store from '@/stores/counter';
 // 接口
 // 接口
 import { DockStore } from '@common/src/stores/allAdmin/dock';
 import { DockStore } from '@common/src/stores/allAdmin/dock';
+import { ProductStore } from '@common/src/stores/allAdmin/product';
+import { DockUserStore } from '@common/src/stores/allAdmin/dockUser';
 import { DictDataStore } from '@common/src/stores/system/dictData'; // 字典表
 import { DictDataStore } from '@common/src/stores/system/dictData'; // 字典表
 import type { IQueryResult } from '@/util/types.util';
 import type { IQueryResult } from '@/util/types.util';
+
 const dock = DockStore();
 const dock = DockStore();
 const dictData = DictDataStore();
 const dictData = DictDataStore();
-
+const product = ProductStore();
+const dockUser = DockUserStore();
 const { proxy } = getCurrentInstance() as any;
 const { proxy } = getCurrentInstance() as any;
 
 
 // 路由
 // 路由
 const router = useRouter();
 const router = useRouter();
-
+let user: Ref<any> = ref({});
 // 加载中
 // 加载中
 const loading = ref(false);
 const loading = ref(false);
 // 列表数据
 // 列表数据
@@ -54,25 +72,33 @@ let fields: Ref<any[]> = ref([
   { label: '手机号', model: 'phone' },
   { label: '手机号', model: 'phone' },
   { label: '开始时间', model: 'start_time' },
   { label: '开始时间', model: 'start_time' },
   { label: '结束时间', model: 'end_time' },
   { label: '结束时间', model: 'end_time' },
-  { label: '状态', model: 'status', format: (i) => getDict(i, 'status'), isSearch: true, type: 'select' }
+  { label: '状态', model: 'status', format: (i) => getDict(i, 'status') }
 ]);
 ]);
 // 操作
 // 操作
 let opera: Ref<any[]> = ref([
 let opera: Ref<any[]> = ref([
-  { label: '修改', method: 'edit' },
-  { label: '删除', method: 'del', confirm: true, type: 'danger' }
+  { label: '查看', method: 'view', type: 'success' },
+  { label: '申请', method: 'apply' }
+]);
+// 弹框
+const dialog: Ref<any> = ref({ title: '展会申请', show: false, type: '1' });
+const form: Ref<any> = ref({});
+const infofields: Ref<any> = ref([
+  { label: '姓名', model: 'name' },
+  { label: '手机', model: 'phone' },
+  { label: '申请时间', model: 'apply_date', type: 'date', options: { disabled: true } },
+  { label: '参展项目', model: 'productList', custom: true }, //多选属性  collapse-tags
+  { label: '状态', model: 'status', type: 'select', options: { disabled: true } }
 ]);
 ]);
-
-
-// 申请,dockUser
-// 选 科技需求和技术成果
 
 
 // 查询数据
 // 查询数据
 let searchForm: Ref<any> = ref({});
 let searchForm: Ref<any> = ref({});
 // 字典表
 // 字典表
 let statusList: Ref<any> = ref([]);
 let statusList: Ref<any> = ref([]);
-
+let productList: Ref<any> = ref([]);
+let common_statusList: Ref<any> = ref([]);
 onMounted(async () => {
 onMounted(async () => {
   loading.value = true;
   loading.value = true;
+  user.value = store.state.user;
   await searchOther();
   await searchOther();
   await search({ skip, limit });
   await search({ skip, limit });
   loading.value = false;
   loading.value = false;
@@ -99,27 +125,59 @@ const getDict = (e, model) => {
     else return '暂无';
     else return '暂无';
   }
   }
 };
 };
-// 新增
-const toAdd = () => {
-  router.push({ path: '/dock/next/detail' });
-};
-// 修改
-const toEdit = async (data) => {
+
+// 查看
+const toView = async (data) => {
   router.push({ path: '/dock/next/detail', query: { id: data._id } });
   router.push({ path: '/dock/next/detail', query: { id: data._id } });
 };
 };
-// 删除
-const toDel = async (data) => {
-  let res: IQueryResult = await dock.del(data._id);
+// 申请
+const toApply = async (data) => {
+  let res: IQueryResult = await dockUser.query({ dock_id: data._id });
   if (res.errcode == 0) {
   if (res.errcode == 0) {
-    ElMessage({ type: `success`, message: `刪除信息成功` });
-    search({ skip, limit });
+    if (res.total > 0) form.value = res.data[0];
+    else
+      form.value = {
+        dock_id: data._id,
+        user_id: user.value._id,
+        name: user.value.name,
+        phone: user.value.phone,
+        apply_date: moment().format('YYYY-MM-DD'),
+        status: '0'
+      };
   }
   }
+  dialog.value = { title: '展会申请', show: true, type: '1' };
+};
+// 提交
+const toSave = async (data) => {
+  data.status = '0';
+  let res: IQueryResult;
+  if (data._id) res = await dockUser.update(data);
+  else res = await dockUser.create(data);
+  if (res.errcode == 0) {
+    ElMessage({ type: `success`, message: `申请成功` });
+    toClose();
+  } else ElMessage({ type: `error`, message: `${res.errmsg}` });
+};
+// 弹框关闭
+const toClose = () => {
+  form.value = {};
+  searchForm.value = {};
+  dialog.value = { title: '信息管理', show: false, type: '1' };
+  search({ skip, limit });
 };
 };
 const searchOther = async () => {
 const searchOther = async () => {
   let res: IQueryResult;
   let res: IQueryResult;
   // 状态
   // 状态
   res = await dictData.query({ type: 'dock_status' });
   res = await dictData.query({ type: 'dock_status' });
   if (res.errcode == 0) statusList.value = res.data;
   if (res.errcode == 0) statusList.value = res.data;
+  res = await product.query({ user_id: user.value._id, status: '2' });
+  if (res.errcode == 0) {
+    let data: any = res.data;
+    productList.value = data.filter((i) => i.type != 2);
+  }
+  // 状态
+  res = await dictData.query({ type: 'common_status' });
+  if (res.errcode == 0) common_statusList.value = res.data;
 };
 };
 </script>
 </script>
 <style lang="scss" scoped>
 <style lang="scss" scoped>

+ 1 - 1
src/views/dock/pass/index.vue

@@ -50,7 +50,7 @@ let fields: Ref<any[]> = ref([
   { label: '手机号', model: 'phone' },
   { label: '手机号', model: 'phone' },
   { label: '开始时间', model: 'start_time' },
   { label: '开始时间', model: 'start_time' },
   { label: '结束时间', model: 'end_time' },
   { label: '结束时间', model: 'end_time' },
-  { label: '状态', model: 'status', format: (i) => getDict(i, 'status'), isSearch: true, type: 'select' }
+  { label: '状态', model: 'status', format: (i) => getDict(i, 'status') }
 ]);
 ]);
 // 操作
 // 操作
 let opera: Ref<any[]> = ref([{ label: '查看', method: 'view' }]);
 let opera: Ref<any[]> = ref([{ label: '查看', method: 'view' }]);

+ 23 - 33
src/views/product/detail.vue

@@ -102,15 +102,8 @@ let user: Ref<any> = ref({});
 // 表单
 // 表单
 let disabled: Ref<any> = ref(false);
 let disabled: Ref<any> = ref(false);
 let form: Ref<any> = ref({});
 let form: Ref<any> = ref({});
-let formFields: Ref<any[]> = ref([
-  // 公共
-  { label: '类型', model: 'type', type: 'select' },
-  { label: '企业名称', model: 'company' },
-  { label: '联系人', model: 'contact' },
-  { label: '手机号', model: 'phone' },
-  { label: '电子邮箱', model: 'email' },
-  { label: 'qq&微信', model: 'qqwx' }
-]);
+let formFields: Ref<any[]> = ref([]);
+let infoFields: Ref<any[]> = ref([]);
 const rules = reactive<FormRules>({
 const rules = reactive<FormRules>({
   type: [{ required: true, message: '请选择类型' }]
   type: [{ required: true, message: '请选择类型' }]
 });
 });
@@ -127,6 +120,18 @@ let product_patent_statusList: Ref<any> = ref([]); // 专利信息状态
 onMounted(async () => {
 onMounted(async () => {
   loading.value = true;
   loading.value = true;
   if (route.query.isdisabled) disabled.value = route.query.isdisabled;
   if (route.query.isdisabled) disabled.value = route.query.isdisabled;
+  // 公共
+  let field = [
+    { label: '类型', model: 'type', type: 'select' },
+    { label: '企业名称', model: 'company' },
+    { label: '联系人', model: 'contact' },
+    { label: '手机号', model: 'phone' },
+    { label: '电子邮箱', model: 'email' },
+    { label: 'qq&微信', model: 'qqwx' },
+    { label: '信息标题', model: 'name' }
+  ];
+  formFields.value = field;
+  infoFields.value = field;
   user.value = store.state.user;
   user.value = store.state.user;
   await searchOther();
   await searchOther();
   await search();
   await search();
@@ -162,14 +167,7 @@ const del = (e) => {
 };
 };
 // 科技需求
 // 科技需求
 const valueOne = () => {
 const valueOne = () => {
-  formFields.value = [
-    { label: '类型', model: 'type', type: 'select' },
-    { label: '企业名称', model: 'company' },
-    { label: '联系人', model: 'contact' },
-    { label: '手机号', model: 'phone' },
-    { label: '电子邮箱', model: 'email' },
-    { label: 'qq&微信', model: 'qqwx' },
-    { label: '需求名称', model: 'name' },
+  let field = [
     { label: '需求紧急程度', model: 'demand', type: 'select' },
     { label: '需求紧急程度', model: 'demand', type: 'select' },
     { label: '所属领域', model: 'field', type: 'select' },
     { label: '所属领域', model: 'field', type: 'select' },
     { label: '投资预算', model: 'budget' },
     { label: '投资预算', model: 'budget' },
@@ -180,17 +178,12 @@ const valueOne = () => {
     { label: '合作条件及要求', model: 'condition' },
     { label: '合作条件及要求', model: 'condition' },
     { label: '产品图片(6)', model: 'file', custom: true }
     { label: '产品图片(6)', model: 'file', custom: true }
   ];
   ];
+  formFields.value = [];
+  formFields.value = [...infoFields.value, ...field];
 };
 };
 // 技术成果
 // 技术成果
 const valueTwo = () => {
 const valueTwo = () => {
-  formFields.value = [
-    { label: '类型', model: 'type', type: 'select' },
-    { label: '企业名称', model: 'company' },
-    { label: '联系人', model: 'contact' },
-    { label: '手机号', model: 'phone' },
-    { label: '电子邮箱', model: 'email' },
-    { label: 'qq&微信', model: 'qqwx' },
-    { label: '成果名称', model: 'name' },
+  let field = [
     { label: '所属领域', model: 'field', type: 'select' },
     { label: '所属领域', model: 'field', type: 'select' },
     { label: '合作方式', model: 'cooperation', type: 'select' },
     { label: '合作方式', model: 'cooperation', type: 'select' },
     { label: '成果状态', model: 'achievestatus', type: 'select' },
     { label: '成果状态', model: 'achievestatus', type: 'select' },
@@ -206,17 +199,12 @@ const valueTwo = () => {
     { label: '合作条件及要求', model: 'condition' },
     { label: '合作条件及要求', model: 'condition' },
     { label: '产品图片(6)', model: 'file', custom: true }
     { label: '产品图片(6)', model: 'file', custom: true }
   ];
   ];
+  formFields.value = [];
+  formFields.value = [...infoFields.value, ...field];
 };
 };
 // 商务服务
 // 商务服务
 const valueThr = () => {
 const valueThr = () => {
-  formFields.value = [
-    { label: '类型', model: 'type', type: 'select' },
-    { label: '企业名称', model: 'company' },
-    { label: '联系人', model: 'contact' },
-    { label: '手机号', model: 'phone' },
-    { label: '电子邮箱', model: 'email' },
-    { label: 'qq&微信', model: 'qqwx' },
-    { label: '信息名称', model: 'name' },
+  let field = [
     { label: '信息属性', model: 'messattribute', type: 'select' },
     { label: '信息属性', model: 'messattribute', type: 'select' },
     { label: '需求程度', model: 'demand', type: 'select' },
     { label: '需求程度', model: 'demand', type: 'select' },
     { label: '信息描述', model: 'informationdesc', type: 'textarea' },
     { label: '信息描述', model: 'informationdesc', type: 'textarea' },
@@ -224,6 +212,8 @@ const valueThr = () => {
     { label: '价格信息', model: 'priceinfo' },
     { label: '价格信息', model: 'priceinfo' },
     { label: '商业预期', model: 'expect' }
     { label: '商业预期', model: 'expect' }
   ];
   ];
+  formFields.value = [];
+  formFields.value = [...infoFields.value, ...field];
 };
 };
 const onUpload = (e: { model: string; value: Array<[]> }) => {
 const onUpload = (e: { model: string; value: Array<[]> }) => {
   const { model, value } = e;
   const { model, value } = e;