neo.mjs 5.15.5 → 5.16.1

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 (33) hide show
  1. package/apps/ServiceWorker.mjs +2 -2
  2. package/buildScripts/docs/jsdocx.mjs +8 -6
  3. package/docs/app/view/MainContainer.mjs +10 -0
  4. package/docs/app/view/classdetails/HeaderComponent.mjs +3 -3
  5. package/docs/app/view/classdetails/MainContainer.mjs +14 -4
  6. package/docs/app/view/classdetails/MembersList.mjs +5 -5
  7. package/examples/ServiceWorker.mjs +2 -2
  8. package/examples/form/field/fileupload/MainContainer.mjs +68 -10
  9. package/examples/form/field/fileupload/README.md +9 -0
  10. package/examples/form/field/fileupload/server.mjs +49 -0
  11. package/examples/form/field/switch/MainContainer.mjs +124 -0
  12. package/examples/form/field/switch/app.mjs +6 -0
  13. package/examples/form/field/switch/index.html +11 -0
  14. package/examples/form/field/switch/neo-config.json +6 -0
  15. package/package.json +2 -1
  16. package/resources/scss/src/apps/docs/HeaderContainer.scss +1 -1
  17. package/resources/scss/src/apps/docs/MainContainer.scss +5 -1
  18. package/resources/scss/src/apps/docs/classdetails/HeaderComponent.scss +2 -5
  19. package/resources/scss/src/apps/docs/classdetails/MainContainer.scss +1 -1
  20. package/resources/scss/src/component/Splitter.scss +3 -1
  21. package/resources/scss/src/form/field/FileUpload.scss +248 -2
  22. package/resources/scss/src/form/field/Switch.scss +85 -115
  23. package/resources/scss/src/tree/List.scss +2 -1
  24. package/resources/scss/theme-dark/form/field/FileUpload.scss +20 -4
  25. package/resources/scss/theme-dark/form/field/Switch.scss +10 -10
  26. package/resources/scss/theme-light/form/field/FileUpload.scss +20 -4
  27. package/resources/scss/theme-light/form/field/Switch.scss +10 -10
  28. package/src/DefaultConfig.mjs +2 -2
  29. package/src/component/Splitter.mjs +27 -22
  30. package/src/form/field/FileUpload.mjs +512 -4
  31. package/src/form/field/Switch.mjs +11 -11
  32. package/src/main/addon/Markdown.mjs +2 -2
  33. package/src/main/addon/ResizeObserver.mjs +79 -0
