ITP_OPER02010.js 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747
  1. require(['config'], function() {
  2. require([
  3. 'jquery.bootstrap.fileUpload' //파일 업로드가 있는 페이지에서 로딩
  4. ], function($) {
  5. pageObj.init();
  6. });
  7. });
  8. const OPER02010_GRID_ID = '#ITP_OPER02010_jqGrid';
  9. const OPER02010_GRID_LIST = '#ITP_OPER02010_jqGrid_list';
  10. const OPER02010_GRID_PAGER = '#ITP_OPER02010_jqGridPager';
  11. const OPER02010_GRID_EMPTY = '#ITP_OPER02010_jqGridEmpty';
  12. // const OPER02010_VIEW_GRID_ID = '#ITP_OPER02010_VIEW_jqGrid';
  13. // const OPER02010_VIEW_GRID_LIST = '#ITP_OPER02010_VIEW_jqGrid_list';
  14. // const OPER02010_VIEW_GRID_PAGER = '#ITP_OPER02010_VIEW_jqGridPager';
  15. // const OPER02010_VIEW_GRID_EMPTY = '#ITP_OPER02010_VIEW_jqGridEmpty';
  16. //
  17. // const OPER02010_DETAIL_GRID_ID = '#ITP_OPER02010_DETAIL_jqGrid';
  18. // const OPER02010_DETAIL_GRID_LIST = '#ITP_OPER02010_DETAIL_jqGrid_list';
  19. // const OPER02010_DETAIL_GRID_PAGER = '#ITP_OPER02010_DETAIL_jqGridPager';
  20. // const OPER02010_DETAIL_GRID_EMPTY = '#ITP_OPER02010_DETAIL_jqGridEmpty';
  21. let ITP_FORM_OPER02010_DETAIL_IS_WRITING = false;
  22. let NTICE_SAVE_NTICE = '/api/ntice/save-ntice';
  23. let NTICE_DETAIL_GRID_LIST = '/api/ntice/detail-grid-list';
  24. let NTICE_INFO_NTICE = '/api/ntice/info-ntice';
  25. let NTICE_TARGET_GRID_LIST = '/api/ntice/target-grid-list';
  26. let BRAND_POP_GRID_LIST = '/api/brand/pop-grid-list';
  27. //공지사항 텍스트 제한
  28. $(document).ready(function() {
  29. $('#ITP_FORM_OPER02010_DETAIL #ITP_FORM_OPER02010_DETAIL_NTICE_DESC').on('keyup', function() {
  30. $('#ITP_FORM_OPER02010_DETAIL_NTICE_DESC_CNT').html('(' + $(this).val().length + ' / 1000)');
  31. console.log($(this).val().length);
  32. if ($(this).val().length > 1000) {
  33. $(this).val($(this).val().substring(0, 1000));
  34. $('#ITP_FORM_OPER02010_DETAIL_NTICE_DESC_CNT').html('(1000 / 1000)');
  35. }
  36. });
  37. });
  38. // Grid Column Model
  39. const gridColModel = {
  40. // 목록
  41. list: [
  42. {
  43. index: 'NTICE_NO', name: 'nticeNo',
  44. label: ITP_MSG_LOCALE.label.notiNo, //공지번호
  45. width: '8', fixed: false, align: 'center',
  46. sortable: false, hidden: false
  47. },
  48. {
  49. index: 'NTICE_TITL', name: 'nticeTitl',
  50. label: ITP_MSG_LOCALE.label.titlet, //공지제목
  51. width: '15', fixed: false, align: 'left',
  52. sortable: false, hidden: false, classes: 'ui-ellipsis'
  53. },
  54. {
  55. index: 'AFFL_SHOP_NM', name: 'afflShopNm',
  56. label: ITP_MSG_LOCALE.label.afflShopNm, //브랜드그룹
  57. width: '10', fixed: false, align: 'center',
  58. sortable: false, hidden: false, classes: 'ui-ellipsis'
  59. },
  60. {
  61. index: 'BRAND_NM', name: 'brandNm',
  62. label: ITP_MSG_LOCALE.label.brandNm, //브랜드
  63. width: '13', fixed: false, align: 'left',
  64. sortable: false, hidden: false, classes: 'ui-ellipsis'
  65. },
  66. {
  67. index: 'TARGET_NM', name: 'targetNm',
  68. label: ITP_MSG_LOCALE.label.targetNm, //공지대상
  69. width: '8', fixed: false, align: 'center',
  70. sortable: false, hidden: false
  71. },
  72. {
  73. index: 'NTICE_STAT_NM', name: 'nticeStatNm',
  74. label: ITP_MSG_LOCALE.label.status, //상태
  75. width: '7', fixed: false, align: 'center',
  76. sortable: false, hidden: false
  77. },
  78. {
  79. index: 'NOTI_ST_DAY', name: 'notiStDay',
  80. label: ITP_MSG_LOCALE.label.viewDt, //노출일
  81. width: '12', fixed: false, align: 'center',
  82. sortable: false, hidden: false
  83. },
  84. {
  85. index: 'ADD_DT', name: 'addDt',
  86. label: ITP_MSG_LOCALE.label.regDt, //등록일
  87. width: '10', fixed: false, align: 'center',
  88. sortable: false, hidden: false
  89. }
  90. ]/*,
  91. detail: [
  92. {
  93. index: 'VIEW_CD', name: 'viewCd',
  94. label: ITP_MSG_LOCALE.label.viewCd,
  95. width: '10', fixed: false, align: 'center',
  96. sortable: false, hidden: true
  97. },
  98. {
  99. index: 'NTICE_NO', name: 'nticeNo',
  100. label: ITP_MSG_LOCALE.label.notiNo,
  101. width: '10', fixed: false, align: 'center',
  102. sortable: false, hidden: true
  103. },
  104. {
  105. index: 'BRAND_ID', name: 'brandId',
  106. label: ITP_MSG_LOCALE.label.brandId,
  107. width: '20', fixed: false, align: 'center',
  108. sortable: false, editable: false, edittype: 'text'
  109. },
  110. {
  111. index: 'BRAND_NM', name: 'brandNm',
  112. label: ITP_MSG_LOCALE.label.brandNm,
  113. width: '30', fixed: false, align: 'center',
  114. sortable: false, editable: false, edittype: 'text'
  115. }
  116. ],
  117. brand: [
  118. {
  119. index: 'VIEW_CD', name: 'viewCd',
  120. label: ITP_MSG_LOCALE.label.viewCd,
  121. width: '10', fixed: false, align: 'center',
  122. sortable: false, hidden: true
  123. },
  124. {
  125. index: 'BRAND_ID', name: 'brandId',
  126. label: ITP_MSG_LOCALE.table.brandId,
  127. width: '20', fixed: false, align: 'center',
  128. sortable: false, editable: false, edittype: 'text'
  129. },
  130. {
  131. index: 'BRAND_NM', name: 'brandNm',
  132. label: ITP_MSG_LOCALE.table.brandNm,
  133. width: '30', fixed: false, align: 'center',
  134. sortable: false, editable: false, edittype: 'text'
  135. }
  136. ]*/
  137. };
  138. /********************************************************
  139. --------------------------------------------------------
  140. - Object 목록 -
  141. --------------------------------------------------------
  142. * let pageObj = {} : 화면공통 Object *
  143. * let listObj = {} : 목록화면 Object *
  144. * let viewObj = {} : 상세화면 Object *
  145. * let modifyObj = {} : 수정화면 Object *
  146. * let createObj = {} : 신규화면 Object *
  147. *******************************************************/
  148. /*화면공통 Object*/
  149. let pageObj = {
  150. init: function () {
  151. this.ui.init();
  152. this.event.init();
  153. },
  154. pageMode: '',
  155. ui: {
  156. init: function () {
  157. this.view();
  158. this.view();
  159. this.ready();
  160. },
  161. view: function () {
  162. // 버튼 권한설정
  163. fn_proc_btn_auth('OPER02010');
  164. // 공통코드 표시
  165. $('select').each(function() {
  166. if($(this).data('select-code')) {
  167. fn_make_select(CODE_LIST, $(this).data('select-code'), $(this).attr('id'));
  168. }
  169. });
  170. // 조회일자 지정
  171. var now = new Date();
  172. $('#ITP_TAB_OPER02010 .input-group.date').datepicker(ITP_DATE_LANGUAGE);
  173. $('#ITP_FORM_OPER02010_SEARCH_FROM_DT').datepicker('setDate', new Date());
  174. },
  175. afflInfo: {
  176. init: function() {
  177. this.authTpCd = fn_make_user_info.get('authTpCd');
  178. if(this.authTpCd === '30' || this.authTpCd === '40' || this.authTpCd === '50') {
  179. this.afflShopId = fn_make_user_info.get('afflShopId');
  180. this.afflShopNm = fn_make_user_info.get('afflShopNm');
  181. this.brandId = fn_make_user_info.get('brandId');
  182. this.brandNm = fn_make_user_info.get('brandNm');
  183. this.setAffl();
  184. }
  185. if (this.authTpCd === '40' || this.authTpCd === '50') {
  186. $('#ITP_FORM_OPER02010_SEARCH_AFFL_SHOP_BTN').attr('disabled', true);
  187. $('#ITP_FORM_OPER02010_DELETE_AFFL_SHOP_BTN').attr('disabled', true);
  188. }
  189. if (this.authTpCd === '50') {
  190. $('#ITP_BTN_OPER02010_NEWREG').hide();
  191. }
  192. },
  193. setAffl: function() {
  194. var _this = this;
  195. var afflShopId = '#ITP_FORM_OPER02010_' + (pageObj.pageMode === 'LIST' ? 'SEARCH' : 'DETAIL') + '_AFFL_SHOP_ID';
  196. var afflShopNm = '#ITP_FORM_OPER02010_' + (pageObj.pageMode === 'LIST' ? 'SEARCH' : 'DETAIL') + '_AFFL_SHOP_NM';
  197. // var afflShopId = '#ITP_FORM_OPER02010_' + (pageObj.pageMode === 'ADD' ? 'DETAIL' : 'SEARCH') + '_AFFL_SHOP_ID';
  198. // var afflShopNm = '#ITP_FORM_OPER02010_' + (pageObj.pageMode === 'ADD' ? 'DETAIL' : 'SEARCH') + '_AFFL_SHOP_NM';
  199. $(afflShopId).val(_this.afflShopId);
  200. $(afflShopNm).val(_this.afflShopNm);
  201. $(afflShopNm).attr('readonly', true);
  202. if(_this.authTpCd === '30') {
  203. var callbackFn = (result) => {
  204. var brandList = [];
  205. $.each(result.gridRows, function(i, item) {
  206. brandList.push({'brandId': item.brandId, 'brandNm': item.brandNm});
  207. });
  208. _this.setBrand(brandList);
  209. };
  210. var param = {
  211. 'afflShopId': _this.afflShopId
  212. };
  213. fn_ajax_call(BRAND_POP_GRID_LIST, JSON.stringify(param), callbackFn, 'POST');
  214. } else {
  215. var brandList = [{'brandId': _this.brandId, 'brandNm': _this.brandNm}];
  216. this.setBrand(brandList);
  217. }
  218. },
  219. setBrand: function(AFFL_BRAND) {
  220. var _this = this;
  221. if(AFFL_BRAND.length > 0) {
  222. var brandId = 'ITP_FORM_OPER02010_' + (pageObj.pageMode === 'LIST' ? 'SEARCH' : 'DETAIL') + '_BRAND_ID';
  223. (_this.authTpCd === '30') ? fn_make_select_brand(AFFL_BRAND, brandId, true, '선택') : fn_make_select_brand(AFFL_BRAND, brandId, false);
  224. } else {
  225. }
  226. }
  227. },
  228. ready: function () {
  229. listObj.init();
  230. // 브랜드그룹 조회
  231. afflShopObj.init();
  232. }
  233. },
  234. event: {
  235. init: function () {
  236. this.button();
  237. },
  238. button: function () {
  239. // 버튼 클릭 이벤트
  240. $('button').each(function() {
  241. var id = $(this).attr('id');
  242. $(this).on('click', function() {
  243. switch (id) {
  244. case 'ITP_BTN_OPER02010_SRH' : listObj.button.search(); break; // 조회 버튼 클릭
  245. case 'ITP_BTN_OPER02010_NEWREG' : listObj.button.create(); break; // 신규등록 버튼
  246. case 'ITP_BTN_OPER02010_MODIFY' : modifyObj.button.modify(); break; // 수정 버튼
  247. case 'ITP_BTN_OPER02010_CANCELLIST' : createObj.button.cancel(); break; // 취소/목록 버튼
  248. case 'ITP_BTN_OPER00210_DELETE' : break; // 삭제 버튼
  249. case 'ITP_BTN_OPER02010_SAVE' : createObj.button.save(); break; // 저장 버튼
  250. // case 'ITP_BTN_OPER02010_DETAIL_ADDROW' : pageObj.grid.button.addRow(); break; // 상세:추가버튼
  251. // case 'ITP_BTN_OPER02010_DETAIL_DELROW' : pageObj.grid.button.delRow(); break; // 상세:삭제버튼
  252. }
  253. });
  254. });
  255. },
  256. notiTarget: function(isDisabled) {
  257. $('#ITP_FORM_OPER02010_DETAIL #ITP_FORM_OPER02010_DETAIL_TARGET_CD').val('A');
  258. $('#ITP_FORM_OPER02010_DETAIL #ITP_FORM_OPER02010_DETAIL_TARGET_CD').attr('disabled', isDisabled);
  259. }
  260. },
  261. fileUpload: function() {
  262. //파일업로드(등록/수정화면)
  263. var id = 'OPER02010';
  264. $('#ITP_' + id + '_DETAIL_UPLOAD').empty();
  265. $('#ITP_' + id + '_DETAIL_LOGO_FILE').empty();
  266. var removeFn = (param) => {
  267. $('#ITP_' + id + '_DETAIL_LOGO_FILE').empty();
  268. };
  269. const fileArgs = {
  270. 'fileNo': $('#ITP_FORM_' + id + '_DETAIL_FILE_NO').val(),
  271. 'viewCd': $('#ITP_FORM_' + id + '_DETAIL_VIEW_CD').val(),
  272. 'showYn': $('#ITP_' + id + '_DETAIL_UPLOAD').attr('data-show-yn'),
  273. 'fileId': '#ITP_FORM_' + id + '_DETAIL_FILE_NO' //파일번호를 서버에서 받아서 넣을 파일번호 인풋박스 아이디
  274. };
  275. itp_fn_set_file_upload('ITP_' + id + '_DETAIL_UPLOAD', 'notice', true, false, id, fileArgs, removeFn);
  276. },
  277. switchScreen: function(mode) {
  278. pageObj.pageMode = mode;
  279. $('.itp_det_head').find('button[id^="ITP_BTN_OPER02010_"]').each(function(i) {
  280. $(this).hide();
  281. });
  282. $('#ITP_TAB_OPER02010').find('div[id$="_CONTAINER"]').each(function(i) {
  283. $(this).hide();
  284. });
  285. if(mode === 'LIST') { // 목록
  286. $('#ITP_AJAX_OPER02010_LIST_CONTAINER').show();
  287. $('#ITP_FORM_OPER02010_DELETE_AFFL_SHOP_BTN').show();
  288. fn_show_btn_auth_array(['#ITP_BTN_OPER02010_SRH', '#ITP_BTN_OPER02010_NEWREG']);
  289. pageObj.ui.afflInfo.init();
  290. } else if(mode == 'ADD') { // 등록
  291. $('#ITP_AJAX_OPER02010_DETAIL_CONTAINER').show();
  292. fn_show_btn_auth_array(['#ITP_BTN_OPER02010_CANCELLIST', '#ITP_BTN_OPER02010_SAVE']);
  293. $('#ITP_FORM_OPER02010_DETAIL').find('input, textarea, select, checkbox').each(function(i, elem) {
  294. $(this).attr('id') === 'ITP_FORM_OPER02010_DETAIL_VIEW_CD' ? $(this).val('C') : $(this).val('');
  295. if(elem.type === 'select') {
  296. $(this).val('').prop('selected', true);
  297. }
  298. });
  299. $('#ITP_FORM_OPER02010_FROM_DT').datepicker('setDate', new Date());
  300. $('#ITP_FORM_OPER02010_TO_DT').datepicker('setDate', new Date());
  301. $('#ITP_FORM_OPER02010_DETAIL #ITP_FORM_OPER02010_DETAIL_AFFL_SHOP_ID').val('');
  302. $('#ITP_FORM_OPER02010_DETAIL #ITP_FORM_OPER02010_DETAIL_AFFL_SHOP_NM').val('').prop('readonly', true);
  303. $('#ITP_FORM_OPER02010_DETAIL #ITP_FORM_OPER02010_DETAIL_SEARCH_BRAND_ID option').remove();
  304. $('#ITP_FORM_OPER02010_DETAIL #ITP_FORM_OPER02010_DETAIL_FILE_NO').val('');
  305. pageObj.ui.afflInfo.init();
  306. pageObj.event.notiTarget(fn_make_user_info.get('authTpCd') === '10');
  307. } else if(mode === 'MODIFY') { // 수정
  308. $('#ITP_AJAX_OPER02010_DETAIL_CONTAINER').show();
  309. fn_show_btn_auth_array(['#ITP_BTN_OPER02010_CANCELLIST', '#ITP_BTN_OPER02010_SAVE', '#ITP_BTN_OPER02010_RESET_PW']);
  310. $('#ITP_FORM_OPER02010_DETAIL #ITP_FORM_OPER02010_DETAIL_AFFL_SHOP_NM').prop('readonly', true);
  311. if(fn_make_user_info.get('authTpCd') === '30') {
  312. pageObj.ui.afflInfo.init();
  313. }
  314. } else if(mode === 'VIEW') { // 보기
  315. $('#ITP_AJAX_OPER02010_VIEW_CONTAINER').show();
  316. }
  317. }
  318. };
  319. /*목록화면 Object*/
  320. let listObj = {
  321. init: function () {
  322. // Grid
  323. this.grid.init();
  324. },
  325. button: {
  326. search: function () {
  327. listObj.grid.itp_OPER02010_search = true;
  328. let param = $('#ITP_FORM_OPER02010_SEARCH').serializeObject();
  329. param.gridSize = $.jgrid.defaults.rowNum;
  330. param.gridPage = $.jgrid.defaults.page;
  331. console.log(JSON.stringify(param));
  332. $(OPER02010_GRID_ID).setGridParam({'postData': JSON.stringify(param)}).trigger('reloadGrid');
  333. },
  334. create: function () {
  335. pageObj.switchScreen('ADD');
  336. itp_fn_form_clear_validate(null, '#ITP_FORM_OPER02010_DETAIL');
  337. createObj.init();
  338. }
  339. },
  340. grid: {
  341. init: function() {
  342. // 데이터 없을때
  343. this.itp_fn_OPER02010_empty.push();
  344. itp_fn_jqgrid_resize(OPER02010_GRID_ID, OPER02010_GRID_LIST, 'lg');
  345. // itp_fn_fire_window_resize();
  346. this.search();
  347. },
  348. itp_OPER02010_param: {},
  349. itp_OPER02010_search: false,
  350. colModel: gridColModel.list,
  351. search: function() {
  352. pageObj.switchScreen('LIST');
  353. this.unload();
  354. this.load();
  355. },
  356. load: function() {
  357. var _this = this;
  358. let param = $('#ITP_FORM_OPER02010_SEARCH').serializeObject();
  359. param.gridSize = $.jgrid.defaults.rowNum;
  360. var option = {
  361. gridId: OPER02010_GRID_ID,
  362. colModel: this.colModel,
  363. param: param,
  364. autowidth:true,
  365. shrinkToFit:false,
  366. url: DOMAIN + NTICE_DETAIL_GRID_LIST,
  367. pager: OPER02010_GRID_PAGER,
  368. onCellSelect: function(rowId, cellIdx, cellValue) {
  369. var cm = $(this).jqGrid('getGridParam', 'colModel');
  370. var colNm = cm[cellIdx].name;
  371. if (colNm == 'nticeTitl') {
  372. const nticeNoVal = $(this).jqGrid('getCell', rowId, 'nticeNo');
  373. const key = {nticeNo: nticeNoVal, viewCd: 'R'};
  374. var param = $.param(key);
  375. viewObj.init(param);
  376. }
  377. },
  378. loadComplete: function(data) {
  379. itp_fn_grid_load_complete(data, OPER02010_GRID_ID, true, 'number', 'OPER02010', listObj.grid.itp_OPER02010_search, _this.itp_fn_OPER02010_empty, true, data.gridRecords, true);
  380. var ids = $(OPER02010_GRID_ID).getDataIDs();
  381. $.each(ids, function(idx, rowId) {
  382. $(OPER02010_GRID_ID).jqGrid('setCell', rowId, 'nticeTitl', '', ITP_GRID_COL_STYLE.link);
  383. // $(OPER02010_GRID_ID).jqGrid('setCell', rowId, 'afflShopNm', '', ITP_GRID_COL_STYLE.link);
  384. });
  385. if ($('#ITP_CONTAINER').data('openYn') == 'Y') {
  386. $('#ITP_CONTAINER').data('openYn', 'N');
  387. const keyNew = {nticeNo: $('#ITP_CONTAINER').data('nticeNo'), viewCd: 'R'};
  388. var paramNew = $.param(keyNew);
  389. viewObj.init(paramNew);
  390. }
  391. }
  392. };
  393. itp_fn_grid_make_remote(option);
  394. },
  395. itp_fn_OPER02010_empty: {
  396. push: function() {
  397. let param = $('#ITP_FORM_OPER02010_SEARCH').serializeObject();
  398. listObj.grid.itp_OPER02010_param = param;
  399. },
  400. back: function() {
  401. var _this = listObj.grid;
  402. $('#ITP_FORM_OPER02010_DEVI_TP_CD').val(_this.itp_OPER02010_param.safflShopId);
  403. $('#ITP_FORM_OPER02010_ORDER_YN').val(_this.itp_OPER02010_param.safflShopNm);
  404. $('#ITP_FORM_OPER02010_ADT_AUTH_CD').val(_this.itp_OPER02010_param.sbrandId);
  405. $('#ITP_FORM_OPER02010_EMAIL_RCV_YN').val(_this.itp_OPER02010_param.snticeTitl);
  406. $('#ITP_FORM_OPER02010_FROM_DT').val(_this.itp_OPER02010_param.fromDt);
  407. $('#ITP_FORM_OPER02010_TO_DT').val(_this.itp_OPER02010_param.toDt);
  408. }
  409. },
  410. reload : function() {
  411. var _this = this;
  412. $(OPER02010_GRID_EMPTY).off('click').on('click', function() {
  413. _this.itp_fn_OPER02010_empty.back();
  414. _this.itp_OPER02010_param.gridSize = $.jgrid.defaults.rowNum;
  415. $(OPER02010_GRID_ID).setGridParam({'postData': JSON.stringify(_this.itp_OPER02010_param)}).trigger('reloadGrid');
  416. });
  417. },
  418. clearData : function() {
  419. $(OPER02010_GRID_ID).jqGrid('clearGridData', true);
  420. $(OPER02010_GRID_LIST).find('.ui-jqgrid-bdiv').css('min-height', '100px');
  421. $(OPER02010_GRID_EMPTY).html(ITP_MSG_LOCALE.message.grid.noData);
  422. $(OPER02010_GRID_EMPTY).show();
  423. },
  424. unload : function() {
  425. $.jgrid.gridUnload(OPER02010_GRID_ID);
  426. }
  427. }
  428. };
  429. /*상세화면 Object*/
  430. let viewObj = {
  431. init: function (param) {
  432. this.load(param);
  433. },
  434. button: {
  435. },
  436. load: function(param) {
  437. fn_ajax_call(NTICE_INFO_NTICE, param, this.callback, 'GET');
  438. },
  439. callback: function (result) {
  440. /*
  441. pageObj.switchScreen('VIEW');
  442. $('#ITP_FORM_OPER02010_VIEW #ITP_FORM_OPER02010_VIEW_NTICE_NO').val(result.nticeNo);
  443. $('#ITP_FORM_OPER02010_VIEW #ITP_FORM_OPER02010_VIEW_USER_ID').val(fn_make_user_info.get('userId'));
  444. $('#ITP_FORM_OPER02010_VIEW #ITP_FORM_OPER02010_VIEW_ADD_ID').val(result.addId);
  445. $('#ITP_FORM_OPER02010_VIEW .fnNticeTitl').text(result.nticeTitl);
  446. $('#ITP_FORM_OPER02010_VIEW .fnNotiDay').text(result.notiStDay+' ~ '+result.notiEdDay);
  447. $('#ITP_FORM_OPER02010_VIEW .fnDelYn').text(result.delYn);
  448. $('#ITP_FORM_OPER02010_VIEW .fnNticeDesc').html(result.nticeDesc.replace(/(\n|\r\n)/g, '<br>'));
  449. $('#ITP_FORM_OPER02010_VIEW .fnTargetNm').text(result.targetNm);
  450. $('#ITP_FORM_OPER02010_VIEW_FILE_NO').val(result.fileNo); //파일번호 셋팅
  451. $('#ITP_FORM_OPER02010_VIEW .fnAddId').text(result.addId);
  452. $('#ITP_FORM_OPER02010_VIEW .fnAddNm').text(result.addNm);
  453. itp_fn_attach_file.view('ITP_OPER02010_VIEW_UPLOAD', result.fileNoList
  454. , 'form-control itp_input', 'border:none; top:0px; left:12px; height:100px; width:125px; position:absolute;');
  455. // if(result.addId === fn_make_user_info.get('userId')) {
  456. if(fn_make_user_info.get('authTpCd') === '10' || result.addId === fn_make_user_info.get('userId')) {
  457. fn_show_btn_auth_array(['#ITP_BTN_OPER02010_MODIFY', '#ITP_BTN_OPER02010_CANCELLIST']);
  458. } else {
  459. fn_show_btn_auth_array(['#ITP_BTN_OPER02010_CANCELLIST']);
  460. }
  461. // 권한정보 리스트 조회
  462. // pageObj.grid.init('VIEW');
  463. */
  464. pageObj.switchScreen('VIEW');
  465. $('#ITP_FORM_OPER02010_VIEW_NTICE_NO').val(result.nticeNo);
  466. $('#ITP_FORM_OPER02010_VIEW_NTICE_TITL').val(result.nticeTitl);
  467. $('#ITP_FORM_OPER02010_VIEW_FROM_DT').val(result.notiStDay);
  468. $('#ITP_FORM_OPER02010_VIEW_TO_DT').val(result.notiEdDay);
  469. $('#ITP_FORM_OPER02010_VIEW_NTICE_DESC').val(result.nticeDesc);
  470. $('#ITP_FORM_OPER02010_VIEW_TARGET_CD').val(result.targetCd);
  471. $('#ITP_FORM_OPER02010_VIEW_FILE_NO').val(result.fileNo); //파일번호 셋팅
  472. // 브랜드그룹 셋팅
  473. $('#ITP_FORM_OPER02010_VIEW_AFFL_SHOP_ID').val(result.afflShopId);
  474. $('#ITP_FORM_OPER02010_VIEW_AFFL_SHOP_NM').val(result.afflShopNm);
  475. pageObj.ui.afflInfo.init();
  476. if(result.brandId && result.brandId !== '') {
  477. var brandList = [{'brandId':result.brandId, 'brandNm':result.brandNm}];
  478. fn_make_select_brand(brandList, 'ITP_FORM_OPER02010_VIEW_SEARCH_BRAND_ID');
  479. }
  480. pageObj.event.notiTarget(result.afflShopId === '');
  481. //파일업로드(수정화면)
  482. setFileUploadInfo('OPER02010','VIEW');
  483. formReadonly("#ITP_FORM_OPER02010_VIEW .form-control");
  484. // if(result.addId === fn_make_user_info.get('userId')) {
  485. if(fn_make_user_info.get('authTpCd') === '10' || result.addId === fn_make_user_info.get('userId')) {
  486. fn_show_btn_auth_array(['#ITP_BTN_OPER02010_MODIFY', '#ITP_BTN_OPER02010_CANCELLIST']);
  487. } else {
  488. fn_show_btn_auth_array(['#ITP_BTN_OPER02010_CANCELLIST']);
  489. }
  490. }
  491. };
  492. function formReadonly(qid) {
  493. if(!qid) qid='.form-readonly .form-control';
  494. setTimeout(function() {
  495. const formInputs=document.querySelectorAll(qid);
  496. formInputs.forEach(el=> {
  497. if( el.tagName=='SELECT') {
  498. $(el).css('pointer-events','none');
  499. } else {
  500. el.readOnly=true;
  501. el.classList.add("form-readonly");
  502. }
  503. });
  504. },100);
  505. }
  506. function setFileUploadInfo(id, type ) {
  507. //파일업로드(등록/수정화면)
  508. if(!id) id = 'OPER02010';
  509. var code=id + '_'+type;
  510. $('#ITP_' + code+'_UPLOAD').empty();
  511. $('#ITP_' + code+'_LOGO_FILE').empty();
  512. var removeFn = (param) => {
  513. $('#ITP_' + code+'_LOGO_FILE').empty();
  514. };
  515. $('#ITP_' + code+'_UPLOAD').bootstrapFileUpload({
  516. url: DOMAIN + '/api/file/upload',
  517. inputName: 'uploadFile',
  518. folderName: 'notice',
  519. fileNumber: $('#ITP_FORM_' + code+'_FILE_NO').val(),
  520. fileInput: '#ITP_FORM_' + code+'_FILE_NO',
  521. fileTypes: ITP_UPLOAD_DEFAULTS.fileTypes,
  522. viewCode: $('#ITP_FORM_' + code+'_VIEW_CD').val(),
  523. formMethod: 'post',
  524. multiFile: true,
  525. multiUpload: false,
  526. maxSize: 100,
  527. maxFiles: 5,
  528. showThumb: false,
  529. thumbWidth: 0,
  530. thumbHeight: 0,
  531. debug: true,
  532. screen_id: code,
  533. showYn: false,
  534. onInit: function() {
  535. }
  536. });
  537. setTimeout(function() {
  538. $('#ITP_' + code+'_UPLOAD .fileupload-add').hide();
  539. $('#ITP_' + code+'_UPLOAD .filedownload-remove').hide();
  540. },20);
  541. }
  542. /*수정화면 Object*/
  543. let modifyObj = {
  544. init: function (param) {
  545. },
  546. button: {
  547. modify: function () {
  548. itp_fn_form_clear_validate(null, '#ITP_FORM_OPER02010_DETAIL');
  549. const nticeNoVal = $('#ITP_FORM_OPER02010_VIEW_NTICE_NO').val();
  550. const userIdVal = $('#ITP_FORM_OPER02010_VIEW_USER_ID').val();
  551. const addIdVal = $('#ITP_FORM_OPER02010_VIEW_ADD_ID').val();
  552. const key = {nticeNo: nticeNoVal, viewCd: 'R'};
  553. if(addIdVal != userIdVal){
  554. itp_fn_modal_alert_ajax(ITP_MSG_LOCALE.message.ajax.diffWrite);
  555. return false;
  556. }
  557. var param = $.param(key);
  558. modifyObj.load(param);
  559. }
  560. },
  561. load: function(param) {
  562. fn_ajax_call(NTICE_INFO_NTICE, param, this.callback, 'GET');
  563. },
  564. callback: function (result) {
  565. pageObj.switchScreen('MODIFY');
  566. $('#ITP_FORM_OPER02010_DETAIL #ITP_FORM_OPER02010_DETAIL_VIEW_CD').val('U');
  567. $('#ITP_FORM_OPER02010_DETAIL #ITP_FORM_OPER02010_DETAIL_NTICE_NO').val(result.nticeNo);
  568. $('#ITP_FORM_OPER02010_DETAIL #ITP_FORM_OPER02010_DETAIL_NTICE_TITL').val(result.nticeTitl);
  569. $('#ITP_FORM_OPER02010_DETAIL #ITP_FORM_OPER02010_FROM_DT').val(result.notiStDay);
  570. $('#ITP_FORM_OPER02010_DETAIL #ITP_FORM_OPER02010_TO_DT').val(result.notiEdDay);
  571. $('#ITP_FORM_OPER02010_DETAIL #ITP_FORM_OPER02010_DEL_YN').val(result.delYn);
  572. $('#ITP_FORM_OPER02010_DETAIL #ITP_FORM_OPER02010_DETAIL_NTICE_DESC').val(result.nticeDesc);
  573. $('#ITP_FORM_OPER02010_DETAIL #ITP_FORM_OPER02010_DETAIL_TARGET_CD').val(result.targetCd);
  574. // $('#ITP_FORM_OPER02010_DETAIL #ITP_FORM_OPER02010_DETAIL_BRAND').prop('checked', result.brandChk === 'Y');
  575. // $('#ITP_FORM_OPER02010_DETAIL #ITP_FORM_OPER02010_DETAIL_STORE').prop('checked', result.shopChk === 'Y');
  576. // $('#ITP_FORM_OPER02010_DETAIL #ITP_FORM_OPER02010_DETAIL_SPPLY').prop('checked', result.supplyChk === 'Y');
  577. // $('#ITP_FORM_OPER02010_DETAIL #ITP_FORM_OPER02010_DETAIL_BRAND_CHK').val(result.brandChk);
  578. // $('#ITP_FORM_OPER02010_DETAIL #ITP_FORM_OPER02010_DETAIL_STORE_CHK').val(result.shopChk);
  579. // $('#ITP_FORM_OPER02010_DETAIL #ITP_FORM_OPER02010_DETAIL_SPPLY_CHK').val(result.supplyChk);
  580. $('#ITP_FORM_OPER02010_DETAIL_FILE_NO').val(result.fileNo); //파일번호 셋팅
  581. // 브랜드그룹 셋팅
  582. $('#ITP_FORM_OPER02010_DETAIL #ITP_FORM_OPER02010_DETAIL_AFFL_SHOP_ID').val(result.afflShopId);
  583. $('#ITP_FORM_OPER02010_DETAIL #ITP_FORM_OPER02010_DETAIL_AFFL_SHOP_NM').val(result.afflShopNm);
  584. // $('#ITP_FORM_OPER02010_DETAIL_SEARCH_AFFL_SHOP').attr('disabled', true);
  585. // $('#ITP_FORM_OPER02010_DETAIL_DELETE_AFFL_SHOP').attr('disabled', true);
  586. // $('#ITP_FORM_OPER02010_DETAIL #ITP_FORM_OPER02010_DETAIL_SEARCH_AFFL_SHOP_NM').attr('readonly', true);
  587. // $('#ITP_FORM_OPER02010_DETAIL #ITP_FORM_OPER02010_DETAIL_SEARCH_BRAND_ID').attr('readonly', true);
  588. pageObj.ui.afflInfo.init();
  589. if(result.brandId && result.brandId !== '') {
  590. var brandList = [{'brandId':result.brandId, 'brandNm':result.brandNm}];
  591. fn_make_select_brand(brandList, 'ITP_FORM_OPER02010_DETAIL_SEARCH_BRAND_ID');
  592. }
  593. pageObj.event.notiTarget(result.afflShopId === '');
  594. // if(result.targetCd && result.targetCd != '') {
  595. // $('#ITP_BTN_OPER02010_DETAIL_ADDROW').attr('disabled', false);
  596. // $('#ITP_BTN_OPER02010_DETAIL_DELROW').attr('disabled', false);
  597. // }
  598. //파일업로드(수정화면)
  599. pageObj.fileUpload();
  600. // 리스트 조회
  601. // createObj.form.init();
  602. // pageObj.grid.init('DETAIL');
  603. }
  604. };
  605. /*신규화면 Object*/
  606. let createObj = {
  607. init: function () {
  608. pageObj.fileUpload();
  609. },
  610. button: {
  611. save: function() {
  612. const formId = '#ITP_FORM_OPER02010_DETAIL';
  613. itp_fn_form_clear_validate(null, formId);
  614. $('#ITP_FORM_OPER02010_DETAIL_TARGET_CD').attr('disabled', false);
  615. if(fn_make_user_info.get('authTpCd') === '30') {
  616. $('#ITP_FORM_OPER02010_DETAIL_TARGET_CD').val('A');
  617. }
  618. if (itp_fn_form_event.isValid(formId)) {
  619. // let gridInsertData = [];
  620. // let gridUpdateData = [];
  621. // let gridDeleteData = [];
  622. // const rowData = $(OPER02010_DETAIL_GRID_ID).getRowData();
  623. // const keyValue = $(formId + '_USER_ID').val();
  624. // $.each(rowData, function(key, value) {
  625. // if (value.viewCd != 'R') {
  626. // value.nticeNo = keyValue;
  627. // if (value.viewCd == 'C') {
  628. // gridInsertData.push(value);
  629. // } else if (value.viewCd == 'U') {
  630. // gridUpdateData.push(value);
  631. // } else if (value.viewCd == 'D') {
  632. // gridDeleteData.push(value);
  633. // }
  634. // }
  635. // });
  636. let param = $(formId).serializeObject();
  637. // param.gridInsertData = gridInsertData;
  638. // param.gridUpdateData = gridUpdateData;
  639. // param.gridDeleteData = gridDeleteData;
  640. // console.log(JSON.stringify(param));
  641. var searhFn = function() {
  642. ITP_FORM_OPER02010_DETAIL_IS_WRITING = false;
  643. listObj.grid.search();
  644. };
  645. fn_ajax_call(NTICE_SAVE_NTICE, JSON.stringify(param), searhFn, 'POST');
  646. }
  647. },
  648. cancel: function() {
  649. listObj.grid.search();
  650. }
  651. }
  652. };
  653. /*브랜드그룹 조회 Object*/
  654. let afflShopObj = {
  655. init: function() {
  656. this.action();
  657. },
  658. button: function() {
  659. var _this = this;
  660. // 브랜드그룹 조회 버튼 클릭
  661. $('#ITP_FORM_OPER02010_SEARCH_AFFL_SHOP_BTN').on('click', function() {
  662. _this.popup('L');
  663. });
  664. // 브랜드그룹 텍스트 삭제 버튼 클릭
  665. $('#ITP_FORM_OPER02010_DELETE_AFFL_SHOP_BTN').on('click', function() {
  666. $('#ITP_FORM_OPER02010_SEARCH_AFFL_SHOP_ID').val('');
  667. $('#ITP_FORM_OPER02010_SEARCH_AFFL_SHOP_NM').val('');
  668. $('select#ITP_FORM_OPER02010_SEARCH_BRAND_ID option').remove();
  669. });
  670. // 신규등록 브랜드그룹 조회 버튼 클릭
  671. $('#ITP_FORM_OPER02010_DETAIL_SEARCH_AFFL_SHOP').on('click', function() {
  672. _this.popup('C');
  673. });
  674. // 신규등록 브랜드그룹 텍스트 삭제 버튼 클릭
  675. $('#ITP_FORM_OPER02010_DETAIL_DELETE_AFFL_SHOP').on('click', function() {
  676. $('#ITP_FORM_OPER02010_DETAIL_AFFL_SHOP_ID').val('');
  677. $('#ITP_FORM_OPER02010_DETAIL_AFFL_SHOP_NM').val('');
  678. $('select#ITP_FORM_OPER02010_DETAIL_BRAND_ID option').remove();
  679. $('#ITP_FORM_OPER02010_DETAIL_TARGET_CD option:eq(0)').prop('selected', true);
  680. // $('#ITP_FORM_OPER02010_DETAIL_TARGET_CD').trigger('change');
  681. pageObj.event.notiTarget(true);
  682. });
  683. },
  684. action: function() {
  685. this.button();
  686. },
  687. popup: function (view) {
  688. // 팝업
  689. var popFn = function(rowDataPop) {
  690. var id = (view === 'C') ? 'ITP_FORM_OPER02010_DETAIL' : 'ITP_FORM_OPER02010_SEARCH';
  691. if(rowDataPop.AFFL_SHOP) {
  692. $('#'+ id + '_AFFL_SHOP_ID').val(rowDataPop.AFFL_SHOP.afflShopId);
  693. $('#'+ id + '_AFFL_SHOP_NM').val(rowDataPop.AFFL_SHOP.afflShopNm);
  694. if(view === 'C') pageObj.event.notiTarget(false);
  695. }
  696. if(rowDataPop.AFFL_BRAND) {
  697. fn_make_select_brand(rowDataPop.AFFL_BRAND, id + '_BRAND_ID', true, '선택');
  698. }
  699. };
  700. fn_call_popup('biz', 'BIZPOP_AFFL_SHOP', '#ITP_ASIDE', popFn, null, 'S');
  701. }
  702. };