cx 25.6.0 → 25.6.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 (96) hide show
  1. package/dist/manifest.js +708 -708
  2. package/package.json +2 -2
  3. package/src/charts/Legend.d.ts +45 -45
  4. package/src/charts/LegendEntry.js +128 -128
  5. package/src/charts/LegendEntry.scss +27 -27
  6. package/src/charts/PieChart.d.ts +92 -92
  7. package/src/charts/RangeMarker.js +159 -159
  8. package/src/charts/axis/Axis.d.ts +113 -113
  9. package/src/charts/axis/Axis.js +280 -280
  10. package/src/charts/axis/CategoryAxis.d.ts +30 -30
  11. package/src/charts/axis/CategoryAxis.js +241 -241
  12. package/src/charts/axis/NumericAxis.js +351 -351
  13. package/src/charts/axis/Stack.js +55 -55
  14. package/src/charts/axis/TimeAxis.js +611 -611
  15. package/src/charts/helpers/SnapPointFinder.js +69 -69
  16. package/src/data/Binding.spec.js +69 -69
  17. package/src/data/Expression.js +229 -229
  18. package/src/data/Expression.spec.js +229 -229
  19. package/src/data/StringTemplate.js +92 -92
  20. package/src/data/StringTemplate.spec.js +132 -132
  21. package/src/data/StructuredSelector.js +132 -132
  22. package/src/data/getAccessor.spec.js +11 -11
  23. package/src/data/getSelector.js +49 -49
  24. package/src/hooks/createLocalStorageRef.d.ts +3 -3
  25. package/src/hooks/createLocalStorageRef.js +20 -20
  26. package/src/index.scss +6 -6
  27. package/src/ui/Culture.d.ts +57 -57
  28. package/src/ui/Culture.js +139 -139
  29. package/src/ui/FocusManager.js +171 -171
  30. package/src/ui/Format.js +108 -108
  31. package/src/ui/HoverSync.js +147 -147
  32. package/src/ui/Repeater.d.ts +61 -61
  33. package/src/ui/index.d.ts +42 -42
  34. package/src/ui/layout/ContentPlaceholder.d.ts +19 -19
  35. package/src/ui/layout/ContentPlaceholder.js +105 -105
  36. package/src/ui/layout/ContentPlaceholder.spec.js +579 -579
  37. package/src/ui/layout/LabelsTopLayout.js +134 -134
  38. package/src/util/Format.js +270 -270
  39. package/src/util/date/encodeDate.d.ts +1 -1
  40. package/src/util/date/encodeDate.js +8 -8
  41. package/src/util/date/encodeDateWithTimezoneOffset.d.ts +1 -1
  42. package/src/util/date/index.d.ts +11 -11
  43. package/src/util/date/index.js +11 -11
  44. package/src/util/date/parseDateInvariant.d.ts +3 -3
  45. package/src/util/date/parseDateInvariant.js +20 -20
  46. package/src/util/getSearchQueryPredicate.js +59 -59
  47. package/src/util/index.d.ts +51 -51
  48. package/src/util/index.js +54 -54
  49. package/src/util/isValidIdentifierName.d.ts +1 -1
  50. package/src/util/isValidIdentifierName.js +5 -5
  51. package/src/util/isValidIdentifierName.spec.js +33 -33
  52. package/src/util/scss/add-rules.scss +38 -38
  53. package/src/widgets/CxCredit.scss +37 -37
  54. package/src/widgets/HighlightedSearchText.js +36 -36
  55. package/src/widgets/HighlightedSearchText.scss +18 -18
  56. package/src/widgets/List.scss +91 -91
  57. package/src/widgets/drag-drop/DropZone.js +214 -214
  58. package/src/widgets/form/Calendar.js +618 -618
  59. package/src/widgets/form/Calendar.scss +196 -196
  60. package/src/widgets/form/Checkbox.scss +127 -127
  61. package/src/widgets/form/ColorField.js +397 -397
  62. package/src/widgets/form/ColorField.scss +96 -96
  63. package/src/widgets/form/ColorPicker.scss +283 -283
  64. package/src/widgets/form/DateTimeField.js +576 -576
  65. package/src/widgets/form/DateTimePicker.js +392 -392
  66. package/src/widgets/form/LookupField.d.ts +179 -179
  67. package/src/widgets/form/LookupField.scss +219 -219
  68. package/src/widgets/form/MonthPicker.scss +118 -118
  69. package/src/widgets/form/NumberField.js +459 -459
  70. package/src/widgets/form/NumberField.scss +61 -61
  71. package/src/widgets/form/Radio.scss +121 -121
  72. package/src/widgets/form/Select.scss +99 -99
  73. package/src/widgets/form/Slider.scss +118 -118
  74. package/src/widgets/form/Switch.scss +140 -140
  75. package/src/widgets/form/TextArea.scss +43 -43
  76. package/src/widgets/form/TextField.js +290 -290
  77. package/src/widgets/form/TextField.scss +55 -55
  78. package/src/widgets/form/UploadButton.d.ts +34 -34
  79. package/src/widgets/form/variables.scss +353 -353
  80. package/src/widgets/grid/Grid.d.ts +442 -442
  81. package/src/widgets/grid/GridRow.js +228 -228
  82. package/src/widgets/grid/TreeNode.d.ts +23 -23
  83. package/src/widgets/grid/TreeNode.scss +88 -88
  84. package/src/widgets/grid/variables.scss +133 -133
  85. package/src/widgets/nav/LinkButton.js +128 -128
  86. package/src/widgets/nav/Menu.scss +74 -74
  87. package/src/widgets/overlay/Dropdown.js +612 -612
  88. package/src/widgets/overlay/FlyweightTooltipTracker.js +39 -39
  89. package/src/widgets/overlay/Overlay.d.ts +73 -73
  90. package/src/widgets/overlay/Window.js +202 -202
  91. package/src/widgets/overlay/captureMouse.js +124 -124
  92. package/src/widgets/overlay/createHotPromiseWindowFactory.d.ts +18 -18
  93. package/src/widgets/overlay/createHotPromiseWindowFactory.js +56 -56
  94. package/src/widgets/overlay/index.d.ts +11 -11
  95. package/src/widgets/overlay/index.js +11 -11
  96. package/src/widgets/variables.scss +144 -144