@@ -1,4 +1,250 @@
1
1
  .neo-file-upload-field {
2
- background-color: v(fileuploadfield-background-color);
3
- color : v(fileuploadfield-color);
2
+ background-color : v(fileuploadfield-background-color);
3
+ border-color : v(fileuploadfield-border-color);
4
+ color : v(fileuploadfield-color);
5
+ }
6
+
7
+ .neo-file-upload-field {
8
+ --upload-icon-codepoint : "\f062";
9
+ --cancel-icon-codepoint : "\f00d";
10
+ --delete-icon-codepoint : "\f014";
11
+ --success-icon-codepoint : "\f00c";
12
+ --download-icon-codepoint : "\f019";
13
+
14
+ min-height : 3.5rem;
15
+ position : relative;
16
+ display : flex;
17
+ align-items : center;
18
+ padding : 0.5rem;
19
+ gap : 0.5rem;
20
+ border : 1px solid var(--fileuploadfield-border-color);
21
+ border-radius : 2px;
22
+
23
+ // Space for any error message
24
+ margin-bottom : 2.5rem;
25
+
26
+ &:focus-within {
27
+ &::after {
28
+ content : "";
29
+ pointer-events : none;
30
+ position : absolute;
31
+ top : -2px;
32
+ right : -2px;
33
+ bottom : -2px;
34
+ left : -2px;
35
+ border : 1px solid var(--fileuploadfield-focus-color);
36
+ border-radius : 3px;
37
+ }
38
+ }
39
+
40
+ // Icons
41
+ i, button {
42
+ font-style : normal;
43
+ font-size : 18px;
44
+ flex : 0 0 2rem;
45
+ height : 2rem;
46
+ border-radius : 50%;
47
+ font-family : var(--fa-style-family,"Font Awesome 6 Free");
48
+ display : flex;
49
+ align-items : center;
50
+ justify-content : center;
51
+ border : 0 none;
52
+ background : transparent;
53
+ color : inherit;
54
+
55
+ &::after {
56
+ font-weight : var(--fa-style, 900);
57
+ display : flex;
58
+ align-items : center;
59
+ justify-content : center;
60
+ aspect-ratio : 1;
61
+ border-radius : 50%;
62
+ }
63
+ }
64
+
65
+ // Cursor appearance is invitation to click
66
+ .neo-file-upload-action-button {
67
+ cursor : pointer;
68
+ &:hover {
69
+ background-color: var(--fileuploadfield-hover-color);
70
+ }
71
+ &:active {
72
+ background-color: var(--fileuploadfield-pressed-color);
73
+ }
74
+ }
75
+
76
+ .neo-file-upload-filename {
77
+ font-weight : bold;
78
+ }
79
+
80
+ .neo-file-upload-filename, .neo-file-upload-state {
81
+ white-space : nowrap;
82
+ overflow : hidden;
83
+ text-overflow : ellipsis;
84
+ color : inherit; // For when it becomes a link
85
+ }
86
+
87
+ // The file input is only visible in the ready state
88
+ &:not(.neo-file-upload-state-ready) {
89
+ input[type="file"] {
90
+ display : none;
91
+ }
92
+ }
93
+
94
+ &.neo-invalid {
95
+ .neo-file-upload-error-message {
96
+ display : initial;
97
+ }
98
+ }
99
+ }
100
+
101
+ // During upload, it's a progress circle.
102
+ // Of the upload fails, the process circle stops but remains visible
103
+ .neo-file-upload-state-uploading, .neo-file-upload-state-upload-failed {
104
+ .neo-file-upload-state-icon {
105
+ background-image : conic-gradient(
106
+ var(--fileuploadfield-progress-color) 0 var(--upload-progress),
107
+ transparent var(--upload-progress) 1turn
108
+ );
109
+
110
+ &::after {
111
+ background-color : var(--fileuploadfield-background-color);
112
+ content : var(--upload-icon-codepoint);
113
+ flex : 0 0 calc(100% - 6px);
114
+ }
115
+ }
116
+ }
117
+
118
+ .neo-file-upload-state-processing {
119
+ .neo-file-upload-state-icon {
120
+ background-image : conic-gradient(
121
+ from 0deg, transparent 0deg,
122
+ var(--fileuploadfield-progress-color) 180deg,
123
+ transparent 180deg
124
+ );
125
+ animation: spinner-rotation 3s linear infinite;
126
+
127
+ &::after {
128
+ content : "";
129
+ flex : 0 0 calc(100% - 6px);
130
+ }
131
+ }
132
+ }
133
+
134
+ // While uploading and scanning, we can abort the whole upload/scan process
135
+ .neo-file-upload-state-uploading, .neo-file-upload-state-processing {
136
+ .neo-file-upload-action-button {
137
+ &::after {
138
+ content : var(--cancel-icon-codepoint);
139
+ }
140
+ }
141
+ }
142
+
143
+ // If the upload or scan failed, we show an error UI and the action button cancels
144
+ .neo-file-upload-state-upload-failed, .neo-file-upload-state-scan-failed {
145
+ --fileuploadfield-progress-color : var(--fileuploadfield-error-color);
146
+ border-color : var(--fileuploadfield-error-color);
147
+
148
+ .neo-file-upload-state-icon, .neo-file-upload-action-button {
149
+ &::after {
150
+ content : var(--cancel-icon-codepoint );
151
+ }
152
+ }
153
+
154
+ .neo-file-upload-state-icon, .neo-file-upload-state {
155
+ color : var(--fileuploadfield-error-color);
156
+ }
157
+ }
158
+
159
+ .neo-file-upload-state-scan-failed {
160
+ .neo-file-upload-state-icon {
161
+ border : 3px solid var(--fileuploadfield-error-color);
162
+ }
163
+ }
164
+
165
+ .neo-file-upload-state-not-downloadable {
166
+ .neo-file-upload-state-icon {
167
+ color : var(--fileuploadfield-success-color);
168
+ border : 3px solid var(--fileuploadfield-success-color);
169
+
170
+ &::after {
171
+ content : var(--success-icon-codepoint);
172
+ }
173
+ }
174
+ .neo-file-upload-action-button {
175
+ &::after {
176
+ content : var(--delete-icon-codepoint);
177
+ }
178
+ }
179
+ }
180
+
181
+ .neo-file-upload-state-downloadable {
182
+ &:has(.neo-file-upload-filename:hover) {
183
+ background-color: var(--fileuploadfield-hover-color);
184
+ }
185
+ &:has(.neo-file-upload-filename:active) {
186
+ background-color: var(--fileuploadfield-pressed-color);
187
+ }
188
+ .neo-file-upload-state-icon {
189
+ background-color : var(--fileuploadfield-downloadable-state-color);
190
+ border : 0 none;
191
+
192
+ &::after {
193
+ content : var(--download-icon-codepoint);
194
+ background-color: transparent;
195
+ }
196
+ }
197
+ .neo-file-upload-action-button {
198
+ &::after {
199
+ content : var(--delete-icon-codepoint);
200
+ }
201
+ }
202
+ }
203
+
204
+ .neo-file-upload-state-ready {
205
+ // Only the input field is visible when in ready state
206
+ // It takes up the whole component, and is the only interactive item
207
+ :not(input[type="file"]) {
208
+ display : none;
209
+ }
210
+ input::file-selector-button {
211
+ position : absolute;
212
+ border : 0 none;
213
+ margin : 0;
214
+ top : 0;
215
+ left : 0;
216
+ right : 0;
217
+ bottom : 0;
218
+ background-color : var(--fileuploadfield-background-color);
219
+ color : var(--fileuploadfield-color);
220
+ cursor : pointer;
221
+ }
222
+ }
223
+
224
+ .neo-file-upload-body {
225
+ flex : 1 1 0%;
226
+ display : flex;
227
+ flex-flow : column nowrap;
228
+ line-height : 1;
229
+ gap : 0.2rem;
230
+ overflow : hidden;
231
+ align-items : flex-start;}
232
+
233
+ .neo-file-upload-error-message {
234
+ display : none;
235
+ position : absolute;
236
+ inset-inline-start : 0;
237
+ white-space : nowrap;
238
+ top : 100%;
239
+ padding : 0.5rem;
240
+ color : var(--fileuploadfield-error-color);
241
+ }
242
+
243
+ @keyframes spinner-rotation {
244
+ 0% {
245
+ transform: rotate(0deg);
246
+ }
247
+ 100% {
248
+ transform: rotate(360deg);
249
+ }
4
250
  }
