ITP_STINFO05010.js 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654
  1. require(['config'], function() {
  2. require([
  3. 'jquery.bootstrap.fileUpload' //파일 업로드가 있는 페이지에서 로딩
  4. ], function($) {
  5. pageObj.init();
  6. });
  7. });
  8. /********************************************************
  9. --------------------------------------------------------
  10. - Object 목록 -
  11. --------------------------------------------------------
  12. * const gridColModel = {} : 화면 Grid Object *
  13. * let pageObj = {} : 화면공통 Object *
  14. * let listObj = {} : 목록화면 Object *
  15. * let viewObj = {} : 상세화면 Object *
  16. * let modifyObj = {} : 수정화면 Object *
  17. * let createObj = {} : 신규화면 Object *
  18. *******************************************************/
  19. /*화면 변수*/
  20. const STINFO05010_GRID_ID = '#ITP_STINFO05010_jqGrid';
  21. const STINFO05010_GRID_LIST = '#ITP_STINFO05010_jqGrid_list';
  22. const STINFO05010_GRID_PAGER = '#ITP_STINFO05010_jqGridPager';
  23. const STINFO05010_GRID_EMPTY = '#ITP_STINFO05010_jqGridEmpty';
  24. let ITP_FORM_STINFO05010_DETAIL_IS_DUPLICATE = false;
  25. let ITP_FORM_STINFO05010_DETAIL_IS_WRITING = false;
  26. /*API URL*/
  27. let API_DETAIL_GRID_LIST = '/api/itemunit/detail-grid-list'; // 목록
  28. let API_DETAIL_INFO = '/api/itemunit/info-itemunit'; // 상세
  29. let API_DETAIL_SAVE = '/api/itemunit/save-itemunit'; // 저장
  30. let API_ITEM_CLASS_LEVEL = '/api/item/class-level-list'; //품목분류 level 검색
  31. /*화면 Grid ColModel*/
  32. const gridColModel = {
  33. list: [
  34. {
  35. index: 'BRAND_ID', name: 'brandId',
  36. label: ITP_MSG_LOCALE.label.brandId, //브랜드ID
  37. width: '0', fixed: false, align: 'center',
  38. sortable: false, hidden: true ,frozen:true
  39. },
  40. {
  41. index: 'BRAND_UNIT_UNQ_NO', name: 'brandUnitUnqNo',
  42. label: ITP_MSG_LOCALE.label.brandUnitUnqNo, //브랜드ID
  43. width: '0', fixed: false, align: 'center',
  44. sortable: false, hidden: true
  45. },
  46. {
  47. index: 'ITEM_ID', name: 'itemId',
  48. label: ITP_MSG_LOCALE.label.itemId, //품목번호
  49. width: '11', fixed: false, align: 'center',
  50. sortable: false, hidden: false ,frozen:true
  51. },
  52. {
  53. index: 'ITEM_NM', name: 'itemNm',
  54. label: ITP_MSG_LOCALE.label.itemNm, //품목명
  55. width: '10', fixed: false, align: 'left',
  56. sortable: false, hidden: false, classes: 'ui-ellipsis'
  57. },
  58. {
  59. index: 'SPPLY_ID_NM', name: 'spplyNm',
  60. label: ITP_MSG_LOCALE.label.spplyNm, //공급업체명
  61. width: '10', fixed: false, align: 'left',
  62. sortable: false, hidden: false, classes: 'ui-ellipsis'
  63. },
  64. {
  65. index: 'UNIT', name: 'unit',
  66. label: ITP_MSG_LOCALE.label.unit, //기본단위
  67. width: '5', fixed: false, align: 'center',
  68. sortable: false, hidden: false
  69. },
  70. {
  71. index: 'CURR', name: 'curr',
  72. label: ITP_MSG_LOCALE.label.curr, //통화
  73. width: '3', fixed: false, align: 'center',
  74. sortable: false, hidden: false
  75. },
  76. {
  77. index: 'UNIT_AMT', name: 'unitAmt',
  78. label: ITP_MSG_LOCALE.label.unitAmt, //단가
  79. width: '8', fixed: false, align: 'right',
  80. sortable: false, hidden: false,
  81. formatter: 'integer', formatoptions: {thousandsSeparator: ','}
  82. },
  83. {
  84. index: 'CONT_STT_DT', name: 'contSttDt',
  85. label: ITP_MSG_LOCALE.label.contSttDt, //시작일
  86. width: '6', fixed: false, align: 'center',
  87. sortable: false, hidden: false
  88. },
  89. {
  90. index: 'CONT_END_DT', name: 'contEndDt',
  91. label: ITP_MSG_LOCALE.label.contEndDt, //종료일
  92. width: '6', fixed: false, align: 'center',
  93. sortable: false, hidden: false
  94. },
  95. {
  96. index: 'LEAD_TIME', name: 'leadTime',
  97. label: '리드타임 Day(s)', //리드타임 (Day)
  98. width: '8', fixed: false, align: 'right',
  99. sortable: false, hidden: false,
  100. formatter: 'integer', formatoptions: {thousandsSeparator: ','}
  101. },
  102. {
  103. index: 'UNIT_ST_NM', name: 'unitStNm',
  104. label: ITP_MSG_LOCALE.label.stNm, //상태
  105. width: '4', fixed: false, align: 'center',
  106. sortable: false, hidden: false
  107. },
  108. {
  109. index: 'SPPLY_ITEM_ID', name: 'spplyItemId',
  110. label: ITP_MSG_LOCALE.label.spplyItemId, //공급사품번
  111. width: '11', fixed: false, align: 'center',
  112. sortable: false, hidden: false
  113. }
  114. ]
  115. };
  116. /*화면공통 Object*/
  117. let pageObj = {
  118. init: function () {
  119. this.ui.init();
  120. this.event.init();
  121. },
  122. ui: {
  123. init: function () {
  124. this.view();
  125. this.form();
  126. this.grid();
  127. this.ready();
  128. },
  129. view: function() {
  130. // 버튼 권한설정
  131. fn_proc_btn_auth('STINFO05010');
  132. // 공통코드 표시
  133. $('select').each(function() {
  134. if($(this).data('select-code')) {
  135. fn_make_select(CODE_LIST, $(this).data('select-code'), $(this).attr('id'));
  136. }
  137. });
  138. itemClassLevel.list(1);
  139. // 조회일자 지정
  140. var now = new Date();
  141. var defaultToDate = new Date(now);
  142. defaultToDate.setDate(now.getDate() - 30);
  143. $('#ITP_TAB_STINFO05010 .input-group.date').datepicker(ITP_DATE_LANGUAGE);
  144. $('#ITP_FORM_STINFO05010_SEARCH_FROM_DT').datepicker('setDate', defaultToDate);
  145. $('#ITP_FORM_STINFO05010_SEARCH_TO_DT').datepicker('setDate', now);
  146. // form alert message 주입
  147. $('input[data-alert-required="ONLYCHK"]').each(function() {
  148. if($(this).data('alert-msg') === 'empty') {
  149. $(this).data('alert-msg', ITP_MSG_LOCALE.message.form.needAll);
  150. }
  151. });
  152. },
  153. form: function() {
  154. itp_fn_form_event.onKeyup('#ITP_FORM_STINFO05010_DETAIL');
  155. },
  156. grid: function() {
  157. itp_fn_jqgrid_resize(STINFO05010_GRID_ID, STINFO05010_GRID_LIST, 'sm');
  158. //listObj.empty.init();
  159. },
  160. ready: function() {
  161. listObj.init();
  162. }
  163. },
  164. event: {
  165. init: function () {
  166. this.button();
  167. },
  168. button: function () {
  169. // 버튼 클릭 이벤트
  170. $('button').each(function() {
  171. var id = $(this).attr('id');
  172. $(this).on('click', function() {
  173. switch (id) {
  174. case 'ITP_BTN_STINFO05010_SRH' : listObj.button.search(); break; // 조회 버튼 클릭
  175. case 'ITP_BTN_STINFO05010_NEWREG' : listObj.button.create(); break; // 신규등록 버튼
  176. case 'ITP_BTN_STINFO05010_MODIFY' : modifyObj.button.modify(); break; // 수정 버튼
  177. case 'ITP_BTN_STINFO05010_CANCELLIST' : createObj.button.cancel(); break; // 취소/목록 버튼
  178. case 'ITP_BTN_STINFO05010_DELETE' : break; // 삭제 버튼
  179. case 'ITP_BTN_STINFO05010_SAVE' : createObj.button.save(); break; // 저장 버튼
  180. case 'ITP_FORM_STINFO05010_DETAIL_DUP' : createObj.button.duplicate(); break; // 중복체크
  181. case 'ITP_BTN_STINFO05010_RESET_PW' : createObj.button.resetPass(); break; // 상세:비밀번호 초기화
  182. case 'ITP_BTN_STINFO05010_EXCEL' : listObj.excelDown(); break; // 엑셀 다운로드 버튼
  183. }
  184. });
  185. });
  186. $('button[id^="ITP_BTN_STINFO05010_SEARCH"]').on('click', function() {
  187. popSearch.init($(this).attr('id'), 'SPPLY');
  188. });
  189. $('button[id^="ITP_BTN_STINFO05010_DETAIL"]').on('click', function() {
  190. var id = $(this).attr('id');
  191. popSearch.init(id, id.indexOf('ITEM') > -1 ? 'ITEM' : 'SPPLY');
  192. });
  193. }
  194. },
  195. fileUpload: function() {
  196. //파일업로드(등록/수정화면)
  197. var id = 'STINFO05010';
  198. $('#ITP_' + id + '_DETAIL_UPLOAD').empty();
  199. const fileArgs = {
  200. 'fileNo': $('#ITP_FORM_' + id + '_DETAIL_FILE_NO').val(),
  201. 'viewCd': $('#ITP_FORM_' + id + '_DETAIL_VIEW_CD').val(),
  202. 'showYn': $('#ITP_' + id + '_DETAIL_UPLOAD').attr('data-show-yn'),
  203. 'fileId': '#ITP_FORM_' + id + '_DETAIL_FILE_NO' //파일번호를 서버에서 받아서 넣을 파일번호 인풋박스 아이디
  204. };
  205. itp_fn_set_file_upload('ITP_' + id + '_DETAIL_UPLOAD', 'notice', true, false, id, fileArgs);
  206. },
  207. switchScreen: function(mode) {
  208. $('.itp_det_head').find('button[id^="ITP_BTN_STINFO05010_"]').each(function(i) {
  209. $(this).hide();
  210. });
  211. $('#ITP_TAB_STINFO05010').find('div[id$="_CONTAINER"]').each(function(i) {
  212. $(this).hide();
  213. });
  214. if(mode == 'LIST') { // 목록
  215. itp_fn_fire_window_resize();
  216. $('#ITP_AJAX_STINFO05010_LIST_CONTAINER').show();
  217. fn_show_btn_auth_array(['#ITP_BTN_STINFO05010_SRH', '#ITP_BTN_STINFO05010_NEWREG']);
  218. $('#ITP_FORM_STINFO05010_SEARCH_BRAND_ID').val(fn_make_user_info.get('brandId'));
  219. $('#ITP_BTN_STINFO05010_EXCEL').show();
  220. } else if(mode == 'ADD') { // 등록
  221. $('#ITP_AJAX_STINFO05010_DETAIL_CONTAINER').show();
  222. fn_show_btn_auth_array(['#ITP_BTN_STINFO05010_CANCELLIST', '#ITP_BTN_STINFO05010_SAVE']);
  223. $('#ITP_FORM_STINFO05010_DETAIL').find('input, textarea, select, checkbox').each(function(i, elem) {
  224. $(this).attr('id') === 'ITP_FORM_STINFO05010_DETAIL_VIEW_CD' ? $(this).val('C') : $(this).val('');
  225. if(elem.type === 'select') {
  226. $(this).val('').prop('selected', true);
  227. }
  228. });
  229. // 브랜드그룹 정보 설정
  230. $('#ITP_FORM_STINFO05010_DETAIL_AFFL_SHOP_ID').val(fn_make_user_info.get('afflShopId'));
  231. $('#ITP_FORM_STINFO05010_DETAIL_BRAND_ID').val(fn_make_user_info.get('brandId'));
  232. $('#ITP_FORM_STINFO05010_DETAIL_STORE_ID').removeAttr('readonly');
  233. $('#ITP_FORM_STINFO05010_DETAIL_DUP').removeAttr('disabled');
  234. $('#ITP_FORM_STINFO05010_DETAIL .itp_form_info').hide();
  235. $('#ITP_FORM_STINFO05010_DETAIL .itp_form_change').show();
  236. $('#ITP_FORM_STINFO05010_DETAIL .fnStoreNm').text('(자동부여)');
  237. $('#ITP_FORM_STINFO05010_DETAIL #ITP_FORM_STINFO05010_DETAIL_CONT_STT_DT').datepicker('setDate', new Date());
  238. $('#ITP_FORM_STINFO05010_DETAIL #ITP_FORM_STINFO05010_DETAIL_CONT_END_DT').datepicker('setDate', itp_fn_date_add('Y', 1));
  239. } else if(mode == 'MODIFY') { // 수정
  240. $('#ITP_AJAX_STINFO05010_DETAIL_CONTAINER').show();
  241. fn_show_btn_auth_array(['#ITP_BTN_STINFO05010_CANCELLIST', '#ITP_BTN_STINFO05010_SAVE', '#ITP_BTN_STINFO05010_RESET_PW']);
  242. $('#ITP_FORM_STINFO05010_DETAIL_AFFL_SHOP_ID').val(fn_make_user_info.get('afflShopId'));
  243. $('#ITP_FORM_STINFO05010_DETAIL_BRAND_ID').val(fn_make_user_info.get('brandId'));
  244. $('#ITP_FORM_STINFO05010_DETAIL .itp_form_info').show();
  245. $('#ITP_FORM_STINFO05010_DETAIL .itp_form_change').hide();
  246. $('#ITP_FORM_STINFO05010_DETAIL_STORE_ID').attr('readonly', true);
  247. $('#ITP_FORM_STINFO05010_DETAIL_DUP').attr('disabled', true);
  248. $('#ITP_FORM_STINFO05010_DETAIL_SEARCH_AFFL_SHOP_NM').attr('readonly', true);
  249. $('#ITP_FORM_STINFO05010_DETAIL_SEARCH_AFFL_SHOP').hide();
  250. $('#ITP_FORM_STINFO05010_DETAIL_DELETE_AFFL_SHOP').hide();
  251. } else if(mode == 'VIEW') { // 보기
  252. $('#ITP_AJAX_STINFO05010_VIEW_CONTAINER').show();
  253. fn_show_btn_auth_array(['#ITP_BTN_STINFO05010_MODIFY', '#ITP_BTN_STINFO05010_CANCELLIST']);
  254. }
  255. }
  256. };
  257. /*목록화면 Object*/
  258. let listObj = {
  259. init: function () {
  260. this.form();
  261. this.grid.init();
  262. },
  263. itp_STINFO05010_search: false,
  264. button: {
  265. search: function() {
  266. listObj.itp_STINFO05010_search = true;
  267. let param = $('#ITP_FORM_STINFO05010_SEARCH').serializeObject();
  268. param.gridSize = $.jgrid.defaults.rowNum;
  269. param.gridPage = $.jgrid.defaults.page;
  270. $(STINFO05010_GRID_ID).data('grid-param',param);
  271. $(STINFO05010_GRID_ID).setGridParam({'postData': JSON.stringify(param)}).trigger('reloadGrid');
  272. },
  273. create: function() {
  274. if(!fn_make_user_info.isEmpty()) {
  275. createObj.init();
  276. }
  277. }
  278. },
  279. form: function() {
  280. $('#ITP_FORM_STINFO05010_SEARCH_ITEM_CLASS1').on('change', function() {
  281. ($(this).val() === '') ? itemClassLevel.clear(2): itemClassLevel.list(2);
  282. });
  283. $('#ITP_FORM_STINFO05010_SEARCH_ITEM_CLASS2').on('change', function() {
  284. ($(this).val() === '') ? itemClassLevel.clear(3): itemClassLevel.list(3);
  285. });
  286. $('#ITP_FORM_STINFO05010_SEARCH_ITEM_CLASS3').on('change', function() {
  287. ($(this).val() === '') ? itemClassLevel.clear(4): itemClassLevel.list(4);
  288. });
  289. },
  290. empty: {
  291. init: function() {
  292. },
  293. itp_STINFO05010_param: {},
  294. push: function() {
  295. },
  296. back: function() {
  297. }
  298. },
  299. grid: {
  300. init: function () {
  301. // 데이터 없을때
  302. //listObj.empty.push();
  303. this.search();
  304. },
  305. search: function() {
  306. pageObj.switchScreen('LIST');
  307. this.unload();
  308. this.load();
  309. },
  310. load: function() {
  311. let param = $('#ITP_FORM_STINFO05010_SEARCH').serializeObject();
  312. param.gridSize = $.jgrid.defaults.rowNum;
  313. param.sbrandId = fn_make_user_info.get('brandId');
  314. var option = {
  315. gridId: STINFO05010_GRID_ID,
  316. colModel: gridColModel.list,
  317. param: param,
  318. autowidth: false,
  319. shrinkToFit :true,
  320. forceFit: true,
  321. url: DOMAIN + API_DETAIL_GRID_LIST,
  322. pager: STINFO05010_GRID_PAGER,
  323. multiselect: true,
  324. multiboxonly: true,
  325. rownumbers: false,
  326. onCellSelect: function(rowId, cellIdx, cellValue) {
  327. var cm = $(this).jqGrid('getGridParam', 'colModel');
  328. var colNm = cm[cellIdx].name;
  329. if (colNm == 'itemId') {
  330. const selectVal = $(this).jqGrid('getCell', rowId, 'brandUnitUnqNo');
  331. const key = {brandId:fn_make_user_info.get('brandId'), brandUnitUnqNo: selectVal, viewCd: 'R'};
  332. var param = $.param(key);
  333. viewObj.init(param);
  334. }
  335. },
  336. loadComplete: function(data) {
  337. console.log(data);
  338. itp_fn_grid_load_complete(data, STINFO05010_GRID_ID, true, 'number', 'STINFO05010', listObj.itp_STINFO05010_search, listObj.empty, true, data.gridRecords, true);
  339. var ids = $(STINFO05010_GRID_ID).getDataIDs();
  340. $.each(ids, function(idx, rowId) {
  341. $(STINFO05010_GRID_ID).jqGrid('setCell', rowId, 'itemId', '', ITP_GRID_COL_STYLE.link);
  342. });
  343. $(STINFO05010_GRID_ID).jqGrid('hideCol', 'cb');
  344. },
  345. onPaging: function(action) {
  346. itp_fn_grid_paging(STINFO05010_GRID_ID, action, param);
  347. }
  348. };
  349. itp_fn_grid_make_remote(option);
  350. },
  351. clearData : function() {
  352. $(STINFO05010_GRID_ID).jqGrid('clearGridData', true);
  353. $(STINFO05010_GRID_LIST).find('.ui-jqgrid-bdiv').css('min-height', '100px');
  354. $(STINFO05010_GRID_EMPTY).html(ITP_MSG_LOCALE.message.grid.noData);
  355. $(STINFO05010_GRID_EMPTY).show();
  356. },
  357. unload : function() {
  358. $.jgrid.gridUnload(STINFO05010_GRID_ID);
  359. }
  360. },
  361. excelDown: function() {
  362. var exparam = $('#ITP_FORM_STINFO05010_SEARCH').serializeObject() ;
  363. exparam.sbrandId = fn_make_user_info.get('brandId');
  364. var param = {
  365. 'url': API_DETAIL_GRID_LIST,
  366. 'param': exparam,
  367. 'gridColumns': $(STINFO05010_GRID_ID).jqGrid('getGridParam', 'colModel'),
  368. 'fileName': '단가관리.xlsx',
  369. 'sheetName': '단가관리'
  370. };
  371. itp_fn_remote_to_excel(param);
  372. }
  373. };
  374. /*상세화면 Object*/
  375. let viewObj = {
  376. init: function (param) {
  377. this.load(param);
  378. },
  379. load: function(param) {
  380. fn_ajax_call(API_DETAIL_INFO, param, this.callback, 'GET');
  381. },
  382. callback: function (result) {
  383. console.log(result);
  384. pageObj.switchScreen('VIEW');
  385. $('#ITP_FORM_STINFO05010_VIEW #ITP_FORM_STINFO05010_VIEW_ITEM_ID').val(result.itemId);
  386. $('#ITP_FORM_STINFO05010_VIEW #ITP_FORM_STINFO05010_VIEW_BRAND_UNIT_UNQ_NO').val(result.brandUnitUnqNo);
  387. $('#ITP_FORM_STINFO05010_VIEW .fnBrandNm').text(result.brandNm);
  388. $('#ITP_FORM_STINFO05010_VIEW .fnStCd').text(result.unitStNm);
  389. $('#ITP_FORM_STINFO05010_VIEW .fnItemId').text(result.itemId);
  390. $('#ITP_FORM_STINFO05010_VIEW .fnItemNm').text(result.itemNm);
  391. $('#ITP_FORM_STINFO05010_VIEW .fnSpplyId').text(result.spplyId);
  392. $('#ITP_FORM_STINFO05010_VIEW .fnSpplyNm').text(result.spplyNm);
  393. let spplyItemId;
  394. if (result.spplyItemId == null || result.spplyItemId == '') {
  395. spplyItemId = '(미등록)';
  396. } else {
  397. spplyItemId = result.spplyItemId;
  398. }
  399. $('#ITP_FORM_STINFO05010_VIEW .fnSpplyItemId').text(spplyItemId);
  400. $('#ITP_FORM_STINFO05010_VIEW .fnContSttDt').text(result.contSttDt);
  401. $('#ITP_FORM_STINFO05010_VIEW .fnContEndDt').text(result.contEndDt);
  402. $('#ITP_FORM_STINFO05010_VIEW .fnLeadTime').text(itp_fn_number_comma(result.leadTime) + ' Day(s)');
  403. $('#ITP_FORM_STINFO05010_VIEW .fnUnit').text(result.unit);
  404. $('#ITP_FORM_STINFO05010_VIEW .fnCurr').text(result.curr);
  405. $('#ITP_FORM_STINFO05010_VIEW .fnUnitAmt').text(result.unitAmt.toString().replace(/\B(?=(\d{3})+(?!\d))/g, ','));
  406. $('#ITP_FORM_STINFO05010_VIEW .fnStoreSaleUnitAmt').text(result.storeSaleUnitAmt.toString().replace(/\B(?=(\d{3})+(?!\d))/g, ','));
  407. $('#ITP_FORM_STINFO05010_VIEW .fnRegId').text(result.sysRegId);
  408. $('#ITP_FORM_STINFO05010_VIEW .fnRegDt').text(result.sysRegDttm);
  409. $('#ITP_FORM_STINFO05010_VIEW .fnChgId').text(result.sysChgId);
  410. $('#ITP_FORM_STINFO05010_VIEW .fnChgDt').text(result.sysChgDttm);
  411. fileUploadInfo5010(result.imageFileNoList);
  412. /*
  413. itp_fn_attach_file.view('ITP_FORM_STINFO05010_VIEW_FILE', result.imageFileNoList
  414. , 'form-control itp_input', 'border:none; top:12px; left:12px; height:100px; width:125px; position:absolute;');
  415. */
  416. }
  417. };
  418. function fileUploadInfo5010(arr) {
  419. //파일업로드(등록/수정화면)
  420. var uid='#ITP_FORM_STINFO05010_VIEW_FILE';
  421. $(uid).empty();
  422. if(Array.isArray(arr) && arr.length ) {
  423. var sid='ITP_FORM_STINFO05010_VIEW';
  424. var fileNo=arr[0].fileNo;
  425. $(uid).bootstrapFileUpload({
  426. url: DOMAIN + '/api/file/upload',
  427. inputName: 'uploadFile',
  428. folderName: 'affl',
  429. fileNumber: fileNo,
  430. fileInput: null,
  431. fileTypes: ITP_UPLOAD_DEFAULTS.fileTypes,
  432. viewCode: 'R',
  433. formMethod: 'post',
  434. multiFile: true,
  435. multiUpload: false,
  436. maxSize: 100,
  437. maxFiles: 5,
  438. showThumb: false,
  439. thumbWidth: 80,
  440. thumbHeight: 80,
  441. debug: true,
  442. screen_id: sid,
  443. showYn: true
  444. });
  445. setTimeout(function() {
  446. $('#'+sid+'_UPLOAD_FORM').hide();
  447. },20);
  448. }
  449. }
  450. /*수정화면 Object*/
  451. let modifyObj = {
  452. init: function () {
  453. },
  454. button: {
  455. modify: function (param) {
  456. itp_fn_form_clear_validate(null, '#ITP_FORM_STINFO05010_DETAIL');
  457. const selectVal = $('#ITP_FORM_STINFO05010_VIEW_BRAND_UNIT_UNQ_NO').val();
  458. const key = {brandId:fn_make_user_info.get('brandId'), brandUnitUnqNo: selectVal, viewCd: 'R'};
  459. var param = $.param(key);
  460. modifyObj.load(param);
  461. }
  462. },
  463. load: function(param) {
  464. fn_ajax_call(API_DETAIL_INFO, param, this.callback, 'GET');
  465. },
  466. callback: function (result) {
  467. console.log(result);
  468. pageObj.switchScreen('MODIFY');
  469. $('#ITP_FORM_STINFO05010_DETAIL #ITP_FORM_STINFO05010_DETAIL_VIEW_CD').val('U');
  470. $('#ITP_FORM_STINFO05010_DETAIL #ITP_FORM_STINFO05010_DETAIL_BRAND_UNIT_UNQ_NO').val(result.brandUnitUnqNo);
  471. $('#ITP_FORM_STINFO05010_DETAIL .fnBrandNm').text(result.brandNm);
  472. $('#ITP_FORM_STINFO05010_DETAIL #ITP_FORM_STINFO05010_DETAIL_UNIT_ST_CD').val(result.unitStCd);
  473. $('#ITP_FORM_STINFO05010_DETAIL .fnItemId').text(result.itemId);
  474. $('#ITP_FORM_STINFO05010_DETAIL .fnItemNm').text(result.itemNm);
  475. $('#ITP_FORM_STINFO05010_DETAIL .fnSpplyId').text(result.spplyId);
  476. $('#ITP_FORM_STINFO05010_DETAIL .fnSpplyNm').text(result.spplyNm);
  477. $('#ITP_FORM_STINFO05010_DETAIL #ITP_FORM_STINFO05010_DETAIL_ITEM_ID').val(result.itemId);
  478. $('#ITP_FORM_STINFO05010_DETAIL #ITP_FORM_STINFO05010_DETAIL_ITEM_NM').val(result.itemNm);
  479. $('#ITP_FORM_STINFO05010_DETAIL #ITP_FORM_STINFO05010_DETAIL_SPPLY_ID').val(result.spplyId);
  480. $('#ITP_FORM_STINFO05010_DETAIL #ITP_FORM_STINFO05010_DETAIL_SPPLY_NM').val(result.spplyNm);
  481. $('#ITP_FORM_STINFO05010_DETAIL #ITP_FORM_STINFO05010_DETAIL_SPPLY_ITEM_ID').val(result.spplyItemId);
  482. $('#ITP_FORM_STINFO05010_DETAIL #ITP_FORM_STINFO05010_DETAIL_CONT_STT_DT').val(result.contSttDt === '' ? today : result.contSttDt);
  483. $('#ITP_FORM_STINFO05010_DETAIL #ITP_FORM_STINFO05010_DETAIL_CONT_END_DT').val(result.contEndDt === '' ? today : result.contEndDt);
  484. $('#ITP_FORM_STINFO05010_DETAIL #ITP_FORM_STINFO05010_DETAIL_LEAD_TIME').val(result.leadTime);
  485. $('#ITP_FORM_STINFO05010_DETAIL #ITP_FORM_STINFO05010_DETAIL_UNIT').val(result.unit);
  486. $('#ITP_FORM_STINFO05010_DETAIL #ITP_FORM_STINFO05010_DETAIL_CURR').val(result.curr);
  487. $('#ITP_FORM_STINFO05010_DETAIL #ITP_FORM_STINFO05010_DETAIL_UNIT_AMT').val(result.unitAmt.toString().replace(/\B(?=(\d{3})+(?!\d))/g, ','));
  488. $('#ITP_FORM_STINFO05010_DETAIL #ITP_FORM_STINFO05010_DETAIL_STORE_SALE_UNIT_AMT').val(result.storeSaleUnitAmt.toString().replace(/\B(?=(\d{3})+(?!\d))/g, ','));
  489. $('#ITP_FORM_STINFO05010_DETAIL .fnRegId').text(result.sysRegId);
  490. $('#ITP_FORM_STINFO05010_DETAIL .fnRegDt').text(result.sysRegDttm);
  491. $('#ITP_FORM_STINFO05010_DETAIL .fnChgId').text(result.sysChgId);
  492. $('#ITP_FORM_STINFO05010_DETAIL .fnChgDt').text(result.sysChgDttm);
  493. $('#ITP_FORM_STINFO05010_DETAIL #ITP_FORM_STINFO05010_DETAIL_FILE_NO').val(result.shortContFileNo);
  494. pageObj.fileUpload();
  495. }
  496. };
  497. /*신규화면 Object*/
  498. let createObj = {
  499. init: function () {
  500. pageObj.switchScreen('ADD');
  501. pageObj.fileUpload();
  502. itp_fn_form_clear_validate(null, '#ITP_FORM_STINFO05010_DETAIL');
  503. $('#ITP_FORM_STINFO05010_DETAIL_BRAND_ID').val(fn_make_user_info.get('brandId'));
  504. $('#ITP_FORM_STINFO05010_DETAIL .fnBrandNm').text(fn_make_user_info.get('brandNm'));
  505. },
  506. button: {
  507. cancel: function() {
  508. let childrens = $('#ITP_FORM_STINFO05010_VIEW_FILE').children();
  509. childrens.remove();
  510. listObj.grid.search();
  511. },
  512. save: function() {
  513. const formId = '#ITP_FORM_STINFO05010_DETAIL';
  514. $('#ITP_FORM_STINFO05010_DETAIL_UNIT').removeAttr('disabled');
  515. itp_fn_form_clear_validate(null, formId);
  516. if (itp_fn_form_event.isValid(formId)) {
  517. itp_fn_form_event.removeChar(formId);
  518. let param = $(formId).serializeObject();
  519. console.log(JSON.stringify(param));
  520. var searhFn = function() {
  521. ITP_FORM_STINFO05010_DETAIL_IS_WRITING = false;
  522. $('#ITP_FORM_STINFO05010_DETAIL_UNIT').attr('disabled', true);
  523. listObj.grid.search();
  524. };
  525. fn_ajax_call(API_DETAIL_SAVE, JSON.stringify(param), searhFn, 'POST');
  526. }
  527. }
  528. }
  529. };
  530. var itemClassLevel = {
  531. level: 1,
  532. levelID: 'ITP_FORM_STINFO05010_SEARCH_ITEM_CLASS',
  533. keys: function() {
  534. var keys = {sBrandId:fn_make_user_info.get('brandId'), sItemLevel: this.level};
  535. for(var i=1; i<=this.level; i++) {
  536. var key = 'sItemClass' + i;
  537. var id = '#' + this.levelID + i;
  538. keys[key] = $(id + ' option:selected').val();
  539. }
  540. return keys;
  541. },
  542. list: function(level) {
  543. this.level = level;
  544. this.clear(level);
  545. this.call( $.param(this.keys()));
  546. },
  547. call: function(param) {
  548. var _this = this;
  549. var callbackFn = function(result) {
  550. console.log(result);
  551. var id = _this.levelID + _this.level;
  552. fn_make_select_item_class(result.searchList, id, true, _this.emptyText());
  553. };
  554. fn_ajax_call(API_ITEM_CLASS_LEVEL, param, callbackFn, 'GET');
  555. },
  556. emptyText: function() {
  557. return '품목분류Level' + this.level;
  558. },
  559. clear: function(level) {
  560. for(var i=level; i<5; i++) {
  561. $('#' + (this.levelID + i)).find('option:not(:first)').remove();
  562. }
  563. }
  564. };
  565. var popSearch = {
  566. init: function(id, mode) {
  567. (id.lastIndexOf('DELETE') > -1 ? this.delete(id) : this.popup(id));
  568. },
  569. popup: function(id) {
  570. var popId = id.lastIndexOf('ITEM') > -1 ? 'BIZPOP_NEW_ITEM' : 'BIZPOP_STORE_SPPLY';
  571. var popFn = function(rowDataPop) {
  572. $.each(rowDataPop, function(key, value) {
  573. if(id.indexOf('SEARCH') > -1) {
  574. $('#ITP_FORM_STINFO05010_SEARCH_SPPLY_NM').val(rowDataPop.spplyNm);
  575. $('#ITP_FORM_STINFO05010_SEARCH_SPPLY_ID').val(rowDataPop.spplyId);
  576. } else {
  577. if(id.lastIndexOf('ITEM') > -1) {
  578. $('#ITP_FORM_STINFO05010_DETAIL_ITEM_ID').val(rowDataPop.itemId);
  579. $('#ITP_FORM_STINFO05010_DETAIL_ITEM_NM').val(rowDataPop.itemNm);
  580. $('#ITP_FORM_STINFO05010_DETAIL_SCH_ITEM_ID').val(rowDataPop.itemId);
  581. $('#ITP_FORM_STINFO05010_DETAIL_SCH_ITEM_NM').val(rowDataPop.itemNm);
  582. $('#ITP_FORM_STINFO05010_DETAIL_UNIT').val(rowDataPop.unit);
  583. } else {
  584. $('#ITP_FORM_STINFO05010_DETAIL_SPPLY_ID').val(rowDataPop.spplyId);
  585. $('#ITP_FORM_STINFO05010_DETAIL_SPPLY_NM').val(rowDataPop.spplyNm);
  586. $('#ITP_FORM_STINFO05010_DETAIL_SCH_SPPLY_ID').val(rowDataPop.spplyId);
  587. $('#ITP_FORM_STINFO05010_DETAIL_SCH_SPPLY_NM').val(rowDataPop.spplyNm);
  588. }
  589. }
  590. });
  591. };
  592. var agrs = {'sbrandId': fn_make_user_info.get('brandId')};
  593. fn_call_popup('biz', popId, '#ITP_ASIDE', popFn, agrs, 'S');
  594. // fn_call_popup('biz', 'BIZPOP_AFFL_BRAND', '#ITP_ASIDE', popFn, agrs, 'S');
  595. },
  596. delete: function(id) {
  597. if(id.indexOf('SEARCH') > -1) {
  598. $('#ITP_FORM_STINFO05010_SEARCH_SPPLY_NM').val('');
  599. $('#ITP_FORM_STINFO05010_SEARCH_SPPLY_ID').val('');
  600. } else {
  601. if(id.lastIndexOf('ITEM') > -1) {
  602. $('#ITP_FORM_STINFO05010_DETAIL_ITEM_ID').val('');
  603. $('#ITP_FORM_STINFO05010_DETAIL_ITEM_NM').val('');
  604. $('#ITP_FORM_STINFO05010_DETAIL_SCH_ITEM_ID').val('');
  605. $('#ITP_FORM_STINFO05010_DETAIL_SCH_ITEM_NM').val('');
  606. $('#ITP_FORM_STINFO05010_DETAIL_UNIT').val('');
  607. } else {
  608. $('#ITP_FORM_STINFO05010_DETAIL_SPPLY_ID').val('');
  609. $('#ITP_FORM_STINFO05010_DETAIL_SPPLY_NM').val('');
  610. $('#ITP_FORM_STINFO05010_DETAIL_SCH_SPPLY_ID').val('');
  611. $('#ITP_FORM_STINFO05010_DETAIL_SCH_SPPLY_NM').val('');
  612. }
  613. }
  614. }
  615. };