cx 25.1.2 → 25.2.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 (109) hide show
  1. package/dist/data.js +3 -3
  2. package/dist/manifest.js +747 -747
  3. package/dist/widgets.js +8 -2
  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 -229
  23. package/src/data/Expression.spec.js +229 -229
  24. package/src/data/StringTemplate.js +92 -92
  25. package/src/data/StringTemplate.spec.js +132 -127
  26. package/src/data/StructuredSelector.js +2 -1
  27. package/src/data/getAccessor.spec.js +11 -11
  28. package/src/data/getSelector.js +2 -1
  29. package/src/hooks/createLocalStorageRef.d.ts +3 -3
  30. package/src/hooks/createLocalStorageRef.js +20 -20
  31. package/src/index.scss +6 -6
  32. package/src/ui/Culture.d.ts +57 -57
  33. package/src/ui/Culture.js +139 -139
  34. package/src/ui/FocusManager.js +171 -171
  35. package/src/ui/Format.js +108 -108
  36. package/src/ui/HoverSync.js +147 -147
  37. package/src/ui/Instance.d.ts +72 -72
  38. package/src/ui/Instance.js +614 -614
  39. package/src/ui/Repeater.d.ts +61 -61
  40. package/src/ui/index.d.ts +42 -42
  41. package/src/ui/layout/ContentPlaceholder.d.ts +19 -19
  42. package/src/ui/layout/ContentPlaceholder.js +105 -105
  43. package/src/ui/layout/ContentPlaceholder.spec.js +579 -579
  44. package/src/ui/layout/LabelsTopLayout.js +134 -134
  45. package/src/util/Format.js +270 -270
  46. package/src/util/date/encodeDate.d.ts +1 -1
  47. package/src/util/date/encodeDate.js +8 -8
  48. package/src/util/date/encodeDateWithTimezoneOffset.d.ts +1 -1
  49. package/src/util/date/index.d.ts +11 -11
  50. package/src/util/date/index.js +11 -11
  51. package/src/util/date/parseDateInvariant.d.ts +3 -3
  52. package/src/util/date/parseDateInvariant.js +20 -20
  53. package/src/util/getSearchQueryPredicate.js +59 -59
  54. package/src/util/index.d.ts +51 -51
  55. package/src/util/index.js +54 -54
  56. package/src/util/isValidIdentifierName.d.ts +1 -1
  57. package/src/util/isValidIdentifierName.js +5 -5
  58. package/src/util/isValidIdentifierName.spec.js +33 -33
  59. package/src/util/scss/add-rules.scss +38 -38
  60. package/src/widgets/CxCredit.scss +37 -37
  61. package/src/widgets/HighlightedSearchText.js +36 -36
  62. package/src/widgets/HighlightedSearchText.scss +18 -18
  63. package/src/widgets/List.scss +91 -91
  64. package/src/widgets/drag-drop/DropZone.js +214 -214
  65. package/src/widgets/form/Calendar.js +618 -618
  66. package/src/widgets/form/Calendar.scss +196 -196
  67. package/src/widgets/form/Checkbox.scss +127 -127
  68. package/src/widgets/form/ColorField.js +397 -397
  69. package/src/widgets/form/ColorField.scss +96 -96
  70. package/src/widgets/form/ColorPicker.scss +283 -283
  71. package/src/widgets/form/DateTimeField.js +576 -576
  72. package/src/widgets/form/DateTimePicker.js +392 -392
  73. package/src/widgets/form/LookupField.d.ts +179 -179
  74. package/src/widgets/form/LookupField.scss +219 -219
  75. package/src/widgets/form/MonthField.d.ts +99 -99
  76. package/src/widgets/form/MonthField.js +523 -523
  77. package/src/widgets/form/MonthPicker.d.ts +76 -76
  78. package/src/widgets/form/MonthPicker.js +641 -641
  79. package/src/widgets/form/MonthPicker.scss +118 -118
  80. package/src/widgets/form/NumberField.js +459 -459
  81. package/src/widgets/form/NumberField.scss +61 -61
  82. package/src/widgets/form/Radio.scss +121 -121
  83. package/src/widgets/form/Select.scss +99 -99
  84. package/src/widgets/form/Slider.scss +118 -118
  85. package/src/widgets/form/Switch.scss +140 -140
  86. package/src/widgets/form/TextArea.scss +43 -43
  87. package/src/widgets/form/TextField.js +290 -290
  88. package/src/widgets/form/TextField.scss +55 -55
  89. package/src/widgets/form/UploadButton.d.ts +34 -34
  90. package/src/widgets/form/variables.scss +353 -353
  91. package/src/widgets/grid/Grid.d.ts +442 -442
  92. package/src/widgets/grid/Grid.js +3414 -3414
  93. package/src/widgets/grid/Grid.scss +638 -637
  94. package/src/widgets/grid/GridRow.js +228 -228
  95. package/src/widgets/grid/TreeNode.d.ts +23 -23
  96. package/src/widgets/grid/TreeNode.scss +88 -88
  97. package/src/widgets/grid/variables.scss +133 -133
  98. package/src/widgets/nav/Menu.scss +74 -74
  99. package/src/widgets/overlay/Dropdown.js +612 -612
  100. package/src/widgets/overlay/FlyweightTooltipTracker.js +39 -39
  101. package/src/widgets/overlay/Overlay.d.ts +73 -73
  102. package/src/widgets/overlay/Tooltip.js +308 -303
  103. package/src/widgets/overlay/Window.js +202 -202
  104. package/src/widgets/overlay/captureMouse.js +124 -124
  105. package/src/widgets/overlay/createHotPromiseWindowFactory.d.ts +18 -18
  106. package/src/widgets/overlay/createHotPromiseWindowFactory.js +56 -56
  107. package/src/widgets/overlay/index.d.ts +11 -11
  108. package/src/widgets/overlay/index.js +11 -11
  109. package/src/widgets/variables.scss +144 -144
