ITP_OPER06010.js 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587
  1. require(['config'], function() {
  2. require([
  3. 'jquery.bootstrap.fileUpload', //파일 업로드가 있는 페이지에서 로딩
  4. 'kakao.map.util'
  5. ], function($) {
  6. pageObj.init();
  7. });
  8. });
  9. /********************************************************
  10. --------------------------------------------------------
  11. - Object 목록 -
  12. --------------------------------------------------------
  13. * const gridColModel = {} : 화면 Grid Object *
  14. * let pageObj = {} : 화면공통 Object *
  15. * let listObj = {} : 목록화면 Object *
  16. * let viewObj = {} : 상세화면 Object *
  17. * let modifyObj = {} : 수정화면 Object *
  18. * let createObj = {} : 신규화면 Object *
  19. *******************************************************/
  20. /*화면 변수*/
  21. const OPER06010_GRID_ID = '#ITP_OPER06010_jqGrid';
  22. const OPER06010_GRID_LIST = '#ITP_OPER06010_jqGrid_list';
  23. const OPER06010_GRID_PAGER = '#ITP_OPER06010_jqGridPager';
  24. const OPER06010_GRID_EMPTY = '#ITP_OPER06010_jqGridEmpty';
  25. const OPER06010_VIEW_GRID_ID = '#ITP_OPER06010_VIEW_jqGrid';
  26. const OPER06010_VIEW_GRID_LIST = '#ITP_OPER06010_VIEW_jqGrid_list';
  27. const OPER06010_VIEW_GRID_PAGER = '#ITP_OPER06010_VIEW_jqGridPager';
  28. const OPER06010_VIEW_GRID_EMPTY = '#ITP_OPER06010_VIEW_jqGridEmpty';
  29. const OPER06010_DETAIL_GRID_ID = '#ITP_OPER06010_DETAIL_jqGrid';
  30. const OPER06010_DETAIL_GRID_LIST = '#ITP_OPER06010_DETAIL_jqGrid_list';
  31. const OPER06010_DETAIL_GRID_PAGER = '#ITP_OPER06010_DETAIL_jqGridPager';
  32. const OPER06010_DETAIL_GRID_EMPTY = '#ITP_OPER06010_DETAIL_jqGridEmpty';
  33. /*API URL*/
  34. let API_DETAIL_GRID_LIST = '/api/brand/detail-grid-list';
  35. let API_DETAIL_INFO = '/api/brand/info-brand';
  36. let API_DETAIL_SAVE = '/api/brand/save-brand';
  37. let BRAND_POP_GRID_LIST = '/api/brand/pop-grid-list';
  38. let ITP_FORM_OPER06010_DETAIL_IS_WRITING = false;
  39. /*화면 Grid Object*/
  40. const gridColModel = {
  41. list: [
  42. {
  43. index: 'VIEW_CD', name: 'viewCd',
  44. label: ITP_MSG_LOCALE.label.viewCd,
  45. width: '10', fixed: false, align: 'center',
  46. sortable: false, hidden: true
  47. },
  48. {
  49. index: 'AFFL_SHOP_ID', name: 'afflShopId',
  50. label: ITP_MSG_LOCALE.label.afflShopId,
  51. width: '10', fixed: false, align: 'center',
  52. sortable: false, hidden: true
  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
  59. },
  60. {
  61. index: 'BRAND_ID', name: 'brandId',
  62. label: ITP_MSG_LOCALE.label.brandId,
  63. width: '10', fixed: false, align: 'center',
  64. sortable: false, hidden: false
  65. },
  66. {
  67. index: 'BRAND_NM', name: 'brandNm',
  68. label: ITP_MSG_LOCALE.label.brandNm, //브랜드명
  69. width: '13', fixed: false, align: 'center',
  70. sortable: false, hidden: false
  71. },
  72. {
  73. index: 'ST_NM', name: 'stNm',
  74. label: ITP_MSG_LOCALE.label.stNm, //상태
  75. width: '10', fixed: false, align: 'center',
  76. sortable: false, hidden: false
  77. },
  78. {
  79. index: 'BRAND_TYPE_NM', name: 'brandTypeNm',
  80. label: ITP_MSG_LOCALE.label.brandTypeNm, //브랜드 타입
  81. width: '13', fixed: false, align: 'center',
  82. sortable: false, hidden: false
  83. },
  84. {
  85. index: 'REG_DT', name: 'regDt',
  86. label: ITP_MSG_LOCALE.label.regDt, //등록일
  87. width: '10', fixed: false, align: 'center',
  88. sortable: false, hidden: false
  89. }],
  90. view: [],
  91. detail: []
  92. };
  93. /*화면공통 Object*/
  94. let pageObj = {
  95. init: function () {
  96. this.ui.init();
  97. this.event.init();
  98. },
  99. ui: {
  100. init: function () {
  101. this.view();
  102. this.grid();
  103. this.ready();
  104. },
  105. view: function() {
  106. // 버튼 권한설정
  107. fn_proc_btn_auth('OPER06010');
  108. // 공통코드 표시
  109. $('select').each(function() {
  110. if($(this).data('select-code')) {
  111. fn_make_select(CODE_LIST, $(this).data('select-code'), $(this).attr('id'));
  112. }
  113. });
  114. itp_fn_form_event.onKeyup('#ITP_FORM_OPER06010_DETAIL');
  115. // form alert message 주입
  116. $('input[data-alert-required="ONLYCHK"]').each(function() {
  117. if($(this).data('alert-msg') === 'address') {
  118. $(this).data('alert-msg', ITP_MSG_LOCALE.message.form.emptyAddr);
  119. }
  120. });
  121. itp_fn_form_event.onKeyup('#ITP_FORM_OPER03010_DETAIL');
  122. //pg사아이디 선택시 보이게함
  123. $('#ITP_FORM_OPER06010_DETAIL_PG_ID').on('change', function() {
  124. if($(this).val() === '') {
  125. $('#ITP_FORM_OPER06010_DETAIL .itp_form_pg').hide();
  126. } else {
  127. $('#ITP_FORM_OPER06010_DETAIL .itp_form_pg').show();
  128. }
  129. });
  130. },
  131. grid: function() {
  132. itp_fn_jqgrid_resize(OPER06010_GRID_ID, OPER06010_GRID_LIST, 'lg');
  133. listObj.empty.init();
  134. itp_fn_fire_window_resize();
  135. },
  136. ready: function() {
  137. listObj.init();
  138. }
  139. },
  140. event: {
  141. init: function () {
  142. this.button();
  143. },
  144. button: function () {
  145. // 버튼 클릭 이벤트
  146. $('button').each(function() {
  147. var id = $(this).attr('id');
  148. $(this).on('click', function() {
  149. switch (id) {
  150. case 'ITP_BTN_OPER06010_SRH' : listObj.button.search(); break; // 조회 버튼 클릭
  151. case 'ITP_BTN_OPER06010_NEWREG' : listObj.button.create(); break; // 신규등록 버튼
  152. case 'ITP_BTN_OPER06010_MODIFY' : modifyObj.button.modify(); break; // 수정 버튼
  153. case 'ITP_BTN_OPER06010_CANCELLIST' : createObj.button.cancel(); break; // 취소/목록 버튼
  154. case 'ITP_BTN_OPER06010_DELETE' : break; // 삭제 버튼
  155. case 'ITP_BTN_OPER06010_SAVE' : createObj.button.save(); break; // 저장 버튼
  156. case 'ITP_FORM_OPER06010_DETAIL_DUP' : createObj.button.duplicate(); break; // 중복체크
  157. case 'ITP_BTN_OPER06010_RESET_PW' : createObj.button.resetPass(); break; // 상세:비밀번호 초기화
  158. case 'ITP_FORM_OPER06010_DETAIL_ADRES_SCH' : createObj.button.address(); break; // 신규등록 주소 찾기
  159. case 'ITP_BTN_OPER06010_DETAIL_ADDROW' : afflShopObj.button.addRow(); break; // 상세:추가버튼
  160. case 'ITP_BTN_OPER06010_DETAIL_DELROW' : afflShopObj.button.delRow(); break; // 상세:삭제버튼
  161. }
  162. });
  163. });
  164. }
  165. },
  166. fileUpload: function() {
  167. //파일업로드(수정화면)
  168. var id = 'OPER06010';
  169. $('#ITP_' + id + '_DETAIL_UPLOAD').empty();
  170. $('#ITP_' + id + '_DETAIL_LOGO_FILE').empty();
  171. var removeFn = (param) => {
  172. $('#ITP_' + id + '_DETAIL_LOGO_FILE').empty();
  173. };
  174. const fileArgs = {
  175. 'fileNo': $('#ITP_FORM_' + id + '_DETAIL_FILE_NO').val(),
  176. 'viewCd': $('#ITP_FORM_' + id + '_DETAIL_VIEW_CD').val(),
  177. 'showYn': $('#ITP_' + id + '_DETAIL_UPLOAD').attr('data-show-yn'),
  178. 'fileId': '#ITP_FORM_' + id + '_DETAIL_FILE_NO' //파일번호를 서버에서 받아서 넣을 파일번호 인풋박스 아이디
  179. };
  180. itp_fn_set_file_upload('ITP_' + id + '_DETAIL_UPLOAD', 'brand', true, false, id, fileArgs, removeFn);
  181. },
  182. switchScreen: function(mode) {
  183. $('.itp_det_head').find('button[id^="ITP_BTN_OPER06010_"]').each(function(i) {
  184. $(this).hide();
  185. });
  186. $('#ITP_TAB_OPER06010').find('div[id$="_CONTAINER"]').each(function(i) {
  187. $(this).hide();
  188. });
  189. if(mode == 'LIST') { // 목록
  190. fn_show_btn_auth_array(['#ITP_BTN_OPER06010_SRH', '#ITP_BTN_OPER06010_NEWREG']);
  191. $('#ITP_AJAX_OPER06010_LIST_CONTAINER').show();
  192. } else if(mode == 'ADD') { // 등록
  193. $('#ITP_AJAX_OPER06010_DETAIL_CONTAINER').show();
  194. fn_show_btn_auth_array(['#ITP_BTN_OPER06010_CANCELLIST', '#ITP_BTN_OPER06010_SAVE']);
  195. $('#ITP_FORM_OPER06010_DETAIL').find('input, textarea, select, checkbox').each(function(i, elem) {
  196. $(this).attr('id') === 'ITP_FORM_OPER06010_DETAIL_VIEW_CD' ? $(this).val('C') : $(this).val('');
  197. if(elem.type === 'select') {
  198. $(this).val('').prop('selected', true);
  199. }
  200. });
  201. $('#ITP_FORM_OPER06010_DETAIL #ITP_FORM_OPER06010_DETAIL_FILE_NO').val('');
  202. $('#ITP_FORM_OPER06010_DETAIL_BRAND_ID').removeAttr('readonly');
  203. $('#ITP_FORM_OPER06010_DETAIL_BRAND_NM').removeAttr('readonly');
  204. $('#ITP_FORM_OPER06010_DETAIL_BSNS_REG_NO').removeAttr('readonly');
  205. $('#ITP_FORM_OPER06010_DETAIL_CORP_REG_NO').removeAttr('readonly');
  206. // $('#ITP_FORM_OPER06010_DETAIL_SEARCH_AFFL_SHOP').removeAttr('disabled');
  207. // $('#ITP_FORM_OPER06010_DETAIL_DELETE_AFFL_SHOP').removeAttr('disabled');
  208. $('#ITP_FORM_OPER06010_DETAIL_SEARCH_AFFL_SHOP').show();
  209. $('#ITP_FORM_OPER06010_DETAIL_DELETE_AFFL_SHOP').show();
  210. $('#ITP_FORM_OPER06010_DETAIL .itp_form_info').hide();
  211. $('#ITP_FORM_OPER06010_DETAIL .itp_form_change').show();
  212. $('#ITP_FORM_OPER06010_DETAIL #ITP_FORM_OPER06010_DETAIL_AFFL_SHOP_ID').val(fn_make_user_info.get('afflShopId'));
  213. $('#ITP_FORM_OPER06010_DETAIL #ITP_FORM_OPER06010_DETAIL_BRAND_ID').val(fn_make_user_info.get('brandId'));
  214. $('.fnBrandId').text('(자동부여)');
  215. $('#ITP_FORM_OPER06010_DETAIL_PG_ID').trigger('change');
  216. } else if(mode == 'MODIFY') { // 수정
  217. $('#ITP_AJAX_OPER06010_DETAIL_CONTAINER').show();
  218. fn_show_btn_auth_array(['#ITP_BTN_OPER06010_CANCELLIST', '#ITP_BTN_OPER06010_SAVE']);
  219. $('#ITP_FORM_OPER06010_DETAIL_BRAND_ID').attr('readonly', true);
  220. $('#ITP_FORM_OPER06010_DETAIL_BRAND_NM').attr('readonly', true);
  221. $('#ITP_FORM_OPER06010_DETAIL_BSNS_REG_NO').attr('readonly', true);
  222. $('#ITP_FORM_OPER06010_DETAIL_CORP_REG_NO').attr('readonly', true);
  223. // $('#ITP_FORM_OPER06010_DETAIL_SEARCH_AFFL_SHOP').attr('disabled', true);
  224. // $('#ITP_FORM_OPER06010_DETAIL_DELETE_AFFL_SHOP').attr('disabled', true);
  225. $('#ITP_FORM_OPER06010_DETAIL_SEARCH_AFFL_SHOP').hide();
  226. $('#ITP_FORM_OPER06010_DETAIL_DELETE_AFFL_SHOP').hide();
  227. $('#ITP_FORM_OPER06010_DETAIL .itp_form_info').show();
  228. $('#ITP_FORM_OPER06010_DETAIL .itp_form_change').hide();
  229. $('#ITP_FORM_OPER06010_DETAIL #ITP_FORM_OPER06010_DETAIL_BRAND_ID').val(fn_make_user_info.get('brandId'));
  230. } else if(mode == 'VIEW') { // 보기
  231. $('#ITP_AJAX_OPER06010_VIEW_CONTAINER').show();
  232. fn_show_btn_auth_array(['#ITP_BTN_OPER06010_MODIFY', '#ITP_BTN_OPER06010_CANCELLIST']);
  233. }
  234. }
  235. };
  236. /*목록화면 Object*/
  237. let listObj = {
  238. init: function () {
  239. afflShopObj.init();
  240. this.grid.init();
  241. },
  242. itp_OPER06010_param: {},
  243. itp_OPER06010_search: false,
  244. button: {
  245. search: function() {
  246. listObj.itp_OPER06010_search = true;
  247. let param = $('#ITP_FORM_OPER06010_SEARCH').serializeObject();
  248. param.gridSize = $.jgrid.defaults.rowNum;
  249. param.gridPage = $.jgrid.defaults.page;
  250. console.log(JSON.stringify(param));
  251. $(OPER06010_GRID_ID).setGridParam({'postData': JSON.stringify(param)}).trigger('reloadGrid');
  252. },
  253. create: function() {
  254. if($('#ITP_FORM_OPER06010_DETAIL_AFFL_SHOP_ID').val() === '') {
  255. itp_fn_modal_alert('가맹점 정보가 존재하지 않습니다.');
  256. return;
  257. }
  258. pageObj.switchScreen('ADD');
  259. itp_fn_form_clear_validate(null, '#ITP_FORM_OPER06010_DETAIL');
  260. // 권한정보 리스트 조회
  261. createObj.init();
  262. }
  263. },
  264. empty: {
  265. init: function() {
  266. var _this = this;
  267. this.push();
  268. $(OPER06010_GRID_EMPTY).on('click', function() {
  269. _this.back();
  270. listObj.itp_OPER06010_param.gridSize = $.jgrid.defaults.rowNum;
  271. $(OPER06010_GRID_ID).setGridParam({'postData': JSON.stringify(listObj.itp_OPER06010_param)}).trigger('reloadGrid');
  272. });
  273. },
  274. push: function() {
  275. let param = $('#ITP_FORM_OPER06010_SEARCH').serializeObject();
  276. listObj.itp_OPER06010_param = param;
  277. },
  278. back: function() {
  279. $('#ITP_FORM_OPER06010_SERVICE_BRAND_TYPE').val(listObj.itp_OPER06010_param.brandType);
  280. $('#ITP_FORM_OPER06010_SERVICE_ST_CD').val(listObj.itp_OPER06010_param.stCd);
  281. $('#ITP_FORM_OPER06010_SEARCH_BRAND_NM').val(listObj.itp_OPER06010_param.brandNm);
  282. }
  283. },
  284. grid: {
  285. init: function () {
  286. // 데이터 없을때
  287. listObj.empty.push();
  288. this.search();
  289. },
  290. colModel: gridColModel.list,
  291. search: function() {
  292. pageObj.switchScreen('LIST');
  293. this.unload();
  294. this.load();
  295. },
  296. load: function() {
  297. let param = $('#ITP_FORM_OPER06010_SEARCH').serializeObject();
  298. param.gridSize = $.jgrid.defaults.rowNum;
  299. var option = {
  300. gridId: OPER06010_GRID_ID,
  301. colModel: gridColModel.list,
  302. param: param,
  303. url: DOMAIN + API_DETAIL_GRID_LIST,
  304. pager: OPER06010_GRID_PAGER,
  305. onCellSelect: function(rowId, cellIdx, cellValue) {
  306. var cm = $(this).jqGrid('getGridParam', 'colModel');
  307. var colNm = cm[cellIdx].name;
  308. if (colNm === 'brandId') {
  309. const brandIdVal = $(this).jqGrid('getCell', rowId, 'brandId');
  310. const key = {brandId: brandIdVal, viewCd: 'R'};
  311. var param = $.param(key);
  312. viewObj.init(param);
  313. }
  314. },
  315. loadComplete: function(data) {
  316. $("tr.jqgrow:odd").css("background", "#f5f5f5"); //2번째 마다 색변경ㄴ
  317. console.log(data);
  318. itp_fn_grid_load_complete(data, OPER06010_GRID_ID, true, 'number', 'OPER06010', listObj.itp_OPER06010_search, listObj.empty, true, data.gridRecords, true);
  319. var ids = $(OPER06010_GRID_ID).getDataIDs();
  320. $.each(ids, function(idx, rowId) {
  321. $(OPER06010_GRID_ID).jqGrid('setCell', rowId, 'brandId', '', ITP_GRID_COL_STYLE.link);
  322. });
  323. },
  324. onPaging: function(action) {
  325. itp_fn_grid_paging(OPER06010_GRID_ID, action, param);
  326. }
  327. };
  328. itp_fn_grid_make_remote(option);
  329. },
  330. clearData : function() {
  331. $(OPER06010_GRID_ID).jqGrid('clearGridData', true);
  332. $(OPER06010_GRID_LIST).find('.ui-jqgrid-bdiv').css('min-height', '100px');
  333. $(OPER06010_GRID_EMPTY).html(ITP_MSG_LOCALE.message.grid.noData);
  334. $(OPER06010_GRID_EMPTY).show();
  335. },
  336. unload : function() {
  337. $.jgrid.gridUnload(OPER06010_GRID_ID);
  338. }
  339. }
  340. };
  341. /*상세화면 Object*/
  342. let viewObj = {
  343. init: function (param) {
  344. this.load(param);
  345. },
  346. load: function(param) {
  347. fn_ajax_call(API_DETAIL_INFO, param, this.callback, 'GET');
  348. },
  349. callback: function (result) {
  350. console.log(result);
  351. pageObj.switchScreen('VIEW');
  352. $('#ITP_FORM_OPER06010_VIEW #ITP_FORM_OPER06010_VIEW_AFFL_SHOP_ID').val(result.afflShopId);
  353. $('#ITP_FORM_OPER06010_VIEW #ITP_FORM_OPER06010_VIEW_BRAND_ID').val(result.brandId);
  354. $('#ITP_FORM_OPER06010_VIEW .fnBrandUnitUnqNo').text(result.brandId);
  355. $('#ITP_FORM_OPER06010_VIEW .fnStCd').text(result.stNm);
  356. $('#ITP_FORM_OPER06010_VIEW .fnBrandNm').text(result.brandNm);
  357. $('#ITP_FORM_OPER06010_VIEW .fnBrandType').text(result.brandTypeNm);
  358. $('#ITP_FORM_OPER06010_VIEW .fnOwnerNm').text(result.ownerNm);
  359. $('#ITP_FORM_OPER06010_VIEW .fnTelNo').text(result.telNo);
  360. $('#ITP_FORM_OPER06010_VIEW .fnFaxNo').text(result.faxNo);
  361. $('#ITP_FORM_OPER06010_VIEW .fnEmalAddr').text(result.emalAddr);
  362. $('#ITP_FORM_OPER06010_VIEW .fnDpstBnkCd').text(result.bnkCdNm);
  363. $('#ITP_FORM_OPER06010_VIEW .fnRcvAcctNo').text(result.acctNo);
  364. $('#ITP_FORM_OPER06010_VIEW .fnBnkCd').text(result.bnkCdNm);
  365. $('#ITP_FORM_OPER06010_VIEW .fnAcctNo').text(result.acctNo);
  366. $('#ITP_FORM_OPER06010_VIEW .fnOwacNm').text(result.owacNm);
  367. $('#ITP_FORM_OPER06010_VIEW .fnZipNo').text(result.zipNo);
  368. $('#ITP_FORM_OPER06010_VIEW .fnLoadAddr').text(result.addr1);
  369. $('#ITP_FORM_OPER06010_VIEW .fnDtlAddr').text(result.addr2);
  370. $('#ITP_FORM_OPER06010_VIEW .fnRegId').text(result.sysRegId);
  371. $('#ITP_FORM_OPER06010_VIEW .fnRegDt').text(result.sysRegDttm);
  372. $('#ITP_FORM_OPER06010_VIEW .fnChgId').text(result.sysChgId);
  373. $('#ITP_FORM_OPER06010_VIEW .fnChgDt').text(result.sysChgDttm);
  374. // $('#ITP_FORM_OPER06010_VIEW .fnBrandLogo').text(result.lastLoginDt);
  375. $('#ITP_FORM_OPER06010_VIEW .fnPgId').text(result.pgId);
  376. $('#ITP_FORM_OPER06010_VIEW .fnPgAfflId').text(result.pgAfflId);
  377. $('#ITP_FORM_OPER06010_VIEW .fnPgKey').text(result.pgKey);
  378. pageObj.fileUpload();
  379. itp_fn_attach_file.view('ITP_OPER06010_VIEW_LOGO_FILE', result.fileLogNoList
  380. , 'form-control itp_input', 'border:none; top:12px; left:12px; height:100px; width:125px; position:absolute;');
  381. let locate = result.addr1 + ' ' + result.addr2;
  382. kakaoMap.init('ITP_FORM_OPER06010_VIEW', locate, result.latX, result.longY);
  383. }
  384. };
  385. /*수정화면 Object*/
  386. let modifyObj = {
  387. button: {
  388. modify: function () {
  389. itp_fn_form_clear_validate(null, '#ITP_FORM_OPER06010_DETAIL');
  390. const brandIdVal = $('#ITP_FORM_OPER06010_VIEW_BRAND_ID').val();
  391. const key = {brandId: brandIdVal, viewCd: 'R'};
  392. var param = $.param(key);
  393. modifyObj.load(param);
  394. }
  395. },
  396. load: function(param) {
  397. fn_ajax_call(API_DETAIL_INFO, param, this.callback, 'GET');
  398. },
  399. callback: function (result) {
  400. console.log(result);
  401. pageObj.switchScreen('MODIFY');
  402. $('#ITP_FORM_OPER06010_DETAIL #ITP_FORM_OPER06010_DETAIL_VIEW_CD').val('U');
  403. $('#ITP_FORM_OPER06010_DETAIL .fnAfflShopId').text(result.fnAfflShopId);
  404. $('#ITP_FORM_OPER06010_DETAIL .fnBrandId').text(result.brandId);
  405. $('#ITP_FORM_OPER06010_DETAIL #ITP_FORM_OPER06010_DETAIL_AFFL_SHOP_ID').val(result.afflShopId);
  406. $('#ITP_FORM_OPER06010_DETAIL #ITP_FORM_OPER06010_DETAIL_AFFL_SHOP_NM').val(result.afflShopNm);
  407. $('#ITP_FORM_OPER06010_DETAIL #ITP_FORM_OPER06010_DETAIL_BRAND_ID').val(result.brandId);
  408. $('#ITP_FORM_OPER06010_DETAIL #ITP_FORM_OPER06010_DETAIL_ST_CD').val(result.stCd);
  409. $('#ITP_FORM_OPER06010_DETAIL #ITP_FORM_OPER06010_DETAIL_BRAND_NM').val(result.brandNm);
  410. $('#ITP_FORM_OPER06010_DETAIL #ITP_FORM_OPER06010_DETAIL_BRAND_TYPE').val(result.brandType);
  411. $('#ITP_FORM_OPER06010_DETAIL #ITP_FORM_OPER06010_DETAIL_BSNS_REG_NO').val(result.bsnsRegNo);
  412. $('#ITP_FORM_OPER06010_DETAIL #ITP_FORM_OPER06010_DETAIL_CORP_REG_NO').val(result.corpRegNo);
  413. $('#ITP_FORM_OPER06010_DETAIL #ITP_FORM_OPER06010_DETAIL_OWNER_NM').val(result.ownerNm);
  414. $('#ITP_FORM_OPER06010_DETAIL #ITP_FORM_OPER06010_DETAIL_TEL_NO').val(result.telNo);
  415. $('#ITP_FORM_OPER06010_DETAIL #ITP_FORM_OPER06010_DETAIL_FAX_NO').val(result.faxNo);
  416. $('#ITP_FORM_OPER06010_DETAIL #ITP_FORM_OPER06010_DETAIL_EMAL_ADDR').val(result.emalAddr);
  417. $('#ITP_FORM_OPER06010_DETAIL #ITP_FORM_OPER06010_DETAIL_DPST_BNK_CD').val(result.bnkCd);
  418. $('#ITP_FORM_OPER06010_DETAIL #ITP_FORM_OPER06010_DETAIL_RCV_ACCT_NO').val(result.acctNo);
  419. $('#ITP_FORM_OPER06010_DETAIL #ITP_FORM_OPER06010_DETAIL_OWAC_NM').val(result.owacNm);
  420. $('#ITP_FORM_OPER06010_DETAIL #ITP_FORM_OPER06010_DETAIL_ZIPNO').val(result.zipNo);
  421. $('#ITP_FORM_OPER06010_DETAIL #ITP_FORM_OPER06010_DETAIL_ADRES').val(result.addr1);
  422. $('#ITP_FORM_OPER06010_DETAIL #ITP_FORM_OPER06010_DETAIL_ADRES_DTL').val(result.addr2);
  423. $('#ITP_FORM_OPER06010_DETAIL #ITP_FORM_OPER06010_DETAIL_PG_ID').val(result.pgId);
  424. $('#ITP_FORM_OPER06010_DETAIL #ITP_FORM_OPER06010_DETAIL_PG_AFFL_ID').val(result.pgAfflId);
  425. $('#ITP_FORM_OPER06010_DETAIL #ITP_FORM_OPER06010_DETAIL_PG_KEY').val(result.pgKey);
  426. $('#ITP_FORM_OPER06010_DETAIL .fnAddDt').text(result.sysRegDttm);
  427. $('#ITP_FORM_OPER06010_DETAIL .fnChgDt').text(result.sysChgDttm);
  428. $('#ITP_FORM_OPER06010_DETAIL #ITP_FORM_OPER06010_DETAIL_PG_ID').trigger('change');
  429. $('#ITP_FORM_OPER06010_DETAIL #ITP_FORM_OPER06010_DETAIL_FILE_NO').val(result.brandLogoFileNo);
  430. pageObj.fileUpload();
  431. itp_fn_attach_file.view('ITP_OPER06010_DETAIL_LOGO_FILE', result.fileLogNoList
  432. , 'form-control itp_input', 'border:none; top:12px; left:12px; height:100px; width:125px; position:absolute;');
  433. let locate = result.addr1 + ' ' + result.addr2;
  434. kakaoMap.init('ITP_FORM_OPER06010_DETAIL', locate, result.latX, result.longY);
  435. }
  436. };
  437. /*신규화면 Object*/
  438. let createObj = {
  439. init: function () {
  440. this.button.init();
  441. pageObj.fileUpload();
  442. kakaoMap.init('ITP_FORM_OPER06010_DETAIL', '');
  443. },
  444. button: {
  445. init: function() {
  446. // 가맹점 조회 버튼 클릭
  447. $('#ITP_FORM_OPER06010_DETAIL_SEARCH_AFFL_SHOP').one('click', function() {
  448. createObj.popup();
  449. });
  450. // 가맹점 텍스트 삭제 버튼 클릭
  451. $('#ITP_FORM_OPER06010_DETAIL_DELETE_AFFL_SHOP').one('click', function() {
  452. $('#ITP_FORM_OPER06010_DETAIL_AFFL_SHOP_ID').val('');
  453. $('#ITP_FORM_OPER06010_DETAIL_AFFL_SHOP_NM').val('');
  454. });
  455. },
  456. address: function() {
  457. kakaoMap.address('ITP_FORM_OPER06010_DETAIL');
  458. },
  459. save: function() {
  460. const formId = '#ITP_FORM_OPER06010_DETAIL';
  461. itp_fn_form_event.removeChar('#ITP_FORM_OPER06010_DETAIL');
  462. itp_fn_form_clear_validate(null, formId);
  463. if (itp_fn_form_event.isValid(formId)) {
  464. let param = $(formId).serializeObject();
  465. console.log(JSON.stringify(param));
  466. var searhFn = function() {
  467. ITP_FORM_OPER06010_DETAIL_IS_WRITING = false;
  468. listObj.grid.search();
  469. };
  470. fn_ajax_call(API_DETAIL_SAVE, JSON.stringify(param), searhFn, 'POST');
  471. }
  472. },
  473. cancel: function () {
  474. listObj.grid.search();
  475. }
  476. },
  477. popup: function() {
  478. var popFn = function(rowDataPop) {
  479. // console.log(rowDataPop);
  480. if(rowDataPop.AFFL_SHOP) {
  481. $('#ITP_FORM_OPER06010_DETAIL_AFFL_SHOP_ID').val(rowDataPop.AFFL_SHOP.afflShopId);
  482. $('#ITP_FORM_OPER06010_DETAIL_AFFL_SHOP_NM').val(rowDataPop.AFFL_SHOP.afflShopNm);
  483. }
  484. };
  485. fn_call_popup('biz', 'BIZPOP_AFFL_SHOP', '#ITP_ASIDE', popFn, null, 'S');
  486. }
  487. };
  488. /*가맹점 Object*/
  489. let afflShopObj = {
  490. init: function () {
  491. this.action();
  492. if(fn_make_user_info.get('authTpCd') === '30') {
  493. this.afflInfo.setAfflShop();
  494. }
  495. },
  496. action: function () {
  497. var _this = this;
  498. // 가맹점 조회 버튼 클릭
  499. $('#ITP_BTN_OPER06010_SEARCH_AFFL_SHOP').one('click', function() {
  500. _this.popup('L');
  501. });
  502. // 가맹점 텍스트 삭제 버튼 클릭
  503. $('#ITP_BTN_OPER06010_DELETE_AFFL_SHOP').one('click', function() {
  504. $('#ITP_FORM_OPER06010_SEARCH_AFFL_SHOP_ID').val('');
  505. $('#ITP_FORM_OPER06010_SEARCH_AFFL_SHOP_NM').val('');
  506. $('select#ITP_FORM_OPER06010_SEARCH_BRAND_ID option').remove();
  507. });
  508. },
  509. afflInfo: {
  510. setAfflShop: function() {
  511. var _this = this;
  512. this.afflShopId = fn_make_user_info.get('afflShopId');
  513. this.afflShopNm = fn_make_user_info.get('afflShopNm');
  514. $('#ITP_FORM_OPER06010_DETAIL_AFFL_SHOP_ID').val(_this.afflShopId);
  515. $('#ITP_FORM_OPER06010_SEARCH_AFFL_SHOP_ID').val(_this.afflShopId);
  516. $('#ITP_FORM_OPER06010_SEARCH_AFFL_SHOP_NM').val(_this.afflShopNm);
  517. $('#ITP_BTN_OPER06010_SEARCH_AFFL_SHOP').attr('disabled', true);
  518. $('#ITP_BTN_OPER06010_DELETE_AFFL_SHOP').attr('disabled', true);
  519. var callbackFn = (result) => {
  520. var brandList = [];
  521. $.each(result.gridRows, function(i, item) {
  522. brandList.push({'brandId': item.brandId, 'brandNm': item.brandNm});
  523. });
  524. fn_make_select_brand(brandList, 'ITP_FORM_OPER06010_SEARCH_BRAND_ID', true, '선택');
  525. };
  526. var param = {'afflShopId': _this.afflShopId};
  527. fn_ajax_call(BRAND_POP_GRID_LIST, JSON.stringify(param), callbackFn, 'POST');
  528. }
  529. },
  530. popup: function (view) {
  531. // 팝업
  532. var popFn = function(rowDataPop) {
  533. // console.log(rowDataPop);
  534. if(rowDataPop.AFFL_SHOP) {
  535. $('#ITP_FORM_OPER06010_SEARCH_AFFL_SHOP_ID').val(rowDataPop.AFFL_SHOP.afflShopId);
  536. $('#ITP_FORM_OPER06010_SEARCH_AFFL_SHOP_NM').val(rowDataPop.AFFL_SHOP.afflShopNm);
  537. }
  538. if(rowDataPop.AFFL_BRAND) {
  539. fn_make_select_brand(rowDataPop.AFFL_BRAND, 'ITP_FORM_OPER06010_SEARCH_BRAND_ID', true, '선택');
  540. }
  541. };
  542. fn_call_popup('biz', 'BIZPOP_AFFL_SHOP', '#ITP_ASIDE', popFn, null, 'S');
  543. }
  544. };