@operato/input 1.0.0-alpha.11 → 1.0.0-alpha.12

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.
@@ -0,0 +1,298 @@
1
+ /**
2
+ * @license Copyright © HatioLab Inc. All rights reserved.
3
+ */
4
+ import { __decorate } from "tslib";
5
+ import './ox-input-color';
6
+ import { css, html } from 'lit';
7
+ import { customElement, property } from 'lit/decorators.js';
8
+ import { OxFormField } from './ox-form-field.js';
9
+ /**
10
+ range value editor element
11
+
12
+ Example:
13
+
14
+ <ox-input-value-ranges
15
+ .value=${range}
16
+ valuetype=${type}
17
+ </ox-input-value-ranges>
18
+ */
19
+ let OxInputValueRange = class OxInputValueRange extends OxFormField {
20
+ constructor() {
21
+ super(...arguments);
22
+ this.value = {};
23
+ this.valuetype = 'string';
24
+ this.rangetype = 'number';
25
+ this._changingNow = false;
26
+ }
27
+ static { this.styles = css `
28
+ :host {
29
+ display: flex;
30
+ flex-direction: column;
31
+ align-content: center;
32
+
33
+ width: 100%;
34
+ overflow: hidden;
35
+ border: 1px solid #ccc;
36
+ }
37
+
38
+ div {
39
+ display: flex;
40
+ flex-flow: row nowrap;
41
+ align-items: center;
42
+
43
+ border-bottom: 1px solid #c0c0c0;
44
+ }
45
+
46
+ div:last-child {
47
+ border-bottom: none;
48
+ }
49
+
50
+ div > * {
51
+ min-width: 0px;
52
+ margin: 2px;
53
+ padding: 0;
54
+ }
55
+
56
+ button {
57
+ width: 20px;
58
+ text-align: center;
59
+ }
60
+
61
+ input,
62
+ ox-input-color {
63
+ flex: 1;
64
+ }
65
+
66
+ ox-input-color {
67
+ --things-editor-color-input-color: {
68
+ margin: 2px;
69
+ }
70
+ --things-editor-color-input-span: {
71
+ width: 12px;
72
+ height: 12px;
73
+ }
74
+ }
75
+
76
+ [placeholder='value'] {
77
+ flex: 2;
78
+ }
79
+
80
+ div {
81
+ border-bottom: 1px solid #c0c0c0;
82
+ }
83
+
84
+ div:last-child {
85
+ border-bottom: none;
86
+ }
87
+
88
+ input[type='checkbox'] {
89
+ width: initial;
90
+ }
91
+ `; }
92
+ firstUpdated() {
93
+ this.renderRoot.addEventListener('change', this._onChange.bind(this));
94
+ }
95
+ render() {
96
+ return html `
97
+ ${this._toArray(this.value).map(item => html `
98
+ <div data-record>
99
+ <input type="text" data-from placeholder="<=" .value=${item.from} />
100
+ <input type="text" data-to placeholder="&gt;" .value=${item.to} />
101
+
102
+ ${this.valuetype == 'boolean'
103
+ ? html ` <input type="checkbox" data-value .checked=${item.value} data-value-type=${this.valuetype} /> `
104
+ : this.valuetype == 'color'
105
+ ? html ` <ox-input-color data-value .value=${item.value}> </ox-input-color> `
106
+ : html `
107
+ <input
108
+ type="text"
109
+ data-value
110
+ placeholder="value"
111
+ .value=${item.value}
112
+ data-value-type=${this.valuetype}
113
+ />
114
+ `} <button class="record-action" @click=${(e) => this._delete(e)} tabindex="-1">-</button>
115
+ </div>
116
+ `)}
117
+
118
+ <div data-record-new>
119
+ <input type="text" data-from placeholder="<=" value="" />
120
+ <input type="text" data-to placeholder="&gt;" value="" />
121
+
122
+ ${this.valuetype == 'boolean'
123
+ ? html ` <input type="checkbox" data-value data-value-type=${this.valuetype} /> `
124
+ : this.valuetype == 'color'
125
+ ? html ` <ox-input-color data-value value="" placeholder="value"> </ox-input-color> `
126
+ : html ` <input type="text" data-value placeholder="value" value="" data-value-type=${this.valuetype} /> `}
127
+ <button class="record-action" @click=${(e) => this._add()} tabindex="-1">+</button>
128
+ </div>
129
+
130
+ <div data-record>
131
+ <input type="text" data-from data-default="" disabled value="default" />
132
+ <input type="text" data-to placeholder="&gt;" value="" hidden />
133
+
134
+ ${this.valuetype == 'boolean'
135
+ ? html `
136
+ <input
137
+ type="checkbox"
138
+ data-value
139
+ .checked=${this.value && this.value.default}
140
+ data-value-type=${this.valuetype}
141
+ />
142
+ `
143
+ : this.valuetype == 'color'
144
+ ? html `
145
+ <ox-input-color data-value .value=${(this.value && this.value.default) || ''} placeholder="value">
146
+ </ox-input-color>
147
+ `
148
+ : html `
149
+ <input
150
+ type="text"
151
+ data-value
152
+ .value=${(this.value && this.value.default) || ''}
153
+ placeholder="value"
154
+ class="default-value"
155
+ data-value-type=${this.valuetype}
156
+ />
157
+ `} <button class="record-action" @click=${(e) => this._sort()}>&gt;</button>
158
+ </div>
159
+ `;
160
+ }
161
+ _defaultValue(type) {
162
+ switch (type || this.valuetype) {
163
+ case 'color':
164
+ return '#000000';
165
+ case 'boolean':
166
+ case 'checkbox':
167
+ return false;
168
+ default:
169
+ return '';
170
+ }
171
+ }
172
+ _onChange(e) {
173
+ if (this._changingNow) {
174
+ return;
175
+ }
176
+ this._changingNow = true;
177
+ const input = e.target;
178
+ var value = input.type === 'checkbox' ? Boolean(input.checked) : input.value;
179
+ const div = input.parentElement;
180
+ if (input.hasAttribute('data-value')) {
181
+ const dataList = div.querySelectorAll('[data-value]:not([hidden])');
182
+ for (var i = 0; i < dataList.length; i++) {
183
+ if (dataList[i] !== input) {
184
+ dataList[i].value = value;
185
+ }
186
+ }
187
+ }
188
+ if (div.hasAttribute('data-record')) {
189
+ this._build();
190
+ }
191
+ else if (div.hasAttribute('data-record-new') && input.hasAttribute('data-value')) {
192
+ this._add();
193
+ }
194
+ this._changingNow = false;
195
+ }
196
+ _build(includeNewRecord) {
197
+ if (includeNewRecord) {
198
+ var records = this.renderRoot.querySelectorAll('[data-record],[data-record-new]');
199
+ }
200
+ else {
201
+ var records = this.renderRoot.querySelectorAll('[data-record]');
202
+ }
203
+ var newrange = {};
204
+ for (var i = 0; i < records.length; i++) {
205
+ const record = records[i];
206
+ const from = record.querySelector('[data-from]').value;
207
+ const to = record.querySelector('[data-to]').value;
208
+ const inputs = record.querySelectorAll('[data-value]:not([style*="display: none"])');
209
+ if (!inputs || inputs.length == 0) {
210
+ continue;
211
+ }
212
+ var input = inputs[inputs.length - 1];
213
+ var value;
214
+ if (input.type == 'checkbox') {
215
+ value = Boolean(input.checked);
216
+ }
217
+ else {
218
+ value = input.value;
219
+ }
220
+ if (from) {
221
+ if (from === 'default')
222
+ newrange['default'] = value || (this.valuetype == 'color' ? '#000000' : '');
223
+ else
224
+ newrange[`${from}~${to}`] = value;
225
+ }
226
+ }
227
+ this.value = newrange;
228
+ this.dispatchEvent(new CustomEvent('change', { bubbles: true, composed: true, detail: this.value }));
229
+ }
230
+ /* default를 제외한 range아이템들을 template(dom-repeat)용 배열로 변환하는 함수 */
231
+ _toArray(range) {
232
+ var array = [];
233
+ for (var key in range) {
234
+ if (key == 'default') {
235
+ continue;
236
+ }
237
+ const fromto = key.split('~');
238
+ array.push({
239
+ from: fromto[0],
240
+ to: fromto[1],
241
+ value: range[key]
242
+ });
243
+ }
244
+ return array;
245
+ }
246
+ _sort() {
247
+ const sorter = this.rangetype === 'number'
248
+ ? function (a, b) {
249
+ return parseFloat(b.from) < parseFloat(a.from) ? 1 : -1;
250
+ }
251
+ : function (a, b) {
252
+ return b.from < a.from ? 1 : -1;
253
+ };
254
+ var range = this._toArray(this.value)
255
+ .sort(sorter)
256
+ .reduce(function (sum, i) {
257
+ sum[`${i.from}~${i.to}`] = i.value;
258
+ return sum;
259
+ }, {});
260
+ range.default = this.value.default;
261
+ this.value = range;
262
+ this.dispatchEvent(new CustomEvent('change', { bubbles: true, composed: true, detail: this.value }));
263
+ }
264
+ _add() {
265
+ this._build(true);
266
+ const inputs = this.renderRoot.querySelectorAll('[data-record-new] input:not([style*="display: none"])');
267
+ for (var i = 0; i < inputs.length; i++) {
268
+ let input = inputs[i];
269
+ if (input.type == 'checkbox') {
270
+ input.checked = false;
271
+ }
272
+ else {
273
+ input.value = this._defaultValue(input.type);
274
+ }
275
+ }
276
+ inputs[0].focus();
277
+ }
278
+ _delete(e) {
279
+ const record = e.target.parentElement;
280
+ const dataFrom = record.querySelector('[data-from]');
281
+ dataFrom.value = '';
282
+ this._build();
283
+ }
284
+ };
285
+ __decorate([
286
+ property({ type: Object })
287
+ ], OxInputValueRange.prototype, "value", void 0);
288
+ __decorate([
289
+ property({ type: String })
290
+ ], OxInputValueRange.prototype, "valuetype", void 0);
291
+ __decorate([
292
+ property({ type: String })
293
+ ], OxInputValueRange.prototype, "rangetype", void 0);
294
+ OxInputValueRange = __decorate([
295
+ customElement('ox-input-value-ranges')
296
+ ], OxInputValueRange);
297
+ export { OxInputValueRange };
298
+ //# sourceMappingURL=ox-input-value-ranges.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ox-input-value-ranges.js","sourceRoot":"","sources":["../../src/ox-input-value-ranges.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license Copyright © HatioLab Inc. All rights reserved.\n */\n\nimport './ox-input-color'\n\nimport { css, html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\n\nimport { OxFormField } from './ox-form-field.js'\n\ntype ValueRange = { default?: any; [fromto: string]: any }\ntype ArrayedRange = { from: any; to: any; value: any }\n\n/**\nrange value editor element\n\nExample:\n\n <ox-input-value-ranges\n .value=${range}\n valuetype=${type}\n </ox-input-value-ranges>\n*/\n\n@customElement('ox-input-value-ranges')\nexport class OxInputValueRange extends OxFormField {\n static styles = css`\n :host {\n display: flex;\n flex-direction: column;\n align-content: center;\n\n width: 100%;\n overflow: hidden;\n border: 1px solid #ccc;\n }\n\n div {\n display: flex;\n flex-flow: row nowrap;\n align-items: center;\n\n border-bottom: 1px solid #c0c0c0;\n }\n\n div:last-child {\n border-bottom: none;\n }\n\n div > * {\n min-width: 0px;\n margin: 2px;\n padding: 0;\n }\n\n button {\n width: 20px;\n text-align: center;\n }\n\n input,\n ox-input-color {\n flex: 1;\n }\n\n ox-input-color {\n --things-editor-color-input-color: {\n margin: 2px;\n }\n --things-editor-color-input-span: {\n width: 12px;\n height: 12px;\n }\n }\n\n [placeholder='value'] {\n flex: 2;\n }\n\n div {\n border-bottom: 1px solid #c0c0c0;\n }\n\n div:last-child {\n border-bottom: none;\n }\n\n input[type='checkbox'] {\n width: initial;\n }\n `\n\n @property({ type: Object }) value: ValueRange = {}\n @property({ type: String }) valuetype: 'string' | 'boolean' | 'color' | string = 'string'\n @property({ type: String }) rangetype: 'string' | 'boolean' | 'color' | string = 'number'\n\n private _changingNow: boolean = false\n\n firstUpdated() {\n this.renderRoot.addEventListener('change', this._onChange.bind(this))\n }\n\n render() {\n return html`\n ${this._toArray(this.value).map(\n item => html`\n <div data-record>\n <input type=\"text\" data-from placeholder=\"<=\" .value=${item.from} />\n <input type=\"text\" data-to placeholder=\"&gt;\" .value=${item.to} />\n\n ${this.valuetype == 'boolean'\n ? html` <input type=\"checkbox\" data-value .checked=${item.value} data-value-type=${this.valuetype} /> `\n : this.valuetype == 'color'\n ? html` <ox-input-color data-value .value=${item.value}> </ox-input-color> `\n : html`\n <input\n type=\"text\"\n data-value\n placeholder=\"value\"\n .value=${item.value}\n data-value-type=${this.valuetype}\n />\n `} <button class=\"record-action\" @click=${(e: Event) => this._delete(e)} tabindex=\"-1\">-</button>\n </div>\n `\n )}\n\n <div data-record-new>\n <input type=\"text\" data-from placeholder=\"<=\" value=\"\" />\n <input type=\"text\" data-to placeholder=\"&gt;\" value=\"\" />\n\n ${this.valuetype == 'boolean'\n ? html` <input type=\"checkbox\" data-value data-value-type=${this.valuetype} /> `\n : this.valuetype == 'color'\n ? html` <ox-input-color data-value value=\"\" placeholder=\"value\"> </ox-input-color> `\n : html` <input type=\"text\" data-value placeholder=\"value\" value=\"\" data-value-type=${this.valuetype} /> `}\n <button class=\"record-action\" @click=${(e: Event) => this._add()} tabindex=\"-1\">+</button>\n </div>\n\n <div data-record>\n <input type=\"text\" data-from data-default=\"\" disabled value=\"default\" />\n <input type=\"text\" data-to placeholder=\"&gt;\" value=\"\" hidden />\n\n ${this.valuetype == 'boolean'\n ? html`\n <input\n type=\"checkbox\"\n data-value\n .checked=${this.value && this.value.default}\n data-value-type=${this.valuetype}\n />\n `\n : this.valuetype == 'color'\n ? html`\n <ox-input-color data-value .value=${(this.value && this.value.default) || ''} placeholder=\"value\">\n </ox-input-color>\n `\n : html`\n <input\n type=\"text\"\n data-value\n .value=${(this.value && this.value.default) || ''}\n placeholder=\"value\"\n class=\"default-value\"\n data-value-type=${this.valuetype}\n />\n `} <button class=\"record-action\" @click=${(e: Event) => this._sort()}>&gt;</button>\n </div>\n `\n }\n\n _defaultValue(type: 'color' | 'boolean' | 'checkbox' | string) {\n switch (type || this.valuetype) {\n case 'color':\n return '#000000'\n case 'boolean':\n case 'checkbox':\n return false\n default:\n return ''\n }\n }\n\n _onChange(e: Event) {\n if (this._changingNow) {\n return\n }\n\n this._changingNow = true\n\n const input = e.target as HTMLInputElement\n var value = input.type === 'checkbox' ? Boolean(input.checked) : input.value\n\n const div = input.parentElement as HTMLDivElement\n if (input.hasAttribute('data-value')) {\n const dataList = div.querySelectorAll('[data-value]:not([hidden])') as NodeListOf<HTMLElement & { value: any }>\n\n for (var i = 0; i < dataList.length; i++) {\n if (dataList[i] !== input) {\n dataList[i].value = value\n }\n }\n }\n\n if (div.hasAttribute('data-record')) {\n this._build()\n } else if (div.hasAttribute('data-record-new') && input.hasAttribute('data-value')) {\n this._add()\n }\n\n this._changingNow = false\n }\n\n _build(includeNewRecord?: boolean) {\n if (includeNewRecord) {\n var records = this.renderRoot.querySelectorAll('[data-record],[data-record-new]')\n } else {\n var records = this.renderRoot.querySelectorAll('[data-record]')\n }\n\n var newrange: ValueRange = {}\n for (var i = 0; i < records.length; i++) {\n const record = records[i]\n const from = (record.querySelector('[data-from]') as HTMLInputElement).value\n const to = (record.querySelector('[data-to]') as HTMLInputElement).value\n const inputs = record.querySelectorAll(\n '[data-value]:not([style*=\"display: none\"])'\n ) as NodeListOf<HTMLInputElement>\n\n if (!inputs || inputs.length == 0) {\n continue\n }\n\n var input = inputs[inputs.length - 1]\n var value\n\n if (input.type == 'checkbox') {\n value = Boolean(input.checked)\n } else {\n value = input.value\n }\n\n if (from) {\n if (from === 'default') newrange['default'] = value || (this.valuetype == 'color' ? '#000000' : '')\n else newrange[`${from}~${to}`] = value\n }\n }\n\n this.value = newrange\n\n this.dispatchEvent(new CustomEvent('change', { bubbles: true, composed: true, detail: this.value }))\n }\n\n /* default를 제외한 range아이템들을 template(dom-repeat)용 배열로 변환하는 함수 */\n _toArray(range: ValueRange) {\n var array: ArrayedRange[] = []\n\n for (var key in range) {\n if (key == 'default') {\n continue\n }\n\n const fromto = key.split('~')\n\n array.push({\n from: fromto[0],\n to: fromto[1],\n value: range[key]\n })\n }\n return array\n }\n\n _sort() {\n const sorter =\n this.rangetype === 'number'\n ? function (a: ArrayedRange, b: ArrayedRange) {\n return parseFloat(b.from) < parseFloat(a.from) ? 1 : -1\n }\n : function (a: ArrayedRange, b: ArrayedRange) {\n return b.from < a.from ? 1 : -1\n }\n\n var range: ValueRange = this._toArray(this.value)\n .sort(sorter)\n .reduce(function (sum, i) {\n sum[`${i.from}~${i.to}`] = i.value\n return sum\n }, {} as ValueRange)\n range.default = this.value.default\n\n this.value = range\n\n this.dispatchEvent(new CustomEvent('change', { bubbles: true, composed: true, detail: this.value }))\n }\n\n _add() {\n this._build(true)\n\n const inputs = this.renderRoot.querySelectorAll(\n '[data-record-new] input:not([style*=\"display: none\"])'\n ) as NodeListOf<HTMLInputElement & { value: any; type: string }>\n\n for (var i = 0; i < inputs.length; i++) {\n let input = inputs[i]\n if (input.type == 'checkbox') {\n input.checked = false\n } else {\n input.value = this._defaultValue(input.type)\n }\n }\n\n inputs[0].focus()\n }\n\n _delete(e: Event) {\n const record = (e.target as Element).parentElement\n\n const dataFrom = record!.querySelector('[data-from]') as HTMLInputElement\n dataFrom.value = ''\n\n this._build()\n }\n}\n"]}