@@ -1,637 +1,638 @@
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
+ font-size: cx-get-state-rule($data-state-style-map, default, font-size);
348
+
349
+ &:empty::before {
350
+ content: "-";
351
+ visibility: hidden;
352
+ }
353
+ }
354
+
355
+ td.#{$state}pad {
356
+ padding: cx-get-state-rule($data-state-style-map, default, padding);
357
+ }
358
+
359
+ .#{$state}selectable & {
360
+ &:hover,
361
+ &.#{$state}hover {
362
+ @include cx-add-state-rules($cx-list-item, hover);
363
+ }
364
+
365
+ &.#{$state}cursor {
366
+ @include cx-add-state-rules($cx-list-item, hover);
367
+ }
368
+
369
+ &.#{$state}selected {
370
+ @include cx-add-state-rules($cx-list-item, selected);
371
+
372
+ &.#{$state}cursor {
373
+ @include cx-add-state-rules($cx-list-item, selected-cursor);
374
+ }
375
+ }
376
+ }
377
+
378
+ .#{$state}focused &,
379
+ :focus & {
380
+ &.#{$state}cursor {
381
+ @include cx-add-state-rules($cx-list-item, cursor);
382
+ }
383
+
384
+ &.#{$state}selected {
385
+ &.#{$state}cursor {
386
+ @include cx-add-state-rules($cx-list-item, selected-cursor);
387
+ }
388
+ }
389
+
390
+ &:active {
391
+ @include cx-add-state-rules($cx-list-item, active);
392
+ }
393
+ }
394
+
395
+ .#{$state}drag-move &.#{$state}dragged {
396
+ display: none;
397
+ }
398
+
399
+ .#{$state}drag-copy &.#{$state}dragged {
400
+ opacity: 0.5;
401
+ }
402
+
403
+ &.#{$state}draggable {
404
+ touch-action: none;
405
+ }
406
+
407
+ &.#{$state}dummy {
408
+ td {
409
+ box-sizing: border-box;
410
+ }
411
+ }
412
+
413
+ &.#{$state}over {
414
+ background: orange !important;
415
+ }
416
+ }
417
+
418
+ .#{$element}#{$name}-dropzone {
419
+ position: relative;
420
+ padding: 0;
421
+
422
+ .#{$state}drop-preview & {
423
+ border-top: 1px solid $cx-default-grid-border-color;
424
+
425
+ &:after {
426
+ position: absolute;
427
+ left: 3px;
428
+ right: 3px;
429
+ top: 3px;
430
+ bottom: 3px;
431
+ border: 1px dotted gray;
432
+ content: " ";
433
+ }
434
+ }
435
+
436
+ .#{$state}drop-insertion & {
437
+ height: 0;
438
+
439
+ &:after {
440
+ position: absolute;
441
+ left: 0;
442
+ right: 0;
443
+ top: 0;
444
+ bottom: 0;
445
+ border-top: 1px solid black;
446
+ content: " ";
447
+ box-shadow: 0 0 2px black;
448
+ }
449
+ }
450
+ }
451
+
452
+ .#{$element}#{$name}-group-caption {
453
+ font-weight: bold;
454
+ font-size: 115%;
455
+
456
+ td {
457
+ padding: cx-get-state-rule($data-state-style-map, default, padding);
458
+ }
459
+
460
+ &:not(:first-child) {
461
+ td {
462
+ padding-top: $cx-default-grid-caption-gap;
463
+ }
464
+ }
465
+ }
466
+
467
+ @for $i from 1 through 4 {
468
+ .#{$element}#{$name}-group-caption.#{$state}level-#{$i} td {
469
+ @include cx-add-state-rules($cx-grid-group-caption-level-style-map, level-#{$i});
470
+ }
471
+ }
472
+
473
+ .#{$element}#{$name}-group-footer {
474
+ td {
475
+ box-sizing: border-box;
476
+ &.#{$state}pad {
477
+ padding: cx-get-state-rule($data-state-style-map, default, padding);
478
+ }
479
+ }
480
+ }
481
+
482
+ @for $i from 1 through 4 {
483
+ .#{$element}#{$name}-group-footer.#{$state}level-#{$i} td {
484
+ @include cx-add-state-rules($cx-grid-group-footer-level-style-map, level-#{$i});
485
+ }
486
+ }
487
+
488
+ .#{$block}#{$name}.#{$state}cell-editable {
489
+ .#{$element}#{$name}-data td {
490
+ &:hover {
491
+ background: rgba(gray, 0.05);
492
+ }
493
+
494
+ &.#{$state}cellected {
495
+ position: relative;
496
+ user-select: none;
497
+ overflow: visible;
498
+
499
+ &:after {
500
+ position: absolute;
501
+ pointer-events: none;
502
+ content: " ";
503
+ @include cx-add-rules($cell-cursor-style);
504
+ }
505
+
506
+ &:last-child::after {
507
+ //prevent horizontal scroll for fixed columns
508
+ right: 0;
509
+ }
510
+ }
511
+
512
+ &.#{$element}#{$name}-cell-editor {
513
+ position: relative;
514
+ user-select: none;
515
+ overflow: visible;
516
+ }
517
+ }
518
+ }
519
+
520
+ .#{$element}#{$name}-cell-editor-wrap {
521
+ position: absolute;
522
+ top: -1px;
523
+ bottom: 0;
524
+ left: 0;
525
+ right: 0;
526
+ width: 100%;
527
+ height: calc(100% + 2px);
528
+
529
+ & > *:only-child {
530
+ width: 100%;
531
+ height: 100%;
532
+ top: 0;
533
+ left: 0;
534
+ }
535
+ }
536
+
537
+ .#{$block}#{$name}.#{$state}buffered,
538
+ .#{$block}#{$name}.#{$state}fixed-columns {
539
+ .#{$element}#{$name}-data {
540
+ white-space: nowrap;
541
+ }
542
+ }
543
+
544
+ .#{$block}#{$name}.#{$state}fixed-columns {
545
+ > .#{$element}#{$name}-scroll-area {
546
+ overflow-x: scroll;
547
+ }
548
+ }
549
+
550
+ .#{$element}#{$name}-scroll-area {
551
+ &.#{$state}fixed-footer
552
+ > .#{$element}#{$name}-table-wrapper
553
+ > table
554
+ > .#{$element}#{$name}-group-footer:last-child {
555
+ visibility: hidden;
556
+
557
+ td {
558
+ border: none;
559
+ }
560
+ }
561
+ }
562
+
563
+ .#{$element}#{$name}-fixed-scroll-area {
564
+ overflow-x: scroll;
565
+ overflow-y: hidden;
566
+ border-color: $cx-default-grid-border-color;
567
+ border-right-style: solid;
568
+ border-right-width: 1px;
569
+
570
+ &.#{$state}fixed-footer
571
+ > .#{$element}#{$name}-fixed-table-wrapper
572
+ > table
573
+ > .#{$element}#{$name}-group-footer:last-child {
574
+ visibility: hidden;
575
+
576
+ td {
577
+ border: none;
578
+ }
579
+ }
580
+ }
581
+
582
+ .#{$element}#{$name}-col-header-tool {
583
+ position: absolute;
584
+ right: 0;
585
+ top: 0;
586
+ bottom: 0;
587
+ }
588
+
589
+ .#{$element}#{$name}-col-resizer {
590
+ position: absolute;
591
+ right: 0;
592
+ top: 0;
593
+ bottom: 0;
594
+ width: 5px;
595
+ cursor: col-resize;
596
+ }
597
+
598
+ .#{$element}#{$name}-col-resizer-prev-col {
599
+ position: absolute;
600
+ left: 0;
601
+ top: 0;
602
+ bottom: 0;
603
+ width: 5px;
604
+ cursor: col-resize;
605
+ }
606
+
607
+ .#{$element}#{$name}-resize-overlay {
608
+ position: absolute;
609
+ display: block;
610
+ pointer-events: none;
611
+ top: 0;
612
+ bottom: 0;
613
+ left: 0;
614
+ width: 0;
615
+ border-right: 3px solid $cx-default-grid-border-color;
616
+ background: rgba($cx-default-grid-border-color, 0.15);
617
+ box-sizing: border-box;
618
+ }
619
+
620
+ .#{$element}#{$name}-col-header-drag-clone {
621
+ border: 1px solid $cx-default-grid-border-color;
622
+ padding: cx-get-state-rule($data-state-style-map, default, padding);
623
+ @include cx-add-state-rules($header-state-style-map, default);
624
+ box-sizing: border-box;
625
+ font-size: $cx-default-grid-font-size;
626
+ }
627
+
628
+ .#{$element}#{$name}-col-insertion-marker {
629
+ border: 1px solid black;
630
+ position: absolute;
631
+ top: 0;
632
+ height: calc(100% - 1px);
633
+ }
634
+ }
635
+
636
+ @if (cx-should-include("cx/widgets/Grid")) {
637
+ @include cx-grid();
638
+ }