@ptsecurity/mosaic 15.3.2 → 15.4.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 (94) hide show
  1. package/_theming.scss +675 -42
  2. package/_visual.scss +132 -42
  3. package/button/button.component.d.ts +1 -0
  4. package/button-toggle/_button-toggle-theme.scss +92 -0
  5. package/button-toggle/button-toggle.component.d.ts +6 -2
  6. package/button-toggle/button-toggle.module.d.ts +2 -1
  7. package/button-toggle/button-toggle.scss +109 -81
  8. package/core/styles/_mosaic-theme.scss +6 -0
  9. package/core/styles/theming/_components-theming.scss +92 -0
  10. package/core/utils/data-size/config.d.ts +20 -0
  11. package/core/utils/data-size/data-size.pipe.d.ts +13 -0
  12. package/core/utils/data-size/index.d.ts +3 -0
  13. package/core/utils/data-size/size.d.ts +16 -0
  14. package/core/utils/public-api.d.ts +1 -0
  15. package/ellipsis-center/ellipsis-center.directive.d.ts +27 -0
  16. package/ellipsis-center/index.d.ts +1 -0
  17. package/ellipsis-center/public-api.d.ts +1 -0
  18. package/esm2020/button/button.component.mjs +9 -7
  19. package/esm2020/button-toggle/button-toggle.component.mjs +28 -9
  20. package/esm2020/button-toggle/button-toggle.module.mjs +5 -4
  21. package/esm2020/core/utils/data-size/config.mjs +22 -0
  22. package/esm2020/core/utils/data-size/data-size.pipe.mjs +32 -0
  23. package/esm2020/core/utils/data-size/index.mjs +4 -0
  24. package/esm2020/core/utils/data-size/size.mjs +50 -0
  25. package/esm2020/core/utils/public-api.mjs +2 -1
  26. package/esm2020/core/version.mjs +2 -2
  27. package/esm2020/ellipsis-center/ellipsis-center.directive.mjs +106 -0
  28. package/esm2020/ellipsis-center/index.mjs +2 -0
  29. package/esm2020/ellipsis-center/ptsecurity-mosaic-ellipsis-center.mjs +5 -0
  30. package/esm2020/ellipsis-center/public-api.mjs +2 -0
  31. package/esm2020/file-upload/file-drop.mjs +43 -0
  32. package/esm2020/file-upload/file-upload.mjs +4 -0
  33. package/esm2020/file-upload/file-upload.module.mjs +66 -0
  34. package/esm2020/file-upload/index.mjs +2 -0
  35. package/esm2020/file-upload/multiple-file-upload.component.mjs +161 -0
  36. package/esm2020/file-upload/ptsecurity-mosaic-file-upload.mjs +5 -0
  37. package/esm2020/file-upload/public-api.mjs +6 -0
  38. package/esm2020/file-upload/single-file-upload.component.mjs +130 -0
  39. package/esm2020/select/select.component.mjs +5 -5
  40. package/esm2020/timezone/timezone-select.component.mjs +2 -2
  41. package/esm2020/tree-select/tree-select.component.mjs +8 -5
  42. package/fesm2015/ptsecurity-mosaic-button-toggle.mjs +31 -11
  43. package/fesm2015/ptsecurity-mosaic-button-toggle.mjs.map +1 -1
  44. package/fesm2015/ptsecurity-mosaic-button.mjs +9 -7
  45. package/fesm2015/ptsecurity-mosaic-button.mjs.map +1 -1
  46. package/fesm2015/ptsecurity-mosaic-core.mjs +101 -2
  47. package/fesm2015/ptsecurity-mosaic-core.mjs.map +1 -1
  48. package/fesm2015/ptsecurity-mosaic-ellipsis-center.mjs +113 -0
  49. package/fesm2015/ptsecurity-mosaic-ellipsis-center.mjs.map +1 -0
  50. package/fesm2015/ptsecurity-mosaic-file-upload.mjs +392 -0
  51. package/fesm2015/ptsecurity-mosaic-file-upload.mjs.map +1 -0
  52. package/fesm2015/ptsecurity-mosaic-select.mjs +4 -4
  53. package/fesm2015/ptsecurity-mosaic-select.mjs.map +1 -1
  54. package/fesm2015/ptsecurity-mosaic-timezone.mjs +2 -2
  55. package/fesm2015/ptsecurity-mosaic-timezone.mjs.map +1 -1
  56. package/fesm2015/ptsecurity-mosaic-tree-select.mjs +7 -4
  57. package/fesm2015/ptsecurity-mosaic-tree-select.mjs.map +1 -1
  58. package/fesm2020/ptsecurity-mosaic-button-toggle.mjs +31 -11
  59. package/fesm2020/ptsecurity-mosaic-button-toggle.mjs.map +1 -1
  60. package/fesm2020/ptsecurity-mosaic-button.mjs +9 -7
  61. package/fesm2020/ptsecurity-mosaic-button.mjs.map +1 -1
  62. package/fesm2020/ptsecurity-mosaic-core.mjs +101 -2
  63. package/fesm2020/ptsecurity-mosaic-core.mjs.map +1 -1
  64. package/fesm2020/ptsecurity-mosaic-ellipsis-center.mjs +111 -0
  65. package/fesm2020/ptsecurity-mosaic-ellipsis-center.mjs.map +1 -0
  66. package/fesm2020/ptsecurity-mosaic-file-upload.mjs +388 -0
  67. package/fesm2020/ptsecurity-mosaic-file-upload.mjs.map +1 -0
  68. package/fesm2020/ptsecurity-mosaic-select.mjs +4 -4
  69. package/fesm2020/ptsecurity-mosaic-select.mjs.map +1 -1
  70. package/fesm2020/ptsecurity-mosaic-timezone.mjs +2 -2
  71. package/fesm2020/ptsecurity-mosaic-timezone.mjs.map +1 -1
  72. package/fesm2020/ptsecurity-mosaic-tree-select.mjs +7 -4
  73. package/fesm2020/ptsecurity-mosaic-tree-select.mjs.map +1 -1
  74. package/file-upload/README.md +0 -0
  75. package/file-upload/_file-upload-theme.scss +174 -0
  76. package/file-upload/file-drop.d.ts +11 -0
  77. package/file-upload/file-upload.d.ts +22 -0
  78. package/file-upload/file-upload.module.d.ts +18 -0
  79. package/file-upload/file-upload.scss +46 -0
  80. package/file-upload/index.d.ts +1 -0
  81. package/file-upload/multiple-file-upload.component.d.ts +51 -0
  82. package/file-upload/multiple-file-upload.component.scss +148 -0
  83. package/file-upload/public-api.d.ts +5 -0
  84. package/file-upload/single-file-upload.component.d.ts +34 -0
  85. package/file-upload/single-file-upload.component.scss +60 -0
  86. package/package.json +18 -2
  87. package/prebuilt-themes/dark-theme.css +1 -1
  88. package/prebuilt-themes/default-theme.css +1 -1
  89. package/select/_select-theme.scss +6 -0
  90. package/select/select.component.d.ts +1 -1
  91. package/select/select.scss +13 -0
  92. package/tree-select/_tree-select-theme.scss +6 -0
  93. package/tree-select/tree-select.component.d.ts +2 -2
  94. package/tree-select/tree-select.scss +13 -0
