cx 25.1.0 → 25.1.2

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 (106) hide show
  1. package/dist/data.js +9 -1
  2. package/dist/manifest.js +731 -731
  3. package/dist/widgets.js +18 -4
  4. package/package.json +32 -32
  5. package/src/charts/Legend.js +167 -167
  6. package/src/charts/Legend.scss +40 -40
  7. package/src/charts/LegendEntry.js +128 -128
  8. package/src/charts/LegendEntry.scss +27 -27
  9. package/src/charts/PieChart.d.ts +92 -92
  10. package/src/charts/PieChart.js +529 -529
  11. package/src/charts/axis/Axis.d.ts +113 -113
  12. package/src/charts/axis/Axis.js +280 -280
  13. package/src/charts/axis/CategoryAxis.d.ts +30 -30
  14. package/src/charts/axis/CategoryAxis.js +241 -241
  15. package/src/charts/axis/NumericAxis.js +351 -351
  16. package/src/charts/axis/Stack.js +55 -55
  17. package/src/charts/axis/TimeAxis.d.ts +28 -28
  18. package/src/charts/axis/TimeAxis.js +611 -611
  19. package/src/charts/helpers/PointReducer.js +47 -47
  20. package/src/charts/helpers/SnapPointFinder.js +69 -69
  21. package/src/data/Binding.spec.js +69 -69
  22. package/src/data/Expression.js +229 -221
  23. package/src/data/Expression.spec.js +229 -217
  24. package/src/data/StringTemplate.js +92 -92
  25. package/src/data/StringTemplate.spec.js +127 -110
  26. package/src/data/getAccessor.spec.js +11 -11
  27. package/src/hooks/createLocalStorageRef.d.ts +3 -3
  28. package/src/hooks/createLocalStorageRef.js +20 -20
  29. package/src/index.scss +6 -6
  30. package/src/ui/Culture.d.ts +57 -57
  31. package/src/ui/Culture.js +139 -139
  32. package/src/ui/FocusManager.js +171 -171
  33. package/src/ui/Format.js +108 -108
  34. package/src/ui/HoverSync.js +147 -147
  35. package/src/ui/Instance.d.ts +72 -72
  36. package/src/ui/Instance.js +614 -614
  37. package/src/ui/Repeater.d.ts +61 -61
  38. package/src/ui/index.d.ts +42 -42
  39. package/src/ui/layout/ContentPlaceholder.d.ts +19 -19
  40. package/src/ui/layout/ContentPlaceholder.js +105 -105
  41. package/src/ui/layout/ContentPlaceholder.spec.js +579 -579
  42. package/src/ui/layout/LabelsTopLayout.js +134 -134
  43. package/src/util/date/encodeDate.d.ts +1 -1
  44. package/src/util/date/encodeDate.js +8 -8
  45. package/src/util/date/encodeDateWithTimezoneOffset.d.ts +1 -1
  46. package/src/util/date/index.d.ts +11 -11
  47. package/src/util/date/index.js +11 -11
  48. package/src/util/date/parseDateInvariant.d.ts +3 -3
  49. package/src/util/date/parseDateInvariant.js +20 -20
  50. package/src/util/getSearchQueryPredicate.js +59 -59
  51. package/src/util/index.d.ts +51 -51
  52. package/src/util/index.js +54 -54
  53. package/src/util/isValidIdentifierName.d.ts +1 -1
  54. package/src/util/isValidIdentifierName.js +5 -5
  55. package/src/util/isValidIdentifierName.spec.js +33 -33
  56. package/src/util/scss/add-rules.scss +38 -38
  57. package/src/widgets/CxCredit.scss +37 -37
  58. package/src/widgets/HighlightedSearchText.js +36 -36
  59. package/src/widgets/HighlightedSearchText.scss +18 -18
  60. package/src/widgets/List.scss +91 -91
  61. package/src/widgets/drag-drop/DropZone.js +214 -214
  62. package/src/widgets/form/Calendar.js +618 -618
  63. package/src/widgets/form/Calendar.scss +196 -196
  64. package/src/widgets/form/Checkbox.scss +127 -127
  65. package/src/widgets/form/ColorField.js +397 -397
  66. package/src/widgets/form/ColorField.scss +96 -96
  67. package/src/widgets/form/ColorPicker.scss +283 -283
  68. package/src/widgets/form/DateTimeField.js +576 -576
  69. package/src/widgets/form/DateTimePicker.js +392 -392
  70. package/src/widgets/form/LookupField.d.ts +179 -179
  71. package/src/widgets/form/LookupField.scss +219 -219
  72. package/src/widgets/form/MonthField.d.ts +99 -95
  73. package/src/widgets/form/MonthField.js +523 -517
  74. package/src/widgets/form/MonthPicker.d.ts +76 -74
  75. package/src/widgets/form/MonthPicker.js +641 -633
  76. package/src/widgets/form/MonthPicker.scss +118 -118
  77. package/src/widgets/form/NumberField.js +459 -459
  78. package/src/widgets/form/NumberField.scss +61 -61
  79. package/src/widgets/form/Radio.scss +121 -121
  80. package/src/widgets/form/Select.scss +99 -99
  81. package/src/widgets/form/Slider.scss +118 -118
  82. package/src/widgets/form/Switch.scss +140 -140
  83. package/src/widgets/form/TextArea.scss +43 -43
  84. package/src/widgets/form/TextField.js +290 -290
  85. package/src/widgets/form/TextField.scss +55 -55
  86. package/src/widgets/form/UploadButton.d.ts +34 -34
  87. package/src/widgets/form/variables.scss +353 -353
  88. package/src/widgets/grid/Grid.d.ts +442 -442
  89. package/src/widgets/grid/Grid.js +3414 -3414
  90. package/src/widgets/grid/Grid.scss +637 -637
  91. package/src/widgets/grid/GridRow.js +228 -228
  92. package/src/widgets/grid/TreeNode.d.ts +23 -23
  93. package/src/widgets/grid/TreeNode.scss +88 -88
  94. package/src/widgets/grid/variables.scss +133 -133
  95. package/src/widgets/nav/Menu.scss +74 -74
  96. package/src/widgets/overlay/Dropdown.js +612 -612
  97. package/src/widgets/overlay/FlyweightTooltipTracker.js +39 -39
  98. package/src/widgets/overlay/Overlay.d.ts +73 -73
  99. package/src/widgets/overlay/Tooltip.js +303 -303
  100. package/src/widgets/overlay/Window.js +202 -202
  101. package/src/widgets/overlay/captureMouse.js +124 -124
  102. package/src/widgets/overlay/createHotPromiseWindowFactory.d.ts +18 -18
  103. package/src/widgets/overlay/createHotPromiseWindowFactory.js +56 -56
  104. package/src/widgets/overlay/index.d.ts +11 -11
  105. package/src/widgets/overlay/index.js +11 -11
  106. package/src/widgets/variables.scss +144 -144
