@operato/input 1.0.0-beta.12 → 1.0.0-beta.13

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.
Files changed (109) hide show
  1. package/CHANGELOG.md +24 -0
  2. package/demo/index-multiple-colors.html +4 -1
  3. package/demo/index-partition-keys.html +2 -5
  4. package/demo/index.html +4 -0
  5. package/dist/src/locales/en.d.ts +8 -0
  6. package/dist/src/locales/en.js +8 -0
  7. package/dist/src/locales/en.js.map +1 -1
  8. package/dist/src/locales/ko.d.ts +8 -0
  9. package/dist/src/locales/ko.js +8 -0
  10. package/dist/src/locales/ko.js.map +1 -1
  11. package/dist/src/locales/ms.d.ts +8 -0
  12. package/dist/src/locales/ms.js +8 -0
  13. package/dist/src/locales/ms.js.map +1 -1
  14. package/dist/src/locales/zh.d.ts +8 -0
  15. package/dist/src/locales/zh.js +8 -0
  16. package/dist/src/locales/zh.js.map +1 -1
  17. package/dist/src/ox-input-3dish.js +24 -8
  18. package/dist/src/ox-input-3dish.js.map +1 -1
  19. package/dist/src/ox-input-color.js +16 -11
  20. package/dist/src/ox-input-color.js.map +1 -1
  21. package/dist/src/ox-input-crontab.js +13 -10
  22. package/dist/src/ox-input-crontab.js.map +1 -1
  23. package/dist/src/ox-input-multiple-colors.d.ts +1 -0
  24. package/dist/src/ox-input-multiple-colors.js +29 -21
  25. package/dist/src/ox-input-multiple-colors.js.map +1 -1
  26. package/dist/src/ox-input-options.d.ts +1 -0
  27. package/dist/src/ox-input-options.js +54 -14
  28. package/dist/src/ox-input-options.js.map +1 -1
  29. package/dist/src/ox-input-partition-keys.d.ts +1 -0
  30. package/dist/src/ox-input-partition-keys.js +51 -23
  31. package/dist/src/ox-input-partition-keys.js.map +1 -1
  32. package/dist/src/ox-input-search.js +7 -2
  33. package/dist/src/ox-input-search.js.map +1 -1
  34. package/dist/src/ox-input-unit.d.ts +17 -0
  35. package/dist/src/ox-input-unit.js +112 -0
  36. package/dist/src/ox-input-unit.js.map +1 -0
  37. package/dist/src/ox-input-work-shift.js +19 -17
  38. package/dist/src/ox-input-work-shift.js.map +1 -1
  39. package/dist/stories/ox-input-3dish.stories.d.ts +26 -0
  40. package/dist/stories/ox-input-3dish.stories.js +59 -0
  41. package/dist/stories/ox-input-3dish.stories.js.map +1 -0
  42. package/dist/stories/ox-input-barcode.stories.d.ts +33 -0
  43. package/dist/stories/ox-input-barcode.stories.js +22 -0
  44. package/dist/stories/ox-input-barcode.stories.js.map +1 -0
  45. package/dist/stories/ox-input-conntab.stories.d.ts +26 -0
  46. package/dist/stories/ox-input-conntab.stories.js +37 -0
  47. package/dist/stories/ox-input-conntab.stories.js.map +1 -0
  48. package/dist/stories/ox-input-multiple-colors.stories.d.ts +20 -0
  49. package/dist/stories/ox-input-multiple-colors.stories.js +167 -0
  50. package/dist/stories/ox-input-multiple-colors.stories.js.map +1 -0
  51. package/dist/stories/ox-input-options.stories.d.ts +25 -0
  52. package/dist/stories/ox-input-options.stories.js +33 -0
  53. package/dist/stories/ox-input-options.stories.js.map +1 -0
  54. package/dist/stories/ox-input-partition-keys.stories.d.ts +27 -0
  55. package/dist/stories/ox-input-partition-keys.stories.js +55 -0
  56. package/dist/stories/ox-input-partition-keys.stories.js.map +1 -0
  57. package/dist/stories/ox-input-range.stories.d.ts +37 -0
  58. package/dist/stories/ox-input-range.stories.js +25 -0
  59. package/dist/stories/ox-input-range.stories.js.map +1 -0
  60. package/dist/stories/ox-input-search.stories.d.ts +29 -0
  61. package/dist/stories/ox-input-search.stories.js +28 -0
  62. package/dist/stories/ox-input-search.stories.js.map +1 -0
  63. package/dist/stories/ox-input-unit.stories.d.ts +40 -0
  64. package/dist/stories/ox-input-unit.stories.js +41 -0
  65. package/dist/stories/ox-input-unit.stories.js.map +1 -0
  66. package/dist/stories/ox-input-work-shift.stories.d.ts +26 -0
  67. package/dist/stories/ox-input-work-shift.stories.js +59 -0
  68. package/dist/stories/ox-input-work-shift.stories.js.map +1 -0
  69. package/dist/stories/ox-select.stories.d.ts +30 -0
  70. package/dist/stories/ox-select.stories.js +82 -0
  71. package/dist/stories/ox-select.stories.js.map +1 -0
  72. package/dist/themes/common-grist-styles.d.ts +1 -0
  73. package/dist/themes/common-grist-styles.js +110 -0
  74. package/dist/themes/common-grist-styles.js.map +1 -0
  75. package/dist/tsconfig.tsbuildinfo +1 -1
  76. package/package.json +10 -10
  77. package/src/locales/en.ts +8 -0
  78. package/src/locales/ko.ts +8 -0
  79. package/src/locales/ms.ts +8 -0
  80. package/src/locales/zh.ts +8 -0
  81. package/src/ox-input-3dish.ts +24 -8
  82. package/src/ox-input-color.ts +17 -11
  83. package/src/ox-input-crontab.ts +13 -10
  84. package/src/ox-input-multiple-colors.ts +29 -21
  85. package/src/ox-input-options.ts +53 -13
  86. package/src/ox-input-partition-keys.ts +51 -22
  87. package/src/ox-input-search.ts +7 -2
  88. package/src/ox-input-unit.ts +112 -0
  89. package/src/ox-input-work-shift.ts +20 -17
  90. package/stories/ox-input-3dish.stories.ts +73 -0
  91. package/stories/ox-input-barcode.stories.ts +38 -0
  92. package/stories/ox-input-code.stories.ts_ +71 -0
  93. package/stories/ox-input-conntab.stories.ts +51 -0
  94. package/stories/ox-input-multiple-colors.stories.ts +178 -0
  95. package/stories/ox-input-options.stories.ts +47 -0
  96. package/stories/ox-input-partition-keys.stories.ts +71 -0
  97. package/stories/ox-input-range.stories.ts +42 -0
  98. package/stories/ox-input-search.stories.ts +43 -0
  99. package/stories/ox-input-unit.stories.ts +65 -0
  100. package/stories/ox-input-work-shift.stories.ts +73 -0
  101. package/stories/ox-select.stories.ts +100 -0
  102. package/themes/app-theme.css +142 -0
  103. package/themes/common-grist-styles.ts +110 -0
  104. package/themes/input-theme.css +19 -0
  105. package/xliff/en.xlf +24 -0
  106. package/xliff/ko.xlf +32 -0
  107. package/xliff/ms.xlf +24 -0
  108. package/xliff/zh.xlf +24 -0
  109. package/stories/index.stories.ts_ +0 -52
