@operato/dataset 8.2.6 → 8.2.8
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/CHANGELOG.md +17 -0
- package/dist/src/ox-checklist-entry-form.d.ts +6 -2
- package/dist/src/ox-checklist-entry-form.js +33 -7
- package/dist/src/ox-checklist-entry-form.js.map +1 -1
- package/dist/stories/ox-checklist-entry-form-stories.d.ts +19 -0
- package/dist/stories/ox-checklist-entry-form-stories.js +421 -0
- package/dist/stories/ox-checklist-entry-form-stories.js.map +1 -0
- package/dist/stories/ox-data-entry-form.stories copy.d.ts +19 -0
- package/dist/stories/ox-data-entry-form.stories copy.js +238 -0
- package/dist/stories/ox-data-entry-form.stories copy.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +5 -5
package/CHANGELOG.md
CHANGED
|
@@ -3,6 +3,23 @@
|
|
|
3
3
|
All notable changes to this project will be documented in this file.
|
|
4
4
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
|
5
5
|
|
|
6
|
+
### [8.2.8](https://github.com/hatiolab/operato/compare/v8.2.7...v8.2.8) (2025-05-27)
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
### :bug: Bug Fix
|
|
10
|
+
|
|
11
|
+
* 체크박스 데이터입력시 설명 없으면 필드 숨김, 모바일 UI 퍼블 수정 ([7d2d36b](https://github.com/hatiolab/operato/commit/7d2d36bb02826d28beb4b15384127c711f26f5aa))
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
### [8.2.7](https://github.com/hatiolab/operato/compare/v8.2.6...v8.2.7) (2025-05-26)
|
|
16
|
+
|
|
17
|
+
**Note:** Version bump only for package @operato/dataset
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
|
|
22
|
+
|
|
6
23
|
### [8.2.6](https://github.com/hatiolab/operato/compare/v8.2.5...v8.2.6) (2025-05-23)
|
|
7
24
|
|
|
8
25
|
**Note:** Version bump only for package @operato/dataset
|
|
@@ -19,8 +19,12 @@ export declare class OxChecklistEntryForm extends LitElement {
|
|
|
19
19
|
private buildValue;
|
|
20
20
|
private extractValuesFromInputs;
|
|
21
21
|
buildInputs(): import("lit-html").TemplateResult<1>;
|
|
22
|
-
buildGroupInputs(items: DataItem[], nameColspan: number
|
|
23
|
-
|
|
22
|
+
buildGroupInputs(items: DataItem[], nameColspan: number, options: {
|
|
23
|
+
isDescEmpty: boolean;
|
|
24
|
+
}): import("lit-html").TemplateResult<1>;
|
|
25
|
+
buildNonGroupInputs(items: DataItem[], nameColspan: number, options: {
|
|
26
|
+
isDescEmpty: boolean;
|
|
27
|
+
}): import("lit-html").TemplateResult<1>;
|
|
24
28
|
isGroupRendered(renderedGroups: {
|
|
25
29
|
group: string;
|
|
26
30
|
subgroup?: string;
|
|
@@ -50,26 +50,30 @@ let OxChecklistEntryForm = class OxChecklistEntryForm extends LitElement {
|
|
|
50
50
|
let nameColspan = 1;
|
|
51
51
|
nameColspan += groupItems.length > 0 ? 1 : 0;
|
|
52
52
|
nameColspan += groupItems.some(i => i.subgroup) ? 1 : 0;
|
|
53
|
+
const isDescEmpty = dataItems.every(i => !i.description);
|
|
54
|
+
const options = { isDescEmpty };
|
|
53
55
|
return html `
|
|
54
56
|
<form class="checklist" @change=${this.onChange}>
|
|
55
57
|
<table>
|
|
56
58
|
<thead>
|
|
57
59
|
<tr>
|
|
58
60
|
<th colspan=${nameColspan} item>${i18next.t('field.item')}</th>
|
|
59
|
-
|
|
61
|
+
${isDescEmpty ? html `` : html `<th desc>${i18next.t('field.description')}</th>`}
|
|
60
62
|
<th value>${i18next.t('field.value')}</th>
|
|
61
63
|
</tr>
|
|
62
64
|
</thead>
|
|
63
65
|
<tbody>
|
|
64
|
-
${this.buildGroupInputs(groupItems, nameColspan
|
|
66
|
+
${this.buildGroupInputs(groupItems, nameColspan, options)}
|
|
67
|
+
${this.buildNonGroupInputs(nonGroupItems, nameColspan, options)}
|
|
65
68
|
</tbody>
|
|
66
69
|
</table>
|
|
67
70
|
</form>
|
|
68
71
|
`;
|
|
69
72
|
}
|
|
70
|
-
buildGroupInputs(items, nameColspan) {
|
|
73
|
+
buildGroupInputs(items, nameColspan, options) {
|
|
71
74
|
let isSubgroupExist = items.some(i => i.subgroup);
|
|
72
75
|
let renderedGroups = [];
|
|
76
|
+
const { isDescEmpty } = options;
|
|
73
77
|
return html `
|
|
74
78
|
${items.map(item => {
|
|
75
79
|
var _a, _b;
|
|
@@ -82,14 +86,14 @@ let OxChecklistEntryForm = class OxChecklistEntryForm extends LitElement {
|
|
|
82
86
|
}
|
|
83
87
|
let subgroupTd = null;
|
|
84
88
|
if (subgroup && !this.isGroupRendered(renderedGroups, group, subgroup)) {
|
|
85
|
-
subgroupTd = html `<td rowspan="${this.groupItemNums(items, group, subgroup)}">${subgroup}</td>`;
|
|
89
|
+
subgroupTd = html `<td subgroup rowspan="${this.groupItemNums(items, group, subgroup)}">${subgroup}</td>`;
|
|
86
90
|
renderedGroups.push({ group, subgroup });
|
|
87
91
|
}
|
|
88
92
|
return html `
|
|
89
93
|
<tr>
|
|
90
94
|
${groupTd} ${subgroupTd}
|
|
91
95
|
<td colspan=${isSubgroupExist && !subgroup ? 2 : 1}>${name}</td>
|
|
92
|
-
|
|
96
|
+
${isDescEmpty ? html `` : html `<td desc>${description}</td>`}
|
|
93
97
|
<td>
|
|
94
98
|
<div elements>
|
|
95
99
|
${Array.from({ length: quota || 1 }, (_, idx) => this.createInputElement(type, tag, Array.isArray(value) ? value[idx] : idx === 0 ? value : undefined, options, idx))}
|
|
@@ -100,7 +104,8 @@ let OxChecklistEntryForm = class OxChecklistEntryForm extends LitElement {
|
|
|
100
104
|
})}
|
|
101
105
|
`;
|
|
102
106
|
}
|
|
103
|
-
buildNonGroupInputs(items, nameColspan) {
|
|
107
|
+
buildNonGroupInputs(items, nameColspan, options) {
|
|
108
|
+
const { isDescEmpty } = options;
|
|
104
109
|
return html `
|
|
105
110
|
${items.map(item => {
|
|
106
111
|
var _a, _b;
|
|
@@ -109,7 +114,7 @@ let OxChecklistEntryForm = class OxChecklistEntryForm extends LitElement {
|
|
|
109
114
|
return html `
|
|
110
115
|
<tr>
|
|
111
116
|
<td name colspan=${nameColspan}>${name}</td>
|
|
112
|
-
|
|
117
|
+
${isDescEmpty ? html `` : html `<td>${description}</td>`}
|
|
113
118
|
<td>
|
|
114
119
|
<div element>
|
|
115
120
|
${Array.from({ length: quota || 1 }, (_, idx) => this.createInputElement(type, tag, Array.isArray(value) ? value[idx] : idx === 0 ? value : undefined, options, idx))}
|
|
@@ -280,6 +285,27 @@ OxChecklistEntryForm.styles = [
|
|
|
280
285
|
font: var(--input-field-font);
|
|
281
286
|
}
|
|
282
287
|
}
|
|
288
|
+
|
|
289
|
+
@media (max-width: 768px) {
|
|
290
|
+
td {
|
|
291
|
+
min-width: 28px;
|
|
292
|
+
|
|
293
|
+
div[element],
|
|
294
|
+
div[elements] {
|
|
295
|
+
display: inline-block;
|
|
296
|
+
}
|
|
297
|
+
|
|
298
|
+
div[element] {
|
|
299
|
+
input,
|
|
300
|
+
select {
|
|
301
|
+
width: 100%;
|
|
302
|
+
}
|
|
303
|
+
}
|
|
304
|
+
}
|
|
305
|
+
td[desc] {
|
|
306
|
+
min-width: 60px;
|
|
307
|
+
}
|
|
308
|
+
}
|
|
283
309
|
`
|
|
284
310
|
];
|
|
285
311
|
__decorate([
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ox-checklist-entry-form.js","sourceRoot":"","sources":["../../src/ox-checklist-entry-form.ts"],"names":[],"mappings":"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","sourcesContent":["import '@material/web/icon/icon.js'\nimport '@operato/context/ox-context-page-toolbar.js'\nimport '@operato/board/ox-board-viewer.js'\n\nimport gql from 'graphql-tag'\nimport { css, html, LitElement } from 'lit'\nimport { customElement, property, query, state } from 'lit/decorators.js'\n\nimport { DataItem, DataSample, DataSet } from './types'\nimport { client } from '@operato/graphql'\nimport { i18next, localize } from '@operato/i18n'\nimport { PageView } from '@operato/shell'\nimport { ScrollbarStyles } from '@operato/styles'\n\n@customElement('ox-checklist-entry-form')\nexport class OxChecklistEntryForm extends LitElement {\n static styles = [\n ScrollbarStyles,\n css`\n :host {\n display: flex;\n flex-direction: column;\n\n --signature-min-width: 100px;\n --signature-min-height: 60px;\n overflow: auto;\n }\n\n form {\n flex: 1;\n\n display: flex;\n flex-direction: column;\n }\n h2 {\n margin: var(--title-margin);\n font: var(--title-font);\n color: var(--title-text-color);\n text-transform: capitalize;\n }\n table {\n border-collapse: collapse;\n margin-bottom: var(--spacing-medium);\n }\n th {\n padding: var(--th-padding);\n border-top: var(--th-border-top);\n border-bottom: var(--td-border-bottom);\n text-transform: var(--th-text-transform);\n font: var(--th-font);\n color: var(--th-color);\n text-align: left;\n white-space: nowrap;\n }\n th[item] {\n min-width: 100px;\n }\n th[value] {\n min-width: 100px;\n }\n thead tr {\n background-color: var(--md-sys-color-primary-container);\n }\n tbody tr {\n background-color: var(--md-sys-color-background);\n }\n tbody tr:hover {\n background-color: var(--tr-background-hover-color);\n }\n tr[ooc],\n tr[oos] {\n background-color: #fefbdf;\n }\n td {\n border: var(--td-border-line);\n padding: var(--td-padding);\n font: var(--td-font);\n color: var(--td-color);\n }\n td[name] {\n font-weight: bold;\n }\n td md-icon {\n color: var(--md-sys-color-error);\n }\n div[element] {\n grid-area: inputs;\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n gap: 10px;\n padding-right: var(--padding-default);\n\n * {\n flex: 1;\n }\n\n input,\n select {\n border: var(--input-field-border);\n border-radius: var(--input-field-border-radius);\n padding: var(--input-field-padding);\n font: var(--input-field-font);\n }\n }\n `\n ]\n\n get context() {\n return {\n title: i18next.t('title.checklist entry page'),\n help: 'dataset/checklist-entry-page',\n toolbar: false\n }\n }\n\n @property({ type: Object }) dataSet?: DataSet\n @property({ type: Object }) value?: { [tag: string]: any }\n\n render() {\n return html` ${this.buildInputs()} `\n }\n\n private onChange = (e: Event) => {\n this.value = this.buildValue()\n\n this.dispatchEvent(\n new CustomEvent('change', {\n bubbles: true,\n composed: true,\n detail: this.value\n })\n )\n }\n\n private buildValue(): { [tag: string]: any } {\n return this.extractValuesFromInputs()\n }\n\n private extractValuesFromInputs(): { [tag: string]: any } {\n return (this.dataSet?.dataItems || []).reduce(\n (values, dataItem) => {\n const { tag, type } = dataItem\n const editors = Array.from(this.renderRoot.querySelectorAll(`[name=${tag}]`) as NodeListOf<HTMLInputElement>)\n\n if (editors.length > 0) {\n values[tag] = editors.map(editor => (type === 'boolean' ? editor.checked : editor.value))\n }\n\n return values\n },\n {} as { [tag: string]: any }\n )\n }\n\n buildInputs() {\n const dataItems = this.dataSet?.dataItems || []\n const groupItems = dataItems?.filter(i => i.group)\n const nonGroupItems = dataItems?.filter(i => !i.group)\n\n let nameColspan = 1\n nameColspan += groupItems.length > 0 ? 1 : 0\n nameColspan += groupItems.some(i => i.subgroup) ? 1 : 0\n\n return html`\n <form class=\"checklist\" @change=${this.onChange}>\n <table>\n <thead>\n <tr>\n <th colspan=${nameColspan} item>${i18next.t('field.item')}</th>\n <th>${i18next.t('field.description')}</th>\n <th value>${i18next.t('field.value')}</th>\n </tr>\n </thead>\n <tbody>\n ${this.buildGroupInputs(groupItems, nameColspan)} ${this.buildNonGroupInputs(nonGroupItems, nameColspan)}\n </tbody>\n </table>\n </form>\n `\n }\n\n buildGroupInputs(items: DataItem[], nameColspan: number) {\n let isSubgroupExist = items.some(i => i.subgroup)\n let renderedGroups: { group: string; subgroup?: string | undefined }[] = []\n\n return html`\n ${items.map(item => {\n const { name, description, tag, type, quota = 1, options = {}, unit, group, subgroup } = item\n const value = this.value?.[tag] === undefined ? [] : this.value?.[tag]\n\n let groupTd = null\n if (!this.isGroupRendered(renderedGroups, group)) {\n groupTd = html`<td rowspan=\"${this.groupItemNums(items, group)}\">${group}</td>`\n renderedGroups.push({ group })\n }\n\n let subgroupTd = null\n if (subgroup && !this.isGroupRendered(renderedGroups, group, subgroup)) {\n subgroupTd = html`<td rowspan=\"${this.groupItemNums(items, group, subgroup)}\">${subgroup}</td>`\n renderedGroups.push({ group, subgroup })\n }\n\n return html`\n <tr>\n ${groupTd} ${subgroupTd}\n <td colspan=${isSubgroupExist && !subgroup ? 2 : 1}>${name}</td>\n <td>${description}</td>\n <td>\n <div elements>\n ${Array.from({ length: quota || 1 }, (_, idx) =>\n this.createInputElement(\n type,\n tag,\n Array.isArray(value) ? value[idx] : idx === 0 ? value : undefined,\n options,\n idx\n )\n )}\n </div>\n </td>\n </tr>\n `\n })}\n `\n }\n\n buildNonGroupInputs(items: DataItem[], nameColspan: number) {\n return html`\n ${items.map(item => {\n const { name, description, tag, type, quota = 1, options = {}, unit } = item\n const value = this.value?.[tag] === undefined ? [] : this.value?.[tag]\n\n return html`\n <tr>\n <td name colspan=${nameColspan}>${name}</td>\n <td>${description}</td>\n <td>\n <div element>\n ${Array.from({ length: quota || 1 }, (_, idx) =>\n this.createInputElement(\n type,\n tag,\n Array.isArray(value) ? value[idx] : idx === 0 ? value : undefined,\n options,\n idx\n )\n )}\n </div>\n </td>\n </tr>\n `\n })}\n `\n }\n\n isGroupRendered(renderedGroups: { group: string; subgroup?: string }[], group: string, subgroup?: string) {\n if (subgroup) {\n return renderedGroups.some(groupInfo => groupInfo.group === group && groupInfo.subgroup === subgroup)\n } else {\n return renderedGroups.some(groupInfo => groupInfo.group === group)\n }\n }\n\n groupItemNums(items: DataItem[], group: string, subgroup?: string) {\n let nums = 0\n\n if (subgroup) {\n items.forEach(i => {\n if (i.group === group && i.subgroup === subgroup) {\n nums += 1\n }\n })\n } else {\n items.forEach(i => {\n if (i.group === group) {\n nums += 1\n }\n })\n }\n\n return nums\n }\n\n createInputElement(type: string, tag: string, value: any, options: any, idx: number) {\n switch (type) {\n case 'select':\n return html` <select .name=${tag}>\n <option value=\"\"></option>\n ${(options.options || []).map(\n (option: any) =>\n html`<option value=${option.value} ?selected=${option.value === value}>${option.text}</option>`\n )}\n </select>`\n\n case 'radio':\n return html`<div\n @change=${(e: Event) => {\n const div = e.currentTarget as HTMLElement\n const inputHidden = div.querySelector(`input[name=\"${tag}\"]`) as HTMLInputElement\n inputHidden.value = (e.target as HTMLInputElement).value\n }}\n >\n <input type=\"hidden\" name=${tag} />\n\n ${(options.options || []).map(\n (option: any) =>\n html`<label>\n <input\n type=\"radio\"\n name=${'$' + tag + '-' + idx}\n .value=${option.value}\n ?checked=${option.value === value}\n />\n ${option.text}\n </label>`\n )}\n </div>`\n\n case 'boolean':\n return html` <input type=\"checkbox\" name=${tag} .checked=${value} />`\n\n case 'number':\n return html` <input type=\"number\" name=${tag} value=${value} />`\n\n case 'date':\n return html` <input type=\"date\" name=${tag} value=${value} />`\n\n case 'datetime':\n return html` <input type=\"datetime-local\" name=${tag} value=${value} />`\n\n case 'file':\n return html`<ox-input-file name=${tag} multiple .value=${value}></ox-input-file>`\n\n case 'signature':\n return html`<ox-input-signature name=${tag} value=${value}></ox-input-signature>`\n\n case 'string':\n default:\n return html` <input type=\"text\" name=${tag} value=${value || ''} />`\n }\n }\n}\n"]}
|
|
1
|
+
{"version":3,"file":"ox-checklist-entry-form.js","sourceRoot":"","sources":["../../src/ox-checklist-entry-form.ts"],"names":[],"mappings":";AAAA,OAAO,4BAA4B,CAAA;AACnC,OAAO,6CAA6C,CAAA;AACpD,OAAO,mCAAmC,CAAA;AAG1C,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,KAAK,CAAA;AAC3C,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAgB,MAAM,mBAAmB,CAAA;AAIzE,OAAO,EAAE,OAAO,EAAY,MAAM,eAAe,CAAA;AAEjD,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAG1C,IAAM,oBAAoB,GAA1B,MAAM,oBAAqB,SAAQ,UAAU;IAA7C;;QAiIG,aAAQ,GAAG,CAAC,CAAQ,EAAE,EAAE;YAC9B,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,UAAU,EAAE,CAAA;YAE9B,IAAI,CAAC,aAAa,CAChB,IAAI,WAAW,CAAC,QAAQ,EAAE;gBACxB,OAAO,EAAE,IAAI;gBACb,QAAQ,EAAE,IAAI;gBACd,MAAM,EAAE,IAAI,CAAC,KAAK;aACnB,CAAC,CACH,CAAA;QACH,CAAC,CAAA;IAwNH,CAAC;IAjPC,IAAI,OAAO;QACT,OAAO;YACL,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,4BAA4B,CAAC;YAC9C,IAAI,EAAE,8BAA8B;YACpC,OAAO,EAAE,KAAK;SACf,CAAA;IACH,CAAC;IAKD,MAAM;QACJ,OAAO,IAAI,CAAA,IAAI,IAAI,CAAC,WAAW,EAAE,GAAG,CAAA;IACtC,CAAC;IAcO,UAAU;QAChB,OAAO,IAAI,CAAC,uBAAuB,EAAE,CAAA;IACvC,CAAC;IAEO,uBAAuB;;QAC7B,OAAO,CAAC,CAAA,MAAA,IAAI,CAAC,OAAO,0CAAE,SAAS,KAAI,EAAE,CAAC,CAAC,MAAM,CAC3C,CAAC,MAAM,EAAE,QAAQ,EAAE,EAAE;YACnB,MAAM,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,QAAQ,CAAA;YAC9B,MAAM,OAAO,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,SAAS,GAAG,GAAG,CAAiC,CAAC,CAAA;YAE7G,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACvB,MAAM,CAAC,GAAG,CAAC,GAAG,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAA;YAC3F,CAAC;YAED,OAAO,MAAM,CAAA;QACf,CAAC,EACD,EAA4B,CAC7B,CAAA;IACH,CAAC;IAED,WAAW;;QACT,MAAM,SAAS,GAAG,CAAA,MAAA,IAAI,CAAC,OAAO,0CAAE,SAAS,KAAI,EAAE,CAAA;QAC/C,MAAM,UAAU,GAAG,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAA;QAClD,MAAM,aAAa,GAAG,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAA;QAEtD,IAAI,WAAW,GAAG,CAAC,CAAA;QACnB,WAAW,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;QAC5C,WAAW,IAAI,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;QAEvD,MAAM,WAAW,GAAG,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAA;QACxD,MAAM,OAAO,GAAG,EAAE,WAAW,EAAE,CAAA;QAE/B,OAAO,IAAI,CAAA;wCACyB,IAAI,CAAC,QAAQ;;;;4BAIzB,WAAW,SAAS,OAAO,CAAC,CAAC,CAAC,YAAY,CAAC;gBACvD,WAAW,CAAC,CAAC,CAAC,IAAI,CAAA,EAAE,CAAC,CAAC,CAAC,IAAI,CAAA,YAAY,OAAO,CAAC,CAAC,CAAC,mBAAmB,CAAC,OAAO;0BAClE,OAAO,CAAC,CAAC,CAAC,aAAa,CAAC;;;;cAIpC,IAAI,CAAC,gBAAgB,CAAC,UAAU,EAAE,WAAW,EAAE,OAAO,CAAC;cACvD,IAAI,CAAC,mBAAmB,CAAC,aAAa,EAAE,WAAW,EAAE,OAAO,CAAC;;;;KAItE,CAAA;IACH,CAAC;IAED,gBAAgB,CAAC,KAAiB,EAAE,WAAmB,EAAE,OAAiC;QACxF,IAAI,eAAe,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAA;QACjD,IAAI,cAAc,GAAuD,EAAE,CAAA;QAC3E,MAAM,EAAE,WAAW,EAAE,GAAG,OAAO,CAAA;QAE/B,OAAO,IAAI,CAAA;QACP,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;;YACjB,MAAM,EAAE,IAAI,EAAE,WAAW,EAAE,GAAG,EAAE,IAAI,EAAE,KAAK,GAAG,CAAC,EAAE,OAAO,GAAG,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAA;YAC7F,MAAM,KAAK,GAAG,CAAA,MAAA,IAAI,CAAC,KAAK,0CAAG,GAAG,CAAC,MAAK,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAA,IAAI,CAAC,KAAK,0CAAG,GAAG,CAAC,CAAA;YAEtE,IAAI,OAAO,GAAG,IAAI,CAAA;YAClB,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,cAAc,EAAE,KAAK,CAAC,EAAE,CAAC;gBACjD,OAAO,GAAG,IAAI,CAAA,gBAAgB,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,KAAK,CAAC,KAAK,KAAK,OAAO,CAAA;gBAC/E,cAAc,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,CAAC,CAAA;YAChC,CAAC;YAED,IAAI,UAAU,GAAG,IAAI,CAAA;YACrB,IAAI,QAAQ,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,cAAc,EAAE,KAAK,EAAE,QAAQ,CAAC,EAAE,CAAC;gBACvE,UAAU,GAAG,IAAI,CAAA,yBAAyB,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,KAAK,EAAE,QAAQ,CAAC,KAAK,QAAQ,OAAO,CAAA;gBACxG,cAAc,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC,CAAA;YAC1C,CAAC;YAED,OAAO,IAAI,CAAA;;cAEL,OAAO,IAAI,UAAU;0BACT,eAAe,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI;cACxD,WAAW,CAAC,CAAC,CAAC,IAAI,CAAA,EAAE,CAAC,CAAC,CAAC,IAAI,CAAA,YAAY,WAAW,OAAO;;;kBAGrD,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,KAAK,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE,CAC9C,IAAI,CAAC,kBAAkB,CACrB,IAAI,EACJ,GAAG,EACH,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,EACjE,OAAO,EACP,GAAG,CACJ,CACF;;;;SAIR,CAAA;QACH,CAAC,CAAC;KACH,CAAA;IACH,CAAC;IAED,mBAAmB,CAAC,KAAiB,EAAE,WAAmB,EAAE,OAAiC;QAC3F,MAAM,EAAE,WAAW,EAAE,GAAG,OAAO,CAAA;QAE/B,OAAO,IAAI,CAAA;QACP,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;;YACjB,MAAM,EAAE,IAAI,EAAE,WAAW,EAAE,GAAG,EAAE,IAAI,EAAE,KAAK,GAAG,CAAC,EAAE,OAAO,GAAG,EAAE,EAAE,IAAI,EAAE,GAAG,IAAI,CAAA;YAC5E,MAAM,KAAK,GAAG,CAAA,MAAA,IAAI,CAAC,KAAK,0CAAG,GAAG,CAAC,MAAK,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAA,IAAI,CAAC,KAAK,0CAAG,GAAG,CAAC,CAAA;YAEtE,OAAO,IAAI,CAAA;;+BAEY,WAAW,IAAI,IAAI;cACpC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAA,EAAE,CAAC,CAAC,CAAC,IAAI,CAAA,OAAO,WAAW,OAAO;;;kBAGhD,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,KAAK,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE,CAC9C,IAAI,CAAC,kBAAkB,CACrB,IAAI,EACJ,GAAG,EACH,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,EACjE,OAAO,EACP,GAAG,CACJ,CACF;;;;SAIR,CAAA;QACH,CAAC,CAAC;KACH,CAAA;IACH,CAAC;IAED,eAAe,CAAC,cAAsD,EAAE,KAAa,EAAE,QAAiB;QACtG,IAAI,QAAQ,EAAE,CAAC;YACb,OAAO,cAAc,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,SAAS,CAAC,KAAK,KAAK,KAAK,IAAI,SAAS,CAAC,QAAQ,KAAK,QAAQ,CAAC,CAAA;QACvG,CAAC;aAAM,CAAC;YACN,OAAO,cAAc,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,SAAS,CAAC,KAAK,KAAK,KAAK,CAAC,CAAA;QACpE,CAAC;IACH,CAAC;IAED,aAAa,CAAC,KAAiB,EAAE,KAAa,EAAE,QAAiB;QAC/D,IAAI,IAAI,GAAG,CAAC,CAAA;QAEZ,IAAI,QAAQ,EAAE,CAAC;YACb,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;gBAChB,IAAI,CAAC,CAAC,KAAK,KAAK,KAAK,IAAI,CAAC,CAAC,QAAQ,KAAK,QAAQ,EAAE,CAAC;oBACjD,IAAI,IAAI,CAAC,CAAA;gBACX,CAAC;YACH,CAAC,CAAC,CAAA;QACJ,CAAC;aAAM,CAAC;YACN,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;gBAChB,IAAI,CAAC,CAAC,KAAK,KAAK,KAAK,EAAE,CAAC;oBACtB,IAAI,IAAI,CAAC,CAAA;gBACX,CAAC;YACH,CAAC,CAAC,CAAA;QACJ,CAAC;QAED,OAAO,IAAI,CAAA;IACb,CAAC;IAED,kBAAkB,CAAC,IAAY,EAAE,GAAW,EAAE,KAAU,EAAE,OAAY,EAAE,GAAW;QACjF,QAAQ,IAAI,EAAE,CAAC;YACb,KAAK,QAAQ;gBACX,OAAO,IAAI,CAAA,kBAAkB,GAAG;;YAE5B,CAAC,OAAO,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC,GAAG,CAC3B,CAAC,MAAW,EAAE,EAAE,CACd,IAAI,CAAA,iBAAiB,MAAM,CAAC,KAAK,cAAc,MAAM,CAAC,KAAK,KAAK,KAAK,IAAI,MAAM,CAAC,IAAI,WAAW,CAClG;kBACO,CAAA;YAEZ,KAAK,OAAO;gBACV,OAAO,IAAI,CAAA;oBACC,CAAC,CAAQ,EAAE,EAAE;oBACrB,MAAM,GAAG,GAAG,CAAC,CAAC,aAA4B,CAAA;oBAC1C,MAAM,WAAW,GAAG,GAAG,CAAC,aAAa,CAAC,eAAe,GAAG,IAAI,CAAqB,CAAA;oBACjF,WAAW,CAAC,KAAK,GAAI,CAAC,CAAC,MAA2B,CAAC,KAAK,CAAA;gBAC1D,CAAC;;sCAE2B,GAAG;;YAE7B,CAAC,OAAO,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC,GAAG,CAC3B,CAAC,MAAW,EAAE,EAAE,CACd,IAAI,CAAA;;;yBAGO,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG;2BACnB,MAAM,CAAC,KAAK;6BACV,MAAM,CAAC,KAAK,KAAK,KAAK;;kBAEjC,MAAM,CAAC,IAAI;uBACN,CACZ;eACI,CAAA;YAET,KAAK,SAAS;gBACZ,OAAO,IAAI,CAAA,gCAAgC,GAAG,aAAa,KAAK,KAAK,CAAA;YAEvE,KAAK,QAAQ;gBACX,OAAO,IAAI,CAAA,8BAA8B,GAAG,UAAU,KAAK,KAAK,CAAA;YAElE,KAAK,MAAM;gBACT,OAAO,IAAI,CAAA,4BAA4B,GAAG,UAAU,KAAK,KAAK,CAAA;YAEhE,KAAK,UAAU;gBACb,OAAO,IAAI,CAAA,sCAAsC,GAAG,UAAU,KAAK,KAAK,CAAA;YAE1E,KAAK,MAAM;gBACT,OAAO,IAAI,CAAA,uBAAuB,GAAG,oBAAoB,KAAK,mBAAmB,CAAA;YAEnF,KAAK,WAAW;gBACd,OAAO,IAAI,CAAA,4BAA4B,GAAG,UAAU,KAAK,wBAAwB,CAAA;YAEnF,KAAK,QAAQ,CAAC;YACd;gBACE,OAAO,IAAI,CAAA,4BAA4B,GAAG,UAAU,KAAK,IAAI,EAAE,KAAK,CAAA;QACxE,CAAC;IACH,CAAC;;AAjWM,2BAAM,GAAG;IACd,eAAe;IACf,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KA4GF;CACF,AA/GY,CA+GZ;AAU2B;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;qDAAkB;AACjB;IAA3B,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;mDAA+B;AA3H/C,oBAAoB;IADhC,aAAa,CAAC,yBAAyB,CAAC;GAC5B,oBAAoB,CAmWhC","sourcesContent":["import '@material/web/icon/icon.js'\nimport '@operato/context/ox-context-page-toolbar.js'\nimport '@operato/board/ox-board-viewer.js'\n\nimport gql from 'graphql-tag'\nimport { css, html, LitElement } from 'lit'\nimport { customElement, property, query, state } from 'lit/decorators.js'\n\nimport { DataItem, DataSample, DataSet } from './types'\nimport { client } from '@operato/graphql'\nimport { i18next, localize } from '@operato/i18n'\nimport { PageView } from '@operato/shell'\nimport { ScrollbarStyles } from '@operato/styles'\n\n@customElement('ox-checklist-entry-form')\nexport class OxChecklistEntryForm extends LitElement {\n static styles = [\n ScrollbarStyles,\n css`\n :host {\n display: flex;\n flex-direction: column;\n\n --signature-min-width: 100px;\n --signature-min-height: 60px;\n overflow: auto;\n }\n\n form {\n flex: 1;\n\n display: flex;\n flex-direction: column;\n }\n h2 {\n margin: var(--title-margin);\n font: var(--title-font);\n color: var(--title-text-color);\n text-transform: capitalize;\n }\n table {\n border-collapse: collapse;\n margin-bottom: var(--spacing-medium);\n }\n th {\n padding: var(--th-padding);\n border-top: var(--th-border-top);\n border-bottom: var(--td-border-bottom);\n text-transform: var(--th-text-transform);\n font: var(--th-font);\n color: var(--th-color);\n text-align: left;\n white-space: nowrap;\n }\n th[item] {\n min-width: 100px;\n }\n th[value] {\n min-width: 100px;\n }\n thead tr {\n background-color: var(--md-sys-color-primary-container);\n }\n tbody tr {\n background-color: var(--md-sys-color-background);\n }\n tbody tr:hover {\n background-color: var(--tr-background-hover-color);\n }\n tr[ooc],\n tr[oos] {\n background-color: #fefbdf;\n }\n td {\n border: var(--td-border-line);\n padding: var(--td-padding);\n font: var(--td-font);\n color: var(--td-color);\n }\n td[name] {\n font-weight: bold;\n }\n td md-icon {\n color: var(--md-sys-color-error);\n }\n div[element] {\n grid-area: inputs;\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n gap: 10px;\n padding-right: var(--padding-default);\n\n * {\n flex: 1;\n }\n\n input,\n select {\n border: var(--input-field-border);\n border-radius: var(--input-field-border-radius);\n padding: var(--input-field-padding);\n font: var(--input-field-font);\n }\n }\n\n @media (max-width: 768px) {\n td {\n min-width: 28px;\n\n div[element],\n div[elements] {\n display: inline-block;\n }\n\n div[element] {\n input,\n select {\n width: 100%;\n }\n }\n }\n td[desc] {\n min-width: 60px;\n }\n }\n `\n ]\n\n get context() {\n return {\n title: i18next.t('title.checklist entry page'),\n help: 'dataset/checklist-entry-page',\n toolbar: false\n }\n }\n\n @property({ type: Object }) dataSet?: DataSet\n @property({ type: Object }) value?: { [tag: string]: any }\n\n render() {\n return html` ${this.buildInputs()} `\n }\n\n private onChange = (e: Event) => {\n this.value = this.buildValue()\n\n this.dispatchEvent(\n new CustomEvent('change', {\n bubbles: true,\n composed: true,\n detail: this.value\n })\n )\n }\n\n private buildValue(): { [tag: string]: any } {\n return this.extractValuesFromInputs()\n }\n\n private extractValuesFromInputs(): { [tag: string]: any } {\n return (this.dataSet?.dataItems || []).reduce(\n (values, dataItem) => {\n const { tag, type } = dataItem\n const editors = Array.from(this.renderRoot.querySelectorAll(`[name=${tag}]`) as NodeListOf<HTMLInputElement>)\n\n if (editors.length > 0) {\n values[tag] = editors.map(editor => (type === 'boolean' ? editor.checked : editor.value))\n }\n\n return values\n },\n {} as { [tag: string]: any }\n )\n }\n\n buildInputs() {\n const dataItems = this.dataSet?.dataItems || []\n const groupItems = dataItems?.filter(i => i.group)\n const nonGroupItems = dataItems?.filter(i => !i.group)\n\n let nameColspan = 1\n nameColspan += groupItems.length > 0 ? 1 : 0\n nameColspan += groupItems.some(i => i.subgroup) ? 1 : 0\n\n const isDescEmpty = dataItems.every(i => !i.description)\n const options = { isDescEmpty }\n\n return html`\n <form class=\"checklist\" @change=${this.onChange}>\n <table>\n <thead>\n <tr>\n <th colspan=${nameColspan} item>${i18next.t('field.item')}</th>\n ${isDescEmpty ? html`` : html`<th desc>${i18next.t('field.description')}</th>`}\n <th value>${i18next.t('field.value')}</th>\n </tr>\n </thead>\n <tbody>\n ${this.buildGroupInputs(groupItems, nameColspan, options)}\n ${this.buildNonGroupInputs(nonGroupItems, nameColspan, options)}\n </tbody>\n </table>\n </form>\n `\n }\n\n buildGroupInputs(items: DataItem[], nameColspan: number, options: { isDescEmpty: boolean }) {\n let isSubgroupExist = items.some(i => i.subgroup)\n let renderedGroups: { group: string; subgroup?: string | undefined }[] = []\n const { isDescEmpty } = options\n\n return html`\n ${items.map(item => {\n const { name, description, tag, type, quota = 1, options = {}, unit, group, subgroup } = item\n const value = this.value?.[tag] === undefined ? [] : this.value?.[tag]\n\n let groupTd = null\n if (!this.isGroupRendered(renderedGroups, group)) {\n groupTd = html`<td rowspan=\"${this.groupItemNums(items, group)}\">${group}</td>`\n renderedGroups.push({ group })\n }\n\n let subgroupTd = null\n if (subgroup && !this.isGroupRendered(renderedGroups, group, subgroup)) {\n subgroupTd = html`<td subgroup rowspan=\"${this.groupItemNums(items, group, subgroup)}\">${subgroup}</td>`\n renderedGroups.push({ group, subgroup })\n }\n\n return html`\n <tr>\n ${groupTd} ${subgroupTd}\n <td colspan=${isSubgroupExist && !subgroup ? 2 : 1}>${name}</td>\n ${isDescEmpty ? html`` : html`<td desc>${description}</td>`}\n <td>\n <div elements>\n ${Array.from({ length: quota || 1 }, (_, idx) =>\n this.createInputElement(\n type,\n tag,\n Array.isArray(value) ? value[idx] : idx === 0 ? value : undefined,\n options,\n idx\n )\n )}\n </div>\n </td>\n </tr>\n `\n })}\n `\n }\n\n buildNonGroupInputs(items: DataItem[], nameColspan: number, options: { isDescEmpty: boolean }) {\n const { isDescEmpty } = options\n\n return html`\n ${items.map(item => {\n const { name, description, tag, type, quota = 1, options = {}, unit } = item\n const value = this.value?.[tag] === undefined ? [] : this.value?.[tag]\n\n return html`\n <tr>\n <td name colspan=${nameColspan}>${name}</td>\n ${isDescEmpty ? html`` : html`<td>${description}</td>`}\n <td>\n <div element>\n ${Array.from({ length: quota || 1 }, (_, idx) =>\n this.createInputElement(\n type,\n tag,\n Array.isArray(value) ? value[idx] : idx === 0 ? value : undefined,\n options,\n idx\n )\n )}\n </div>\n </td>\n </tr>\n `\n })}\n `\n }\n\n isGroupRendered(renderedGroups: { group: string; subgroup?: string }[], group: string, subgroup?: string) {\n if (subgroup) {\n return renderedGroups.some(groupInfo => groupInfo.group === group && groupInfo.subgroup === subgroup)\n } else {\n return renderedGroups.some(groupInfo => groupInfo.group === group)\n }\n }\n\n groupItemNums(items: DataItem[], group: string, subgroup?: string) {\n let nums = 0\n\n if (subgroup) {\n items.forEach(i => {\n if (i.group === group && i.subgroup === subgroup) {\n nums += 1\n }\n })\n } else {\n items.forEach(i => {\n if (i.group === group) {\n nums += 1\n }\n })\n }\n\n return nums\n }\n\n createInputElement(type: string, tag: string, value: any, options: any, idx: number) {\n switch (type) {\n case 'select':\n return html` <select .name=${tag}>\n <option value=\"\"></option>\n ${(options.options || []).map(\n (option: any) =>\n html`<option value=${option.value} ?selected=${option.value === value}>${option.text}</option>`\n )}\n </select>`\n\n case 'radio':\n return html`<div\n @change=${(e: Event) => {\n const div = e.currentTarget as HTMLElement\n const inputHidden = div.querySelector(`input[name=\"${tag}\"]`) as HTMLInputElement\n inputHidden.value = (e.target as HTMLInputElement).value\n }}\n >\n <input type=\"hidden\" name=${tag} />\n\n ${(options.options || []).map(\n (option: any) =>\n html`<label>\n <input\n type=\"radio\"\n name=${'$' + tag + '-' + idx}\n .value=${option.value}\n ?checked=${option.value === value}\n />\n ${option.text}\n </label>`\n )}\n </div>`\n\n case 'boolean':\n return html` <input type=\"checkbox\" name=${tag} .checked=${value} />`\n\n case 'number':\n return html` <input type=\"number\" name=${tag} value=${value} />`\n\n case 'date':\n return html` <input type=\"date\" name=${tag} value=${value} />`\n\n case 'datetime':\n return html` <input type=\"datetime-local\" name=${tag} value=${value} />`\n\n case 'file':\n return html`<ox-input-file name=${tag} multiple .value=${value}></ox-input-file>`\n\n case 'signature':\n return html`<ox-input-signature name=${tag} value=${value}></ox-input-signature>`\n\n case 'string':\n default:\n return html` <input type=\"text\" name=${tag} value=${value || ''} />`\n }\n }\n}\n"]}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import '@operato/i18n';
|
|
2
|
+
import '../src/ox-checklist-entry-form.js';
|
|
3
|
+
import '../src/usecase/ccp/index.js';
|
|
4
|
+
import '@material/web/icon/icon.js';
|
|
5
|
+
import { TemplateResult } from 'lit';
|
|
6
|
+
declare const _default: {
|
|
7
|
+
title: string;
|
|
8
|
+
component: string;
|
|
9
|
+
argTypes: {};
|
|
10
|
+
};
|
|
11
|
+
export default _default;
|
|
12
|
+
interface Story<T> {
|
|
13
|
+
(args: T): TemplateResult;
|
|
14
|
+
args?: Partial<T>;
|
|
15
|
+
argTypes?: Record<string, unknown>;
|
|
16
|
+
}
|
|
17
|
+
interface ArgTypes {
|
|
18
|
+
}
|
|
19
|
+
export declare const Regular: Story<ArgTypes>;
|
|
@@ -0,0 +1,421 @@
|
|
|
1
|
+
import '@operato/i18n';
|
|
2
|
+
import '../src/ox-checklist-entry-form.js';
|
|
3
|
+
import '../src/usecase/ccp/index.js'; /* register usecase CCP */
|
|
4
|
+
import '@material/web/icon/icon.js';
|
|
5
|
+
import { html } from 'lit';
|
|
6
|
+
export default {
|
|
7
|
+
title: 'ox-checklist-entry-form',
|
|
8
|
+
component: 'ox-checklist-entry-form',
|
|
9
|
+
argTypes: {}
|
|
10
|
+
};
|
|
11
|
+
const dataSet = {
|
|
12
|
+
name: '일반위생관리 및 공정점검표 (월간) - 매월 셋째주',
|
|
13
|
+
description: '일반위생관리 및 공정점검표 (통합)',
|
|
14
|
+
useCase: 'CCP',
|
|
15
|
+
dataItems: [
|
|
16
|
+
{
|
|
17
|
+
name: '작업장 전체 청소 상태는 양호한가?',
|
|
18
|
+
description: null,
|
|
19
|
+
active: true,
|
|
20
|
+
hidden: false,
|
|
21
|
+
tag: 'question_1',
|
|
22
|
+
group: '매월 (셋째주)',
|
|
23
|
+
subgroup: '청소',
|
|
24
|
+
type: 'radio',
|
|
25
|
+
unit: null,
|
|
26
|
+
options: {
|
|
27
|
+
options: [
|
|
28
|
+
{
|
|
29
|
+
text: '예',
|
|
30
|
+
value: 'Y'
|
|
31
|
+
},
|
|
32
|
+
{
|
|
33
|
+
text: '아니오',
|
|
34
|
+
value: 'N'
|
|
35
|
+
}
|
|
36
|
+
]
|
|
37
|
+
},
|
|
38
|
+
quota: null,
|
|
39
|
+
spec: {
|
|
40
|
+
CCP: {
|
|
41
|
+
criticalLimits: {
|
|
42
|
+
acceptables: ['Y']
|
|
43
|
+
},
|
|
44
|
+
targetLimits: {
|
|
45
|
+
acceptables: ['Y']
|
|
46
|
+
}
|
|
47
|
+
},
|
|
48
|
+
QC: {
|
|
49
|
+
passLimits: {
|
|
50
|
+
acceptables: ['Y']
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
},
|
|
54
|
+
stat: null,
|
|
55
|
+
agg: null
|
|
56
|
+
},
|
|
57
|
+
{
|
|
58
|
+
name: '종사자 위생교육을 실시하였는가?',
|
|
59
|
+
description: null,
|
|
60
|
+
active: true,
|
|
61
|
+
hidden: false,
|
|
62
|
+
tag: 'question_2',
|
|
63
|
+
group: '매월 (셋째주)',
|
|
64
|
+
subgroup: '교육',
|
|
65
|
+
type: 'radio',
|
|
66
|
+
unit: null,
|
|
67
|
+
options: {
|
|
68
|
+
options: [
|
|
69
|
+
{
|
|
70
|
+
text: '예',
|
|
71
|
+
value: 'Y'
|
|
72
|
+
},
|
|
73
|
+
{
|
|
74
|
+
text: '아니오',
|
|
75
|
+
value: 'N'
|
|
76
|
+
}
|
|
77
|
+
]
|
|
78
|
+
},
|
|
79
|
+
quota: null,
|
|
80
|
+
spec: {
|
|
81
|
+
CCP: {
|
|
82
|
+
criticalLimits: {
|
|
83
|
+
acceptables: ['Y']
|
|
84
|
+
},
|
|
85
|
+
targetLimits: {
|
|
86
|
+
acceptables: ['Y']
|
|
87
|
+
}
|
|
88
|
+
},
|
|
89
|
+
QC: {
|
|
90
|
+
passLimits: {
|
|
91
|
+
acceptables: ['Y']
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
},
|
|
95
|
+
stat: null,
|
|
96
|
+
agg: null
|
|
97
|
+
},
|
|
98
|
+
{
|
|
99
|
+
name: '중요관리공정(CCP) 검증표를 작성하였는가?',
|
|
100
|
+
description: null,
|
|
101
|
+
active: true,
|
|
102
|
+
hidden: false,
|
|
103
|
+
tag: 'question_3',
|
|
104
|
+
group: '매월 (셋째주)',
|
|
105
|
+
subgroup: '검증',
|
|
106
|
+
type: 'radio',
|
|
107
|
+
unit: null,
|
|
108
|
+
options: {
|
|
109
|
+
options: [
|
|
110
|
+
{
|
|
111
|
+
text: '예',
|
|
112
|
+
value: 'Y'
|
|
113
|
+
},
|
|
114
|
+
{
|
|
115
|
+
text: '아니오',
|
|
116
|
+
value: 'N'
|
|
117
|
+
}
|
|
118
|
+
]
|
|
119
|
+
},
|
|
120
|
+
quota: null,
|
|
121
|
+
spec: {
|
|
122
|
+
CCP: {
|
|
123
|
+
criticalLimits: {
|
|
124
|
+
acceptables: ['Y']
|
|
125
|
+
},
|
|
126
|
+
targetLimits: {
|
|
127
|
+
acceptables: ['Y']
|
|
128
|
+
}
|
|
129
|
+
},
|
|
130
|
+
QC: {
|
|
131
|
+
passLimits: {
|
|
132
|
+
acceptables: ['Y']
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
},
|
|
136
|
+
stat: null,
|
|
137
|
+
agg: null
|
|
138
|
+
},
|
|
139
|
+
{
|
|
140
|
+
name: '특이사항',
|
|
141
|
+
description: null,
|
|
142
|
+
active: true,
|
|
143
|
+
hidden: false,
|
|
144
|
+
tag: 'etc_1',
|
|
145
|
+
group: null,
|
|
146
|
+
subgroup: null,
|
|
147
|
+
type: 'text',
|
|
148
|
+
unit: null,
|
|
149
|
+
options: null,
|
|
150
|
+
quota: null,
|
|
151
|
+
spec: null,
|
|
152
|
+
stat: null,
|
|
153
|
+
agg: null
|
|
154
|
+
},
|
|
155
|
+
{
|
|
156
|
+
name: '개선조치 및 결과',
|
|
157
|
+
description: null,
|
|
158
|
+
active: true,
|
|
159
|
+
hidden: false,
|
|
160
|
+
tag: 'etc_2',
|
|
161
|
+
group: null,
|
|
162
|
+
subgroup: null,
|
|
163
|
+
type: 'text',
|
|
164
|
+
unit: null,
|
|
165
|
+
options: null,
|
|
166
|
+
quota: null,
|
|
167
|
+
spec: null,
|
|
168
|
+
stat: null,
|
|
169
|
+
agg: null
|
|
170
|
+
}
|
|
171
|
+
],
|
|
172
|
+
__seq__: 16,
|
|
173
|
+
__origin__: {
|
|
174
|
+
id: '6b1da009-596d-486d-a1d2-a67024155873',
|
|
175
|
+
name: '일반위생관리 및 공정점검표 (월간) - 매월 셋째주',
|
|
176
|
+
description: '일반위생관리 및 공정점검표 (통합)',
|
|
177
|
+
tag: null,
|
|
178
|
+
partitionKeys: null,
|
|
179
|
+
active: true,
|
|
180
|
+
type: 'manual',
|
|
181
|
+
useCase: 'CCP',
|
|
182
|
+
schedule: '0 0 8 15-21 * 1',
|
|
183
|
+
timezone: 'Asia/Seoul',
|
|
184
|
+
scheduleId: null,
|
|
185
|
+
summaryPeriod: null,
|
|
186
|
+
summaryScheduleId: null,
|
|
187
|
+
timeLimit: 604800,
|
|
188
|
+
dataKeySet: {
|
|
189
|
+
id: 'ac5aef77-de5c-4c46-8a75-1b279d9404ec',
|
|
190
|
+
name: 'ha-data-set'
|
|
191
|
+
},
|
|
192
|
+
entryRole: {
|
|
193
|
+
id: 'aea75cfa-e270-41dc-9007-b62fec7995f2',
|
|
194
|
+
name: '현장 관리자'
|
|
195
|
+
},
|
|
196
|
+
supervisoryRole: {
|
|
197
|
+
id: '48583404-a01e-449e-96e7-678ee52a768a',
|
|
198
|
+
name: '대표'
|
|
199
|
+
},
|
|
200
|
+
resolverRole: {
|
|
201
|
+
id: 'aea75cfa-e270-41dc-9007-b62fec7995f2',
|
|
202
|
+
name: '현장 관리자'
|
|
203
|
+
},
|
|
204
|
+
normalScenario: null,
|
|
205
|
+
outlierScenario: null,
|
|
206
|
+
reviewApprovalLine: [],
|
|
207
|
+
outlierApprovalLine: [
|
|
208
|
+
{
|
|
209
|
+
type: 'Employee',
|
|
210
|
+
value: null,
|
|
211
|
+
approver: {
|
|
212
|
+
id: 'b98ab916-a43f-4e50-9811-64f0d5eaa66d',
|
|
213
|
+
name: '해썹 결재자',
|
|
214
|
+
description: null,
|
|
215
|
+
controlNo: '99'
|
|
216
|
+
}
|
|
217
|
+
}
|
|
218
|
+
],
|
|
219
|
+
requiresReview: true,
|
|
220
|
+
entryType: 'checklist',
|
|
221
|
+
entryView: 'Checklist',
|
|
222
|
+
monitorType: 'checklist',
|
|
223
|
+
monitorView: 'Checklist',
|
|
224
|
+
reportType: null,
|
|
225
|
+
reportView: null,
|
|
226
|
+
reportTemplate: null,
|
|
227
|
+
updater: {
|
|
228
|
+
id: '4df009ae-a346-4966-9753-3539ad3c84e4',
|
|
229
|
+
name: 'Admin'
|
|
230
|
+
},
|
|
231
|
+
updatedAt: '2025-04-22T10:29:20.349Z',
|
|
232
|
+
dataItems: [
|
|
233
|
+
{
|
|
234
|
+
name: '작업장 전체 청소 상태는 양호한가?',
|
|
235
|
+
description: null,
|
|
236
|
+
active: true,
|
|
237
|
+
hidden: false,
|
|
238
|
+
tag: 'question_1',
|
|
239
|
+
group: '매월 (셋째주)',
|
|
240
|
+
subgroup: '청소',
|
|
241
|
+
type: 'radio',
|
|
242
|
+
unit: null,
|
|
243
|
+
options: {
|
|
244
|
+
options: [
|
|
245
|
+
{
|
|
246
|
+
text: '예',
|
|
247
|
+
value: 'Y'
|
|
248
|
+
},
|
|
249
|
+
{
|
|
250
|
+
text: '아니오',
|
|
251
|
+
value: 'N'
|
|
252
|
+
}
|
|
253
|
+
]
|
|
254
|
+
},
|
|
255
|
+
quota: null,
|
|
256
|
+
spec: {
|
|
257
|
+
CCP: {
|
|
258
|
+
criticalLimits: {
|
|
259
|
+
acceptables: ['Y']
|
|
260
|
+
},
|
|
261
|
+
targetLimits: {
|
|
262
|
+
acceptables: ['Y']
|
|
263
|
+
}
|
|
264
|
+
},
|
|
265
|
+
QC: {
|
|
266
|
+
passLimits: {
|
|
267
|
+
acceptables: ['Y']
|
|
268
|
+
}
|
|
269
|
+
}
|
|
270
|
+
},
|
|
271
|
+
stat: null,
|
|
272
|
+
agg: null
|
|
273
|
+
},
|
|
274
|
+
{
|
|
275
|
+
name: '종사자 위생교육을 실시하였는가?',
|
|
276
|
+
description: null,
|
|
277
|
+
active: true,
|
|
278
|
+
hidden: false,
|
|
279
|
+
tag: 'question_2',
|
|
280
|
+
group: '매월 (셋째주)',
|
|
281
|
+
subgroup: '교육',
|
|
282
|
+
type: 'radio',
|
|
283
|
+
unit: null,
|
|
284
|
+
options: {
|
|
285
|
+
options: [
|
|
286
|
+
{
|
|
287
|
+
text: '예',
|
|
288
|
+
value: 'Y'
|
|
289
|
+
},
|
|
290
|
+
{
|
|
291
|
+
text: '아니오',
|
|
292
|
+
value: 'N'
|
|
293
|
+
}
|
|
294
|
+
]
|
|
295
|
+
},
|
|
296
|
+
quota: null,
|
|
297
|
+
spec: {
|
|
298
|
+
CCP: {
|
|
299
|
+
criticalLimits: {
|
|
300
|
+
acceptables: ['Y']
|
|
301
|
+
},
|
|
302
|
+
targetLimits: {
|
|
303
|
+
acceptables: ['Y']
|
|
304
|
+
}
|
|
305
|
+
},
|
|
306
|
+
QC: {
|
|
307
|
+
passLimits: {
|
|
308
|
+
acceptables: ['Y']
|
|
309
|
+
}
|
|
310
|
+
}
|
|
311
|
+
},
|
|
312
|
+
stat: null,
|
|
313
|
+
agg: null
|
|
314
|
+
},
|
|
315
|
+
{
|
|
316
|
+
name: '중요관리공정(CCP) 검증표를 작성하였는가?',
|
|
317
|
+
description: null,
|
|
318
|
+
active: true,
|
|
319
|
+
hidden: false,
|
|
320
|
+
tag: 'question_3',
|
|
321
|
+
group: '매월 (셋째주)',
|
|
322
|
+
subgroup: '검증',
|
|
323
|
+
type: 'radio',
|
|
324
|
+
unit: null,
|
|
325
|
+
options: {
|
|
326
|
+
options: [
|
|
327
|
+
{
|
|
328
|
+
text: '예',
|
|
329
|
+
value: 'Y'
|
|
330
|
+
},
|
|
331
|
+
{
|
|
332
|
+
text: '아니오',
|
|
333
|
+
value: 'N'
|
|
334
|
+
}
|
|
335
|
+
]
|
|
336
|
+
},
|
|
337
|
+
quota: null,
|
|
338
|
+
spec: {
|
|
339
|
+
CCP: {
|
|
340
|
+
criticalLimits: {
|
|
341
|
+
acceptables: ['Y']
|
|
342
|
+
},
|
|
343
|
+
targetLimits: {
|
|
344
|
+
acceptables: ['Y']
|
|
345
|
+
}
|
|
346
|
+
},
|
|
347
|
+
QC: {
|
|
348
|
+
passLimits: {
|
|
349
|
+
acceptables: ['Y']
|
|
350
|
+
}
|
|
351
|
+
}
|
|
352
|
+
},
|
|
353
|
+
stat: null,
|
|
354
|
+
agg: null
|
|
355
|
+
},
|
|
356
|
+
{
|
|
357
|
+
name: '특이사항',
|
|
358
|
+
description: null,
|
|
359
|
+
active: true,
|
|
360
|
+
hidden: false,
|
|
361
|
+
tag: 'etc_1',
|
|
362
|
+
group: null,
|
|
363
|
+
subgroup: null,
|
|
364
|
+
type: 'text',
|
|
365
|
+
unit: null,
|
|
366
|
+
options: null,
|
|
367
|
+
quota: null,
|
|
368
|
+
spec: null,
|
|
369
|
+
stat: null,
|
|
370
|
+
agg: null
|
|
371
|
+
},
|
|
372
|
+
{
|
|
373
|
+
name: '개선조치 및 결과',
|
|
374
|
+
description: null,
|
|
375
|
+
active: true,
|
|
376
|
+
hidden: false,
|
|
377
|
+
tag: 'etc_2',
|
|
378
|
+
group: null,
|
|
379
|
+
subgroup: null,
|
|
380
|
+
type: 'text',
|
|
381
|
+
unit: null,
|
|
382
|
+
options: null,
|
|
383
|
+
quota: null,
|
|
384
|
+
spec: null,
|
|
385
|
+
stat: null,
|
|
386
|
+
agg: null
|
|
387
|
+
}
|
|
388
|
+
]
|
|
389
|
+
}
|
|
390
|
+
};
|
|
391
|
+
const Template = ({}) => html `
|
|
392
|
+
<link
|
|
393
|
+
href="https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL@20..48,100..700,0..1"
|
|
394
|
+
rel="stylesheet"
|
|
395
|
+
/>
|
|
396
|
+
<link
|
|
397
|
+
href="https://fonts.googleapis.com/css2?family=Material+Symbols+Rounded:opsz,wght,FILL@20..48,100..700,0..1"
|
|
398
|
+
rel="stylesheet"
|
|
399
|
+
/>
|
|
400
|
+
<link
|
|
401
|
+
href="https://fonts.googleapis.com/css2?family=Material+Symbols+Sharp:opsz,wght,FILL@20..48,100..700,0..1"
|
|
402
|
+
rel="stylesheet"
|
|
403
|
+
/>
|
|
404
|
+
|
|
405
|
+
<style>
|
|
406
|
+
body {
|
|
407
|
+
}
|
|
408
|
+
</style>
|
|
409
|
+
|
|
410
|
+
<link href="/themes/app-theme.css" rel="stylesheet" />
|
|
411
|
+
<link href="/themes/light.css" rel="stylesheet" />
|
|
412
|
+
<link href="/themes/dark.css" rel="stylesheet" />
|
|
413
|
+
<link href="/themes/spacing.css" rel="stylesheet" />
|
|
414
|
+
<link href="/themes/grist-theme.css" rel="stylesheet" />
|
|
415
|
+
<link href="/themes/form-theme.css" rel="stylesheet" />
|
|
416
|
+
|
|
417
|
+
<ox-checklist-entry-form .dataSet=${dataSet}></ox-checklist-entry-form>
|
|
418
|
+
`;
|
|
419
|
+
export const Regular = Template.bind({});
|
|
420
|
+
Regular.args = {};
|
|
421
|
+
//# sourceMappingURL=ox-checklist-entry-form-stories.js.map
|