@things-factory/meta-ui 9.0.0-beta.8 → 9.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist-client/bootstrap.d.ts +5 -5
- package/dist-client/bootstrap.js +20 -20
- package/dist-client/bootstrap.js.map +1 -1
- package/dist-client/component/grist/renderer/grist-renderer-meta-object-selector.js +1 -2
- package/dist-client/component/grist/renderer/grist-renderer-meta-object-selector.js.map +1 -1
- package/dist-client/component/popup/code-input-editor-popup.js +20 -20
- package/dist-client/component/popup/code-input-editor-popup.js.map +1 -1
- package/dist-client/component/popup/file-upload-popup.js +4 -1
- package/dist-client/component/popup/file-upload-popup.js.map +1 -1
- package/dist-client/component/popup/meta-object-selector-popup.js +26 -26
- package/dist-client/component/popup/meta-object-selector-popup.js.map +1 -1
- package/dist-client/component/popup/record-based-code-editor-popup.js +20 -20
- package/dist-client/component/popup/record-based-code-editor-popup.js.map +1 -1
- package/dist-client/mixin/meta-base-mixin.js +1 -2
- package/dist-client/mixin/meta-base-mixin.js.map +1 -1
- package/dist-client/mixin/meta-basic-grist-mixin.js +2 -4
- package/dist-client/mixin/meta-basic-grist-mixin.js.map +1 -1
- package/dist-client/mixin/meta-form-mixin.js +2 -2
- package/dist-client/mixin/meta-form-mixin.js.map +1 -1
- package/dist-client/mixin/meta-grist-tab-mixin.js +1 -2
- package/dist-client/mixin/meta-grist-tab-mixin.js.map +1 -1
- package/dist-client/mixin/meta-main-tab-mixin.js +1 -2
- package/dist-client/mixin/meta-main-tab-mixin.js.map +1 -1
- package/dist-client/mixin/meta-master-detail-mixin.js +1 -2
- package/dist-client/mixin/meta-master-detail-mixin.js.map +1 -1
- package/dist-client/mixin/meta-service-mixin.js +2 -4
- package/dist-client/mixin/meta-service-mixin.js.map +1 -1
- package/dist-client/mixin/meta-tab-detail-mixin.js +1 -2
- package/dist-client/mixin/meta-tab-detail-mixin.js.map +1 -1
- package/dist-client/pages/activity/meta-activity-define-page.js +10 -9
- package/dist-client/pages/activity/meta-activity-define-page.js.map +1 -1
- package/dist-client/pages/activity/meta-activity-list-page.js +22 -10
- package/dist-client/pages/activity/meta-activity-list-page.js.map +1 -1
- package/dist-client/pages/activity/meta-activiy-mixin.js +1 -2
- package/dist-client/pages/activity/meta-activiy-mixin.js.map +1 -1
- package/dist-client/pages/entity/config-entity.js +12 -10
- package/dist-client/pages/entity/config-entity.js.map +1 -1
- package/dist-client/pages/history/history-json-list-popup.js +4 -1
- package/dist-client/pages/history/history-json-list-popup.js.map +1 -1
- package/dist-client/pages/menu/dynamic-menu.js +5 -6
- package/dist-client/pages/menu/dynamic-menu.js.map +1 -1
- package/dist-client/pages/terms/config-terminology.js +10 -2
- package/dist-client/pages/terms/config-terminology.js.map +1 -1
- package/dist-client/tsconfig.tsbuildinfo +1 -1
- package/dist-client/utils/meta-ui-util.js +25 -17
- package/dist-client/utils/meta-ui-util.js.map +1 -1
- package/dist-client/utils/service-util.js +22 -23
- package/dist-client/utils/service-util.js.map +1 -1
- package/dist-client/utils/terms-util.js +8 -2
- package/dist-client/utils/terms-util.js.map +1 -1
- package/dist-client/utils/ui-util.js +1 -2
- package/dist-client/utils/ui-util.js.map +1 -1
- package/dist-server/service/button-role/button-role-mutation.js +24 -6
- package/dist-server/service/button-role/button-role-mutation.js.map +1 -1
- package/dist-server/service/dynamic-menu/dynamic-menu-query.js +3 -4
- package/dist-server/service/dynamic-menu/dynamic-menu-query.js.map +1 -1
- package/dist-server/service/menu-button-auth/menu-button-auth-mutation.js +24 -6
- package/dist-server/service/menu-button-auth/menu-button-auth-mutation.js.map +1 -1
- package/dist-server/service/meta-activity/meta-activity-mutation.js +15 -5
- package/dist-server/service/meta-activity/meta-activity-mutation.js.map +1 -1
- package/dist-server/service/work-code/work-code-mutation.js +27 -8
- package/dist-server/service/work-code/work-code-mutation.js.map +1 -1
- package/dist-server/service/work-code-detail/work-code-detail-mutation.js +25 -7
- package/dist-server/service/work-code-detail/work-code-detail-mutation.js.map +1 -1
- package/dist-server/tsconfig.tsbuildinfo +1 -1
- package/package.json +24 -24
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"meta-base-mixin.js","sourceRoot":"","sources":["../../client/mixin/meta-base-mixin.js"],"names":[],"mappings":"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","sourcesContent":["import { MetaApi } from './../utils/meta-api'\nimport { ValueUtil } from './../utils/value-util'\nimport { TermsUtil } from './../utils/terms-util'\n\n/**\n * @license\n * Copyright © HatioLab Inc. All rights reserved.\n * @author Shortstop shortstop@hatiolab.com\n * @description 메타 기반의 화면 생성을 위한 기본 믹스인\n * 화면에 필요한 프로퍼티 정의, 메타 데이터 조회 및 파싱, 기본 데이터 조회, 변경 이벤트 핸들러 등록 등\n */\nexport const MetaBaseMixin = baseElement =>\n class extends baseElement {\n /**\n * @override properties\n ***************************\n * @returns {Object} 프로퍼티 오브젝트\n */\n static get properties() {\n return {\n /**\n * @description 메뉴 메타 정보\n ****************************\n * @type {Object}\n */\n menuInfo: Object,\n\n /**\n * @description 화면 라우팅 정보, 상세 뷰는 호출시에 route_name 변수를 설정하여 넘겨준다.\n ****************************\n * @type {String}\n */\n route_name: String,\n\n /**\n * 상세 폼 뷰 상위 데이터 ID, 상세 뷰는 호출시에 parent_id 변수를 설정하여 넘겨준다.\n ****************************\n * @type {String}\n */\n parent_id: String,\n\n /**\n * @description 페이지 내 컴포넌트 여부, 상세 뷰는 호출시에 is_detail 변수를 설정하여 넘겨준다.\n ****************************\n * @type {Boolean}\n */\n is_detail: {\n type: Boolean,\n converter(value) {\n return Boolean(value)\n }\n },\n\n /**\n * @description 팝업 여부, 팝업 뷰는 호출시에 is_popup 변수를 설정하여 넘겨준다.\n ****************************\n * @type {Boolean}\n */\n is_popup: {\n type: Boolean,\n converter(value) {\n return Boolean(value)\n }\n },\n\n /**\n * @description 작업, 결제 관련 화면에서 호출 된 경우\n ****************************\n * @type {Boolean}\n */\n is_activity: {\n type: Boolean,\n converter(value) {\n return Boolean(value)\n }\n },\n\n /**\n * @description 수정 불가 페이지\n ****************************\n * @type {Boolean}\n */\n is_readonly: {\n type: Boolean,\n converter(value) {\n return Boolean(value)\n }\n }\n }\n }\n\n /**\n * @description 엘리먼트 (페이지 내 컴포넌트 혹은 팝업인 경우) 여부\n ********************************************************\n * @returns {Boolean} 엘리먼트 여부\n */\n get isElement() {\n return this.is_detail === true || this.is_popup === true\n }\n\n /**\n * @description 페이지 내 포함된 하나의 컴포넌트 여부\n *******************************************\n * @returns {Boolean} 컴포넌트 여부\n */\n get isDetail() {\n return ValueUtil.isEmpty(this.is_detail) ? false : this.is_detail\n }\n\n /**\n * @description 시나리오 기반 데이터 변경 이벤트 핸들러\n **********************************************\n */\n async dataChangeEventHandler(e) {\n // 이벤트 디테일 추출\n let { after, before, column, record, row } = e.detail\n\n // 데이터 변경 컬럼 명\n let columnName = column.name\n // 해당 컬럼에 컬럼 변경 핸들러가 등록되어 있다면 해당 컬럼 변경 이벤트 핸들러 (시나리오)를 실행\n if (Object.keys(this.fieldChangeHandlers || {}).includes(columnName)) {\n let response = await MetaApi.callScenario(\n columnName,\n this.fieldChangeHandlers[columnName],\n {\n columnName,\n column,\n record,\n after,\n before,\n row,\n parentId: this.parent_id ? this.parent_id : ''\n },\n false\n )\n let result = response.data.runScenario.result.result\n if (!result) return\n\n // 이벤트 타겟 추출\n let eventTarget = this.grist ? this.grist.grist.body : this\n // 이벤트 타겟에 필드 변경 이벤트 전파\n Object.keys(result).forEach(key => {\n eventTarget.dispatchEvent(\n new CustomEvent('field-change', {\n bubbles: true,\n composed: true,\n detail: {\n record,\n row,\n after: result[key],\n before: record[key],\n column: { name: key }\n }\n })\n )\n })\n }\n\n // 데이터 변경 이벤트 전파\n this.dispatchEvent(\n new CustomEvent('data-changed', {\n bubbles: true,\n composed: true,\n detail: e.detail\n })\n )\n }\n\n /**\n * @override connectedCallback\n ********************************\n */\n async connectedCallback() {\n if (super.connectedCallback) {\n await super.connectedCallback()\n }\n\n // meta-form 계열인 경우 form-field-change 이벤트에 대한 핸들러를 등록\n if (this.tagName.toLowerCase().startsWith('meta-form-')) {\n this.addEventListener('form-field-change', async e => {\n await this.dataChangeEventHandler(e)\n })\n // 그렇지 않으면 field-change 이벤트에 대한 핸들러를 등록\n } else {\n this.addEventListener('field-change', async e => {\n await this.dataChangeEventHandler(e)\n })\n }\n }\n\n /**\n * @override pageUpdated : URL 파라미터에 대한 triggering\n ******************************************************\n * @returns\n */\n async pageUpdated(changes, lifecycle, before) {\n let navParams = this.lifecycle?.params ? this.lifecycle.params : {}\n if (this.isPage && this.active && before.active == false && ValueUtil.isNotEmpty(navParams)) {\n this.fetch()\n }\n }\n\n /**\n * @description 팝업으로 오픈되었는지 여부\n *************************************\n * @returns {Boolean} 팝업 오픈 여부\n */\n get isPopup() {\n return ValueUtil.isEmpty(this.is_popup) ? false : this.is_popup\n }\n\n /**\n * @description 페이지 여부 리턴 (마스터 디테일의 디테일 엘리먼트나 팝업 화면은 페이지가 아니다.)\n * - 페이지란 라우트 정보를 가지는 페이지를 뜻한다.\n ******************************************\n * @returns {Boolean} 페이지 여부\n */\n get isPage() {\n return !this.is_detail && !this.is_popup\n }\n\n /**\n * @description 메뉴 메타 정보 조회 && 화면 생성을 위한 Configuration 구성\n *****************************************************************\n * @returns {Object} 화면 생성을 위한 메타 정보 리턴\n */\n async getAndParseMenuMeta() {\n let menuMeta = await MetaApi.getMenuMeta(this)\n\n if (menuMeta) {\n // 기본 메뉴 정보\n this.menuInfo = menuMeta.menu\n // 기타 설정\n this.etcConfig = menuMeta.etc\n\n // 그리드 정보 파싱\n if (this.parseBasicGridConfigs) {\n this.parseBasicGridConfigs(menuMeta)\n }\n\n // GraphQL 이용을 위한 서비스 Configuration\n if (this.parseBasicServiceConfigs) {\n this.parseBasicServiceConfigs(menuMeta)\n }\n\n // 폼 정보 구성을 위한 폼 Configuration\n if (this.parseBasicFormConfigs) {\n this.parseBasicFormConfigs(menuMeta)\n }\n\n // MetaTabMixin\n if (this.parseBasicTabConfigs) {\n this.parseBasicTabConfigs(menuMeta)\n }\n\n // 버튼 정보 파싱\n if (this.parseBasicButtonConfigs) {\n this.parseBasicButtonConfigs(menuMeta)\n }\n }\n }\n\n /**\n * @description 화면에 구성된 콤포넌트에 따라 조회를 호출\n ***********************************************\n */\n async fetch() {\n if (ValueUtil.isNotEmpty(this.grist)) {\n this.grist.fetch()\n } else if (ValueUtil.isNotEmpty(this.filterForm)) {\n await this.fetchHandler()\n } else if (this.fetchHandler) {\n await this.fetchHandler()\n }\n }\n\n /**\n * @description 팝업 오픈 버튼 처리\n ********************************\n * @param {Object} action\n * @param {Object} record\n * @param {Function} closeCallback\n */\n async excuteOpenPopupButtonClick(action, record, closeCallback) {\n // 타이틀 변환\n let title = TermsUtil.tTitle(action.title)\n\n // 타이틀 상세 필드 정의 확인\n if (ValueUtil.isNotEmpty(action.title_detail)) {\n title = `${title}-${ValueUtil.getParams(record, ...action.title_detail.split('.'))}`\n }\n\n // 팝업 오픈\n MetaApi.openDynamicPopup(title, action, record, closeCallback)\n }\n\n /**\n * @description 시나리오 호출 버튼 처리\n ***********************************\n * @param {Object} action\n * @param {Object or Array} params\n * @param {Function} afterCallback\n */\n async executeCallScenarioButtonClick(action, params, afterCallback) {\n // 시나리오 호출\n let response = await MetaApi.callScenario(action.name, action.name, params)\n\n // 처리 중 에러가 발생했으면 시나리오 호출 후 처리가 없으면 return\n if (response !== false && !response.errors && ValueUtil.isNotEmpty(action.after)) {\n afterCallback()\n }\n }\n\n /**\n * @description 상위 페이지 에서 하위 엘리먼트로 전달하는 ID 저장 및 조회 실행\n ***********************************\n * @param {String} id\n */\n setParentId(id) {\n this.parent_id = id\n this.fetch()\n }\n }\n"]}
|
|
1
|
+
{"version":3,"file":"meta-base-mixin.js","sourceRoot":"","sources":["../../client/mixin/meta-base-mixin.js"],"names":[],"mappings":"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","sourcesContent":["import { MetaApi } from './../utils/meta-api'\nimport { ValueUtil } from './../utils/value-util'\nimport { TermsUtil } from './../utils/terms-util'\n\n/**\n * @license\n * Copyright © HatioLab Inc. All rights reserved.\n * @author Shortstop shortstop@hatiolab.com\n * @description 메타 기반의 화면 생성을 위한 기본 믹스인\n * 화면에 필요한 프로퍼티 정의, 메타 데이터 조회 및 파싱, 기본 데이터 조회, 변경 이벤트 핸들러 등록 등\n */\nexport const MetaBaseMixin = baseElement =>\n class extends baseElement {\n /**\n * @override properties\n ***************************\n * @returns {Object} 프로퍼티 오브젝트\n */\n static get properties() {\n return {\n /**\n * @description 메뉴 메타 정보\n ****************************\n * @type {Object}\n */\n menuInfo: Object,\n\n /**\n * @description 화면 라우팅 정보, 상세 뷰는 호출시에 route_name 변수를 설정하여 넘겨준다.\n ****************************\n * @type {String}\n */\n route_name: String,\n\n /**\n * 상세 폼 뷰 상위 데이터 ID, 상세 뷰는 호출시에 parent_id 변수를 설정하여 넘겨준다.\n ****************************\n * @type {String}\n */\n parent_id: String,\n\n /**\n * @description 페이지 내 컴포넌트 여부, 상세 뷰는 호출시에 is_detail 변수를 설정하여 넘겨준다.\n ****************************\n * @type {Boolean}\n */\n is_detail: {\n type: Boolean,\n converter(value) {\n return Boolean(value)\n }\n },\n\n /**\n * @description 팝업 여부, 팝업 뷰는 호출시에 is_popup 변수를 설정하여 넘겨준다.\n ****************************\n * @type {Boolean}\n */\n is_popup: {\n type: Boolean,\n converter(value) {\n return Boolean(value)\n }\n },\n\n /**\n * @description 작업, 결제 관련 화면에서 호출 된 경우\n ****************************\n * @type {Boolean}\n */\n is_activity: {\n type: Boolean,\n converter(value) {\n return Boolean(value)\n }\n },\n\n /**\n * @description 수정 불가 페이지\n ****************************\n * @type {Boolean}\n */\n is_readonly: {\n type: Boolean,\n converter(value) {\n return Boolean(value)\n }\n }\n }\n }\n\n /**\n * @description 엘리먼트 (페이지 내 컴포넌트 혹은 팝업인 경우) 여부\n ********************************************************\n * @returns {Boolean} 엘리먼트 여부\n */\n get isElement() {\n return this.is_detail === true || this.is_popup === true\n }\n\n /**\n * @description 페이지 내 포함된 하나의 컴포넌트 여부\n *******************************************\n * @returns {Boolean} 컴포넌트 여부\n */\n get isDetail() {\n return ValueUtil.isEmpty(this.is_detail) ? false : this.is_detail\n }\n\n /**\n * @description 시나리오 기반 데이터 변경 이벤트 핸들러\n **********************************************\n */\n async dataChangeEventHandler(e) {\n // 이벤트 디테일 추출\n let { after, before, column, record, row } = e.detail\n\n // 데이터 변경 컬럼 명\n let columnName = column.name\n // 해당 컬럼에 컬럼 변경 핸들러가 등록되어 있다면 해당 컬럼 변경 이벤트 핸들러 (시나리오)를 실행\n if (Object.keys(this.fieldChangeHandlers || {}).includes(columnName)) {\n let response = await MetaApi.callScenario(\n columnName,\n this.fieldChangeHandlers[columnName],\n {\n columnName,\n column,\n record,\n after,\n before,\n row,\n parentId: this.parent_id ? this.parent_id : ''\n },\n false\n )\n let result = response.data.runScenario.result.result\n if (!result) return\n\n // 이벤트 타겟 추출\n let eventTarget = this.grist ? this.grist.grist.body : this\n // 이벤트 타겟에 필드 변경 이벤트 전파\n Object.keys(result).forEach(key => {\n eventTarget.dispatchEvent(\n new CustomEvent('field-change', {\n bubbles: true,\n composed: true,\n detail: {\n record,\n row,\n after: result[key],\n before: record[key],\n column: { name: key }\n }\n })\n )\n })\n }\n\n // 데이터 변경 이벤트 전파\n this.dispatchEvent(\n new CustomEvent('data-changed', {\n bubbles: true,\n composed: true,\n detail: e.detail\n })\n )\n }\n\n /**\n * @override connectedCallback\n ********************************\n */\n async connectedCallback() {\n if (super.connectedCallback) {\n await super.connectedCallback()\n }\n\n // meta-form 계열인 경우 form-field-change 이벤트에 대한 핸들러를 등록\n if (this.tagName.toLowerCase().startsWith('meta-form-')) {\n this.addEventListener('form-field-change', async e => {\n await this.dataChangeEventHandler(e)\n })\n // 그렇지 않으면 field-change 이벤트에 대한 핸들러를 등록\n } else {\n this.addEventListener('field-change', async e => {\n await this.dataChangeEventHandler(e)\n })\n }\n }\n\n /**\n * @override pageUpdated : URL 파라미터에 대한 triggering\n ******************************************************\n * @returns\n */\n async pageUpdated(changes, lifecycle, before) {\n let navParams = this.lifecycle?.params ? this.lifecycle.params : {}\n if (this.isPage && this.active && before.active == false && ValueUtil.isNotEmpty(navParams)) {\n this.fetch()\n }\n }\n\n /**\n * @description 팝업으로 오픈되었는지 여부\n *************************************\n * @returns {Boolean} 팝업 오픈 여부\n */\n get isPopup() {\n return ValueUtil.isEmpty(this.is_popup) ? false : this.is_popup\n }\n\n /**\n * @description 페이지 여부 리턴 (마스터 디테일의 디테일 엘리먼트나 팝업 화면은 페이지가 아니다.)\n * - 페이지란 라우트 정보를 가지는 페이지를 뜻한다.\n ******************************************\n * @returns {Boolean} 페이지 여부\n */\n get isPage() {\n return !this.is_detail && !this.is_popup\n }\n\n /**\n * @description 메뉴 메타 정보 조회 && 화면 생성을 위한 Configuration 구성\n *****************************************************************\n * @returns {Object} 화면 생성을 위한 메타 정보 리턴\n */\n async getAndParseMenuMeta() {\n let menuMeta = await MetaApi.getMenuMeta(this)\n\n if (menuMeta) {\n // 기본 메뉴 정보\n this.menuInfo = menuMeta.menu\n // 기타 설정\n this.etcConfig = menuMeta.etc\n\n // 그리드 정보 파싱\n if (this.parseBasicGridConfigs) {\n this.parseBasicGridConfigs(menuMeta)\n }\n\n // GraphQL 이용을 위한 서비스 Configuration\n if (this.parseBasicServiceConfigs) {\n this.parseBasicServiceConfigs(menuMeta)\n }\n\n // 폼 정보 구성을 위한 폼 Configuration\n if (this.parseBasicFormConfigs) {\n this.parseBasicFormConfigs(menuMeta)\n }\n\n // MetaTabMixin\n if (this.parseBasicTabConfigs) {\n this.parseBasicTabConfigs(menuMeta)\n }\n\n // 버튼 정보 파싱\n if (this.parseBasicButtonConfigs) {\n this.parseBasicButtonConfigs(menuMeta)\n }\n }\n }\n\n /**\n * @description 화면에 구성된 콤포넌트에 따라 조회를 호출\n ***********************************************\n */\n async fetch() {\n if (ValueUtil.isNotEmpty(this.grist)) {\n this.grist.fetch()\n } else if (ValueUtil.isNotEmpty(this.filterForm)) {\n await this.fetchHandler()\n } else if (this.fetchHandler) {\n await this.fetchHandler()\n }\n }\n\n /**\n * @description 팝업 오픈 버튼 처리\n ********************************\n * @param {Object} action\n * @param {Object} record\n * @param {Function} closeCallback\n */\n async excuteOpenPopupButtonClick(action, record, closeCallback) {\n // 타이틀 변환\n let title = TermsUtil.tTitle(action.title)\n\n // 타이틀 상세 필드 정의 확인\n if (ValueUtil.isNotEmpty(action.title_detail)) {\n title = `${title}-${ValueUtil.getParams(record, ...action.title_detail.split('.'))}`\n }\n\n // 팝업 오픈\n MetaApi.openDynamicPopup(title, action, record, closeCallback)\n }\n\n /**\n * @description 시나리오 호출 버튼 처리\n ***********************************\n * @param {Object} action\n * @param {Object or Array} params\n * @param {Function} afterCallback\n */\n async executeCallScenarioButtonClick(action, params, afterCallback) {\n // 시나리오 호출\n let response = await MetaApi.callScenario(action.name, action.name, params)\n\n // 처리 중 에러가 발생했으면 시나리오 호출 후 처리가 없으면 return\n if (response !== false && !response.errors && ValueUtil.isNotEmpty(action.after)) {\n afterCallback()\n }\n }\n\n /**\n * @description 상위 페이지 에서 하위 엘리먼트로 전달하는 ID 저장 및 조회 실행\n ***********************************\n * @param {String} id\n */\n setParentId(id) {\n this.parent_id = id\n this.fetch()\n }\n }\n"]}
|
|
@@ -113,8 +113,7 @@ export const MetaBasicGristMixin = baseElement => class extends MetaButtonMixin(
|
|
|
113
113
|
* @returns {HTMLElement}
|
|
114
114
|
*/
|
|
115
115
|
get grist() {
|
|
116
|
-
|
|
117
|
-
return (_a = this.renderRoot) === null || _a === void 0 ? void 0 : _a.querySelector(this.gristId);
|
|
116
|
+
return this.renderRoot?.querySelector(this.gristId);
|
|
118
117
|
}
|
|
119
118
|
/**
|
|
120
119
|
* @description 필터 폼
|
|
@@ -122,8 +121,7 @@ export const MetaBasicGristMixin = baseElement => class extends MetaButtonMixin(
|
|
|
122
121
|
* @returns {HTMLElement}
|
|
123
122
|
*/
|
|
124
123
|
get filterForm() {
|
|
125
|
-
|
|
126
|
-
return (_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector(this.filterFormId);
|
|
124
|
+
return this.shadowRoot?.querySelector(this.filterFormId);
|
|
127
125
|
}
|
|
128
126
|
/**
|
|
129
127
|
* @description 컨텍스트
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"meta-basic-grist-mixin.js","sourceRoot":"","sources":["../../client/mixin/meta-basic-grist-mixin.js"],"names":[],"mappings":"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","sourcesContent":["import '@operato/data-grist'\n\nimport { html } from 'lit'\n\nimport { MetaApi } from '../utils/meta-api'\nimport { MetaUiUtil } from '../utils/meta-ui-util'\nimport { ValueUtil } from '../utils/value-util'\nimport { TermsUtil } from '../utils/terms-util'\n\nimport { MetaButtonMixin } from './meta-button-mixin'\n\n/**\n * @description 메뉴 메타 정보를 이용해 그리드를 렌더링\n ******************************************************\n * @param {Object} MetaButtonMixin\n * @returns\n */\nexport const MetaBasicGristMixin = baseElement =>\n class extends MetaButtonMixin(baseElement) {\n /**\n * @description 스타일 정의\n **************************\n * @returns {Array} 스타일\n */\n static get styles() {\n return MetaApi.getBasicGristStyles()\n }\n\n /**\n * @description 프로퍼티 정의\n ***************************************\n * @returns {Object} 프로퍼티\n */\n static get properties() {\n return {\n /**\n * @description 그리드 구성 정보\n *****************************\n * @type {Object}\n */\n gridConfig: Object,\n /**\n * @description 그리드 컬럼 구성 정보\n *********************************\n * @type {Array}\n */\n gridColumnConfig: Array,\n /**\n * @description 검색 폼 구성 정보\n *******************************\n * @type {Array}\n */\n searchConfig: Array,\n /**\n * @description 화면에서 사용되는 서치 폼 : grist, filter, not\n *********************************************************\n * @type {String}\n */\n searchFormElement: String,\n /**\n * @description 메뉴 메타 정보로 부터 추출한 후 그리스트를 위해 설정 정보 구성\n *****************************************************************\n * @type {Object}\n */\n gristConfigSet: Object,\n /**\n * @description 필터 폼 사용 여부\n *****************************\n * @type {Boolean}\n */\n useFilterForm: Boolean,\n /**\n * @description 모바일 기기에서 그리드 모드 : GRID, LIST, CARD\n *********************************************************\n * @type {String}\n */\n gridMobileMode: String,\n /**\n * @description 데스크탑에서 그리드 모드 : GRID, LIST, CARD\n ******************************************************\n * @type {String}\n */\n gridDeskMode: String,\n /**\n * @description 그리드 뷰 모드 : GRID, LIST, CARD\n **********************************************\n * @type {Array}\n */\n gridViewOptions: Array,\n /**\n * @description 현재 그리드 뷰 모드 : GRID, LIST, CARD\n ***************************************************\n * @type {String}\n */\n gridMode: String,\n /**\n * @description Infinity Page 사용 여부\n **************************************\n * @type {Boolean}\n */\n infinityPage: Boolean,\n /**\n * @description 그리스트 엘리먼트 ID\n ***************************\n * @type {String}\n */\n gristId: String,\n /**\n * @description 필터 폼 엘리먼트 ID\n ***************************\n * @type {String}\n */\n filterFormId: String\n }\n }\n\n /**\n * @description 그리스트\n ***********************\n * @returns {HTMLElement}\n */\n get grist() {\n return this.renderRoot?.querySelector(this.gristId)\n }\n\n /**\n * @description 필터 폼\n ***********************\n * @returns {HTMLElement}\n */\n get filterForm() {\n return this.shadowRoot?.querySelector(this.filterFormId)\n }\n\n /**\n * @description 컨텍스트\n ***********************\n * @returns {HTMLElement}\n */\n get context() {\n return MetaUiUtil.getContextObject(this)\n }\n\n /******************************************************\n * LifeCycle\n ******************************************************/\n\n async connectedCallback() {\n // 그리스트, 필터 폼 ID 설정\n this.gristId = 'ox-grist'\n this.filterFormId = 'ox-filters-form'\n\n // 메뉴 메타 정보 조회 및 기본 파싱\n await this.getAndParseMenuMeta()\n\n if (this.isElement) {\n await this.parseGristConfigs()\n }\n\n if (this.activityDataSet) {\n this.dataSet = this.activityDataSet\n }\n\n if (super.connectedCallback) {\n await super.connectedCallback()\n }\n }\n\n async firstUpdated() {\n if (super.firstUpdated) {\n await super.firstUpdated()\n }\n }\n\n async pageInitialized(lifecycle) {\n if (this.isPage) {\n await this.parseGristConfigs()\n }\n\n if (super.pageInitialized) {\n await super.pageInitialized()\n }\n }\n\n async pageUpdated(changes, lifecycle, before) {\n if (this.active) {\n /* this page is activated */\n if (this.gridConfig.grid_refresh_when_page_activated) {\n this.fetch()\n }\n } else {\n /* this page is deactivated */\n }\n }\n\n render() {\n return html` ${MetaApi.getBasicGristHtml(this)} ${this.isPage ? html`` : MetaUiUtil.getButtonContainer(this)} `\n }\n\n /**\n * @descrtiption 메뉴 메타에서 기본 그리드 정보 파싱 처리\n ************************************************\n * @param {Object} menuMeta 메뉴 메타 정보\n */\n parseBasicGridConfigs(menuMeta) {\n this.gridConfig = menuMeta.grid\n this.gridColumnConfig = menuMeta.grid_column\n this.searchConfig = menuMeta.search\n this.gridEmphasized = menuMeta.gridEmphasized\n }\n\n /**\n * @descrtiption 그리스트 구성 정보 파싱 처리\n ***************************************\n */\n async parseGristConfigs() {\n this.gristConfigSet = await MetaApi.parseGridConfigSet(this)\n }\n\n /********************************************************************\n * C R U D Functions\n ********************************************************************/\n\n async fetch() {\n await this.grist.fetch()\n }\n\n back() {\n history.back()\n }\n\n async save() {\n let patches = MetaApi.patchesForUpdateMultiple(this.grist)\n let result = ValueUtil.isNotEmpty(patches) ? await this.updateMultiple(patches) : false\n if (result) {\n this.fetch()\n }\n }\n\n async find() {\n let ids = MetaApi.getSelectedIdList(this.grist, true)\n return ValueUtil.isNotEmpty(ids) ? await this.findOne(ids[0]) : {}\n }\n\n async delete() {\n let ids = MetaApi.getSelectedIdList(this.grist, true)\n let result = ValueUtil.isNotEmpty(ids) ? await this.deleteByIds(ids) : false\n if (result) {\n this.fetch()\n }\n }\n\n async export() {\n let exportTitle = TermsUtil.tTitle(ValueUtil.getParams(this.menuInfo, 'title'))\n return await MetaApi.exportableData(this.isElement, exportTitle, this.grist)\n }\n\n async import() {\n // TODO\n }\n\n async clear() {\n if (this.grist) {\n this.grist.data = { page: 0, total: 0, limit: 0, records: [] }\n }\n }\n\n getData() {\n let records = this.grist.___data.records\n records = JSON.parse(JSON.stringify(records))\n\n records.forEach(record => {\n let keys = Object.keys(record)\n keys.forEach(x => {\n if (x.startsWith('__')) {\n delete record[x]\n }\n })\n })\n\n return records\n }\n }\n"]}
|
|
1
|
+
{"version":3,"file":"meta-basic-grist-mixin.js","sourceRoot":"","sources":["../../client/mixin/meta-basic-grist-mixin.js"],"names":[],"mappings":"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","sourcesContent":["import '@operato/data-grist'\n\nimport { html } from 'lit'\n\nimport { MetaApi } from '../utils/meta-api'\nimport { MetaUiUtil } from '../utils/meta-ui-util'\nimport { ValueUtil } from '../utils/value-util'\nimport { TermsUtil } from '../utils/terms-util'\n\nimport { MetaButtonMixin } from './meta-button-mixin'\n\n/**\n * @description 메뉴 메타 정보를 이용해 그리드를 렌더링\n ******************************************************\n * @param {Object} MetaButtonMixin\n * @returns\n */\nexport const MetaBasicGristMixin = baseElement =>\n class extends MetaButtonMixin(baseElement) {\n /**\n * @description 스타일 정의\n **************************\n * @returns {Array} 스타일\n */\n static get styles() {\n return MetaApi.getBasicGristStyles()\n }\n\n /**\n * @description 프로퍼티 정의\n ***************************************\n * @returns {Object} 프로퍼티\n */\n static get properties() {\n return {\n /**\n * @description 그리드 구성 정보\n *****************************\n * @type {Object}\n */\n gridConfig: Object,\n /**\n * @description 그리드 컬럼 구성 정보\n *********************************\n * @type {Array}\n */\n gridColumnConfig: Array,\n /**\n * @description 검색 폼 구성 정보\n *******************************\n * @type {Array}\n */\n searchConfig: Array,\n /**\n * @description 화면에서 사용되는 서치 폼 : grist, filter, not\n *********************************************************\n * @type {String}\n */\n searchFormElement: String,\n /**\n * @description 메뉴 메타 정보로 부터 추출한 후 그리스트를 위해 설정 정보 구성\n *****************************************************************\n * @type {Object}\n */\n gristConfigSet: Object,\n /**\n * @description 필터 폼 사용 여부\n *****************************\n * @type {Boolean}\n */\n useFilterForm: Boolean,\n /**\n * @description 모바일 기기에서 그리드 모드 : GRID, LIST, CARD\n *********************************************************\n * @type {String}\n */\n gridMobileMode: String,\n /**\n * @description 데스크탑에서 그리드 모드 : GRID, LIST, CARD\n ******************************************************\n * @type {String}\n */\n gridDeskMode: String,\n /**\n * @description 그리드 뷰 모드 : GRID, LIST, CARD\n **********************************************\n * @type {Array}\n */\n gridViewOptions: Array,\n /**\n * @description 현재 그리드 뷰 모드 : GRID, LIST, CARD\n ***************************************************\n * @type {String}\n */\n gridMode: String,\n /**\n * @description Infinity Page 사용 여부\n **************************************\n * @type {Boolean}\n */\n infinityPage: Boolean,\n /**\n * @description 그리스트 엘리먼트 ID\n ***************************\n * @type {String}\n */\n gristId: String,\n /**\n * @description 필터 폼 엘리먼트 ID\n ***************************\n * @type {String}\n */\n filterFormId: String\n }\n }\n\n /**\n * @description 그리스트\n ***********************\n * @returns {HTMLElement}\n */\n get grist() {\n return this.renderRoot?.querySelector(this.gristId)\n }\n\n /**\n * @description 필터 폼\n ***********************\n * @returns {HTMLElement}\n */\n get filterForm() {\n return this.shadowRoot?.querySelector(this.filterFormId)\n }\n\n /**\n * @description 컨텍스트\n ***********************\n * @returns {HTMLElement}\n */\n get context() {\n return MetaUiUtil.getContextObject(this)\n }\n\n /******************************************************\n * LifeCycle\n ******************************************************/\n\n async connectedCallback() {\n // 그리스트, 필터 폼 ID 설정\n this.gristId = 'ox-grist'\n this.filterFormId = 'ox-filters-form'\n\n // 메뉴 메타 정보 조회 및 기본 파싱\n await this.getAndParseMenuMeta()\n\n if (this.isElement) {\n await this.parseGristConfigs()\n }\n\n if (this.activityDataSet) {\n this.dataSet = this.activityDataSet\n }\n\n if (super.connectedCallback) {\n await super.connectedCallback()\n }\n }\n\n async firstUpdated() {\n if (super.firstUpdated) {\n await super.firstUpdated()\n }\n }\n\n async pageInitialized(lifecycle) {\n if (this.isPage) {\n await this.parseGristConfigs()\n }\n\n if (super.pageInitialized) {\n await super.pageInitialized()\n }\n }\n\n async pageUpdated(changes, lifecycle, before) {\n if (this.active) {\n /* this page is activated */\n if (this.gridConfig.grid_refresh_when_page_activated) {\n this.fetch()\n }\n } else {\n /* this page is deactivated */\n }\n }\n\n render() {\n return html` ${MetaApi.getBasicGristHtml(this)} ${this.isPage ? html`` : MetaUiUtil.getButtonContainer(this)} `\n }\n\n /**\n * @descrtiption 메뉴 메타에서 기본 그리드 정보 파싱 처리\n ************************************************\n * @param {Object} menuMeta 메뉴 메타 정보\n */\n parseBasicGridConfigs(menuMeta) {\n this.gridConfig = menuMeta.grid\n this.gridColumnConfig = menuMeta.grid_column\n this.searchConfig = menuMeta.search\n this.gridEmphasized = menuMeta.gridEmphasized\n }\n\n /**\n * @descrtiption 그리스트 구성 정보 파싱 처리\n ***************************************\n */\n async parseGristConfigs() {\n this.gristConfigSet = await MetaApi.parseGridConfigSet(this)\n }\n\n /********************************************************************\n * C R U D Functions\n ********************************************************************/\n\n async fetch() {\n await this.grist.fetch()\n }\n\n back() {\n history.back()\n }\n\n async save() {\n let patches = MetaApi.patchesForUpdateMultiple(this.grist)\n let result = ValueUtil.isNotEmpty(patches) ? await this.updateMultiple(patches) : false\n if (result) {\n this.fetch()\n }\n }\n\n async find() {\n let ids = MetaApi.getSelectedIdList(this.grist, true)\n return ValueUtil.isNotEmpty(ids) ? await this.findOne(ids[0]) : {}\n }\n\n async delete() {\n let ids = MetaApi.getSelectedIdList(this.grist, true)\n let result = ValueUtil.isNotEmpty(ids) ? await this.deleteByIds(ids) : false\n if (result) {\n this.fetch()\n }\n }\n\n async export() {\n let exportTitle = TermsUtil.tTitle(ValueUtil.getParams(this.menuInfo, 'title'))\n return await MetaApi.exportableData(this.isElement, exportTitle, this.grist)\n }\n\n async import() {\n // TODO\n }\n\n async clear() {\n if (this.grist) {\n this.grist.data = { page: 0, total: 0, limit: 0, records: [] }\n }\n }\n\n getData() {\n let records = this.grist.___data.records\n records = JSON.parse(JSON.stringify(records))\n\n records.forEach(record => {\n let keys = Object.keys(record)\n keys.forEach(x => {\n if (x.startsWith('__')) {\n delete record[x]\n }\n })\n })\n\n return records\n }\n }\n"]}
|
|
@@ -150,7 +150,7 @@ export const MetaFormMixin = baseElement => class extends MetaButtonMixin(baseEl
|
|
|
150
150
|
}
|
|
151
151
|
// dirty flag 설정
|
|
152
152
|
record.__dirty__ = ValueUtil.isNotEmpty(record.__dirtyfields__) ? 'M' : '';
|
|
153
|
-
this.record =
|
|
153
|
+
this.record = { ...record };
|
|
154
154
|
// form-field-change 변경 이벤트 전파
|
|
155
155
|
this.dispatchEvent(new CustomEvent('form-field-change', {
|
|
156
156
|
bubbles: true,
|
|
@@ -310,7 +310,7 @@ export const MetaFormMixin = baseElement => class extends MetaButtonMixin(baseEl
|
|
|
310
310
|
let orgData = {};
|
|
311
311
|
Object.assign(orgData, data);
|
|
312
312
|
data['__origin__'] = orgData;
|
|
313
|
-
this.record =
|
|
313
|
+
this.record = { ...data };
|
|
314
314
|
}
|
|
315
315
|
/**
|
|
316
316
|
* @description 폼 데이터 저장
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"meta-form-mixin.js","sourceRoot":"","sources":["../../client/mixin/meta-form-mixin.js"],"names":[],"mappings":"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","sourcesContent":["import { closePopup } from '@operato/popup'\n\nimport { MetaApi } from '../utils/meta-api'\nimport { MetaUiUtil } from '../utils/meta-ui-util'\nimport { ValueUtil } from '../utils/value-util'\nimport { UiUtil } from '../utils/ui-util'\nimport { TermsUtil } from '../utils/terms-util'\n\nimport { MetaButtonMixin } from './meta-button-mixin'\n\n/**\n * @license\n * Copyright © HatioLab Inc. All rights reserved.\n * @author Shortstop shortstop@hatiolab.com\n * @description 메뉴 메타 정보를 이용해 폼 화면 구성\n */\nexport const MetaFormMixin = baseElement =>\n class extends MetaButtonMixin(baseElement) {\n /**\n * @description 스타일 정의\n **************************\n * @returns {Array} 스타일\n */\n static get styles() {\n return MetaApi.getBasicFormStyles()\n }\n\n /**\n * @description 프로퍼티 정의\n ***************************\n * @returns {Object} 프로퍼티\n */\n static get properties() {\n return {\n /**\n * @description 폽 컬럼 구성 정보\n ******************************\n * @type {Array}\n */\n formColumnConfig: Array,\n /**\n * @description 메뉴 메타 정보로 부터 추출한 후 폼을 위해 설정 정보 구성\n ************************************************************\n * @type {Object}\n */\n formConfigSet: Object,\n /**\n * @description 폼 상세 렌터링 정보\n *******************************\n * @type {Object}\n */\n formRenderConfig: Array,\n /**\n * @description 데이터 레코드\n ***************************\n * @type {Object}\n */\n record: Object\n }\n }\n\n /**\n * @description 컨텍스트\n ***********************\n * @returns {HTMLElement}\n */\n get context() {\n return MetaUiUtil.getContextObject(this)\n }\n\n /******************************************************\n * LifeCycle\n ******************************************************/\n\n /**\n * @override connectedCallback\n *******************************\n */\n async connectedCallback() {\n // 메뉴 메타 정보 조회 및 기본 파싱\n await this.getAndParseMenuMeta()\n\n if (this.isElement) {\n await this.parseFormConfigs()\n }\n\n if (this.activityDataSet) {\n this.dataSet = this.activityDataSet\n }\n\n if (this.is_activity === true && !this.parent_id) {\n this.parent_id = 'activity'\n }\n\n if (super.connectedCallback) {\n await super.connectedCallback()\n }\n\n if (this.isElement) {\n await this.fetch()\n }\n\n // 인풋 키 이벤트 처리\n this.renderRoot.addEventListener('keydown', e => {\n switch (e.key) {\n case 'Esc':\n case 'Escape':\n // TODO 편집이 취소되어야 한다.\n case 'Enter':\n // 먼저 focus를 옮겨놓아야 focusout으로 인해서 popup이 닫히는 것을 방지할 수 있다.\n this.focus()\n\n if (this.currentTarget) {\n this.currentTarget.removeAttribute('editing')\n }\n\n this.currentTarget = null\n break\n default:\n }\n })\n\n // 인풋 클릭 처리 (readOnly <> editing)\n this.renderRoot.addEventListener('click', e => {\n e.stopPropagation()\n // target should be 'ox-grid-field'\n let target = e.target\n\n if (this.currentTarget) {\n this.focus()\n this.currentTarget.removeAttribute('editing')\n }\n\n if (target.tagName !== 'OX-GRID-FIELD' || !target.column.record.editable) {\n this.focus()\n this.currentTarget = null\n return\n }\n\n this.currentTarget = target\n target.setAttribute('editing', 'true')\n })\n\n // 폼 뷰의 인풋에서 발생되는 변경 이벤트 처리\n this.addEventListener('field-change', e => {\n let { after, before, column, record, row } = e.detail\n\n // before, after 값으로 달라진 값이 없으면 스킵\n if (ValueUtil.isEquals(after, before)) {\n return\n }\n\n // 유효성 체크 함수가 있는 경우 해당 함수 호출\n let validation = column.validation\n if (validation && typeof validation == 'function') {\n if (!validation.call(this, after, before, record, column)) {\n return\n }\n }\n\n // 변경 값 셋팅\n let colName = column.name\n record[colName] = after\n\n // 변경 필드 정보\n record.__dirtyfields__ = record.__dirtyfields__ || {}\n record.__origin__ = record.__origin__ || {}\n record.__dirtyfields__[colName] = {\n before: record.__origin__[colName],\n after: record[colName]\n }\n\n // 같은 값으로 변경 되었다면\n if (ValueUtil.isEquals(record.__dirtyfields__[colName].before, record.__dirtyfields__[colName].after)) {\n delete record.__dirtyfields__[colName]\n }\n\n // dirty flag 설정\n record.__dirty__ = ValueUtil.isNotEmpty(record.__dirtyfields__) ? 'M' : ''\n\n this.record = { ...record }\n\n // form-field-change 변경 이벤트 전파\n this.dispatchEvent(\n new CustomEvent('form-field-change', {\n bubbles: true,\n composed: true,\n detail: e.detail\n })\n )\n })\n }\n\n /**\n * @override firstUpdated\n ***************************\n */\n async firstUpdated() {\n if (super.firstUpdated) {\n await super.firstUpdated()\n }\n }\n\n /**\n * @override pageInitialized\n *****************************\n */\n async pageInitialized() {\n if (this.isPage) {\n await this.parseFormConfigs()\n }\n\n if (super.pageInitialized) {\n await super.pageInitialized()\n }\n\n if (this.isPage) {\n await this.fetch()\n }\n }\n\n /**\n * @description 화면 그리기\n *************************\n * @returns {HTMLElement}\n */\n render() {\n return MetaApi.getBasicFormHtml(this)\n }\n\n /**\n * @descrtiption 메뉴 메타 정보로 부터 기본 폼 정보 구성을 위한 Configuration\n *******************************************************************\n * @param {Object} menuMeta 메뉴 메타 정보\n */\n parseBasicFormConfigs(menuMeta) {\n this.formColumnConfig = menuMeta.grid_column\n this.formRenderConfig = menuMeta.form\n }\n\n /**\n * @descrtiption 폼 구성 정보 Configuration\n *****************************************\n */\n async parseFormConfigs() {\n this.formConfigSet = await MetaApi.parseFormConfigSet(this)\n }\n\n /********************************************************************\n * Data Filtering\n ********************************************************************/\n\n /**\n * @description 최초 조회된 원본 데이터\n ***********************************\n * @returns {Object} 원본 데이터 (변경 값 무시)\n */\n get orgData() {\n return this.removeGarbageData(this.record.__origin__)\n }\n\n /**\n * @description 변경된 데이터\n **************************\n * @returns {Object} 변경된 데이터만\n */\n get dirtyData() {\n if (ValueUtil.isEmpty((this.record || {}).__dirtyfields__)) {\n return {}\n }\n\n let retData = {}\n\n Object.entries(this.record.__dirtyfields__).map(([key, value]) => {\n if (key.startsWith('__') == false) {\n retData[key] = value.after\n }\n })\n\n return retData\n }\n\n /**\n * @description 현재 데이터\n *************************\n * @returns {Object} 화면에 표현되어 있는 현재 데이터 (수정된 값 반영)\n */\n get currentData() {\n return this.removeGarbageData(this.record)\n }\n\n /**\n * @description 레코드 데이터에서 쓰레기 데이터 정리\n ********************************************\n * @returns {Object} __dirty__,__dirtyfields__,__origin__ 등 (__ 로 시작되는 데이터 삭제)\n */\n removeGarbageData(data) {\n if (!data) return undefined\n\n let retData = {}\n\n Object.entries(data).map(([key, value]) => {\n if (key.startsWith('__') == false) {\n retData[key] = value\n }\n })\n\n return retData\n }\n\n /**\n * @description 트랜잭션을 위한 변경 데이터 + cuFlag 가져오기\n *****************************************************\n * @returns {Object}\n */\n get patchData() {\n let dirtyData = this.dirtyData\n let recordData = this.record\n // 코드 인풋 타입\n let codeInputColumns = (this.formColumnConfig || []).filter(x => x.type === 'code-input').map(x => x.name)\n\n if (ValueUtil.isEmpty(dirtyData)) {\n return undefined\n }\n\n // 기존 데이터 존재 여부 - 변경 플래그 판단\n if (ValueUtil.isNotEmpty(recordData.id)) {\n dirtyData.id = recordData.id\n dirtyData.cuFlag = 'M'\n } else {\n dirtyData.cuFlag = '+'\n }\n\n // object 타입은 id만 전송되도록 변경\n Object.keys(dirtyData).forEach(key => {\n if (typeof dirtyData[key] === 'object' && codeInputColumns.includes(key) == false) {\n dirtyData[key] = { id: dirtyData[key].id }\n }\n })\n\n return [dirtyData]\n }\n\n /********************************************************************\n * C R U D Functions\n ********************************************************************/\n /**\n * @description 폼 데이터 조회\n ***************************\n */\n async fetch() {\n // 부모 ID가 없다면 리턴\n if (ValueUtil.isEmpty(this.parent_id)) return\n\n // 단건 조회 함수\n let findOneFunc = ValueUtil.getParams(this.gqlInfo, 'query', 'find_one_func')\n if (!findOneFunc) return\n\n // 부모 ID로 조회\n let data = await this.findOne(this.parent_id)\n\n // 데이터 형식 맞추기\n data['__seq__'] = 1\n let orgData = {}\n Object.assign(orgData, data)\n data['__origin__'] = orgData\n this.record = { ...data }\n }\n\n /**\n * @description 폼 데이터 저장\n *****************************\n * @returns {Boolean} 저장 여부\n */\n async save() {\n let patches = this.patchData\n\n // 변경 여부 메시지 처리\n if (ValueUtil.isEmpty(patches)) {\n MetaApi.showAlertPopup('title.info', 'text.NOTHING_CHANGED', 'warning', 'confirm')\n return\n }\n\n // 필수 입력 컬럼\n let mandatoryColumns = {}\n ;(this.formColumnConfig || [])\n .filter(x => x.mandatory === true)\n .forEach(x => {\n mandatoryColumns[x.name] = x.header\n })\n\n // 필수 입력 값 체크\n let allFields = this.currentData\n for (let key in mandatoryColumns) {\n if (allFields[key] === undefined || allFields[key] == '') {\n UiUtil.showAlertPopup('text.check-mandatory', TermsUtil.tText('check-mandatory-field', { x: TermsUtil.tLabel(mandatoryColumns[key]) }), 'info', 'confirm')\n return\n }\n }\n\n // 저장 서비스 호출\n let isRes = await this.updateMultiple(patches)\n if (isRes) {\n // 폼 데이터 조회\n await this.fetch()\n\n // 저장이 잘 되었고 팝업이라면 팝업 닫기\n if (this.isPopup) {\n closePopup(this)\n }\n }\n\n // 저장 결과 리턴\n return isRes\n }\n\n /**\n * @description 데이터 클리어\n ***************************\n */\n async clear() {\n if (this.record) {\n this.record = {}\n }\n }\n\n /**\n * @description 데이터 리턴\n *************************\n * @returns {Object}\n */\n getData() {\n return this.currentData || {}\n }\n }\n"]}
|
|
1
|
+
{"version":3,"file":"meta-form-mixin.js","sourceRoot":"","sources":["../../client/mixin/meta-form-mixin.js"],"names":[],"mappings":"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","sourcesContent":["import { closePopup } from '@operato/popup'\n\nimport { MetaApi } from '../utils/meta-api'\nimport { MetaUiUtil } from '../utils/meta-ui-util'\nimport { ValueUtil } from '../utils/value-util'\nimport { UiUtil } from '../utils/ui-util'\nimport { TermsUtil } from '../utils/terms-util'\n\nimport { MetaButtonMixin } from './meta-button-mixin'\n\n/**\n * @license\n * Copyright © HatioLab Inc. All rights reserved.\n * @author Shortstop shortstop@hatiolab.com\n * @description 메뉴 메타 정보를 이용해 폼 화면 구성\n */\nexport const MetaFormMixin = baseElement =>\n class extends MetaButtonMixin(baseElement) {\n /**\n * @description 스타일 정의\n **************************\n * @returns {Array} 스타일\n */\n static get styles() {\n return MetaApi.getBasicFormStyles()\n }\n\n /**\n * @description 프로퍼티 정의\n ***************************\n * @returns {Object} 프로퍼티\n */\n static get properties() {\n return {\n /**\n * @description 폽 컬럼 구성 정보\n ******************************\n * @type {Array}\n */\n formColumnConfig: Array,\n /**\n * @description 메뉴 메타 정보로 부터 추출한 후 폼을 위해 설정 정보 구성\n ************************************************************\n * @type {Object}\n */\n formConfigSet: Object,\n /**\n * @description 폼 상세 렌터링 정보\n *******************************\n * @type {Object}\n */\n formRenderConfig: Array,\n /**\n * @description 데이터 레코드\n ***************************\n * @type {Object}\n */\n record: Object\n }\n }\n\n /**\n * @description 컨텍스트\n ***********************\n * @returns {HTMLElement}\n */\n get context() {\n return MetaUiUtil.getContextObject(this)\n }\n\n /******************************************************\n * LifeCycle\n ******************************************************/\n\n /**\n * @override connectedCallback\n *******************************\n */\n async connectedCallback() {\n // 메뉴 메타 정보 조회 및 기본 파싱\n await this.getAndParseMenuMeta()\n\n if (this.isElement) {\n await this.parseFormConfigs()\n }\n\n if (this.activityDataSet) {\n this.dataSet = this.activityDataSet\n }\n\n if (this.is_activity === true && !this.parent_id) {\n this.parent_id = 'activity'\n }\n\n if (super.connectedCallback) {\n await super.connectedCallback()\n }\n\n if (this.isElement) {\n await this.fetch()\n }\n\n // 인풋 키 이벤트 처리\n this.renderRoot.addEventListener('keydown', e => {\n switch (e.key) {\n case 'Esc':\n case 'Escape':\n // TODO 편집이 취소되어야 한다.\n case 'Enter':\n // 먼저 focus를 옮겨놓아야 focusout으로 인해서 popup이 닫히는 것을 방지할 수 있다.\n this.focus()\n\n if (this.currentTarget) {\n this.currentTarget.removeAttribute('editing')\n }\n\n this.currentTarget = null\n break\n default:\n }\n })\n\n // 인풋 클릭 처리 (readOnly <> editing)\n this.renderRoot.addEventListener('click', e => {\n e.stopPropagation()\n // target should be 'ox-grid-field'\n let target = e.target\n\n if (this.currentTarget) {\n this.focus()\n this.currentTarget.removeAttribute('editing')\n }\n\n if (target.tagName !== 'OX-GRID-FIELD' || !target.column.record.editable) {\n this.focus()\n this.currentTarget = null\n return\n }\n\n this.currentTarget = target\n target.setAttribute('editing', 'true')\n })\n\n // 폼 뷰의 인풋에서 발생되는 변경 이벤트 처리\n this.addEventListener('field-change', e => {\n let { after, before, column, record, row } = e.detail\n\n // before, after 값으로 달라진 값이 없으면 스킵\n if (ValueUtil.isEquals(after, before)) {\n return\n }\n\n // 유효성 체크 함수가 있는 경우 해당 함수 호출\n let validation = column.validation\n if (validation && typeof validation == 'function') {\n if (!validation.call(this, after, before, record, column)) {\n return\n }\n }\n\n // 변경 값 셋팅\n let colName = column.name\n record[colName] = after\n\n // 변경 필드 정보\n record.__dirtyfields__ = record.__dirtyfields__ || {}\n record.__origin__ = record.__origin__ || {}\n record.__dirtyfields__[colName] = {\n before: record.__origin__[colName],\n after: record[colName]\n }\n\n // 같은 값으로 변경 되었다면\n if (ValueUtil.isEquals(record.__dirtyfields__[colName].before, record.__dirtyfields__[colName].after)) {\n delete record.__dirtyfields__[colName]\n }\n\n // dirty flag 설정\n record.__dirty__ = ValueUtil.isNotEmpty(record.__dirtyfields__) ? 'M' : ''\n\n this.record = { ...record }\n\n // form-field-change 변경 이벤트 전파\n this.dispatchEvent(\n new CustomEvent('form-field-change', {\n bubbles: true,\n composed: true,\n detail: e.detail\n })\n )\n })\n }\n\n /**\n * @override firstUpdated\n ***************************\n */\n async firstUpdated() {\n if (super.firstUpdated) {\n await super.firstUpdated()\n }\n }\n\n /**\n * @override pageInitialized\n *****************************\n */\n async pageInitialized() {\n if (this.isPage) {\n await this.parseFormConfigs()\n }\n\n if (super.pageInitialized) {\n await super.pageInitialized()\n }\n\n if (this.isPage) {\n await this.fetch()\n }\n }\n\n /**\n * @description 화면 그리기\n *************************\n * @returns {HTMLElement}\n */\n render() {\n return MetaApi.getBasicFormHtml(this)\n }\n\n /**\n * @descrtiption 메뉴 메타 정보로 부터 기본 폼 정보 구성을 위한 Configuration\n *******************************************************************\n * @param {Object} menuMeta 메뉴 메타 정보\n */\n parseBasicFormConfigs(menuMeta) {\n this.formColumnConfig = menuMeta.grid_column\n this.formRenderConfig = menuMeta.form\n }\n\n /**\n * @descrtiption 폼 구성 정보 Configuration\n *****************************************\n */\n async parseFormConfigs() {\n this.formConfigSet = await MetaApi.parseFormConfigSet(this)\n }\n\n /********************************************************************\n * Data Filtering\n ********************************************************************/\n\n /**\n * @description 최초 조회된 원본 데이터\n ***********************************\n * @returns {Object} 원본 데이터 (변경 값 무시)\n */\n get orgData() {\n return this.removeGarbageData(this.record.__origin__)\n }\n\n /**\n * @description 변경된 데이터\n **************************\n * @returns {Object} 변경된 데이터만\n */\n get dirtyData() {\n if (ValueUtil.isEmpty((this.record || {}).__dirtyfields__)) {\n return {}\n }\n\n let retData = {}\n\n Object.entries(this.record.__dirtyfields__).map(([key, value]) => {\n if (key.startsWith('__') == false) {\n retData[key] = value.after\n }\n })\n\n return retData\n }\n\n /**\n * @description 현재 데이터\n *************************\n * @returns {Object} 화면에 표현되어 있는 현재 데이터 (수정된 값 반영)\n */\n get currentData() {\n return this.removeGarbageData(this.record)\n }\n\n /**\n * @description 레코드 데이터에서 쓰레기 데이터 정리\n ********************************************\n * @returns {Object} __dirty__,__dirtyfields__,__origin__ 등 (__ 로 시작되는 데이터 삭제)\n */\n removeGarbageData(data) {\n if (!data) return undefined\n\n let retData = {}\n\n Object.entries(data).map(([key, value]) => {\n if (key.startsWith('__') == false) {\n retData[key] = value\n }\n })\n\n return retData\n }\n\n /**\n * @description 트랜잭션을 위한 변경 데이터 + cuFlag 가져오기\n *****************************************************\n * @returns {Object}\n */\n get patchData() {\n let dirtyData = this.dirtyData\n let recordData = this.record\n // 코드 인풋 타입\n let codeInputColumns = (this.formColumnConfig || []).filter(x => x.type === 'code-input').map(x => x.name)\n\n if (ValueUtil.isEmpty(dirtyData)) {\n return undefined\n }\n\n // 기존 데이터 존재 여부 - 변경 플래그 판단\n if (ValueUtil.isNotEmpty(recordData.id)) {\n dirtyData.id = recordData.id\n dirtyData.cuFlag = 'M'\n } else {\n dirtyData.cuFlag = '+'\n }\n\n // object 타입은 id만 전송되도록 변경\n Object.keys(dirtyData).forEach(key => {\n if (typeof dirtyData[key] === 'object' && codeInputColumns.includes(key) == false) {\n dirtyData[key] = { id: dirtyData[key].id }\n }\n })\n\n return [dirtyData]\n }\n\n /********************************************************************\n * C R U D Functions\n ********************************************************************/\n /**\n * @description 폼 데이터 조회\n ***************************\n */\n async fetch() {\n // 부모 ID가 없다면 리턴\n if (ValueUtil.isEmpty(this.parent_id)) return\n\n // 단건 조회 함수\n let findOneFunc = ValueUtil.getParams(this.gqlInfo, 'query', 'find_one_func')\n if (!findOneFunc) return\n\n // 부모 ID로 조회\n let data = await this.findOne(this.parent_id)\n\n // 데이터 형식 맞추기\n data['__seq__'] = 1\n let orgData = {}\n Object.assign(orgData, data)\n data['__origin__'] = orgData\n this.record = { ...data }\n }\n\n /**\n * @description 폼 데이터 저장\n *****************************\n * @returns {Boolean} 저장 여부\n */\n async save() {\n let patches = this.patchData\n\n // 변경 여부 메시지 처리\n if (ValueUtil.isEmpty(patches)) {\n MetaApi.showAlertPopup('title.info', 'text.NOTHING_CHANGED', 'warning', 'confirm')\n return\n }\n\n // 필수 입력 컬럼\n let mandatoryColumns = {}\n ;(this.formColumnConfig || [])\n .filter(x => x.mandatory === true)\n .forEach(x => {\n mandatoryColumns[x.name] = x.header\n })\n\n // 필수 입력 값 체크\n let allFields = this.currentData\n for (let key in mandatoryColumns) {\n if (allFields[key] === undefined || allFields[key] == '') {\n UiUtil.showAlertPopup('text.check-mandatory', TermsUtil.tText('check-mandatory-field', { x: TermsUtil.tLabel(mandatoryColumns[key]) }), 'info', 'confirm')\n return\n }\n }\n\n // 저장 서비스 호출\n let isRes = await this.updateMultiple(patches)\n if (isRes) {\n // 폼 데이터 조회\n await this.fetch()\n\n // 저장이 잘 되었고 팝업이라면 팝업 닫기\n if (this.isPopup) {\n closePopup(this)\n }\n }\n\n // 저장 결과 리턴\n return isRes\n }\n\n /**\n * @description 데이터 클리어\n ***************************\n */\n async clear() {\n if (this.record) {\n this.record = {}\n }\n }\n\n /**\n * @description 데이터 리턴\n *************************\n * @returns {Object}\n */\n getData() {\n return this.currentData || {}\n }\n }\n"]}
|
|
@@ -119,8 +119,7 @@ export const MetaGristTabMixin = baseElement => class extends MetaButtonMixin(ba
|
|
|
119
119
|
* @returns {HTMLElement}
|
|
120
120
|
*/
|
|
121
121
|
get filterForm() {
|
|
122
|
-
|
|
123
|
-
return (_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector(this.filterFormId);
|
|
122
|
+
return this.shadowRoot?.querySelector(this.filterFormId);
|
|
124
123
|
}
|
|
125
124
|
/**
|
|
126
125
|
* @description 디테일 Element
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"meta-grist-tab-mixin.js","sourceRoot":"","sources":["../../client/mixin/meta-grist-tab-mixin.js"],"names":[],"mappings":"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","sourcesContent":["import { MetaApi } from '../utils/meta-api'\nimport { MetaUiUtil } from '../utils/meta-ui-util'\nimport { ValueUtil } from '../utils/value-util'\nimport { TermsUtil } from '../utils/terms-util'\n\nimport { MetaButtonMixin } from './meta-button-mixin'\n\n/**\n * @license\n * Copyright © HatioLab Inc. All rights reserved.\n * @author Shortstop shortstop@hatiolab.com\n * @description 메뉴 메타 정보를 기반으로 그리드 탭 구성\n */\nexport const MetaGristTabMixin = baseElement =>\n class extends MetaButtonMixin(baseElement) {\n /**\n * @description 스타일 정의\n **************************\n * @returns {Array} 스타일\n */\n static get styles() {\n return MetaApi.getBasicGristTabStyles()\n }\n\n /**\n * @description 프로퍼티 정의\n ****************************\n * @returns {Object} 프로퍼티\n */\n static get properties() {\n return {\n /**\n * @description 그리드 구성 정보\n *****************************\n * @type {Object}\n */\n gridConfig: Object,\n /**\n * @description 그리드 컬럼 구성 정보\n *********************************\n * @type {Array}\n */\n gridColumnConfig: Array,\n /**\n * @description 검색 폼 구성 정보\n *******************************\n * @type {Array}\n */\n searchConfig: Array,\n /**\n * @description 화면에서 사용되는 서치 폼 : grist, filter, not\n *********************************************************\n * @type {String}\n */\n searchFormElement: String,\n /**\n * @description 메뉴 메타 정보로 부터 추출한 후 그리스트를 위해 설정 정보 구성\n *****************************************************************\n * @type {Object}\n */\n gristConfigSet: Object,\n /**\n * @description 필터 폼 사용 여부\n *****************************\n * @type {Boolean}\n */\n useFilterForm: Boolean,\n /**\n * @description 모바일 기기에서 그리드 모드 : GRID, LIST, CARD\n *********************************************************\n * @type {String}\n */\n gridMobileMode: String,\n /**\n * @description 데스크탑에서 그리드 모드 : GRID, LIST, CARD\n ******************************************************\n * @type {String}\n */\n gridDeskMode: String,\n /**\n * @description 그리드 뷰 모드 : GRID, LIST, CARD\n **********************************************\n * @type {Array}\n */\n gridViewOptions: Array,\n /**\n * @description 현재 그리드 뷰 모드 : GRID, LIST, CARD\n ***************************************************\n * @type {String}\n */\n gridMode: String,\n /**\n * @description Infinity Page 사용 여부\n **************************************\n * @type {Boolean}\n */\n infinityPage: Boolean,\n /**\n * @description 그리스트 엘리먼트 ID\n ***************************\n * @type {String}\n */\n gristId: String,\n /**\n * @description 필터 폼 엘리먼트 ID\n ***************************\n * @type {String}\n */\n filterFormId: String\n }\n }\n\n /**\n * @description 그리스트\n ***********************\n * @returns {HTMLElement}\n */\n get grist() {\n return this.renderRoot.querySelector(this.gristId)\n }\n\n /**\n * @description 필터 폼\n ***********************\n * @returns {HTMLElement}\n */\n get filterForm() {\n return this.shadowRoot?.querySelector(this.filterFormId)\n }\n\n /**\n * @description 디테일 Element\n *****************************\n * @returns {HTMLElement}\n */\n get detailElement() {\n return this.shadowRoot.querySelector('#detail')\n }\n\n /**\n * @description 컨텍스트\n ***********************\n * @returns {HTMLElement}\n */\n get context() {\n let ctx = MetaUiUtil.getContextObject(this)\n\n if (ctx.actions) delete ctx.actions\n if (ctx.exportable) delete ctx.exportable\n if (ctx.importable) delete ctx.importable\n return ctx\n }\n\n /******************************************************\n * LifeCycle\n ******************************************************/\n\n /**\n * @override connectedCallback\n ***************************\n */\n async connectedCallback() {\n // 그리스트, 필터 폼 ID 설정\n this.gristId = 'ox-grist'\n this.filterFormId = 'ox-filters-form-base'\n\n // 메뉴 메타 정보 조회 및 기본 파싱\n await this.getAndParseMenuMeta()\n\n if (this.isElement) {\n await this.parseGristConfigs()\n }\n\n if (this.activityDataSet) {\n this.dataSet = (this.activityDataSet || {}).main\n }\n\n if (super.connectedCallback) {\n await super.connectedCallback()\n }\n }\n\n /**\n * @override pageUpdated\n ***************************\n * @param {Object} changes\n * @param {Object} lifecycle\n * @param {Object} before\n */\n async pageUpdated(changes, lifecycle, before) {\n super.pageUpdated(changes, lifecycle, before)\n\n if (this.isPage && before.active == false) {\n // TODO 탭이 다른 탭으로 이동하는 경우에 현재 탭의 데이터에 dirty인 것이 있는지 체크해서 있다면 메시지 출력!!!\n console.log('page updated!!!!')\n }\n }\n\n async firstUpdated() {\n if (super.firstUpdated) {\n await super.firstUpdated()\n }\n }\n\n async pageInitialized() {\n if (this.isPage) {\n await this.parseGristConfigs()\n }\n\n if (super.pageInitialized) {\n await super.pageInitialized()\n }\n }\n\n render() {\n return MetaApi.getGristTabHtml(this)\n }\n\n /**\n * @descrtiption 메뉴 메타에서 기본 그리드 정보 파싱 처리\n ************************************************\n * @param {Object} menuMeta 메뉴 메타 정보\n */\n parseBasicGridConfigs(menuMeta) {\n this.gridConfig = menuMeta.grid\n this.gridColumnConfig = menuMeta.grid_column\n this.searchConfig = menuMeta.search\n this.gridEmphasized = menuMeta.gridEmphasized\n }\n\n /**\n * @descrtiption 그리스트 구성 정보 파싱 처리\n ***************************************\n */\n async parseGristConfigs() {\n this.gristConfigSet = await MetaApi.parseGridConfigSet(this)\n this.useMasterFilterForm = this.useFilterForm === true ? true : false\n this.useFilterForm = false\n this.searchFieldValues = []\n this.searchFields = this.gristConfigSet.columns\n .filter(x => x.filter)\n .map(x => {\n let searchField = {\n name: x.name,\n type: x.filter.operator === 'search' ? 'search' : x.type,\n label: x.header,\n operator: x.filter.operator ? x.filter.operator : 'eq'\n }\n\n if (x.filter.options) {\n searchField.options = x.filter.options\n }\n\n if (x.record.options) {\n searchField.options = x.record.options\n }\n\n if (x.filter.value) {\n this.searchFieldValues.push({\n name: searchField.name,\n operator: searchField.operator,\n value: x.filter.value\n })\n }\n\n delete x.filter\n return searchField\n })\n }\n\n /********************************************************************\n * C R U D Functions\n ********************************************************************/\n\n async fetch() {\n await this.grist.fetch()\n }\n\n async beforeFetch({ page = 0, limit = 0, sortings = [], filters = [] }) {\n let detailContainer = this.renderRoot.querySelector('meta-tab-element')\n await detailContainer.clear()\n\n return true\n }\n\n async save() {\n let patches = MetaApi.patchesForUpdateMultiple(this.grist)\n let result = ValueUtil.isNotEmpty(patches) ? await this.updateMultiple(patches) : false\n if (result) {\n this.fetch()\n }\n }\n\n async find() {\n let ids = MetaApi.getSelectedIdList(this.grist, true)\n return ValueUtil.isNotEmpty(ids) ? await this.findOne(ids[0]) : {}\n }\n\n async delete() {\n let ids = MetaApi.getSelectedIdList(this.grist, true)\n let result = ValueUtil.isNotEmpty(ids) ? await this.deleteByIds(ids) : false\n if (result) {\n this.fetch()\n }\n }\n\n async export() {\n let exportTitle = TermsUtil.tTitle(ValueUtil.getParams(this.menuInfo, 'title'))\n return await MetaApi.exportableData(this.isElement, exportTitle, this.grist)\n }\n\n async import() {\n // TODO\n }\n\n getData() {\n let records = this.grist.___data.records\n records = JSON.parse(JSON.stringify(records))\n\n records.forEach(record => {\n let keys = Object.keys(record)\n keys.forEach(x => {\n if (x.startsWith('__')) {\n delete record[x]\n }\n })\n })\n\n let tabElement = this.renderRoot.querySelector('meta-tab-element')\n return {\n main: records,\n detail: tabElement.getData()\n }\n }\n }\n"]}
|
|
1
|
+
{"version":3,"file":"meta-grist-tab-mixin.js","sourceRoot":"","sources":["../../client/mixin/meta-grist-tab-mixin.js"],"names":[],"mappings":"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","sourcesContent":["import { MetaApi } from '../utils/meta-api'\nimport { MetaUiUtil } from '../utils/meta-ui-util'\nimport { ValueUtil } from '../utils/value-util'\nimport { TermsUtil } from '../utils/terms-util'\n\nimport { MetaButtonMixin } from './meta-button-mixin'\n\n/**\n * @license\n * Copyright © HatioLab Inc. All rights reserved.\n * @author Shortstop shortstop@hatiolab.com\n * @description 메뉴 메타 정보를 기반으로 그리드 탭 구성\n */\nexport const MetaGristTabMixin = baseElement =>\n class extends MetaButtonMixin(baseElement) {\n /**\n * @description 스타일 정의\n **************************\n * @returns {Array} 스타일\n */\n static get styles() {\n return MetaApi.getBasicGristTabStyles()\n }\n\n /**\n * @description 프로퍼티 정의\n ****************************\n * @returns {Object} 프로퍼티\n */\n static get properties() {\n return {\n /**\n * @description 그리드 구성 정보\n *****************************\n * @type {Object}\n */\n gridConfig: Object,\n /**\n * @description 그리드 컬럼 구성 정보\n *********************************\n * @type {Array}\n */\n gridColumnConfig: Array,\n /**\n * @description 검색 폼 구성 정보\n *******************************\n * @type {Array}\n */\n searchConfig: Array,\n /**\n * @description 화면에서 사용되는 서치 폼 : grist, filter, not\n *********************************************************\n * @type {String}\n */\n searchFormElement: String,\n /**\n * @description 메뉴 메타 정보로 부터 추출한 후 그리스트를 위해 설정 정보 구성\n *****************************************************************\n * @type {Object}\n */\n gristConfigSet: Object,\n /**\n * @description 필터 폼 사용 여부\n *****************************\n * @type {Boolean}\n */\n useFilterForm: Boolean,\n /**\n * @description 모바일 기기에서 그리드 모드 : GRID, LIST, CARD\n *********************************************************\n * @type {String}\n */\n gridMobileMode: String,\n /**\n * @description 데스크탑에서 그리드 모드 : GRID, LIST, CARD\n ******************************************************\n * @type {String}\n */\n gridDeskMode: String,\n /**\n * @description 그리드 뷰 모드 : GRID, LIST, CARD\n **********************************************\n * @type {Array}\n */\n gridViewOptions: Array,\n /**\n * @description 현재 그리드 뷰 모드 : GRID, LIST, CARD\n ***************************************************\n * @type {String}\n */\n gridMode: String,\n /**\n * @description Infinity Page 사용 여부\n **************************************\n * @type {Boolean}\n */\n infinityPage: Boolean,\n /**\n * @description 그리스트 엘리먼트 ID\n ***************************\n * @type {String}\n */\n gristId: String,\n /**\n * @description 필터 폼 엘리먼트 ID\n ***************************\n * @type {String}\n */\n filterFormId: String\n }\n }\n\n /**\n * @description 그리스트\n ***********************\n * @returns {HTMLElement}\n */\n get grist() {\n return this.renderRoot.querySelector(this.gristId)\n }\n\n /**\n * @description 필터 폼\n ***********************\n * @returns {HTMLElement}\n */\n get filterForm() {\n return this.shadowRoot?.querySelector(this.filterFormId)\n }\n\n /**\n * @description 디테일 Element\n *****************************\n * @returns {HTMLElement}\n */\n get detailElement() {\n return this.shadowRoot.querySelector('#detail')\n }\n\n /**\n * @description 컨텍스트\n ***********************\n * @returns {HTMLElement}\n */\n get context() {\n let ctx = MetaUiUtil.getContextObject(this)\n\n if (ctx.actions) delete ctx.actions\n if (ctx.exportable) delete ctx.exportable\n if (ctx.importable) delete ctx.importable\n return ctx\n }\n\n /******************************************************\n * LifeCycle\n ******************************************************/\n\n /**\n * @override connectedCallback\n ***************************\n */\n async connectedCallback() {\n // 그리스트, 필터 폼 ID 설정\n this.gristId = 'ox-grist'\n this.filterFormId = 'ox-filters-form-base'\n\n // 메뉴 메타 정보 조회 및 기본 파싱\n await this.getAndParseMenuMeta()\n\n if (this.isElement) {\n await this.parseGristConfigs()\n }\n\n if (this.activityDataSet) {\n this.dataSet = (this.activityDataSet || {}).main\n }\n\n if (super.connectedCallback) {\n await super.connectedCallback()\n }\n }\n\n /**\n * @override pageUpdated\n ***************************\n * @param {Object} changes\n * @param {Object} lifecycle\n * @param {Object} before\n */\n async pageUpdated(changes, lifecycle, before) {\n super.pageUpdated(changes, lifecycle, before)\n\n if (this.isPage && before.active == false) {\n // TODO 탭이 다른 탭으로 이동하는 경우에 현재 탭의 데이터에 dirty인 것이 있는지 체크해서 있다면 메시지 출력!!!\n console.log('page updated!!!!')\n }\n }\n\n async firstUpdated() {\n if (super.firstUpdated) {\n await super.firstUpdated()\n }\n }\n\n async pageInitialized() {\n if (this.isPage) {\n await this.parseGristConfigs()\n }\n\n if (super.pageInitialized) {\n await super.pageInitialized()\n }\n }\n\n render() {\n return MetaApi.getGristTabHtml(this)\n }\n\n /**\n * @descrtiption 메뉴 메타에서 기본 그리드 정보 파싱 처리\n ************************************************\n * @param {Object} menuMeta 메뉴 메타 정보\n */\n parseBasicGridConfigs(menuMeta) {\n this.gridConfig = menuMeta.grid\n this.gridColumnConfig = menuMeta.grid_column\n this.searchConfig = menuMeta.search\n this.gridEmphasized = menuMeta.gridEmphasized\n }\n\n /**\n * @descrtiption 그리스트 구성 정보 파싱 처리\n ***************************************\n */\n async parseGristConfigs() {\n this.gristConfigSet = await MetaApi.parseGridConfigSet(this)\n this.useMasterFilterForm = this.useFilterForm === true ? true : false\n this.useFilterForm = false\n this.searchFieldValues = []\n this.searchFields = this.gristConfigSet.columns\n .filter(x => x.filter)\n .map(x => {\n let searchField = {\n name: x.name,\n type: x.filter.operator === 'search' ? 'search' : x.type,\n label: x.header,\n operator: x.filter.operator ? x.filter.operator : 'eq'\n }\n\n if (x.filter.options) {\n searchField.options = x.filter.options\n }\n\n if (x.record.options) {\n searchField.options = x.record.options\n }\n\n if (x.filter.value) {\n this.searchFieldValues.push({\n name: searchField.name,\n operator: searchField.operator,\n value: x.filter.value\n })\n }\n\n delete x.filter\n return searchField\n })\n }\n\n /********************************************************************\n * C R U D Functions\n ********************************************************************/\n\n async fetch() {\n await this.grist.fetch()\n }\n\n async beforeFetch({ page = 0, limit = 0, sortings = [], filters = [] }) {\n let detailContainer = this.renderRoot.querySelector('meta-tab-element')\n await detailContainer.clear()\n\n return true\n }\n\n async save() {\n let patches = MetaApi.patchesForUpdateMultiple(this.grist)\n let result = ValueUtil.isNotEmpty(patches) ? await this.updateMultiple(patches) : false\n if (result) {\n this.fetch()\n }\n }\n\n async find() {\n let ids = MetaApi.getSelectedIdList(this.grist, true)\n return ValueUtil.isNotEmpty(ids) ? await this.findOne(ids[0]) : {}\n }\n\n async delete() {\n let ids = MetaApi.getSelectedIdList(this.grist, true)\n let result = ValueUtil.isNotEmpty(ids) ? await this.deleteByIds(ids) : false\n if (result) {\n this.fetch()\n }\n }\n\n async export() {\n let exportTitle = TermsUtil.tTitle(ValueUtil.getParams(this.menuInfo, 'title'))\n return await MetaApi.exportableData(this.isElement, exportTitle, this.grist)\n }\n\n async import() {\n // TODO\n }\n\n getData() {\n let records = this.grist.___data.records\n records = JSON.parse(JSON.stringify(records))\n\n records.forEach(record => {\n let keys = Object.keys(record)\n keys.forEach(x => {\n if (x.startsWith('__')) {\n delete record[x]\n }\n })\n })\n\n let tabElement = this.renderRoot.querySelector('meta-tab-element')\n return {\n main: records,\n detail: tabElement.getData()\n }\n }\n }\n"]}
|
|
@@ -117,8 +117,7 @@ export const MetaMainTabMixin = baseElement => class extends MetaButtonMixin(bas
|
|
|
117
117
|
* @returns {HTMLElement}
|
|
118
118
|
*/
|
|
119
119
|
get filterForm() {
|
|
120
|
-
|
|
121
|
-
return (_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector(this.filterFormId);
|
|
120
|
+
return this.shadowRoot?.querySelector(this.filterFormId);
|
|
122
121
|
}
|
|
123
122
|
/**
|
|
124
123
|
* @description 컨텍스트
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"meta-main-tab-mixin.js","sourceRoot":"","sources":["../../client/mixin/meta-main-tab-mixin.js"],"names":[],"mappings":"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","sourcesContent":["import { MetaApi } from '../utils/meta-api'\nimport { MetaUiUtil } from '../utils/meta-ui-util'\n\nimport { MetaButtonMixin } from './meta-button-mixin'\n\n/**\n * @license\n * Copyright © HatioLab Inc. All rights reserved.\n * @author Shortstop shortstop@hatiolab.com\n * @description 메뉴 메타 정보를 기반으로 메인 탭 화면을 구성\n */\nexport const MetaMainTabMixin = baseElement =>\n class extends MetaButtonMixin(baseElement) {\n /**\n * @description 스타일 정의\n **************************\n * @returns {Array} 스타일\n */\n static get styles() {\n return MetaApi.getBasicMainTabStyles()\n }\n\n /**\n * @description 프로퍼티 정의\n ***************************\n * @returns {Object} 프로퍼티\n */\n static get properties() {\n return {\n /**\n * @description 그리드 구성 정보\n *****************************\n * @type {Object}\n */\n gridConfig: Object,\n /**\n * @description 그리드 컬럼 구성 정보\n *********************************\n * @type {Array}\n */\n gridColumnConfig: Array,\n /**\n * @description 검색 폼 구성 정보\n *******************************\n * @type {Array}\n */\n searchConfig: Array,\n /**\n * @description 화면에서 사용되는 서치 폼 : grist, filter, not\n *********************************************************\n * @type {String}\n */\n searchFormElement: String,\n /**\n * @description 메뉴 메타 정보로 부터 추출한 후 그리스트를 위해 설정 정보 구성\n *****************************************************************\n * @type {Object}\n */\n gristConfigSet: Object,\n /**\n * @description 필터 폼 사용 여부\n *****************************\n * @type {Boolean}\n */\n useFilterForm: Boolean,\n /**\n * @description 모바일 기기에서 그리드 모드 : GRID, LIST, CARD\n *********************************************************\n * @type {String}\n */\n gridMobileMode: String,\n /**\n * @description 데스크탑에서 그리드 모드 : GRID, LIST, CARD\n ******************************************************\n * @type {String}\n */\n gridDeskMode: String,\n /**\n * @description 그리드 뷰 모드 : GRID, LIST, CARD\n **********************************************\n * @type {Array}\n */\n gridViewOptions: Array,\n /**\n * @description 현재 그리드 뷰 모드 : GRID, LIST, CARD\n ***************************************************\n * @type {String}\n */\n gridMode: String,\n /**\n * @description Infinity Page 사용 여부\n **************************************\n * @type {Boolean}\n */\n infinityPage: Boolean,\n /**\n * @description 그리스트 엘리먼트 ID\n ***************************\n * @type {String}\n */\n gristId: String,\n /**\n * @description 필터 폼 엘리먼트 ID\n ***************************\n * @type {String}\n */\n filterFormId: String\n }\n }\n\n /**\n * @description 그리스트\n ***********************\n * @returns {HTMLElement}\n */\n get grist() {\n return this.masterElement.getMainGrist()\n }\n\n /**\n * @description 필터 폼\n ***********************\n * @returns {HTMLElement}\n */\n get filterForm() {\n return this.shadowRoot?.querySelector(this.filterFormId)\n }\n\n /**\n * @description 컨텍스트\n ***********************\n * @returns {HTMLElement}\n */\n get context() {\n let ctx = MetaUiUtil.getContextObject(this)\n\n if (ctx.actions) delete ctx.actions\n if (ctx.exportable) delete ctx.exportable\n if (ctx.importable) delete ctx.importable\n return ctx\n }\n\n /******************************************************\n * LifeCycle\n ******************************************************/\n\n async connectedCallback() {\n // 그리스트, 필터 폼 ID 설정\n this.gristId = 'ox-grist'\n this.filterFormId = 'ox-filters-form-base'\n\n // 메뉴 메타 정보 조회 및 기본 파싱\n await this.getAndParseMenuMeta()\n\n if (this.isElement) {\n await this.parseGristConfigs()\n }\n\n if (this.activityDataSet) {\n this.dataSet = (this.activityDataSet || {}).main\n }\n\n if (super.connectedCallback) {\n await super.connectedCallback()\n }\n }\n\n async firstUpdated() {\n if (super.firstUpdated) {\n await super.firstUpdated()\n }\n }\n\n async pageInitialized() {\n if (this.isPage) {\n await this.parseGristConfigs()\n }\n\n if (super.pageInitialized) {\n await super.pageInitialized()\n }\n }\n\n render() {\n return MetaApi.getMainTabHtml(this)\n }\n\n /**\n * @descrtiption 메뉴 메타 정보로 부터 메인 그리드 Configuration\n ********************************************************\n * @param {Object} menuMeta 메뉴 메타 정보\n */\n parseBasicGridConfigs(menuMeta) {\n this.gridConfig = menuMeta.grid\n this.gridColumnConfig = menuMeta.grid_column\n this.searchConfig = menuMeta.search\n this.gridEmphasized = menuMeta.gridEmphasized\n }\n\n /**\n * @descrtiption 그리스트 구성 정보로 부터 화면 구성 정보 추출\n ****************************************************\n */\n async parseGristConfigs() {\n this.gristConfigSet = await MetaApi.parseGridConfigSet(this)\n this.useMasterFilterForm = this.useFilterForm === true ? true : false\n this.useFilterForm = false\n this.buttonConfig = undefined\n this.useButtonExport = false\n this.useButtonImport = false\n this.searchFieldValues = []\n\n this.searchFields = this.gristConfigSet.columns\n .filter(x => x.filter)\n .map(x => {\n let searchField = {\n name: x.name,\n type: x.filter.operator === 'search' ? 'search' : x.type,\n label: x.header,\n operator: x.filter.operator ? x.filter.operator : 'eq'\n }\n\n if (x.filter.options) {\n searchField.options = x.filter.options\n }\n\n if (x.record.options) {\n searchField.options = x.record.options\n }\n\n if (x.filter.value) {\n this.searchFieldValues.push({\n name: searchField.name,\n operator: searchField.operator,\n value: x.filter.value\n })\n }\n\n delete x.filter\n return searchField\n })\n }\n\n /********************************************************************\n * C R U D Functions\n ********************************************************************/\n\n async fetch() {\n await this.grist.fetch()\n }\n\n async beforeFetch({ page = 0, limit = 0, sortings = [], filters = [] }) {\n if (this.masterElement) {\n if (this.masterElement.clear) {\n await this.masterElement.clear()\n }\n }\n\n return true\n }\n\n getData() {\n return {\n master: this.masterElement.getData()\n }\n }\n }\n"]}
|
|
1
|
+
{"version":3,"file":"meta-main-tab-mixin.js","sourceRoot":"","sources":["../../client/mixin/meta-main-tab-mixin.js"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAA;AAC3C,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAA;AAElD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AAErD;;;;;GAKG;AACH,MAAM,CAAC,MAAM,gBAAgB,GAAG,WAAW,CAAC,EAAE,CAC5C,KAAM,SAAQ,eAAe,CAAC,WAAW,CAAC;IACxC;;;;OAIG;IACH,MAAM,KAAK,MAAM;QACf,OAAO,OAAO,CAAC,qBAAqB,EAAE,CAAA;IACxC,CAAC;IAED;;;;OAIG;IACH,MAAM,KAAK,UAAU;QACnB,OAAO;YACL;;;;eAIG;YACH,UAAU,EAAE,MAAM;YAClB;;;;eAIG;YACH,gBAAgB,EAAE,KAAK;YACvB;;;;eAIG;YACH,YAAY,EAAE,KAAK;YACnB;;;;eAIG;YACH,iBAAiB,EAAE,MAAM;YACzB;;;;eAIG;YACH,cAAc,EAAE,MAAM;YACtB;;;;eAIG;YACH,aAAa,EAAE,OAAO;YACtB;;;;eAIG;YACH,cAAc,EAAE,MAAM;YACtB;;;;eAIG;YACH,YAAY,EAAE,MAAM;YACpB;;;;eAIG;YACH,eAAe,EAAE,KAAK;YACtB;;;;eAIG;YACH,QAAQ,EAAE,MAAM;YAChB;;;;eAIG;YACH,YAAY,EAAE,OAAO;YACrB;;;;eAIG;YACH,OAAO,EAAE,MAAM;YACf;;;;eAIG;YACH,YAAY,EAAE,MAAM;SACrB,CAAA;IACH,CAAC;IAED;;;;OAIG;IACH,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,CAAA;IAC1C,CAAC;IAED;;;;OAIG;IACH,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,UAAU,EAAE,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,CAAA;IAC1D,CAAC;IAED;;;;OAIG;IACH,IAAI,OAAO;QACT,IAAI,GAAG,GAAG,UAAU,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAA;QAE3C,IAAI,GAAG,CAAC,OAAO;YAAE,OAAO,GAAG,CAAC,OAAO,CAAA;QACnC,IAAI,GAAG,CAAC,UAAU;YAAE,OAAO,GAAG,CAAC,UAAU,CAAA;QACzC,IAAI,GAAG,CAAC,UAAU;YAAE,OAAO,GAAG,CAAC,UAAU,CAAA;QACzC,OAAO,GAAG,CAAA;IACZ,CAAC;IAED;;4DAEwD;IAExD,KAAK,CAAC,iBAAiB;QACrB,mBAAmB;QACnB,IAAI,CAAC,OAAO,GAAG,UAAU,CAAA;QACzB,IAAI,CAAC,YAAY,GAAG,sBAAsB,CAAA;QAE1C,sBAAsB;QACtB,MAAM,IAAI,CAAC,mBAAmB,EAAE,CAAA;QAEhC,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,MAAM,IAAI,CAAC,iBAAiB,EAAE,CAAA;QAChC,CAAC;QAED,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;YACzB,IAAI,CAAC,OAAO,GAAG,CAAC,IAAI,CAAC,eAAe,IAAI,EAAE,CAAC,CAAC,IAAI,CAAA;QAClD,CAAC;QAED,IAAI,KAAK,CAAC,iBAAiB,EAAE,CAAC;YAC5B,MAAM,KAAK,CAAC,iBAAiB,EAAE,CAAA;QACjC,CAAC;IACH,CAAC;IAED,KAAK,CAAC,YAAY;QAChB,IAAI,KAAK,CAAC,YAAY,EAAE,CAAC;YACvB,MAAM,KAAK,CAAC,YAAY,EAAE,CAAA;QAC5B,CAAC;IACH,CAAC;IAED,KAAK,CAAC,eAAe;QACnB,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,MAAM,IAAI,CAAC,iBAAiB,EAAE,CAAA;QAChC,CAAC;QAED,IAAI,KAAK,CAAC,eAAe,EAAE,CAAC;YAC1B,MAAM,KAAK,CAAC,eAAe,EAAE,CAAA;QAC/B,CAAC;IACH,CAAC;IAED,MAAM;QACJ,OAAO,OAAO,CAAC,cAAc,CAAC,IAAI,CAAC,CAAA;IACrC,CAAC;IAED;;;;OAIG;IACH,qBAAqB,CAAC,QAAQ;QAC5B,IAAI,CAAC,UAAU,GAAG,QAAQ,CAAC,IAAI,CAAA;QAC/B,IAAI,CAAC,gBAAgB,GAAG,QAAQ,CAAC,WAAW,CAAA;QAC5C,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC,MAAM,CAAA;QACnC,IAAI,CAAC,cAAc,GAAG,QAAQ,CAAC,cAAc,CAAA;IAC/C,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,iBAAiB;QACrB,IAAI,CAAC,cAAc,GAAG,MAAM,OAAO,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAA;QAC5D,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,aAAa,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAA;QACrE,IAAI,CAAC,aAAa,GAAG,KAAK,CAAA;QAC1B,IAAI,CAAC,YAAY,GAAG,SAAS,CAAA;QAC7B,IAAI,CAAC,eAAe,GAAG,KAAK,CAAA;QAC5B,IAAI,CAAC,eAAe,GAAG,KAAK,CAAA;QAC5B,IAAI,CAAC,iBAAiB,GAAG,EAAE,CAAA;QAE3B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,cAAc,CAAC,OAAO;aAC5C,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC;aACrB,GAAG,CAAC,CAAC,CAAC,EAAE;YACP,IAAI,WAAW,GAAG;gBAChB,IAAI,EAAE,CAAC,CAAC,IAAI;gBACZ,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,QAAQ,KAAK,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI;gBACxD,KAAK,EAAE,CAAC,CAAC,MAAM;gBACf,QAAQ,EAAE,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI;aACvD,CAAA;YAED,IAAI,CAAC,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;gBACrB,WAAW,CAAC,OAAO,GAAG,CAAC,CAAC,MAAM,CAAC,OAAO,CAAA;YACxC,CAAC;YAED,IAAI,CAAC,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;gBACrB,WAAW,CAAC,OAAO,GAAG,CAAC,CAAC,MAAM,CAAC,OAAO,CAAA;YACxC,CAAC;YAED,IAAI,CAAC,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;gBACnB,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC;oBAC1B,IAAI,EAAE,WAAW,CAAC,IAAI;oBACtB,QAAQ,EAAE,WAAW,CAAC,QAAQ;oBAC9B,KAAK,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK;iBACtB,CAAC,CAAA;YACJ,CAAC;YAED,OAAO,CAAC,CAAC,MAAM,CAAA;YACf,OAAO,WAAW,CAAA;QACpB,CAAC,CAAC,CAAA;IACN,CAAC;IAED;;0EAEsE;IAEtE,KAAK,CAAC,KAAK;QACT,MAAM,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAA;IAC1B,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,EAAE,IAAI,GAAG,CAAC,EAAE,KAAK,GAAG,CAAC,EAAE,QAAQ,GAAG,EAAE,EAAE,OAAO,GAAG,EAAE,EAAE;QACpE,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YACvB,IAAI,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;gBAC7B,MAAM,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAA;YAClC,CAAC;QACH,CAAC;QAED,OAAO,IAAI,CAAA;IACb,CAAC;IAED,OAAO;QACL,OAAO;YACL,MAAM,EAAE,IAAI,CAAC,aAAa,CAAC,OAAO,EAAE;SACrC,CAAA;IACH,CAAC;CACF,CAAA","sourcesContent":["import { MetaApi } from '../utils/meta-api'\nimport { MetaUiUtil } from '../utils/meta-ui-util'\n\nimport { MetaButtonMixin } from './meta-button-mixin'\n\n/**\n * @license\n * Copyright © HatioLab Inc. All rights reserved.\n * @author Shortstop shortstop@hatiolab.com\n * @description 메뉴 메타 정보를 기반으로 메인 탭 화면을 구성\n */\nexport const MetaMainTabMixin = baseElement =>\n class extends MetaButtonMixin(baseElement) {\n /**\n * @description 스타일 정의\n **************************\n * @returns {Array} 스타일\n */\n static get styles() {\n return MetaApi.getBasicMainTabStyles()\n }\n\n /**\n * @description 프로퍼티 정의\n ***************************\n * @returns {Object} 프로퍼티\n */\n static get properties() {\n return {\n /**\n * @description 그리드 구성 정보\n *****************************\n * @type {Object}\n */\n gridConfig: Object,\n /**\n * @description 그리드 컬럼 구성 정보\n *********************************\n * @type {Array}\n */\n gridColumnConfig: Array,\n /**\n * @description 검색 폼 구성 정보\n *******************************\n * @type {Array}\n */\n searchConfig: Array,\n /**\n * @description 화면에서 사용되는 서치 폼 : grist, filter, not\n *********************************************************\n * @type {String}\n */\n searchFormElement: String,\n /**\n * @description 메뉴 메타 정보로 부터 추출한 후 그리스트를 위해 설정 정보 구성\n *****************************************************************\n * @type {Object}\n */\n gristConfigSet: Object,\n /**\n * @description 필터 폼 사용 여부\n *****************************\n * @type {Boolean}\n */\n useFilterForm: Boolean,\n /**\n * @description 모바일 기기에서 그리드 모드 : GRID, LIST, CARD\n *********************************************************\n * @type {String}\n */\n gridMobileMode: String,\n /**\n * @description 데스크탑에서 그리드 모드 : GRID, LIST, CARD\n ******************************************************\n * @type {String}\n */\n gridDeskMode: String,\n /**\n * @description 그리드 뷰 모드 : GRID, LIST, CARD\n **********************************************\n * @type {Array}\n */\n gridViewOptions: Array,\n /**\n * @description 현재 그리드 뷰 모드 : GRID, LIST, CARD\n ***************************************************\n * @type {String}\n */\n gridMode: String,\n /**\n * @description Infinity Page 사용 여부\n **************************************\n * @type {Boolean}\n */\n infinityPage: Boolean,\n /**\n * @description 그리스트 엘리먼트 ID\n ***************************\n * @type {String}\n */\n gristId: String,\n /**\n * @description 필터 폼 엘리먼트 ID\n ***************************\n * @type {String}\n */\n filterFormId: String\n }\n }\n\n /**\n * @description 그리스트\n ***********************\n * @returns {HTMLElement}\n */\n get grist() {\n return this.masterElement.getMainGrist()\n }\n\n /**\n * @description 필터 폼\n ***********************\n * @returns {HTMLElement}\n */\n get filterForm() {\n return this.shadowRoot?.querySelector(this.filterFormId)\n }\n\n /**\n * @description 컨텍스트\n ***********************\n * @returns {HTMLElement}\n */\n get context() {\n let ctx = MetaUiUtil.getContextObject(this)\n\n if (ctx.actions) delete ctx.actions\n if (ctx.exportable) delete ctx.exportable\n if (ctx.importable) delete ctx.importable\n return ctx\n }\n\n /******************************************************\n * LifeCycle\n ******************************************************/\n\n async connectedCallback() {\n // 그리스트, 필터 폼 ID 설정\n this.gristId = 'ox-grist'\n this.filterFormId = 'ox-filters-form-base'\n\n // 메뉴 메타 정보 조회 및 기본 파싱\n await this.getAndParseMenuMeta()\n\n if (this.isElement) {\n await this.parseGristConfigs()\n }\n\n if (this.activityDataSet) {\n this.dataSet = (this.activityDataSet || {}).main\n }\n\n if (super.connectedCallback) {\n await super.connectedCallback()\n }\n }\n\n async firstUpdated() {\n if (super.firstUpdated) {\n await super.firstUpdated()\n }\n }\n\n async pageInitialized() {\n if (this.isPage) {\n await this.parseGristConfigs()\n }\n\n if (super.pageInitialized) {\n await super.pageInitialized()\n }\n }\n\n render() {\n return MetaApi.getMainTabHtml(this)\n }\n\n /**\n * @descrtiption 메뉴 메타 정보로 부터 메인 그리드 Configuration\n ********************************************************\n * @param {Object} menuMeta 메뉴 메타 정보\n */\n parseBasicGridConfigs(menuMeta) {\n this.gridConfig = menuMeta.grid\n this.gridColumnConfig = menuMeta.grid_column\n this.searchConfig = menuMeta.search\n this.gridEmphasized = menuMeta.gridEmphasized\n }\n\n /**\n * @descrtiption 그리스트 구성 정보로 부터 화면 구성 정보 추출\n ****************************************************\n */\n async parseGristConfigs() {\n this.gristConfigSet = await MetaApi.parseGridConfigSet(this)\n this.useMasterFilterForm = this.useFilterForm === true ? true : false\n this.useFilterForm = false\n this.buttonConfig = undefined\n this.useButtonExport = false\n this.useButtonImport = false\n this.searchFieldValues = []\n\n this.searchFields = this.gristConfigSet.columns\n .filter(x => x.filter)\n .map(x => {\n let searchField = {\n name: x.name,\n type: x.filter.operator === 'search' ? 'search' : x.type,\n label: x.header,\n operator: x.filter.operator ? x.filter.operator : 'eq'\n }\n\n if (x.filter.options) {\n searchField.options = x.filter.options\n }\n\n if (x.record.options) {\n searchField.options = x.record.options\n }\n\n if (x.filter.value) {\n this.searchFieldValues.push({\n name: searchField.name,\n operator: searchField.operator,\n value: x.filter.value\n })\n }\n\n delete x.filter\n return searchField\n })\n }\n\n /********************************************************************\n * C R U D Functions\n ********************************************************************/\n\n async fetch() {\n await this.grist.fetch()\n }\n\n async beforeFetch({ page = 0, limit = 0, sortings = [], filters = [] }) {\n if (this.masterElement) {\n if (this.masterElement.clear) {\n await this.masterElement.clear()\n }\n }\n\n return true\n }\n\n getData() {\n return {\n master: this.masterElement.getData()\n }\n }\n }\n"]}
|
|
@@ -125,8 +125,7 @@ export const MetaMasterDetailMixin = baseElement => class extends MetaButtonMixi
|
|
|
125
125
|
* @returns {HTMLElement}
|
|
126
126
|
*/
|
|
127
127
|
get filterForm() {
|
|
128
|
-
|
|
129
|
-
return (_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector(this.filterFormId);
|
|
128
|
+
return this.shadowRoot?.querySelector(this.filterFormId);
|
|
130
129
|
}
|
|
131
130
|
/**
|
|
132
131
|
* @description 컨텍스트
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"meta-master-detail-mixin.js","sourceRoot":"","sources":["../../client/mixin/meta-master-detail-mixin.js"],"names":[],"mappings":"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","sourcesContent":["import { MetaApi } from '../utils/meta-api'\nimport { MetaUiUtil } from '../utils/meta-ui-util'\nimport { ValueUtil } from '../utils/value-util'\nimport { TermsUtil } from '../utils/terms-util'\n\nimport { MetaButtonMixin } from './meta-button-mixin'\n\n/**\n * @description 메뉴 메타 정보를 이용해 마스터 - 디테일 그리드 화면 구현\n ************************************************************\n * @param {Object} MetaButtonMixin\n * @returns\n */\nexport const MetaMasterDetailMixin = baseElement =>\n class extends MetaButtonMixin(baseElement) {\n /**\n * @description 스타일 정의\n **************************\n * @returns {Array} 스타일\n */\n static get styles() {\n return MetaApi.getBasicMasterDetailStyles()\n }\n\n /**\n * @description 프로퍼티 정의\n ****************************\n * @returns {Object} 프로퍼티\n */\n static get properties() {\n return {\n /**\n * @description 그리드 구성 정보\n *****************************\n * @type {Object}\n */\n gridConfig: Object,\n /**\n * @description 그리드 컬럼 구성 정보\n *********************************\n * @type {Array}\n */\n gridColumnConfig: Array,\n /**\n * @description 검색 폼 구성 정보\n *******************************\n * @type {Array}\n */\n searchConfig: Array,\n /**\n * @description 화면에서 사용되는 서치 폼 : grist, filter, not\n *********************************************************\n * @type {String}\n */\n searchFormElement: String,\n /**\n * @description 메뉴 메타 정보로 부터 추출한 후 그리스트를 위해 설정 정보 구성\n *****************************************************************\n * @type {Object}\n */\n gristConfigSet: Object,\n /**\n * @description 필터 폼 사용 여부\n *****************************\n * @type {Boolean}\n */\n useFilterForm: Boolean,\n /**\n * @description 모바일 기기에서 그리드 모드 : GRID, LIST, CARD\n *********************************************************\n * @type {String}\n */\n gridMobileMode: String,\n /**\n * @description 데스크탑에서 그리드 모드 : GRID, LIST, CARD\n ******************************************************\n * @type {String}\n */\n gridDeskMode: String,\n /**\n * @description 그리드 뷰 모드 : GRID, LIST, CARD\n **********************************************\n * @type {Array}\n */\n gridViewOptions: Array,\n /**\n * @description 현재 그리드 뷰 모드 : GRID, LIST, CARD\n ***************************************************\n * @type {String}\n */\n gridMode: String,\n /**\n * @description Infinity Page 사용 여부\n **************************************\n * @type {Boolean}\n */\n infinityPage: Boolean,\n /**\n * @description 그리스트 엘리먼트 ID\n ********************************\n * @type {String}\n */\n gristId: String,\n /**\n * @description 필터 폼 엘리먼트 ID\n ********************************\n * @type {String}\n */\n filterFormId: String,\n /**\n * @description detail 엘리먼트\n ******************************\n * @type {Object}\n */\n detailElement: Object\n }\n }\n\n /**\n * @description 그리스트\n ***********************\n * @returns {HTMLElement}\n */\n get grist() {\n return this.renderRoot.querySelector(this.gristId)\n }\n\n /**\n * @description 필터 폼\n ***********************\n * @returns {HTMLElement}\n */\n get filterForm() {\n return this.shadowRoot?.querySelector(this.filterFormId)\n }\n\n /**\n * @description 컨텍스트\n ***********************\n * @returns {HTMLElement}\n */\n get context() {\n let ctx = MetaUiUtil.getContextObject(this)\n\n if (ctx.actions) delete ctx.actions\n if (ctx.exportable) delete ctx.exportable\n if (ctx.importable) delete ctx.importable\n return ctx\n }\n\n /******************************************************\n * LifeCycle\n ******************************************************/\n\n /**\n * @override connectedCallback\n *******************************\n */\n async connectedCallback() {\n // 그리스트, 필터 폼 ID 설정\n this.gristId = 'ox-grist'\n this.filterFormId = 'ox-filters-form-base'\n\n // 메뉴 메타 정보 조회 및 기본 파싱\n await this.getAndParseMenuMeta()\n\n if (this.isElement) {\n await this.parseGristConfigs()\n }\n\n if (this.activityDataSet) {\n this.dataSet = (this.activityDataSet || {}).main\n }\n\n if (super.connectedCallback) {\n await super.connectedCallback()\n }\n }\n\n /**\n * @override firstUpdated\n **************************\n */\n async firstUpdated() {\n if (super.firstUpdated) {\n await super.firstUpdated()\n }\n }\n\n /**\n * @override pageInitialized\n ****************************\n */\n async pageInitialized() {\n if (this.isPage) {\n await this.parseGristConfigs()\n }\n\n if (super.pageInitialized) {\n await super.pageInitialized()\n }\n }\n\n /**\n * @override render\n ********************\n */\n render() {\n return MetaApi.getMasterDetailHtml(this)\n }\n\n /**\n * @descrtiption 메뉴 메타에서 기본 그리드 정보 파싱 처리\n ************************************************\n * @param {Object} menuMeta 메뉴 메타 정보\n */\n parseBasicGridConfigs(menuMeta) {\n this.gridConfig = menuMeta.grid\n this.gridColumnConfig = menuMeta.grid_column\n this.searchConfig = menuMeta.search\n this.gridEmphasized = menuMeta.gridEmphasized\n }\n\n /**\n * @descrtiption 그리스트 구성 정보 파싱 처리\n ***************************************\n */\n async parseGristConfigs() {\n // 그리드 설정 셋 파싱\n this.gristConfigSet = await MetaApi.parseGridConfigSet(this)\n\n // 마스터 그리드에 handlers > focus 이벤트를 등록\n this.gristConfigSet.rows.handlers = this.gristConfigSet.rows.handlers || {}\n let gristRowHandler = this.gristConfigSet.rows.handlers\n gristRowHandler.focus = this.masterGridFocusEventHandler.bind(this)\n\n // 마스터 그리드 옵션 처리\n this.masterOption = JSON.parse(this.etcConfig.master_option || '{}')\n let { split_filter = false } = this.masterOption\n this.useMasterFilterForm = this.useFilterForm === true && split_filter === false ? true : false\n this.useFilterForm = split_filter === true ? true : false\n\n // 필터 폼 사용을 하지 않는다면\n if (this.useFilterForm == false) {\n // 검색 조건 초기값 설정이 있다면 검색 초기값을 등록해놓는다.\n this.searchFieldValues = []\n\n // 검색 조건이 있는 컬럼 정보로 부터 그리드의 검색 조건 정보를 구성\n this.searchFields = this.gristConfigSet.columns\n .filter(x => x.filter)\n .map(x => {\n // 검색 조건\n let searchField = {\n name: x.name,\n type: x.filter.operator === 'search' ? 'search' : x.type,\n label: x.header,\n operator: x.filter.operator ? x.filter.operator : 'eq'\n }\n\n if (x.filter.options) {\n searchField.options = x.filter.options\n }\n\n if (x.record.options) {\n searchField.options = x.record.options\n }\n\n // 검색 조건 초기값이 있다면 설정\n if (x.filter.value) {\n this.searchFieldValues.push({\n name: searchField.name,\n operator: searchField.operator,\n value: x.filter.value\n })\n }\n\n delete x.filter\n return searchField\n })\n }\n }\n\n /**\n * @descrtiption 마스터 그리드에 대한 포커스 이벤트 핸들러 정의\n *****************************************************\n * @param {Array} columns\n * @param {Object} data\n * @param {Object} column\n * @param {Object} record\n * @param {Number} rowIndex\n */\n masterGridFocusEventHandler(columns, data, column, record, rowIndex) {\n if (record.id && this.detailElement) {\n this.detailElement.setParentId(record.id)\n }\n }\n\n /********************************************************************\n * C R U D Functions\n ********************************************************************/\n\n /**\n * @descrtiption 데이터 조회\n **************************\n */\n async fetch() {\n await this.grist.fetch()\n }\n\n /**\n * @descrtiption 데이터 조회 전 액션\n ********************************\n */\n async beforeFetch({ page = 0, limit = 0, sortings = [], filters = [] }) {\n if (this.detailElement && this.detailElement.clear) {\n await this.detailElement.clear()\n }\n\n return true\n }\n\n /**\n * @descrtiption 저장 처리\n **************************\n */\n async save() {\n let patches = MetaApi.patchesForUpdateMultiple(this.grist)\n let result = ValueUtil.isNotEmpty(patches) ? await this.updateMultiple(patches) : false\n if (result) {\n this.fetch()\n }\n }\n\n /**\n * @descrtiption id 리스트로 데이터 조회\n ************************************\n */\n async find() {\n let ids = MetaApi.getSelectedIdList(this.grist, true)\n return ValueUtil.isNotEmpty(ids) ? await this.findOne(ids[0]) : {}\n }\n\n /**\n * @descrtiption 삭제 처리\n **************************\n */\n async delete() {\n let ids = MetaApi.getSelectedIdList(this.grist, true)\n let result = ValueUtil.isNotEmpty(ids) ? await this.deleteByIds(ids) : false\n if (result) {\n this.fetch()\n }\n }\n\n /**\n * @descrtiption 익스포트 처리\n ****************************\n */\n async export() {\n let exportTitle = TermsUtil.tTitle(ValueUtil.getParams(this.menuInfo, 'title'))\n return await MetaApi.exportableData(this.isElement, exportTitle, this.grist)\n }\n\n /**\n * @descrtiption 임포트 처리\n **************************\n */\n async import() {\n // TODO\n }\n\n /**\n * @descrtiption 그리드 데이터 리턴\n *******************************\n * @returns {Object}\n */\n getData() {\n let records = this.grist.___data.records\n records = JSON.parse(JSON.stringify(records))\n\n records.forEach(record => {\n let keys = Object.keys(record)\n keys.forEach(x => {\n if (x.startsWith('__')) {\n delete record[x]\n }\n })\n })\n\n return {\n main: records,\n detail: this.detailElement.getData()\n }\n }\n }\n"]}
|
|
1
|
+
{"version":3,"file":"meta-master-detail-mixin.js","sourceRoot":"","sources":["../../client/mixin/meta-master-detail-mixin.js"],"names":[],"mappings":"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","sourcesContent":["import { MetaApi } from '../utils/meta-api'\nimport { MetaUiUtil } from '../utils/meta-ui-util'\nimport { ValueUtil } from '../utils/value-util'\nimport { TermsUtil } from '../utils/terms-util'\n\nimport { MetaButtonMixin } from './meta-button-mixin'\n\n/**\n * @description 메뉴 메타 정보를 이용해 마스터 - 디테일 그리드 화면 구현\n ************************************************************\n * @param {Object} MetaButtonMixin\n * @returns\n */\nexport const MetaMasterDetailMixin = baseElement =>\n class extends MetaButtonMixin(baseElement) {\n /**\n * @description 스타일 정의\n **************************\n * @returns {Array} 스타일\n */\n static get styles() {\n return MetaApi.getBasicMasterDetailStyles()\n }\n\n /**\n * @description 프로퍼티 정의\n ****************************\n * @returns {Object} 프로퍼티\n */\n static get properties() {\n return {\n /**\n * @description 그리드 구성 정보\n *****************************\n * @type {Object}\n */\n gridConfig: Object,\n /**\n * @description 그리드 컬럼 구성 정보\n *********************************\n * @type {Array}\n */\n gridColumnConfig: Array,\n /**\n * @description 검색 폼 구성 정보\n *******************************\n * @type {Array}\n */\n searchConfig: Array,\n /**\n * @description 화면에서 사용되는 서치 폼 : grist, filter, not\n *********************************************************\n * @type {String}\n */\n searchFormElement: String,\n /**\n * @description 메뉴 메타 정보로 부터 추출한 후 그리스트를 위해 설정 정보 구성\n *****************************************************************\n * @type {Object}\n */\n gristConfigSet: Object,\n /**\n * @description 필터 폼 사용 여부\n *****************************\n * @type {Boolean}\n */\n useFilterForm: Boolean,\n /**\n * @description 모바일 기기에서 그리드 모드 : GRID, LIST, CARD\n *********************************************************\n * @type {String}\n */\n gridMobileMode: String,\n /**\n * @description 데스크탑에서 그리드 모드 : GRID, LIST, CARD\n ******************************************************\n * @type {String}\n */\n gridDeskMode: String,\n /**\n * @description 그리드 뷰 모드 : GRID, LIST, CARD\n **********************************************\n * @type {Array}\n */\n gridViewOptions: Array,\n /**\n * @description 현재 그리드 뷰 모드 : GRID, LIST, CARD\n ***************************************************\n * @type {String}\n */\n gridMode: String,\n /**\n * @description Infinity Page 사용 여부\n **************************************\n * @type {Boolean}\n */\n infinityPage: Boolean,\n /**\n * @description 그리스트 엘리먼트 ID\n ********************************\n * @type {String}\n */\n gristId: String,\n /**\n * @description 필터 폼 엘리먼트 ID\n ********************************\n * @type {String}\n */\n filterFormId: String,\n /**\n * @description detail 엘리먼트\n ******************************\n * @type {Object}\n */\n detailElement: Object\n }\n }\n\n /**\n * @description 그리스트\n ***********************\n * @returns {HTMLElement}\n */\n get grist() {\n return this.renderRoot.querySelector(this.gristId)\n }\n\n /**\n * @description 필터 폼\n ***********************\n * @returns {HTMLElement}\n */\n get filterForm() {\n return this.shadowRoot?.querySelector(this.filterFormId)\n }\n\n /**\n * @description 컨텍스트\n ***********************\n * @returns {HTMLElement}\n */\n get context() {\n let ctx = MetaUiUtil.getContextObject(this)\n\n if (ctx.actions) delete ctx.actions\n if (ctx.exportable) delete ctx.exportable\n if (ctx.importable) delete ctx.importable\n return ctx\n }\n\n /******************************************************\n * LifeCycle\n ******************************************************/\n\n /**\n * @override connectedCallback\n *******************************\n */\n async connectedCallback() {\n // 그리스트, 필터 폼 ID 설정\n this.gristId = 'ox-grist'\n this.filterFormId = 'ox-filters-form-base'\n\n // 메뉴 메타 정보 조회 및 기본 파싱\n await this.getAndParseMenuMeta()\n\n if (this.isElement) {\n await this.parseGristConfigs()\n }\n\n if (this.activityDataSet) {\n this.dataSet = (this.activityDataSet || {}).main\n }\n\n if (super.connectedCallback) {\n await super.connectedCallback()\n }\n }\n\n /**\n * @override firstUpdated\n **************************\n */\n async firstUpdated() {\n if (super.firstUpdated) {\n await super.firstUpdated()\n }\n }\n\n /**\n * @override pageInitialized\n ****************************\n */\n async pageInitialized() {\n if (this.isPage) {\n await this.parseGristConfigs()\n }\n\n if (super.pageInitialized) {\n await super.pageInitialized()\n }\n }\n\n /**\n * @override render\n ********************\n */\n render() {\n return MetaApi.getMasterDetailHtml(this)\n }\n\n /**\n * @descrtiption 메뉴 메타에서 기본 그리드 정보 파싱 처리\n ************************************************\n * @param {Object} menuMeta 메뉴 메타 정보\n */\n parseBasicGridConfigs(menuMeta) {\n this.gridConfig = menuMeta.grid\n this.gridColumnConfig = menuMeta.grid_column\n this.searchConfig = menuMeta.search\n this.gridEmphasized = menuMeta.gridEmphasized\n }\n\n /**\n * @descrtiption 그리스트 구성 정보 파싱 처리\n ***************************************\n */\n async parseGristConfigs() {\n // 그리드 설정 셋 파싱\n this.gristConfigSet = await MetaApi.parseGridConfigSet(this)\n\n // 마스터 그리드에 handlers > focus 이벤트를 등록\n this.gristConfigSet.rows.handlers = this.gristConfigSet.rows.handlers || {}\n let gristRowHandler = this.gristConfigSet.rows.handlers\n gristRowHandler.focus = this.masterGridFocusEventHandler.bind(this)\n\n // 마스터 그리드 옵션 처리\n this.masterOption = JSON.parse(this.etcConfig.master_option || '{}')\n let { split_filter = false } = this.masterOption\n this.useMasterFilterForm = this.useFilterForm === true && split_filter === false ? true : false\n this.useFilterForm = split_filter === true ? true : false\n\n // 필터 폼 사용을 하지 않는다면\n if (this.useFilterForm == false) {\n // 검색 조건 초기값 설정이 있다면 검색 초기값을 등록해놓는다.\n this.searchFieldValues = []\n\n // 검색 조건이 있는 컬럼 정보로 부터 그리드의 검색 조건 정보를 구성\n this.searchFields = this.gristConfigSet.columns\n .filter(x => x.filter)\n .map(x => {\n // 검색 조건\n let searchField = {\n name: x.name,\n type: x.filter.operator === 'search' ? 'search' : x.type,\n label: x.header,\n operator: x.filter.operator ? x.filter.operator : 'eq'\n }\n\n if (x.filter.options) {\n searchField.options = x.filter.options\n }\n\n if (x.record.options) {\n searchField.options = x.record.options\n }\n\n // 검색 조건 초기값이 있다면 설정\n if (x.filter.value) {\n this.searchFieldValues.push({\n name: searchField.name,\n operator: searchField.operator,\n value: x.filter.value\n })\n }\n\n delete x.filter\n return searchField\n })\n }\n }\n\n /**\n * @descrtiption 마스터 그리드에 대한 포커스 이벤트 핸들러 정의\n *****************************************************\n * @param {Array} columns\n * @param {Object} data\n * @param {Object} column\n * @param {Object} record\n * @param {Number} rowIndex\n */\n masterGridFocusEventHandler(columns, data, column, record, rowIndex) {\n if (record.id && this.detailElement) {\n this.detailElement.setParentId(record.id)\n }\n }\n\n /********************************************************************\n * C R U D Functions\n ********************************************************************/\n\n /**\n * @descrtiption 데이터 조회\n **************************\n */\n async fetch() {\n await this.grist.fetch()\n }\n\n /**\n * @descrtiption 데이터 조회 전 액션\n ********************************\n */\n async beforeFetch({ page = 0, limit = 0, sortings = [], filters = [] }) {\n if (this.detailElement && this.detailElement.clear) {\n await this.detailElement.clear()\n }\n\n return true\n }\n\n /**\n * @descrtiption 저장 처리\n **************************\n */\n async save() {\n let patches = MetaApi.patchesForUpdateMultiple(this.grist)\n let result = ValueUtil.isNotEmpty(patches) ? await this.updateMultiple(patches) : false\n if (result) {\n this.fetch()\n }\n }\n\n /**\n * @descrtiption id 리스트로 데이터 조회\n ************************************\n */\n async find() {\n let ids = MetaApi.getSelectedIdList(this.grist, true)\n return ValueUtil.isNotEmpty(ids) ? await this.findOne(ids[0]) : {}\n }\n\n /**\n * @descrtiption 삭제 처리\n **************************\n */\n async delete() {\n let ids = MetaApi.getSelectedIdList(this.grist, true)\n let result = ValueUtil.isNotEmpty(ids) ? await this.deleteByIds(ids) : false\n if (result) {\n this.fetch()\n }\n }\n\n /**\n * @descrtiption 익스포트 처리\n ****************************\n */\n async export() {\n let exportTitle = TermsUtil.tTitle(ValueUtil.getParams(this.menuInfo, 'title'))\n return await MetaApi.exportableData(this.isElement, exportTitle, this.grist)\n }\n\n /**\n * @descrtiption 임포트 처리\n **************************\n */\n async import() {\n // TODO\n }\n\n /**\n * @descrtiption 그리드 데이터 리턴\n *******************************\n * @returns {Object}\n */\n getData() {\n let records = this.grist.___data.records\n records = JSON.parse(JSON.stringify(records))\n\n records.forEach(record => {\n let keys = Object.keys(record)\n keys.forEach(x => {\n if (x.startsWith('__')) {\n delete record[x]\n }\n })\n })\n\n return {\n main: records,\n detail: this.detailElement.getData()\n }\n }\n }\n"]}
|
|
@@ -37,7 +37,6 @@ export const MetaServiceMixin = (baseElement) => class extends MetaBaseMixin(bas
|
|
|
37
37
|
* @returns {Object} { total : Number, records : Array }
|
|
38
38
|
*/
|
|
39
39
|
async fetchHandler({ page = 0, limit = 0, sortings = [], filters = [] }) {
|
|
40
|
-
var _a;
|
|
41
40
|
if (this.is_activity) {
|
|
42
41
|
return {
|
|
43
42
|
total: 0,
|
|
@@ -61,7 +60,7 @@ export const MetaServiceMixin = (baseElement) => class extends MetaBaseMixin(bas
|
|
|
61
60
|
// 필터 처리
|
|
62
61
|
let formFilters = ValueUtil.isEmpty(filters)
|
|
63
62
|
? (this.mainFilterForm ? ((await this.mainFilterForm.getQueryFilters()) || [])
|
|
64
|
-
: ((await
|
|
63
|
+
: ((await this.filterForm?.getQueryFilters()) || []))
|
|
65
64
|
: filters;
|
|
66
65
|
// 조회 함수
|
|
67
66
|
let queryFunc = ValueUtil.getParams(this.gqlInfo, 'query', 'list_func');
|
|
@@ -137,11 +136,10 @@ export const MetaServiceMixin = (baseElement) => class extends MetaBaseMixin(bas
|
|
|
137
136
|
* @returns {Array} [{ name: '', operator: 'eq', value: '' }]
|
|
138
137
|
*/
|
|
139
138
|
getPageNavigateParams() {
|
|
140
|
-
var _a;
|
|
141
139
|
if (this.isPage == false)
|
|
142
140
|
return [];
|
|
143
141
|
// 페이지의 경우만 URL 파라미터 추출
|
|
144
|
-
let navParams =
|
|
142
|
+
let navParams = this.lifecycle?.params ? this.lifecycle.params : {};
|
|
145
143
|
if (!navParams.pass)
|
|
146
144
|
return [];
|
|
147
145
|
let passParams = navParams.pass;
|