index.vue 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487
  1. <template>
  2. <div class="dealGoodsPool pagePadding">
  3. <ex-table
  4. v-loading="loading"
  5. v-if="powers && powers.length > 0 && powers.some((item) => item == '001')"
  6. :table="table"
  7. :data="tableData"
  8. :columns="columns"
  9. :page="pageInfo"
  10. :size="size"
  11. @page-curr-change="handlePageChange"
  12. @page-size-change="handleSizeChange"
  13. @screen-reset="
  14. pageInfo.curr = 1;
  15. parmValue.page = 1;
  16. searchList();
  17. "
  18. @screen-submit="
  19. pageInfo.curr = 1;
  20. parmValue.page = 1;
  21. searchList();
  22. "
  23. @selection="selection_change"
  24. >
  25. <template #table-header="{}">
  26. <div style="width: 100%">
  27. <el-row style="padding: 0 0 0 80px">
  28. <el-col :span="6" style="width: 293px">
  29. <period-date-picker
  30. :type="1"
  31. :width="'135px'"
  32. :size="searchSize"
  33. :start="parmValue.start"
  34. :end="parmValue.end"
  35. @timeReturned="handleTime"
  36. />
  37. </el-col>
  38. <el-col :span="6" style="width: 250px; padding: 0 0 0 10px">
  39. <el-input
  40. :size="searchSize"
  41. style="100%"
  42. v-model="parmValue.good_code"
  43. :maxlength="40"
  44. placeholder="商品编码"
  45. ></el-input>
  46. </el-col>
  47. <el-col :span="6" style="width: 280px; padding: 0 0 0 10px">
  48. <el-input
  49. :size="searchSize"
  50. style="100%"
  51. v-model="parmValue.supplier_name"
  52. :maxlength="40"
  53. placeholder="商品名称"
  54. ></el-input>
  55. </el-col>
  56. <el-col
  57. :span="3"
  58. class="fr"
  59. style="width: 110px; padding: 0 0 0 10px"
  60. >
  61. <!-- v-if="powers.some((item) => item == '055')" -->
  62. <el-button
  63. :size="searchSize"
  64. type="warning"
  65. style="float: right"
  66. @click="add_online"
  67. >
  68. <i class="el-icon-circle-plus-outline"></i>
  69. <span>商品上线</span>
  70. </el-button>
  71. </el-col>
  72. <el-col
  73. :span="3"
  74. class="fr"
  75. style="width: 66px; padding: 0 0 0 10px"
  76. >
  77. <el-button type="primary" :size="searchSize" @click="searchList">
  78. 刷新
  79. </el-button>
  80. </el-col>
  81. <el-col
  82. :span="3"
  83. class="fr"
  84. style="width: 66px; padding: 0 0 0 10px"
  85. >
  86. <el-button type="warning" :size="searchSize" @click="restSearch">
  87. 重置
  88. </el-button>
  89. </el-col>
  90. </el-row>
  91. <!-- <el-row> -->
  92. <!-- <el-col :span="4" style="width: 518px">
  93. <el-input
  94. :size="searchSize"
  95. v-model="sinput"
  96. :maxlength="40"
  97. placeholder="关键字"
  98. >
  99. <el-select
  100. v-model="select"
  101. slot="prepend"
  102. @change="
  103. pageInfo.curr = 1;
  104. parmValue.page = 1;
  105. searchList();
  106. "
  107. style="width: 130px"
  108. placeholder="关键词类型"
  109. >
  110. <el-option label="业务公司编码" value="1" />
  111. <el-option label="业务公司名称" value="2" />
  112. <el-option label="供应商编码" value="3" />
  113. <el-option label="供应商名称" value="4" />
  114. </el-select>
  115. </el-input>
  116. </el-col> -->
  117. <!-- </el-row> -->
  118. </div></template
  119. >
  120. <template #good_img="{ scope }">
  121. <div
  122. v-if="scope.row.good_img"
  123. style="width: 20px; height: 20px"
  124. class="hover"
  125. v-viewer
  126. >
  127. <img
  128. :src="scope.row.good_img"
  129. style="display: inline-block; width: 100%; height: 100%"
  130. alt=""
  131. />
  132. </div>
  133. </template>
  134. <!-- <template #status="{ scope }">
  135. <el-tag
  136. :size="tablebtnSize"
  137. :type="scope.row.status == '0' ? '' : 'warning'"
  138. v-text="
  139. (statusList.find((item) => item.code == scope.row.status) || {})
  140. .name || '--'
  141. "
  142. ></el-tag>
  143. </template> -->
  144. <template #good_type="{ scope }">
  145. <el-tag
  146. :size="tablebtnSize"
  147. :type="scope.row.good_type == '0' ? 'warning' : ''"
  148. v-text="
  149. (options1.find((item) => item.id == scope.row.good_type) || {})
  150. .name || '--'
  151. "
  152. ></el-tag>
  153. </template>
  154. <template #operation="{ scope }">
  155. <el-tooltip
  156. v-if="powers.some((item) => item == '007')"
  157. effect="dark"
  158. content="详情"
  159. placement="top"
  160. >
  161. <i class="el-icon-view tb-icon" @click="show_view(scope.row)"></i>
  162. </el-tooltip>
  163. </template>
  164. </ex-table>
  165. <no-auth v-else></no-auth>
  166. <show-goods-data-table-modal
  167. :showModel="visible"
  168. :type="'3'"
  169. :title="row.dtitle"
  170. :skuCode="row.skuCode"
  171. :spuCode="row.spuCode"
  172. :iscgd="false"
  173. @cancel="visible = false"
  174. />
  175. <add-edit
  176. :id="''"
  177. :sitem="changeList"
  178. :show-model="showModel"
  179. :is-detail="false"
  180. @refresh="showModel = false,searchList()"
  181. @cancel="showModel = false"
  182. />
  183. </div>
  184. </template>
  185. <script>
  186. import asyncRequest from "@/apis/service/goodStore/dealGoodsPool";
  187. import mixinPage from "@/mixins/elPaginationHandle";
  188. import { mapGetters } from "vuex";
  189. import resToken from "@/mixins/resToken";
  190. import { listCol, options1 } from "./columns";
  191. import showGoodsDataTableModal from "@/components/show-goods-data-table-modal";
  192. import addEdit from "./addEdit";
  193. export default {
  194. name: "dealGoodsPool",
  195. mixins: [mixinPage, resToken],
  196. components: {
  197. showGoodsDataTableModal,
  198. addEdit
  199. },
  200. computed: {
  201. //组件SIZE设置
  202. ...mapGetters(["tablebtnSize", "searchSize", "size"]),
  203. powers() {
  204. let tran =
  205. this.$store.getters.btnList.find(
  206. (item) => item.menu_route == "dealGoodsPool"
  207. ) || {};
  208. if (tran && tran.action && tran.action.length > 0) {
  209. return tran.action;
  210. } else {
  211. return [];
  212. }
  213. },
  214. },
  215. data() {
  216. return {
  217. row: {},
  218. visible: false,
  219. select: "1",
  220. sinput: "",
  221. //弹窗
  222. showModel:false,
  223. //选中数组
  224. changeList:[],
  225. statusList: [
  226. {
  227. code: "0",
  228. name: "新建待审核",
  229. },
  230. {
  231. code: "1",
  232. name: "审核通过",
  233. },
  234. {
  235. code: "2",
  236. name: "基础修改待审核",
  237. },
  238. {
  239. code: "3",
  240. name: "成本修改待审核",
  241. },
  242. ],
  243. options1: options1,
  244. loading: false,
  245. parmValue: {
  246. page: 1, // 页码
  247. size: 15, // 每页显示条数
  248. start: "",
  249. end: "",
  250. status: "",
  251. creater: "",
  252. },
  253. // 表格 - 数据
  254. tableData: [],
  255. // 表格 - 参数
  256. table: {
  257. stripe: true,
  258. border: true,
  259. _defaultHeader_: ["setcol"],
  260. },
  261. // 表格 - 分页
  262. pageInfo: {
  263. size: 15,
  264. curr: 1,
  265. total: 0,
  266. },
  267. // 表格 - 列参数
  268. columns: listCol,
  269. supplierNo: [],
  270. cat_id: [],
  271. brandid: [],
  272. };
  273. },
  274. mounted() {
  275. this.supplierNo = [];
  276. this.cat_id = [];
  277. this.brandid = [];
  278. this.searchList();
  279. },
  280. methods: {
  281. //点击商品上线
  282. add_online(){
  283. if (this.changeList.length === 0) {
  284. this.$message.warning("至少选择一个商品!");
  285. return;
  286. }
  287. if (this.changeList.length >100) {
  288. this.$message.warning("商品数量不能超过100!");
  289. return;
  290. }
  291. this.showModel = true;
  292. },
  293. //选中触发函数
  294. selection_change(e) {
  295. console.log(e);
  296. const { list } = e;
  297. //选中的数组集合
  298. this.changeList = list.length > 0 ? JSON.parse(JSON.stringify(list)) : [];
  299. },
  300. show_view(keyRow) {
  301. this.row = keyRow;
  302. this.row.dtitle = "咨询成交商品详情";
  303. this.visible = true;
  304. },
  305. restSearch() {
  306. this.supplierNo = [];
  307. this.cat_id = [];
  308. this.brandid = [];
  309. // 表格 - 分页
  310. this.pageInfo = {
  311. size: 15,
  312. curr: 1,
  313. total: 0,
  314. };
  315. this.parmValue = {
  316. page: 1, // 页码
  317. size: 15, // 每页显示条数
  318. start: "",
  319. end: "",
  320. status: "",
  321. creater: "",
  322. };
  323. this.searchList();
  324. },
  325. //供应商选择
  326. async supplierNosearchChange(e) {
  327. console.log(e);
  328. const { code } = e;
  329. this.supplierNo = code ? [code] : [];
  330. this.parmValue.supplierNo = this.supplierNo.toString();
  331. this.pageInfo.curr = 1;
  332. this.parmValue.page = 1;
  333. await this.searchList();
  334. },
  335. //业务企业选择
  336. async company_idsearchChange(e) {
  337. const { code } = e;
  338. this.parmValue.company_id = code ? code : "";
  339. this.pageInfo.curr = 1;
  340. this.parmValue.page = 1;
  341. await this.searchList();
  342. },
  343. //商品品牌选择
  344. async brandidsearchChange(e) {
  345. const { id, code, label } = e;
  346. if (id) {
  347. this.brandid = [id];
  348. } else {
  349. this.brandid = [];
  350. }
  351. this.ruleForm.brandid = this.this.brandid.toString();
  352. this.pageInfo.curr = 1;
  353. this.parmValue.page = 1;
  354. await this.searchList();
  355. },
  356. // 时间
  357. async handleTime(e) {
  358. this.parmValue.start = e.startTime || "";
  359. this.parmValue.end = e.endTime || "";
  360. if (
  361. (this.parmValue.start !== "" && this.parmValue.end !== "") ||
  362. (this.parmValue.start === "" && this.parmValue.end === "")
  363. ) {
  364. this.pageInfo.curr = 1;
  365. this.parmValue.page = 1;
  366. await this.searchList();
  367. }
  368. },
  369. /**
  370. * 启用/禁用
  371. * @param {String} id id
  372. * @param {String} status 0-禁用 1-启用
  373. */
  374. async changeStatus(id, status) {
  375. await this.$confirm(`确定要改为${status === "1" ? "禁用" : "启用"}?`, {
  376. confirmButtonText: "确定",
  377. cancelButtonText: "取消",
  378. type: "warning",
  379. })
  380. .then(async () => {
  381. this.loading = true;
  382. const model = {
  383. id: id,
  384. status: status === "1" ? "0" : "1",
  385. };
  386. const res = await asyncRequest.status(model);
  387. if (res && res.code === 0) {
  388. this.loading = false;
  389. this.$notify.success({
  390. title: "状态修改成功!",
  391. message: "",
  392. });
  393. await this.searchList();
  394. } else if (res && res.code >= 100 && res.code <= 104) {
  395. await this.logout();
  396. } else {
  397. this.loading = false;
  398. this.$message.warning(res.message);
  399. }
  400. })
  401. .catch(() => {
  402. console.log("取消");
  403. });
  404. },
  405. async deleteItem(code) {
  406. await this.$confirm("确定要删除?", {
  407. confirmButtonText: "确定",
  408. cancelButtonText: "取消",
  409. type: "warning",
  410. })
  411. .then(async () => {
  412. const model = {
  413. codes: [code],
  414. };
  415. const res = await asyncRequest.delete(model);
  416. if (res && res.code === 0) {
  417. this.$notify.success({
  418. title: "删除成功",
  419. message: "",
  420. });
  421. this.searchList();
  422. } else if (res && res.code >= 100 && res.code <= 104) {
  423. await this.logout();
  424. } else {
  425. this.$message.warning(res.message);
  426. }
  427. })
  428. .catch(() => {
  429. console.log("取消");
  430. });
  431. },
  432. // 刷新表格
  433. async searchList() {
  434. if (
  435. (this.parmValue.start !== "" && this.parmValue.end === "") ||
  436. (this.parmValue.start === "" && this.parmValue.end !== "")
  437. ) {
  438. this.$message.warning("时间区间不完整!");
  439. return;
  440. }
  441. this.loading = true;
  442. const res = await asyncRequest.list(this.parmValue);
  443. if (res && res.code === 0 && res.data) {
  444. this.tableData = res.data.list;
  445. console.log("11111111",this.tableData)
  446. this.tableData.forEach((a) => {
  447. a.cat_name = "";
  448. let list = a.cat_info || [];
  449. list.forEach((b, i) => {
  450. a.cat_name += i == 0 ? b.name : "/" + b.name;
  451. });
  452. });
  453. this.pageInfo.total = Number(res.data.count);
  454. } else if (res && res.code >= 100 && res.code <= 104) {
  455. await this.logout();
  456. } else {
  457. this.tableData = [];
  458. this.pageInfo.total = 0;
  459. }
  460. this.loading = false;
  461. },
  462. //商品分类选择
  463. async goods_class_change(e) {
  464. const { value } = e;
  465. this.cat_id = value || [];
  466. this.pageInfo.cat_id = this.cat_id.toString();
  467. this.pageInfo.curr = 1;
  468. this.parmValue.page = 1;
  469. await this.searchList();
  470. },
  471. },
  472. };
  473. </script>
  474. <style lang="scss" scoped>
  475. </style>