@indico-data/design-system 3.5.0 → 3.6.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/lib/components/icons/types.d.ts +1 -1
- package/lib/docs/BaseColorPalette/BaseColorPalette.d.ts +1 -0
- package/lib/docs/BaseColorPalette/BaseColorsPalette.stories.d.ts +6 -0
- package/lib/docs/SemanticTokens/ColorSwatch.d.ts +6 -0
- package/lib/docs/SemanticTokens/SemanticTokens.stories.d.ts +9 -0
- package/lib/index.css +6383 -3670
- package/lib/index.d.ts +1 -1
- package/lib/index.esm.css +6383 -3670
- package/lib/index.esm.js +2 -2
- package/lib/index.esm.js.map +1 -1
- package/lib/index.js +2 -2
- package/lib/index.js.map +1 -1
- package/package.json +1 -1
- package/src/components/badge/styles/Badge.scss +10 -10
- package/src/components/button/styles/Button.scss +7 -7
- package/src/components/button/styles/_variables.scss +5 -5
- package/src/components/card/styles/Card.scss +11 -13
- package/src/components/floatUI/styles/FloatUI.scss +3 -3
- package/src/components/forms/checkbox/styles/Checkbox.scss +11 -23
- package/src/components/forms/date/datePicker/styles/DatePicker.scss +25 -25
- package/src/components/forms/form/styles/Form.scss +19 -53
- package/src/components/forms/input/styles/Input.scss +10 -10
- package/src/components/forms/numberInput/styles/NumberInput.scss +13 -18
- package/src/components/forms/passwordInput/styles/PasswordInput.scss +12 -12
- package/src/components/forms/radio/styles/Radio.scss +8 -22
- package/src/components/forms/select/styles/Select.scss +38 -54
- package/src/components/forms/textarea/styles/Textarea.scss +11 -11
- package/src/components/forms/toggle/styles/Toggle.scss +14 -31
- package/src/components/icons/Icon.mdx +1 -1
- package/src/components/icons/Icon.stories.tsx +10 -9
- package/src/components/icons/styles/Icon.scss +2 -0
- package/src/components/icons/types.ts +1 -1
- package/src/components/menu/styles/Menu.scss +9 -9
- package/src/components/modal/styles/Modal.scss +23 -56
- package/src/components/pagination/styles/Pagination.scss +1 -1
- package/src/components/pill/styles/Pill.scss +8 -6
- package/src/components/skeleton/styles/Skeleton.scss +3 -3
- package/src/components/stepper/examples/constants.ts +2 -2
- package/src/components/stepper/styles/Stepper.scss +25 -71
- package/src/components/table/styles/Table.scss +8 -8
- package/src/components/tanstackTable/components/ActionBar/ActionBar.scss +3 -3
- package/src/components/tanstackTable/components/NoResults/NoResults.scss +3 -3
- package/src/components/tanstackTable/styles/table.scss +39 -40
- package/src/components/toast/styles/Toast.scss +20 -36
- package/src/components/tooltip/Tooltip.tsx +2 -2
- package/src/docs/BaseColorPalette/BaseColorPalette.mdx +35 -0
- package/src/docs/BaseColorPalette/BaseColorPalette.tsx +51 -0
- package/src/docs/BaseColorPalette/BaseColorsPalette.stories.tsx +13 -0
- package/src/{stylesAndAnimations/colors → docs/BaseColorPalette}/Swatch.tsx +32 -3
- package/src/docs/Primitives.mdx +110 -0
- package/src/docs/SemanticTokens/ColorSwatch.tsx +22 -0
- package/src/docs/SemanticTokens/SemanticTokens.mdx +53 -0
- package/src/docs/SemanticTokens/SemanticTokens.stories.tsx +152 -0
- package/src/styles/_borders.scss +16 -19
- package/src/styles/_colors.scss +16 -6
- package/src/styles/_spacing-utilities.scss +185 -0
- package/src/styles/_typography.scss +4 -4
- package/src/styles/globals.scss +7 -77
- package/src/styles/index.scss +3 -5
- package/src/styles/primitives/{_borderRadius.scss → _borders.scss} +7 -0
- package/src/styles/primitives/_colors.scss +0 -24
- package/src/styles/primitives/index.scss +1 -1
- package/src/styles/storybook.scss +9 -9
- package/src/styles/tokens/_semantic-tokens.scss +2 -1
- package/src/styles/variables/index.scss +0 -6
- package/src/stylesAndAnimations/borders/BorderColor.tsx +0 -4
- package/src/stylesAndAnimations/sizing/Sizing.mdx +4 -1
- package/src/stylesAndAnimations/utilityClasses/UtilityClassesData.ts +2 -1
- package/lib/stylesAndAnimations/colors/Colors.d.ts +0 -1
- package/lib/stylesAndAnimations/colors/Colors.stories.d.ts +0 -6
- package/lib/stylesAndAnimations/colors/constants.d.ts +0 -34
- package/lib/stylesAndAnimations/colors/index.d.ts +0 -1
- package/src/components/tooltip/styles/Tooltip.scss +0 -12
- package/src/styles/_gap.scss +0 -18
- package/src/styles/_margin.scss +0 -41
- package/src/styles/_padding.scss +0 -30
- package/src/styles/_sheets.scss +0 -7
- package/src/styles/variables/_borders.scss +0 -46
- package/src/styles/variables/_gap.scss +0 -19
- package/src/styles/variables/_icons.scss +0 -7
- package/src/styles/variables/_margin.scss +0 -37
- package/src/styles/variables/_padding.scss +0 -19
- package/src/styles/variables/_size.scss +0 -19
- package/src/stylesAndAnimations/colors/BaseColorPalette.mdx +0 -56
- package/src/stylesAndAnimations/colors/Colors.stories.tsx +0 -13
- package/src/stylesAndAnimations/colors/Colors.tsx +0 -64
- package/src/stylesAndAnimations/colors/constants.ts +0 -280
- package/src/stylesAndAnimations/colors/index.ts +0 -1
- /package/lib/{stylesAndAnimations/colors → docs/BaseColorPalette}/Swatch.d.ts +0 -0
- /package/src/{stylesAndAnimations/colors → docs/BaseColorPalette}/swatches.scss +0 -0
|
@@ -1,24 +1,10 @@
|
|
|
1
|
-
// Common Variables
|
|
2
|
-
|
|
3
|
-
:root [data-theme='light'] {
|
|
4
|
-
--pf-radio-check-color: var(--pf-primary-color);
|
|
5
|
-
--pf-radio-disabled-color: var(--pf-gray-color-400);
|
|
6
|
-
}
|
|
7
|
-
|
|
8
|
-
// Dark Theme Specific Variables
|
|
9
|
-
:root [data-theme='dark'],
|
|
10
|
-
:root {
|
|
11
|
-
--pf-radio-check-color: var(--pf-white-color);
|
|
12
|
-
--pf-radio-disabled-color: var(--pf-gray-color-300);
|
|
13
|
-
}
|
|
14
|
-
|
|
15
1
|
.radio-wrapper {
|
|
16
2
|
display: flex;
|
|
17
3
|
align-items: center;
|
|
18
4
|
}
|
|
19
5
|
.radio-input {
|
|
20
6
|
margin: 0;
|
|
21
|
-
margin-right: var(--pf-
|
|
7
|
+
margin-right: var(--pf-spacing-sm);
|
|
22
8
|
cursor: pointer;
|
|
23
9
|
}
|
|
24
10
|
.radio-input-label {
|
|
@@ -33,7 +19,7 @@
|
|
|
33
19
|
[type='radio']:checked + label,
|
|
34
20
|
[type='radio']:not(:checked) + label {
|
|
35
21
|
position: relative;
|
|
36
|
-
padding-left: var(--pf-
|
|
22
|
+
padding-left: var(--pf-spacing-5xl);
|
|
37
23
|
cursor: pointer;
|
|
38
24
|
line-height: 20px;
|
|
39
25
|
display: inline-block;
|
|
@@ -46,16 +32,16 @@
|
|
|
46
32
|
top: 0;
|
|
47
33
|
width: 18px;
|
|
48
34
|
height: 18px;
|
|
49
|
-
border: 1px solid var(--pf-
|
|
35
|
+
border: 1px solid var(--pf-semantic-border-primary);
|
|
50
36
|
border-radius: 100%;
|
|
51
|
-
background: var(--pf-
|
|
37
|
+
background: var(--pf-semantic-background-secondary);
|
|
52
38
|
}
|
|
53
39
|
[type='radio']:checked + label:after,
|
|
54
40
|
[type='radio']:not(:checked) + label:after {
|
|
55
41
|
content: '';
|
|
56
42
|
width: 12px;
|
|
57
43
|
height: 12px;
|
|
58
|
-
background: var(--pf-
|
|
44
|
+
background: var(--pf-semantic-background-inverted);
|
|
59
45
|
position: absolute;
|
|
60
46
|
top: 4px;
|
|
61
47
|
left: 4px;
|
|
@@ -79,14 +65,14 @@
|
|
|
79
65
|
}
|
|
80
66
|
|
|
81
67
|
[type='radio']:disabled + label {
|
|
82
|
-
color: var(--pf-
|
|
68
|
+
color: var(--pf-semantic-font-disabled);
|
|
83
69
|
opacity: 0.5;
|
|
84
70
|
}
|
|
85
71
|
|
|
86
72
|
[type='radio']:disabled + label:before {
|
|
87
|
-
border-color: var(--pf-
|
|
73
|
+
border-color: var(--pf-semantic-font-disabled);
|
|
88
74
|
}
|
|
89
75
|
|
|
90
76
|
[type='radio']:disabled + label:after {
|
|
91
|
-
background: var(--pf-
|
|
77
|
+
background: var(--pf-semantic-font-disabled);
|
|
92
78
|
}
|
|
@@ -1,44 +1,28 @@
|
|
|
1
|
-
// Light Theme Specific Variables
|
|
2
|
-
:root [data-theme='light'] {
|
|
3
|
-
--pf-select-indicator-color: var(--pf-font-color-accent);
|
|
4
|
-
--pf-select-option-selected-color: var(--pf-background-color-accent);
|
|
5
|
-
--pf-select-option-color: var(--pf-font-color);
|
|
6
|
-
--pf-select-option-hover-color: var(--pf-background-color-highlight);
|
|
7
|
-
}
|
|
8
|
-
|
|
9
|
-
// Dark Theme and Default Variables
|
|
10
|
-
:root [data-theme='dark'],
|
|
11
|
-
:root {
|
|
12
|
-
--pf-select-indicator-color: var(--pf-font-color-accent);
|
|
13
|
-
--pf-select-option-selected-color: var(--pf-background-color-accent);
|
|
14
|
-
--pf-select-option-color: var(--pf-font-color);
|
|
15
|
-
--pf-select-option-hover-color: var(--pf-background-color-highlight);
|
|
16
|
-
}
|
|
17
1
|
.select-wrapper {
|
|
18
2
|
.select__ {
|
|
19
3
|
&control {
|
|
20
|
-
background-color: var(--pf-
|
|
21
|
-
border: var(--pf-border-sm) solid var(--pf-
|
|
22
|
-
color: var(--pf-
|
|
4
|
+
background-color: var(--pf-semantic-background-secondary);
|
|
5
|
+
border: var(--pf-border-sm) solid var(--pf-semantic-border-primary);
|
|
6
|
+
color: var(--pf-semantic-font-regular);
|
|
23
7
|
box-shadow: none;
|
|
24
8
|
|
|
25
9
|
&:hover:not(:focus) {
|
|
26
|
-
border-color: var(--pf-
|
|
10
|
+
border-color: var(--pf-semantic-border-hover);
|
|
27
11
|
}
|
|
28
12
|
|
|
29
13
|
&:focus,
|
|
30
14
|
&--is-focused {
|
|
31
|
-
border: var(--pf-border-sm) solid var(--pf-
|
|
15
|
+
border: var(--pf-border-sm) solid var(--pf-semantic-border-accent);
|
|
32
16
|
}
|
|
33
17
|
|
|
34
18
|
&--is-disabled {
|
|
35
|
-
background-color: var(--pf-
|
|
36
|
-
color: var(--pf-
|
|
19
|
+
background-color: var(--pf-semantic-page-background);
|
|
20
|
+
color: var(--pf-semantic-font-disabled);
|
|
37
21
|
}
|
|
38
22
|
}
|
|
39
23
|
|
|
40
24
|
&placeholder {
|
|
41
|
-
color: var(--pf-
|
|
25
|
+
color: var(--pf-semantic-font-placeholder);
|
|
42
26
|
}
|
|
43
27
|
|
|
44
28
|
&value-container {
|
|
@@ -46,48 +30,48 @@
|
|
|
46
30
|
}
|
|
47
31
|
|
|
48
32
|
&input-container {
|
|
49
|
-
color: var(--pf-
|
|
33
|
+
color: var(--pf-semantic-font-regular);
|
|
50
34
|
}
|
|
51
35
|
|
|
52
36
|
&multi-value {
|
|
53
|
-
background-color: var(--pf-
|
|
54
|
-
border-radius: var(--pf-
|
|
37
|
+
background-color: var(--pf-semantic-background-accent);
|
|
38
|
+
border-radius: var(--pf-border-radius-xs);
|
|
55
39
|
&__label {
|
|
56
40
|
padding-top: 5px; // TODO -- clean up padding on this component overall
|
|
57
|
-
color: var(--pf-
|
|
41
|
+
color: var(--pf-semantic-font-regular);
|
|
58
42
|
}
|
|
59
43
|
&__remove {
|
|
60
|
-
color: var(--pf-
|
|
44
|
+
color: var(--pf-semantic-font-regular);
|
|
61
45
|
cursor: pointer;
|
|
62
46
|
&:hover {
|
|
63
|
-
background-color: var(--pf-
|
|
64
|
-
color: var(--pf-
|
|
47
|
+
background-color: var(--pf-semantic-background-highlight);
|
|
48
|
+
color: var(--pf-semantic-font-regular);
|
|
65
49
|
}
|
|
66
50
|
}
|
|
67
51
|
}
|
|
68
52
|
|
|
69
53
|
&menu {
|
|
70
|
-
border: var(--pf-border-sm) solid var(--pf-
|
|
54
|
+
border: var(--pf-border-sm) solid var(--pf-semantic-border-primary);
|
|
71
55
|
box-shadow: 0px 1px 8px 0px rgba(0, 0, 0, 0.4);
|
|
72
|
-
margin: var(--pf-
|
|
73
|
-
background-color: var(--pf-
|
|
56
|
+
margin: var(--pf-spacing-sm) 0;
|
|
57
|
+
background-color: var(--pf-semantic-background-secondary);
|
|
74
58
|
}
|
|
75
59
|
|
|
76
60
|
&menu-notice {
|
|
77
|
-
color: var(--pf-
|
|
61
|
+
color: var(--pf-semantic-font-regular);
|
|
78
62
|
}
|
|
79
63
|
|
|
80
64
|
&indicator-separator {
|
|
81
|
-
background-color: var(--pf-
|
|
65
|
+
background-color: var(--pf-semantic-font-accent);
|
|
82
66
|
}
|
|
83
67
|
|
|
84
68
|
&indicator {
|
|
85
69
|
cursor: pointer;
|
|
86
|
-
color: var(--pf-
|
|
70
|
+
color: var(--pf-semantic-font-accent);
|
|
87
71
|
|
|
88
72
|
&:hover,
|
|
89
73
|
&:focus {
|
|
90
|
-
color: var(--pf-
|
|
74
|
+
color: var(--pf-semantic-font-regular);
|
|
91
75
|
}
|
|
92
76
|
}
|
|
93
77
|
|
|
@@ -103,19 +87,19 @@
|
|
|
103
87
|
&option {
|
|
104
88
|
cursor: pointer;
|
|
105
89
|
overflow-wrap: break-word;
|
|
106
|
-
color: var(--pf-
|
|
90
|
+
color: var(--pf-semantic-font-regular);
|
|
107
91
|
&--is-focused,
|
|
108
92
|
&:active {
|
|
109
|
-
background: var(--pf-
|
|
93
|
+
background: var(--pf-semantic-background-highlight);
|
|
110
94
|
}
|
|
111
95
|
|
|
112
96
|
&--is-selected {
|
|
113
|
-
background: var(--pf-
|
|
97
|
+
background: var(--pf-semantic-background-accent);
|
|
114
98
|
}
|
|
115
99
|
}
|
|
116
100
|
|
|
117
101
|
&single-value {
|
|
118
|
-
color: var(--pf-
|
|
102
|
+
color: var(--pf-semantic-font-regular);
|
|
119
103
|
}
|
|
120
104
|
}
|
|
121
105
|
}
|
|
@@ -128,16 +112,16 @@ body .select__menu-portal {
|
|
|
128
112
|
/* Apply theme styling to portal elements */
|
|
129
113
|
body {
|
|
130
114
|
div[class*='select__menu'] {
|
|
131
|
-
background-color: var(--pf-
|
|
115
|
+
background-color: var(--pf-semantic-background-secondary);
|
|
132
116
|
}
|
|
133
117
|
|
|
134
118
|
div[class*='select__menu-list'] {
|
|
135
|
-
background-color: var(--pf-
|
|
119
|
+
background-color: var(--pf-semantic-background-secondary);
|
|
136
120
|
}
|
|
137
121
|
|
|
138
122
|
div[class*='select__option'] {
|
|
139
|
-
background-color: var(--pf-
|
|
140
|
-
color: var(--pf-
|
|
123
|
+
background-color: var(--pf-semantic-background-secondary);
|
|
124
|
+
color: var(--pf-semantic-font-regular);
|
|
141
125
|
cursor: pointer;
|
|
142
126
|
overflow-wrap: break-word;
|
|
143
127
|
|
|
@@ -145,24 +129,24 @@ body {
|
|
|
145
129
|
&.select__option--is-focused,
|
|
146
130
|
&[class*='--is-focused'],
|
|
147
131
|
&:active {
|
|
148
|
-
background: var(--pf-
|
|
149
|
-
color: var(--pf-
|
|
132
|
+
background: var(--pf-semantic-background-primary);
|
|
133
|
+
color: var(--pf-semantic-font-regular);
|
|
150
134
|
}
|
|
151
135
|
|
|
152
136
|
&.select__option--is-selected,
|
|
153
137
|
&[class*='--is-selected'] {
|
|
154
|
-
background: var(--pf-
|
|
155
|
-
color: var(--pf-
|
|
138
|
+
background: var(--pf-semantic-background-highlight);
|
|
139
|
+
color: var(--pf-semantic-font-regular);
|
|
156
140
|
}
|
|
157
141
|
}
|
|
158
142
|
|
|
159
143
|
div[class*='select__control'] {
|
|
160
|
-
background-color: var(--pf-
|
|
161
|
-
border: var(--pf-border-sm) solid var(--pf-
|
|
162
|
-
color: var(--pf-
|
|
144
|
+
background-color: var(--pf-semantic-background-secondary);
|
|
145
|
+
border: var(--pf-border-sm) solid var(--pf-semantic-border-primary);
|
|
146
|
+
color: var(--pf-semantic-font-regular);
|
|
163
147
|
}
|
|
164
148
|
|
|
165
149
|
div[class*='select__single-value'] {
|
|
166
|
-
color: var(--pf-
|
|
150
|
+
color: var(--pf-semantic-font-regular);
|
|
167
151
|
}
|
|
168
152
|
}
|
|
@@ -1,23 +1,23 @@
|
|
|
1
1
|
.textarea {
|
|
2
2
|
padding: 10px;
|
|
3
3
|
&.error {
|
|
4
|
-
border-color: var(--pf-error-
|
|
4
|
+
border-color: var(--pf-semantic-utility-error-default);
|
|
5
5
|
}
|
|
6
6
|
|
|
7
7
|
&.success {
|
|
8
|
-
border-color: var(--pf-success-
|
|
8
|
+
border-color: var(--pf-semantic-utility-success-default);
|
|
9
9
|
}
|
|
10
10
|
|
|
11
11
|
&.warning {
|
|
12
|
-
border-color: var(--pf-warning-
|
|
12
|
+
border-color: var(--pf-semantic-utility-warning-default);
|
|
13
13
|
}
|
|
14
14
|
|
|
15
15
|
&.info {
|
|
16
|
-
border-color: var(--pf-info-
|
|
16
|
+
border-color: var(--pf-semantic-utility-info-default);
|
|
17
17
|
}
|
|
18
18
|
|
|
19
19
|
&--has-icon {
|
|
20
|
-
padding-left: var(--pf-
|
|
20
|
+
padding-left: var(--pf-spacing-5xl);
|
|
21
21
|
}
|
|
22
22
|
}
|
|
23
23
|
|
|
@@ -25,13 +25,13 @@
|
|
|
25
25
|
list-style: none;
|
|
26
26
|
padding: 0;
|
|
27
27
|
margin: 0;
|
|
28
|
-
margin-top: var(--pf-
|
|
29
|
-
margin-bottom: var(--pf-
|
|
30
|
-
color: var(--pf-error-
|
|
28
|
+
margin-top: var(--pf-spacing-sm);
|
|
29
|
+
margin-bottom: var(--pf-spacing-sm);
|
|
30
|
+
color: var(--pf-semantic-utility-error-default);
|
|
31
31
|
}
|
|
32
32
|
.help-text {
|
|
33
|
-
margin-top: var(--pf-
|
|
34
|
-
margin-bottom: var(--pf-
|
|
35
|
-
color: var(--pf-
|
|
33
|
+
margin-top: var(--pf-spacing-sm);
|
|
34
|
+
margin-bottom: var(--pf-spacing-sm);
|
|
35
|
+
color: var(--pf-semantic-font-mute);
|
|
36
36
|
font-size: var(--pf-font-size-subtitle2);
|
|
37
37
|
}
|
|
@@ -1,52 +1,35 @@
|
|
|
1
|
-
// Common Variables
|
|
2
|
-
|
|
3
|
-
:root [data-theme='light'] {
|
|
4
|
-
--pf-toggle-background-color: var(--pf-form-input-background-color);
|
|
5
|
-
--pf-toggle-circle-color: var(--pf-primary-color);
|
|
6
|
-
--pf-toggle-border-color: var(--pf-form-input-border-color);
|
|
7
|
-
--pf-toggle-disabled-background-color: var(--pf-form-input-disabled-background-color);
|
|
8
|
-
--pf-toggle-disabled-circle-color: var(--pf-form-input-disabled-color);
|
|
9
|
-
--pf-toggle-checked-background-color: var(--pf-primary-color-300);
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
// Dark Theme Specific Variables
|
|
13
|
-
:root [data-theme='dark'],
|
|
14
|
-
:root {
|
|
15
|
-
--pf-toggle-background-color: var(--pf-form-input-background-color);
|
|
16
|
-
--pf-toggle-circle-color: var(--pf-white-color);
|
|
17
|
-
--pf-toggle-border-color: var(--pf-primary-color);
|
|
18
|
-
--pf-toggle-disabled-background-color: var(--pf-form-input-disabled-background-color);
|
|
19
|
-
--pf-toggle-disabled-circle-color: var(--pf-form-input-disabled-color);
|
|
20
|
-
--pf-toggle-checked-background-color: var(--pf-secondary-color-400);
|
|
21
|
-
}
|
|
22
1
|
.switch {
|
|
23
2
|
position: relative;
|
|
24
3
|
display: inline-block;
|
|
25
4
|
width: 40px;
|
|
26
5
|
height: 20px;
|
|
27
|
-
background-color: var(--pf-
|
|
6
|
+
background-color: var(--pf-semantic-background-tertiary);
|
|
28
7
|
border-radius: 20px;
|
|
29
8
|
transition: all 0.3s;
|
|
30
9
|
cursor: pointer;
|
|
31
|
-
border: 1px solid var(--pf-
|
|
10
|
+
border: 1px solid var(--pf-semantic-border-primary);
|
|
32
11
|
}
|
|
33
12
|
.switch::after {
|
|
34
13
|
content: '';
|
|
35
14
|
position: absolute;
|
|
36
|
-
width:
|
|
37
|
-
height:
|
|
15
|
+
width: 16px;
|
|
16
|
+
height: 16px;
|
|
38
17
|
border-radius: 50%;
|
|
39
|
-
background-color: var(--pf-
|
|
18
|
+
background-color: var(--pf-semantic-background-secondary);
|
|
19
|
+
box-shadow:
|
|
20
|
+
-1px 1px 2px 0 var(--pf-shadow-xs),
|
|
21
|
+
0 1px 3px 0 var(--pf-shadow-xs);
|
|
40
22
|
top: 1px;
|
|
41
23
|
left: 1px;
|
|
42
24
|
transition: all 0.3s;
|
|
25
|
+
border: 1px solid var(--pf-semantic-border-primary);
|
|
43
26
|
}
|
|
44
27
|
|
|
45
28
|
.toggle-input:checked + label.switch::after {
|
|
46
|
-
left:
|
|
29
|
+
left: 21px;
|
|
47
30
|
}
|
|
48
31
|
.toggle-input:checked + label.switch {
|
|
49
|
-
background-color: var(--pf-
|
|
32
|
+
background-color: var(--pf-semantic-font-accent);
|
|
50
33
|
}
|
|
51
34
|
.toggle-input:checked,
|
|
52
35
|
.toggle-input:not(:checked) {
|
|
@@ -54,12 +37,12 @@
|
|
|
54
37
|
left: -9999px;
|
|
55
38
|
}
|
|
56
39
|
.toggle-input:disabled + label.switch {
|
|
57
|
-
background-color: var(--pf-
|
|
40
|
+
background-color: var(--pf-semantic-background-primary);
|
|
58
41
|
cursor: not-allowed;
|
|
59
42
|
}
|
|
60
43
|
|
|
61
44
|
.toggle-input:disabled + label.switch::after {
|
|
62
|
-
background-color: var(--pf-
|
|
45
|
+
background-color: var(--pf-semantic-font-disabled);
|
|
63
46
|
}
|
|
64
47
|
|
|
65
48
|
.toggle-wrapper {
|
|
@@ -69,6 +52,6 @@
|
|
|
69
52
|
|
|
70
53
|
.toggle-label {
|
|
71
54
|
cursor: pointer;
|
|
72
|
-
margin-left: var(--pf-
|
|
55
|
+
margin-left: var(--pf-spacing-sm);
|
|
73
56
|
font-size: var(--pf-font-size-form-label);
|
|
74
57
|
}
|
|
@@ -31,7 +31,7 @@ You can use the `className` prop to apply custom styles to the icons.
|
|
|
31
31
|
|
|
32
32
|
<Story of={IconStories.CustomStyledIcon} />
|
|
33
33
|
```tsx // .tsx
|
|
34
|
-
<Icon name="fa-mountain-sun" size="xl"
|
|
34
|
+
<Icon name="fa-mountain-sun" size="xl" style={{ color: 'var(--pf-semantic-font-success)' }} />
|
|
35
35
|
```
|
|
36
36
|
|
|
37
37
|
### Duotone Icons
|
|
@@ -42,9 +42,9 @@ const meta: Meta = {
|
|
|
42
42
|
},
|
|
43
43
|
size: {
|
|
44
44
|
control: 'select',
|
|
45
|
-
options: ['xs', 'sm', 'md', 'lg', 'xl'],
|
|
45
|
+
options: ['xs', 'sm', 'md', 'lg', 'xl', '2xl', '3xl'],
|
|
46
46
|
table: {
|
|
47
|
-
type: { summary: 'xs | sm | md | lg | xl' },
|
|
47
|
+
type: { summary: 'xs | sm | md | lg | xl | 2xl | 3xl' },
|
|
48
48
|
category: 'styling',
|
|
49
49
|
},
|
|
50
50
|
},
|
|
@@ -77,15 +77,14 @@ export const DefaultIcon: Story = {
|
|
|
77
77
|
|
|
78
78
|
export const IconStates: Story = {
|
|
79
79
|
render: (args) => {
|
|
80
|
-
const sizes: IconSizes[] = ['xs', 'sm', 'md', 'lg', 'xl'];
|
|
81
|
-
const rems = ['
|
|
80
|
+
const sizes: IconSizes[] = ['xs', 'sm', 'md', 'lg', 'xl', '2xl', '3xl'];
|
|
81
|
+
const rems = ['10px', '12px', '16px', '24px', '32px', '48px', '64px'];
|
|
82
|
+
|
|
82
83
|
return (
|
|
83
84
|
<Row>
|
|
84
85
|
{sizes.map((size, idx) => (
|
|
85
|
-
<Col xs={
|
|
86
|
-
<
|
|
87
|
-
<Icon name={args.name} size={size} />
|
|
88
|
-
</div>
|
|
86
|
+
<Col xs={3} key={`${args.name}-${size}`}>
|
|
87
|
+
<Icon name={args.name} size={size} />
|
|
89
88
|
<div className="mt-2 text-body-2">{`${size} (${rems[idx]})`}</div>
|
|
90
89
|
</Col>
|
|
91
90
|
))}
|
|
@@ -99,7 +98,9 @@ export const IconStates: Story = {
|
|
|
99
98
|
|
|
100
99
|
export const CustomStyledIcon: Story = {
|
|
101
100
|
render: () => {
|
|
102
|
-
return
|
|
101
|
+
return (
|
|
102
|
+
<Icon name="fa-mountain-sun" size="xl" style={{ color: 'var(--pf-semantic-font-success)' }} />
|
|
103
|
+
);
|
|
103
104
|
},
|
|
104
105
|
};
|
|
105
106
|
|
|
@@ -3,7 +3,7 @@ import { PermafrostComponent } from '../../types';
|
|
|
3
3
|
import { IconName as FAIconName } from '@fortawesome/fontawesome-svg-core';
|
|
4
4
|
import { indicons } from './indicons';
|
|
5
5
|
|
|
6
|
-
export type IconSizes = 'xs' | 'sm' | 'md' | 'lg' | 'xl';
|
|
6
|
+
export type IconSizes = 'xs' | 'sm' | 'md' | 'lg' | 'xl' | '2xl' | '3xl';
|
|
7
7
|
|
|
8
8
|
export type IndiconName = keyof typeof indicons;
|
|
9
9
|
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
.menu {
|
|
2
|
-
border-radius: var(--pf-
|
|
2
|
+
border-radius: var(--pf-border-radius-xs);
|
|
3
3
|
|
|
4
4
|
.menu-item {
|
|
5
5
|
width: 100%;
|
|
6
|
-
background: var(--pf-background-
|
|
7
|
-
color: var(--pf-font-
|
|
6
|
+
background: var(--pf-semantic-background-secondary);
|
|
7
|
+
color: var(--pf-semantic-font-regular);
|
|
8
8
|
display: block;
|
|
9
9
|
width: 100%;
|
|
10
10
|
text-align: left;
|
|
@@ -12,22 +12,22 @@
|
|
|
12
12
|
border-radius: 0;
|
|
13
13
|
|
|
14
14
|
&:first-child {
|
|
15
|
-
border-top-left-radius: var(--pf-
|
|
16
|
-
border-top-right-radius: var(--pf-
|
|
15
|
+
border-top-left-radius: var(--pf-border-radius-xs);
|
|
16
|
+
border-top-right-radius: var(--pf-border-radius-xs);
|
|
17
17
|
}
|
|
18
18
|
|
|
19
19
|
&:last-child {
|
|
20
|
-
border-bottom-left-radius: var(--pf-
|
|
21
|
-
border-bottom-right-radius: var(--pf-
|
|
20
|
+
border-bottom-left-radius: var(--pf-border-radius-xs);
|
|
21
|
+
border-bottom-right-radius: var(--pf-border-radius-xs);
|
|
22
22
|
}
|
|
23
23
|
|
|
24
24
|
&:hover {
|
|
25
|
-
background: var(--pf-background-
|
|
25
|
+
background: var(--pf-semantic-background-highlight);
|
|
26
26
|
}
|
|
27
27
|
|
|
28
28
|
box-shadow: none;
|
|
29
29
|
&:focus {
|
|
30
|
-
background-color: var(--pf-background-
|
|
30
|
+
background-color: var(--pf-semantic-background-accent);
|
|
31
31
|
}
|
|
32
32
|
}
|
|
33
33
|
}
|
|
@@ -1,36 +1,3 @@
|
|
|
1
|
-
// Common Variables
|
|
2
|
-
:root {
|
|
3
|
-
--pf-modal-rounded: var(--pf-rounded-lg);
|
|
4
|
-
--pf-modal-close-button-top: var(--pf-margin-2);
|
|
5
|
-
--pf-modal-close-button-right: var(--pf-margin-2);
|
|
6
|
-
--pf-modal-close-button-padding: var(--pf-padding-3) var(--pf-padding-4);
|
|
7
|
-
--pf-modal-title-font-size: var(--pf-font-size-h1);
|
|
8
|
-
--pf-modal-title-font-weight: var(--pf-font-weight-bold);
|
|
9
|
-
--pf-modal-subtitle-font-size: var(--pf-font-size-body);
|
|
10
|
-
--pf-modal-close-button-font-size: var(--pf-font-size-caption);
|
|
11
|
-
--pf-modal-close-button-icon-size: var(--pf-font-size-caption);
|
|
12
|
-
--pf-modal-overlay-background: rgba(0, 0, 0, 0.5);
|
|
13
|
-
--pf-modal-overlay-transition: opacity 100ms ease-in-out;
|
|
14
|
-
--pf-modal-content-padding: var(--pf-padding-5) var(--pf-padding-6);
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
// Light Theme Specific Variables
|
|
18
|
-
:root [data-theme='light'] {
|
|
19
|
-
--pf-modal-background-color: var(--pf-background-color-secondary);
|
|
20
|
-
--pf-modal-border-color: var(--pf-border-color-secondary);
|
|
21
|
-
--pf-modal-subtitle-font-color: var(--pf-font-color-soft);
|
|
22
|
-
--pf-modal-close-button-font-color: var(--pf-font-color-soft);
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
// Dark Theme Specific Variables
|
|
26
|
-
:root [data-theme='dark'],
|
|
27
|
-
:root {
|
|
28
|
-
--pf-modal-background-color: var(--pf-background-color-secondary);
|
|
29
|
-
--pf-modal-border-color: var(--pf-border-color-secondary);
|
|
30
|
-
--pf-modal-subtitle-font-color: var(--pf-font-color-soft);
|
|
31
|
-
--pf-modal-close-button-font-color: var(--pf-font-color-soft);
|
|
32
|
-
}
|
|
33
|
-
|
|
34
1
|
// Library overrides
|
|
35
2
|
.ReactModal__Overlay {
|
|
36
3
|
position: fixed;
|
|
@@ -38,14 +5,14 @@
|
|
|
38
5
|
left: 0;
|
|
39
6
|
right: 0;
|
|
40
7
|
bottom: 0;
|
|
41
|
-
background-color:
|
|
8
|
+
background-color: rgba(0, 0, 0, 0.5);
|
|
42
9
|
display: flex;
|
|
43
10
|
align-items: center;
|
|
44
11
|
justify-content: center;
|
|
45
12
|
}
|
|
46
13
|
.ReactModal__Overlay {
|
|
47
14
|
opacity: 0;
|
|
48
|
-
transition:
|
|
15
|
+
transition: opacity 100ms ease-in-out;
|
|
49
16
|
}
|
|
50
17
|
|
|
51
18
|
.ReactModal__Overlay--after-open {
|
|
@@ -60,8 +27,8 @@
|
|
|
60
27
|
position: absolute;
|
|
61
28
|
left: 50%;
|
|
62
29
|
transform: translateX(-50%);
|
|
63
|
-
background: var(--pf-background-
|
|
64
|
-
border-radius: var(--pf-
|
|
30
|
+
background: var(--pf-semantic-background-primary);
|
|
31
|
+
border-radius: var(--pf-border-radius-md);
|
|
65
32
|
outline: none;
|
|
66
33
|
|
|
67
34
|
&--center {
|
|
@@ -74,13 +41,13 @@
|
|
|
74
41
|
}
|
|
75
42
|
|
|
76
43
|
.modal-content {
|
|
77
|
-
background-color: var(--pf-
|
|
78
|
-
border: var(--pf-border-sm) solid var(--pf-
|
|
79
|
-
border-radius: var(--pf-
|
|
44
|
+
background-color: var(--pf-semantic-background-secondary);
|
|
45
|
+
border: var(--pf-border-sm) solid var(--pf-semantic-border-secondary);
|
|
46
|
+
border-radius: var(--pf-border-radius-md);
|
|
80
47
|
}
|
|
81
48
|
.modal-header {
|
|
82
|
-
border-bottom: var(--pf-border-sm) solid var(--pf-
|
|
83
|
-
padding: var(--pf-
|
|
49
|
+
border-bottom: var(--pf-border-sm) solid var(--pf-semantic-border-secondary);
|
|
50
|
+
padding: var(--pf-spacing-3xl) var(--pf-spacing-4xl);
|
|
84
51
|
|
|
85
52
|
.modal-title {
|
|
86
53
|
font-size: var(--pf-font-size-h1);
|
|
@@ -88,23 +55,23 @@
|
|
|
88
55
|
}
|
|
89
56
|
.modal-subtitle {
|
|
90
57
|
font-size: var(--pf-font-size-subtitle);
|
|
91
|
-
color: var(--pf-
|
|
58
|
+
color: var(--pf-semantic-font-soft);
|
|
92
59
|
}
|
|
93
60
|
}
|
|
94
61
|
|
|
95
62
|
.modal-close-button {
|
|
96
63
|
position: absolute;
|
|
97
|
-
top: var(--pf-
|
|
98
|
-
right: var(--pf-
|
|
99
|
-
padding: var(--pf-
|
|
100
|
-
font-size: var(--pf-
|
|
101
|
-
color: var(--pf-
|
|
64
|
+
top: var(--pf-spacing-sm);
|
|
65
|
+
right: var(--pf-spacing-sm);
|
|
66
|
+
padding: var(--pf-spacing-lg) var(--pf-spacing-2xl);
|
|
67
|
+
font-size: var(--pf-font-size-caption);
|
|
68
|
+
color: var(--pf-semantic-font-soft);
|
|
102
69
|
line-height: 1;
|
|
103
70
|
z-index: 1000;
|
|
104
71
|
|
|
105
72
|
&.btn .icon {
|
|
106
|
-
width: var(--pf-
|
|
107
|
-
height: var(--pf-
|
|
73
|
+
width: var(--pf-font-size-caption) !important;
|
|
74
|
+
height: var(--pf-font-size-caption);
|
|
108
75
|
|
|
109
76
|
svg {
|
|
110
77
|
width: 100%;
|
|
@@ -114,12 +81,12 @@
|
|
|
114
81
|
}
|
|
115
82
|
|
|
116
83
|
.modal-body {
|
|
117
|
-
padding: var(--pf-
|
|
84
|
+
padding: var(--pf-spacing-3xl) var(--pf-spacing-4xl);
|
|
118
85
|
}
|
|
119
86
|
|
|
120
87
|
.modal-footer {
|
|
121
|
-
padding: var(--pf-
|
|
122
|
-
border-top: var(--pf-border-sm) solid var(--pf-
|
|
88
|
+
padding: var(--pf-spacing-3xl) var(--pf-spacing-4xl);
|
|
89
|
+
border-top: var(--pf-border-sm) solid var(--pf-semantic-border-secondary);
|
|
123
90
|
text-align: right;
|
|
124
91
|
}
|
|
125
92
|
}
|
|
@@ -128,11 +95,11 @@
|
|
|
128
95
|
.confirmation-modal-title {
|
|
129
96
|
font-size: var(--pf-font-size-h1);
|
|
130
97
|
font-weight: var(--pf-font-weight-bold);
|
|
131
|
-
margin-bottom: var(--pf-
|
|
98
|
+
margin-bottom: var(--pf-spacing-2xl);
|
|
132
99
|
}
|
|
133
100
|
|
|
134
101
|
.confirmation-modal-icon {
|
|
135
|
-
margin-top: var(--pf-
|
|
136
|
-
margin-bottom: var(--pf-
|
|
102
|
+
margin-top: var(--pf-spacing-2xl);
|
|
103
|
+
margin-bottom: var(--pf-spacing-2xl);
|
|
137
104
|
}
|
|
138
105
|
}
|