goods.js 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724
  1. $(function () {
  2. $("#jqGrid").jqGrid({
  3. url: '../goods/list',
  4. datatype: "json",
  5. colModel: [
  6. {label: 'ID', name: 'id', index: 'id', width: 60, key: true},
  7. {label: '商户名称', name: 'merchName', index: 'merchName', width: 100, align: 'center'},
  8. {label: '第三方商户编号', name: 'thirdPartyMerchCode', index: 'thirdPartyMerchCode', width: 60, align: 'center'},
  9. {label: '商品编码', name: 'goodsSn', index: 'goods_Sn', width: 60, align: 'center'},
  10. {label: 'SKU', name: 'sku', index: 'sku', width: 80, align: 'center'},
  11. {label: '产品条码', name: 'prodBarcode', index: 'prod_barcode', width: 60, align: 'center'},
  12. // {label: '商品类型', name: 'categoryName', index: 'category_id', width: 40, align: 'center'},
  13. {label: '名称', name: 'name', index: 'name', width: 160, align: 'center'},
  14. {
  15. label: '货品业务类型', name: 'goodsBizType', index: 'goods_biz_type', width: 70, align: 'center',
  16. formatter: function (value) {
  17. if (value == '00') {
  18. return '保税备货';
  19. } else if (value == '02') {
  20. return '保税展示补货';
  21. } else if (value == '10') {
  22. return '保税展示跨境';
  23. }
  24. return '普通货物';
  25. }
  26. },
  27. {label: '库存是否共享', name: 'isStockShare', index: 'isStockShare', width: 80, align: 'center',
  28. formatter: function (value) {
  29. if (value == '0') {
  30. return '否';
  31. } else if (value == '1') {
  32. return '是';
  33. }
  34. return '-';
  35. }},
  36. {label: '商品库存', name: 'goodsNumber', index: 'goodsNumber', width: 80, align: 'center'},
  37. // {label: '零售价格', name: 'retailPrice', index: 'retail_price', width: 80, align: 'center'},
  38. // {label: '市场价', name: 'marketPrice', index: 'market_price', width: 80, align: 'center'},
  39. {
  40. label: '上架', name: 'isOnSale', index: 'is_on_sale', width: 40, align: 'center',
  41. formatter: function (value) {
  42. return transIsNot(value);
  43. }
  44. },
  45. {
  46. label: '热销', name: 'isHot', index: 'is_hot', width: 80, formatter: function (value) {
  47. return transIsNot(value);
  48. }
  49. },
  50. /*{
  51. label: '活动', name: 'goodsType', index: 'goodsType', width: 80,
  52. formatter: function (value) {
  53. if (value == 2) {
  54. return '<span class="label label-warning">团购</span>';
  55. } else {
  56. return '<span class="label label-success">无活动</span>';
  57. }
  58. }
  59. },*/
  60. {
  61. label: '录入日期', name: 'addTime', index: 'add_time', width: 80, align: 'center',
  62. formatter: function (value) {
  63. return transDate(value, 'yyyy-MM-dd hh:mm:ss');
  64. }
  65. }
  66. ],
  67. viewrecords: true,
  68. height: 575,
  69. rowNum: 10,
  70. rowList: [10, 30, 50],
  71. rownumbers: true,
  72. rownumWidth: 25,
  73. autowidth: true,
  74. multiselect: true,
  75. pager: "#jqGridPager",
  76. jsonReader: {
  77. root: "page.list",
  78. page: "page.currPage",
  79. total: "page.totalPage",
  80. records: "page.totalCount"
  81. },
  82. prmNames: {
  83. page: "page",
  84. rows: "limit",
  85. order: "order"
  86. },
  87. gridComplete: function () {
  88. $("#jqGrid").closest(".ui-jqgrid-bdiv").css({"overflow-x": "hidden"});
  89. }
  90. });
  91. $('#goodsDesc').editable({
  92. inlineMode: false,
  93. alwaysBlank: true,
  94. height: '500px', //高度
  95. minHeight: '200px',
  96. language: "zh_cn",
  97. spellcheck: false,
  98. plainPaste: true,
  99. enableScript: false,
  100. imageButtons: ["floatImageLeft", "floatImageNone", "floatImageRight", "linkImage", "replaceImage", "removeImage"],
  101. allowedImageTypes: ["jpeg", "jpg", "png", "gif"],
  102. imageUploadURL: '../sys/oss/upload',
  103. imageUploadParams: {id: "edit"},
  104. imagesLoadURL: '../sys/oss/queryAll'
  105. })
  106. });
  107. var ztree;
  108. var exportMsg;
  109. var setting = {
  110. data: {
  111. simpleData: {
  112. enable: true,
  113. idKey: "id",
  114. pIdKey: "parentId",
  115. rootPId: -1
  116. },
  117. key: {
  118. url: "nourl"
  119. }
  120. }
  121. };
  122. var vm = new Vue({
  123. el: '#rrapp',
  124. data: {
  125. showList: true,
  126. fileList: true,
  127. title: null,
  128. uploadList: [],
  129. imgName: '',
  130. visible: false,
  131. goods: {primaryPicUrl: '', listPicUrl: '',videoUrl:'', categoryId: '', isOnSale: 1, isAppExclusive: 0, isLimited: 0, isHot: 0, categoryName: '', retailPrice: '', marketPrice: '', goodsRate: '', sortOrder: '',goodsNumber: '' },
  132. ruleValidate: {
  133. /*name: [
  134. {required: true, message: '名称不能为空', trigger: 'blur'}
  135. ]*/
  136. },
  137. q: {name: '', goodsSn: '', prodBarcode: '',goodsBizType:'', merchSn: '',thirdPartyMerchCode:''},
  138. attributes: [],
  139. attributeEntityList: [{'id': '', 'goodsId': '', 'attributeId': '', 'value': '', 'isDelete': 0}],
  140. productEntityList: [{'id': '', 'goodsId': '', 'goodsSpecificationIds': '', 'goodsSpecificationNameValue': '', 'goodsSn': '', 'goodsNumber': '', 'isDelete': 0, 'goodsDefault': 0}],
  141. /*queryCategories: [],//一级分类
  142. queryCategoriesTwo: [],*/
  143. queryMerch: [],
  144. /*categories: [],//一级分类
  145. categoriesTwo: [],*/
  146. macros: [],//商品单位
  147. // attributeCategories: [],//属性类别
  148. specifications: [],
  149. // brands: [],
  150. // freights: [],
  151. showInput: true,
  152. // categoryId: '',
  153. cusUnitCodeList: [],
  154. cusNationCodeList: [],
  155. merchList: [],
  156. suppliers: [],
  157. thirdMerchantBizList: [],
  158. thirdMerchantBizViewList: [],
  159. isStockShare: false,
  160. goodsBizType: '',
  161. isOperator: '',
  162. share: ''
  163. },
  164. methods: {
  165. delSpeRow: function (index) {
  166. //最后一行时禁止删除
  167. if (vm.productEntityList.length == 1) {
  168. return;
  169. }
  170. vm.productEntityList[index].isDelete = 1;
  171. },
  172. addSpeRow: function () {
  173. let goodsId = '';
  174. if (vm.goods) {
  175. goodsId = vm.goods.id;
  176. }
  177. vm.productEntityList.push({'id': '', 'goodsId': '', 'goodsSpecificationIds': '', 'goodsSpecificationNameValue': '', 'goodsSn': '', 'goodsNumber': '', 'isDelete': 0, 'goodsDefault': 0});
  178. },
  179. /*delAttrRow: function (index) {
  180. //最后一行时禁止删除
  181. if (vm.attributeEntityList.length == 1) {
  182. return;
  183. }
  184. vm.attributeEntityList[index].isDelete = 1;
  185. },
  186. addAttrRow: function () {
  187. let goodsId = '';
  188. if (vm.goods) {
  189. goodsId = vm.goods.id;
  190. }
  191. vm.attributeEntityList.push({'id': '', 'goodsId': goodsId, 'attributeId': '', 'value': '', 'isDelete': 0});
  192. },*/
  193. reloadSearch: function () {
  194. vm.q = {
  195. name: '',
  196. goodsSn: '',
  197. prodBarcode: '',
  198. goodsBizType: '',
  199. merchSn: '',
  200. thirdPartyMerchCode:''
  201. }
  202. },
  203. query: function () {
  204. vm.reload(1);
  205. },
  206. add: function () {
  207. vm.showList = false;
  208. vm.isOperator='add';
  209. vm.title = "新增";
  210. vm.uploadList = [];
  211. vm.goods = {primaryPicUrl: '', listPicUrl: '',videoUrl:'', categoryId: '', isOnSale: 1, isAppExclusive: 0, isLimited: 0,
  212. isHot: 0, categoryName: '', retailPrice: '', marketPrice: '', goodsRate: '', sortOrder: '',goodsNumber: '' };
  213. $('#goodsDesc').editable('setHTML', '');
  214. vm.getCategory();
  215. vm.macros = [];
  216. vm.brands = [];
  217. // vm.freights = [];
  218. vm.cusUnitCodeList = [];
  219. vm.cusNationCodeList = [];
  220. // vm.attributeEntityList = [{'id': '', 'goodsId': '', 'attributeId': '', 'value': '', 'isDelete': 0}];
  221. vm.getMacro();
  222. vm.getCusUnitCodeList();
  223. vm.getCusNationCode();
  224. vm.getMerchList();
  225. vm.showInput = true;
  226. },
  227. update: function (event) {
  228. var id = getSelectedRow();
  229. if (id == null) {
  230. return;
  231. }
  232. vm.isOperator='update';
  233. vm.showList = false;
  234. vm.title = "修改";
  235. vm.uploadList = [];
  236. // vm.goods = {primaryPicUrl: '', listPicUrl: '',videoUrl:'', categoryId: '', isOnSale: 1, isAppExclusive: 0, isLimited: 0,
  237. // isHot: 0, categoryName: '', retailPrice: '', marketPrice: '', goodsRate: '', sortOrder: '',goodsNumber: '' };
  238. vm.getInfo(id);/*
  239. var opt = {};
  240. opt.value = vm.goods.categoryId;
  241. opt.flag = 1;
  242. vm.getAttributes(opt);*/
  243. vm.thirdMerchantBizList = [];
  244. vm.getMacro();
  245. vm.getCusUnitCodeList();
  246. vm.getCusNationCode();
  247. vm.getGoodsGallery(id);
  248. vm.getMerchList();
  249. vm.showInput = true;
  250. if (vm.goods.goodsBizType == '10' || vm.goods.goodsBizType == '02') {
  251. vm.showInput = false;
  252. }
  253. },
  254. getMacro: function () {
  255. // 获取货品业务类型
  256. $.get("../sys/macro/queryMacrosByValue?value=goodsBizType", function (r) {
  257. vm.macros = r.list;
  258. });
  259. },/*
  260. getBrand: function (merchSn) {
  261. $.get("../brand/queryAll?merchSn=" + merchSn, function (r) {
  262. vm.brands = r.list;
  263. });
  264. },*/
  265. getSuppliers: function (thirdMerchantCode) {
  266. $.get("../supplier/queryAll?thirdPartyMerchCode=" + thirdMerchantCode, function (r) {
  267. vm.suppliers = r.list;
  268. });
  269. },
  270. getCusUnitCodeList: function () {
  271. $.get("../syscusunitcode/queryAll", function (r) {
  272. vm.cusUnitCodeList = r.list;
  273. });
  274. },
  275. getCusNationCode: function () {
  276. $.get("../syscusnationcode/queryAll", function (r) {
  277. vm.cusNationCodeList = r.list;
  278. });
  279. },/*
  280. getFreights: function(merchSn) {
  281. $.get("../freight/queryAll?merchSn=" + merchSn, function (r) {
  282. vm.freights = r.list;
  283. });
  284. },*/
  285. getGoodsGallery: function (id) {//获取商品顶部轮播图
  286. $.get("../goodsgallery/queryAll?goodsId=" + id, function (r) {
  287. vm.uploadList = r.list;
  288. });
  289. },
  290. getMerchList: function() {
  291. $.get("../merch/queryAll", function (r) {
  292. vm.merchList = r.list;
  293. });
  294. },
  295. getThirdMerchantBizList: function(merchSn) {
  296. $.get("../thirdmerchantbiz/queryAll?merchSn=" + merchSn, function (r) {
  297. vm.thirdMerchantBizList = r.list;
  298. });
  299. },
  300. saveOrUpdate: function (event) {
  301. var url = vm.goods.id == null ? "../goods/save" : "../goods/update";
  302. vm.goods.goodsDesc = $('#goodsDesc').editable('getHTML');
  303. vm.goods.goodsImgList = vm.uploadList;
  304. // vm.goods.attributeEntityList = vm.attributeEntityList;
  305. vm.goods.productEntityList = vm.productEntityList;
  306. $.ajax({
  307. type: "POST",
  308. url: url,
  309. dataType: "json",
  310. contentType: "application/json",
  311. data: JSON.stringify(vm.goods),
  312. success: function (r) {
  313. if (r.code === 0) {
  314. alert('操作成功', function (index) {
  315. vm.reload();
  316. });
  317. } else {
  318. alert(r.msg);
  319. }
  320. }
  321. });
  322. },
  323. enSale: function () {
  324. var ids = getSelectedRows();
  325. if (ids == null) {
  326. return;
  327. }
  328. confirm('确定要上架选中的商品?', function () {
  329. $.ajax({
  330. type: "POST",
  331. url: "../goods/enSaleBatch",
  332. contentType: "application/json",
  333. data: JSON.stringify(ids),
  334. success: function (r) {
  335. if (r.code == 0) {
  336. alert('操作成功', function (index) {
  337. $("#jqGrid").trigger("reloadGrid");
  338. });
  339. } else {
  340. alert(r.msg);
  341. }
  342. }
  343. });
  344. });
  345. },
  346. openSpe: function () {
  347. var id = getSelectedRow();
  348. if (id == null) {
  349. return;
  350. }
  351. openWindow({
  352. type: 2,
  353. title: '商品规格',
  354. content: '../shop/goodsspecification.html?goodsId=' + id
  355. })
  356. },
  357. openPro: function () {
  358. var id = getSelectedRow();
  359. if (id == null) {
  360. return;
  361. }
  362. openWindow({
  363. type: 2,
  364. title: '产品设置',
  365. content: '../shop/product.html?goodsId=' + id
  366. });
  367. },
  368. unSale: function () {
  369. var ids = getSelectedRows();
  370. if (ids == null) {
  371. return;
  372. }
  373. confirm('确定要下架选中的商品?', function () {
  374. $.ajax({
  375. type: "POST",
  376. url: "../goods/unSaleBatch",
  377. contentType: "application/json",
  378. data: JSON.stringify(ids),
  379. success: function (r) {
  380. if (r.code == 0) {
  381. alert('操作成功', function (index) {
  382. $("#jqGrid").trigger("reloadGrid");
  383. });
  384. } else {
  385. alert(r.msg);
  386. }
  387. }
  388. });
  389. });
  390. },
  391. del: function (event) {
  392. var ids = getSelectedRows();
  393. if (ids == null) {
  394. return;
  395. }
  396. confirm('确定要删除选中的记录?', function () {
  397. $.ajax({
  398. type: "POST",
  399. url: "../goods/delete",
  400. contentType: "application/json",
  401. data: JSON.stringify(ids),
  402. success: function (r) {
  403. if (r.code == 0) {
  404. alert('操作成功', function (index) {
  405. $("#jqGrid").trigger("reloadGrid");
  406. });
  407. } else {
  408. alert(r.msg);
  409. }
  410. }
  411. });
  412. });
  413. },
  414. getInfo: function (id) {
  415. $.get("../goods/info/" + id, function (r) {
  416. vm.goods = r.goods;
  417. vm.goodsBizType = r.goods.goodsBizType;
  418. // var opt = {};
  419. // opt.value = vm.goods.thirdPartyMerchCode;
  420. // vm.showStockShare(opt);
  421. // var opt2 = {};
  422. // opt2.value = vm.goods.goodsBizType;
  423. // vm.changeGoodsBizType(opt2);
  424. /*vm.categoryId = r.goods.categoryId;
  425. // vm.getCategory();
  426. var opt = {};
  427. opt.value = vm.goods.attributeCategory;
  428. vm.changeCategories(opt);
  429. if (r.goods.attributeEntityList.length > 0) {
  430. vm.attributeEntityList = r.goods.attributeEntityList;
  431. } else {
  432. vm.attributeEntityList = [{'id': '', 'goodsId': '', 'attributeId': '', 'value': '', 'isDelete': 0}];
  433. }
  434. if (r.goods.productEntityList.length > 0) {
  435. vm.productEntityList = r.goods.productEntityList;
  436. } else {
  437. vm.productEntityList = [{'id': '', 'goodsId': '', 'goodsSpecificationIds': '', 'goodsSpecificationNameValue': '', 'goodsSn': '', 'goodsNumber': '', 'isDelete': 0, 'goodsDefault': 0}];
  438. }*/
  439. if(vm.goods.goodsDesc){
  440. $('#goodsDesc').editable('setHTML', vm.goods.goodsDesc);
  441. }else{
  442. $('#goodsDesc').editable('setHTML', '');
  443. }
  444. });
  445. },
  446. reload: function (event) {
  447. vm.showList = true;
  448. let page = event;
  449. if (event != 1) {
  450. page = $("#jqGrid").jqGrid('getGridParam', 'page');
  451. }
  452. $("#jqGrid").jqGrid('setGridParam', {
  453. postData: {
  454. 'name': vm.q.name,
  455. 'goodsSn': vm.q.goodsSn,
  456. 'prodBarcode': vm.q.prodBarcode,
  457. 'goodsBizType': vm.q.goodsBizType,
  458. 'merchSn': vm.q.merchSn,
  459. 'thirdPartyMerchCode': vm.q.thirdPartyMerchCode
  460. },
  461. page: page
  462. }).trigger("reloadGrid");
  463. vm.handleReset('formValidate');
  464. },
  465. getCategory: function () {
  466. //加载分类树
  467. $.get("../category/query", function (r) {
  468. ztree = $.fn.zTree.init($("#categoryTree"), setting, r.list);
  469. var node = ztree.getNodeByParam("id", vm.goods.categoryId);
  470. if (node) {
  471. ztree.selectNode(node);
  472. vm.goods.categoryName = node.name;
  473. } else {
  474. node = ztree.getNodeByParam("id", 0);
  475. ztree.selectNode(node);
  476. vm.goods.categoryName = node.name;
  477. }
  478. })
  479. },
  480. categoryTree: function () {
  481. openWindow({
  482. title: "选择类型",
  483. area: ['300px', '450px'],
  484. content: jQuery("#categoryLayer"),
  485. btn: ['确定', '取消'],
  486. btn1: function (index) {
  487. var node = ztree.getSelectedNodes();
  488. if (node[0].isParent) {
  489. alert("只能选择");
  490. return;
  491. }
  492. //选择上级菜单
  493. vm.goods.categoryId = node[0].id;
  494. vm.goods.categoryName = node[0].name;
  495. layer.close(index);
  496. }
  497. });
  498. },
  499. showStockShare:function(opt){
  500. var thirdMerchantCode = opt.value;
  501. /*$.get("../thirdmerchantbiz/infoByCode?thirdMerchantCode=" + thirdMerchantCode, function (r) {
  502. if(r.thirdMerchantBiz){
  503. vm.share = r.thirdMerchantBiz.isStockShare;
  504. if(vm.goods.goodsBizType == '00' && r.thirdMerchantBiz.isStockShare == 1){
  505. // vm.isStockShare = true;
  506. }else{
  507. // vm.isStockShare = false;
  508. vm.goods.goodsNumber= '';
  509. }
  510. }
  511. });*/
  512. vm.getSuppliers(thirdMerchantCode);
  513. },
  514. changeGoodsBizType: function(opt) {
  515. var goodsBizType = opt.value;
  516. if (vm.goods.goodsBizType == '10' || vm.goods.goodsBizType == '02') {
  517. vm.showInput = false;
  518. } else {
  519. vm.showInput = true;
  520. }
  521. // console.log('goodsBizType:'+vm.goods.goodsBizType)
  522. // console.log('share:'+vm.share)
  523. // if(vm.goods.goodsBizType == '00' && vm.share == 1){
  524. // vm.isStockShare = true;
  525. // }else{
  526. // vm.isStockShare = false;
  527. // // vm.goods.goodsNumber= '';
  528. // // console.log('错错错')
  529. // }
  530. },
  531. handleView(name) {
  532. this.imgName = name;
  533. this.visible = true;
  534. },
  535. /*changeQueryCategories: function (opt) {
  536. var value = opt.value;
  537. $.get("../category/getCategorySelectByParent?parentId=" + value, function (r) {
  538. vm.queryCategoriesTwo = r.list;
  539. });
  540. },
  541. getAttributes: function (opt) {
  542. var value = opt.value;
  543. $.get("../attribute/query?attributeCategoryId=" + value, function (r) {
  544. vm.attributes = r.list;
  545. });
  546. if (opt.flag != 1 && !(value === vm.categoryId)) {
  547. if (vm.attributeEntityList.length > 0 && vm.attributeEntityList[0].attributeId != '') {
  548. for (var i = 0; i < vm.attributeEntityList.length; i++) {
  549. if (!(vm.attributeEntityList[0].attributeId === '')) {
  550. vm.attributeEntityList[i].isDelete = 1;
  551. }
  552. }
  553. var goodsId = '';
  554. if (vm.goods) {
  555. goodsId = vm.goods.id;
  556. }
  557. vm.attributeEntityList.unshift({'id': '', 'goodsId': goodsId, 'attributeId': '', 'value': '', 'isDelete': 0});
  558. }
  559. }
  560. },
  561. changeCategories: function (opt) {
  562. var value = opt.value;
  563. $.get("../category/getCategorySelectByParent?isShow=1&parentId=" + value, function (r) {
  564. vm.categoriesTwo = r.list;
  565. });
  566. },*/
  567. uploadExcelSuccess: function (data) {
  568. // console.log(data);
  569. if(data.code==0){
  570. alert('导入成功', function (index) {
  571. $("#jqGrid").trigger("reloadGrid");
  572. });
  573. }else{
  574. alert(data.msg);
  575. }
  576. },
  577. uploadExcelError: function () {
  578. alert('上传出现异常,请重试!');
  579. },
  580. uploadExcelFormatError: function (file) {
  581. this.$Notice.warning({
  582. title: '文件格式不正确',
  583. desc: '文件 ' + file.name + ' 格式不正确,请上传 xls 或 xlsx 格式的文件。'
  584. });
  585. },
  586. uploadExcelProgress:function(event, file, fileList){
  587. console.log("上传中")
  588. console.log(event)
  589. console.log(file)
  590. console.log(fileList)
  591. console.log("上传中")
  592. exportMsg = this.$Message.loading({
  593. content: 'Loading...',
  594. duration: 0
  595. });
  596. setTimeout(exportMsg,1000);
  597. },
  598. handleRemove(file) {
  599. // 从 upload 实例删除数据
  600. const fileList = vm.uploadList;
  601. vm.uploadList.splice(fileList.indexOf(file), 1);
  602. },
  603. handleSuccess(res, file) {
  604. // 因为上传过程为实例,这里模拟添加 url
  605. file.imgUrl = res.url;
  606. file.name = res.url;
  607. vm.uploadList.add(file);
  608. },
  609. handleBeforeUpload() {
  610. const check = vm.uploadList.length < 5;
  611. if (!check) {
  612. this.$Notice.warning({
  613. title: '最多只能上传 5 张图片。'
  614. });
  615. }
  616. return check;
  617. },
  618. handleSubmit: function (name) {
  619. // handleSubmitValidate(this, name, function () {
  620. vm.saveOrUpdate()
  621. // });
  622. },
  623. handleFormatError: function (file) {
  624. this.$Notice.warning({
  625. title: '文件格式不正确',
  626. desc: '文件 ' + file.name + ' 格式不正确,请上传 jpg 或 png 格式的图片。'
  627. });
  628. },
  629. handleMaxSize: function (file) {
  630. this.$Notice.warning({
  631. title: '超出文件大小限制',
  632. desc: '文件 ' + file.name + ' 太大,不能超过 100k。'
  633. });
  634. },
  635. handleMaxSizeByInfo: function (file) {
  636. this.$Notice.warning({
  637. title: '超出文件大小限制',
  638. desc: '文件 ' + file.name + ' 太大,不能超过 300k。'
  639. });
  640. },
  641. handleReset: function (name) {
  642. handleResetForm(this, name);
  643. },
  644. handleSuccessPicUrl: function (res, file) {
  645. vm.goods.primaryPicUrl = file.response.url;
  646. },
  647. handleSuccessListPicUrl: function (res, file) {
  648. vm.goods.listPicUrl = file.response.url;
  649. },
  650. eyeImagePicUrl: function () {
  651. var url = vm.goods.primaryPicUrl;
  652. eyeImage(url);
  653. },
  654. eyeImageListPicUrl: function () {
  655. var url = vm.goods.listPicUrl;
  656. eyeImage(url);
  657. },
  658. eyeImage: function (e) {
  659. eyeImage($(e.target).attr('src'));
  660. },
  661. eyeImageListVideoUrl: function (e) {
  662. var url = vm.goods.videoUrl;
  663. eyeVideo(url);
  664. },
  665. handleVideoFormatError: function (file) {
  666. this.$Notice.warning({
  667. title: '文件格式不正确',
  668. desc: '文件 ' + file.name + ' 格式不正确,请上传 mp4 格式的图片。'
  669. });
  670. },
  671. handleVideoMaxSize: function (file) {
  672. this.$Notice.warning({
  673. title: '超出文件大小限制',
  674. desc: '文件 ' + file.name + ' 太大,不能超过 1M。'
  675. });
  676. },
  677. handleSuccessListVideoUrl: function (res, file) {
  678. vm.goods.videoUrl = file.response.url;
  679. },
  680. goodsExport: function () {
  681. vm.fileList = false;
  682. },
  683. showMerchInfo:function(opt){
  684. var merchSn = opt.value;
  685. // vm.getCategories(merchSn);
  686. // vm.getFreights(merchSn);
  687. // vm.getBrand(merchSn);
  688. vm.getThirdMerchantBizList(merchSn);
  689. },
  690. // getCategories: function (merchSn) {
  691. // $.get("../category/getCategorySelect?isShow=1&merchSn=" + merchSn, function (r) {
  692. // vm.categories = r.list;
  693. // });
  694. // }
  695. },
  696. mounted() {
  697. // this.uploadList = this.$refs.upload.fileList;
  698. /*$.get("../category/getCategorySelect", function (r) {
  699. vm.queryCategories = r.list;
  700. });*/
  701. $.get("../merch/queryAll", function (r) {
  702. vm.queryMerch = r.list;
  703. });
  704. $.get("../sys/macro/queryMacrosByValue?value=goodsBizType", function (r) {
  705. vm.macros = r.list;
  706. });
  707. $.get("../thirdmerchantbiz/queryAll", function (r) {
  708. vm.thirdMerchantBizViewList = r.list;
  709. });
  710. }
  711. });