@@ -0,0 +1,30 @@
1
+ import '../src/ox-select.js';
2
+ import '../src/ox-checkbox.js';
3
+ import { TemplateResult } from 'lit';
4
+ declare const _default: {
5
+ title: string;
6
+ component: string;
7
+ argTypes: {
8
+ placeholder: {
9
+ control: string;
10
+ };
11
+ name: {
12
+ control: string;
13
+ };
14
+ };
15
+ };
16
+ export default _default;
17
+ interface Story<T> {
18
+ (args: T): TemplateResult;
19
+ args?: Partial<T>;
20
+ argTypes?: Record<string, unknown>;
21
+ }
22
+ interface ArgTypes {
23
+ placeholder?: string;
24
+ name?: string;
25
+ value?: object | string;
26
+ slot?: TemplateResult;
27
+ }
28
+ export declare const Regular: Story<ArgTypes>;
29
+ export declare const MultipleSelect: Story<ArgTypes>;
30
+ export declare const MultipleWithCheckbox: Story<ArgTypes>;
@@ -0,0 +1,82 @@
1
+ import '../src/ox-select.js';
2
+ import '../src/ox-checkbox.js';
3
+ import { html } from 'lit';
4
+ export default {
5
+ title: 'ox-select',
6
+ component: 'ox-select',
7
+ argTypes: {
8
+ placeholder: { control: 'text' },
9
+ name: { control: 'text' }
10
+ }
11
+ };
12
+ const Template = ({ placeholder = 'Checkbox', name = 'hello', value = '', slot }) => html `
13
+ <link href="https://fonts.googleapis.com/css?family=Material+Icons&display=block" rel="stylesheet" />
14
+
15
+ <ox-select
16
+ name=${name}
17
+ @change=${(e) => {
18
+ console.log(e.target.value);
19
+ }}
20
+ placeholder=${placeholder}
21
+ .value=${value}
22
+ >
23
+ ${slot}
24
+ </ox-select>
25
+ `;
26
+ export const Regular = Template.bind({});
27
+ Regular.args = {
28
+ placeholder: 'single select',
29
+ name: 'label',
30
+ value: '',
31
+ slot: html `
32
+ <ox-popup-list align-left nowrap>
33
+ <div option value="A">LABEL-A</div>
34
+ <div option value="B">LABEL-B</div>
35
+ <div option value="C">LABEL-C</div>
36
+ <div option value="TOO LONG VALUE">LABEL-TOO LONG VALUE</div>
37
+ </ox-popup-list>
38
+ `
39
+ };
40
+ export const MultipleSelect = Template.bind({});
41
+ MultipleSelect.args = {
42
+ placeholder: 'multiple select',
43
+ name: 'multiple',
44
+ value: ['B', 'TOO LONG VALUE'],
45
+ slot: html `
46
+ <ox-popup-list multiple with-search>
47
+ <div option value="A">A</div>
48
+ <div option value="B">B</div>
49
+ <div option value="C">C</div>
50
+ <div option value="TOO LONG VALUE" />TOO LONG VALUE</div>
51
+ </ox-popup-list>
52
+ `
53
+ };
54
+ export const MultipleWithCheckbox = Template.bind({});
55
+ MultipleWithCheckbox.args = {
56
+ placeholder: 'multiple with checkbox',
57
+ name: 'multiple',
58
+ value: ['B', 'C', 'F'],
59
+ slot: html `
60
+ <ox-popup-list attr-selected="checked" multiple with-search>
61
+ <ox-checkbox
62
+ option
63
+ @change=${(e) => {
64
+ const target = e.target;
65
+ const options = target.parentElement.querySelectorAll('[option]');
66
+ console.log(options);
67
+ options.forEach(option => (option.checked = target.checked));
68
+ }}
69
+ >set all</ox-checkbox
70
+ >
71
+ <ox-checkbox option value="A">LABEL-A</ox-checkbox>
72
+ <ox-checkbox option value="B">LABEL-B</ox-checkbox>
73
+ <ox-checkbox option value="C" checked>LABEL-C</ox-checkbox>
74
+ <ox-checkbox option value="D">LABEL-D</ox-checkbox>
75
+ <ox-checkbox option value="E">LABEL-E</ox-checkbox>
76
+ <ox-checkbox option value="F">LABEL-F</ox-checkbox>
77
+ <ox-checkbox option value="G">LABEL-G</ox-checkbox>
78
+ <ox-checkbox option value="TOO LONG VALUE">TOO LONG VALUE</ox-checkbox>
79
+ </ox-popup-list>
80
+ `
81
+ };
82
+ //# sourceMappingURL=ox-select.stories.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ox-select.stories.js","sourceRoot":"","sources":["../../stories/ox-select.stories.ts"],"names":[],"mappings":"AAAA,OAAO,qBAAqB,CAAA;AAC5B,OAAO,uBAAuB,CAAA;AAE9B,OAAO,EAAE,IAAI,EAAkB,MAAM,KAAK,CAAA;AAE1C,eAAe;IACb,KAAK,EAAE,WAAW;IAClB,SAAS,EAAE,WAAW;IACtB,QAAQ,EAAE;QACR,WAAW,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE;QAChC,IAAI,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE;KAC1B;CACF,CAAA;AAeD,MAAM,QAAQ,GAAoB,CAAC,EAAE,WAAW,GAAG,UAAU,EAAE,IAAI,GAAG,OAAO,EAAE,KAAK,GAAG,EAAE,EAAE,IAAI,EAAY,EAAE,EAAE,CAAC,IAAI,CAAA;;;;WAIzG,IAAI;cACD,CAAC,CAAQ,EAAE,EAAE;IACrB,OAAO,CAAC,GAAG,CAAE,CAAC,CAAC,MAA2B,CAAC,KAAK,CAAC,CAAA;AACnD,CAAC;kBACa,WAAW;aAChB,KAAK;;MAEZ,IAAI;;CAET,CAAA;AAED,MAAM,CAAC,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;AACxC,OAAO,CAAC,IAAI,GAAG;IACb,WAAW,EAAE,eAAe;IAC5B,IAAI,EAAE,OAAO;IACb,KAAK,EAAE,EAAE;IACT,IAAI,EAAE,IAAI,CAAA;;;;;;;GAOT;CACF,CAAA;AAED,MAAM,CAAC,MAAM,cAAc,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;AAC/C,cAAc,CAAC,IAAI,GAAG;IACpB,WAAW,EAAE,iBAAiB;IAC9B,IAAI,EAAE,UAAU;IAChB,KAAK,EAAE,CAAC,GAAG,EAAE,gBAAgB,CAAC;IAC9B,IAAI,EAAE,IAAI,CAAA;;;;;;;GAOT;CACF,CAAA;AAED,MAAM,CAAC,MAAM,oBAAoB,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;AACrD,oBAAoB,CAAC,IAAI,GAAG;IAC1B,WAAW,EAAE,wBAAwB;IACrC,IAAI,EAAE,UAAU;IAChB,KAAK,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC;IACtB,IAAI,EAAE,IAAI,CAAA;;;;kBAIM,CAAC,CAAQ,EAAE,EAAE;QACrB,MAAM,MAAM,GAAG,CAAC,CAAC,MAA0B,CAAA;QAC3C,MAAM,OAAO,GAAG,MAAM,CAAC,aAAc,CAAC,gBAAgB,CAAC,UAAU,CAAC,CAAA;QAClE,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;QACpB,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC,CAAE,MAA2B,CAAC,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC,CAAA;IACpF,CAAC;;;;;;;;;;;;GAYN;CACF,CAAA","sourcesContent":["import '../src/ox-select.js'\nimport '../src/ox-checkbox.js'\n\nimport { html, TemplateResult } from 'lit'\n\nexport default {\n title: 'ox-select',\n component: 'ox-select',\n argTypes: {\n placeholder: { control: 'text' },\n name: { control: 'text' }\n }\n}\n\ninterface Story<T> {\n (args: T): TemplateResult\n args?: Partial<T>\n argTypes?: Record<string, unknown>\n}\n\ninterface ArgTypes {\n placeholder?: string\n name?: string\n value?: object | string\n slot?: TemplateResult\n}\n\nconst Template: Story<ArgTypes> = ({ placeholder = 'Checkbox', name = 'hello', value = '', slot }: ArgTypes) => html`\n <link href=\"https://fonts.googleapis.com/css?family=Material+Icons&display=block\" rel=\"stylesheet\" />\n\n <ox-select\n name=${name}\n @change=${(e: Event) => {\n console.log((e.target as HTMLInputElement).value)\n }}\n placeholder=${placeholder}\n .value=${value}\n >\n ${slot}\n </ox-select>\n`\n\nexport const Regular = Template.bind({})\nRegular.args = {\n placeholder: 'single select',\n name: 'label',\n value: '',\n slot: html`\n <ox-popup-list align-left nowrap>\n <div option value=\"A\">LABEL-A</div>\n <div option value=\"B\">LABEL-B</div>\n <div option value=\"C\">LABEL-C</div>\n <div option value=\"TOO LONG VALUE\">LABEL-TOO LONG VALUE</div>\n </ox-popup-list>\n `\n}\n\nexport const MultipleSelect = Template.bind({})\nMultipleSelect.args = {\n placeholder: 'multiple select',\n name: 'multiple',\n value: ['B', 'TOO LONG VALUE'],\n slot: html`\n <ox-popup-list multiple with-search>\n <div option value=\"A\">A</div>\n <div option value=\"B\">B</div>\n <div option value=\"C\">C</div>\n <div option value=\"TOO LONG VALUE\" />TOO LONG VALUE</div>\n </ox-popup-list>\n `\n}\n\nexport const MultipleWithCheckbox = Template.bind({})\nMultipleWithCheckbox.args = {\n placeholder: 'multiple with checkbox',\n name: 'multiple',\n value: ['B', 'C', 'F'],\n slot: html`\n <ox-popup-list attr-selected=\"checked\" multiple with-search>\n <ox-checkbox\n option\n @change=${(e: Event) => {\n const target = e.target as HTMLInputElement\n const options = target.parentElement!.querySelectorAll('[option]')\n console.log(options)\n options.forEach(option => ((option as HTMLInputElement).checked = target.checked))\n }}\n >set all</ox-checkbox\n >\n <ox-checkbox option value=\"A\">LABEL-A</ox-checkbox>\n <ox-checkbox option value=\"B\">LABEL-B</ox-checkbox>\n <ox-checkbox option value=\"C\" checked>LABEL-C</ox-checkbox>\n <ox-checkbox option value=\"D\">LABEL-D</ox-checkbox>\n <ox-checkbox option value=\"E\">LABEL-E</ox-checkbox>\n <ox-checkbox option value=\"F\">LABEL-F</ox-checkbox>\n <ox-checkbox option value=\"G\">LABEL-G</ox-checkbox>\n <ox-checkbox option value=\"TOO LONG VALUE\">TOO LONG VALUE</ox-checkbox>\n </ox-popup-list>\n `\n}\n"]}
@@ -0,0 +1 @@
1
+ export declare const CommonGristStyles: import("lit").CSSResult;
@@ -0,0 +1,110 @@
1
+ import { css } from 'lit';
2
+ export const CommonGristStyles = css `
3
+ :host {
4
+ display: flex;
5
+
6
+ width: 100%;
7
+ }
8
+
9
+ ox-grist {
10
+ flex: 1;
11
+ overflow-y: auto;
12
+ }
13
+
14
+ [slot='headroom'] {
15
+ display: flex;
16
+ flex-direction: row;
17
+ align-items: center;
18
+ padding: var(--padding-default) var(--padding-wide);
19
+ border-top: 2px solid rgba(0, 0, 0, 0.2);
20
+ background-color: var(--theme-white-color);
21
+ box-shadow: var(--box-shadow);
22
+
23
+ --mdc-icon-size: 24px;
24
+ }
25
+ #sorters mwc-icon,
26
+ #modes mwc-icon {
27
+ --mdc-icon-size: 18px;
28
+ }
29
+ #sorters {
30
+ margin-left: auto;
31
+ margin-right: var(--margin-default);
32
+ padding-left: var(--padding-narrow);
33
+ border-bottom: var(--border-dark-color);
34
+ position: relative;
35
+ color: var(--secondary-color);
36
+ font-size: var(--fontsize-default);
37
+ user-select: none;
38
+ }
39
+
40
+ #sorters > * {
41
+ padding: var(--padding-narrow);
42
+ vertical-align: middle;
43
+ }
44
+
45
+ #modes > * {
46
+ padding: var(--padding-narrow);
47
+ opacity: 0.5;
48
+ color: var(--primary-text-color);
49
+ cursor: pointer;
50
+ }
51
+
52
+ #modes > mwc-icon[active] {
53
+ border-radius: 9px;
54
+ background-color: rgba(var(--primary-color-rgb), 0.05);
55
+ opacity: 1;
56
+ color: var(--secondary-text-color);
57
+ cursor: default;
58
+ }
59
+
60
+ #modes > mwc-icon:hover {
61
+ opacity: 1;
62
+ color: var(--secondary-text-color);
63
+ }
64
+
65
+ #add {
66
+ width: 50px;
67
+ text-align: right;
68
+ }
69
+
70
+ #add button {
71
+ background-color: var(--status-success-color);
72
+ border: 0;
73
+ border-radius: 50%;
74
+ padding: 5px;
75
+ width: 36px;
76
+ height: 36px;
77
+ cursor: pointer;
78
+ }
79
+
80
+ #add button:hover {
81
+ background-color: var(--focus-background-color);
82
+ box-shadow: var(--box-shadow);
83
+ }
84
+
85
+ #add button mwc-icon {
86
+ font-size: 2em;
87
+ color: var(--theme-white-color);
88
+ }
89
+
90
+ #filters {
91
+ display: flex;
92
+ justify-content: center;
93
+ align-items: center;
94
+ }
95
+
96
+ #filters * {
97
+ margin-right: var(--margin-default);
98
+ }
99
+
100
+ @media only screen and (max-width: 460px) {
101
+ #filters {
102
+ flex-direction: column;
103
+ }
104
+
105
+ #modes {
106
+ display: none;
107
+ }
108
+ }
109
+ `;
110
+ //# sourceMappingURL=common-grist-styles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"common-grist-styles.js","sourceRoot":"","sources":["../../themes/common-grist-styles.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,KAAK,CAAA;AAEzB,MAAM,CAAC,MAAM,iBAAiB,GAAG,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA2GnC,CAAA","sourcesContent":["import { css } from 'lit'\n\nexport const CommonGristStyles = css`\n :host {\n display: flex;\n\n width: 100%;\n }\n\n ox-grist {\n flex: 1;\n overflow-y: auto;\n }\n\n [slot='headroom'] {\n display: flex;\n flex-direction: row;\n align-items: center;\n padding: var(--padding-default) var(--padding-wide);\n border-top: 2px solid rgba(0, 0, 0, 0.2);\n background-color: var(--theme-white-color);\n box-shadow: var(--box-shadow);\n\n --mdc-icon-size: 24px;\n }\n #sorters mwc-icon,\n #modes mwc-icon {\n --mdc-icon-size: 18px;\n }\n #sorters {\n margin-left: auto;\n margin-right: var(--margin-default);\n padding-left: var(--padding-narrow);\n border-bottom: var(--border-dark-color);\n position: relative;\n color: var(--secondary-color);\n font-size: var(--fontsize-default);\n user-select: none;\n }\n\n #sorters > * {\n padding: var(--padding-narrow);\n vertical-align: middle;\n }\n\n #modes > * {\n padding: var(--padding-narrow);\n opacity: 0.5;\n color: var(--primary-text-color);\n cursor: pointer;\n }\n\n #modes > mwc-icon[active] {\n border-radius: 9px;\n background-color: rgba(var(--primary-color-rgb), 0.05);\n opacity: 1;\n color: var(--secondary-text-color);\n cursor: default;\n }\n\n #modes > mwc-icon:hover {\n opacity: 1;\n color: var(--secondary-text-color);\n }\n\n #add {\n width: 50px;\n text-align: right;\n }\n\n #add button {\n background-color: var(--status-success-color);\n border: 0;\n border-radius: 50%;\n padding: 5px;\n width: 36px;\n height: 36px;\n cursor: pointer;\n }\n\n #add button:hover {\n background-color: var(--focus-background-color);\n box-shadow: var(--box-shadow);\n }\n\n #add button mwc-icon {\n font-size: 2em;\n color: var(--theme-white-color);\n }\n\n #filters {\n display: flex;\n justify-content: center;\n align-items: center;\n }\n\n #filters * {\n margin-right: var(--margin-default);\n }\n\n @media only screen and (max-width: 460px) {\n #filters {\n flex-direction: column;\n }\n\n #modes {\n display: none;\n }\n }\n`\n"]}