@@ -9,47 +9,89 @@
9
9
  $tokens: meta.module-variables(tokens) !default;
10
10
 
11
11
  .mc-button-toggle-group {
12
- display: flex;
12
+ box-sizing: border-box;
13
+ display: inline-flex;
13
14
  flex-direction: row;
15
+ align-items: center;
16
+ gap: map.get($tokens, size-3xs);
17
+
18
+ border-width: var(
19
+ --mc-button-toggle-group-size-border-width,
20
+ map.get($tokens, button-toggle-group-size-border-width)
21
+ );
22
+ border-radius: var(
23
+ --mc-button-toggle-group-size-border-radius,
24
+ map.get($tokens, button-toggle-group-size-border-radius)
25
+ );
26
+ border-style: solid;
27
+ padding: var(
28
+ --mc-button-toggle-group-size-padding,
29
+ map.get($tokens, button-toggle-group-size-padding)
30
+ );
14
31
 
15
32
  .mc-button-toggle {
16
- &:first-of-type:not(:last-of-type) {
17
- > .mc-button,
18
- > .mc-icon-button {
19
- @include common.border-right-radius(
20
- var(
21
- --mc-button-toggle-size-border-siblings-radius,
22
- map.get($tokens, button-toggle-size-border-siblings-radius)
23
- )
24
- );
25
- @include common.border-left-radius(
26
- var(--mc-button-toggle-size-border-radius, map.get($tokens, button-toggle-size-border-radius))
27
- );
33
+ display: flex;
34
+ overflow: hidden;
35
+ justify-content: flex-start;
36
+
37
+ border-radius: var(
38
+ --mc-button-toggle-size-border-radius,
39
+ map.get($tokens, button-toggle-size-border-radius)
40
+ );
41
+
42
+ > .mc-button,
43
+ > .mc-icon-button {
44
+ border: none;
45
+ border-width: var(
46
+ --mc-button-toggle-size-border-width,
47
+ map.get($tokens, button-toggle-size-border-width)
48
+ );
49
+ border-radius: var(
50
+ --mc-button-toggle-size-border-radius,
51
+ map.get($tokens, button-toggle-size-border-radius)
52
+ );
53
+ min-width: var(
54
+ --mc-button-toggle-size-min-width,
55
+ map.get($tokens, button-toggle-size-min-width)
56
+ );
57
+ padding-left: var(
58
+ --mc-button-toggle-size-horizontal-padding,
59
+ map.get($tokens, button-toggle-size-horizontal-padding)
60
+ );
61
+ padding-right: var(
62
+ --mc-button-toggle-size-horizontal-padding,
63
+ map.get($tokens, button-toggle-size-horizontal-padding)
64
+ );
65
+
66
+ & .mc-button-wrapper {
67
+ width: 100%;
28
68
  }
29
- }
30
69
 
31
- &:last-of-type:not(:first-of-type) {
32
- > .mc-button,
33
- > .mc-icon-button {
34
- @include common.border-left-radius(
35
- var(
36
- --mc-button-toggle-size-border-siblings-radius,
37
- map.get($tokens, button-toggle-size-border-siblings-radius)
38
- )
39
- );
40
- @include common.border-right-radius(
41
- var(--mc-button-toggle-size-border-radius, map.get($tokens, button-toggle-size-border-radius))
42
- );
70
+ .mc-button-toggle-wrapper {
71
+ text-overflow: ellipsis;
72
+ overflow: hidden;
73
+ white-space: nowrap;
74
+ display: inline-block;
75
+ width: 100%;
76
+
77
+ .mc-icon {
78
+ line-height: 20px;
79
+ vertical-align: baseline;
80
+ }
43
81
  }
44
82
  }
45
83
 
46
- &:not(:first-of-type):not(:last-of-type) {
84
+ &.mc-button-toggle-icon-text {
47
85
  > .mc-button,
48
86
  > .mc-icon-button {
49
- border-radius: var(
50
- --mc-button-toggle-size-border-siblings-radius,
51
- map.get($tokens, button-toggle-size-border-siblings-radius)
52
- )
87
+ padding-left: var(
88
+ --mc-button-toggle-size-left-icon-padding,
89
+ map.get($tokens, button-toggle-size-left-icon-padding)
90
+ );
91
+
92
+ & .mc-icon {
93
+ margin-right: map.get($tokens, size-xxs);
94
+ }
53
95
  }
54
96
  }
55
97
 
@@ -59,10 +101,29 @@ $tokens: meta.module-variables(tokens) !default;
59
101
  }
60
102
 
61
103
  &:not(.mc-button-toggle_vertical) {
62
- .mc-button-toggle:not([disabled]) + .mc-button-toggle:not([disabled]) {
63
- margin-left:calc(
64
- -1 * var(--mc-button-toggle-size-border-size, #{map.get($tokens, button-toggle-size-border-size)})
65
- );
104
+ height: 32px;
105
+
106
+ .mc-button-toggle {
107
+ > .mc-button,
108
+ > .mc-icon-button {
109
+ height: 28px;
110
+ min-height: 28px;
111
+ }
112
+
113
+ &.mc-button-toggle-icon {
114
+ width: var(
115
+ --mc-icon-button-toggle-size-width,
116
+ map.get($tokens, icon-button-toggle-size-width)
117
+ );
118
+
119
+ > .mc-button,
120
+ > .mc-icon-button {
121
+ width: var(
122
+ --mc-icon-button-toggle-size-width,
123
+ map.get($tokens, icon-button-toggle-size-width)
124
+ );
125
+ }
126
+ }
66
127
  }
67
128
  }
68
129
  }
@@ -76,58 +137,25 @@ $tokens: meta.module-variables(tokens) !default;
76
137
  border-right: none;
77
138
  }
78
139
 
79
- .mc-button-toggle:not([disabled]) + .mc-button-toggle:not([disabled]) {
80
- margin-top: calc(
81
- -1 * var(--mc-button-toggle-size-border-size, #{map.get($tokens, button-toggle-size-border-size)})
82
- );
83
- }
84
-
85
140
  .mc-button-toggle {
86
- .mc-button,
87
- .mc-icon-button {
88
- width: 100%;
89
- }
90
-
91
- &:first-child:not(:last-child) {
92
- > .mc-button,
93
- > .mc-icon-button {
94
- @include common.border-bottom-radius(
95
- var(
96
- --mc-button-toggle-size-border-siblings-radius,
97
- map.get($tokens, button-toggle-size-border-siblings-radius)
98
- )
99
- );
100
- @include common.border-top-radius(
101
- var(--mc-button-toggle-size-border-radius, map.get($tokens, button-toggle-size-border-radius)));
102
- }
103
- }
141
+ width: 100%;
104
142
 
105
- &:last-child:not(:first-child) {
106
- > .mc-button,
107
- > .mc-icon-button {
108
- @include common.border-top-radius(
109
- var(
110
- --mc-button-toggle-size-border-siblings-radius,
111
- map.get($tokens, button-toggle-size-border-siblings-radius)
112
- )
113
- );
114
-
115
- @include common.border-bottom-radius(
116
- var(--mc-button-toggle-size-border-radius, map.get($tokens, button-toggle-size-border-radius)));
117
- }
118
- }
143
+ > .mc-button,
144
+ > .mc-icon-button {
145
+ width: 100%;
146
+ border-width: var(
147
+ --mc-button-toggle-size-border-width,
148
+ map.get($tokens, button-toggle-size-border-width)
149
+ );
119
150
 
120
- &:not(:first-child):not(:last-child) {
121
- > .mc-button,
122
- > .mc-icon-button {
123
- border-radius: var(
124
- --mc-button-toggle-size-border-siblings-radius,
125
- map.get($tokens, button-toggle-size-border-siblings-radius)
126
- )
127
- }
151
+ border-radius: var(
152
+ --mc-button-toggle-size-border-radius,
153
+ map.get($tokens, button-toggle-size-border-radius)
154
+ );
128
155
  }
129
156
  }
130
157
  }
158
+
131
159
  /* stylelint-enable no-descending-specificity */
132
160
 
133
161
  .mc-button-toggle-standalone {
@@ -8,6 +8,7 @@
8
8
  @use '../selection/pseudo-checkbox/pseudo-checkbox-theme' as *;
9
9
  @use '../../autocomplete/autocomplete-theme' as *;
10
10
  @use '../../button/button-theme' as *;
11
+ @use '../../button-toggle/button-toggle-theme' as *;
11
12
  @use '../../card/card-theme' as *;
12
13
  @use '../../checkbox/checkbox-theme' as *;
13
14
  @use '../../code-block/code-block-theme' as *;
@@ -46,6 +47,7 @@
46
47
  @use '../option/option-action-theme' as *;
47
48
  @use '../highlight/highlight-theme' as *;
48
49
  @use '../../dl/dl-theme' as *;
50
+ @use '../../file-upload/file-upload-theme' as *;
49
51
 
50
52
 
51
53
  @mixin mosaic-theme($theme) {
@@ -55,6 +57,7 @@
55
57
  @include mc-autocomplete-theme($theme);
56
58
  @include mc-badge-theme($theme);
57
59
  @include mc-button-theme($theme);
60
+ @include mc-button-toggle-theme($theme);
58
61
  @include mc-card-theme($theme);
59
62
  @include mc-checkbox-theme($theme);
60
63
  @include mc-code-block-theme($theme);
@@ -95,6 +98,7 @@
95
98
  @include mc-tree-select-theme($theme);
96
99
  @include mc-tree-theme($theme);
97
100
  @include mc-table-theme($theme);
101
+ @include mc-file-upload-theme($theme);
98
102
  }
99
103
 
100
104
 
@@ -113,6 +117,7 @@
113
117
  @include mc-alert-typography($config);
114
118
  @include mc-badge-typography($config);
115
119
  @include mc-button-typography($config);
120
+ @include mc-button-toggle-typography($config);
116
121
  @include mc-checkbox-typography($config);
117
122
  @include mc-code-block-typography($config);
118
123
  @include mc-datepicker-typography($config);
@@ -142,6 +147,7 @@
142
147
  @include mc-tree-select-typography($config);
143
148
  @include mc-tree-typography($config);
144
149
  @include mc-table-typography($config);
150
+ @include mc-file-upload-typography($config);
145
151
 
146
152
  @include mc-markdown-typography($md-config);
147
153
  }
@@ -148,6 +148,39 @@
148
148
  )
149
149
  );
150
150
 
151
+ $button-toggle: (
152
+ button-toggle-group: (
153
+ background: map-get($tokens, 'button-toggle-group-#{$scheme}-background'),
154
+ border: map-get($tokens, 'button-toggle-group-#{$scheme}-border'),
155
+ states: (
156
+ disabled: (
157
+ opacity: map-get($tokens, 'button-toggle-group-#{$scheme}-states-disabled-opacity')
158
+ )
159
+ ),
160
+ ),
161
+ button-toggle: (
162
+ color: map-get($tokens, 'button-toggle-#{$scheme}-color'),
163
+ icon: map-get($tokens, 'button-toggle-#{$scheme}-icon'),
164
+ states: (
165
+ disabled: (
166
+ opacity: map-get($tokens, 'button-toggle-#{$scheme}-states-disabled-opacity')
167
+ ),
168
+ hover: (
169
+ background: map-get($tokens, 'button-toggle-#{$scheme}-states-hover-background'),
170
+ icon: map-get($tokens, 'button-toggle-#{$scheme}-states-hover-icon')
171
+ ),
172
+ active: (
173
+ background: map-get($tokens, 'button-toggle-#{$scheme}-states-active-background'),
174
+ icon: map-get($tokens, 'button-toggle-#{$scheme}-states-active-icon')
175
+ ),
176
+ pressed: (
177
+ background: map-get($tokens, 'button-toggle-#{$scheme}-states-pressed-background'),
178
+ icon: map-get($tokens, 'button-toggle-#{$scheme}-states-pressed-icon')
179
+ )
180
+ )
181
+ )
182
+ );
183
+
151
184
  $card: (
152
185
  error: (
153
186
  vertical-line: map-get($tokens, 'card-#{$scheme}-error-vertical-line'),
@@ -353,6 +386,57 @@
353
386
  dd: map-get($tokens, 'description-list-#{$scheme}-dd')
354
387
  );
355
388
 
389
+ $file-upload: (
390
+ single: (
391
+ default: (
392
+ background: map-get($tokens, 'file-upload-#{$scheme}-single-default-background'),
393
+ border: map-get($tokens, 'file-upload-#{$scheme}-single-default-border'),
394
+ ),
395
+ states: (
396
+ error: (
397
+ background: map-get($tokens, 'file-upload-#{$scheme}-single-states-error-background'),
398
+ border: map-get($tokens, 'file-upload-#{$scheme}-single-states-error-border')
399
+ ),
400
+ progress: (
401
+ background: map-get($tokens, 'file-upload-#{$scheme}-single-states-progress-background'),
402
+ border: map-get($tokens, 'file-upload-#{$scheme}-single-states-progress-border')
403
+ ),
404
+ drag-n-drop: (
405
+ background: map-get($tokens, 'file-upload-#{$scheme}-single-states-drag-n-drop-background'),
406
+ border: map-get($tokens, 'file-upload-#{$scheme}-single-states-drag-n-drop-border')
407
+ ),
408
+ disabled: (
409
+ background: map-get($tokens, 'file-upload-#{$scheme}-single-states-disable-background'),
410
+ border: map-get($tokens, 'file-upload-#{$scheme}-single-states-disable-border')
411
+ )
412
+ )
413
+ ),
414
+ multiple: (
415
+ default: (
416
+ background: map-get($tokens, 'file-upload-#{$scheme}-multiple-default-background'),
417
+ border: map-get($tokens, 'file-upload-#{$scheme}-multiple-default-border'),
418
+ ),
419
+ states: (
420
+ error: (
421
+ background: map-get($tokens, 'file-upload-#{$scheme}-multiple-states-error-background'),
422
+ border: map-get($tokens, 'file-upload-#{$scheme}-multiple-states-error-border')
423
+ ),
424
+ progress: (
425
+ background: map-get($tokens, 'file-upload-#{$scheme}-multiple-states-progress-background'),
426
+ border: map-get($tokens, 'file-upload-#{$scheme}-multiple-states-progress-border')
427
+ ),
428
+ drag-n-drop: (
429
+ background: map-get($tokens, 'file-upload-#{$scheme}-multiple-states-drag-n-drop-background'),
430
+ border: map-get($tokens, 'file-upload-#{$scheme}-multiple-states-drag-n-drop-border')
431
+ ),
432
+ disabled: (
433
+ background: map-get($tokens, 'file-upload-#{$scheme}-multiple-states-disable-background'),
434
+ border: map-get($tokens, 'file-upload-#{$scheme}-multiple-states-disable-border')
435
+ )
436
+ )
437
+ )
438
+ );
439
+
356
440
  $form-field: (
357
441
  border: map-get($tokens, 'form-field-#{$scheme}-border'),
358
442
  background: map-get($tokens, 'form-field-#{$scheme}-background'),
@@ -437,6 +521,11 @@
437
521
  state-focused-outline: map-get($tokens, 'link-#{$scheme}-state-focused-outline')
438
522
  );
439
523
 
524
+ $list: (
525
+ footer-background: map-get($tokens, 'list-#{$scheme}-footer-background'),
526
+ footer-divider: map-get($tokens, 'list-#{$scheme}-footer-divider'),
527
+ );
528
+
440
529
  $loader-overlay: (
441
530
  background: map-get($tokens, 'loader-overlay-#{$scheme}-background'),
442
531
 
@@ -694,18 +783,21 @@
694
783
  popup: $popup,
695
784
  badge: $badge,
696
785
  button: $button,
786
+ button-toggle: $button-toggle,
697
787
  card: $card,
698
788
  checkbox: $checkbox,
699
789
  code-block: $code-block,
700
790
  datepicker: $datepicker,
701
791
  divider: $divider,
702
792
  dl: $dl,
793
+ file-upload: $file-upload,
703
794
  form-field: $form-field,
704
795
  form-field-password-hint: $form-field-password-hint,
705
796
  form-field-hint: $form-field-hint,
706
797
  forms: $forms,
707
798
  icon: $icon,
708
799
  link: $link,
800
+ list: $list,
709
801
  loader-overlay: $loader-overlay,
710
802
  modal: $modal,
711
803
  markdown: $markdown,
@@ -0,0 +1,20 @@
1
+ export declare enum MeasurementSystem {
2
+ SI = "SI",
3
+ IEC = "IEC"
4
+ }
5
+ export declare const sizeUnitsConfig: {
6
+ defaultUnitSystem: MeasurementSystem;
7
+ defaultPrecision: number;
8
+ unitSystems: {
9
+ SI: {
10
+ abbreviations: string[];
11
+ base: number;
12
+ power: number;
13
+ };
14
+ IEC: {
15
+ abbreviations: string[];
16
+ base: number;
17
+ power: number;
18
+ };
19
+ };
20
+ };
@@ -0,0 +1,13 @@
1
+ import { PipeTransform } from '@angular/core';
2
+ import { MeasurementSystem } from './config';
3
+ import * as i0 from "@angular/core";
4
+ export declare class McDataSizePipe implements PipeTransform {
5
+ transform(source: number, precision?: number, measurementSystem?: MeasurementSystem): string;
6
+ static ɵfac: i0.ɵɵFactoryDeclaration<McDataSizePipe, never>;
7
+ static ɵpipe: i0.ɵɵPipeDeclaration<McDataSizePipe, "mcDataSize", false>;
8
+ }
9
+ export declare class McDataSizeModule {
10
+ static ɵfac: i0.ɵɵFactoryDeclaration<McDataSizeModule, never>;
11
+ static ɵmod: i0.ɵɵNgModuleDeclaration<McDataSizeModule, [typeof McDataSizePipe], never, [typeof McDataSizePipe]>;
12
+ static ɵinj: i0.ɵɵInjectorDeclaration<McDataSizeModule>;
13
+ }
@@ -0,0 +1,3 @@
1
+ export * from './config';
2
+ export * from './size';
3
+ export * from './data-size.pipe';
@@ -0,0 +1,16 @@
1
+ import { MeasurementSystem } from './config';
2
+ export declare const formatDataSize: (value: number, systemCode?: MeasurementSystem, precision?: number) => {
3
+ value: string;
4
+ unit: string;
5
+ };
6
+ /**
7
+ * Переводит байты в Кб, Мб, Гб
8
+ *
9
+ * @param value количество байт
10
+ * @param systemCode система измерения
11
+ * @param threshold нижний порог подсчета
12
+ */
13
+ export declare const getHumanizedBytes: (value: number, systemCode?: MeasurementSystem, threshold?: number) => {
14
+ result: number;
15
+ unit: string;
16
+ };
@@ -1 +1,2 @@
1
1
  export * from './utils';
2
+ export * from './data-size';
@@ -0,0 +1,27 @@
1
+ import { Directionality } from '@angular/cdk/bidi';
2
+ import { Overlay, ScrollDispatcher } from '@angular/cdk/overlay';
3
+ import { ElementRef, OnInit, OnDestroy, NgZone, ViewContainerRef, Renderer2, AfterViewInit } from '@angular/core';
4
+ import { McTooltipTrigger } from '@ptsecurity/mosaic/tooltip';
5
+ import { Subject } from 'rxjs';
6
+ import * as i0 from "@angular/core";
7
+ export declare class McEllipsisCenterDirective extends McTooltipTrigger implements OnInit, AfterViewInit, OnDestroy {
8
+ private renderer;
9
+ set mcEllipsisCenter(value: string);
10
+ minVisibleLength: number;
11
+ readonly resizeStream: Subject<Event>;
12
+ private _mcEllipsisCenter;
13
+ private resizeSubscription;
14
+ private readonly debounceInterval;
15
+ constructor(overlay: Overlay, elementRef: ElementRef<HTMLElement>, ngZone: NgZone, scrollDispatcher: ScrollDispatcher, hostView: ViewContainerRef, scrollStrategy: any, direction: Directionality, renderer: Renderer2);
16
+ ngOnInit(): void;
17
+ ngAfterViewInit(): void;
18
+ ngOnDestroy(): void;
19
+ private refresh;
20
+ static ɵfac: i0.ɵɵFactoryDeclaration<McEllipsisCenterDirective, [null, null, null, null, null, null, { optional: true; }, null]>;
21
+ static ɵdir: i0.ɵɵDirectiveDeclaration<McEllipsisCenterDirective, "[mcEllipsisCenter]", never, { "mcEllipsisCenter": "mcEllipsisCenter"; "minVisibleLength": "minVisibleLength"; }, {}, never, never, false, never>;
22
+ }
23
+ export declare class McEllipsisCenterModule {
24
+ static ɵfac: i0.ɵɵFactoryDeclaration<McEllipsisCenterModule, never>;
25
+ static ɵmod: i0.ɵɵNgModuleDeclaration<McEllipsisCenterModule, [typeof McEllipsisCenterDirective], never, [typeof McEllipsisCenterDirective]>;
26
+ static ɵinj: i0.ɵɵInjectorDeclaration<McEllipsisCenterModule>;
27
+ }
@@ -0,0 +1 @@
1
+ export * from './public-api';
@@ -0,0 +1 @@
1
+ export * from './ellipsis-center.directive';
@@ -1,6 +1,6 @@
1
1
  import { FocusMonitor } from '@angular/cdk/a11y';
2
2
  import { coerceBooleanProperty } from '@angular/cdk/coercion';
3
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Directive, ElementRef, ViewEncapsulation, Renderer2, QueryList, ContentChildren, SkipSelf, Input } from '@angular/core';
3
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Directive, ElementRef, ViewEncapsulation, Renderer2, QueryList, ContentChildren, SkipSelf, Input, forwardRef } from '@angular/core';
4
4
  import { mixinColor, mixinTabIndex } from '@ptsecurity/mosaic/core';
5
5
  import { McIcon } from '@ptsecurity/mosaic/icon';
6
6
  import * as i0 from "@angular/core";
@@ -10,6 +10,10 @@ export const leftIconClassName = 'mc-icon_left';
10
10
  export const rightIconClassName = 'mc-icon_right';
11
11
  export const buttonLeftIconClassName = 'mc-icon-button_left';
12
12
  export const buttonRightIconClassName = 'mc-icon-button_right';
13
+ export const getNodesWithoutComments = (nodes) => {
14
+ const COMMENT_NODE = 8;
15
+ return Array.from(nodes).filter((node) => node.nodeType !== COMMENT_NODE);
16
+ };
13
17
  export class McButtonCssStyler {
14
18
  constructor(elementRef, renderer, cdr) {
15
19
  this.renderer = renderer;
@@ -24,9 +28,7 @@ export class McButtonCssStyler {
24
28
  this.renderer.removeClass(this.nativeElement, buttonLeftIconClassName);
25
29
  this.renderer.removeClass(this.nativeElement, buttonRightIconClassName);
26
30
  const twoIcons = 2;
27
- const COMMENT_NODE = 8;
28
- const filteredNodesWithoutComments = Array.from(this.nativeElement.querySelector('.mc-button-wrapper').childNodes)
29
- .filter((node) => node.nodeType !== COMMENT_NODE);
31
+ const filteredNodesWithoutComments = getNodesWithoutComments(this.nativeElement.querySelector('.mc-button-wrapper').childNodes);
30
32
  const currentIsIconButtonValue = !!this.icons.length &&
31
33
  this.icons.length === filteredNodesWithoutComments.length && this.icons.length <= twoIcons;
32
34
  if (currentIsIconButtonValue !== this.isIconButton) {
@@ -52,7 +54,7 @@ export class McButtonCssStyler {
52
54
  }
53
55
  }
54
56
  /** @nocollapse */ McButtonCssStyler.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.2", ngImport: i0, type: McButtonCssStyler, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef, skipSelf: true }], target: i0.ɵɵFactoryTarget.Directive });
55
- /** @nocollapse */ McButtonCssStyler.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.2", type: McButtonCssStyler, selector: "[mc-button]", host: { properties: { "class.mc-button": "!isIconButton", "class.mc-icon-button": "isIconButton" } }, queries: [{ propertyName: "icons", predicate: McIcon, descendants: true }], ngImport: i0 });
57
+ /** @nocollapse */ McButtonCssStyler.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.2", type: McButtonCssStyler, selector: "[mc-button]", host: { properties: { "class.mc-button": "!isIconButton", "class.mc-icon-button": "isIconButton" } }, queries: [{ propertyName: "icons", predicate: i0.forwardRef(function () { return McIcon; }) }], ngImport: i0 });
56
58
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.2", ngImport: i0, type: McButtonCssStyler, decorators: [{
57
59
  type: Directive,
58
60
  args: [{
@@ -66,7 +68,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.2", ngImpor
66
68
  type: SkipSelf
67
69
  }] }]; }, propDecorators: { icons: [{
68
70
  type: ContentChildren,
69
- args: [McIcon, { descendants: true }]
71
+ args: [(forwardRef(() => McIcon))]
70
72
  }] } });
71
73
  /** @docs-private */
72
74
  export class McButtonBase {
@@ -143,4 +145,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.2", ngImpor
143
145
  }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.FocusMonitor }, { type: McButtonCssStyler }]; }, propDecorators: { disabled: [{
144
146
  type: Input
145
147
  }] } });
