ITP_MRTNMNG02010.js 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658
  1. require(['config'], function() {
  2. require([
  3. ], function($) {
  4. mobPageObj.init();
  5. });
  6. });
  7. /*API URL*/
  8. const API_MOBILE_GRID_LIST = '/api/rtnmng/detail-grid-list'; // 목록
  9. const API_MOBILE_INFO = '/api/rtnmng/info-rtnReq'; // 상세
  10. const API_MOBILE_SAVE = '/api/rtnmng/save-rtnReq'; // 저장
  11. const API_POP_SEARCH_LIST = '/api/whs/mng/pop-whs-search';
  12. const API_POP_ITEM_LIST = '/api/item/pop-grid-list';
  13. const RTN_REQ_ST_CD_TEMP_SAVE ="RR00";
  14. const RTN_REQ_ST_CD_REQUEST_SAVE ="RR20";
  15. const VIEW_MODE_LIST = "LIST";
  16. const VIEW_MODE_DETAIL = "DETAIL";
  17. const VIEW_MODE_MODIFY = "MODIFY";
  18. let mobPageObj = {
  19. viewMode: VIEW_MODE_LIST,
  20. init: function () {
  21. this.ui.init();
  22. this.event.init();
  23. this.ready();
  24. },
  25. ui: {
  26. init: function () {
  27. this.view();
  28. this.info();
  29. this.action();
  30. },
  31. view: function() {
  32. // 공통코드 표시
  33. $('select').each(function() {
  34. if($(this).data('select-code')) {
  35. fn_make_select(CODE_LIST, $(this).data('select-code'), $(this).attr('id'));
  36. }
  37. });
  38. // 조회일자 지정
  39. $('#ITP_MOBILE_MRTNMNG02010 .itp_input.date').datepicker(ITP_DATE_LANGUAGE);
  40. $('#ITP_FORM_MRTNMNG02010_LIST_SEARCH_FROM_DT').datepicker('setDate', itp_fn_date_add('M', 0));
  41. $('#ITP_FORM_MRTNMNG02010_LIST_SEARCH_TO_DT').datepicker('setDate', itp_fn_date_add('M', 1));
  42. },
  43. info: function() {
  44. $('input:hidden[id$="_BRAND_ID"]').val(fn_make_user_info.get('brandId'));
  45. $('input:hidden[id$="_STORE_ID"]').val(fn_make_user_info.get('storeId'));
  46. },
  47. action: function() {
  48. }
  49. },
  50. event: {
  51. init: function() {
  52. this.button();
  53. },
  54. button: function() {
  55. $('button[id^="ITP_BTN_MRTNMNG02010_LIST"]').on('click', function() {
  56. var id = $(this).attr('id');
  57. switch (id) {
  58. case 'ITP_BTN_MRTNMNG02010_LIST_SEARCH_WHS_NM' : mobPopObj.popWhsNm.init(VIEW_MODE_LIST); break;
  59. case 'ITP_BTN_MRTNMNG02010_LIST_DELETE_WHS_NM' : mobPopObj.popWhsNm.delete(VIEW_MODE_LIST); break;
  60. case 'ITP_BTN_MRTNMNG02010_LIST_SEARCH' : mobContObj.list.search(); break;
  61. }
  62. return false;
  63. });
  64. $('button[id^="ITP_BTN_MRTNMNG02010_DETAIL"]').on('click', function() {
  65. var id = $(this).attr('id');
  66. switch (id) {
  67. case 'ITP_BTN_MRTNMNG02010_DETAIL_CANCEL_LIST' : mobContObj.detail.cancel(); break;
  68. }
  69. return false;
  70. });
  71. $('button[id^="ITP_BTN_MRTNMNG02010_MODIFY"]').on('click', function() {
  72. var id = $(this).attr('id');
  73. switch (id) {
  74. case 'ITP_BTN_MRTNMNG02010_MODIFY_SEARCH_WHS_NM' : mobPopObj.popWhsNm.init(VIEW_MODE_MODIFY); break;
  75. case 'ITP_BTN_MRTNMNG02010_MODIFY_DELETE_WHS_NM' : mobPopObj.popWhsNm.delete(VIEW_MODE_MODIFY); break;
  76. case 'ITP_BTN_MRTNMNG02010_MODIFY_ADD_ROW' : mobPopObj.popItem.init(); break;
  77. case 'ITP_BTN_MRTNMNG02010_MODIFY_DEL_ROW' : mobContObj.modify.list.detachRow(); break;
  78. case 'ITP_BTN_MRTNMNG02010_MODIFY_CANCEL' : mobContObj.modify.cancel(); break;
  79. case 'ITP_BTN_MRTNMNG02010_MODIFY_REQ_ORDER' : mobPopObj.popReqConfirm.init(RTN_REQ_ST_CD_REQUEST_SAVE); break;
  80. case 'ITP_BTN_MRTNMNG02010_MODIFY_TEMP_SAVE' : mobPopObj.popReqConfirm.init(RTN_REQ_ST_CD_TEMP_SAVE); break;
  81. }
  82. return false;
  83. });
  84. $(document).on('click', '#ITP_LIST_MRTNMNG02010_LIST_ROWS li', function() {
  85. var index = $(this).index();
  86. var item = mobContObj.list.rows[index];
  87. (item.rtnReqStCd === RTN_REQ_ST_CD_TEMP_SAVE) ?
  88. (item.rtnReqMgrId === fn_make_user_info.get('userId')) ? mobContObj.modify.init(item) : mobContObj.detail.init(item) :
  89. mobContObj.detail.init(item);
  90. });
  91. // $(document).on('click', '#ITP_LIST_MRTNMNG02010_MODIFY_ROWS li', function(e) {
  92. // if($(e.target).hasClass('DETAIL_ITEM_PLUS')) {
  93. // mobContObj.modify.list.actPlus($(this));
  94. // } else if($(e.target).hasClass('DETAIL_ITEM_MINUS')) {
  95. // mobContObj.modify.list.actMinus($(this));
  96. // } else {
  97. // }
  98. // });
  99. $(document).off('click', '#ITP_LIST_MRTNMNG02010_POP_WHS_ROWS li button');
  100. $(document).on('click', '#ITP_LIST_MRTNMNG02010_POP_WHS_ROWS li button', function() {
  101. mobPopObj.popWhsNm.choice($(this));
  102. });
  103. }
  104. },
  105. switchScreen: function(mode) {
  106. $('#ITP_MOBILE_MRTNMNG02010').find('div[id$="_CONTAINER"]').each(function(i) {
  107. $(this).hide();
  108. });
  109. if(mode === VIEW_MODE_LIST) {
  110. $('#ITP_AJAX_MRTNMNG02010_LIST_CONTAINER').show();
  111. } else if(mode === VIEW_MODE_DETAIL) {
  112. $('#ITP_AJAX_MRTNMNG02010_DETAIL_CONTAINER').show();
  113. CommonObj.moreView('#ITP_LIST_MRTNMNG02010_LIST_AREA', false);
  114. } else if(mode === VIEW_MODE_MODIFY) {
  115. $('#ITP_AJAX_MRTNMNG02010_MODIFY_CONTAINER').show();
  116. CommonObj.moreView('#ITP_LIST_MRTNMNG02010_LIST_AREA', false);
  117. }
  118. this.viewMode = mode;
  119. },
  120. ready: function() {
  121. mobContObj.list.init();
  122. }
  123. };
  124. let mobContObj = {
  125. list: {
  126. listPage: 1,
  127. rows: [],
  128. init: function() {
  129. mobPageObj.switchScreen(VIEW_MODE_LIST);
  130. this.search();
  131. },
  132. search: function() {
  133. this.listPage = 1;
  134. this.rows.length = 0;
  135. $('#ITP_LIST_MRTNMNG02010_LIST_ROWS').empty();
  136. setTimeout(function() {
  137. mobContObj.list.load();
  138. }, 100);
  139. },
  140. pager: function(totPage) {
  141. (this.listPage < totPage) ?
  142. CommonObj.moreView('#ITP_LIST_MRTNMNG02010_ITEM_AREA', true, mobContObj.list.load) :
  143. CommonObj.moreView('#ITP_LIST_MRTNMNG02010_ITEM_AREA', false);
  144. this.listPage += 1;
  145. },
  146. load: function() {
  147. var _this = this;
  148. var callbackFn = function(result) {
  149. console.log(result);
  150. mobContObj.list.pager(result.gridTotal);
  151. $.each(result.gridRows, function (i, item) {
  152. $('#ITP_LIST_MRTNMNG02010_LIST_AREA .panel-group').append($('#ITP_LIST_MRTNMNG02010_LIST_ROWCOPY').html());
  153. var $li = $('#ITP_LIST_MRTNMNG02010_LIST_AREA .panel-group > .history_list5:last');
  154. // $li.find('.fnRtnReqUnqNo').text(item.rtnReqUnqNo);
  155. $li.find('.fnRtnReqDt').text(item.colReqDt);
  156. // $li.find('.fnRtnReqDt').text(item.rtnReqStCd === 'RR00' ? item.colReqDt : item.rtnReqDt);
  157. $li.find('.fnRtnReqMgrNm').text(item.rtnReqMgrNm);
  158. $li.find('.fnRtnReqStNm').text(item.rtnReqStNm);
  159. $li.find('.fnRtnReqAmt').text(CommonObj.currency.add(item.rtnReqAmt));
  160. $li.find('.fnRtnReqItemQty').text(CommonObj.comma.set(item.rtnReqItemQty));
  161. $li.find('.fnRtnWhsNm').text(item.rtnWhsNm);
  162. $li.find('.fnRtnReqRjctNm').text(item.pchReqRjctNm);
  163. mobContObj.list.rows.push(item);
  164. });
  165. };
  166. const param = $('#ITP_FORM_MRTNMNG02010_LIST_SEARCH').serializeObject();
  167. param.gridPage = mobContObj.list.listPage;
  168. param.gridSize = mobile_list_size;
  169. fn_ajax_call(API_MOBILE_GRID_LIST, JSON.stringify(param), callbackFn, 'POST');
  170. },
  171. },
  172. detail: {
  173. rows: [],
  174. init: function(item) {
  175. mobPageObj.switchScreen(VIEW_MODE_DETAIL);
  176. this.search(item);
  177. },
  178. search: function(item) {
  179. var _this = this;
  180. var callbackFn = function(result) {
  181. console.log(result);
  182. _this.view(result);
  183. };
  184. const param = {'brandId':fn_make_user_info.get('brandId'), 'rtnReqUnqNo': item.rtnReqUnqNo};
  185. fn_ajax_call(API_MOBILE_INFO, param, callbackFn, 'GET');
  186. },
  187. view: function(result) {
  188. var _this = this;
  189. var id = '#ITP_AJAX_MRTNMNG02010_DETAIL_CONTAINER';
  190. $(id).find('.fnRtnReqDt').text(result.rtnReqDt);
  191. $(id).find('.fnRtnReqAmt').text(CommonObj.currency.add(result.rtnReqAmt));
  192. $(id).find('.fnRtnWhsNm').text(result.rtnWhsNm);
  193. $(id).find('.fnRtnApprNm').text('(' + result.pchApprNm + ')' + CommonObj.currency.add(result.pchApprAmt));
  194. $.each(result.rtnReqDtlList, function (i, item) {
  195. $('#ITP_LIST_MRTNMNG02010_DETAIL_AREA .panel-group').append($('#ITP_LIST_MRTNMNG02010_DETAIL_ROWCOPY').html());
  196. var $li = $('#ITP_LIST_MRTNMNG02010_DETAIL_AREA .panel-group > .item-row:last');
  197. $li.find('.fnItemNm').text(item.itemNm);
  198. $li.find('.fnUnit').text(item.unit);
  199. $li.find('.fnRtnAmt').text(CommonObj.comma.set(item.rtnAmt));
  200. $li.find('.fnRtnQty').text(CommonObj.currency.add(item.rtnQty, ''));
  201. _this.rows.push(item);
  202. });
  203. },
  204. cancel: function () {
  205. this.rows.length = 0;
  206. var id = '#ITP_AJAX_MRTNMNG02010_DETAIL_CONTAINER';
  207. $(id).find('.fnDlvReqDt').text('');
  208. $(id).find('.fnRtnReqTotalAmt').text('');
  209. $(id).find('.fnLocationNm').text('');
  210. $(id).find('.fnRtnApprNm').text('');
  211. $('#ITP_LIST_MRTNMNG02010_DETAIL_AREA .panel-group').empty();
  212. mobPageObj.switchScreen(VIEW_MODE_LIST);
  213. }
  214. },
  215. modify: {
  216. init: function(item) {
  217. mobPageObj.switchScreen(VIEW_MODE_MODIFY);
  218. this.clear();
  219. this.search(item);
  220. },
  221. search: function(item) {
  222. var _this = this;
  223. var callbackFn = function(result) {
  224. console.log(result);
  225. _this.view(result);
  226. };
  227. const param = {'brandId':fn_make_user_info.get('brandId'), 'rtnReqUnqNo': item.rtnReqUnqNo};
  228. fn_ajax_call(API_MOBILE_INFO, param, callbackFn, 'GET');
  229. },
  230. view: function(result) {
  231. var _this = this;
  232. var id = '#ITP_AJAX_MRTNMNG02010_MODIFY_CONTAINER';
  233. $('#ITP_FORM_MRTNMNG02010_MODIFY #ITP_FORM_MRTNMNG02010_MODIFY_COL_REQ_DT').val(result.colReqDt.replace(/\./g, "."));
  234. $('#ITP_FORM_MRTNMNG02010_MODIFY_COL_REQ_DT').datepicker('setDate', result.colReqDt.replace(/\./g, "."));
  235. $(id).find('.fnRtnReqTotalAmt').text(CommonObj.currency.add(result.pchReqTotalAmt));
  236. $(id).find('.fnOrdUseAmt').text(CommonObj.currency.add(result.ordUseAmt));
  237. $('#ITP_FORM_MRTNMNG02010_MODIFY #ITP_FORM_MRTNMNG02010_MODIFY_RTN_REQ_UNQ_NO').val(result.rtnReqUnqNo);
  238. $('#ITP_FORM_MRTNMNG02010_MODIFY #ITP_FORM_MRTNMNG02010_MODIFY_WHS_DVSN').val(result.whsDvsn);
  239. $('#ITP_FORM_MRTNMNG02010_MODIFY #ITP_FORM_MRTNMNG02010_MODIFY_RTN_REQ_MGR_ID').val(result.rtnReqMgrId);
  240. $('#ITP_FORM_MRTNMNG02010_MODIFY #ITP_FORM_MRTNMNG02010_MODIFY_WHS_NM').val(result.rtnWhsNm);
  241. $('#ITP_FORM_MRTNMNG02010_MODIFY #ITP_FORM_MRTNMNG02010_MODIFY_WHS_ID').val(result.rtnWhsId);
  242. $('#ITP_FORM_MRTNMNG02010_MODIFY #ITP_FORM_MRTNMNG02010_MODIFY_LOCATION').val(result.rtnLocation);
  243. _this.list.init(result.rtnReqDtlList);
  244. },
  245. list: {
  246. rows: [],
  247. init: function(rtnReqDtlList) {
  248. var _this = this;
  249. var existRows = [];
  250. $.each(rtnReqDtlList, function (i, item) {
  251. item['viewCd'] = 'U';
  252. existRows.push(item);
  253. });
  254. this.attachRow(existRows);
  255. },
  256. attachRow: function (items) {
  257. var _this = this;
  258. var fnIsNotExist = function(rows, item) {
  259. var isPushRow = true;
  260. var isAddItem = true;
  261. $.each(rows, function(i, row) {
  262. if(row.brandUnitUnqNo === item.brandUnitUnqNo) {
  263. if(row.viewCd === 'D') {
  264. row.viewCd = 'U';
  265. row.rtnQty = item.rtnQty;
  266. } else {
  267. isAddItem = false;
  268. }
  269. isPushRow = false;
  270. return false;
  271. }
  272. });
  273. if(isPushRow) _this.rows.push(item);
  274. return isAddItem;
  275. };
  276. $.each(items, function(i, item) {
  277. if(fnIsNotExist(_this.rows, item)) {
  278. $('#ITP_LIST_MRTNMNG02010_MODIFY_AREA .mb_0').append($('#ITP_LIST_MRTNMNG02010_MODIFY_ROWCOPY').html());
  279. var $li = $('#ITP_LIST_MRTNMNG02010_MODIFY_AREA .mb_0 > .item-row:last');
  280. $li.find('.fnBrandUnitUnqNo').val(item.brandUnitUnqNo);
  281. $li.find('.fnItemNm').text(item.itemNm);
  282. $li.find('.fnRtnQty').text(item.rtnQty);
  283. $li.find('.fnUnitAmt').text(CommonObj.currency.add(item.unitAmt));
  284. $li.find('.fnOrdAmt').text(CommonObj.currency.add(Number(item.unitAmt) * Number(item.rtnQty)));
  285. $('.item-row .DETAIL_ITEM_PLUS')[$li.index()].addEventListener('click', function() { _this.actPlus(this); });
  286. $('.item-row .DETAIL_ITEM_MINUS')[$li.index()].addEventListener('click', function() { _this.actMinus(this); });
  287. _this.rtnReqAmtTot();
  288. }
  289. });
  290. },
  291. detachRow: function () {
  292. if($('#ITP_LIST_MRTNMNG02010_MODIFY_AREA input:checkbox[name=brandUnitUnqNo]:checked').length > 0) {
  293. var _this = this;
  294. $('#ITP_LIST_MRTNMNG02010_MODIFY_ROWS li').each(function(index, elem) {
  295. var __this = this;
  296. var isChecked = $(this).find('input[type="checkbox"]').is(':checked');
  297. if(isChecked) {
  298. if(_this.rows[index].viewCd === 'U') {
  299. _this.rows[index].viewCd = 'D';
  300. } else {
  301. $.each(_this.rows, function(i, row){
  302. if(row.brandUnitUnqNo === $(__this).find('input[type="checkbox"]').val()) {
  303. _this.rows.splice(i, 1);
  304. return false;
  305. }
  306. });
  307. }
  308. $(this).remove();
  309. }
  310. });
  311. this.rtnReqAmtTot();
  312. }
  313. },
  314. actPlus: function(elem) {
  315. var $li = $(elem).closest('li');
  316. var num = Number($li.find('.fnRtnQty').text());
  317. var calcNum = num + 1;
  318. $($li).find('.fnRtnQty').text(calcNum.toString());
  319. this.rows[$li.index()]['rtnQty'] = calcNum;
  320. this.rtnReqAmtUnit(elem, calcNum);
  321. this.rtnReqAmtTot();
  322. },
  323. actMinus: function(elem) {
  324. var $div = $(elem).siblings('div');
  325. var num = Number($div.text());
  326. if(num <= 1) {
  327. itp_fn_modal_alert('수량을 확인하세요.');
  328. } else {
  329. $($div).text((num - 1).toString());
  330. this.rows[$div.parents('li').index()]['rtnQty'] = $($div).text();
  331. this.rtnReqAmtUnit(elem, $($div).text());
  332. this.rtnReqAmtTot();
  333. }
  334. },
  335. rtnReqAmtUnit: function(elem, qty) {
  336. var $div = $(elem).parent().prev();
  337. var unitAmt = CommonObj.onlyNumber($div.find('.fnUnitAmt').text());
  338. $div.find('.fnOrdAmt').text(CommonObj.currency.add(Number(unitAmt ? unitAmt : 0) * Number(qty)));
  339. },
  340. rtnReqAmtTot: function() {
  341. var reqAmt = 0;
  342. $.each(this.rows, function(index, item) {
  343. if(item.viewCd !== 'D') {
  344. var qty = item.rtnQty;
  345. var amt = item.unitAmt;
  346. reqAmt += Number(qty) * amt;
  347. }
  348. });
  349. $('#ITP_FORM_MRTNMNG02010_MODIFY').find('.fnRtnReqAmtTot').text(CommonObj.currency.add(reqAmt));
  350. }
  351. },
  352. cancel: function () {
  353. mobPageObj.switchScreen(VIEW_MODE_LIST);
  354. },
  355. clear: function() {
  356. this.list.rows.length = 0;
  357. var id = '#ITP_AJAX_MRTNMNG02010_MODIFY_CONTAINER';
  358. $(id).find('.fnDlvReqDt').val('');
  359. $(id).find('.fnRtnReqTotalAmt').text('');
  360. $(id).find('.fnOrdUseAmt').text('');
  361. $('#ITP_FORM_MRTNMNG02010_MODIFY #ITP_FORM_MRTNMNG02010_MODIFY_COL_REQ_DT').val('');
  362. $('#ITP_FORM_MRTNMNG02010_MODIFY #ITP_FORM_MRTNMNG02010_MODIFY_RTN_REQ_UNQ_NO').val('');
  363. $('#ITP_FORM_MRTNMNG02010_MODIFY #ITP_FORM_MRTNMNG02010_MODIFY_WHS_DVSN').val('');
  364. $('#ITP_FORM_MRTNMNG02010_MODIFY #ITP_FORM_MRTNMNG02010_MODIFY_RTN_REQ_MGR_ID').val('');
  365. $('#ITP_FORM_MRTNMNG02010_MODIFY #ITP_FORM_MRTNMNG02010_MODIFY_WHS_NM').val('');
  366. $('#ITP_FORM_MRTNMNG02010_MODIFY #ITP_FORM_MRTNMNG02010_MODIFY_WHS_ID').val('');
  367. $('#ITP_FORM_MRTNMNG02010_MODIFY #ITP_FORM_MRTNMNG02010_MODIFY_LOCATION').val('');
  368. $('#ITP_LIST_MRTNMNG02010_MODIFY_ROWS').children().remove();
  369. }
  370. }
  371. };
  372. let mobPopObj = {
  373. popItem: {
  374. popId: 'ITP_POP_MRTNMNG02010_ITEM_AREA',
  375. init: function() {
  376. mobPopObj.show(this.popId);
  377. $('#ITP_POP_MRTNMNG02010_ITEM_AREA #ITP_FORM_MRTNMNG02010_POP_ITEM_KEYWORD').val('');
  378. this.search();
  379. },
  380. search: function() {
  381. $('#ITP_LIST_MRTNMNG02010_POP_ITEM_AREA .panel-group').empty();
  382. var callbackFn = function(result) {
  383. console.log(result);
  384. mobPopObj.popItem.rows = result.gridRows;
  385. $.each(mobPopObj.popItem.rows, function (i, item) {
  386. $('#ITP_LIST_MRTNMNG02010_POP_ITEM_AREA .panel-group').append($('#ITP_LIST_MRTNMNG02010_POP_ITEM_ROWCOPY').html());
  387. var $li = $('#ITP_LIST_MRTNMNG02010_POP_ITEM_AREA .panel-group > .row_2:last');
  388. $li.find('#ITP_FORM_MRTNMNG02010_POP_ITEM_CHECKBOX').val(item.itemId);
  389. $li.find('.fnItemNm').text(item.itemNm);
  390. $li.find('.fnUnitAmt').text(CommonObj.currency.add(item.unitAmt));
  391. $li.find('.fnOrdAmt').text(CommonObj.currency.add(item.unitAmt));
  392. });
  393. mobPopObj.popItem.addRow.init();
  394. };
  395. let param = $('#ITP_FORM_MRTNMNG02010_POPUP_ITEM').serializeObject();
  396. fn_ajax_call(API_POP_ITEM_LIST, JSON.stringify(param), callbackFn, 'POST');
  397. },
  398. addRow: {
  399. init: function() {
  400. this.button.init();
  401. },
  402. button: {
  403. init: function() {
  404. var _this = this;
  405. $('button[id^="ITP_BTN_MRTNMNG02010_POP_ITEM_"]').off('click').on('click', function() {
  406. var id = $(this).attr('id');
  407. switch (id) {
  408. case 'ITP_BTN_MRTNMNG02010_POP_ITEM_PLUS' : _this.actPlus($(this)); break;
  409. case 'ITP_BTN_MRTNMNG02010_POP_ITEM_MINUS' : _this.actMinus($(this)); break;
  410. case 'ITP_BTN_MRTNMNG02010_POP_ITEM_ADD' : _this.addItems(); break;
  411. // case 'ITP_BTN_MRTNMNG02010_POP_ITEM_ADD' : _this.actItemAdd($(this)); break;
  412. case 'ITP_BTN_MRTNMNG02010_POP_ITEM_SEARCH' : mobPopObj.popItem.search(); break;
  413. case 'ITP_BTN_MRTNMNG02010_POP_ITEM_CLOSE' : mobPopObj.hide(id); break;
  414. }
  415. return false;
  416. });
  417. },
  418. actPlus: function(elem) {
  419. var $div = $(elem).siblings('div');
  420. var num = Number($div.text());
  421. $($div).text((num + 1).toString());
  422. this.reqAmtUnit(elem, $($div).text());
  423. },
  424. actMinus: function(elem) {
  425. var $div = $(elem).siblings('div');
  426. var num = Number($div.text());
  427. if(num <= 1) {
  428. itp_fn_modal_alert('수량을 확인하세요.');
  429. } else {
  430. $($div).text((num - 1).toString());
  431. this.reqAmtUnit(elem, $($div).text());
  432. }
  433. },
  434. reqAmtUnit: function(elem, qty) {
  435. var $li = $(elem).closest('li');
  436. var unitAmt = CommonObj.onlyNumber($li.find('.fnUnitAmt').text());
  437. $li.find('.fnOrdAmt').text(CommonObj.currency.add(Number(unitAmt ? unitAmt : 0) * Number(qty)));
  438. },
  439. actItemAdd: function(elem) {
  440. var $li = $(elem).closest('li');
  441. var item = mobPopObj.popItem.rows[$li.index()];
  442. item['viewCd'] = 'C';
  443. item['rtnQty'] = $li.find('.fnRtnQty').html();
  444. // var index = $(elem).closest('li').index();
  445. // var item = mobPopObj.popItem.rows[index];
  446. // item['pchReqQty'] = $(elem).closest('li').find('.fnPchReqQty').html();
  447. mobContObj.list.attachRow(item);
  448. },
  449. addItems: function() {
  450. var items = [];
  451. $('#ITP_LIST_MRTNMNG02010_POP_ITEM_ROWS').find('input:checkbox').each(function() {
  452. if($(this).is(':checked')) {
  453. var index = $(this).closest('li').index();
  454. var item = mobPopObj.popItem.rows[index];
  455. item['viewCd'] = 'C';
  456. item['rtnQty'] = $(this).closest('li').find('.fnRtnQty').html();
  457. items.push(item);
  458. }
  459. });
  460. if(items.length > 0) {
  461. mobContObj.modify.list.attachRow(items);
  462. mobPopObj.popItem.close();
  463. } else {
  464. itp_fn_modal_alert('품목을 선택하세요.');
  465. }
  466. }
  467. }
  468. },
  469. delRow: function() {
  470. },
  471. close: function() {
  472. this.rows.length = 0;
  473. $('#ITP_LIST_MRTNMNG02010_POP_ITEM_ROWS').children().remove();
  474. mobPopObj.hide('ITP_POP_MRTNMNG02010_ITEM_AREA');
  475. }
  476. },
  477. popWhsNm: {
  478. popId: 'ITP_POP_MRTNMNG02010_WHS_AREA',
  479. mode: '',
  480. rows: [],
  481. init: function (mode) {
  482. this.mode = mode;
  483. $('#ITP_POP_MRTNMNG02010_WHS_AREA #ITP_FORM_MRTNMNG02010_POP_WHS_KEYWORD').val('');
  484. this.rows.length = 0;
  485. mobPopObj.show(this.popId);
  486. this.search();
  487. this.action();
  488. },
  489. search: function () {
  490. var _this = this;
  491. $('#ITP_LIST_MRTNMNG02010_POP_WHS_AREA .panel-group').empty();
  492. var callbackFn = function(result) {
  493. console.log(result);
  494. _this.view(result.gridRows);
  495. };
  496. const param = $('#ITP_FORM_MRTNMNG02010_POP_WHS').serializeObject();
  497. (fn_make_user_info.get('authTpCd') === '50') ? param.swhsDvsn = 'W02' : param.swhsDvsn = mobPageObj.viewMode === VIEW_MODE_LIST ? '' : 'W01';
  498. fn_ajax_call(API_POP_SEARCH_LIST, JSON.stringify(param), callbackFn, 'POST');
  499. },
  500. view: function(gridRows) {
  501. this.rows = gridRows;
  502. $.each(gridRows, function (i, item) {
  503. $('#ITP_LIST_MRTNMNG02010_POP_WHS_AREA .panel-group').append($('#ITP_LIST_MRTNMNG02010_POP_WHS_ROWCOPY').html());
  504. var $li = $('#ITP_LIST_MRTNMNG02010_POP_WHS_AREA .panel-group > .row_2:last');
  505. $li.find('.fnWhsNm').text(item.whsNm);
  506. $li.find('.fnLocationNm').text(item.locationNm);
  507. $li.find('.fnWhsId').data('whs-id', item.whsId);
  508. });
  509. },
  510. choice: function(elem) {
  511. var _this = this;
  512. var whsId = $(elem).data('whs-id');
  513. $.each(this.rows, function (i, item) {
  514. if(whsId === item.whsId) {
  515. if(_this.mode === VIEW_MODE_LIST) {
  516. $('#ITP_FORM_MRTNMNG02010_LIST_SEARCH #ITP_FORM_MRTNMNG02010_LIST_SEARCH_WHS_ID').val(item.whsId);
  517. $('#ITP_FORM_MRTNMNG02010_LIST_SEARCH #ITP_FORM_MRTNMNG02010_LIST_SEARCH_WHS_NM').val(item.whsNm);
  518. } else if(_this.mode === VIEW_MODE_MODIFY) {
  519. $('#ITP_FORM_MRTNMNG02010_MODIFY #ITP_FORM_MRTNMNG02010_MODIFY_WHS_ID').val(item.whsId);
  520. $('#ITP_FORM_MRTNMNG02010_MODIFY #ITP_FORM_MRTNMNG02010_MODIFY_WHS_NM').val(item.whsNm);
  521. $('#ITP_FORM_MRTNMNG02010_MODIFY #ITP_FORM_MRTNMNG02010_MODIFY_LOCATION').val(item.location);
  522. }
  523. mobPopObj.hide(_this.popId);
  524. return false;
  525. }
  526. });
  527. },
  528. action: function() {
  529. var _this = this;
  530. $('button[id^="ITP_BTN_MRTNMNG02010_POP"]').off('click').on('click', function() {
  531. var id = $(this).attr('id');
  532. switch (id) {
  533. case 'ITP_BTN_MRTNMNG02010_POP_WHS_SEARCH' : _this.search(); break;
  534. case 'ITP_BTN_MRTNMNG02010_POP_WHS_CHOICE' : _this.choice($(this)); break;
  535. case 'ITP_BTN_MRTNMNG02010_POP_WHS_CLOSE' : mobPopObj.hide(_this.popId); break;
  536. }
  537. return false;
  538. });
  539. },
  540. delete: function(mode) {
  541. if(mode === VIEW_MODE_LIST) {
  542. $('#ITP_FORM_MRTNMNG02010_LIST_SEARCH #ITP_FORM_MRTNMNG02010_LIST_SEARCH_WHS_ID').val('');
  543. $('#ITP_FORM_MRTNMNG02010_LIST_SEARCH #ITP_FORM_MRTNMNG02010_LIST_SEARCH_WHS_NM').val('');
  544. } else if(mode === VIEW_MODE_MODIFY) {
  545. $('#ITP_FORM_MRTNMNG02010_MODIFY #ITP_FORM_MRTNMNG02010_MODIFY_WHS_ID').val('');
  546. $('#ITP_FORM_MRTNMNG02010_MODIFY #ITP_FORM_MRTNMNG02010_MODIFY_WHS_NM').val('');
  547. $('#ITP_FORM_MRTNMNG02010_MODIFY #ITP_FORM_MRTNMNG02010_MODIFY_LOCATION').val('');
  548. }
  549. }
  550. },
  551. popReqConfirm: {
  552. popId: 'ITP_POP_MRTNMNG02010_REQ_AREA',
  553. rtnReqStCd: '',
  554. init: function (rtnReqStCd) {
  555. let mgrId = $('#ITP_FORM_MRTNMNG02010_MODIFY #ITP_FORM_MRTNMNG02010_MODIFY_RTN_REQ_MGR_ID').val();
  556. if(mgrId !== fn_make_user_info.get('userId')) {
  557. itp_fn_modal_alert(ITP_MSG_LOCALE.message.ajax.diffWrite);
  558. return;
  559. }
  560. if($('#ITP_LIST_MRTNMNG02010_MODIFY_ROWS').children().length < 1) {
  561. itp_fn_modal_alert( "요청할 품목내역이 없습니다.");
  562. return;
  563. }
  564. this.rtnReqStCd = rtnReqStCd;
  565. mobPopObj.show(this.popId);
  566. this.view();
  567. this.action();
  568. },
  569. view: function() {
  570. if(this.rtnReqStCd === RTN_REQ_ST_CD_REQUEST_SAVE) {
  571. $('#ITP_POP_MRTNMNG02010_REQ_AREA .msg_save').text('반품요청 하시겠습니까?');
  572. } else {
  573. $('#ITP_POP_MRTNMNG02010_REQ_AREA .msg_save').text('임시저장 하시겠습니까?');
  574. }
  575. $('#ITP_POP_MRTNMNG02010_REQ_AREA .fnPopDlvReqDt').text($('#ITP_FORM_MRTNMNG02010_MODIFY #ITP_FORM_MRTNMNG02010_MODIFY_COL_REQ_DT').val());
  576. $('#ITP_POP_MRTNMNG02010_REQ_AREA .fnItemQty').text(CommonObj.currency.add($('#ITP_LIST_MRTNMNG02010_MODIFY_ROWS').children().length, '개'));
  577. $('#ITP_POP_MRTNMNG02010_REQ_AREA .fnRtnTotalAmt').text($('#ITP_FORM_MRTNMNG02010_MODIFY .fnRtnReqAmtTot').text());
  578. },
  579. action: function() {
  580. var _this = this;
  581. $('#ITP_POP_MRTNMNG02010_REQ_AREA button[id="ITP_BTN_MRTNMNG02010_POP_REQ_CONFIRM"]').off('click').on('click', function() {
  582. $('#ITP_FORM_MRTNMNG02010_MODIFY #ITP_FORM_MRTNMNG02010_MODIFY_PCH_REQ_ST_CD').val(_this.rtnReqStCd);
  583. _this.save('#ITP_FORM_MRTNMNG02010_MODIFY');
  584. });
  585. },
  586. save: function(formId) {
  587. var _this = this;
  588. var gridInsertData = [];
  589. var gridUpdateData = [];
  590. var gridDeleteData = [];
  591. $.each(mobContObj.modify.list.rows, function(index, item) {
  592. // var item = {};
  593. // item['brandUnitUnqNo'] = row.brandUnitUnqNo;
  594. // item['itemId'] = row.itemId;
  595. // item['itemNm'] = row.itemNm;
  596. // item['rtnAmt'] = parseInt(row.unitAmt) * parseInt(row.rtnQty);
  597. // item['rtnDvsn'] = row.rtnDvsn;
  598. // item['rtnQty'] = row.rtnQty;
  599. // item['rtnReqDtlNo'] = row.rtnReqDtlNo;
  600. // item['rtnReqUnqNo'] = row.rtnReqUnqNo;
  601. // item['rtnRsn'] = row.rtnRsn;
  602. // item['rtnRsnDvsn'] = row.rtnRsnDvsn;
  603. // item['spplyId'] = row.spplyId;
  604. // item['storeUnitUnqNo'] = row.storeUnitUnqNo;
  605. // item['unit'] = row.unit;
  606. // item['unitAmt'] = row.unitAmt;
  607. // item['unitGubun'] = row.unitGubun;
  608. item['rtnAmt'] = parseInt(item.unitAmt) * parseInt(item.rtnQty);
  609. if(item.viewCd === 'D') {
  610. gridDeleteData.push(item);
  611. } else if(item.viewCd === 'C') {
  612. gridInsertData.push(item);
  613. } else {
  614. item.viewCd = 'U';
  615. gridUpdateData.push(item);
  616. }
  617. });
  618. let param = $(formId).serializeObject();
  619. param['rtnReqStCd'] = this.rtnReqStCd;
  620. param['colReqDt'] = param.colReqDt.replace(/[^0-9]/g, "");
  621. param.gridInsertData = gridInsertData;
  622. param.gridUpdateData = gridUpdateData;
  623. param.gridDeleteData = gridDeleteData;
  624. console.log(JSON.stringify(param));
  625. var saveFn = function (result) {
  626. console.log(result);
  627. mobPopObj.hide(_this.popId);
  628. mobContObj.list.init();
  629. };
  630. fn_ajax_call(API_MOBILE_SAVE, JSON.stringify(param), saveFn, 'POST');
  631. }
  632. },
  633. show: function(popId) {
  634. $('button[id$="_CLOSE"]').off('click').on('click', function() {
  635. if($(this).hasClass('btn-pop-close')) {
  636. mobPopObj.hide(popId);
  637. }
  638. });
  639. $('#' + popId).show();
  640. },
  641. hide: function(popId) {
  642. $('#' + popId).closest('.mobile-pop-close').hide();
  643. }
  644. };