@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.
- package/_theming.scss +675 -42
- package/_visual.scss +132 -42
- package/button/button.component.d.ts +1 -0
- package/button-toggle/_button-toggle-theme.scss +92 -0
- package/button-toggle/button-toggle.component.d.ts +6 -2
- package/button-toggle/button-toggle.module.d.ts +2 -1
- package/button-toggle/button-toggle.scss +109 -81
- package/core/styles/_mosaic-theme.scss +6 -0
- package/core/styles/theming/_components-theming.scss +92 -0
- package/core/utils/data-size/config.d.ts +20 -0
- package/core/utils/data-size/data-size.pipe.d.ts +13 -0
- package/core/utils/data-size/index.d.ts +3 -0
- package/core/utils/data-size/size.d.ts +16 -0
- package/core/utils/public-api.d.ts +1 -0
- package/ellipsis-center/ellipsis-center.directive.d.ts +27 -0
- package/ellipsis-center/index.d.ts +1 -0
- package/ellipsis-center/public-api.d.ts +1 -0
- package/esm2020/button/button.component.mjs +9 -7
- package/esm2020/button-toggle/button-toggle.component.mjs +28 -9
- package/esm2020/button-toggle/button-toggle.module.mjs +5 -4
- package/esm2020/core/utils/data-size/config.mjs +22 -0
- package/esm2020/core/utils/data-size/data-size.pipe.mjs +32 -0
- package/esm2020/core/utils/data-size/index.mjs +4 -0
- package/esm2020/core/utils/data-size/size.mjs +50 -0
- package/esm2020/core/utils/public-api.mjs +2 -1
- package/esm2020/core/version.mjs +2 -2
- package/esm2020/ellipsis-center/ellipsis-center.directive.mjs +106 -0
- package/esm2020/ellipsis-center/index.mjs +2 -0
- package/esm2020/ellipsis-center/ptsecurity-mosaic-ellipsis-center.mjs +5 -0
- package/esm2020/ellipsis-center/public-api.mjs +2 -0
- package/esm2020/file-upload/file-drop.mjs +43 -0
- package/esm2020/file-upload/file-upload.mjs +4 -0
- package/esm2020/file-upload/file-upload.module.mjs +66 -0
- package/esm2020/file-upload/index.mjs +2 -0
- package/esm2020/file-upload/multiple-file-upload.component.mjs +161 -0
- package/esm2020/file-upload/ptsecurity-mosaic-file-upload.mjs +5 -0
- package/esm2020/file-upload/public-api.mjs +6 -0
- package/esm2020/file-upload/single-file-upload.component.mjs +130 -0
- package/esm2020/select/select.component.mjs +5 -5
- package/esm2020/timezone/timezone-select.component.mjs +2 -2
- package/esm2020/tree-select/tree-select.component.mjs +8 -5
- package/fesm2015/ptsecurity-mosaic-button-toggle.mjs +31 -11
- package/fesm2015/ptsecurity-mosaic-button-toggle.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-button.mjs +9 -7
- package/fesm2015/ptsecurity-mosaic-button.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-core.mjs +101 -2
- package/fesm2015/ptsecurity-mosaic-core.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-ellipsis-center.mjs +113 -0
- package/fesm2015/ptsecurity-mosaic-ellipsis-center.mjs.map +1 -0
- package/fesm2015/ptsecurity-mosaic-file-upload.mjs +392 -0
- package/fesm2015/ptsecurity-mosaic-file-upload.mjs.map +1 -0
- package/fesm2015/ptsecurity-mosaic-select.mjs +4 -4
- package/fesm2015/ptsecurity-mosaic-select.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-timezone.mjs +2 -2
- package/fesm2015/ptsecurity-mosaic-timezone.mjs.map +1 -1
- package/fesm2015/ptsecurity-mosaic-tree-select.mjs +7 -4
- package/fesm2015/ptsecurity-mosaic-tree-select.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-button-toggle.mjs +31 -11
- package/fesm2020/ptsecurity-mosaic-button-toggle.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-button.mjs +9 -7
- package/fesm2020/ptsecurity-mosaic-button.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-core.mjs +101 -2
- package/fesm2020/ptsecurity-mosaic-core.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-ellipsis-center.mjs +111 -0
- package/fesm2020/ptsecurity-mosaic-ellipsis-center.mjs.map +1 -0
- package/fesm2020/ptsecurity-mosaic-file-upload.mjs +388 -0
- package/fesm2020/ptsecurity-mosaic-file-upload.mjs.map +1 -0
- package/fesm2020/ptsecurity-mosaic-select.mjs +4 -4
- package/fesm2020/ptsecurity-mosaic-select.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-timezone.mjs +2 -2
- package/fesm2020/ptsecurity-mosaic-timezone.mjs.map +1 -1
- package/fesm2020/ptsecurity-mosaic-tree-select.mjs +7 -4
- package/fesm2020/ptsecurity-mosaic-tree-select.mjs.map +1 -1
- package/file-upload/README.md +0 -0
- package/file-upload/_file-upload-theme.scss +174 -0
- package/file-upload/file-drop.d.ts +11 -0
- package/file-upload/file-upload.d.ts +22 -0
- package/file-upload/file-upload.module.d.ts +18 -0
- package/file-upload/file-upload.scss +46 -0
- package/file-upload/index.d.ts +1 -0
- package/file-upload/multiple-file-upload.component.d.ts +51 -0
- package/file-upload/multiple-file-upload.component.scss +148 -0
- package/file-upload/public-api.d.ts +5 -0
- package/file-upload/single-file-upload.component.d.ts +34 -0
- package/file-upload/single-file-upload.component.scss +60 -0
- package/package.json +18 -2
- package/prebuilt-themes/dark-theme.css +1 -1
- package/prebuilt-themes/default-theme.css +1 -1
- package/select/_select-theme.scss +6 -0
- package/select/select.component.d.ts +1 -1
- package/select/select.scss +13 -0
- package/tree-select/_tree-select-theme.scss +6 -0
- package/tree-select/tree-select.component.d.ts +2 -2
- 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
|
-
|
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
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
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
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
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
|
-
|
84
|
+
&.mc-button-toggle-icon-text {
|
47
85
|
> .mc-button,
|
48
86
|
> .mc-icon-button {
|
49
|
-
|
50
|
-
--mc-button-toggle-size-
|
51
|
-
map.get($tokens, button-toggle-size-
|
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
|
-
|
63
|
-
|
64
|
-
|
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
|
-
|
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
|
-
|
106
|
-
|
107
|
-
|
108
|
-
|
109
|
-
|
110
|
-
|
111
|
-
|
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
|
-
|
121
|
-
|
122
|
-
|
123
|
-
|
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,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
|
+
};
|
@@ -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
|
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:
|
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: [
|
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"]}
|