@@ -1,135 +1,105 @@
1
- .switchfield {
2
- @keyframes switch-on-position {
3
- 0% {
4
- left: 0;
5
- right: 50%
1
+ .neo-switchfield {
2
+ @keyframes switch-on-position {
3
+ 0% {left: 0; right: 50%}
4
+ 25% {left: 0; right: 37.5%}
5
+ 100% {left: 50%; right: 0}
6
6
  }
7
- 25% {
8
- left: 0;
9
- right: 37.5%
10
- }
11
- 100% {
12
- left: 50%;
13
- right: 0
14
- }
15
- }
16
7
 
17
- @keyframes switch-off-position {
18
- 0% {
19
- left: 50%;
20
- right: 0
21
- }
22
- 25% {
23
- left: 37.5%;
24
- right: 0
25
- }
26
- 100% {
27
- left: 0%;
28
- right: 50%
8
+ @keyframes switch-off-position {
9
+ 0% {left: 50%; right: 0}
10
+ 25% {left: 37.5%; right: 0}
11
+ 100% {left: 0; right: 50%}
29
12
  }
30
- }
31
13
 
32
- @keyframes switch-on-transform {
33
- 0% {
34
- transform: translate(0) scaleX(1)
14
+ @keyframes switch-on-transform {
15
+ 0% {transform: translate(0) scaleX(1)}
16
+ 25% {transform: translate(0) scaleX(1.33)}
17
+ 100% {transform: translate(100%) scaleX(1)}
35
18
  }
36
- 25% {
37
- transform: translate(0) scaleX(1.33)
38
- }
39
- 100% {
40
- transform: translate(100%) scaleX(1)
41
- }
42
- }
43
19
 
44
- @keyframes switch-off-transform {
45
- 0% {
46
- transform: translate(100%) scaleX(1)
47
- }
48
- 25% {
49
- transform: translate(100%) scaleX(1.33)
50
- }
51
- 100% {
52
- transform: translate(0) scaleX(1)
20
+ @keyframes switch-off-transform {
21
+ 0% {transform: translate(100%) scaleX(1)}
22
+ 25% {transform: translate(100%) scaleX(1.33)}
23
+ 100% {transform: translate(0) scaleX(1)}
53
24
  }
54
- }
55
25
 
56
- input[type="checkbox"] {
57
- position: relative;
58
- display: inline-block;
59
- -webkit-appearance: none;
60
- -webkit-tap-highlight-color: transparent;
61
- height: 1.5em;
62
- width: 3em;
63
- font-size: 1.5em;
26
+ input[type="checkbox"] {
27
+ background-clip : padding-box;
28
+ background-color: v(switchfield-background-color);
29
+ border-color : transparent;
30
+ border-radius : 1.25em;
31
+ color : v(switchfield-inactive-color);
32
+ display : inline-block;
33
+ font-size : 1.5em;
34
+ height : 1.5em;
35
+ position : relative;
36
+ transition : transform 0.25s linear 0.25s;
37
+ vertical-align : middle;
38
+ width : 3em;
64
39
 
65
- border-radius: 1.25em;
66
- background-color: v(switchfield-background-color);
67
- border-color: transparent;
68
- background-clip: padding-box;
69
- color: v(switchfield-inactive-color);
70
- vertical-align: middle;
71
- transition: all 0.25s linear 0.25s;
40
+ -webkit-appearance : none;
41
+ -webkit-tap-highlight-color: transparent;
72
42
 
73
43
 
74
- &::before {
75
- content: "";
76
- position: absolute;
77
- top: 0;
78
- left: 0;
79
- bottom: 0;
80
- right: 50%;
81
- background-color: v(switchfield-thumb-color);
82
- border-radius: 100%;
83
- border: 0.125em solid transparent;
84
- background-clip: padding-box;
85
- z-index: 2;
86
- transform-origin: right center;
87
- }
44
+ &::before {
45
+ background-clip : padding-box;
46
+ background-color: v(switchfield-thumb-color);
47
+ border : 0.125em solid transparent;
48
+ border-radius : 100%;
49
+ bottom : 0;
50
+ content : "";
51
+ left : 0;
52
+ position : absolute;
53
+ right : 50%;
54
+ top : 0;
55
+ transform-origin: right center;
56
+ z-index : 2;
57
+ }
88
58
 
89
- &::after {
90
- position: absolute;
91
- left: 0.5em;
92
- top: 0.15em;
93
- line-height: 1.5;
94
- font-family: "Font Awesome 6 Free";
95
- font-weight: 900;
96
- content: "\f00c\f00d";
97
- letter-spacing: 1em;
98
- z-index: 1;
99
- font-size: 1.25rem;
100
- }
59
+ &::after {
60
+ content : "\f00c\f00d";
61
+ font-family : "Font Awesome 6 Free";
62
+ font-size : 1.25rem;
63
+ font-weight : 900;
64
+ left : 0.5em;
65
+ letter-spacing: 1em;
66
+ line-height : 1.5;
67
+ position : absolute;
68
+ top : 0.15em;
69
+ z-index : 1;
70
+ }
101
71
 
102
- &:focus {
103
- color: v(switchfield-active-color);
104
- border-color: transparent;
105
- background-color: v(switchfield-background-color);
106
- outline: none;
107
- }
72
+ &:focus {
73
+ background-color: v(switchfield-background-color);
74
+ border-color : transparent;
75
+ color : v(switchfield-active-color);
76
+ outline : none;
77
+ }
108
78
 
109
- &:checked {
110
- color: v(switchfield-inactive-color);
111
- background-color: v(switchfield-checked);
112
- border-color: transparent;
79
+ &:checked {
80
+ background-color: v(switchfield-checked);
81
+ border-color : transparent;
82
+ color : v(switchfield-inactive-color);
113
83
 
114
- &::before {
115
- transform-origin: left center;
116
- }
84
+ &::before {
85
+ transform-origin: left center;
86
+ }
87
+ }
117
88
  }
118
- }
119
89
 
120
- input[type="checkbox"]::before {
121
- animation: switch-off-position 0.25s ease-out forwards;
122
- }
90
+ input[type="checkbox"]::before {
91
+ animation: switch-off-position 0.25s ease-out forwards;
92
+ }
123
93
 
124
- input[type="checkbox"]:checked::before {
125
- animation: switch-on-position 0.25s ease-out forwards;
126
- }
94
+ input[type="checkbox"]:checked::before {
95
+ animation: switch-on-position 0.25s ease-out forwards;
96
+ }
127
97
 
128
- input[type="checkbox"]::before {
129
- animation: switch-off-transform 0.25s ease-out forwards;
130
- }
98
+ input[type="checkbox"]::before {
99
+ animation: switch-off-transform 0.25s ease-out forwards;
100
+ }
131
101
 
132
- input[type="checkbox"]:checked::before {
133
- animation: switch-on-transform 0.25s ease-out forwards;
134
- }
135
- }
102
+ input[type="checkbox"]:checked::before {
103
+ animation: switch-on-transform 0.25s ease-out forwards;
104
+ }
105
+ }
@@ -6,7 +6,8 @@
6
6
  position: relative;
7
7
 
8
8
  .neo-list {
9
- overflow: visible;
9
+ overflow : visible;
10
+ user-select: none;
10
11
 
11
12
  &:focus {
12
13
  outline: none;
@@ -1,11 +1,27 @@
1
1
  $neoMap: map-merge($neoMap, (
2
- 'fileuploadfield-background-color': red,
3
- 'fileuploadfield-color' : #fff
2
+ 'fileuploadfield-background-color' : rgb(62, 51, 51),
3
+ 'fileuploadfield-color' : #fff,
4
+ 'fileuploadfield-border-color' : #d5d5d5,
5
+ 'fileuploadfield-progress-color' : #fff,
6
+ 'fileuploadfield-error-color' : #f00,
7
+ 'fileuploadfield-success-color' : rgb(71, 226, 71),
8
+ 'fileuploadfield-hover-color' : #0f0f0f,
9
+ 'fileuploadfield-pressed-color' : #0e0e0e,
10
+ 'fileuploadfield-downloadable-state-color' : #181818,
11
+ 'fileuploadfield-focus-color' : #80d3f4
4
12
  ));
5
13
 
6
14
  @if $useCssVars == true {
7
15
  :root .neo-theme-dark { // .neo-fileuploadfield
8
- --fileuploadfield-background-color: #{neo(fileuploadfield-background-color)};
9
- --fileuploadfield-color : #{neo(fileuploadfield-color)};
16
+ --fileuploadfield-background-color : #{neo(fileuploadfield-background-color)};
17
+ --fileuploadfield-color : #{neo(fileuploadfield-color)};
18
+ --fileuploadfield-border-color : #{neo(fileuploadfield-border-color)};
19
+ --fileuploadfield-progress-color : #{neo(fileuploadfield-progress-color)};
20
+ --fileuploadfield-error-color : #{neo(fileuploadfield-error-color)};
21
+ --fileuploadfield-success-color : #{neo(fileuploadfield-success-color)};
22
+ --fileuploadfield-hover-color : #{neo(fileuploadfield-hover-color)};
23
+ --fileuploadfield-pressed-color : #{neo(fileuploadfield-pressed-color)};
24
+ --fileuploadfield-downloadable-state-color : #{neo(fileuploadfield-pressed-color)};
25
+ --fileuploadfield-focus-color : #{neo(fileuploadfield-focus-color)};
10
26
  }
11
27
  }
@@ -1,17 +1,17 @@
1
1
  $neoMap: map-merge($neoMap, (
2
- 'switchfield-checked': green,
2
+ 'switchfield-active-color' : white,
3
3
  'switchfield-background-color': darkgrey,
4
- 'switchfield-inactive-color': grey,
5
- 'switchfield-active-color': white,
6
- 'switchfield-thumb-color': white
4
+ 'switchfield-checked' : green,
5
+ 'switchfield-inactive-color' : grey,
6
+ 'switchfield-thumb-color' : white
7
7
  ));
8
8
 
9
9
  @if $useCssVars == true {
10
10
  :root .neo-theme-dark { // .neo-switchfield
11
- --neo-switchfield-checked : #{neo(switchfield-checked)};
12
- --neo-switchfield-background-color : #{neo(switchfield-background-color)};
13
- --neo-switchfield-inactive-color : #{neo(switchfield-inactive-color)};
14
- --neo-switchfield-active-color : #{neo(switchfield-active-color)};
15
- --neo-switchfield-thumb-color-active-color : #{neo(switchfield-thumb-color-active-color)};
11
+ --switchfield-active-color : #{neo(switchfield-active-color)};
12
+ --switchfield-background-color: #{neo(switchfield-background-color)};
13
+ --switchfield-checked : #{neo(switchfield-checked)};
14
+ --switchfield-inactive-color : #{neo(switchfield-inactive-color)};
15
+ --switchfield-thumb-color : #{neo(switchfield-thumb-color)};
16
16
  }
17
- }
17
+ }
@@ -1,11 +1,27 @@
1
1
  $neoMap: map-merge($neoMap, (
2
- 'fileuploadfield-background-color': darkblue,
3
- 'fileuploadfield-color' : #fff
2
+ 'fileuploadfield-background-color' : #fff,
3
+ 'fileuploadfield-color' : #000,
4
+ 'fileuploadfield-border-color' : #d5d5d5,
5
+ 'fileuploadfield-progress-color' : #5d94f3,
6
+ 'fileuploadfield-error-color' : #f00,
7
+ 'fileuploadfield-success-color' : rgb(112, 169, 112),
8
+ 'fileuploadfield-hover-color' : #f0f0f0,
9
+ 'fileuploadfield-pressed-color' : #e0e0e0,
10
+ 'fileuploadfield-downloadable-state-color' : #d9d9d9,
11
+ 'fileuploadfield-focus-color' : #80d3f4
4
12
  ));
5
13
 
6
14
  @if $useCssVars == true {
7
15
  :root .neo-theme-light { // .neo-fileuploadfield
8
- --fileuploadfield-background-color: #{neo(fileuploadfield-background-color)};
9
- --fileuploadfield-color : #{neo(fileuploadfield-color)};
16
+ --fileuploadfield-background-color : #{neo(fileuploadfield-background-color)};
17
+ --fileuploadfield-color : #{neo(fileuploadfield-color)};
18
+ --fileuploadfield-border-color : #{neo(fileuploadfield-border-color)};
19
+ --fileuploadfield-progress-color : #{neo(fileuploadfield-progress-color)};
20
+ --fileuploadfield-error-color : #{neo(fileuploadfield-error-color)};
21
+ --fileuploadfield-success-color : #{neo(fileuploadfield-success-color)};
22
+ --fileuploadfield-hover-color : #{neo(fileuploadfield-hover-color)};
23
+ --fileuploadfield-pressed-color : #{neo(fileuploadfield-pressed-color)};
24
+ --fileuploadfield-downloadable-state-color : #{neo(fileuploadfield-pressed-color)};
25
+ --fileuploadfield-focus-color : #{neo(fileuploadfield-focus-color)};
10
26
  }
11
27
  }
@@ -1,17 +1,17 @@
1
1
  $neoMap: map-merge($neoMap, (
2
- 'switchfield-checked': green,
2
+ 'switchfield-active-color' : white,
3
3
  'switchfield-background-color': darkgrey,
4
- 'switchfield-inactive-color': grey,
5
- 'switchfield-active-color': white,
6
- 'switchfield-thumb-color': white
4
+ 'switchfield-checked' : green,
5
+ 'switchfield-inactive-color' : grey,
6
+ 'switchfield-thumb-color' : white
7
7
  ));
8
8
 
9
9
  @if $useCssVars == true {
10
10
  :root .neo-theme-light { // .neo-switchfield
11
- --neo-switchfield-checked : #{neo(switchfield-checked)};
12
- --neo-switchfield-background-color : #{neo(switchfield-background-color)};
13
- --neo-switchfield-inactive-color : #{neo(switchfield-inactive-color)};
14
- --neo-switchfield-active-color : #{neo(switchfield-active-color)};
15
- --neo-switchfield-thumb-color-active-color : #{neo(switchfield-thumb-color-active-color)};
11
+ --switchfield-active-color : #{neo(switchfield-active-color)};
12
+ --switchfield-background-color: #{neo(switchfield-background-color)};
13
+ --switchfield-checked : #{neo(switchfield-checked)};
14
+ --switchfield-inactive-color : #{neo(switchfield-inactive-color)};
15
+ --switchfield-thumb-color : #{neo(switchfield-thumb-color)};
16
16
  }
17
- }
17
+ }
@@ -245,12 +245,12 @@ const DefaultConfig = {
245
245
  useVdomWorker: true,
246
246
  /**
247
247
  * buildScripts/injectPackageVersion.mjs will update this value
248
- * @default '5.15.5'
248
+ * @default '5.16.1'
249
249
  * @memberOf! module:Neo
250
250
  * @name config.version
251
251
  * @type String
252
252
  */
253
- version: '5.15.5'
253
+ version: '5.16.1'
254
254
  };
255
255
 
256
256
  Object.assign(DefaultConfig, {