ToChargeBackRecord_Admin.js 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455
  1. var ExcelData, ExcelKind;
  2. //机具扣款退还
  3. function ConfirmImport() {
  4. $.ajax({
  5. type: "POST",
  6. url: "/Admin/ToChargeBackRecord/Import?r=" + Math.random(1),
  7. data: "ExcelData=" + encodeURIComponent(JSON.stringify(ExcelData)),
  8. dataType: "text",
  9. success: function (data) {
  10. if (data == "success") {
  11. layer.msg("导入成功", { time: 2000 }, function () {
  12. window.location.reload();
  13. });
  14. } else if (data.indexOf("Warning") == 0) {
  15. var datalist = data.split('|');
  16. console.log(datalist);
  17. layer.alert(datalist[1], { time: 20000 }, function () {
  18. window.location.reload();
  19. });
  20. } else {
  21. layer.msg(data);
  22. }
  23. }
  24. });
  25. }
  26. //机具回收确认退还
  27. function ConfirmImports() {
  28. $.ajax({
  29. type: "POST",
  30. url: "/Admin/ToChargeBackRecord/Imports?r=" + Math.random(1),
  31. data: "ExcelData=" + encodeURIComponent(JSON.stringify(ExcelData)),
  32. dataType: "text",
  33. success: function (data) {
  34. if (data == "success") {
  35. layer.msg("导入成功", { time: 2000 }, function () {
  36. window.location.reload();
  37. });
  38. } else if (data.indexOf("warning") == 0) {
  39. var datalist = data.split('|');
  40. layer.alert(datalist[0], { time: 20000 }, function () {
  41. window.location.reload();
  42. });
  43. } else {
  44. layer.msg(data);
  45. }
  46. }
  47. });
  48. }
  49. var excel;
  50. layui.config({
  51. base: '/layuiadmin/' //静态资源所在路径
  52. }).extend({
  53. myexcel: 'layui/lay/modules/excel',
  54. index: 'lib/index' //主入口模块
  55. }).use(['index', 'table', 'excel', 'laydate'], function () {
  56. var $ = layui.$
  57. , form = layui.form
  58. , table = layui.table;
  59. //- 筛选条件-日期
  60. var laydate = layui.laydate;
  61. var layCreateDate = laydate.render({
  62. elem: '#CreateDate',
  63. type: 'date',
  64. range: true,
  65. trigger: 'click',
  66. change: function (value, date, endDate) {
  67. var op = true;
  68. if (date.year == endDate.year && endDate.month - date.month <= 1) {
  69. if (endDate.month - date.month == 1 && endDate.date > date.date) {
  70. op = false;
  71. layCreateDate.hint('日期范围请不要超过1个月');
  72. setTimeout(function () {
  73. $(".laydate-btns-confirm").addClass("laydate-disabled");
  74. }, 1);
  75. }
  76. } else {
  77. op = false;
  78. layCreateDate.hint('日期范围请不要超过1个月');
  79. setTimeout(function () {
  80. $(".laydate-btns-confirm").addClass("laydate-disabled");
  81. }, 1);
  82. }
  83. if (op) {
  84. $('#CreateDate').val(value);
  85. }
  86. }
  87. });
  88. //excel导入
  89. excel = layui.excel;
  90. $('#ExcelFile').change(function (e) {
  91. var files = e.target.files;
  92. excel.importExcel(files, {}, function (data) {
  93. ExcelData = data[0].sheet1;
  94. });
  95. });
  96. //监听单元格编辑
  97. table.on('edit(LAY-list-manage)', function (obj) {
  98. var value = obj.value //得到修改后的值
  99. , data = obj.data //得到所在行所有键值
  100. , field = obj.field; //得到字段
  101. if (field == "Sort") {
  102. $.ajax({
  103. type: "POST",
  104. url: "/Admin/ToChargeBackRecord/Sort?r=" + Math.random(1),
  105. data: "Id=" + data.Id + "&Sort=" + value,
  106. dataType: "text",
  107. success: function (data) {
  108. }
  109. });
  110. }
  111. });
  112. //列表数据
  113. table.render({
  114. elem: '#LAY-list-manage'
  115. , url: '/Admin/ToChargeBackRecord/IndexData' //模拟接口
  116. , cols: [[
  117. { type: 'checkbox', fixed: 'left' }
  118. , { field: 'Id', fixed: 'left', title: 'ID', width: 80, sort: true, unresize: true }
  119. , { field: 'UserIdMakerCode', width: 200, title: '创客创客编号', sort: true }
  120. , { field: 'UserIdRealName', width: 200, title: '创客真实姓名', sort: true }
  121. , { field: 'CreateDate', width: 200, title: '创建时间', sort: true }
  122. , { field: 'ChargeAmount', width: 200, title: '待扣金额', sort: true }
  123. , { field: 'ChargeType', width: 200, title: '待扣类型', sort: true }
  124. , { field: 'Status', width: 200, title: '扣款状态', sort: true }
  125. , { field: 'Remark', width: 200, title: '机具Sn', sort: true }
  126. , { field: 'Sort', fixed: 'right', title: '排序', width: 80, edit: 'text' }
  127. , { title: '操作', align: 'center', fixed: 'right', toolbar: '#table-list-tools' }
  128. ]]
  129. , where: {
  130. }
  131. , page: true
  132. , limit: 30
  133. , height: 'full-220'
  134. , text: '对不起,加载出现异常!'
  135. , done: function (res, curr, count) {
  136. $(".layui-none").text("无数据");
  137. }
  138. });
  139. //监听工具条
  140. table.on('tool(LAY-list-manage)', function (obj) {
  141. var data = obj.data;
  142. if (obj.event === 'del') {
  143. var index = layer.confirm('确定要删除吗?删除后不能恢复!', function (index) {
  144. $.ajax({
  145. type: "POST",
  146. url: "/Admin/ToChargeBackRecord/Delete?r=" + Math.random(1),
  147. data: "Id=" + data.Id,
  148. dataType: "text",
  149. success: function (data) {
  150. if (data == "success") {
  151. obj.del();
  152. layer.close(index);
  153. } else {
  154. parent.layer.msg(data);
  155. }
  156. }
  157. });
  158. });
  159. } else if (obj.event === 'edit') {
  160. var tr = $(obj.tr);
  161. var perContent = layer.open({
  162. type: 2
  163. , title: '待扣款明细-编辑'
  164. , content: 'Edit?Id=' + data.Id + ''
  165. , maxmin: true
  166. , area: ['500px', '450px']
  167. , btn: ['确定', '取消']
  168. , yes: function (index, layero) {
  169. var iframeWindow = window['layui-layer-iframe' + index]
  170. , submitID = 'LAY-list-front-submit'
  171. , submit = layero.find('iframe').contents().find('#' + submitID);
  172. setTimeout(function () {
  173. layero.find('iframe').contents().find('.layui-tab-item').each(function (i) {
  174. var errObj = $(this).find('.layui-form-danger');
  175. if (errObj.length > 0) {
  176. iframeWindow.element.tabChange('mytabbar', String(i + 1));
  177. submit.click();
  178. }
  179. });
  180. }, 300);
  181. //监听提交
  182. iframeWindow.layui.form.on('submit(' + submitID + ')', function (data) {
  183. var field = data.field; //获取提交的字段
  184. var userdata = "";
  185. for (var prop in field) {
  186. userdata += prop + "=" + encodeURIComponent(field[prop]) + "&";
  187. }
  188. //提交 Ajax 成功后,静态更新表格中的数据
  189. //$.ajax({});
  190. $.ajax({
  191. type: "POST",
  192. url: "/Admin/ToChargeBackRecord/Edit?r=" + Math.random(1),
  193. data: userdata,
  194. dataType: "text",
  195. success: function (data) {
  196. layer.close(index); //关闭弹层
  197. if (data == "success") {
  198. table.reload('LAY-list-manage'); //数据刷新
  199. } else {
  200. layer.msg(data);
  201. }
  202. }
  203. });
  204. });
  205. submit.trigger('click');
  206. }
  207. , success: function (layero, index) {
  208. }
  209. });
  210. layer.full(perContent);
  211. }
  212. });
  213. //监听搜索
  214. form.on('submit(LAY-list-front-search)', function (data) {
  215. var field = data.field;
  216. //执行重载
  217. table.reload('LAY-list-manage', {
  218. where: field,
  219. page: {
  220. curr: 1
  221. }
  222. });
  223. });
  224. form.on('submit(LAY-list-front-searchall)', function (data) {
  225. table.reload('LAY-list-manage', {
  226. where: null,
  227. page: {
  228. curr: 1
  229. }
  230. });
  231. });
  232. //事件
  233. var active = {
  234. batchdel: function () {
  235. var checkStatus = table.checkStatus('LAY-list-manage')
  236. , data = checkStatus.data; //得到选中的数据
  237. if (data.length < 1) {
  238. parent.layer.msg("请选择要删除的项");
  239. } else {
  240. var ids = "";
  241. $.each(data, function (index, value) {
  242. ids += data[index].Id + ",";
  243. });
  244. ids = ids.substring(0, ids.length - 1);
  245. var index = layer.confirm('确定要删除吗?删除后不能恢复!', function (index) {
  246. $.ajax({
  247. type: "POST",
  248. url: "/Admin/ToChargeBackRecord/Delete?r=" + Math.random(1),
  249. data: "Id=" + ids,
  250. dataType: "text",
  251. success: function (data) {
  252. layer.close(index);
  253. if (data == "success") {
  254. table.reload('LAY-list-manage');
  255. } else {
  256. layer.msg(data);
  257. }
  258. }
  259. });
  260. });
  261. }
  262. }
  263. , add: function () {
  264. var perContent = layer.open({
  265. type: 2
  266. , title: '待扣款明细-添加'
  267. , content: 'Add'
  268. , maxmin: true
  269. , area: ['500px', '450px']
  270. , btn: ['确定', '取消']
  271. , yes: function (index, layero) {
  272. var iframeWindow = window['layui-layer-iframe' + index]
  273. , submitID = 'LAY-list-front-submit'
  274. , submit = layero.find('iframe').contents().find('#' + submitID);
  275. setTimeout(function () {
  276. layero.find('iframe').contents().find('.layui-tab-item').each(function (i) {
  277. var errObj = $(this).find('.layui-form-danger');
  278. if (errObj.length > 0) {
  279. iframeWindow.element.tabChange('mytabbar', String(i + 1));
  280. submit.click();
  281. }
  282. });
  283. }, 300);
  284. //监听提交
  285. iframeWindow.layui.form.on('submit(' + submitID + ')', function (data) {
  286. var field = data.field; //获取提交的字段
  287. var userdata = "";
  288. for (var prop in field) {
  289. userdata += prop + "=" + encodeURIComponent(field[prop]) + "&";
  290. }
  291. //提交 Ajax 成功后,静态更新表格中的数据
  292. //$.ajax({});
  293. $.ajax({
  294. type: "POST",
  295. url: "/Admin/ToChargeBackRecord/Add?r=" + Math.random(1),
  296. data: userdata,
  297. dataType: "text",
  298. success: function (data) {
  299. layer.close(index); //关闭弹层
  300. if (data == "success") {
  301. table.reload('LAY-list-manage'); //数据刷新
  302. } else {
  303. layer.msg(data);
  304. }
  305. }
  306. });
  307. });
  308. submit.trigger('click');
  309. }
  310. });
  311. layer.full(perContent);
  312. }
  313. , ImportData: function () {
  314. ExcelKind = 1;
  315. layer.open({
  316. type: 1,
  317. title: '导入',
  318. maxmin: false,
  319. area: ['460px', '280px'],
  320. content: $('#excelForm'),
  321. cancel: function () {
  322. }
  323. });
  324. $("#excelTemp").html('<a href="/users/机具扣款退还模版.xlsx">点击下载机具扣款退还模版文件</a>');
  325. }
  326. , ImportDatas: function () {
  327. ExcelKind = 1;
  328. layer.open({
  329. type: 1,
  330. title: '导入',
  331. maxmin: false,
  332. area: ['460px', '280px'],
  333. content: $('#excelForm'),
  334. cancel: function () {
  335. }
  336. });
  337. $("#excelTemp").html('<a href="/users/机具扣款退还模版.xlsx">点击下载机具扣款退还模版文件</a>');
  338. }
  339. , ExportExcel: function () {
  340. var userdata = '';
  341. $(".layuiadmin-card-header-auto input").each(function (i) {
  342. userdata += $(this).attr('name') + '=' + encodeURIComponent($(this).val()) + '&';
  343. });
  344. $(".layuiadmin-card-header-auto select").each(function (i) {
  345. userdata += $(this).attr('name') + '=' + encodeURIComponent($(this).val()) + '&';
  346. });
  347. $.ajax({
  348. type: "GET",
  349. url: "/Admin/ToChargeBackRecord/ExportExcel?r=" + Math.random(1),
  350. data: userdata,
  351. dataType: "json",
  352. success: function (data) {
  353. data.Obj.unshift(data.Fields);
  354. excel.exportExcel(data.Obj, data.Info, 'xlsx');
  355. }
  356. });
  357. }
  358. , Open: function () {
  359. var checkStatus = table.checkStatus('LAY-list-manage')
  360. , data = checkStatus.data; //得到选中的数据
  361. if (data.length < 1) {
  362. parent.layer.msg("请选择要开启的项");
  363. } else {
  364. var ids = "";
  365. $.each(data, function (index, value) {
  366. ids += data[index].Id + ",";
  367. });
  368. ids = ids.substring(0, ids.length - 1);
  369. var index = layer.confirm('确定要开启吗?', function (index) {
  370. $.ajax({
  371. type: "POST",
  372. url: "/Admin/ToChargeBackRecord/Open?r=" + Math.random(1),
  373. data: "Id=" + ids,
  374. dataType: "text",
  375. success: function (data) {
  376. layer.close(index);
  377. if (data == "success") {
  378. table.reload('LAY-list-manage');
  379. } else {
  380. layer.msg(data);
  381. }
  382. }
  383. });
  384. });
  385. }
  386. }
  387. , Close: function () {
  388. var checkStatus = table.checkStatus('LAY-list-manage')
  389. , data = checkStatus.data; //得到选中的数据
  390. if (data.length < 1) {
  391. parent.layer.msg("请选择要关闭的项");
  392. } else {
  393. var ids = "";
  394. $.each(data, function (index, value) {
  395. ids += data[index].Id + ",";
  396. });
  397. ids = ids.substring(0, ids.length - 1);
  398. var index = layer.confirm('确定要关闭吗?', function (index) {
  399. $.ajax({
  400. type: "POST",
  401. url: "/Admin/ToChargeBackRecord/Close?r=" + Math.random(1),
  402. data: "Id=" + ids,
  403. dataType: "text",
  404. success: function (data) {
  405. layer.close(index);
  406. if (data == "success") {
  407. table.reload('LAY-list-manage');
  408. } else {
  409. layer.msg(data);
  410. }
  411. }
  412. });
  413. });
  414. }
  415. }
  416. };
  417. $('.layui-btn').on('click', function () {
  418. var type = $(this).data('type');
  419. active[type] ? active[type].call(this) : '';
  420. });
  421. });