admin.vue 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256
  1. <template>
  2. <el-row>
  3. <el-col :span="24" class="main animate__animated animate__backInRight" v-loading="loading">
  4. <el-col :span="24" class="one">
  5. <cSearch :is_title="false" :is_search="true" :fields="fields" @search="toSearch">
  6. <template #industry_sector>
  7. <el-option v-for="i in industrySectorList" :key="i._id" :label="i.label" :value="i.value"></el-option>
  8. </template>
  9. <template #urgency>
  10. <el-option v-for="i in urgencyList" :key="i._id" :label="i.label" :value="i.value"></el-option>
  11. </template>
  12. </cSearch>
  13. </el-col>
  14. <el-col :span="24" class="two">
  15. <cButton :isAdd="false"> </cButton>
  16. </el-col>
  17. <el-col :span="24" class="thr">
  18. <cTable :fields="fields" :opera="opera" :list="list" @query="search" :total="total" @edit="toEdit" @del="toDel" @changeUse="toChangeUse"> </cTable>
  19. </el-col>
  20. </el-col>
  21. </el-row>
  22. <cDialog :dialog="dialog" @toClose="toClose">
  23. <el-col :span="24" class="dialog_one" v-if="dialog.type == '1'">
  24. <cForm :span="24" :fields="formFields" :form="form" :rules="{}" @save="toSave" label-width="auto">
  25. <template #status>
  26. <el-radio v-for="i in statusList" :key="i._id" :label="i.value">{{ i.label }}</el-radio>
  27. </template>
  28. <template #industry_sector>
  29. <el-option v-for="i in industrySectorList" :key="i._id" :label="i.label" :value="i.value"></el-option>
  30. </template>
  31. <template #urgency>
  32. <el-option v-for="i in urgencyList" :key="i._id" :label="i.label" :value="i.value"></el-option>
  33. </template>
  34. <template #way>
  35. <el-option v-for="i in wayList" :key="i._id" :label="i.label" :value="i.value"></el-option>
  36. </template>
  37. <template #area>
  38. <el-option v-for="i in areaList" :key="i._id" :label="i.label" :value="i.value"></el-option>
  39. </template>
  40. </cForm>
  41. </el-col>
  42. </cDialog>
  43. </template>
  44. <script setup lang="ts">
  45. import { ref, Ref, onMounted, inject } from 'vue';
  46. // NeedChange
  47. import { DemandStore } from '@/stores/core/demand';
  48. import { DictDataStore } from '@/stores/system/dictData';
  49. import type { IQueryResult } from '@/util/types.util';
  50. import { cloneDeep, get } from 'lodash';
  51. import baseStore from '@/stores/counter';
  52. const user = ref(baseStore.state.user);
  53. onMounted(async () => {
  54. loading.value = true;
  55. await searchOther();
  56. await search({ skip, limit });
  57. loading.value = false;
  58. });
  59. const loading: Ref<any> = ref(false);
  60. // NeedChange
  61. const store = DemandStore();
  62. const dictDataStore = DictDataStore();
  63. const $checkRes = inject('$checkRes') as Function;
  64. // #region 字典
  65. // NeedChange
  66. const statusList: Ref<any> = ref([]);
  67. const industrySectorList: Ref<any> = ref([]);
  68. const urgencyList: Ref<any> = ref([]);
  69. const wayList: Ref<any> = ref([]);
  70. const areaList: Ref<any> = ref([]);
  71. const searchOther = async () => {
  72. const statusResult: IQueryResult = await dictDataStore.query({ code: 'demandStatus' });
  73. if ($checkRes(statusResult)) {
  74. statusList.value = statusResult.data;
  75. }
  76. const urgencyResult: IQueryResult = await dictDataStore.query({ code: 'urgency' });
  77. if ($checkRes(urgencyResult)) {
  78. urgencyList.value = urgencyResult.data;
  79. }
  80. const cooperateResult: IQueryResult = await dictDataStore.query({ code: 'cooperate' });
  81. if ($checkRes(cooperateResult)) {
  82. wayList.value = cooperateResult.data;
  83. }
  84. const techResult: IQueryResult = await dictDataStore.query({ code: 'tech' });
  85. if ($checkRes(techResult)) {
  86. industrySectorList.value = techResult.data;
  87. }
  88. const achieveAreaResult: IQueryResult = await dictDataStore.query({ code: 'achieveArea' });
  89. if ($checkRes(achieveAreaResult)) {
  90. areaList.value = achieveAreaResult.data;
  91. }
  92. };
  93. // #endregion
  94. // #region 查询相关
  95. let list: Ref<any> = ref([]);
  96. let total: Ref<number> = ref(0);
  97. let skip = 0;
  98. let limit = inject('$limit') as number;
  99. let searchForm: Ref<any> = ref({});
  100. const search = async (e: { skip: number; limit: number }) => {
  101. const info = { skip: e.skip, limit: e.limit, ...searchForm.value };
  102. const res: IQueryResult = await store.query(info);
  103. if (res.errcode == '0') {
  104. list.value = res.data;
  105. total.value = res.total;
  106. }
  107. };
  108. const toSearch = (query) => {
  109. searchForm.value = query;
  110. search({ skip, limit });
  111. };
  112. const toChangeUse = async (data) => {
  113. let status = '0';
  114. switch (data.status) {
  115. case '0':
  116. status = '1';
  117. break;
  118. case '1':
  119. status = '2';
  120. break;
  121. default:
  122. break;
  123. }
  124. const udata = { _id: data._id, status };
  125. const res = await store.update(udata);
  126. if ($checkRes(res, true)) {
  127. search({ skip: 0, limit });
  128. }
  129. };
  130. // #endregion
  131. // #region 表格及操作
  132. // NeedChange
  133. let fields: Ref<any[]> = ref([
  134. { label: '需求标题', model: 'title', isSearch: true },
  135. { label: '需求领域', model: 'industry_sector', isSearch: true, type: 'selectMult', format: (i) => getDict(i, 'industry_sector') },
  136. { label: '需求紧急度', model: 'urgency', isSearch: true, type: 'select', format: (i) => getDict(i, 'urgency') },
  137. { label: '合作方式', model: 'way', format: (i) => getDict(i, 'way') },
  138. { label: '地区', model: 'area', format: (i) => getDict(i, 'area') },
  139. { label: '需求开始时间', model: 'start_time' },
  140. { label: '需求结束时间', model: 'end_time' },
  141. { label: '需求状态', model: 'status', format: (i) => getDict(i, 'status') }
  142. ]);
  143. // 操作
  144. let opera: Ref<any[]> = ref([
  145. { label: '修改', method: 'edit' },
  146. { label: '进入洽谈', method: 'changeUse', type: 'warning', confirm: true, confirmWord: '您确定需求进入洽谈阶段?', display: (i) => i.status === '0' },
  147. { label: '结束', method: 'changeUse', type: 'success', confirm: true, confirmWord: '您确定结束该需求?', display: (i) => i.status === '1' },
  148. { label: '删除', method: 'del', confirm: true, type: 'danger' }
  149. ]);
  150. const getDict = (data, model) => {
  151. let list;
  152. switch (model) {
  153. case 'status':
  154. list = statusList.value;
  155. break;
  156. case 'industry_sector':
  157. list = industrySectorList.value;
  158. break;
  159. case 'way':
  160. list = wayList.value;
  161. break;
  162. case 'area':
  163. list = areaList.value;
  164. break;
  165. case 'urgency':
  166. list = urgencyList.value;
  167. break;
  168. default:
  169. break;
  170. }
  171. if (!list) return;
  172. const res = list.find((f) => f.value == data);
  173. return get(res, 'label');
  174. };
  175. const toAdd = () => {
  176. formFields.value = formFieldsForCreate;
  177. // 所属人是自己,需要把自己的id放进去
  178. form.value = { ...cloneDeep(defaultForm), owner: user.value._id };
  179. dialog.value.show = true;
  180. };
  181. const toEdit = async (data) => {
  182. formFields.value = formFieldsForUpdate;
  183. const res = await store.getOwner({ owner: data.owner });
  184. let owner_name;
  185. if ($checkRes(res)) {
  186. owner_name = get(res, 'data');
  187. }
  188. form.value = { ...data, owner_name };
  189. dialog.value.show = true;
  190. };
  191. // #endregion
  192. // #region 常规接口
  193. const toSave = async () => {
  194. const data = cloneDeep(form.value);
  195. let res: IQueryResult;
  196. if (get(data, '_id')) res = await store.update(data);
  197. else res = await store.create(data);
  198. if ($checkRes(res, true)) {
  199. search({ skip: 0, limit });
  200. toClose();
  201. }
  202. };
  203. const toDel = async (data) => {
  204. const res = await store.del(data._id);
  205. if ($checkRes(res, true)) {
  206. search({ skip: 0, limit });
  207. }
  208. };
  209. // #endregion
  210. // #region 表单及操作
  211. // NeedChange
  212. const defaultForm = { status: '1' };
  213. const formFields: Ref<any> = ref();
  214. const dialog: Ref<any> = ref({ title: '数据信息', show: false, type: '1' });
  215. const form: Ref<any> = ref({ file: [] });
  216. const formFieldsForCreate = [
  217. { label: '需求标题', model: 'title' },
  218. { label: '需求领域', model: 'industry_sector', type: 'select' },
  219. { label: '需求紧急度', model: 'urgency', type: 'select' },
  220. { label: '合作方式', model: 'way', type: 'select' },
  221. { label: '需求地区', model: 'area', type: 'select' },
  222. { label: '需求开始时间', model: 'start_time', type: 'datetime' },
  223. { label: '需求结束时间', model: 'end_time', type: 'datetime' },
  224. { label: '需求详情', model: 'desc', type: 'textarea' }
  225. ];
  226. const formFieldsForUpdate = [
  227. { label: '所属人', model: 'owner_name', options: { disabled: true } },
  228. { label: '需求标题', model: 'title' },
  229. { label: '需求领域', model: 'industry_sector', type: 'select' },
  230. { label: '需求紧急度', model: 'urgency', type: 'select' },
  231. { label: '合作方式', model: 'way', type: 'select' },
  232. { label: '需求地区', model: 'area', type: 'select' },
  233. { label: '需求开始时间', model: 'start_time', type: 'datetime' },
  234. { label: '需求结束时间', model: 'end_time', type: 'datetime' },
  235. { label: '需求详情', model: 'desc', type: 'textarea' }
  236. ];
  237. // 关闭弹框
  238. const toClose = () => {
  239. form.value = {};
  240. dialog.value.show = false;
  241. };
  242. // #endregion
  243. </script>
  244. <style scoped></style>