@operato/input 1.1.21 → 1.1.24

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 CHANGED
@@ -3,6 +3,25 @@
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
+ ### [1.1.24](https://github.com/hatiolab/operato/compare/v1.1.23...v1.1.24) (2022-12-04)
7
+
8
+
9
+ ### :bug: Bug Fix
10
+
11
+ * ox-input-mass-fraction.ts ([8113c2b](https://github.com/hatiolab/operato/commit/8113c2b2b233d3199abdddd3a974b095b22e40a0))
12
+ * placeholder for ox-input-mass-fraction ([7b7c79c](https://github.com/hatiolab/operato/commit/7b7c79c22a23006b19981714f58266aee52af034))
13
+
14
+
15
+
16
+ ### [1.1.23](https://github.com/hatiolab/operato/compare/v1.1.22...v1.1.23) (2022-12-04)
17
+
18
+
19
+ ### :bug: Bug Fix
20
+
21
+ * add ox-input-mass-fraction ([6d52d4d](https://github.com/hatiolab/operato/commit/6d52d4d456bf4b405964b5b46f79e97cba6ba64e))
22
+
23
+
24
+
6
25
  ### [1.1.21](https://github.com/hatiolab/operato/compare/v1.1.20...v1.1.21) (2022-12-01)
7
26
 
8
27
 
@@ -0,0 +1,46 @@
1
+ /**
2
+ * @license Copyright © HatioLab Inc. All rights reserved.
3
+ */
4
+ import '@material/mwc-icon';
5
+ import '@operato/popup/ox-popup-list.js';
6
+ import { OxFormField } from './ox-form-field';
7
+ import './ox-select.js';
8
+ declare const FLUIDS: string[];
9
+ type ArrayElement<ArrayType extends readonly unknown[]> = ArrayType extends readonly (infer ElementType)[] ? ElementType : never;
10
+ type FLUID = ArrayElement<typeof FLUIDS>;
11
+ type MassFraction = {
12
+ [key: FLUID]: number;
13
+ };
14
+ type ArrayedMassFraction = {
15
+ key: FLUID;
16
+ value: number;
17
+ }[];
18
+ /**
19
+ input component for mass-fraction map
20
+
21
+ Example:
22
+
23
+ <ox-input-mass-fraction
24
+ value=${map}
25
+ </ox-input-mass-fraction>
26
+ */
27
+ export declare class OxInputMassFraction extends OxFormField {
28
+ static styles: import("lit").CSSResult[];
29
+ defaultValue: MassFraction;
30
+ value: MassFraction;
31
+ records: NodeListOf<HTMLElement>;
32
+ private options;
33
+ private changingNow;
34
+ firstUpdated(): void;
35
+ render(): import("lit-html").TemplateResult<1>;
36
+ _onChange(e: Event): void;
37
+ _normalize(): void;
38
+ _build(includeNewRecord?: boolean): void;
39
+ _toArray(map: MassFraction): ArrayedMassFraction;
40
+ _add(): void;
41
+ _delete(e: MouseEvent): void;
42
+ _up(e: MouseEvent): void;
43
+ _down(e: MouseEvent): void;
44
+ dispatchChangeEvent(): void;
45
+ }
46
+ export {};
@@ -0,0 +1,469 @@
1
+ /**
2
+ * @license Copyright © HatioLab Inc. All rights reserved.
3
+ */
4
+ import { __decorate } from "tslib";
5
+ import '@material/mwc-icon';
6
+ import '@operato/popup/ox-popup-list.js';
7
+ import { ScrollbarStyles } from '@operato/styles';
8
+ import { css, html } from 'lit';
9
+ import { customElement, property, queryAll } from 'lit/decorators.js';
10
+ import { live } from 'lit/directives/live.js';
11
+ import { OxFormField } from './ox-form-field';
12
+ import './ox-select.js';
13
+ const FLUIDS = [
14
+ '1-Butene',
15
+ 'Acetone',
16
+ 'Air',
17
+ 'Ammonia',
18
+ 'Argon',
19
+ 'Benzene',
20
+ 'CO2',
21
+ 'CarbonMonoxide',
22
+ 'CarbonylSulfide',
23
+ 'CycloHexane',
24
+ 'CycloPropane',
25
+ 'Cyclopentane',
26
+ 'D4',
27
+ 'D5',
28
+ 'D6',
29
+ 'Deuterium',
30
+ 'Dichloroethane',
31
+ 'DiethylEther',
32
+ 'DimethylCarbonate',
33
+ 'DimethylEther',
34
+ 'Ethane',
35
+ 'Ethanol',
36
+ 'EthylBenzene',
37
+ 'Ethylene',
38
+ 'EthyleneOxide',
39
+ 'Fluorine',
40
+ 'HFE143m',
41
+ 'HeavyWater',
42
+ 'Helium',
43
+ 'Hydrogen',
44
+ 'HydrogenChloride',
45
+ 'HydrogenSulfide',
46
+ 'IsoButane',
47
+ 'IsoButene',
48
+ 'Isohexane',
49
+ 'Isopentane',
50
+ 'Krypton',
51
+ 'MD2M',
52
+ 'MD3M',
53
+ 'MD4M',
54
+ 'MDM',
55
+ 'MM',
56
+ 'Methane',
57
+ 'Methanol',
58
+ 'MethylLinoleate',
59
+ 'MethylLinolenate',
60
+ 'MethylOleate',
61
+ 'MethylPalmitate',
62
+ 'MethylStearate',
63
+ 'Neon',
64
+ 'Neopentane',
65
+ 'Nitrogen',
66
+ 'NitrousOxide',
67
+ 'Novec649',
68
+ 'OrthoDeuterium',
69
+ 'OrthoHydrogen',
70
+ 'Oxygen',
71
+ 'ParaDeuterium',
72
+ 'ParaHydrogen',
73
+ 'Propylene',
74
+ 'Propyne',
75
+ 'R11',
76
+ 'R113',
77
+ 'R114',
78
+ 'R115',
79
+ 'R116',
80
+ 'R12',
81
+ 'R123',
82
+ 'R1233zd(E)',
83
+ 'R1234yf',
84
+ 'R1234ze(E)',
85
+ 'R1234ze(Z)',
86
+ 'R124',
87
+ 'R1243zf',
88
+ 'R125',
89
+ 'R13',
90
+ 'R134a',
91
+ 'R13I1',
92
+ 'R14',
93
+ 'R141b',
94
+ 'R142b',
95
+ 'R143a',
96
+ 'R152A',
97
+ 'R161',
98
+ 'R21',
99
+ 'R218',
100
+ 'R22',
101
+ 'R227EA',
102
+ 'R23',
103
+ 'R236EA',
104
+ 'R236FA',
105
+ 'R245ca',
106
+ 'R245fa',
107
+ 'R32',
108
+ 'R365MFC',
109
+ 'R40',
110
+ 'R404A',
111
+ 'R407C',
112
+ 'R41',
113
+ 'R410A',
114
+ 'R507A',
115
+ 'RC318',
116
+ 'SES36',
117
+ 'SulfurDioxide',
118
+ 'SulfurHexafluorid',
119
+ 'Toluene',
120
+ 'Water',
121
+ 'Xenon',
122
+ 'cis-2-Butene',
123
+ 'm-Xylene',
124
+ 'n-Butane',
125
+ 'n-Decane',
126
+ 'n-Dodecane',
127
+ 'n-Heptane',
128
+ 'n-Hexane',
129
+ 'n-Nonane',
130
+ 'n-Octane',
131
+ 'n-Pentane',
132
+ 'n-Propane',
133
+ 'n-Undecane',
134
+ 'o-Xylene',
135
+ 'p-Xylene',
136
+ 'trans-2-Butene'
137
+ ];
138
+ /**
139
+ input component for mass-fraction map
140
+
141
+ Example:
142
+
143
+ <ox-input-mass-fraction
144
+ value=${map}
145
+ </ox-input-mass-fraction>
146
+ */
147
+ let OxInputMassFraction = class OxInputMassFraction extends OxFormField {
148
+ constructor() {
149
+ super(...arguments);
150
+ this.defaultValue = {};
151
+ this.value = {};
152
+ this.options = FLUIDS.map(fluid => html `<div option value=${fluid}>${fluid}</div>`);
153
+ this.changingNow = false;
154
+ }
155
+ static { this.styles = [
156
+ ScrollbarStyles,
157
+ css `
158
+ :host {
159
+ display: flex;
160
+ flex-direction: column;
161
+ justify-content: space-between;
162
+ }
163
+
164
+ [records] {
165
+ flex: 1;
166
+
167
+ overflow: overlay;
168
+ }
169
+
170
+ [records] > div {
171
+ display: flex;
172
+ flex-flow: row nowrap;
173
+ gap: var(--mass-fraction-gap, 4px);
174
+ margin-bottom: var(--margin-narrow);
175
+ }
176
+
177
+ [data-record-new] {
178
+ display: flex;
179
+ flex-flow: row nowrap;
180
+ gap: var(--mass-fraction-gap, 3px);
181
+ margin: var(--margin-narrow) 0;
182
+ }
183
+
184
+ button {
185
+ align-self: center;
186
+ border: var(--button-border);
187
+ border-radius: var(--border-radius);
188
+ background-color: var(--button-background-color);
189
+ padding: var(--mass-fraction-button-padding-vertical, 3px) var(--mass-fraction-button-padding-horizontal, 3px);
190
+ color: var(--button-color);
191
+ cursor: pointer;
192
+ }
193
+ button mwc-icon {
194
+ font-size: var(--fontsize-default);
195
+ }
196
+ button:focus,
197
+ button:hover,
198
+ button:active {
199
+ border: var(--button-active-border);
200
+ background-color: var(--button-background-focus-color);
201
+ color: var(--theme-white-color);
202
+ }
203
+
204
+ input,
205
+ ox-select {
206
+ border: 0;
207
+ border-bottom: var(--border-dark-color);
208
+ font: var(--input-font);
209
+ color: var(--primary-text-color);
210
+ min-width: 50px;
211
+ }
212
+
213
+ input {
214
+ padding: var(--input-padding);
215
+ }
216
+
217
+ ox-select {
218
+ padding: 0;
219
+ }
220
+
221
+ [data-key] {
222
+ flex: 2;
223
+ }
224
+
225
+ [data-value] {
226
+ flex: 1;
227
+ }
228
+
229
+ input:focus {
230
+ outline: none;
231
+ border-bottom: 1px solid var(--primary-color);
232
+ }
233
+
234
+ button.hidden {
235
+ opacity: 0;
236
+ cursor: default;
237
+ }
238
+
239
+ ox-popup-list {
240
+ max-height: 300px;
241
+ overflow: auto;
242
+ left: 0;
243
+ }
244
+
245
+ [records] > [nofraction] {
246
+ display: block;
247
+ text-align: center;
248
+ }
249
+ `
250
+ ]; }
251
+ firstUpdated() {
252
+ this.renderRoot.addEventListener('change', this._onChange.bind(this));
253
+ }
254
+ render() {
255
+ const value = !this.value || typeof this.value !== 'object' ? {} : this.value;
256
+ const arrayed = this._toArray(value);
257
+ return html `
258
+ <div records>
259
+ ${arrayed.length
260
+ ? arrayed.map((item, idx) => html `
261
+ <div data-record>
262
+ <input type="text" data-key .value=${item.key} disabled />
263
+ <input
264
+ type="number"
265
+ data-value
266
+ placeholder="fraction"
267
+ min="0"
268
+ max="1"
269
+ step="0.01"
270
+ .value=${String(item.value)}
271
+ list="value-template"
272
+ />
273
+ <button class="record-action" @click=${(e) => this._delete(e)} tabindex="-1">
274
+ <mwc-icon>remove</mwc-icon>
275
+ </button>
276
+ <button
277
+ class="record-action"
278
+ @click=${(e) => this._up(e)}
279
+ tabindex="-1"
280
+ ?disabled=${idx === 0}
281
+ >
282
+ <mwc-icon>arrow_upward</mwc-icon>
283
+ </button>
284
+ <button
285
+ class="record-action"
286
+ @click=${(e) => this._down(e)}
287
+ tabindex="-1"
288
+ ?disabled=${idx === arrayed.length - 1}
289
+ >
290
+ <mwc-icon>arrow_downward</mwc-icon>
291
+ </button>
292
+ </div>
293
+ `)
294
+ : html `<div nofraction>No Fractions</div>`}
295
+ </div>
296
+
297
+ <div data-record-new>
298
+ <ox-select
299
+ data-key
300
+ placeholder="Fluid"
301
+ .value=${live('')}
302
+ @change=${(e) => {
303
+ e.stopPropagation();
304
+ }}
305
+ >
306
+ <ox-popup-list with-search> ${this.options} </ox-popup-list>
307
+ </ox-select>
308
+
309
+ <input
310
+ type="number"
311
+ data-value
312
+ placeholder="proportion"
313
+ min="0"
314
+ max="1"
315
+ step="0.01"
316
+ value=""
317
+ list="value-template"
318
+ />
319
+ <button class="record-action" @click=${(e) => this._add()} tabindex="-1">
320
+ <mwc-icon>add</mwc-icon>
321
+ </button>
322
+ <button
323
+ title="fill with the values suggested"
324
+ @click=${() => {
325
+ this.value = { ...this.defaultValue };
326
+ this.dispatchChangeEvent();
327
+ }}
328
+ >
329
+ <mwc-icon>settings_suggest</mwc-icon>
330
+ </button>
331
+ <button
332
+ title="normalize fraction"
333
+ @click=${() => {
334
+ this._normalize();
335
+ }}
336
+ >
337
+ <mwc-icon>repartition</mwc-icon>
338
+ </button>
339
+ </div>
340
+ `;
341
+ }
342
+ _onChange(e) {
343
+ if (this.changingNow) {
344
+ return;
345
+ }
346
+ this.changingNow = true;
347
+ const input = e.target;
348
+ const record = e.target.closest('[data-record],[data-record-new]');
349
+ if (record.hasAttribute('data-record')) {
350
+ this._build();
351
+ }
352
+ else if (record.hasAttribute('data-record-new') && input.hasAttribute('data-value')) {
353
+ this._add();
354
+ }
355
+ this.changingNow = false;
356
+ }
357
+ _normalize() {
358
+ const fraction = this.value || {};
359
+ const sum = Object.values(fraction).reduce((a, b) => a + b, 0);
360
+ this.value = Object.keys(fraction).reduce((newvalue, key) => {
361
+ newvalue[key] = fraction[key] / sum;
362
+ return newvalue;
363
+ }, {});
364
+ this.dispatchChangeEvent();
365
+ }
366
+ _build(includeNewRecord) {
367
+ if (includeNewRecord) {
368
+ var records = this.renderRoot.querySelectorAll('[data-record],[data-record-new]');
369
+ }
370
+ else {
371
+ var records = this.renderRoot.querySelectorAll('[data-record]');
372
+ }
373
+ var newmap = {};
374
+ for (var i = 0; i < records.length; i++) {
375
+ var record = records[i];
376
+ const key = record.querySelector('[data-key]').value;
377
+ const inputs = record.querySelectorAll('[data-value]:not([style*="display: none"])');
378
+ if (!inputs || inputs.length == 0) {
379
+ continue;
380
+ }
381
+ var input = inputs[inputs.length - 1];
382
+ var value = input.value;
383
+ if (key) {
384
+ newmap[key] = Number(value) || 0;
385
+ }
386
+ }
387
+ this.value = newmap;
388
+ this.dispatchChangeEvent();
389
+ }
390
+ /* map아이템들을 template(dom-repeat)용 배열로 변환하는 함수 */
391
+ _toArray(map) {
392
+ var array = [];
393
+ for (var key in map) {
394
+ array.push({
395
+ key: key,
396
+ value: map[key]
397
+ });
398
+ }
399
+ return array;
400
+ }
401
+ _add() {
402
+ this._build(true);
403
+ const inputs = this.renderRoot.querySelectorAll('[data-record-new] input:not([style*="display: none"])');
404
+ for (var i = 0; i < inputs.length; i++) {
405
+ let input = inputs[i];
406
+ if (input.type == 'checkbox')
407
+ input.checked = false;
408
+ else
409
+ input.value = '';
410
+ }
411
+ inputs[0].focus();
412
+ }
413
+ _delete(e) {
414
+ const record = e.target.closest('[data-record]');
415
+ record.querySelector('[data-key]').value = '';
416
+ this._build();
417
+ }
418
+ _up(e) {
419
+ const record = e.target.closest('[data-record]');
420
+ const array = Array.from(this.records);
421
+ const index = array.indexOf(record) - 1;
422
+ if (index < 0) {
423
+ return;
424
+ }
425
+ const deleted = array.splice(index, 1);
426
+ array.splice(index + 1, 0, ...deleted);
427
+ this.value = array.reduce((sum, record) => {
428
+ const key = record.querySelector('[data-key]').value;
429
+ const value = record.querySelector('[data-value]').value;
430
+ sum[key] = Number(value) || 0;
431
+ return sum;
432
+ }, {});
433
+ this.dispatchChangeEvent();
434
+ }
435
+ _down(e) {
436
+ const record = e.target.closest('[data-record]');
437
+ const array = Array.from(this.records);
438
+ const index = array.indexOf(record);
439
+ if (index > array.length) {
440
+ return;
441
+ }
442
+ array.splice(index, 1);
443
+ array.splice(index + 1, 0, record);
444
+ this.value = array.reduce((sum, record) => {
445
+ const key = record.querySelector('[data-key]').value;
446
+ const value = record.querySelector('[data-value]').value;
447
+ sum[key] = Number(value) || 0;
448
+ return sum;
449
+ }, {});
450
+ this.dispatchChangeEvent();
451
+ }
452
+ dispatchChangeEvent() {
453
+ this.dispatchEvent(new CustomEvent('change', { bubbles: true, composed: true, detail: this.value }));
454
+ }
455
+ };
456
+ __decorate([
457
+ property({ type: Object })
458
+ ], OxInputMassFraction.prototype, "defaultValue", void 0);
459
+ __decorate([
460
+ property({ type: Object })
461
+ ], OxInputMassFraction.prototype, "value", void 0);
462
+ __decorate([
463
+ queryAll('[data-record]')
464
+ ], OxInputMassFraction.prototype, "records", void 0);
465
+ OxInputMassFraction = __decorate([
466
+ customElement('ox-input-mass-fraction')
467
+ ], OxInputMassFraction);
468
+ export { OxInputMassFraction };
469
+ //# sourceMappingURL=ox-input-mass-fraction.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ox-input-mass-fraction.js","sourceRoot":"","sources":["../../src/ox-input-mass-fraction.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license Copyright © HatioLab Inc. All rights reserved.\n */\n\nimport '@material/mwc-icon'\nimport '@operato/popup/ox-popup-list.js'\nimport { ScrollbarStyles } from '@operato/styles'\n\nimport { css, html } from 'lit'\nimport { customElement, property, queryAll } from 'lit/decorators.js'\nimport { live } from 'lit/directives/live.js'\n\nimport { OxFormField } from './ox-form-field'\nimport './ox-select.js'\n\nconst FLUIDS = [\n '1-Butene',\n 'Acetone',\n 'Air',\n 'Ammonia',\n 'Argon',\n 'Benzene',\n 'CO2',\n 'CarbonMonoxide',\n 'CarbonylSulfide',\n 'CycloHexane',\n 'CycloPropane',\n 'Cyclopentane',\n 'D4',\n 'D5',\n 'D6',\n 'Deuterium',\n 'Dichloroethane',\n 'DiethylEther',\n 'DimethylCarbonate',\n 'DimethylEther',\n 'Ethane',\n 'Ethanol',\n 'EthylBenzene',\n 'Ethylene',\n 'EthyleneOxide',\n 'Fluorine',\n 'HFE143m',\n 'HeavyWater',\n 'Helium',\n 'Hydrogen',\n 'HydrogenChloride',\n 'HydrogenSulfide',\n 'IsoButane',\n 'IsoButene',\n 'Isohexane',\n 'Isopentane',\n 'Krypton',\n 'MD2M',\n 'MD3M',\n 'MD4M',\n 'MDM',\n 'MM',\n 'Methane',\n 'Methanol',\n 'MethylLinoleate',\n 'MethylLinolenate',\n 'MethylOleate',\n 'MethylPalmitate',\n 'MethylStearate',\n 'Neon',\n 'Neopentane',\n 'Nitrogen',\n 'NitrousOxide',\n 'Novec649',\n 'OrthoDeuterium',\n 'OrthoHydrogen',\n 'Oxygen',\n 'ParaDeuterium',\n 'ParaHydrogen',\n 'Propylene',\n 'Propyne',\n 'R11',\n 'R113',\n 'R114',\n 'R115',\n 'R116',\n 'R12',\n 'R123',\n 'R1233zd(E)',\n 'R1234yf',\n 'R1234ze(E)',\n 'R1234ze(Z)',\n 'R124',\n 'R1243zf',\n 'R125',\n 'R13',\n 'R134a',\n 'R13I1',\n 'R14',\n 'R141b',\n 'R142b',\n 'R143a',\n 'R152A',\n 'R161',\n 'R21',\n 'R218',\n 'R22',\n 'R227EA',\n 'R23',\n 'R236EA',\n 'R236FA',\n 'R245ca',\n 'R245fa',\n 'R32',\n 'R365MFC',\n 'R40',\n 'R404A',\n 'R407C',\n 'R41',\n 'R410A',\n 'R507A',\n 'RC318',\n 'SES36',\n 'SulfurDioxide',\n 'SulfurHexafluorid',\n 'Toluene',\n 'Water',\n 'Xenon',\n 'cis-2-Butene',\n 'm-Xylene',\n 'n-Butane',\n 'n-Decane',\n 'n-Dodecane',\n 'n-Heptane',\n 'n-Hexane',\n 'n-Nonane',\n 'n-Octane',\n 'n-Pentane',\n 'n-Propane',\n 'n-Undecane',\n 'o-Xylene',\n 'p-Xylene',\n 'trans-2-Butene'\n]\n\ntype ArrayElement<ArrayType extends readonly unknown[]> = ArrayType extends readonly (infer ElementType)[]\n ? ElementType\n : never\n\ntype FLUID = ArrayElement<typeof FLUIDS>\n\ntype MassFraction = { [key: FLUID]: number }\ntype ArrayedMassFraction = { key: FLUID; value: number }[]\n\n/**\n input component for mass-fraction map\n \n Example:\n \n <ox-input-mass-fraction \n value=${map}\n </ox-input-mass-fraction>\n */\n@customElement('ox-input-mass-fraction')\nexport class OxInputMassFraction extends OxFormField {\n static styles = [\n ScrollbarStyles,\n css`\n :host {\n display: flex;\n flex-direction: column;\n justify-content: space-between;\n }\n\n [records] {\n flex: 1;\n\n overflow: overlay;\n }\n\n [records] > div {\n display: flex;\n flex-flow: row nowrap;\n gap: var(--mass-fraction-gap, 4px);\n margin-bottom: var(--margin-narrow);\n }\n\n [data-record-new] {\n display: flex;\n flex-flow: row nowrap;\n gap: var(--mass-fraction-gap, 3px);\n margin: var(--margin-narrow) 0;\n }\n\n button {\n align-self: center;\n border: var(--button-border);\n border-radius: var(--border-radius);\n background-color: var(--button-background-color);\n padding: var(--mass-fraction-button-padding-vertical, 3px) var(--mass-fraction-button-padding-horizontal, 3px);\n color: var(--button-color);\n cursor: pointer;\n }\n button mwc-icon {\n font-size: var(--fontsize-default);\n }\n button:focus,\n button:hover,\n button:active {\n border: var(--button-active-border);\n background-color: var(--button-background-focus-color);\n color: var(--theme-white-color);\n }\n\n input,\n ox-select {\n border: 0;\n border-bottom: var(--border-dark-color);\n font: var(--input-font);\n color: var(--primary-text-color);\n min-width: 50px;\n }\n\n input {\n padding: var(--input-padding);\n }\n\n ox-select {\n padding: 0;\n }\n\n [data-key] {\n flex: 2;\n }\n\n [data-value] {\n flex: 1;\n }\n\n input:focus {\n outline: none;\n border-bottom: 1px solid var(--primary-color);\n }\n\n button.hidden {\n opacity: 0;\n cursor: default;\n }\n\n ox-popup-list {\n max-height: 300px;\n overflow: auto;\n left: 0;\n }\n\n [records] > [nofraction] {\n display: block;\n text-align: center;\n }\n `\n ]\n\n @property({ type: Object }) defaultValue: MassFraction = {}\n @property({ type: Object }) value: MassFraction = {}\n\n @queryAll('[data-record]') records!: NodeListOf<HTMLElement>\n\n private options = FLUIDS.map(fluid => html`<div option value=${fluid}>${fluid}</div>`)\n private changingNow: boolean = false\n\n firstUpdated() {\n this.renderRoot.addEventListener('change', this._onChange.bind(this))\n }\n\n render() {\n const value = !this.value || typeof this.value !== 'object' ? {} : this.value\n const arrayed = this._toArray(value)\n\n return html`\n <div records>\n ${arrayed.length\n ? arrayed.map(\n (item, idx) => html`\n <div data-record>\n <input type=\"text\" data-key .value=${item.key} disabled />\n <input\n type=\"number\"\n data-value\n placeholder=\"fraction\"\n min=\"0\"\n max=\"1\"\n step=\"0.01\"\n .value=${String(item.value)}\n list=\"value-template\"\n />\n <button class=\"record-action\" @click=${(e: MouseEvent) => this._delete(e)} tabindex=\"-1\">\n <mwc-icon>remove</mwc-icon>\n </button>\n <button\n class=\"record-action\"\n @click=${(e: MouseEvent) => this._up(e)}\n tabindex=\"-1\"\n ?disabled=${idx === 0}\n >\n <mwc-icon>arrow_upward</mwc-icon>\n </button>\n <button\n class=\"record-action\"\n @click=${(e: MouseEvent) => this._down(e)}\n tabindex=\"-1\"\n ?disabled=${idx === arrayed.length - 1}\n >\n <mwc-icon>arrow_downward</mwc-icon>\n </button>\n </div>\n `\n )\n : html`<div nofraction>No Fractions</div>`}\n </div>\n\n <div data-record-new>\n <ox-select\n data-key\n placeholder=\"Fluid\"\n .value=${live('')}\n @change=${(e: Event) => {\n e.stopPropagation()\n }}\n >\n <ox-popup-list with-search> ${this.options} </ox-popup-list>\n </ox-select>\n\n <input\n type=\"number\"\n data-value\n placeholder=\"proportion\"\n min=\"0\"\n max=\"1\"\n step=\"0.01\"\n value=\"\"\n list=\"value-template\"\n />\n <button class=\"record-action\" @click=${(e: MouseEvent) => this._add()} tabindex=\"-1\">\n <mwc-icon>add</mwc-icon>\n </button>\n <button\n title=\"fill with the values suggested\"\n @click=${() => {\n this.value = { ...this.defaultValue }\n this.dispatchChangeEvent()\n }}\n >\n <mwc-icon>settings_suggest</mwc-icon>\n </button>\n <button\n title=\"normalize fraction\"\n @click=${() => {\n this._normalize()\n }}\n >\n <mwc-icon>repartition</mwc-icon>\n </button>\n </div>\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\n const record = (e.target as Element).closest('[data-record],[data-record-new]') as HTMLElement\n\n if (record.hasAttribute('data-record')) {\n this._build()\n } else if (record.hasAttribute('data-record-new') && input.hasAttribute('data-value')) {\n this._add()\n }\n\n this.changingNow = false\n }\n\n _normalize() {\n const fraction: MassFraction = this.value || {}\n const sum = Object.values(fraction).reduce((a, b) => a + b, 0)\n this.value = Object.keys(fraction).reduce((newvalue, key) => {\n newvalue[key] = fraction[key] / sum\n return newvalue\n }, {} as MassFraction)\n\n this.dispatchChangeEvent()\n }\n\n _build(includeNewRecord?: boolean) {\n if (includeNewRecord) {\n var records = this.renderRoot.querySelectorAll('[data-record],[data-record-new]') as NodeListOf<HTMLElement>\n } else {\n var records = this.renderRoot.querySelectorAll('[data-record]') as NodeListOf<HTMLElement>\n }\n\n var newmap: MassFraction = {}\n\n for (var i = 0; i < records.length; i++) {\n var record = records[i]\n\n const key = (record.querySelector('[data-key]') 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\n var value = input.value\n\n if (key) {\n newmap[key] = Number(value) || 0\n }\n }\n\n this.value = newmap\n\n this.dispatchChangeEvent()\n }\n\n /* map아이템들을 template(dom-repeat)용 배열로 변환하는 함수 */\n _toArray(map: MassFraction) {\n var array: ArrayedMassFraction = []\n\n for (var key in map) {\n array.push({\n key: key,\n value: map[key]\n })\n }\n\n return array\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 }>\n\n for (var i = 0; i < inputs.length; i++) {\n let input = inputs[i]\n\n if (input.type == 'checkbox') input.checked = false\n else input.value = ''\n }\n\n inputs[0].focus()\n }\n\n _delete(e: MouseEvent) {\n const record = (e.target as Element).closest('[data-record]') as HTMLElement\n\n ;(record!.querySelector('[data-key]') as HTMLInputElement)!.value = ''\n\n this._build()\n }\n\n _up(e: MouseEvent) {\n const record = (e.target as Element).closest('[data-record]') as HTMLElement\n const array = Array.from(this.records)\n const index = array.indexOf(record) - 1\n\n if (index < 0) {\n return\n }\n\n const deleted = array.splice(index, 1)\n array.splice(index + 1, 0, ...deleted)\n\n this.value = array.reduce((sum, record) => {\n const key = (record.querySelector('[data-key]') as HTMLInputElement).value\n const value = (record.querySelector('[data-value]') as HTMLInputElement).value\n\n sum[key] = Number(value) || 0\n return sum\n }, {} as MassFraction)\n\n this.dispatchChangeEvent()\n }\n\n _down(e: MouseEvent) {\n const record = (e.target as Element).closest('[data-record]') as HTMLElement\n const array = Array.from(this.records)\n const index = array.indexOf(record)\n\n if (index > array.length) {\n return\n }\n\n array.splice(index, 1)\n array.splice(index + 1, 0, record)\n\n this.value = array.reduce((sum, record) => {\n const key = (record.querySelector('[data-key]') as HTMLInputElement).value\n const value = (record.querySelector('[data-value]') as HTMLInputElement).value\n\n sum[key] = Number(value) || 0\n return sum\n }, {} as MassFraction)\n\n this.dispatchChangeEvent()\n }\n\n dispatchChangeEvent() {\n this.dispatchEvent(new CustomEvent('change', { bubbles: true, composed: true, detail: this.value }))\n }\n}\n"]}
@@ -169,6 +169,7 @@ let OxInputUnit = class OxInputUnit extends OxFormField {
169
169
  padding: var(--input-padding);
170
170
  font: var(--input-font);
171
171
  color: var(--primary-text-color);
172
+ min-width: 120px;
172
173
  }
173
174
 
174
175
  input:focus {
@@ -192,6 +193,7 @@ let OxInputUnit = class OxInputUnit extends OxFormField {
192
193
  margin-left: var(--margin-narrow);
193
194
  font: var(--label-font);
194
195
  color: var(--label-color);
196
+ min-width: 24px;
195
197
  }
196
198
  `
197
199
  ]; }