@cfpb/cfpb-design-system 4.1.0 → 4.2.0
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/CHANGELOG.md +36 -1
- package/dist/base/index.css +1 -1
- package/dist/base/index.css.map +2 -2
- package/dist/base/index.js +1 -1
- package/dist/base/index.js.map +1 -1
- package/dist/components/cfpb-buttons/index.css +1 -1
- package/dist/components/cfpb-buttons/index.css.map +2 -2
- package/dist/components/cfpb-buttons/index.js +1 -1
- package/dist/components/cfpb-buttons/index.js.map +1 -1
- package/dist/components/cfpb-expandables/index.css +1 -1
- package/dist/components/cfpb-expandables/index.css.map +2 -2
- package/dist/components/cfpb-expandables/index.js.map +1 -1
- package/dist/components/cfpb-forms/index.css +1 -1
- package/dist/components/cfpb-forms/index.css.map +2 -2
- package/dist/components/cfpb-forms/index.js +1 -1
- package/dist/components/cfpb-forms/index.js.map +1 -1
- package/dist/components/cfpb-layout/index.css +1 -1
- package/dist/components/cfpb-layout/index.css.map +2 -2
- package/dist/components/cfpb-layout/index.js.map +1 -1
- package/dist/components/cfpb-notifications/index.css +1 -1
- package/dist/components/cfpb-notifications/index.css.map +2 -2
- package/dist/components/cfpb-notifications/index.js +1 -1
- package/dist/components/cfpb-notifications/index.js.map +1 -1
- package/dist/components/cfpb-tooltips/index.css +1 -1
- package/dist/components/cfpb-tooltips/index.css.map +2 -2
- package/dist/components/cfpb-tooltips/index.js.map +1 -1
- package/dist/components/cfpb-typography/index.css +1 -1
- package/dist/components/cfpb-typography/index.css.map +2 -2
- package/dist/components/cfpb-typography/index.js +1 -1
- package/dist/components/cfpb-typography/index.js.map +1 -1
- package/dist/elements/cfpb-button/index.js +13 -4
- package/dist/elements/cfpb-button/index.js.map +4 -4
- package/dist/elements/cfpb-file-upload/index.js +4 -4
- package/dist/elements/cfpb-file-upload/index.js.map +4 -4
- package/dist/elements/cfpb-icon-text/index.js +29 -0
- package/dist/elements/cfpb-icon-text/index.js.map +7 -0
- package/dist/elements/cfpb-label/index.js.map +1 -1
- package/dist/elements/cfpb-multiselect/index.js +2 -2
- package/dist/elements/cfpb-multiselect/index.js.map +2 -2
- package/dist/elements/cfpb-pagination/index.js +32 -0
- package/dist/elements/cfpb-pagination/index.js.map +7 -0
- package/dist/elements/cfpb-tag-filter/index.js.map +1 -1
- package/dist/elements/cfpb-tag-topic/index.js +3 -3
- package/dist/elements/cfpb-tag-topic/index.js.map +2 -2
- package/dist/elements/cfpb-utilities/index.js +2 -0
- package/dist/elements/cfpb-utilities/index.js.map +7 -0
- package/dist/elements/index.js +7 -6
- package/dist/elements/index.js.map +4 -4
- package/dist/index.css +1 -1
- package/dist/index.css.map +2 -2
- package/dist/index.js +7 -6
- package/dist/index.js.map +4 -4
- package/package.json +2 -2
- package/src/base/base.scss +14 -26
- package/src/components/cfpb-buttons/button.scss +4 -2
- package/src/components/cfpb-forms/tag.scss +3 -0
- package/src/components/cfpb-pagination/vars.scss +0 -4
- package/src/components/cfpb-typography/link.scss +4 -2
- package/src/components/cfpb-typography/mixins.scss +8 -0
- package/src/elements/cfpb-button/cfpb-button.component.scss +15 -0
- package/src/elements/cfpb-button/index.js +52 -27
- package/src/elements/cfpb-icon-text/cfpb-icon-text.component.scss +59 -0
- package/src/elements/cfpb-icon-text/index.js +150 -0
- package/src/elements/cfpb-label/index.js +4 -3
- package/src/elements/cfpb-pagination/cfpb-pagination.component.scss +72 -0
- package/src/elements/cfpb-pagination/index.js +211 -0
- package/src/elements/cfpb-tag-filter/index.js +1 -0
- package/src/elements/cfpb-tag-topic/cfpb-tag-topic.component.scss +2 -0
- package/src/elements/cfpb-tag-topic/index.js +1 -0
- package/src/elements/cfpb-utilities/i18n-service.js +128 -0
- package/src/elements/cfpb-utilities/i18n-service.spec.js +156 -0
- package/src/elements/cfpb-utilities/index.js +7 -0
- package/src/elements/cfpb-utilities/media-query-service.js +102 -0
- package/src/elements/cfpb-utilities/media-query-service.spec.js +126 -0
- package/src/elements/index.js +1 -0
- package/src/utilities/utilities.scss +8 -8
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
import { jest } from '@jest/globals';
|
|
2
|
+
import { MediaQueryService } from './media-query-service';
|
|
3
|
+
|
|
4
|
+
describe('MediaQueryService', () => {
|
|
5
|
+
const originalMatchMedia = window.matchMedia;
|
|
6
|
+
|
|
7
|
+
let mockMatchMedia;
|
|
8
|
+
let listeners = {};
|
|
9
|
+
let mediaQueryState = {};
|
|
10
|
+
|
|
11
|
+
beforeEach(() => {
|
|
12
|
+
// Reset state before each test.
|
|
13
|
+
listeners = {};
|
|
14
|
+
mediaQueryState = {};
|
|
15
|
+
|
|
16
|
+
mockMatchMedia = jest.fn().mockImplementation((query) => {
|
|
17
|
+
const key = query;
|
|
18
|
+
mediaQueryState[key] = mediaQueryState[key] ?? false;
|
|
19
|
+
|
|
20
|
+
return {
|
|
21
|
+
matches: mediaQueryState[key],
|
|
22
|
+
media: query,
|
|
23
|
+
addEventListener: (event, cb) => {
|
|
24
|
+
if (event === 'change') {
|
|
25
|
+
listeners[key] = cb;
|
|
26
|
+
}
|
|
27
|
+
},
|
|
28
|
+
removeEventListener: jest.fn(),
|
|
29
|
+
dispatchEvent: jest.fn(),
|
|
30
|
+
};
|
|
31
|
+
});
|
|
32
|
+
|
|
33
|
+
window.matchMedia = mockMatchMedia;
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
afterEach(() => {
|
|
37
|
+
window.matchMedia = originalMatchMedia;
|
|
38
|
+
});
|
|
39
|
+
|
|
40
|
+
/**
|
|
41
|
+
* @param {string} key - A media query string.
|
|
42
|
+
* @param {boolean} newMedia - True if it's a new media query.
|
|
43
|
+
*/
|
|
44
|
+
function simulateResize(key, newMedia) {
|
|
45
|
+
mediaQueryState[key] = newMedia;
|
|
46
|
+
if (listeners[key]) {
|
|
47
|
+
listeners[key]({ matches: newMedia });
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
it('initializes with default breakpoints and tracks matches', () => {
|
|
52
|
+
const mqs = new MediaQueryService();
|
|
53
|
+
const expectedBreakpoints = ['xs', 'sm', 'med', 'lg', 'xl'];
|
|
54
|
+
|
|
55
|
+
expect(Object.keys(mqs.matches)).toEqual(
|
|
56
|
+
expect.arrayContaining(expectedBreakpoints),
|
|
57
|
+
);
|
|
58
|
+
});
|
|
59
|
+
|
|
60
|
+
it('accepts custom breakpoints', () => {
|
|
61
|
+
const custom = {
|
|
62
|
+
mobile: { min: 0, max: 500 },
|
|
63
|
+
desktop: { min: 501 },
|
|
64
|
+
};
|
|
65
|
+
|
|
66
|
+
const mqs = new MediaQueryService(custom);
|
|
67
|
+
|
|
68
|
+
expect(Object.keys(mqs.matches)).toEqual(['mobile', 'desktop']);
|
|
69
|
+
});
|
|
70
|
+
|
|
71
|
+
it('fires a single change event when a match changes', (done) => {
|
|
72
|
+
const mqs = new MediaQueryService({
|
|
73
|
+
test: { min: 100 },
|
|
74
|
+
});
|
|
75
|
+
|
|
76
|
+
mqs.addEventListener('change', (event) => {
|
|
77
|
+
expect(event.detail.matches.test).toBe(true);
|
|
78
|
+
done();
|
|
79
|
+
});
|
|
80
|
+
|
|
81
|
+
simulateResize('(min-width: 100px)', true);
|
|
82
|
+
});
|
|
83
|
+
|
|
84
|
+
it('does not fire change if match does not actually change', () => {
|
|
85
|
+
const mqs = new MediaQueryService({
|
|
86
|
+
test: { min: 100 },
|
|
87
|
+
});
|
|
88
|
+
|
|
89
|
+
const mockHandler = jest.fn();
|
|
90
|
+
mqs.addEventListener('change', mockHandler);
|
|
91
|
+
|
|
92
|
+
simulateResize('(min-width: 100px)', false);
|
|
93
|
+
expect(mockHandler).not.toHaveBeenCalled();
|
|
94
|
+
});
|
|
95
|
+
|
|
96
|
+
it('updates matches correctly', () => {
|
|
97
|
+
const mqs = new MediaQueryService({
|
|
98
|
+
large: { min: 1000 },
|
|
99
|
+
});
|
|
100
|
+
|
|
101
|
+
expect(mqs.matches.large).toBe(false);
|
|
102
|
+
simulateResize('(min-width: 1000px)', true);
|
|
103
|
+
expect(mqs.matches.large).toBe(true);
|
|
104
|
+
});
|
|
105
|
+
|
|
106
|
+
it('destroy removes all listeners', () => {
|
|
107
|
+
const removeListenerMock = jest.fn();
|
|
108
|
+
|
|
109
|
+
window.matchMedia = jest.fn().mockImplementation((query) => {
|
|
110
|
+
return {
|
|
111
|
+
matches: false,
|
|
112
|
+
media: query,
|
|
113
|
+
addEventListener: jest.fn(),
|
|
114
|
+
removeEventListener: removeListenerMock,
|
|
115
|
+
};
|
|
116
|
+
});
|
|
117
|
+
|
|
118
|
+
const mqs = new MediaQueryService({
|
|
119
|
+
test: { min: 500 },
|
|
120
|
+
});
|
|
121
|
+
|
|
122
|
+
mqs.destroy();
|
|
123
|
+
|
|
124
|
+
expect(removeListenerMock).toHaveBeenCalled();
|
|
125
|
+
});
|
|
126
|
+
});
|
package/src/elements/index.js
CHANGED
|
@@ -245,29 +245,29 @@ $ba: Link underline active color.
|
|
|
245
245
|
$ba: $link-underline-active
|
|
246
246
|
) {
|
|
247
247
|
color: $c;
|
|
248
|
-
|
|
248
|
+
text-decoration-color: $bc;
|
|
249
249
|
|
|
250
250
|
&:visited,
|
|
251
251
|
&.visited {
|
|
252
|
-
|
|
252
|
+
text-decoration-color: $bv;
|
|
253
253
|
color: $v;
|
|
254
254
|
}
|
|
255
255
|
|
|
256
256
|
&:hover,
|
|
257
257
|
&.hover {
|
|
258
|
-
|
|
258
|
+
text-decoration-color: $bh;
|
|
259
259
|
color: $h;
|
|
260
260
|
}
|
|
261
261
|
|
|
262
262
|
&:focus,
|
|
263
263
|
&.focus {
|
|
264
|
-
|
|
264
|
+
text-decoration-color: $bf;
|
|
265
265
|
color: $f;
|
|
266
266
|
}
|
|
267
267
|
|
|
268
268
|
&:active,
|
|
269
269
|
&.active {
|
|
270
|
-
|
|
270
|
+
text-decoration-color: $ba;
|
|
271
271
|
color: $a;
|
|
272
272
|
}
|
|
273
273
|
}
|
|
@@ -275,19 +275,19 @@ $ba: Link underline active color.
|
|
|
275
275
|
|
|
276
276
|
// Turn off the default bottom `border` on the default and `:hover` states.
|
|
277
277
|
@mixin u-link-no-border() {
|
|
278
|
-
|
|
278
|
+
text-decoration-line: none !important;
|
|
279
279
|
}
|
|
280
280
|
|
|
281
281
|
// Turn off the default bottom `border` on the default state,
|
|
282
282
|
// but force a bottom border on the `:hover` state.
|
|
283
283
|
@mixin u-link-hover-border() {
|
|
284
|
-
|
|
284
|
+
text-decoration-line: none !important;
|
|
285
285
|
|
|
286
286
|
&:hover,
|
|
287
287
|
&.hover,
|
|
288
288
|
&:focus,
|
|
289
289
|
&.focus {
|
|
290
|
-
|
|
290
|
+
text-decoration-line: underline !important;
|
|
291
291
|
}
|
|
292
292
|
}
|
|
293
293
|
|