cx 24.3.5 → 24.3.7

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.
@@ -1,680 +1,680 @@
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
- &:nth-child(odd) {
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: 15px;
462
- }
463
- }
464
-
465
- &.#{$state}level-2 {
466
- font-size: 130%;
467
-
468
- td {
469
- border-bottom: 1px solid grey;
470
- }
471
- }
472
-
473
- &.#{$state}level-3 {
474
- font-size: 145%;
475
-
476
- td {
477
- border-bottom: 1px solid grey;
478
- }
479
- }
480
-
481
- &.#{$state}level-4 {
482
- font-size: 160%;
483
-
484
- td {
485
- border-bottom: 1px solid grey;
486
- }
487
- }
488
- }
489
-
490
- .#{$element}#{$name}-group-footer {
491
- font-weight: bold;
492
-
493
- td {
494
- border-top: 1px solid $cx-default-grid-border-color;
495
- box-sizing: border-box;
496
-
497
- &.#{$state}pad {
498
- padding: cx-get-state-rule($data-state-style-map, default, padding);
499
- }
500
- }
501
-
502
- &.#{$state}level-2 {
503
- font-weight: bold;
504
- font-size: 110%;
505
-
506
- td {
507
- border-top: 1px solid grey;
508
- }
509
- }
510
-
511
- &.#{$state}level-3 {
512
- font-weight: bold;
513
- font-size: 120%;
514
-
515
- td {
516
- border-top: 1px solid grey;
517
- }
518
- }
519
-
520
- &.#{$state}level-4 {
521
- font-weight: bold;
522
- font-size: 130%;
523
-
524
- td {
525
- border-top: 1px solid grey;
526
- }
527
- }
528
- }
529
-
530
- .#{$block}#{$name}.#{$state}cell-editable {
531
- .#{$element}#{$name}-data td {
532
- &:hover {
533
- background: rgba(gray, 0.05);
534
- }
535
-
536
- &.#{$state}cellected {
537
- position: relative;
538
- user-select: none;
539
- overflow: visible;
540
-
541
- &:after {
542
- position: absolute;
543
- pointer-events: none;
544
- content: " ";
545
- @include cx-add-rules($cell-cursor-style);
546
- }
547
-
548
- &:last-child::after {
549
- //prevent horizontal scroll for fixed columns
550
- right: 0;
551
- }
552
- }
553
-
554
- &.#{$element}#{$name}-cell-editor {
555
- position: relative;
556
- user-select: none;
557
- overflow: visible;
558
- }
559
- }
560
- }
561
-
562
- .#{$element}#{$name}-cell-editor-wrap {
563
- position: absolute;
564
- top: -1px;
565
- bottom: 0;
566
- left: 0;
567
- right: 0;
568
- width: 100%;
569
- height: calc(100% + 2px);
570
-
571
- & > *:only-child {
572
- width: 100%;
573
- height: 100%;
574
- top: 0;
575
- left: 0;
576
- }
577
- }
578
-
579
- .#{$block}#{$name}.#{$state}buffered,
580
- .#{$block}#{$name}.#{$state}fixed-columns {
581
- .#{$element}#{$name}-data {
582
- white-space: nowrap;
583
- }
584
- }
585
-
586
- .#{$block}#{$name}.#{$state}fixed-columns {
587
- > .#{$element}#{$name}-scroll-area {
588
- overflow-x: scroll;
589
- }
590
- }
591
-
592
- .#{$element}#{$name}-scroll-area {
593
- &.#{$state}fixed-footer
594
- > .#{$element}#{$name}-table-wrapper
595
- > table
596
- > .#{$element}#{$name}-group-footer:last-child {
597
- visibility: hidden;
598
-
599
- td {
600
- border: none;
601
- }
602
- }
603
- }
604
-
605
- .#{$element}#{$name}-fixed-scroll-area {
606
- overflow-x: scroll;
607
- overflow-y: hidden;
608
- border-color: $cx-default-grid-border-color;
609
- border-right-style: solid;
610
- border-right-width: 1px;
611
-
612
- &.#{$state}fixed-footer
613
- > .#{$element}#{$name}-fixed-table-wrapper
614
- > table
615
- > .#{$element}#{$name}-group-footer:last-child {
616
- visibility: hidden;
617
-
618
- td {
619
- border: none;
620
- }
621
- }
622
- }
623
-
624
- .#{$element}#{$name}-col-header-tool {
625
- position: absolute;
626
- right: 0;
627
- top: 0;
628
- bottom: 0;
629
- }
630
-
631
- .#{$element}#{$name}-col-resizer {
632
- position: absolute;
633
- right: 0;
634
- top: 0;
635
- bottom: 0;
636
- width: 5px;
637
- cursor: col-resize;
638
- }
639
-
640
- .#{$element}#{$name}-col-resizer-prev-col {
641
- position: absolute;
642
- left: 0;
643
- top: 0;
644
- bottom: 0;
645
- width: 5px;
646
- cursor: col-resize;
647
- }
648
-
649
- .#{$element}#{$name}-resize-overlay {
650
- position: absolute;
651
- display: block;
652
- pointer-events: none;
653
- top: 0;
654
- bottom: 0;
655
- left: 0;
656
- width: 0;
657
- border-right: 3px solid $cx-default-grid-border-color;
658
- background: rgba($cx-default-grid-border-color, 0.15);
659
- box-sizing: border-box;
660
- }
661
-
662
- .#{$element}#{$name}-col-header-drag-clone {
663
- border: 1px solid $cx-default-grid-border-color;
664
- padding: cx-get-state-rule($data-state-style-map, default, padding);
665
- @include cx-add-state-rules($header-state-style-map, default);
666
- box-sizing: border-box;
667
- font-size: $cx-default-grid-font-size;
668
- }
669
-
670
- .#{$element}#{$name}-col-insertion-marker {
671
- border: 1px solid black;
672
- position: absolute;
673
- top: 0;
674
- height: calc(100% - 1px);
675
- }
676
- }
677
-
678
- @if (cx-should-include("cx/widgets/Grid")) {
679
- @include cx-grid();
680
- }
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: 15px;
462
+ }
463
+ }
464
+
465
+ &.#{$state}level-2 {
466
+ font-size: 130%;
467
+
468
+ td {
469
+ border-bottom: 1px solid grey;
470
+ }
471
+ }
472
+
473
+ &.#{$state}level-3 {
474
+ font-size: 145%;
475
+
476
+ td {
477
+ border-bottom: 1px solid grey;
478
+ }
479
+ }
480
+
481
+ &.#{$state}level-4 {
482
+ font-size: 160%;
483
+
484
+ td {
485
+ border-bottom: 1px solid grey;
486
+ }
487
+ }
488
+ }
489
+
490
+ .#{$element}#{$name}-group-footer {
491
+ font-weight: bold;
492
+
493
+ td {
494
+ border-top: 1px solid $cx-default-grid-border-color;
495
+ box-sizing: border-box;
496
+
497
+ &.#{$state}pad {
498
+ padding: cx-get-state-rule($data-state-style-map, default, padding);
499
+ }
500
+ }
501
+
502
+ &.#{$state}level-2 {
503
+ font-weight: bold;
504
+ font-size: 110%;
505
+
506
+ td {
507
+ border-top: 1px solid grey;
508
+ }
509
+ }
510
+
511
+ &.#{$state}level-3 {
512
+ font-weight: bold;
513
+ font-size: 120%;
514
+
515
+ td {
516
+ border-top: 1px solid grey;
517
+ }
518
+ }
519
+
520
+ &.#{$state}level-4 {
521
+ font-weight: bold;
522
+ font-size: 130%;
523
+
524
+ td {
525
+ border-top: 1px solid grey;
526
+ }
527
+ }
528
+ }
529
+
530
+ .#{$block}#{$name}.#{$state}cell-editable {
531
+ .#{$element}#{$name}-data td {
532
+ &:hover {
533
+ background: rgba(gray, 0.05);
534
+ }
535
+
536
+ &.#{$state}cellected {
537
+ position: relative;
538
+ user-select: none;
539
+ overflow: visible;
540
+
541
+ &:after {
542
+ position: absolute;
543
+ pointer-events: none;
544
+ content: " ";
545
+ @include cx-add-rules($cell-cursor-style);
546
+ }
547
+
548
+ &:last-child::after {
549
+ //prevent horizontal scroll for fixed columns
550
+ right: 0;
551
+ }
552
+ }
553
+
554
+ &.#{$element}#{$name}-cell-editor {
555
+ position: relative;
556
+ user-select: none;
557
+ overflow: visible;
558
+ }
559
+ }
560
+ }
561
+
562
+ .#{$element}#{$name}-cell-editor-wrap {
563
+ position: absolute;
564
+ top: -1px;
565
+ bottom: 0;
566
+ left: 0;
567
+ right: 0;
568
+ width: 100%;
569
+ height: calc(100% + 2px);
570
+
571
+ & > *:only-child {
572
+ width: 100%;
573
+ height: 100%;
574
+ top: 0;
575
+ left: 0;
576
+ }
577
+ }
578
+
579
+ .#{$block}#{$name}.#{$state}buffered,
580
+ .#{$block}#{$name}.#{$state}fixed-columns {
581
+ .#{$element}#{$name}-data {
582
+ white-space: nowrap;
583
+ }
584
+ }
585
+
586
+ .#{$block}#{$name}.#{$state}fixed-columns {
587
+ > .#{$element}#{$name}-scroll-area {
588
+ overflow-x: scroll;
589
+ }
590
+ }
591
+
592
+ .#{$element}#{$name}-scroll-area {
593
+ &.#{$state}fixed-footer
594
+ > .#{$element}#{$name}-table-wrapper
595
+ > table
596
+ > .#{$element}#{$name}-group-footer:last-child {
597
+ visibility: hidden;
598
+
599
+ td {
600
+ border: none;
601
+ }
602
+ }
603
+ }
604
+
605
+ .#{$element}#{$name}-fixed-scroll-area {
606
+ overflow-x: scroll;
607
+ overflow-y: hidden;
608
+ border-color: $cx-default-grid-border-color;
609
+ border-right-style: solid;
610
+ border-right-width: 1px;
611
+
612
+ &.#{$state}fixed-footer
613
+ > .#{$element}#{$name}-fixed-table-wrapper
614
+ > table
615
+ > .#{$element}#{$name}-group-footer:last-child {
616
+ visibility: hidden;
617
+
618
+ td {
619
+ border: none;
620
+ }
621
+ }
622
+ }
623
+
624
+ .#{$element}#{$name}-col-header-tool {
625
+ position: absolute;
626
+ right: 0;
627
+ top: 0;
628
+ bottom: 0;
629
+ }
630
+
631
+ .#{$element}#{$name}-col-resizer {
632
+ position: absolute;
633
+ right: 0;
634
+ top: 0;
635
+ bottom: 0;
636
+ width: 5px;
637
+ cursor: col-resize;
638
+ }
639
+
640
+ .#{$element}#{$name}-col-resizer-prev-col {
641
+ position: absolute;
642
+ left: 0;
643
+ top: 0;
644
+ bottom: 0;
645
+ width: 5px;
646
+ cursor: col-resize;
647
+ }
648
+
649
+ .#{$element}#{$name}-resize-overlay {
650
+ position: absolute;
651
+ display: block;
652
+ pointer-events: none;
653
+ top: 0;
654
+ bottom: 0;
655
+ left: 0;
656
+ width: 0;
657
+ border-right: 3px solid $cx-default-grid-border-color;
658
+ background: rgba($cx-default-grid-border-color, 0.15);
659
+ box-sizing: border-box;
660
+ }
661
+
662
+ .#{$element}#{$name}-col-header-drag-clone {
663
+ border: 1px solid $cx-default-grid-border-color;
664
+ padding: cx-get-state-rule($data-state-style-map, default, padding);
665
+ @include cx-add-state-rules($header-state-style-map, default);
666
+ box-sizing: border-box;
667
+ font-size: $cx-default-grid-font-size;
668
+ }
669
+
670
+ .#{$element}#{$name}-col-insertion-marker {
671
+ border: 1px solid black;
672
+ position: absolute;
673
+ top: 0;
674
+ height: calc(100% - 1px);
675
+ }
676
+ }
677
+
678
+ @if (cx-should-include("cx/widgets/Grid")) {
679
+ @include cx-grid();
680
+ }