ITP_VENDINFO03010.js 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251
  1. require(['config'], function() {
  2. require([
  3. ], function($) {
  4. pageObj.init();
  5. });
  6. });
  7. // 화면변수
  8. const VENDINFO03010_GRID_ID = '#ITP_VENDINFO03010_jqGrid';
  9. const VENDINFO03010_GRID_LIST = '#ITP_VENDINFO03010_jqGrid_list';
  10. const VENDINFO03010_GRID_PAGER = '#ITP_VENDINFO03010_jqGridPager';
  11. const VENDINFO03010_GRID_EMPTY = '#ITP_VENDINFO03010_jqGridEmpty';
  12. // API URL
  13. let API_ITEMUNIT_SPPLY_GRID_LIST = '/api/itemunit/spply-grid-list';
  14. // 화면 grid ColModel
  15. const gridColModel = {
  16. list:[
  17. {
  18. index: 'ITEM_ID', name: 'itemId',
  19. label: ITP_MSG_LOCALE.label.itemId, //품목번호
  20. width: '10', fixed: false, align: 'center',
  21. sortable: false, hidden: false
  22. },
  23. {
  24. index: 'ITEM_NM', name: 'itemNm',
  25. label: ITP_MSG_LOCALE.label.itemNm, //품목명
  26. width: '12', fixed: false, align: 'left',
  27. sortable: false, hidden: false, classes: 'ui-ellipsis'
  28. },
  29. {
  30. index: 'UNIT', name: 'unit',
  31. label: ITP_MSG_LOCALE.label.unit, //기본단위
  32. width: '5', fixed: false, align: 'center',
  33. sortable: false, hidden: false
  34. },
  35. {
  36. index: 'CURR', name: 'curr',
  37. label: ITP_MSG_LOCALE.label.curr, //통화
  38. width: '4', fixed: false, align: 'center',
  39. sortable: false, hidden: false
  40. },
  41. {
  42. index: 'UNIT_AMT', name: 'unitAmt',
  43. label: ITP_MSG_LOCALE.label.unitAmt, //단가
  44. width: '5', fixed: false, align: 'right',
  45. sortable: false, hidden: false,
  46. formatter: 'integer', formatoptions: {thousandsSeparator: ','}
  47. },
  48. {
  49. index: 'CONT_STT_DT', name: 'contSttDt',
  50. label: ITP_MSG_LOCALE.label.contSttDt, //시작일
  51. width: '7', fixed: false, align: 'center',
  52. sortable: false, hidden: false
  53. },
  54. {
  55. index: 'CONT_END_DT', name: 'contEndDt',
  56. label: ITP_MSG_LOCALE.label.contEndDt, //종료일
  57. width: '7', fixed: false, align: 'center',
  58. sortable: false, hidden: false
  59. },
  60. {
  61. index: 'LEAD_TIME', name: 'leadTime',
  62. label: ITP_MSG_LOCALE.label.leadTime, //리드타임 (Day)
  63. width: '7', fixed: false, align: 'right',
  64. sortable: false, hidden: false
  65. },
  66. {
  67. index: 'UNIT_ST_NM', name: 'unitStNm',
  68. label: ITP_MSG_LOCALE.label.status, //상태
  69. width: '4', fixed: false, align: 'center',
  70. sortable: false, hidden: false
  71. },
  72. {
  73. index: 'SPPLY_ITME_ID', name: 'spplyItemId',
  74. label: ITP_MSG_LOCALE.label.spplyItemId, //공급사품번
  75. width: '10', fixed: false, align: 'center',
  76. sortable: false, hidden: false
  77. }
  78. ]
  79. }
  80. /*화면공통 Object*/
  81. let pageObj = {
  82. init: function () {
  83. this.ui.init();
  84. this.event.init();
  85. },
  86. ui: {
  87. init: function () {
  88. this.view();
  89. this.grid();
  90. this.ready();
  91. },
  92. view: function() {
  93. // 버튼 권한설정
  94. fn_proc_btn_auth('VENDINFO03010');
  95. // 공통코드 표시
  96. $('select').each(function() {
  97. if($(this).data('select-code')) {
  98. fn_make_select(CODE_LIST, $(this).data('select-code'), $(this).attr('id'));
  99. }
  100. });
  101. // 조회일자 지정
  102. var now = new Date();
  103. var defaultToDate = new Date(now);
  104. defaultToDate.setDate(now.getDate()+7);
  105. $('#ITP_TAB_VENDINFO03010 .input-group.date').datepicker(ITP_DATE_LANGUAGE);
  106. $('#ITP_FORM_VENDINFO03010_SEARCH_FROM_DT').datepicker('setDate', now);
  107. $('#ITP_FORM_VENDINFO03010_SEARCH_TO_DT').datepicker('setDate', defaultToDate);
  108. },
  109. grid: function() {
  110. itp_fn_jqgrid_resize(VENDINFO03010_GRID_ID, VENDINFO03010_GRID_LIST, 'lg');
  111. itp_fn_fire_window_resize();
  112. },
  113. ready: function() {
  114. listObj.init();
  115. }
  116. },
  117. event: {
  118. init: function () {
  119. this.button();
  120. },
  121. button: function () {
  122. // 버튼 클릭 이벤트
  123. $('button').each(function() {
  124. var id = $(this).attr('id');
  125. $(this).on('click', function() {
  126. switch (id) {
  127. case 'ITP_BTN_VENDINFO03010_SRH' : listObj.button.search(); break; // 조회 버튼 클릭
  128. case 'ITP_BTN_VENDINFO03010_NEWREG' : listObj.button.create(); break; // 신규등록 버튼
  129. case 'ITP_BTN_VENDINFO03010_MODIFY' : modifyObj.button.modify(); break; // 수정 버튼
  130. case 'ITP_BTN_VENDINFO03010_CANCELLIST' : createObj.button.cancel(); break; // 취소/목록 버튼
  131. case 'ITP_BTN_VENDINFO03010_DELETE' : break; // 삭제 버튼
  132. case 'ITP_BTN_VENDINFO03010_SAVE' : createObj.button.save(); break; // 저장 버튼
  133. case 'ITP_BTN_VENDINFO03010_EXCEL' : listObj.excelDown(); break; // 엑셀 다운로드
  134. }
  135. });
  136. });
  137. }
  138. },
  139. switchScreen: function(mode) {
  140. $('.itp_det_head').find('button[id^="ITP_BTN_VENDINFO03010_"]').each(function(i) {
  141. $(this).hide();
  142. });
  143. $('#ITP_TAB_VENDINFO03010').find('div[id$="_CONTAINER"]').each(function(i) {
  144. $(this).hide();
  145. });
  146. if(mode === 'LIST') { // 목록
  147. $('#ITP_AJAX_VENDINFO03010_LIST_CONTAINER').show();
  148. fn_show_btn_auth_array(['#ITP_BTN_VENDINFO03010_SRH', '#ITP_BTN_VENDINFO03010_NEWREG']);
  149. $('#ITP_FORM_VENDINFO03010_SEARCH #ITP_FORM_VENDINFO03010_SEARCH_BRAND_ID').val(fn_make_user_info.get('brandId'));
  150. $('#ITP_FORM_VENDINFO03010_SEARCH #ITP_FORM_VENDINFO03010_SEARCH_SPPLY_ID').val(fn_make_user_info.get('spplyId'));
  151. $('#ITP_BTN_VENDINFO03010_EXCEL').show();
  152. }
  153. }
  154. }
  155. /*목록화면 Object*/
  156. let listObj = {
  157. init: function () {
  158. this.grid.init();
  159. },
  160. itp_VENDINFO03010_param: {},
  161. itp_VENDINFO03010_search: false,
  162. button: {
  163. search: function() {
  164. listObj.itp_VENDINFO03010_search = true;
  165. let param = $('#ITP_FORM_VENDINFO03010_SEARCH').serializeObject();
  166. param.gridSize = $.jgrid.defaults.rowNum;
  167. param.gridPage = $.jgrid.defaults.page;
  168. $(VENDINFO03010_GRID_ID).setGridParam({'postData': JSON.stringify(param)}).trigger('reloadGrid');
  169. }
  170. },
  171. empty: {
  172. init: function() {
  173. },
  174. push: function() {
  175. },
  176. back: function() {
  177. }
  178. },
  179. grid: {
  180. init: function () {
  181. // 데이터 없을때
  182. this.search();
  183. },
  184. colModel: gridColModel.list,
  185. search: function() {
  186. pageObj.switchScreen('LIST');
  187. this.unload();
  188. this.load();
  189. },
  190. load: function() {
  191. let param = $('#ITP_FORM_VENDINFO03010_SEARCH').serializeObject();
  192. param.gridSize = $.jgrid.defaults.rowNum;
  193. var option = {
  194. gridId: VENDINFO03010_GRID_ID,
  195. colModel: gridColModel.list,
  196. param: param,
  197. url: DOMAIN + API_ITEMUNIT_SPPLY_GRID_LIST,
  198. pager: VENDINFO03010_GRID_PAGER,
  199. rownumbers: false,
  200. loadComplete: function(data) {
  201. itp_fn_grid_load_complete(data, VENDINFO03010_GRID_ID, true, 'number', 'VENDINFO03010', listObj.itp_VENDINFO03010_search, listObj.empty, true, data.gridRecords, true);
  202. var ids = $(VENDINFO03010_GRID_ID).getDataIDs();
  203. $.each(ids, function(idx, rowId) {
  204. $(VENDINFO03010_GRID_ID).jqGrid('setCell', rowId, 'spplyId', '', ITP_GRID_COL_STYLE.link);
  205. });
  206. },
  207. onPaging: function(action) {
  208. itp_fn_grid_paging(VENDINFO03010_GRID_ID, action, param);
  209. }
  210. };
  211. itp_fn_grid_make_remote(option);
  212. },
  213. clearData : function() {
  214. $(VENDINFO03010_GRID_ID).jqGrid('clearGridData', true);
  215. $(VENDINFO03010_GRID_LIST).find('.ui-jqgrid-bdiv').css('min-height', '100px');
  216. $(VENDINFO03010_GRID_EMPTY).html(ITP_MSG_LOCALE.message.grid.noData);
  217. $(VENDINFO03010_GRID_EMPTY).show();
  218. },
  219. unload : function() {
  220. $.jgrid.gridUnload(VENDINFO03010_GRID_ID);
  221. }
  222. },
  223. excelDown: function() {
  224. var param = {
  225. 'url': API_ITEMUNIT_SPPLY_GRID_LIST,
  226. 'param': $('#ITP_FORM_VENDINFO03010_SEARCH').serializeObject(),
  227. 'gridColumns': $(VENDINFO03010_GRID_ID).jqGrid('getGridParam', 'colModel'),
  228. 'fileName': '공급사 단가정보.xlsx',
  229. 'sheetName': '공급사 단가리스트'
  230. };
  231. itp_fn_remote_to_excel(param);
  232. }
  233. };