StoreHouse_Admin.js 42 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032
  1. var ExcelData, ExcelKind;
  2. function ConfirmImport() {
  3. var index = layer.load(1, {
  4. shade: [0.5, '#000']
  5. });
  6. $.ajax({
  7. type: "POST",
  8. url: "/Admin/StoreHouseOperate/Import?r=" + Math.random(1),
  9. data: "Kind=" + ExcelKind + "&ExcelData=" + encodeURIComponent(JSON.stringify(ExcelData)),
  10. dataType: "text",
  11. success: function (data) {
  12. layer.close(index);
  13. if (data.indexOf("success") == 0) {
  14. layer.msg("成功操作" + data.split('|')[1] + "部机具", {
  15. time: 2000
  16. }, function () {
  17. window.location.reload();
  18. });
  19. } else {
  20. layer.msg(data);
  21. }
  22. }
  23. });
  24. }
  25. function ConfirmRejectImport() {
  26. $.ajax({
  27. type: "POST",
  28. url: "/Admin/StoreHouseOperate/RejectStore?r=" + Math.random(1),
  29. data: "ExcelKind=" + ExcelKind + "&ExcelData=" + encodeURIComponent(JSON.stringify(ExcelData)),
  30. dataType: "text",
  31. success: function (data) {
  32. if (data == "success") {
  33. layer.msg("导入成功", { time: 2000 }, function () {
  34. window.location.reload();
  35. });
  36. } else if (data.indexOf("warning") == 0) {
  37. var datalist = data.split('|');
  38. layer.alert(datalist[0], { time: 20000 }, function () {
  39. window.location.reload();
  40. });
  41. } else {
  42. layer.msg(data);
  43. }
  44. }
  45. });
  46. }
  47. function CheckImport(table, key, loadindex, index) {
  48. $.ajax({
  49. url: "/Admin/StoreHouseOperate/CheckImportV2?r=" + Math.random(1),
  50. data: "key=" + key,
  51. dataType: "json",
  52. success: function (data) {
  53. if (data.status == 1) {
  54. layer.msg("成功操作" + data.data + "部机具", {
  55. time: 2000
  56. }, function () {
  57. layer.close(index); //关闭弹层
  58. layer.close(loadindex);
  59. table.reload('LAY-list-manage'); //数据刷新
  60. });
  61. } else if (data.status == 2) {
  62. layer.close(index); //关闭弹层
  63. layer.close(loadindex);
  64. var content = '';
  65. for (var i = 0; i < data.errList.length; i++) {
  66. content += data.errList[i] + '<br/>'
  67. }
  68. layer.alert(content);
  69. } else {
  70. layer.msg(data.data, {
  71. time: 1000
  72. }, function () {
  73. CheckImport(table, key, loadindex, index);
  74. });
  75. }
  76. }
  77. });
  78. }
  79. var excel;
  80. var loadindex;
  81. layui.config({
  82. base: '/layuiadmin/' //静态资源所在路径
  83. }).extend({
  84. myexcel: 'layui/lay/modules/excel',
  85. index: 'lib/index' //主入口模块
  86. }).use(['index', 'table', 'excel', 'laydate'], function () {
  87. var $ = layui.$,
  88. form = layui.form,
  89. table = layui.table;
  90. //- 筛选条件-日期
  91. var laydate = layui.laydate;
  92. var layCreateDate = laydate.render({
  93. elem: '#CreateDate',
  94. type: 'date',
  95. range: true,
  96. trigger: 'click',
  97. change: function (value, date, endDate) {
  98. var op = true;
  99. if (date.year == endDate.year && endDate.month - date.month <= 1) {
  100. if (endDate.month - date.month == 1 && endDate.date > date.date) {
  101. op = false;
  102. layCreateDate.hint('日期范围请不要超过1个月');
  103. setTimeout(function () {
  104. $(".laydate-btns-confirm").addClass("laydate-disabled");
  105. }, 1);
  106. }
  107. } else {
  108. op = false;
  109. layCreateDate.hint('日期范围请不要超过1个月');
  110. setTimeout(function () {
  111. $(".laydate-btns-confirm").addClass("laydate-disabled");
  112. }, 1);
  113. }
  114. if (op) {
  115. $('#CreateDate').val(value);
  116. }
  117. }
  118. });
  119. //excel导入
  120. excel = layui.excel;
  121. $('#ExcelFile').change(function (e) {
  122. var files = e.target.files;
  123. excel.importExcel(files, {}, function (data) {
  124. ExcelData = data[0].Sheet1;
  125. });
  126. });
  127. //监听单元格编辑
  128. table.on('edit(LAY-list-manage)', function (obj) {
  129. var value = obj.value //得到修改后的值
  130. ,
  131. data = obj.data //得到所在行所有键值
  132. ,
  133. field = obj.field; //得到字段
  134. if (field == "Sort") {
  135. $.ajax({
  136. type: "POST",
  137. url: "/Admin/StoreHouseOperate/Sort?r=" + Math.random(1),
  138. data: "Id=" + data.Id + "&Sort=" + value,
  139. dataType: "text",
  140. success: function (data) { }
  141. });
  142. }
  143. });
  144. //列表数据
  145. table.render({
  146. elem: '#LAY-list-manage',
  147. url: '/Admin/StoreHouseOperate/IndexData' //模拟接口
  148. ,
  149. cols: [
  150. [{
  151. type: 'checkbox',
  152. fixed: 'left'
  153. }, {
  154. field: 'StoreNo',
  155. width: 150,
  156. title: '仓库编号',
  157. sort: true
  158. }, {
  159. field: 'StoreName',
  160. width: 150,
  161. title: '仓库名称',
  162. sort: true
  163. }, {
  164. field: 'UserIdMakerCode',
  165. width: 150,
  166. title: '仓库所属人编号',
  167. sort: true,
  168. }, {
  169. field: 'UserIdRealName',
  170. width: 150,
  171. title: '仓库所属人姓名',
  172. sort: true,
  173. }, {
  174. field: 'MakerMobiles',
  175. width: 150,
  176. title: '仓库所属人手机号',
  177. sort: true,
  178. }, {
  179. field: 'OpCode',
  180. width: 150,
  181. title: '运营中心编号',
  182. sort: true,
  183. }, {
  184. field: 'RealNames',
  185. width: 150,
  186. title: '运营中心名称',
  187. sort: true,
  188. }, {
  189. field: 'BrandId',
  190. width: 110,
  191. title: '产品类型',
  192. sort: true
  193. }, {
  194. field: 'Address',
  195. width: 150,
  196. title: '仓库地址',
  197. sort: true
  198. }, {
  199. field: 'TotalNum',
  200. width: 110,
  201. title: '总库存数',
  202. sort: true
  203. }, {
  204. field: 'LaveNum',
  205. width: 120,
  206. title: '剩余库存数',
  207. sort: true
  208. }, {
  209. field: 'OutNum',
  210. width: 100,
  211. title: '出库数',
  212. sort: true
  213. }, {
  214. field: 'Status',
  215. width: 110,
  216. title: '仓库状态',
  217. sort: true
  218. }, {
  219. field: 'CreateDate',
  220. width: 150,
  221. title: '创建时间',
  222. sort: true
  223. }
  224. // , {
  225. // field: 'Deposit',
  226. // width: 110,
  227. // title: '押金',
  228. // sort: true
  229. // }, {
  230. // field: 'ValidAmount',
  231. // width: 110,
  232. // title: '可用额度',
  233. // sort: true
  234. // }, {
  235. // field: 'FixedAmount',
  236. // width: 110,
  237. // title: '固定额度',
  238. // sort: true
  239. // }, {
  240. // field: 'TempAmount',
  241. // width: 110,
  242. // title: '临时额度',
  243. // sort: true
  244. // }, {
  245. // field: 'PromissAmount',
  246. // width: 110,
  247. // title: '担保额度',
  248. // sort: true
  249. // }, {
  250. // field: 'ThisMonthPreAmount',
  251. // width: 150,
  252. // title: '本月小分仓额度',
  253. // sort: true
  254. // }, {
  255. // field: 'ValidPreAmount',
  256. // width: 150,
  257. // title: '可用小分仓额度',
  258. // sort: true
  259. // }
  260. ]
  261. ],
  262. where: {
  263. },
  264. page: true,
  265. limit: 30,
  266. height: 'full-' + String($('.layui-card-header').height() + 130),
  267. text: '对不起,加载出现异常!',
  268. done: function (res, curr, count) {
  269. $(".layui-none").text("无数据");
  270. layer.close(loadindex);
  271. }
  272. });
  273. //监听工具条
  274. table.on('tool(LAY-list-manage)', function (obj) {
  275. var data = obj.data;
  276. if (obj.event === 'del') {
  277. var index = layer.confirm('确定要删除吗?删除后不能恢复!', function (index) {
  278. $.ajax({
  279. type: "POST",
  280. url: "/Admin/StoreHouseOperate/Delete?r=" + Math.random(1),
  281. data: "Id=" + data.Id,
  282. dataType: "text",
  283. success: function (data) {
  284. if (data == "success") {
  285. obj.del();
  286. layer.close(index);
  287. } else {
  288. parent.layer.msg(data);
  289. }
  290. }
  291. });
  292. });
  293. } else if (obj.event === 'sycn') {
  294. var index = layer.confirm('确定要同步该仓库的库存数据吗?', function (index) {
  295. layer.close(index);
  296. var loadindex = layer.load(1, {
  297. shade: [0.5, '#000']
  298. });
  299. $.ajax({
  300. type: "POST",
  301. url: "/Admin/StoreHouseOperate/SycnData?r=" + Math.random(1),
  302. data: "Id=" + data.Id,
  303. dataType: "text",
  304. success: function (data) {
  305. layer.close(loadindex);
  306. if (data == "success") {
  307. layer.msg('同步成功');
  308. table.reload('LAY-list-manage');
  309. } else {
  310. layer.msg(data);
  311. }
  312. }
  313. });
  314. });
  315. } else if (obj.event === 'edit') {
  316. var tr = $(obj.tr);
  317. var perContent = layer.open({
  318. type: 2,
  319. title: '仓库-编辑',
  320. content: 'Edit?Id=' + data.Id + '',
  321. maxmin: true,
  322. area: ['800px', '650px'],
  323. btn: ['确定', '取消'],
  324. yes: function (index, layero) {
  325. var iframeWindow = window['layui-layer-iframe' + index],
  326. submitID = 'LAY-list-front-submit',
  327. submit = layero.find('iframe').contents().find('#' + submitID);
  328. setTimeout(function () {
  329. layero.find('iframe').contents().find('.layui-tab-item').each(function (i) {
  330. var errObj = $(this).find('.layui-form-danger');
  331. if (errObj.length > 0) {
  332. iframeWindow.element.tabChange('mytabbar', String(i + 1));
  333. submit.click();
  334. }
  335. });
  336. }, 300);
  337. //监听提交
  338. iframeWindow.layui.form.on('submit(' + submitID + ')', function (data) {
  339. var field = data.field; //获取提交的字段
  340. var userdata = "";
  341. for (var prop in field) {
  342. userdata += prop + "=" + encodeURIComponent(field[prop]) + "&";
  343. }
  344. //提交 Ajax 成功后,静态更新表格中的数据
  345. //$.ajax({});
  346. $.ajax({
  347. type: "POST",
  348. url: "/Admin/StoreHouseOperate/Edit?r=" + Math.random(1),
  349. data: userdata,
  350. dataType: "text",
  351. success: function (data) {
  352. if (data == "success") {
  353. layer.close(index); //关闭弹层
  354. table.reload('LAY-list-manage'); //数据刷新
  355. } else {
  356. layer.msg(data);
  357. }
  358. }
  359. });
  360. });
  361. submit.trigger('click');
  362. },
  363. success: function (layero, index) {
  364. }
  365. });
  366. } else if (obj.event === 'edits') {
  367. var tr = $(obj.tr);
  368. var perContent = layer.open({
  369. type: 2,
  370. title: '一键新建仓库',
  371. content: 'Edits?Id=' + data.Id + '',
  372. maxmin: true,
  373. area: ['860px', '650px'],
  374. btn: ['确定', '取消'],
  375. yes: function (index, layero) {
  376. var iframeWindow = window['layui-layer-iframe' + index],
  377. submitID = 'LAY-list-front-submit',
  378. submit = layero.find('iframe').contents().find('#' + submitID);
  379. setTimeout(function () {
  380. layero.find('iframe').contents().find('.layui-tab-item').each(function (i) {
  381. var errObj = $(this).find('.layui-form-danger');
  382. if (errObj.length > 0) {
  383. iframeWindow.element.tabChange('mytabbar', String(i + 1));
  384. submit.click();
  385. }
  386. });
  387. }, 300);
  388. //监听提交
  389. iframeWindow.layui.form.on('submit(' + submitID + ')', function (data) {
  390. var field = data.field; //获取提交的字段
  391. var userdata = "";
  392. for (var prop in field) {
  393. userdata += prop + "=" + encodeURIComponent(field[prop]) + "&";
  394. }
  395. //提交 Ajax 成功后,静态更新表格中的数据
  396. //$.ajax({});
  397. $.ajax({
  398. type: "POST",
  399. url: "/Admin/StoreHouseOperate/Edits?r=" + Math.random(1),
  400. data: userdata,
  401. dataType: "text",
  402. success: function (data) {
  403. if (data == "success") {
  404. layer.close(index); //关闭弹层
  405. table.reload('LAY-list-manage'); //数据刷新
  406. } else {
  407. layer.msg(data);
  408. }
  409. }
  410. });
  411. });
  412. submit.trigger('click');
  413. },
  414. success: function (layero, index) {
  415. }
  416. });
  417. }
  418. });
  419. //监听搜索
  420. form.on('submit(LAY-list-front-search)', function (data) {
  421. var field = data.field;
  422. field.ShowFlag = 1;
  423. if (field.StoreNo == "" && field.StoreName == "" && field.UserIdMakerCode == "" && field.UserIdRealName == "" && field.ManageUserIdRealName == "" && field.ManageUserIdMobile == "" && field.ManageUserIdMakerCode == "" && field.ManagerEmail == "" && field.StoreStatusSelect == "" && field.CreateDateData == "" && field.MakerCode == "") {
  424. layer.alert('请输入查询条件');
  425. }
  426. else {
  427. //执行重载
  428. table.reload('LAY-list-manage', {
  429. where: field,
  430. page: {
  431. curr: 1
  432. }
  433. });
  434. }
  435. });
  436. form.on('submit(LAY-list-front-searchall)', function (data) {
  437. loadindex = layer.load(1, {
  438. shade: [0.5, '#000']
  439. });
  440. var field = data.field;
  441. field.ShowFlag = 1;
  442. field.StoreNo = "";
  443. field.StoreName = "";
  444. field.ManagerEmail = "";
  445. field.UserIdMakerCode = "";
  446. field.UserIdRealName = "";
  447. field.ManageUserIdRealName = "";
  448. field.ManageUserIdMobile = "";
  449. field.ManageUserIdMakerCode = "";
  450. field.StoreStatusSelect = "";
  451. field.CreateDateData = "";
  452. table.reload('LAY-list-manage', {
  453. where: field,
  454. page: {
  455. curr: 1
  456. }
  457. });
  458. });
  459. //事件
  460. var active = {
  461. batchdel: function () {
  462. var checkStatus = table.checkStatus('LAY-list-manage'),
  463. data = checkStatus.data; //得到选中的数据
  464. if (data.length < 1) {
  465. parent.layer.msg("请选择要删除的项");
  466. } else {
  467. var ids = "";
  468. $.each(data, function (index, value) {
  469. ids += data[index].Id + ",";
  470. });
  471. ids = ids.substring(0, ids.length - 1);
  472. var index = layer.confirm('确定要删除吗?删除后不能恢复!', function (index) {
  473. $.ajax({
  474. type: "POST",
  475. url: "/Admin/StoreHouseOperate/Delete?r=" + Math.random(1),
  476. data: "Id=" + ids,
  477. dataType: "text",
  478. success: function (data) {
  479. layer.close(index);
  480. if (data == "success") {
  481. table.reload('LAY-list-manage');
  482. } else {
  483. layer.msg(data);
  484. }
  485. }
  486. });
  487. });
  488. }
  489. },
  490. add: function () {
  491. var perContent = layer.open({
  492. type: 2,
  493. title: '仓库-添加',
  494. content: 'Add',
  495. maxmin: true,
  496. area: ['950px', '650px'],
  497. btn: ['确定', '取消'],
  498. yes: function (index, layero) {
  499. var iframeWindow = window['layui-layer-iframe' + index],
  500. submitID = 'LAY-list-front-submit',
  501. submit = layero.find('iframe').contents().find('#' + submitID);
  502. setTimeout(function () {
  503. layero.find('iframe').contents().find('.layui-tab-item').each(function (i) {
  504. var errObj = $(this).find('.layui-form-danger');
  505. if (errObj.length > 0) {
  506. iframeWindow.element.tabChange('mytabbar', String(i + 1));
  507. submit.click();
  508. }
  509. });
  510. }, 300);
  511. //监听提交
  512. iframeWindow.layui.form.on('submit(' + submitID + ')', function (data) {
  513. var field = data.field; //获取提交的字段
  514. var userdata = "";
  515. for (var prop in field) {
  516. userdata += prop + "=" + encodeURIComponent(field[prop]) + "&";
  517. }
  518. //提交 Ajax 成功后,静态更新表格中的数据
  519. //$.ajax({});
  520. $.ajax({
  521. type: "POST",
  522. url: "/Admin/StoreHouseOperate/Add?r=" + Math.random(1),
  523. data: userdata,
  524. dataType: "text",
  525. success: function (data) {
  526. if (data == "success") {
  527. layer.close(index); //关闭弹层
  528. table.reload('LAY-list-manage'); //数据刷新
  529. } else {
  530. layer.msg(data);
  531. }
  532. }
  533. });
  534. });
  535. submit.trigger('click');
  536. }
  537. });
  538. },
  539. ImportMachine: function () {
  540. var perContent = layer.open({
  541. type: 2,
  542. title: '机具入库',
  543. content: 'Import?ExcelKind=1',
  544. maxmin: true,
  545. area: ['650px', '350px'],
  546. btn: ['确定', '取消'],
  547. yes: function (index, layero) {
  548. var iframeWindow = window['layui-layer-iframe' + index],
  549. submitID = 'LAY-list-front-submit',
  550. submit = layero.find('iframe').contents().find('#' + submitID);
  551. //监听提交
  552. iframeWindow.layui.form.on('submit(' + submitID + ')', function (data) {
  553. var field = data.field; //获取提交的字段
  554. var userdata = "";
  555. for (var prop in field) {
  556. userdata += prop + "=" + encodeURIComponent(field[prop]) + "&";
  557. }
  558. //提交 Ajax 成功后,静态更新表格中的数据
  559. //$.ajax({});
  560. var loadindex = layer.load(1, {
  561. shade: [0.5, '#000']
  562. });
  563. $.ajax({
  564. type: "POST",
  565. url: "/Admin/StoreHouseOperate/ImportPost?r=" + Math.random(1),
  566. data: userdata,
  567. dataType: "text",
  568. success: function (data) {
  569. if (data.indexOf("success") == 0) {
  570. var datalist = data.split('|');
  571. var key = datalist[1];
  572. CheckImport(table, key, loadindex, index);
  573. } else {
  574. layer.msg(data);
  575. }
  576. }
  577. });
  578. });
  579. submit.trigger('click');
  580. }
  581. });
  582. },
  583. ImportChange: function () {
  584. var perContent = layer.open({
  585. type: 2,
  586. title: '仓库调拨',
  587. content: 'Import?ExcelKind=2',
  588. maxmin: true,
  589. area: ['650px', '350px'],
  590. btn: ['确定', '取消'],
  591. yes: function (index, layero) {
  592. var iframeWindow = window['layui-layer-iframe' + index],
  593. submitID = 'LAY-list-front-submit',
  594. submit = layero.find('iframe').contents().find('#' + submitID);
  595. //监听提交
  596. iframeWindow.layui.form.on('submit(' + submitID + ')', function (data) {
  597. var field = data.field; //获取提交的字段
  598. var userdata = "";
  599. for (var prop in field) {
  600. userdata += prop + "=" + encodeURIComponent(field[prop]) + "&";
  601. }
  602. //提交 Ajax 成功后,静态更新表格中的数据
  603. //$.ajax({});
  604. var loadindex = layer.load(1, {
  605. shade: [0.5, '#000']
  606. });
  607. $.ajax({
  608. type: "POST",
  609. url: "/Admin/StoreHouseOperate/ImportPost?r=" + Math.random(1),
  610. data: userdata,
  611. dataType: "text",
  612. success: function (data) {
  613. if (data.indexOf("success") == 0) {
  614. var datalist = data.split('|');
  615. var key = datalist[1];
  616. CheckImport(table, key, loadindex, index);
  617. } else {
  618. layer.msg(data);
  619. }
  620. }
  621. });
  622. });
  623. submit.trigger('click');
  624. }
  625. });
  626. },
  627. ImportSend: function () {
  628. var perContent = layer.open({
  629. type: 2,
  630. title: '仓库发货至创客',
  631. content: 'Import?ExcelKind=3',
  632. maxmin: true,
  633. area: ['650px', '350px'],
  634. btn: ['确定', '取消'],
  635. yes: function (index, layero) {
  636. var iframeWindow = window['layui-layer-iframe' + index],
  637. submitID = 'LAY-list-front-submit',
  638. submit = layero.find('iframe').contents().find('#' + submitID);
  639. //监听提交
  640. iframeWindow.layui.form.on('submit(' + submitID + ')', function (data) {
  641. var field = data.field; //获取提交的字段
  642. var userdata = "";
  643. for (var prop in field) {
  644. userdata += prop + "=" + encodeURIComponent(field[prop]) + "&";
  645. }
  646. //提交 Ajax 成功后,静态更新表格中的数据
  647. //$.ajax({});
  648. var loadindex = layer.load(1, {
  649. shade: [0.5, '#000']
  650. });
  651. $.ajax({
  652. type: "POST",
  653. url: "/Admin/StoreHouseOperate/ImportPost?r=" + Math.random(1),
  654. data: userdata,
  655. dataType: "text",
  656. success: function (data) {
  657. if (data.indexOf("success") == 0) {
  658. var datalist = data.split('|');
  659. var key = datalist[1];
  660. CheckImport(table, key, loadindex, index);
  661. } else {
  662. layer.msg(data);
  663. }
  664. }
  665. });
  666. });
  667. submit.trigger('click');
  668. }
  669. });
  670. },
  671. ImportBack: function () {
  672. var perContent = layer.open({
  673. type: 2,
  674. title: '机具回仓库',
  675. content: 'Import?ExcelKind=4',
  676. maxmin: true,
  677. area: ['650px', '350px'],
  678. btn: ['确定', '取消'],
  679. yes: function (index, layero) {
  680. var iframeWindow = window['layui-layer-iframe' + index],
  681. submitID = 'LAY-list-front-submit',
  682. submit = layero.find('iframe').contents().find('#' + submitID);
  683. //监听提交
  684. iframeWindow.layui.form.on('submit(' + submitID + ')', function (data) {
  685. var field = data.field; //获取提交的字段
  686. var userdata = "";
  687. for (var prop in field) {
  688. userdata += prop + "=" + encodeURIComponent(field[prop]) + "&";
  689. }
  690. //提交 Ajax 成功后,静态更新表格中的数据
  691. //$.ajax({});
  692. var loadindex = layer.load(1, {
  693. shade: [0.5, '#000']
  694. });
  695. $.ajax({
  696. type: "POST",
  697. url: "/Admin/StoreHouseOperate/ImportPost?r=" + Math.random(1),
  698. data: userdata,
  699. dataType: "text",
  700. success: function (data) {
  701. if (data.indexOf("success") == 0) {
  702. var datalist = data.split('|');
  703. var key = datalist[1];
  704. CheckImport(table, key, loadindex, index);
  705. } else {
  706. layer.msg(data);
  707. }
  708. }
  709. });
  710. });
  711. submit.trigger('click');
  712. }
  713. });
  714. }, ImportRejectStore: function () {
  715. ExcelKind = 1;
  716. layer.open({
  717. type: 1,
  718. title: '导入',
  719. maxmin: false,
  720. area: ['650px', '350px'],
  721. // btn: ['确定', '取消'],
  722. content: $('#excelForm'),
  723. cancel: function () {
  724. }
  725. });
  726. $("#excelTemp").html('<a href="/users/创客机具驳回仓库模版.xlsx">点击下载创客机具驳回仓库模版</a>');
  727. },
  728. ExportExcel: function () {
  729. var userdata = '';
  730. $(".layuiadmin-card-header-auto input").each(function (i) {
  731. userdata += $(this).attr('name') + '=' + encodeURIComponent($(this).val()) + '&';
  732. });
  733. $(".layuiadmin-card-header-auto select").each(function (i) {
  734. userdata += $(this).attr('name') + '=' + encodeURIComponent($(this).val()) + '&';
  735. });
  736. $.ajax({
  737. type: "GET",
  738. url: "/Admin/StoreHouseOperate/ExportExcel?r=" + Math.random(1),
  739. data: userdata,
  740. dataType: "json",
  741. success: function (data) {
  742. data.Obj.unshift(data.Fields);
  743. excel.exportExcel(data.Obj, data.Info, 'xlsx');
  744. }
  745. });
  746. }, BatchSetting: function () {
  747. var checkStatus = table.checkStatus('LAY-list-manage'),
  748. data = checkStatus.data; //得到选中的数据
  749. if (data.length < 1) {
  750. parent.layer.msg("请选择要关联的分仓");
  751. } else {
  752. var ids = "";
  753. $.each(data, function (index, value) {
  754. ids += data[index].Id + ",";
  755. });
  756. ids = ids.substring(0, ids.length - 1);
  757. var perContent = layer.open({
  758. type: 2,
  759. title: '关联分仓',
  760. content: 'BatchSetting',
  761. maxmin: true,
  762. area: ['550px', '350px'],
  763. btn: ['确定', '取消'],
  764. yes: function (index, layero) {
  765. loadindex = layer.load(1, {
  766. shade: [0.5, '#000']
  767. });
  768. var iframeWindow = window['layui-layer-iframe' + index],
  769. submitID = 'LAY-list-front-submit',
  770. submit = layero.find('iframe').contents().find('#' + submitID);
  771. setTimeout(function () {
  772. layero.find('iframe').contents().find('.layui-tab-item').each(function (i) {
  773. var errObj = $(this).find('.layui-form-danger');
  774. if (errObj.length > 0) {
  775. iframeWindow.element.tabChange('mytabbar', String(i + 1));
  776. submit.click();
  777. }
  778. });
  779. }, 300);
  780. //监听提交
  781. iframeWindow.layui.form.on('submit(' + submitID + ')', function (data) {
  782. var field = data.field; //获取提交的字段
  783. var userdata = "";
  784. for (var prop in field) {
  785. userdata += prop + "=" + encodeURIComponent(field[prop]) + "&";
  786. }
  787. //提交 Ajax 成功后,静态更新表格中的数据
  788. //$.ajax({});
  789. $.ajax({
  790. type: "POST",
  791. url: "/Admin/StoreHouseOperate/BatchSetting?r=" + Math.random(1),
  792. data: userdata + "Id=" + ids,
  793. dataType: "text",
  794. success: function (data) {
  795. layer.close(index);
  796. if (data == "success") {
  797. table.reload('LAY-list-manage');
  798. }
  799. else if (data.indexOf("Warning") == 0) {
  800. var datalist = data.split('|');
  801. layer.alert(datalist[1], { time: 20000 }, function () {
  802. window.location.reload();
  803. });
  804. }
  805. else {
  806. layer.close(loadindex);
  807. layer.msg(data);
  808. }
  809. }
  810. });
  811. });
  812. submit.trigger('click');
  813. }
  814. });
  815. }
  816. },
  817. BatchCancle: function () {
  818. var checkStatus = table.checkStatus('LAY-list-manage'),
  819. data = checkStatus.data; //得到选中的数据
  820. if (data.length < 1) {
  821. parent.layer.msg("请选择要取消关联的分仓");
  822. } else {
  823. var ids = "";
  824. $.each(data, function (index, value) {
  825. ids += data[index].Id + ",";
  826. });
  827. ids = ids.substring(0, ids.length - 1);
  828. var perContent = layer.open({
  829. type: 2,
  830. title: '取消关联',
  831. content: 'BatchSetting',
  832. maxmin: true,
  833. area: ['650px', '550px'],
  834. btn: ['确定', '取消'],
  835. yes: function (index, layero) {
  836. loadindex = layer.load(1, {
  837. shade: [0.5, '#000']
  838. });
  839. var iframeWindow = window['layui-layer-iframe' + index],
  840. submitID = 'LAY-list-front-submit',
  841. submit = layero.find('iframe').contents().find('#' + submitID);
  842. setTimeout(function () {
  843. layero.find('iframe').contents().find('.layui-tab-item').each(function (i) {
  844. var errObj = $(this).find('.layui-form-danger');
  845. if (errObj.length > 0) {
  846. iframeWindow.element.tabChange('mytabbar', String(i + 1));
  847. submit.click();
  848. }
  849. });
  850. }, 300);
  851. //监听提交
  852. iframeWindow.layui.form.on('submit(' + submitID + ')', function (data) {
  853. var field = data.field; //获取提交的字段
  854. var userdata = "";
  855. for (var prop in field) {
  856. userdata += prop + "=" + encodeURIComponent(field[prop]) + "&";
  857. }
  858. //提交 Ajax 成功后,静态更新表格中的数据
  859. //$.ajax({});
  860. $.ajax({
  861. type: "POST",
  862. url: "/Admin/StoreHouseOperate/BatchCancle?r=" + Math.random(1),
  863. data: userdata + "Id=" + ids,
  864. dataType: "text",
  865. success: function (data) {
  866. layer.close(loadindex);
  867. layer.close(index);
  868. if (data == "success") {
  869. table.reload('LAY-list-manage');
  870. }
  871. else if (data.indexOf("Warning") == 0) {
  872. var datalist = data.split('|');
  873. layer.alert(datalist[1], { time: 20000 }, function () {
  874. window.location.reload();
  875. });
  876. }
  877. else {
  878. layer.close(loadindex);
  879. layer.msg(data);
  880. }
  881. }
  882. });
  883. });
  884. submit.trigger('click');
  885. }
  886. });
  887. }
  888. },
  889. Open: function () {
  890. var checkStatus = table.checkStatus('LAY-list-manage'),
  891. data = checkStatus.data; //得到选中的数据
  892. if (data.length < 1) {
  893. parent.layer.msg("请选择要开启的项");
  894. } else {
  895. var ids = "";
  896. $.each(data, function (index, value) {
  897. ids += data[index].Id + ",";
  898. });
  899. ids = ids.substring(0, ids.length - 1);
  900. var index = layer.confirm('确定要开启吗?', function (index) {
  901. $.ajax({
  902. type: "POST",
  903. url: "/Admin/StoreHouseOperate/Open?r=" + Math.random(1),
  904. data: "Id=" + ids,
  905. dataType: "text",
  906. success: function (data) {
  907. layer.close(index);
  908. if (data == "success") {
  909. table.reload('LAY-list-manage');
  910. layer.close(index);
  911. } else {
  912. layer.msg(data);
  913. }
  914. }
  915. });
  916. });
  917. }
  918. },
  919. Close: function () {
  920. var checkStatus = table.checkStatus('LAY-list-manage'),
  921. data = checkStatus.data; //得到选中的数据
  922. if (data.length < 1) {
  923. parent.layer.msg("请选择要关闭的项");
  924. } else {
  925. var ids = "";
  926. $.each(data, function (index, value) {
  927. ids += data[index].Id + ",";
  928. });
  929. ids = ids.substring(0, ids.length - 1);
  930. var index = layer.confirm('确定要关闭吗?', function (index) {
  931. $.ajax({
  932. type: "POST",
  933. url: "/Admin/StoreHouseOperate/Close?r=" + Math.random(1),
  934. data: "Id=" + ids,
  935. dataType: "text",
  936. success: function (data) {
  937. layer.close(index);
  938. if (data == "success") {
  939. table.reload('LAY-list-manage');
  940. } else {
  941. layer.msg(data);
  942. }
  943. }
  944. });
  945. });
  946. }
  947. },
  948. SycnData: function () {
  949. var index = layer.confirm('确定要同步所有仓库的库存数据吗?', function (index) {
  950. layer.close(index);
  951. var loadindex = layer.load(1, {
  952. shade: [0.5, '#000']
  953. });
  954. $.ajax({
  955. type: "POST",
  956. url: "/Admin/StoreHouseOperate/SycnData?r=" + Math.random(1),
  957. data: "Id=0",
  958. dataType: "text",
  959. success: function (data) {
  960. layer.close(loadindex);
  961. if (data == "success") {
  962. layer.msg('同步成功');
  963. table.reload('LAY-list-manage');
  964. } else {
  965. layer.msg(data);
  966. }
  967. }
  968. });
  969. });
  970. },
  971. };
  972. $('.layui-btn').on('click', function () {
  973. var type = $(this).data('type');
  974. active[type] ? active[type].call(this) : '';
  975. });
  976. });