@@ -1,219 +1,219 @@
1
- @mixin cx-lookupfield(
2
- $name: "lookupfield",
3
- $state-style-map: $cx-std-field-state-style-map,
4
- $placeholder: $cx-input-placeholder,
5
- $empty-text: $cx-empty-text,
6
- $left-icon-state-style-map: $cx-input-left-icon-state-style-map,
7
- $clear-state-style-map: $cx-clear-state-style-map,
8
- $tool-state-style-map: $cx-input-right-icon-state-style-map,
9
- $icon-size: $cx-default-input-icon-size,
10
- $width: $cx-default-input-width,
11
- $tag-state-style-map: $cx-input-tag-state-style-map,
12
- $tag-clear-state-style-map: $cx-input-tag-clear-state-style-map,
13
- $besm: $cx-besm
14
- ) {
15
- $block: map-get($besm, block);
16
- $element: map-get($besm, element);
17
- $state: map-get($besm, state);
18
-
19
- $padding: cx-get-state-rule($state-style-map, default, padding);
20
- $border-radius-offset: round(cx-get-state-rule($tag-state-style-map, default, border-radius) * 0.25);
21
-
22
- .#{$block}#{$name} {
23
- cursor: pointer;
24
- width: $width;
25
- font: cx-get-state-rule($state-style-map, default, "font");
26
- font-size: cx-get-state-rule($state-style-map, default, "font-size");
27
-
28
- @include cxb-field($besm, $state-style-map, $input: false);
29
-
30
- &.#{$state}multiple {
31
- min-width: $cx-default-input-width;
32
- width: auto;
33
- }
34
-
35
- &.#{$state}readonly {
36
- pointer-events: none;
37
-
38
- & > .#{$element}#{$name}-input {
39
- padding-right: cx-right($padding);
40
- }
41
- }
42
- }
43
-
44
- .#{$element}#{$name}-input {
45
- @include cxe-field-input(
46
- $besm,
47
- $state-style-map,
48
- $placeholder: $placeholder,
49
- $input: false,
50
- $overrides: (
51
- default: (
52
- height: 100%,
53
- text-overflow: null,
54
- padding: cx-top($padding)
55
- cx-calc(cx-right($padding), $cx-default-clear-size, $cx-default-input-tag-spacing) cx-bottom($padding)
56
- cx-left($padding),
57
- )
58
- )
59
- );
60
-
61
- .#{$state}multiple > & {
62
- padding: 0 cx-calc(cx-right($padding), $cx-default-clear-size, $cx-default-input-tag-spacing)
63
- $cx-default-input-tag-spacing 0;
64
- align-items: center;
65
- flex-wrap: wrap;
66
- display: flex;
67
- }
68
-
69
- .#{$state}single > & {
70
- overflow: hidden;
71
- text-overflow: ellipsis;
72
- white-space: nowrap;
73
- display: block;
74
- flex-basis: 0%;
75
- flex-grow: 1;
76
- }
77
-
78
- .#{$state}icon > & {
79
- padding-left: cx-calc(2 * cx-left($padding), $icon-size);
80
- }
81
- }
82
-
83
- .#{$element}#{$name}-tag {
84
- display: inline-block;
85
- position: relative;
86
- box-sizing: border-box;
87
-
88
- @include cx-add-state-rules($tag-state-style-map, default);
89
-
90
- &:hover {
91
- @include cx-add-state-rules($tag-state-style-map, hover);
92
- }
93
-
94
- &.#{$state}readonly {
95
- padding-right: cx-right($padding);
96
- pointer-events: none;
97
- }
98
- }
99
-
100
- .#{$element}#{$name}-placeholder {
101
- color: $cx-default-input-placeholder-color;
102
-
103
- .#{$block}#{$name}.#{$state}multiple & {
104
- display: inline-block;
105
- margin: $cx-default-input-tag-spacing 0 0 $cx-default-input-tag-spacing;
106
- box-sizing: border-box;
107
- padding: cx-calc(cx-top($cx-default-input-padding), -$cx-default-input-tag-spacing)
108
- cx-calc(cx-right($cx-default-input-padding), -$cx-default-input-tag-spacing)
109
- cx-calc(cx-bottom($cx-default-input-padding), -$cx-default-input-tag-spacing)
110
- cx-calc(cx-left($cx-default-input-padding), -$cx-default-input-tag-spacing);
111
- }
112
- }
113
-
114
- .#{$element}#{$name}-tag-value {
115
- padding: 0 cx-calc($cx-default-input-tag-spacing, $border-radius-offset);
116
- display: inline-block;
117
- }
118
-
119
- .#{$element}#{$name}-tag-clear {
120
- @include cxe-field-button($besm, $tag-clear-state-style-map);
121
- }
122
-
123
- .#{$element}#{$name}-lookup-options {
124
- padding: 0;
125
- margin: 0;
126
- min-width: 100%;
127
- width: 100%;
128
- }
129
-
130
- .#{$element}#{$name}-query {
131
- @include cxe-field-input(
132
- $besm,
133
- $state-style-map,
134
- $placeholder: $placeholder,
135
- $width: calc(100% - 10px),
136
- $overrides: (
137
- default: (
138
- margin: 5px,
139
- flex: 0 0 auto,
140
- height: auto,
141
- )
142
- )
143
- );
144
- //put query field down when placed up
145
- .#{$state}place-up-right &,
146
- .#{$state}place-up &,
147
- .#{$state}place-up-left & {
148
- order: 1;
149
- }
150
- }
151
-
152
- .#{$element}#{$name}-dropdown {
153
- display: flex;
154
- flex-direction: column;
155
- height: 100%;
156
-
157
- &:focus {
158
- outline: none;
159
- }
160
- }
161
-
162
- .#{$element}#{$name}-message {
163
- font-size: smaller;
164
- padding: 10px;
165
- color: gray;
166
- font-style: italic;
167
-
168
- &.#{$state}error {
169
- color: #9e2f2d;
170
- }
171
- }
172
-
173
- .#{$element}#{$name}-scroll-container {
174
- overflow: auto;
175
- flex: 1 1 auto;
176
- }
177
-
178
- .#{$element}#{$name}-clear {
179
- @include cxe-field-button($besm, $clear-state-style-map);
180
-
181
- .#{$state}focus > & {
182
- @include cx-add-state-rules($clear-state-style-map, focus);
183
- }
184
- .#{$state}error > & {
185
- @include cx-add-state-rules($clear-state-style-map, error);
186
- }
187
- }
188
-
189
- .#{$element}#{$name}-tool {
190
- @include cxe-field-button($besm, $tool-state-style-map);
191
-
192
- .#{$state}disabled > & {
193
- border-width: 0;
194
- @include cx-add-state-rules($state-style-map, disabled);
195
- }
196
- .#{$state}focus > & {
197
- @include cx-add-state-rules($tool-state-style-map, focus);
198
- }
199
- .#{$state}error > & {
200
- @include cx-add-state-rules($tool-state-style-map, error);
201
- }
202
- }
203
-
204
- .#{$element}#{$name}-left-icon {
205
- @include cxe-field-button($besm, $left-icon-state-style-map);
206
- }
207
-
208
- .#{$element}#{$name}-icon {
209
- @include cxe-field-button-icon($besm, $icon-size);
210
- }
211
-
212
- .#{$element}#{$name}-empty-text {
213
- @include cxe-field-empty-text($empty-text);
214
- }
215
- }
216
-
217
- @if (cx-should-include("cx/widgets/LookupField")) {
218
- @include cx-lookupfield();
219
- }
1
+ @mixin cx-lookupfield(
2
+ $name: "lookupfield",
3
+ $state-style-map: $cx-std-field-state-style-map,
4
+ $placeholder: $cx-input-placeholder,
5
+ $empty-text: $cx-empty-text,
6
+ $left-icon-state-style-map: $cx-input-left-icon-state-style-map,
7
+ $clear-state-style-map: $cx-clear-state-style-map,
8
+ $tool-state-style-map: $cx-input-right-icon-state-style-map,
9
+ $icon-size: $cx-default-input-icon-size,
10
+ $width: $cx-default-input-width,
11
+ $tag-state-style-map: $cx-input-tag-state-style-map,
12
+ $tag-clear-state-style-map: $cx-input-tag-clear-state-style-map,
13
+ $besm: $cx-besm
14
+ ) {
15
+ $block: map-get($besm, block);
16
+ $element: map-get($besm, element);
17
+ $state: map-get($besm, state);
18
+
19
+ $padding: cx-get-state-rule($state-style-map, default, padding);
20
+ $border-radius-offset: round(cx-get-state-rule($tag-state-style-map, default, border-radius) * 0.25);
21
+
22
+ .#{$block}#{$name} {
23
+ cursor: pointer;
24
+ width: $width;
25
+ font: cx-get-state-rule($state-style-map, default, "font");
26
+ font-size: cx-get-state-rule($state-style-map, default, "font-size");
27
+
28
+ @include cxb-field($besm, $state-style-map, $input: false);
29
+
30
+ &.#{$state}multiple {
31
+ min-width: $cx-default-input-width;
32
+ width: auto;
33
+ }
34
+
35
+ &.#{$state}readonly {
36
+ pointer-events: none;
37
+
38
+ & > .#{$element}#{$name}-input {
39
+ padding-right: cx-right($padding);
40
+ }
41
+ }
42
+ }
43
+
44
+ .#{$element}#{$name}-input {
45
+ @include cxe-field-input(
46
+ $besm,
47
+ $state-style-map,
48
+ $placeholder: $placeholder,
49
+ $input: false,
50
+ $overrides: (
51
+ default: (
52
+ height: 100%,
53
+ text-overflow: null,
54
+ padding: cx-top($padding)
55
+ cx-calc(cx-right($padding), $cx-default-clear-size, $cx-default-input-tag-spacing) cx-bottom($padding)
56
+ cx-left($padding),
57
+ )
58
+ )
59
+ );
60
+
61
+ .#{$state}multiple > & {
62
+ padding: 0 cx-calc(cx-right($padding), $cx-default-clear-size, $cx-default-input-tag-spacing)
63
+ $cx-default-input-tag-spacing 0;
64
+ align-items: center;
65
+ flex-wrap: wrap;
66
+ display: flex;
67
+ }
68
+
69
+ .#{$state}single > & {
70
+ overflow: hidden;
71
+ text-overflow: ellipsis;
72
+ white-space: nowrap;
73
+ display: block;
74
+ flex-basis: 0%;
75
+ flex-grow: 1;
76
+ }
77
+
78
+ .#{$state}icon > & {
79
+ padding-left: cx-calc(2 * cx-left($padding), $icon-size);
80
+ }
81
+ }
82
+
83
+ .#{$element}#{$name}-tag {
84
+ display: inline-block;
85
+ position: relative;
86
+ box-sizing: border-box;
87
+
88
+ @include cx-add-state-rules($tag-state-style-map, default);
89
+
90
+ &:hover {
91
+ @include cx-add-state-rules($tag-state-style-map, hover);
92
+ }
93
+
94
+ &.#{$state}readonly {
95
+ padding-right: cx-right($padding);
96
+ pointer-events: none;
97
+ }
98
+ }
99
+
100
+ .#{$element}#{$name}-placeholder {
101
+ color: $cx-default-input-placeholder-color;
102
+
103
+ .#{$block}#{$name}.#{$state}multiple & {
104
+ display: inline-block;
105
+ margin: $cx-default-input-tag-spacing 0 0 $cx-default-input-tag-spacing;
106
+ box-sizing: border-box;
107
+ padding: cx-calc(cx-top($cx-default-input-padding), -$cx-default-input-tag-spacing)
108
+ cx-calc(cx-right($cx-default-input-padding), -$cx-default-input-tag-spacing)
109
+ cx-calc(cx-bottom($cx-default-input-padding), -$cx-default-input-tag-spacing)
110
+ cx-calc(cx-left($cx-default-input-padding), -$cx-default-input-tag-spacing);
111
+ }
112
+ }
113
+
114
+ .#{$element}#{$name}-tag-value {
115
+ padding: 0 cx-calc($cx-default-input-tag-spacing, $border-radius-offset);
116
+ display: inline-block;
117
+ }
118
+
119
+ .#{$element}#{$name}-tag-clear {
120
+ @include cxe-field-button($besm, $tag-clear-state-style-map);
121
+ }
122
+
123
+ .#{$element}#{$name}-lookup-options {
124
+ padding: 0;
125
+ margin: 0;
126
+ min-width: 100%;
127
+ width: 100%;
128
+ }
129
+
130
+ .#{$element}#{$name}-query {
131
+ @include cxe-field-input(
132
+ $besm,
133
+ $state-style-map,
134
+ $placeholder: $placeholder,
135
+ $width: calc(100% - 10px),
136
+ $overrides: (
137
+ default: (
138
+ margin: 5px,
139
+ flex: 0 0 auto,
140
+ height: auto,
141
+ )
142
+ )
143
+ );
144
+ //put query field down when placed up
145
+ .#{$state}place-up-right &,
146
+ .#{$state}place-up &,
147
+ .#{$state}place-up-left & {
148
+ order: 1;
149
+ }
150
+ }
151
+
152
+ .#{$element}#{$name}-dropdown {
153
+ display: flex;
154
+ flex-direction: column;
155
+ height: 100%;
156
+
157
+ &:focus {
158
+ outline: none;
159
+ }
160
+ }
161
+
162
+ .#{$element}#{$name}-message {
163
+ font-size: smaller;
164
+ padding: 10px;
165
+ color: gray;
166
+ font-style: italic;
167
+
168
+ &.#{$state}error {
169
+ color: #9e2f2d;
170
+ }
171
+ }
172
+
173
+ .#{$element}#{$name}-scroll-container {
174
+ overflow: auto;
175
+ flex: 1 1 auto;
176
+ }
177
+
178
+ .#{$element}#{$name}-clear {
179
+ @include cxe-field-button($besm, $clear-state-style-map);
180
+
181
+ .#{$state}focus > & {
182
+ @include cx-add-state-rules($clear-state-style-map, focus);
183
+ }
184
+ .#{$state}error > & {
185
+ @include cx-add-state-rules($clear-state-style-map, error);
186
+ }
187
+ }
188
+
189
+ .#{$element}#{$name}-tool {
190
+ @include cxe-field-button($besm, $tool-state-style-map);
191
+
192
+ .#{$state}disabled > & {
193
+ border-width: 0;
194
+ @include cx-add-state-rules($state-style-map, disabled);
195
+ }
196
+ .#{$state}focus > & {
197
+ @include cx-add-state-rules($tool-state-style-map, focus);
198
+ }
199
+ .#{$state}error > & {
200
+ @include cx-add-state-rules($tool-state-style-map, error);
201
+ }
202
+ }
203
+
204
+ .#{$element}#{$name}-left-icon {
205
+ @include cxe-field-button($besm, $left-icon-state-style-map);
206
+ }
207
+
208
+ .#{$element}#{$name}-icon {
209
+ @include cxe-field-button-icon($besm, $icon-size);
210
+ }
211
+
212
+ .#{$element}#{$name}-empty-text {
213
+ @include cxe-field-empty-text($empty-text);
214
+ }
215
+ }
216
+
217
+ @if (cx-should-include("cx/widgets/LookupField")) {
218
+ @include cx-lookupfield();
219
+ }
@@ -1,118 +1,118 @@
1
- @mixin cx-monthpicker($name: "monthpicker", $state-style-map: $cx-input-state-style-map, $besm: $cx-besm) {
2
- $block: map-get($besm, block);
3
- $element: map-get($besm, element);
4
- $state: map-get($besm, state);
5
-
6
- .#{$block}#{$name} {
7
- overflow-y: scroll;
8
- overflow-x: hidden;
9
- min-height: 10em;
10
- max-height: 30em; //100vh;
11
- height: 100%;
12
- position: relative;
13
- width: 23em;
14
- overflow-anchor: none;
15
- touch-action: pan-y;
16
-
17
- @include cxe-field-input($besm, $state-style-map, $input: false);
18
-
19
- table {
20
- border-spacing: 0;
21
- width: 100%;
22
- font-size: 0.9em;
23
- }
24
-
25
- $border-color: cx-get-state-rule($state-style-map, default, border-color);
26
-
27
- th,
28
- td {
29
- border-top: 1px solid transparentize($border-color, 0.5);
30
- -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
31
- }
32
-
33
- tbody:not(:first-child) {
34
- tr:first-child {
35
- th,
36
- td {
37
- border-top: 1px solid $border-color;
38
- }
39
- }
40
- }
41
-
42
- th,
43
- td {
44
- text-align: center;
45
- font-size: $cx-default-monthpicker-font-size;
46
- font-weight: $cx-default-monthpicker-font-weight;
47
- line-height: 2em;
48
- cursor: pointer;
49
- -webkit-user-select: none;
50
- -ms-user-select: none;
51
- -moz-user-select: none;
52
- user-select: none;
53
- }
54
-
55
- th {
56
- padding: 0 0.5em;
57
- color: lightgray;
58
- }
59
-
60
- .#{$element}#{$name}-year {
61
- font-size: 120%;
62
- color: gray;
63
- }
64
-
65
- td {
66
- padding: 0.5em 1em;
67
- }
68
-
69
- td.#{$state}outside {
70
- color: lightgray;
71
- }
72
-
73
- td.#{$state}unselectable {
74
- @include cx-add-state-rules($cx-list-item, disabled);
75
- }
76
-
77
- td.#{$state}selected {
78
- border-color: transparent;
79
- @include cx-add-state-rules($cx-list-item, selected);
80
-
81
- &:hover {
82
- @include cx-add-state-rules($cx-list-item, selected-hover);
83
- }
84
- }
85
-
86
- td.#{$state}cursor,
87
- th.#{$state}cursor {
88
- @include cx-add-state-rules($cx-list-item, hover);
89
- }
90
-
91
- &:focus {
92
- td.#{$state}selected {
93
- @include cx-add-state-rules($cx-list-item, selected);
94
- }
95
-
96
- td.#{$state}cursor,
97
- th.#{$state}cursor {
98
- @include cx-add-state-rules($cx-list-item, selected-cursor);
99
- }
100
- }
101
-
102
- td.#{$state}handle {
103
- //@include cx-add-state-rules($cx-list-item, selected-cursor);
104
- touch-action: none;
105
- }
106
- }
107
-
108
- .#{$block}#{$name}.#{$state}disabled {
109
- background-color: transparent;
110
- border-color: transparent;
111
- color: darken(#fff, 18);
112
- pointer-events: none;
113
- }
114
- }
115
-
116
- @if (cx-should-include("cx/widgets/MonthPicker")) {
117
- @include cx-monthpicker();
118
- }
1
+ @mixin cx-monthpicker($name: "monthpicker", $state-style-map: $cx-input-state-style-map, $besm: $cx-besm) {
2
+ $block: map-get($besm, block);
3
+ $element: map-get($besm, element);
4
+ $state: map-get($besm, state);
5
+
6
+ .#{$block}#{$name} {
7
+ overflow-y: scroll;
8
+ overflow-x: hidden;
9
+ min-height: 10em;
10
+ max-height: 30em; //100vh;
11
+ height: 100%;
12
+ position: relative;
13
+ width: 23em;
14
+ overflow-anchor: none;
15
+ touch-action: pan-y;
16
+
17
+ @include cxe-field-input($besm, $state-style-map, $input: false);
18
+
19
+ table {
20
+ border-spacing: 0;
21
+ width: 100%;
22
+ font-size: 0.9em;
23
+ }
24
+
25
+ $border-color: cx-get-state-rule($state-style-map, default, border-color);
26
+
27
+ th,
28
+ td {
29
+ border-top: 1px solid transparentize($border-color, 0.5);
30
+ -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
31
+ }
32
+
33
+ tbody:not(:first-child) {
34
+ tr:first-child {
35
+ th,
36
+ td {
37
+ border-top: 1px solid $border-color;
38
+ }
39
+ }
40
+ }
41
+
42
+ th,
43
+ td {
44
+ text-align: center;
45
+ font-size: $cx-default-monthpicker-font-size;
46
+ font-weight: $cx-default-monthpicker-font-weight;
47
+ line-height: 2em;
48
+ cursor: pointer;
49
+ -webkit-user-select: none;
50
+ -ms-user-select: none;
51
+ -moz-user-select: none;
52
+ user-select: none;
53
+ }
54
+
55
+ th {
56
+ padding: 0 0.5em;
57
+ color: lightgray;
58
+ }
59
+
60
+ .#{$element}#{$name}-year {
61
+ font-size: 120%;
62
+ color: gray;
63
+ }
64
+
65
+ td {
66
+ padding: 0.5em 1em;
67
+ }
68
+
69
+ td.#{$state}outside {
70
+ color: lightgray;
71
+ }
72
+
73
+ td.#{$state}unselectable {
74
+ @include cx-add-state-rules($cx-list-item, disabled);
75
+ }
76
+
77
+ td.#{$state}selected {
78
+ border-color: transparent;
79
+ @include cx-add-state-rules($cx-list-item, selected);
80
+
81
+ &:hover {
82
+ @include cx-add-state-rules($cx-list-item, selected-hover);
83
+ }
84
+ }
85
+
86
+ td.#{$state}cursor,
87
+ th.#{$state}cursor {
88
+ @include cx-add-state-rules($cx-list-item, hover);
89
+ }
90
+
91
+ &:focus {
92
+ td.#{$state}selected {
93
+ @include cx-add-state-rules($cx-list-item, selected);
94
+ }
95
+
96
+ td.#{$state}cursor,
97
+ th.#{$state}cursor {
98
+ @include cx-add-state-rules($cx-list-item, selected-cursor);
99
+ }
100
+ }
101
+
102
+ td.#{$state}handle {
103
+ //@include cx-add-state-rules($cx-list-item, selected-cursor);
104
+ touch-action: none;
105
+ }
106
+ }
107
+
108
+ .#{$block}#{$name}.#{$state}disabled {
109
+ background-color: transparent;
110
+ border-color: transparent;
111
+ color: darken(#fff, 18);
112
+ pointer-events: none;
113
+ }
114
+ }
115
+
116
+ @if (cx-should-include("cx/widgets/MonthPicker")) {
117
+ @include cx-monthpicker();
118
+ }