146
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../packages/mosaic/button/button.component.ts","../../../../packages/mosaic/button/button.component.html"],"names":[],"mappings":"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","sourcesContent":["import { FocusMonitor } from '@angular/cdk/a11y';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    Directive,\n    ElementRef,\n    OnDestroy,\n    ViewEncapsulation,\n    Renderer2,\n    QueryList,\n    ContentChildren,\n    AfterContentInit,\n    SkipSelf,\n    Input\n} from '@angular/core';\nimport {\n    mixinColor,\n    mixinTabIndex,\n    CanColor,\n    CanDisable,\n    CanColorCtor,\n    HasTabIndexCtor\n} from '@ptsecurity/mosaic/core';\nimport { McIcon } from '@ptsecurity/mosaic/icon';\n\n\nexport const leftIconClassName = 'mc-icon_left';\nexport const rightIconClassName = 'mc-icon_right';\n\nexport const buttonLeftIconClassName = 'mc-icon-button_left';\nexport const buttonRightIconClassName = 'mc-icon-button_right';\n\n@Directive({\n    selector: '[mc-button]',\n    host: {\n        '[class.mc-button]': '!isIconButton',\n        '[class.mc-icon-button]': 'isIconButton'\n    }\n})\nexport class McButtonCssStyler implements AfterContentInit {\n    @ContentChildren(McIcon, { descendants: true }) icons: QueryList<McIcon>;\n\n    nativeElement: HTMLElement;\n\n    isIconButton: boolean = false;\n\n    constructor(elementRef: ElementRef, private renderer: Renderer2, @SkipSelf() private cdr: ChangeDetectorRef) {\n        this.nativeElement = elementRef.nativeElement;\n    }\n\n    ngAfterContentInit() {\n        this.updateClassModifierForIcons();\n    }\n\n    updateClassModifierForIcons() {\n        this.renderer.removeClass(this.nativeElement, buttonLeftIconClassName);\n        this.renderer.removeClass(this.nativeElement, buttonRightIconClassName);\n\n        const twoIcons = 2;\n        const COMMENT_NODE = 8;\n        const filteredNodesWithoutComments = Array.from(\n            this.nativeElement.querySelector('.mc-button-wrapper')!.childNodes as NodeList\n        )\n            .filter((node) => node.nodeType !== COMMENT_NODE);\n        const currentIsIconButtonValue = !!this.icons.length &&\n            this.icons.length === filteredNodesWithoutComments.length && this.icons.length <= twoIcons;\n\n        if (currentIsIconButtonValue !== this.isIconButton) {\n            this.isIconButton = currentIsIconButtonValue;\n            this.cdr.detectChanges();\n        }\n\n        if (this.icons.length && filteredNodesWithoutComments.length > 1) {\n            this.icons.map((item) => item.getHostElement())\n                .forEach((iconHostElement) => {\n                    this.renderer.removeClass(iconHostElement, leftIconClassName);\n                    this.renderer.removeClass(iconHostElement, rightIconClassName);\n\n                    const iconIndex = filteredNodesWithoutComments.findIndex(\n                        (node) => node === iconHostElement\n                    );\n\n                    if (iconIndex === 0) {\n                        this.renderer.addClass(iconHostElement, leftIconClassName);\n                        this.renderer.addClass(this.nativeElement, buttonLeftIconClassName);\n                    }\n\n                    if (iconIndex === filteredNodesWithoutComments.length - 1) {\n                        this.renderer.addClass(iconHostElement, rightIconClassName);\n                        this.renderer.addClass(this.nativeElement, buttonRightIconClassName);\n                    }\n                });\n        }\n\n    }\n}\n\n/** @docs-private */\nexport class McButtonBase {\n    constructor(public elementRef: ElementRef) {}\n}\n\n/** @docs-private */\nexport const McButtonMixinBase: HasTabIndexCtor & CanColorCtor &\n    typeof McButtonBase = mixinTabIndex(mixinColor(McButtonBase));\n\n\n@Component({\n    selector: '[mc-button]',\n    templateUrl: './button.component.html',\n    styleUrls: ['./button.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    inputs: ['color', 'tabIndex'],\n    host: {\n        '[attr.disabled]': 'disabled || null',\n        '[attr.tabIndex]': 'tabIndex',\n\n        '(focus)': 'onFocus($event)',\n        '(blur)': 'onBlur()'\n    }\n})\nexport class McButton extends McButtonMixinBase implements OnDestroy, CanDisable, CanColor {\n    hasFocus: boolean = false;\n\n    @Input()\n    get disabled() {\n        return this._disabled;\n    }\n\n    set disabled(value: any) {\n        this._disabled = coerceBooleanProperty(value);\n\n        this._disabled ? this.stopFocusMonitor() : this.runFocusMonitor();\n    }\n\n    private _disabled: boolean = false;\n\n    constructor(elementRef: ElementRef, private focusMonitor: FocusMonitor, private styler: McButtonCssStyler) {\n        super(elementRef);\n\n        this.runFocusMonitor();\n    }\n\n    ngOnDestroy() {\n        this.stopFocusMonitor();\n    }\n\n    onFocus($event) {\n        $event.stopPropagation();\n\n        this.hasFocus = true;\n    }\n\n    onBlur() {\n        this.hasFocus = false;\n    }\n\n    getHostElement() {\n        return this.elementRef.nativeElement;\n    }\n\n    focus(): void {\n        this.hasFocus = true;\n\n        this.getHostElement().focus();\n    }\n\n    focusViaKeyboard(): void {\n        this.hasFocus = true;\n\n        this.focusMonitor.focusVia(this.getHostElement(), 'keyboard');\n    }\n\n    haltDisabledEvents(event: Event) {\n        if (this.disabled) {\n            event.preventDefault();\n            event.stopImmediatePropagation();\n            event.stopPropagation();\n        }\n    }\n\n    projectContentChanged() {\n        this.styler.updateClassModifierForIcons();\n    }\n\n    private runFocusMonitor() {\n        this.focusMonitor.monitor(this.elementRef.nativeElement, true);\n    }\n\n    private stopFocusMonitor() {\n        this.focusMonitor.stopMonitoring(this.elementRef.nativeElement);\n    }\n}\n\n","<div class=\"mc-button-wrapper\" (cdkObserveContent)=\"projectContentChanged()\">\n    <ng-content></ng-content>\n</div>\n<div class=\"mc-button-overlay\" (click)=\"haltDisabledEvents($event)\"></div>\n"]}
148
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../packages/mosaic/button/button.component.ts","../../../../packages/mosaic/button/button.component.html"],"names":[],"mappings":"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","sourcesContent":["import { FocusMonitor } from '@angular/cdk/a11y';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    Directive,\n    ElementRef,\n    OnDestroy,\n    ViewEncapsulation,\n    Renderer2,\n    QueryList,\n    ContentChildren,\n    AfterContentInit,\n    SkipSelf,\n    Input, forwardRef\n} from '@angular/core';\nimport {\n    mixinColor,\n    mixinTabIndex,\n    CanColor,\n    CanDisable,\n    CanColorCtor,\n    HasTabIndexCtor\n} from '@ptsecurity/mosaic/core';\nimport { McIcon } from '@ptsecurity/mosaic/icon';\n\n\nexport const leftIconClassName = 'mc-icon_left';\nexport const rightIconClassName = 'mc-icon_right';\n\nexport const buttonLeftIconClassName = 'mc-icon-button_left';\nexport const buttonRightIconClassName = 'mc-icon-button_right';\n\nexport const getNodesWithoutComments = (nodes: NodeList): Node[] => {\n    const COMMENT_NODE = 8;\n\n    return Array.from(nodes).filter((node) => node.nodeType !== COMMENT_NODE);\n};\n\n@Directive({\n    selector: '[mc-button]',\n    host: {\n        '[class.mc-button]': '!isIconButton',\n        '[class.mc-icon-button]': 'isIconButton'\n    }\n})\nexport class McButtonCssStyler implements AfterContentInit {\n    @ContentChildren((forwardRef(() => McIcon))) icons: QueryList<McIcon>;\n\n    nativeElement: HTMLElement;\n\n    isIconButton: boolean = false;\n\n    constructor(elementRef: ElementRef, private renderer: Renderer2, @SkipSelf() private cdr: ChangeDetectorRef) {\n        this.nativeElement = elementRef.nativeElement;\n    }\n\n    ngAfterContentInit() {\n        this.updateClassModifierForIcons();\n    }\n\n    updateClassModifierForIcons() {\n        this.renderer.removeClass(this.nativeElement, buttonLeftIconClassName);\n        this.renderer.removeClass(this.nativeElement, buttonRightIconClassName);\n\n        const twoIcons = 2;\n        const filteredNodesWithoutComments = getNodesWithoutComments(\n            this.nativeElement.querySelector('.mc-button-wrapper')!.childNodes as NodeList\n        );\n\n        const currentIsIconButtonValue = !!this.icons.length &&\n            this.icons.length === filteredNodesWithoutComments.length && this.icons.length <= twoIcons;\n\n        if (currentIsIconButtonValue !== this.isIconButton) {\n            this.isIconButton = currentIsIconButtonValue;\n            this.cdr.detectChanges();\n        }\n\n        if (this.icons.length && filteredNodesWithoutComments.length > 1) {\n            this.icons.map((item) => item.getHostElement())\n                .forEach((iconHostElement) => {\n                    this.renderer.removeClass(iconHostElement, leftIconClassName);\n                    this.renderer.removeClass(iconHostElement, rightIconClassName);\n\n                    const iconIndex = filteredNodesWithoutComments.findIndex(\n                        (node) => node === iconHostElement\n                    );\n\n                    if (iconIndex === 0) {\n                        this.renderer.addClass(iconHostElement, leftIconClassName);\n                        this.renderer.addClass(this.nativeElement, buttonLeftIconClassName);\n                    }\n\n                    if (iconIndex === filteredNodesWithoutComments.length - 1) {\n                        this.renderer.addClass(iconHostElement, rightIconClassName);\n                        this.renderer.addClass(this.nativeElement, buttonRightIconClassName);\n                    }\n                });\n        }\n\n    }\n}\n\n/** @docs-private */\nexport class McButtonBase {\n    constructor(public elementRef: ElementRef) {}\n}\n\n/** @docs-private */\nexport const McButtonMixinBase: HasTabIndexCtor & CanColorCtor &\n    typeof McButtonBase = mixinTabIndex(mixinColor(McButtonBase));\n\n\n@Component({\n    selector: '[mc-button]',\n    templateUrl: './button.component.html',\n    styleUrls: ['./button.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    inputs: ['color', 'tabIndex'],\n    host: {\n        '[attr.disabled]': 'disabled || null',\n        '[attr.tabIndex]': 'tabIndex',\n\n        '(focus)': 'onFocus($event)',\n        '(blur)': 'onBlur()'\n    }\n})\nexport class McButton extends McButtonMixinBase implements OnDestroy, CanDisable, CanColor {\n    hasFocus: boolean = false;\n\n    @Input()\n    get disabled() {\n        return this._disabled;\n    }\n\n    set disabled(value: any) {\n        this._disabled = coerceBooleanProperty(value);\n\n        this._disabled ? this.stopFocusMonitor() : this.runFocusMonitor();\n    }\n\n    private _disabled: boolean = false;\n\n    constructor(elementRef: ElementRef, private focusMonitor: FocusMonitor, private styler: McButtonCssStyler) {\n        super(elementRef);\n\n        this.runFocusMonitor();\n    }\n\n    ngOnDestroy() {\n        this.stopFocusMonitor();\n    }\n\n    onFocus($event) {\n        $event.stopPropagation();\n\n        this.hasFocus = true;\n    }\n\n    onBlur() {\n        this.hasFocus = false;\n    }\n\n    getHostElement() {\n        return this.elementRef.nativeElement;\n    }\n\n    focus(): void {\n        this.hasFocus = true;\n\n        this.getHostElement().focus();\n    }\n\n    focusViaKeyboard(): void {\n        this.hasFocus = true;\n\n        this.focusMonitor.focusVia(this.getHostElement(), 'keyboard');\n    }\n\n    haltDisabledEvents(event: Event) {\n        if (this.disabled) {\n            event.preventDefault();\n            event.stopImmediatePropagation();\n            event.stopPropagation();\n        }\n    }\n\n    projectContentChanged() {\n        this.styler.updateClassModifierForIcons();\n    }\n\n    private runFocusMonitor() {\n        this.focusMonitor.monitor(this.elementRef.nativeElement, true);\n    }\n\n    private stopFocusMonitor() {\n        this.focusMonitor.stopMonitoring(this.elementRef.nativeElement);\n    }\n}\n\n","<div class=\"mc-button-wrapper\" (cdkObserveContent)=\"projectContentChanged()\">\n    <ng-content></ng-content>\n</div>\n<div class=\"mc-button-overlay\" (click)=\"haltDisabledEvents($event)\"></div>\n"]}