ITP_STOCKMNG01010.js 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436
  1. /********************************************************
  2. --------------------------------------------------------
  3. - Object 목록 -
  4. --------------------------------------------------------
  5. * const gridColModel = {} : 화면 Grid Object *
  6. * let pageObj = {} : 화면공통 Object *
  7. * let listObj = {} : 목록화면 Object *
  8. *******************************************************/
  9. /*화면 변수*/
  10. const STOCKMNG01010_GRID_ID = '#ITP_STOCKMNG01010_jqGrid';
  11. const STOCKMNG01010_GRID_LIST = '#ITP_STOCKMNG01010_jqGrid_list';
  12. const STOCKMNG01010_GRID_PAGER = '#ITP_STOCKMNG01010_jqGridPager';
  13. const STOCKMNG01010_GRID_EMPTY = '#ITP_STOCKMNG01010_jqGridEmpty';
  14. let ITP_FORM_STOCKMNG01010_DETAIL_IS_DUPLICATE = false;
  15. let ITP_FORM_STOCKMNG01010_DETAIL_IS_WRITING = false;
  16. let STOCKMNG01010_DETAIL_GRID_LAST_ROW_ID;
  17. /*API URL*/
  18. let STOCK_MNG_DETAIL_GRID_LIST = '/api/stock/mng/detail-grid-list';
  19. let WHS_MNG_DETAIL_GRID_LIST = '/api/whs/mng/detail-grid-list';
  20. let WHS_MNG_LOCATION_GRID_LIST = '/api/whs/mng/location-grid-list';
  21. let API_ITEM_CLASS_LEVEL = '/api/item/class-level-list'; //품목분류 level 검색
  22. /*화면 Grid ColModel*/
  23. const gridColModel = {
  24. list: [
  25. {
  26. index: 'BRAND_ID', name: 'brandId',
  27. label: "브랜드ID",
  28. width: '0', fixed: false, align: 'center',
  29. sortable: false, hidden: true
  30. },
  31. {
  32. index: 'LOCATION', name: 'location',
  33. label: "로케이션",
  34. width: '0', fixed: false, align: 'center',
  35. sortable: false, hidden: true
  36. },
  37. {
  38. index: 'BRAND_NM', name: 'brandNm',
  39. label: ITP_MSG_LOCALE.label.brandNm, //브랜드
  40. width: '10', fixed: false, align: 'center',
  41. sortable: false, hidden: false
  42. },
  43. {
  44. index: 'STORE_NM', name: 'storeNm',
  45. label: "매장명",
  46. width: '10', fixed: false, align: 'center',
  47. sortable: false, hidden: false
  48. },
  49. {
  50. index: 'WHS_ID', name: 'whsId',
  51. label: "창고번호",
  52. width: '8', fixed: false, align: 'center',
  53. sortable: false, hidden: false
  54. },
  55. {
  56. index: 'WHS_NM', name: 'whsNm',
  57. label: "창고명",
  58. width: '13', fixed: false, align: 'center',
  59. sortable: false, hidden: false
  60. },
  61. {
  62. index: 'LOCATION_NM', name: 'locationNm',
  63. label: "Location명",
  64. width: '10', fixed: false, align: 'center',
  65. sortable: false, hidden: false
  66. },
  67. {
  68. index: 'ITEM_ID', name: 'itemId',
  69. label: "품목번호",
  70. width: '11', fixed: false, align: 'center',
  71. sortable: false, hidden: false
  72. },
  73. {
  74. index: 'ITEM_NM', name: 'itemNm',
  75. label: "품목명",
  76. width: '10', fixed: false, align: 'center',
  77. sortable: false, hidden: false
  78. },
  79. {
  80. index: 'UNIT', name: 'unit',
  81. label: "단위",
  82. width: '7', fixed: false, align: 'center',
  83. sortable: false, hidden: false
  84. },
  85. {
  86. index: 'STCK_QTY', name: 'stckQty',
  87. label: "현재고수량",
  88. width: '8', fixed: false, align: 'center',
  89. sortable: false, hidden: false
  90. },
  91. {
  92. index: 'PRP_STCK_QTY', name: 'prpStckQty',
  93. label: "적정재고수량",
  94. width: '8', fixed: false, align: 'center',
  95. sortable: false, hidden: false
  96. },
  97. {
  98. index: 'SFT_STCK_RT', name: 'sftStckRt',
  99. label: "안전재고비율(%)",
  100. width: '10', fixed: false, align: 'center',
  101. sortable: false, hidden: false
  102. },
  103. {
  104. index: 'CUR_STCK_RT', name: 'curStckRt',
  105. label: "현재고비율(%)",
  106. width: '10', fixed: false, align: 'center',
  107. sortable: false, hidden: false
  108. }
  109. ]
  110. };
  111. require(['config'], function() {
  112. require([
  113. ], function($) {
  114. pageObj.init();
  115. });
  116. });
  117. /*화면공통 Object*/
  118. let pageObj = {
  119. init: function () {
  120. this.brandInfo = JSON.parse(sessionStorage.getItem('itp_manage_user_info'));
  121. this.ui.init();
  122. this.event.init();
  123. },
  124. brandInfo: {},
  125. ui: {
  126. init: function () {
  127. this.view();
  128. this.grid();
  129. this.ready();
  130. },
  131. view: function() {
  132. // 버튼 권한설정
  133. fn_proc_btn_auth('STOCKMNG01010');
  134. // 브랜드ID 지정
  135. $('#ITP_FORM_STOCKMNG01010_SEARCH_BRAND_ID').val(pageObj.brandInfo.brandId);
  136. pageObj.fnWhsList(function() {
  137. pageObj.fnLocationList();
  138. }); // 창고리스트
  139. // 공통코드 표시
  140. // fn_make_select(CODE_LIST, 'WHS_DVSN', 'ITP_FORM_STOCKMNG01010_WHS_DVSN');
  141. // 조회일자 지정
  142. $('#ITP_TAB_STOCKMNG01010 .input-group.date').datepicker(ITP_DATE_LANGUAGE);
  143. // 분류
  144. itemClassLevel.list(1, true);
  145. },
  146. grid: function() {
  147. itp_fn_jqgrid_resize(STOCKMNG01010_GRID_ID, STOCKMNG01010_GRID_LIST, 'lg');
  148. listObj.empty.init();
  149. itp_fn_fire_window_resize();
  150. },
  151. ready: function() {
  152. listObj.init();
  153. }
  154. },
  155. event: {
  156. init: function () {
  157. this.button();
  158. this.change();
  159. },
  160. button: function () {
  161. // 버튼 클릭 이벤트
  162. $('button').each(function() {
  163. var id = $(this).attr('id');
  164. $(this).on('click', function() {
  165. switch (id) {
  166. case 'ITP_BTN_STOCKMNG01010_SRH' : listObj.button.search(); break; // 조회 버튼
  167. case 'ITP_BTN_STOCKMNG01010_ADDROW' : listObj.button.clickStockProc(); break; // 재고처리 버튼
  168. case 'ITP_BTN_STOCKMNG01010_DELROW' : listObj.button.clickStockHist(); break; // 재고이력 버튼
  169. }
  170. });
  171. });
  172. $('body').on('click', function(e) {
  173. });
  174. },
  175. change: function () {
  176. // 창고 변경
  177. $('#ITP_FORM_STOCKMNG01010_SEARCH_WHS_ID').on('change', function() {
  178. pageObj.fnLocationList(function() {
  179. listObj.button.search(); // 조회
  180. }); // 로케이션 리스트
  181. });
  182. $('#ITP_FORM_STOCKMNG01010_SEARCH_LOCATION').on('change', function() {
  183. listObj.button.search(); // 조회
  184. });
  185. }
  186. },
  187. switchScreen: function(mode) {
  188. if(mode == 'LIST') { // 목록
  189. fn_show_btn_auth('#ITP_BTN_STOCKMNG01010_SRH');
  190. $('#ITP_AJAX_STOCKMNG01010_LIST_CONTAINER').show();
  191. }
  192. },
  193. fnWhsList: function(fnCall) {
  194. const brandIdVal = $('#ITP_FORM_STOCKMNG01010_SEARCH_BRAND_ID').val();
  195. const param = {sbrandId: brandIdVal, pagingYn: false};
  196. fn_ajax_call(WHS_MNG_DETAIL_GRID_LIST, JSON.stringify(param), function(result) {
  197. fn_make_select_whs(result.gridRows, 'ITP_FORM_STOCKMNG01010_SEARCH_WHS_ID');
  198. if (fnCall !== undefined || typeof fnCall !== 'undefined') fnCall();
  199. }, 'POST');
  200. },
  201. fnLocationList: function(fnCall) {
  202. const brandIdVal = $('#ITP_FORM_STOCKMNG01010_SEARCH_BRAND_ID').val();
  203. const whsIdVal = $('#ITP_FORM_STOCKMNG01010_SEARCH_WHS_ID').val();
  204. const param = {brandId: brandIdVal, whsId: whsIdVal, pagingYn: false};
  205. fn_ajax_call(WHS_MNG_LOCATION_GRID_LIST, JSON.stringify(param), function(result) {
  206. fn_make_select_location(result.gridRows, 'ITP_FORM_STOCKMNG01010_SEARCH_LOCATION');
  207. if (fnCall !== undefined || typeof fnCall !== 'undefined') fnCall();
  208. }, 'POST');
  209. }
  210. };
  211. /*목록화면 Object*/
  212. let listObj = {
  213. init: function () {
  214. this.form();
  215. this.grid.init();
  216. },
  217. itp_STOCKMNG01010_search: false,
  218. button: {
  219. search: function() {
  220. listObj.itp_STOCKMNG01010_search = true;
  221. let param = $('#ITP_FORM_STOCKMNG01010_SEARCH').serializeObject();
  222. param.gridSize = $.jgrid.defaults.rowNum;
  223. param.gridPage = $.jgrid.defaults.page;
  224. $(STOCKMNG01010_GRID_ID).setGridParam({'postData': JSON.stringify(param)}).trigger('reloadGrid');
  225. },
  226. clickStockProc: function() {
  227. // 그리드에서 최소1개는 선택해야 함
  228. const rowKey = $(STOCKMNG01010_GRID_ID).getGridParam('selrow');
  229. if (!rowKey) {
  230. itp_fn_modal_alert_ajax(ITP_MSG_LOCALE.message.ajax.noData);
  231. return;
  232. }
  233. var selectedIds = $(STOCKMNG01010_GRID_ID).getGridParam('selarrrow');
  234. if (selectedIds.length > 1) {
  235. itp_fn_modal_alert_ajax(ITP_MSG_LOCALE.message.ajax.noSingleData);
  236. return;
  237. }
  238. var brandId = $(STOCKMNG01010_GRID_ID).jqGrid('getRowData', selectedIds[0]).brandId;
  239. var whsId = $(STOCKMNG01010_GRID_ID).jqGrid('getRowData', selectedIds[0]).whsId;
  240. var location = $(STOCKMNG01010_GRID_ID).jqGrid('getRowData', selectedIds[0]).location;
  241. var itemId = $(STOCKMNG01010_GRID_ID).jqGrid('getRowData', selectedIds[0]).itemId;
  242. var args = {'brandId': brandId, 'whsId': whsId, 'location': location, 'itemId': itemId};
  243. fn_call_popup('biz', 'BIZPOP_PO_STOCK_PROC', '#ITP_ASIDE', function() {
  244. listObj.button.search(); // 조회
  245. }, args, 'S');
  246. },
  247. clickStockHist: function() {
  248. // 그리드에서 최소1개는 선택해야 함
  249. const rowKey = $(STOCKMNG01010_GRID_ID).getGridParam('selrow');
  250. if (!rowKey) {
  251. itp_fn_modal_alert_ajax(ITP_MSG_LOCALE.message.ajax.noData);
  252. return;
  253. }
  254. var selectedIds = $(STOCKMNG01010_GRID_ID).getGridParam('selarrrow');
  255. if (selectedIds.length > 1) {
  256. itp_fn_modal_alert_ajax(ITP_MSG_LOCALE.message.ajax.noSingleData);
  257. return;
  258. }
  259. var brandId = $(STOCKMNG01010_GRID_ID).jqGrid('getRowData', selectedIds[0]).brandId;
  260. var whsId = $(STOCKMNG01010_GRID_ID).jqGrid('getRowData', selectedIds[0]).whsId;
  261. var location = $(STOCKMNG01010_GRID_ID).jqGrid('getRowData', selectedIds[0]).location;
  262. var itemId = $(STOCKMNG01010_GRID_ID).jqGrid('getRowData', selectedIds[0]).itemId;
  263. var args = {'brandId': brandId, 'whsId': whsId, 'location': location, 'itemId': itemId};
  264. fn_call_popup('biz', 'BIZPOP_PO_STOCK_HIST', '#ITP_ASIDE', null, args, 'S');
  265. }
  266. },
  267. form: function() {
  268. $('#ITP_FORM_STOCKMNG01010_SEARCH_ITEM_CLASS1').on('change', function() {
  269. ($(this).val() === '') ? itemClassLevel.clear(2, true): itemClassLevel.list(2, true);
  270. });
  271. $('#ITP_FORM_STOCKMNG01010_SEARCH_ITEM_CLASS2').on('change', function() {
  272. ($(this).val() === '') ? itemClassLevel.clear(3, true): itemClassLevel.list(3, true);
  273. });
  274. $('#ITP_FORM_STOCKMNG01010_SEARCH_ITEM_CLASS3').on('change', function() {
  275. ($(this).val() === '') ? itemClassLevel.clear(4, true): itemClassLevel.list(4, true);
  276. });
  277. },
  278. empty: {
  279. init: function() {
  280. var _this = this;
  281. this.push();
  282. $(STOCKMNG01010_GRID_EMPTY).on('click', function() {
  283. _this.back();
  284. _this.itp_STOCKMNG01010_param.gridSize = $.jgrid.defaults.rowNum;
  285. $(STOCKMNG01010_GRID_ID).setGridParam({'postData': JSON.stringify(_this.itp_STOCKMNG01010_param)}).trigger('reloadGrid');
  286. });
  287. },
  288. itp_STOCKMNG01010_param: {},
  289. push: function() {
  290. let param = $('#ITP_FORM_STOCKMNG01010_SEARCH').serializeObject();
  291. listObj.itp_STOCKMNG01010_param = param;
  292. },
  293. back: function() {
  294. $('#ITP_FORM_STOCKMNG01010_SEARCH_WHS_ID').val(listObj.itp_STOCKMNG01010_param.swhsId);
  295. $('#ITP_FORM_STOCKMNG01010_SEARCH_LOCATION').val(listObj.itp_STOCKMNG01010_param.slocation);
  296. $('#ITP_FORM_STOCKMNG01010_SEARCH_ITEM_CLASS1').val(listObj.itp_STOCKMNG01010_param.sitemClass1);
  297. $('#ITP_FORM_STOCKMNG01010_SEARCH_ITEM_CLASS2').val(listObj.itp_STOCKMNG01010_param.sitemClass2);
  298. $('#ITP_FORM_STOCKMNG01010_SEARCH_ITEM_CLASS3').val(listObj.itp_STOCKMNG01010_param.sitemClass3);
  299. $('#ITP_FORM_STOCKMNG01010_SEARCH_ITEM_CLASS4').val(listObj.itp_STOCKMNG01010_param.sitemClass4);
  300. $('#ITP_FORM_STOCKMNG01010_SEARCH_ITEM_NM').val(listObj.itp_STOCKMNG01010_param.sitemNm);
  301. }
  302. },
  303. grid: {
  304. init: function () {
  305. // 데이터 없을때
  306. listObj.empty.push();
  307. this.search();
  308. },
  309. colModel: gridColModel.list,
  310. search: function() {
  311. pageObj.switchScreen('LIST');
  312. this.unload();
  313. this.load();
  314. },
  315. load: function() {
  316. $('#ITP_FORM_STOCKMNG01010_SEARCH_BRAND_ID').val(pageObj.brandInfo.brandId);
  317. let param = $('#ITP_FORM_STOCKMNG01010_SEARCH').serializeObject();
  318. param.gridSize = $.jgrid.defaults.rowNum;
  319. var option = {
  320. gridId: STOCKMNG01010_GRID_ID,
  321. colModel: gridColModel.list,
  322. param: JSON.stringify(param),
  323. url: DOMAIN + STOCK_MNG_DETAIL_GRID_LIST,
  324. pager: STOCKMNG01010_GRID_PAGER,
  325. multiselect: true,
  326. onCellSelect: function(rowId, cellIdx, cellValue) {
  327. var cm = $(this).jqGrid('getGridParam', 'colModel');
  328. var colNm = cm[cellIdx].name;
  329. if (colNm == 'whsNm') {
  330. }
  331. },
  332. loadComplete: function(data) {
  333. console.log(data);
  334. itp_fn_grid_load_complete(data, STOCKMNG01010_GRID_ID, true, 'number', 'STOCKMNG01010', listObj.itp_STOCKMNG01010_search, listObj.empty, true, data.gridRecords, true);
  335. var ids = $(STOCKMNG01010_GRID_ID).getDataIDs();
  336. $.each(ids, function(idx, rowId) {
  337. // $(STOCKMNG01010_GRID_ID).jqGrid('setCell', rowId, 'whsNm', '', ITP_GRID_COL_STYLE.link);
  338. });
  339. },
  340. onPaging: function(action) {
  341. itp_fn_grid_paging(STOCKMNG01010_GRID_ID, action, param);
  342. }
  343. };
  344. itp_fn_grid_make_remote(option);
  345. },
  346. clearData : function() {
  347. $(STOCKMNG01010_GRID_ID).jqGrid('clearGridData', true);
  348. $(STOCKMNG01010_GRID_LIST).find('.ui-jqgrid-bdiv').css('min-height', '100px');
  349. $(STOCKMNG01010_GRID_EMPTY).html(ITP_MSG_LOCALE.message.grid.noData);
  350. $(STOCKMNG01010_GRID_EMPTY).show();
  351. },
  352. unload : function() {
  353. $.jgrid.gridUnload(STOCKMNG01010_GRID_ID);
  354. }
  355. }
  356. };
  357. var itemClassLevel = {
  358. isList: true,
  359. level: 1,
  360. keys: function() {
  361. var keys = {sBrandId:pageObj.brandInfo.brandId, sItemLevel: this.level};
  362. for(var i=1; i<this.level; i++) {
  363. var key = 'sItemClass' + i;
  364. var id = (this.isList ? '#ITP_FORM_STOCKMNG01010_SEARCH_ITEM_CLASS' : '#ITP_FORM_STOCKMNG01010_DETAIL_ITEM_CLASS') + i;
  365. keys[key] = $(id + ' option:selected').val();
  366. }
  367. return keys;
  368. },
  369. list: function(level, isList) {
  370. this.level = level;
  371. this.isList = isList;
  372. this.clear(level, isList);
  373. this.call( $.param(this.keys()));
  374. },
  375. detail: {
  376. data: [],
  377. make: function() {
  378. itemClassLevel.isList = false;
  379. itemClassLevel.call( $.param(itemClassLevel.keys()));
  380. }
  381. },
  382. call: function(param) {
  383. fn_ajax_call(API_ITEM_CLASS_LEVEL, param, this.callback, 'GET');
  384. },
  385. callback: function(result) {
  386. var id = 'ITP_FORM_STOCKMNG01010_SEARCH_ITEM_CLASS' + itemClassLevel.level;
  387. fn_make_select_item_class(result.searchList, id, true, '선택');
  388. if(!itemClassLevel.isList) {
  389. $('#' + id).val(itemClassLevel.detail.data[ itemClassLevel.level - 1]);
  390. if(itemClassLevel.level < itemClassLevel.detail.data.length) {
  391. if(itemClassLevel.detail.data[itemClassLevel.level] !== '') {
  392. itemClassLevel.level++;
  393. itemClassLevel.call( $.param(itemClassLevel.keys()));
  394. }
  395. }
  396. }
  397. },
  398. clear: function(level, isList) {
  399. for(var i=level; i<5; i++) {
  400. var id = 'ITP_FORM_STOCKMNG01010_SEARCH_ITEM_CLASS' + i;
  401. $('#' + id).find('option').remove();
  402. }
  403. }
  404. };