@@ -1,637 +1,637 @@
1
- @mixin cx-grid(
2
- $name: "grid",
3
- $header-state-style-map: $cx-grid-header-state-style-map,
4
- $data-state-style-map: $cx-grid-data-state-style-map,
5
- $cell-cursor-style: $cx-grid-cell-cursor-style,
6
- $icon-size: $cx-default-icon-size,
7
- $besm: $cx-besm
8
- ) {
9
- $block: map-get($besm, block);
10
- $element: map-get($besm, element);
11
- $state: map-get($besm, state);
12
- $mod: map-get($besm, mod);
13
-
14
- .#{$block}#{$name} {
15
- box-sizing: border-box;
16
- position: relative;
17
- font-size: $cx-default-grid-font-size;
18
- box-shadow: $cx-default-grid-box-shadow;
19
- border-radius: $cx-default-grid-border-radius;
20
-
21
- @include cx-add-state-rules($cx-list, default);
22
-
23
- &:focus {
24
- @include cx-add-state-rules($cx-list, focus);
25
- }
26
-
27
- table {
28
- border-spacing: 0;
29
- border-collapse: collapse;
30
- width: 100%;
31
- position: relative;
32
- }
33
-
34
- .#{$state}aligned-left {
35
- text-align: left;
36
- }
37
-
38
- .#{$state}aligned-right {
39
- text-align: right;
40
- }
41
-
42
- .#{$state}aligned-center {
43
- text-align: center;
44
- }
45
-
46
- &.#{$state}scrollable {
47
- overflow: hidden;
48
- display: flex;
49
- flex-direction: row;
50
- align-items: stretch;
51
-
52
- &.#{$state}border {
53
- border: 1px solid $cx-default-grid-border-color;
54
-
55
- table {
56
- border: none;
57
- }
58
-
59
- .#{$element}#{$name}-header:first-child {
60
- th {
61
- border-top: none;
62
- }
63
- }
64
-
65
- th {
66
- border-left: none;
67
- }
68
-
69
- th:last-child {
70
- border-right: none;
71
- }
72
- }
73
-
74
- & > .#{$element}#{$name}-scroll-area {
75
- overflow-y: auto;
76
- flex: 1 1 0%;
77
- -webkit-overflow-scrolling: touch;
78
-
79
- &.#{$state}fixed-header
80
- > .#{$element}#{$name}-table-wrapper
81
- > table
82
- > .#{$element}#{$name}-header:first-child {
83
- visibility: hidden;
84
- }
85
-
86
- //used to cut off the negative margin
87
- & > .#{$element}#{$name}-table-wrapper {
88
- overflow: hidden;
89
- display: inline-block; //preserve content width
90
- vertical-align: top;
91
- min-width: 100%;
92
- min-height: 100%;
93
- }
94
- }
95
- }
96
-
97
- &.#{$state}resizable {
98
- .#{$element}#{$name}-data td,
99
- .#{$element}#{$name}-group-footer td,
100
- .#{$element}#{$name}-group-header td {
101
- box-sizing: border-box;
102
- overflow: hidden;
103
- text-overflow: ellipsis;
104
- }
105
-
106
- .cxe-grid-fixed-header .cxe-grid-col-header:last-child {
107
- max-width: 100%;
108
- width: 100%;
109
- }
110
- }
111
-
112
- &.#{$state}border {
113
- table {
114
- border: 1px solid $cx-default-grid-border-color;
115
- }
116
- }
117
-
118
- &.#{$state}vlines {
119
- td:not(:last-child),
120
- th:not(:last-child) {
121
- border-right-width: 1px;
122
- border-right-style: solid;
123
- border-right-color: $cx-default-grid-border-color;
124
- }
125
- }
126
-
127
- &.#{$mod}responsive {
128
- width: 100%;
129
-
130
- & > .#{$element}#{$name}-scroll-area {
131
- overflow-x: auto;
132
- }
133
- }
134
-
135
- &.#{$mod}fixed-layout {
136
- table {
137
- table-layout: fixed;
138
- width: auto;
139
- }
140
- }
141
-
142
- &.#{$mod}contain {
143
- table {
144
- contain: layout paint;
145
- }
146
- }
147
-
148
- &.#{$mod}nowrap {
149
- .cxe-grid-data td,
150
- .cxe-grid-fixed-footer td,
151
- .cxe-grid-fixed-fixed-footer td {
152
- white-space: nowrap;
153
- }
154
- }
155
- }
156
-
157
- .#{$element}#{$name}-table-wrapper {
158
- overflow-anchor: none;
159
- }
160
-
161
- .#{$element}#{$name}-cell-clip {
162
- overflow: hidden;
163
- text-overflow: ellipsis;
164
- }
165
-
166
- .#{$element}#{$name}-row-number::after {
167
- counter-increment: cx-row-number;
168
- content: counter(cx-row-number);
169
- }
170
-
171
- .#{$element}#{$name}-fixed-header {
172
- overflow: hidden;
173
- position: absolute;
174
- display: none;
175
- left: 0;
176
- top: 0;
177
- right: 0;
178
-
179
- & > table {
180
- width: auto;
181
- table-layout: fixed;
182
- }
183
- }
184
-
185
- .#{$element}#{$name}-fixed-fixed-header {
186
- overflow: hidden;
187
- position: absolute;
188
- display: none;
189
- left: 0;
190
- top: 0;
191
- box-sizing: border-box;
192
- border-right: 1px solid $cx-default-grid-border-color;
193
-
194
- & > table {
195
- width: auto;
196
- table-layout: fixed;
197
- }
198
- }
199
-
200
- .#{$element}#{$name}-fixed-footer {
201
- overflow: hidden;
202
- position: absolute;
203
- display: none;
204
- left: 0;
205
- bottom: 0;
206
- right: 0;
207
-
208
- & > table {
209
- width: auto;
210
- table-layout: fixed;
211
- }
212
- }
213
-
214
- .#{$element}#{$name}-fixed-fixed-footer {
215
- overflow: hidden;
216
- position: absolute;
217
- display: none;
218
- left: 0;
219
- bottom: 0;
220
- border-right: 1px solid $cx-default-grid-border-color;
221
- box-sizing: border-box;
222
-
223
- & > table {
224
- width: auto;
225
- table-layout: fixed;
226
- }
227
- }
228
-
229
- .#{$element}#{$name}-fixed-footer-corner {
230
- width: 100%;
231
- }
232
-
233
- .#{$element}#{$name}-empty-text td {
234
- color: #aaa;
235
- padding: 2rem;
236
- }
237
-
238
- .#{$element}#{$name}-col-header {
239
- text-align: left;
240
- padding: cx-get-state-rule($data-state-style-map, default, padding);
241
- box-sizing: border-box;
242
- position: relative;
243
- -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
244
- -webkit-user-select: none;
245
-
246
- @include cx-add-state-rules($header-state-style-map, default);
247
-
248
- .#{$state}header-default & {
249
- border-width: 1px;
250
- border-style: solid;
251
- position: relative;
252
- }
253
-
254
- .#{$state}header-plain & {
255
- background-color: transparent;
256
- }
257
-
258
- &.#{$state}sortable {
259
- cursor: pointer;
260
- user-select: none;
261
-
262
- &.#{$state}sorted-asc,
263
- &.#{$state}sorted-desc {
264
- @include cx-add-state-rules($header-state-style-map, sorted);
265
-
266
- &:hover {
267
- @include cx-add-state-rules($header-state-style-map, sorted-hover);
268
- }
269
- }
270
-
271
- &:hover,
272
- .#{$element}#{$name}-fixed-header &:hover {
273
- @include cx-add-state-rules($header-state-style-map, hover);
274
- }
275
-
276
- .#{$element}#{$name}-fixed-header & {
277
- &.#{$state}sorted-asc,
278
- &.#{$state}sorted-desc {
279
- &:hover {
280
- @include cx-add-state-rules($header-state-style-map, sorted-hover);
281
- }
282
- }
283
- }
284
- }
285
-
286
- &.#{$state}tool {
287
- transition: padding-left 0.2s;
288
- padding-right: cx-calc(15px, $icon-size);
289
- }
290
-
291
- &.#{$state}sortable:not(.#{$state}aligned-right) {
292
- padding-right: cx-calc(5px, $icon-size);
293
-
294
- .#{$element}#{$name}-column-sort-icon {
295
- right: 2px;
296
- }
297
-
298
- &.#{$state}tool.#{$state}sorted-asc,
299
- &.#{$state}tool.#{$state}sorted-desc {
300
- padding-left: cx-calc(5px, $icon-size);
301
-
302
- .#{$element}#{$name}-column-sort-icon {
303
- left: 2px;
304
- }
305
- }
306
- }
307
-
308
- &.#{$state}sortable.#{$state}aligned-center {
309
- padding-left: cx-calc(5px, $icon-size);
310
- }
311
-
312
- &.#{$state}sortable.#{$state}aligned-right {
313
- padding-left: cx-calc(5px, $icon-size);
314
-
315
- .#{$element}#{$name}-column-sort-icon {
316
- left: 2px;
317
- }
318
- }
319
- }
320
-
321
- .#{$element}#{$name}-column-sort-icon {
322
- width: $icon-size;
323
- height: $icon-size;
324
- top: 50%;
325
- margin-top: -$icon-size * 0.5;
326
- position: absolute;
327
- transition: transform 0.1s linear;
328
-
329
- .#{$state}sorted-desc > & {
330
- transform: rotate(180deg);
331
- }
332
- }
333
-
334
- .#{$element}#{$name}-data {
335
- -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
336
- background-color: cx-get-state-rule($data-state-style-map, default, background-color);
337
-
338
- &.#{$state}alternate {
339
- @include cx-add-state-rules($data-state-style-map, alternate);
340
- }
341
-
342
- td {
343
- padding: 0;
344
- border-top: 1px solid cx-get-state-rule($data-state-style-map, default, border-color);
345
- line-height: cx-get-state-rule($data-state-style-map, default, line-height);
346
- font-weight: cx-get-state-rule($data-state-style-map, default, font-weight);
347
-
348
- &:empty::before {
349
- content: "-";
350
- visibility: hidden;
351
- }
352
- }
353
-
354
- td.#{$state}pad {
355
- padding: cx-get-state-rule($data-state-style-map, default, padding);
356
- }
357
-
358
- .#{$state}selectable & {
359
- &:hover,
360
- &.#{$state}hover {
361
- @include cx-add-state-rules($cx-list-item, hover);
362
- }
363
-
364
- &.#{$state}cursor {
365
- @include cx-add-state-rules($cx-list-item, hover);
366
- }
367
-
368
- &.#{$state}selected {
369
- @include cx-add-state-rules($cx-list-item, selected);
370
-
371
- &.#{$state}cursor {
372
- @include cx-add-state-rules($cx-list-item, selected-cursor);
373
- }
374
- }
375
- }
376
-
377
- .#{$state}focused &,
378
- :focus & {
379
- &.#{$state}cursor {
380
- @include cx-add-state-rules($cx-list-item, cursor);
381
- }
382
-
383
- &.#{$state}selected {
384
- &.#{$state}cursor {
385
- @include cx-add-state-rules($cx-list-item, selected-cursor);
386
- }
387
- }
388
-
389
- &:active {
390
- @include cx-add-state-rules($cx-list-item, active);
391
- }
392
- }
393
-
394
- .#{$state}drag-move &.#{$state}dragged {
395
- display: none;
396
- }
397
-
398
- .#{$state}drag-copy &.#{$state}dragged {
399
- opacity: 0.5;
400
- }
401
-
402
- &.#{$state}draggable {
403
- touch-action: none;
404
- }
405
-
406
- &.#{$state}dummy {
407
- td {
408
- box-sizing: border-box;
409
- }
410
- }
411
-
412
- &.#{$state}over {
413
- background: orange !important;
414
- }
415
- }
416
-
417
- .#{$element}#{$name}-dropzone {
418
- position: relative;
419
- padding: 0;
420
-
421
- .#{$state}drop-preview & {
422
- border-top: 1px solid $cx-default-grid-border-color;
423
-
424
- &:after {
425
- position: absolute;
426
- left: 3px;
427
- right: 3px;
428
- top: 3px;
429
- bottom: 3px;
430
- border: 1px dotted gray;
431
- content: " ";
432
- }
433
- }
434
-
435
- .#{$state}drop-insertion & {
436
- height: 0;
437
-
438
- &:after {
439
- position: absolute;
440
- left: 0;
441
- right: 0;
442
- top: 0;
443
- bottom: 0;
444
- border-top: 1px solid black;
445
- content: " ";
446
- box-shadow: 0 0 2px black;
447
- }
448
- }
449
- }
450
-
451
- .#{$element}#{$name}-group-caption {
452
- font-weight: bold;
453
- font-size: 115%;
454
-
455
- td {
456
- padding: cx-get-state-rule($data-state-style-map, default, padding);
457
- }
458
-
459
- &:not(:first-child) {
460
- td {
461
- padding-top: $cx-default-grid-caption-gap;
462
- }
463
- }
464
- }
465
-
466
- @for $i from 1 through 4 {
467
- .#{$element}#{$name}-group-caption.#{$state}level-#{$i} td {
468
- @include cx-add-state-rules($cx-grid-group-caption-level-style-map, level-#{$i});
469
- }
470
- }
471
-
472
- .#{$element}#{$name}-group-footer {
473
- td {
474
- box-sizing: border-box;
475
- &.#{$state}pad {
476
- padding: cx-get-state-rule($data-state-style-map, default, padding);
477
- }
478
- }
479
- }
480
-
481
- @for $i from 1 through 4 {
482
- .#{$element}#{$name}-group-footer.#{$state}level-#{$i} td {
483
- @include cx-add-state-rules($cx-grid-group-footer-level-style-map, level-#{$i});
484
- }
485
- }
486
-
487
- .#{$block}#{$name}.#{$state}cell-editable {
488
- .#{$element}#{$name}-data td {
489
- &:hover {
490
- background: rgba(gray, 0.05);
491
- }
492
-
493
- &.#{$state}cellected {
494
- position: relative;
495
- user-select: none;
496
- overflow: visible;
497
-
498
- &:after {
499
- position: absolute;
500
- pointer-events: none;
501
- content: " ";
502
- @include cx-add-rules($cell-cursor-style);
503
- }
504
-
505
- &:last-child::after {
506
- //prevent horizontal scroll for fixed columns
507
- right: 0;
508
- }
509
- }
510
-
511
- &.#{$element}#{$name}-cell-editor {
512
- position: relative;
513
- user-select: none;
514
- overflow: visible;
515
- }
516
- }
517
- }
518
-
519
- .#{$element}#{$name}-cell-editor-wrap {
520
- position: absolute;
521
- top: -1px;
522
- bottom: 0;
523
- left: 0;
524
- right: 0;
525
- width: 100%;
526
- height: calc(100% + 2px);
527
-
528
- & > *:only-child {
529
- width: 100%;
530
- height: 100%;
531
- top: 0;
532
- left: 0;
533
- }
534
- }
535
-
536
- .#{$block}#{$name}.#{$state}buffered,
537
- .#{$block}#{$name}.#{$state}fixed-columns {
538
- .#{$element}#{$name}-data {
539
- white-space: nowrap;
540
- }
541
- }
542
-
543
- .#{$block}#{$name}.#{$state}fixed-columns {
544
- > .#{$element}#{$name}-scroll-area {
545
- overflow-x: scroll;
546
- }
547
- }
548
-
549
- .#{$element}#{$name}-scroll-area {
550
- &.#{$state}fixed-footer
551
- > .#{$element}#{$name}-table-wrapper
552
- > table
553
- > .#{$element}#{$name}-group-footer:last-child {
554
- visibility: hidden;
555
-
556
- td {
557
- border: none;
558
- }
559
- }
560
- }
561
-
562
- .#{$element}#{$name}-fixed-scroll-area {
563
- overflow-x: scroll;
564
- overflow-y: hidden;
565
- border-color: $cx-default-grid-border-color;
566
- border-right-style: solid;
567
- border-right-width: 1px;
568
-
569
- &.#{$state}fixed-footer
570
- > .#{$element}#{$name}-fixed-table-wrapper
571
- > table
572
- > .#{$element}#{$name}-group-footer:last-child {
573
- visibility: hidden;
574
-
575
- td {
576
- border: none;
577
- }
578
- }
579
- }
580
-
581
- .#{$element}#{$name}-col-header-tool {
582
- position: absolute;
583
- right: 0;
584
- top: 0;
585
- bottom: 0;
586
- }
587
-
588
- .#{$element}#{$name}-col-resizer {
589
- position: absolute;
590
- right: 0;
591
- top: 0;
592
- bottom: 0;
593
- width: 5px;
594
- cursor: col-resize;
595
- }
596
-
597
- .#{$element}#{$name}-col-resizer-prev-col {
598
- position: absolute;
599
- left: 0;
600
- top: 0;
601
- bottom: 0;
602
- width: 5px;
603
- cursor: col-resize;
604
- }
605
-
606
- .#{$element}#{$name}-resize-overlay {
607
- position: absolute;
608
- display: block;
609
- pointer-events: none;
610
- top: 0;
611
- bottom: 0;
612
- left: 0;
613
- width: 0;
614
- border-right: 3px solid $cx-default-grid-border-color;
615
- background: rgba($cx-default-grid-border-color, 0.15);
616
- box-sizing: border-box;
617
- }
618
-
619
- .#{$element}#{$name}-col-header-drag-clone {
620
- border: 1px solid $cx-default-grid-border-color;
621
- padding: cx-get-state-rule($data-state-style-map, default, padding);
622
- @include cx-add-state-rules($header-state-style-map, default);
623
- box-sizing: border-box;
624
- font-size: $cx-default-grid-font-size;
625
- }
626
-
627
- .#{$element}#{$name}-col-insertion-marker {
628
- border: 1px solid black;
629
- position: absolute;
630
- top: 0;
631
- height: calc(100% - 1px);
632
- }
633
- }
634
-
635
- @if (cx-should-include("cx/widgets/Grid")) {
636
- @include cx-grid();
637
- }
1
+ @mixin cx-grid(
2
+ $name: "grid",
3
+ $header-state-style-map: $cx-grid-header-state-style-map,
4
+ $data-state-style-map: $cx-grid-data-state-style-map,
5
+ $cell-cursor-style: $cx-grid-cell-cursor-style,
6
+ $icon-size: $cx-default-icon-size,
7
+ $besm: $cx-besm
8
+ ) {
9
+ $block: map-get($besm, block);
10
+ $element: map-get($besm, element);
11
+ $state: map-get($besm, state);
12
+ $mod: map-get($besm, mod);
13
+
14
+ .#{$block}#{$name} {
15
+ box-sizing: border-box;
16
+ position: relative;
17
+ font-size: $cx-default-grid-font-size;
18
+ box-shadow: $cx-default-grid-box-shadow;
19
+ border-radius: $cx-default-grid-border-radius;
20
+
21
+ @include cx-add-state-rules($cx-list, default);
22
+
23
+ &:focus {
24
+ @include cx-add-state-rules($cx-list, focus);
25
+ }
26
+
27
+ table {
28
+ border-spacing: 0;
29
+ border-collapse: collapse;
30
+ width: 100%;
31
+ position: relative;
32
+ }
33
+
34
+ .#{$state}aligned-left {
35
+ text-align: left;
36
+ }
37
+
38
+ .#{$state}aligned-right {
39
+ text-align: right;
40
+ }
41
+
42
+ .#{$state}aligned-center {
43
+ text-align: center;
44
+ }
45
+
46
+ &.#{$state}scrollable {
47
+ overflow: hidden;
48
+ display: flex;
49
+ flex-direction: row;
50
+ align-items: stretch;
51
+
52
+ &.#{$state}border {
53
+ border: 1px solid $cx-default-grid-border-color;
54
+
55
+ table {
56
+ border: none;
57
+ }
58
+
59
+ .#{$element}#{$name}-header:first-child {
60
+ th {
61
+ border-top: none;
62
+ }
63
+ }
64
+
65
+ th {
66
+ border-left: none;
67
+ }
68
+
69
+ th:last-child {
70
+ border-right: none;
71
+ }
72
+ }
73
+
74
+ & > .#{$element}#{$name}-scroll-area {
75
+ overflow-y: auto;
76
+ flex: 1 1 0%;
77
+ -webkit-overflow-scrolling: touch;
78
+
79
+ &.#{$state}fixed-header
80
+ > .#{$element}#{$name}-table-wrapper
81
+ > table
82
+ > .#{$element}#{$name}-header:first-child {
83
+ visibility: hidden;
84
+ }
85
+
86
+ //used to cut off the negative margin
87
+ & > .#{$element}#{$name}-table-wrapper {
88
+ overflow: hidden;
89
+ display: inline-block; //preserve content width
90
+ vertical-align: top;
91
+ min-width: 100%;
92
+ min-height: 100%;
93
+ }
94
+ }
95
+ }
96
+
97
+ &.#{$state}resizable {
98
+ .#{$element}#{$name}-data td,
99
+ .#{$element}#{$name}-group-footer td,
100
+ .#{$element}#{$name}-group-header td {
101
+ box-sizing: border-box;
102
+ overflow: hidden;
103
+ text-overflow: ellipsis;
104
+ }
105
+
106
+ .cxe-grid-fixed-header .cxe-grid-col-header:last-child {
107
+ max-width: 100%;
108
+ width: 100%;
109
+ }
110
+ }
111
+
112
+ &.#{$state}border {
113
+ table {
114
+ border: 1px solid $cx-default-grid-border-color;
115
+ }
116
+ }
117
+
118
+ &.#{$state}vlines {
119
+ td:not(:last-child),
120
+ th:not(:last-child) {
121
+ border-right-width: 1px;
122
+ border-right-style: solid;
123
+ border-right-color: $cx-default-grid-border-color;
124
+ }
125
+ }
126
+
127
+ &.#{$mod}responsive {
128
+ width: 100%;
129
+
130
+ & > .#{$element}#{$name}-scroll-area {
131
+ overflow-x: auto;
132
+ }
133
+ }
134
+
135
+ &.#{$mod}fixed-layout {
136
+ table {
137
+ table-layout: fixed;
138
+ width: auto;
139
+ }
140
+ }
141
+
142
+ &.#{$mod}contain {
143
+ table {
144
+ contain: layout paint;
145
+ }
146
+ }
147
+
148
+ &.#{$mod}nowrap {
149
+ .cxe-grid-data td,
150
+ .cxe-grid-fixed-footer td,
151
+ .cxe-grid-fixed-fixed-footer td {
152
+ white-space: nowrap;
153
+ }
154
+ }
155
+ }
156
+
157
+ .#{$element}#{$name}-table-wrapper {
158
+ overflow-anchor: none;
159
+ }
160
+
161
+ .#{$element}#{$name}-cell-clip {
162
+ overflow: hidden;
163
+ text-overflow: ellipsis;
164
+ }
165
+
166
+ .#{$element}#{$name}-row-number::after {
167
+ counter-increment: cx-row-number;
168
+ content: counter(cx-row-number);
169
+ }
170
+
171
+ .#{$element}#{$name}-fixed-header {
172
+ overflow: hidden;
173
+ position: absolute;
174
+ display: none;
175
+ left: 0;
176
+ top: 0;
177
+ right: 0;
178
+
179
+ & > table {
180
+ width: auto;
181
+ table-layout: fixed;
182
+ }
183
+ }
184
+
185
+ .#{$element}#{$name}-fixed-fixed-header {
186
+ overflow: hidden;
187
+ position: absolute;
188
+ display: none;
189
+ left: 0;
190
+ top: 0;
191
+ box-sizing: border-box;
192
+ border-right: 1px solid $cx-default-grid-border-color;
193
+
194
+ & > table {
195
+ width: auto;
196
+ table-layout: fixed;
197
+ }
198
+ }
199
+
200
+ .#{$element}#{$name}-fixed-footer {
201
+ overflow: hidden;
202
+ position: absolute;
203
+ display: none;
204
+ left: 0;
205
+ bottom: 0;
206
+ right: 0;
207
+
208
+ & > table {
209
+ width: auto;
210
+ table-layout: fixed;
211
+ }
212
+ }
213
+
214
+ .#{$element}#{$name}-fixed-fixed-footer {
215
+ overflow: hidden;
216
+ position: absolute;
217
+ display: none;
218
+ left: 0;
219
+ bottom: 0;
220
+ border-right: 1px solid $cx-default-grid-border-color;
221
+ box-sizing: border-box;
222
+
223
+ & > table {
224
+ width: auto;
225
+ table-layout: fixed;
226
+ }
227
+ }
228
+
229
+ .#{$element}#{$name}-fixed-footer-corner {
230
+ width: 100%;
231
+ }
232
+
233
+ .#{$element}#{$name}-empty-text td {
234
+ color: #aaa;
235
+ padding: 2rem;
236
+ }
237
+
238
+ .#{$element}#{$name}-col-header {
239
+ text-align: left;
240
+ padding: cx-get-state-rule($data-state-style-map, default, padding);
241
+ box-sizing: border-box;
242
+ position: relative;
243
+ -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
244
+ -webkit-user-select: none;
245
+
246
+ @include cx-add-state-rules($header-state-style-map, default);
247
+
248
+ .#{$state}header-default & {
249
+ border-width: 1px;
250
+ border-style: solid;
251
+ position: relative;
252
+ }
253
+
254
+ .#{$state}header-plain & {
255
+ background-color: transparent;
256
+ }
257
+
258
+ &.#{$state}sortable {
259
+ cursor: pointer;
260
+ user-select: none;
261
+
262
+ &.#{$state}sorted-asc,
263
+ &.#{$state}sorted-desc {
264
+ @include cx-add-state-rules($header-state-style-map, sorted);
265
+
266
+ &:hover {
267
+ @include cx-add-state-rules($header-state-style-map, sorted-hover);
268
+ }
269
+ }
270
+
271
+ &:hover,
272
+ .#{$element}#{$name}-fixed-header &:hover {
273
+ @include cx-add-state-rules($header-state-style-map, hover);
274
+ }
275
+
276
+ .#{$element}#{$name}-fixed-header & {
277
+ &.#{$state}sorted-asc,
278
+ &.#{$state}sorted-desc {
279
+ &:hover {
280
+ @include cx-add-state-rules($header-state-style-map, sorted-hover);
281
+ }
282
+ }
283
+ }
284
+ }
285
+
286
+ &.#{$state}tool {
287
+ transition: padding-left 0.2s;
288
+ padding-right: cx-calc(15px, $icon-size);
289
+ }
290
+
291
+ &.#{$state}sortable:not(.#{$state}aligned-right) {
292
+ padding-right: cx-calc(5px, $icon-size);
293
+
294
+ .#{$element}#{$name}-column-sort-icon {
295
+ right: 2px;
296
+ }
297
+
298
+ &.#{$state}tool.#{$state}sorted-asc,
299
+ &.#{$state}tool.#{$state}sorted-desc {
300
+ padding-left: cx-calc(5px, $icon-size);
301
+
302
+ .#{$element}#{$name}-column-sort-icon {
303
+ left: 2px;
304
+ }
305
+ }
306
+ }
307
+
308
+ &.#{$state}sortable.#{$state}aligned-center {
309
+ padding-left: cx-calc(5px, $icon-size);
310
+ }
311
+
312
+ &.#{$state}sortable.#{$state}aligned-right {
313
+ padding-left: cx-calc(5px, $icon-size);
314
+
315
+ .#{$element}#{$name}-column-sort-icon {
316
+ left: 2px;
317
+ }
318
+ }
319
+ }
320
+
321
+ .#{$element}#{$name}-column-sort-icon {
322
+ width: $icon-size;
323
+ height: $icon-size;
324
+ top: 50%;
325
+ margin-top: -$icon-size * 0.5;
326
+ position: absolute;
327
+ transition: transform 0.1s linear;
328
+
329
+ .#{$state}sorted-desc > & {
330
+ transform: rotate(180deg);
331
+ }
332
+ }
333
+
334
+ .#{$element}#{$name}-data {
335
+ -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
336
+ background-color: cx-get-state-rule($data-state-style-map, default, background-color);
337
+
338
+ &.#{$state}alternate {
339
+ @include cx-add-state-rules($data-state-style-map, alternate);
340
+ }
341
+
342
+ td {
343
+ padding: 0;
344
+ border-top: 1px solid cx-get-state-rule($data-state-style-map, default, border-color);
345
+ line-height: cx-get-state-rule($data-state-style-map, default, line-height);
346
+ font-weight: cx-get-state-rule($data-state-style-map, default, font-weight);
347
+
348
+ &:empty::before {
349
+ content: "-";
350
+ visibility: hidden;
351
+ }
352
+ }
353
+
354
+ td.#{$state}pad {
355
+ padding: cx-get-state-rule($data-state-style-map, default, padding);
356
+ }
357
+
358
+ .#{$state}selectable & {
359
+ &:hover,
360
+ &.#{$state}hover {
361
+ @include cx-add-state-rules($cx-list-item, hover);
362
+ }
363
+
364
+ &.#{$state}cursor {
365
+ @include cx-add-state-rules($cx-list-item, hover);
366
+ }
367
+
368
+ &.#{$state}selected {
369
+ @include cx-add-state-rules($cx-list-item, selected);
370
+
371
+ &.#{$state}cursor {
372
+ @include cx-add-state-rules($cx-list-item, selected-cursor);
373
+ }
374
+ }
375
+ }
376
+
377
+ .#{$state}focused &,
378
+ :focus & {
379
+ &.#{$state}cursor {
380
+ @include cx-add-state-rules($cx-list-item, cursor);
381
+ }
382
+
383
+ &.#{$state}selected {
384
+ &.#{$state}cursor {
385
+ @include cx-add-state-rules($cx-list-item, selected-cursor);
386
+ }
387
+ }
388
+
389
+ &:active {
390
+ @include cx-add-state-rules($cx-list-item, active);
391
+ }
392
+ }
393
+
394
+ .#{$state}drag-move &.#{$state}dragged {
395
+ display: none;
396
+ }
397
+
398
+ .#{$state}drag-copy &.#{$state}dragged {
399
+ opacity: 0.5;
400
+ }
401
+
402
+ &.#{$state}draggable {
403
+ touch-action: none;
404
+ }
405
+
406
+ &.#{$state}dummy {
407
+ td {
408
+ box-sizing: border-box;
409
+ }
410
+ }
411
+
412
+ &.#{$state}over {
413
+ background: orange !important;
414
+ }
415
+ }
416
+
417
+ .#{$element}#{$name}-dropzone {
418
+ position: relative;
419
+ padding: 0;
420
+
421
+ .#{$state}drop-preview & {
422
+ border-top: 1px solid $cx-default-grid-border-color;
423
+
424
+ &:after {
425
+ position: absolute;
426
+ left: 3px;
427
+ right: 3px;
428
+ top: 3px;
429
+ bottom: 3px;
430
+ border: 1px dotted gray;
431
+ content: " ";
432
+ }
433
+ }
434
+
435
+ .#{$state}drop-insertion & {
436
+ height: 0;
437
+
438
+ &:after {
439
+ position: absolute;
440
+ left: 0;
441
+ right: 0;
442
+ top: 0;
443
+ bottom: 0;
444
+ border-top: 1px solid black;
445
+ content: " ";
446
+ box-shadow: 0 0 2px black;
447
+ }
448
+ }
449
+ }
450
+
451
+ .#{$element}#{$name}-group-caption {
452
+ font-weight: bold;
453
+ font-size: 115%;
454
+
455
+ td {
456
+ padding: cx-get-state-rule($data-state-style-map, default, padding);
457
+ }
458
+
459
+ &:not(:first-child) {
460
+ td {
461
+ padding-top: $cx-default-grid-caption-gap;
462
+ }
463
+ }
464
+ }
465
+
466
+ @for $i from 1 through 4 {
467
+ .#{$element}#{$name}-group-caption.#{$state}level-#{$i} td {
468
+ @include cx-add-state-rules($cx-grid-group-caption-level-style-map, level-#{$i});
469
+ }
470
+ }
471
+
472
+ .#{$element}#{$name}-group-footer {
473
+ td {
474
+ box-sizing: border-box;
475
+ &.#{$state}pad {
476
+ padding: cx-get-state-rule($data-state-style-map, default, padding);
477
+ }
478
+ }
479
+ }
480
+
481
+ @for $i from 1 through 4 {
482
+ .#{$element}#{$name}-group-footer.#{$state}level-#{$i} td {
483
+ @include cx-add-state-rules($cx-grid-group-footer-level-style-map, level-#{$i});
484
+ }
485
+ }
486
+
487
+ .#{$block}#{$name}.#{$state}cell-editable {
488
+ .#{$element}#{$name}-data td {
489
+ &:hover {
490
+ background: rgba(gray, 0.05);
491
+ }
492
+
493
+ &.#{$state}cellected {
494
+ position: relative;
495
+ user-select: none;
496
+ overflow: visible;
497
+
498
+ &:after {
499
+ position: absolute;
500
+ pointer-events: none;
501
+ content: " ";
502
+ @include cx-add-rules($cell-cursor-style);
503
+ }
504
+
505
+ &:last-child::after {
506
+ //prevent horizontal scroll for fixed columns
507
+ right: 0;
508
+ }
509
+ }
510
+
511
+ &.#{$element}#{$name}-cell-editor {
512
+ position: relative;
513
+ user-select: none;
514
+ overflow: visible;
515
+ }
516
+ }
517
+ }
518
+
519
+ .#{$element}#{$name}-cell-editor-wrap {
520
+ position: absolute;
521
+ top: -1px;
522
+ bottom: 0;
523
+ left: 0;
524
+ right: 0;
525
+ width: 100%;
526
+ height: calc(100% + 2px);
527
+
528
+ & > *:only-child {
529
+ width: 100%;
530
+ height: 100%;
531
+ top: 0;
532
+ left: 0;
533
+ }
534
+ }
535
+
536
+ .#{$block}#{$name}.#{$state}buffered,
537
+ .#{$block}#{$name}.#{$state}fixed-columns {
538
+ .#{$element}#{$name}-data {
539
+ white-space: nowrap;
540
+ }
541
+ }
542
+
543
+ .#{$block}#{$name}.#{$state}fixed-columns {
544
+ > .#{$element}#{$name}-scroll-area {
545
+ overflow-x: scroll;
546
+ }
547
+ }
548
+
549
+ .#{$element}#{$name}-scroll-area {
550
+ &.#{$state}fixed-footer
551
+ > .#{$element}#{$name}-table-wrapper
552
+ > table
553
+ > .#{$element}#{$name}-group-footer:last-child {
554
+ visibility: hidden;
555
+
556
+ td {
557
+ border: none;
558
+ }
559
+ }
560
+ }
561
+
562
+ .#{$element}#{$name}-fixed-scroll-area {
563
+ overflow-x: scroll;
564
+ overflow-y: hidden;
565
+ border-color: $cx-default-grid-border-color;
566
+ border-right-style: solid;
567
+ border-right-width: 1px;
568
+
569
+ &.#{$state}fixed-footer
570
+ > .#{$element}#{$name}-fixed-table-wrapper
571
+ > table
572
+ > .#{$element}#{$name}-group-footer:last-child {
573
+ visibility: hidden;
574
+
575
+ td {
576
+ border: none;
577
+ }
578
+ }
579
+ }
580
+
581
+ .#{$element}#{$name}-col-header-tool {
582
+ position: absolute;
583
+ right: 0;
584
+ top: 0;
585
+ bottom: 0;
586
+ }
587
+
588
+ .#{$element}#{$name}-col-resizer {
589
+ position: absolute;
590
+ right: 0;
591
+ top: 0;
592
+ bottom: 0;
593
+ width: 5px;
594
+ cursor: col-resize;
595
+ }
596
+
597
+ .#{$element}#{$name}-col-resizer-prev-col {
598
+ position: absolute;
599
+ left: 0;
600
+ top: 0;
601
+ bottom: 0;
602
+ width: 5px;
603
+ cursor: col-resize;
604
+ }
605
+
606
+ .#{$element}#{$name}-resize-overlay {
607
+ position: absolute;
608
+ display: block;
609
+ pointer-events: none;
610
+ top: 0;
611
+ bottom: 0;
612
+ left: 0;
613
+ width: 0;
614
+ border-right: 3px solid $cx-default-grid-border-color;
615
+ background: rgba($cx-default-grid-border-color, 0.15);
616
+ box-sizing: border-box;
617
+ }
618
+
619
+ .#{$element}#{$name}-col-header-drag-clone {
620
+ border: 1px solid $cx-default-grid-border-color;
621
+ padding: cx-get-state-rule($data-state-style-map, default, padding);
622
+ @include cx-add-state-rules($header-state-style-map, default);
623
+ box-sizing: border-box;
624
+ font-size: $cx-default-grid-font-size;
625
+ }
626
+
627
+ .#{$element}#{$name}-col-insertion-marker {
628
+ border: 1px solid black;
629
+ position: absolute;
630
+ top: 0;
631
+ height: calc(100% - 1px);
632
+ }
633
+ }
634
+
635
+ @if (cx-should-include("cx/widgets/Grid")) {
636
+ @include cx-grid();
637
+ }