@arbor-education/design-system.components 0.1.5 → 0.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.
Files changed (105) hide show
  1. package/CHANGELOG.md +6 -0
  2. package/dist/components/formField/fieldset/Fieldset.d.ts +6 -0
  3. package/dist/components/formField/fieldset/Fieldset.d.ts.map +1 -0
  4. package/dist/components/formField/fieldset/Fieldset.js +7 -0
  5. package/dist/components/formField/fieldset/Fieldset.js.map +1 -0
  6. package/dist/components/formField/fieldset/Fieldset.stories.d.ts +28 -0
  7. package/dist/components/formField/fieldset/Fieldset.stories.d.ts.map +1 -0
  8. package/dist/components/formField/fieldset/Fieldset.stories.js +51 -0
  9. package/dist/components/formField/fieldset/Fieldset.stories.js.map +1 -0
  10. package/dist/components/formField/fieldset/Fieldset.test.d.ts +2 -0
  11. package/dist/components/formField/fieldset/Fieldset.test.d.ts.map +1 -0
  12. package/dist/components/formField/fieldset/Fieldset.test.js +62 -0
  13. package/dist/components/formField/fieldset/Fieldset.test.js.map +1 -0
  14. package/dist/components/formField/inputs/checkbox/CheckboxGroup.d.ts +8 -0
  15. package/dist/components/formField/inputs/checkbox/CheckboxGroup.d.ts.map +1 -0
  16. package/dist/components/formField/inputs/checkbox/CheckboxGroup.js +8 -0
  17. package/dist/components/formField/inputs/checkbox/CheckboxGroup.js.map +1 -0
  18. package/dist/components/formField/inputs/checkbox/CheckboxGroup.test.d.ts +2 -0
  19. package/dist/components/formField/inputs/checkbox/CheckboxGroup.test.d.ts.map +1 -0
  20. package/dist/components/formField/inputs/checkbox/CheckboxGroup.test.js +86 -0
  21. package/dist/components/formField/inputs/checkbox/CheckboxGroup.test.js.map +1 -0
  22. package/dist/components/formField/inputs/checkbox/CheckboxInput.stories.d.ts +3 -1
  23. package/dist/components/formField/inputs/checkbox/CheckboxInput.stories.d.ts.map +1 -1
  24. package/dist/components/formField/inputs/checkbox/CheckboxInput.stories.js +7 -0
  25. package/dist/components/formField/inputs/checkbox/CheckboxInput.stories.js.map +1 -1
  26. package/dist/components/formField/inputs/radio/RadioButtonGroup.d.ts +11 -0
  27. package/dist/components/formField/inputs/radio/RadioButtonGroup.d.ts.map +1 -0
  28. package/dist/components/formField/inputs/radio/RadioButtonGroup.js +8 -0
  29. package/dist/components/formField/inputs/radio/RadioButtonGroup.js.map +1 -0
  30. package/dist/components/formField/inputs/radio/RadioButtonGroup.test.d.ts +2 -0
  31. package/dist/components/formField/inputs/radio/RadioButtonGroup.test.d.ts.map +1 -0
  32. package/dist/components/formField/inputs/radio/RadioButtonGroup.test.js +86 -0
  33. package/dist/components/formField/inputs/radio/RadioButtonGroup.test.js.map +1 -0
  34. package/dist/components/formField/inputs/radio/RadioButtonInput.stories.d.ts.map +1 -1
  35. package/dist/components/formField/inputs/radio/RadioButtonInput.stories.js +8 -2
  36. package/dist/components/formField/inputs/radio/RadioButtonInput.stories.js.map +1 -1
  37. package/dist/components/separator/Separator.d.ts +7 -0
  38. package/dist/components/separator/Separator.d.ts.map +1 -0
  39. package/dist/components/separator/Separator.js +8 -0
  40. package/dist/components/separator/Separator.js.map +1 -0
  41. package/dist/components/separator/Separator.stories.d.ts +10 -0
  42. package/dist/components/separator/Separator.stories.d.ts.map +1 -0
  43. package/dist/components/separator/Separator.stories.js +12 -0
  44. package/dist/components/separator/Separator.stories.js.map +1 -0
  45. package/dist/components/separator/Separator.test.d.ts +2 -0
  46. package/dist/components/separator/Separator.test.d.ts.map +1 -0
  47. package/dist/components/separator/Separator.test.js +10 -0
  48. package/dist/components/separator/Separator.test.js.map +1 -0
  49. package/dist/components/table/Table.d.ts +13 -0
  50. package/dist/components/table/Table.d.ts.map +1 -1
  51. package/dist/components/table/Table.js +43 -7
  52. package/dist/components/table/Table.js.map +1 -1
  53. package/dist/components/table/Table.stories.d.ts.map +1 -1
  54. package/dist/components/table/Table.stories.js +8 -1
  55. package/dist/components/table/Table.stories.js.map +1 -1
  56. package/dist/components/table/Table.test.js +254 -2
  57. package/dist/components/table/Table.test.js.map +1 -1
  58. package/dist/components/table/pagination/TableSettingsDropdown.d.ts +2 -0
  59. package/dist/components/table/pagination/TableSettingsDropdown.d.ts.map +1 -0
  60. package/dist/components/table/pagination/TableSettingsDropdown.js +43 -0
  61. package/dist/components/table/pagination/TableSettingsDropdown.js.map +1 -0
  62. package/dist/components/table/useTableSettings.d.ts +22 -0
  63. package/dist/components/table/useTableSettings.d.ts.map +1 -0
  64. package/dist/components/table/useTableSettings.js +28 -0
  65. package/dist/components/table/useTableSettings.js.map +1 -0
  66. package/dist/index.css +31 -1
  67. package/dist/index.css.map +1 -1
  68. package/dist/index.d.ts +2 -0
  69. package/dist/index.d.ts.map +1 -1
  70. package/dist/index.js +2 -0
  71. package/dist/index.js.map +1 -1
  72. package/dist/utils/hooks/useComponentDidUpdate.d.ts +7 -0
  73. package/dist/utils/hooks/useComponentDidUpdate.d.ts.map +1 -0
  74. package/dist/utils/hooks/useComponentDidUpdate.js +18 -0
  75. package/dist/utils/hooks/useComponentDidUpdate.js.map +1 -0
  76. package/dist/utils/hooks/useComponentDidUpdate.test.d.ts +2 -0
  77. package/dist/utils/hooks/useComponentDidUpdate.test.d.ts.map +1 -0
  78. package/dist/utils/hooks/useComponentDidUpdate.test.js +69 -0
  79. package/dist/utils/hooks/useComponentDidUpdate.test.js.map +1 -0
  80. package/package.json +1 -1
  81. package/src/components/formField/fieldset/Fieldset.stories.tsx +89 -0
  82. package/src/components/formField/fieldset/Fieldset.test.tsx +85 -0
  83. package/src/components/formField/fieldset/Fieldset.tsx +17 -0
  84. package/src/components/formField/fieldset/fieldset.scss +19 -0
  85. package/src/components/formField/inputs/checkbox/CheckboxGroup.test.tsx +127 -0
  86. package/src/components/formField/inputs/checkbox/CheckboxGroup.tsx +17 -0
  87. package/src/components/formField/inputs/checkbox/CheckboxInput.stories.tsx +12 -1
  88. package/src/components/formField/inputs/radio/RadioButtonGroup.test.tsx +190 -0
  89. package/src/components/formField/inputs/radio/RadioButtonGroup.tsx +22 -0
  90. package/src/components/formField/inputs/radio/RadioButtonInput.stories.tsx +16 -7
  91. package/src/components/formField/label/label.scss +1 -1
  92. package/src/components/separator/Separator.stories.tsx +15 -0
  93. package/src/components/separator/Separator.test.tsx +10 -0
  94. package/src/components/separator/Separator.tsx +15 -0
  95. package/src/components/separator/separator.scss +6 -0
  96. package/src/components/table/Table.stories.tsx +8 -1
  97. package/src/components/table/Table.test.tsx +444 -1
  98. package/src/components/table/Table.tsx +69 -24
  99. package/src/components/table/pagination/TableSettingsDropdown.tsx +90 -0
  100. package/src/components/table/table.scss +6 -0
  101. package/src/components/table/useTableSettings.ts +47 -0
  102. package/src/index.scss +2 -0
  103. package/src/index.ts +2 -0
  104. package/src/utils/hooks/useComponentDidUpdate.test.ts +107 -0
  105. package/src/utils/hooks/useComponentDidUpdate.ts +19 -0
@@ -0,0 +1,47 @@
1
+ import { useState } from 'react';
2
+ import { TABLE_SPACING } from './Table';
3
+ import { useComponentDidUpdate } from 'Utils/hooks/useComponentDidUpdate';
4
+
5
+ export type TableSettings = {
6
+ hasColumnBorders?: boolean;
7
+ setHasColumnBorders: (val: boolean) => void;
8
+ tableSpacing: TABLE_SPACING;
9
+ setTableSpacing: (val: TABLE_SPACING) => void;
10
+ };
11
+
12
+ type UseTableSettingsParams = {
13
+ onTableSettingsChanged?: (val: TableSettings) => void;
14
+ onTableSettingsReset?: () => void;
15
+ };
16
+
17
+ export const useTableSettings = (params: UseTableSettingsParams = {}) => {
18
+ const {
19
+ onTableSettingsChanged,
20
+ onTableSettingsReset,
21
+ } = params;
22
+ const [hasColumnBorders, setHasColumnBorders] = useState(false);
23
+ const [tableSpacing, setTableSpacing] = useState(TABLE_SPACING.M);
24
+
25
+ const settings = {
26
+ hasColumnBorders,
27
+ setHasColumnBorders,
28
+ tableSpacing,
29
+ setTableSpacing,
30
+ };
31
+
32
+ const resetSettings = () => {
33
+ setHasColumnBorders(false);
34
+ setTableSpacing(TABLE_SPACING.M);
35
+ if (onTableSettingsReset) {
36
+ onTableSettingsReset();
37
+ }
38
+ };
39
+
40
+ useComponentDidUpdate(() => {
41
+ if (onTableSettingsChanged) {
42
+ onTableSettingsChanged(settings);
43
+ }
44
+ }, [hasColumnBorders, tableSpacing]);
45
+
46
+ return { settings, resetSettings };
47
+ };
package/src/index.scss CHANGED
@@ -6,6 +6,7 @@
6
6
  @use "components/card/card.scss";
7
7
  @use "components/dropdown/dropdown.scss";
8
8
  @use "components/formField/formField.scss";
9
+ @use "components/formField/fieldset/fieldset.scss";
9
10
  @use "components/formField/inputs/input.scss";
10
11
  @use "components/formField/label/label.scss";
11
12
  @use "components/formField/inputs/number/numberInput.scss";
@@ -22,4 +23,5 @@
22
23
  @use "components/searchBar/searchBar.scss";
23
24
  @use "components/table/pagination/pagination.scss";
24
25
  @use "components/tooltip/tooltip.scss";
26
+ @use "components/separator/separator.scss";
25
27
  @import "https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap";
package/src/index.ts CHANGED
@@ -19,3 +19,5 @@ export { Table } from 'Components/table/Table';
19
19
  export { GridApiContext } from 'Components/table/GridApiContext';
20
20
  export { Tooltip } from 'Components/tooltip/Tooltip';
21
21
  export { TooltipWrapper } from 'Components/tooltip/TooltipWrapper';
22
+ export { Fieldset } from 'Components/formField/fieldset/Fieldset';
23
+ export { Separator } from 'Components/separator/Separator';
@@ -0,0 +1,107 @@
1
+ import { expect, test, describe, vi } from 'vitest';
2
+ import { renderHook } from '@testing-library/react';
3
+ import { useComponentDidUpdate } from './useComponentDidUpdate';
4
+
5
+ describe('useComponentDidUpdate', () => {
6
+ test('does not call effect on initial render', () => {
7
+ const effect = vi.fn();
8
+ renderHook(() => useComponentDidUpdate(effect, []));
9
+
10
+ expect(effect).not.toHaveBeenCalled();
11
+ });
12
+
13
+ test('calls effect on subsequent renders when dependencies change', () => {
14
+ const effect = vi.fn();
15
+ const { rerender } = renderHook(
16
+ ({ deps }) => useComponentDidUpdate(effect, deps),
17
+ { initialProps: { deps: [1] } },
18
+ );
19
+
20
+ expect(effect).not.toHaveBeenCalled();
21
+
22
+ rerender({ deps: [2] });
23
+ expect(effect).toHaveBeenCalledTimes(1);
24
+ });
25
+
26
+ test('does not call effect when dependencies do not change', () => {
27
+ const effect = vi.fn();
28
+ const { rerender } = renderHook(
29
+ ({ deps }) => useComponentDidUpdate(effect, deps),
30
+ { initialProps: { deps: [1] } },
31
+ );
32
+
33
+ expect(effect).not.toHaveBeenCalled();
34
+
35
+ rerender({ deps: [1] });
36
+ expect(effect).not.toHaveBeenCalled();
37
+ });
38
+
39
+ test('calls effect multiple times on multiple updates', () => {
40
+ const effect = vi.fn();
41
+ const { rerender } = renderHook(
42
+ ({ deps }) => useComponentDidUpdate(effect, deps),
43
+ { initialProps: { deps: [1] } },
44
+ );
45
+
46
+ rerender({ deps: [2] });
47
+ expect(effect).toHaveBeenCalledTimes(1);
48
+
49
+ rerender({ deps: [3] });
50
+ expect(effect).toHaveBeenCalledTimes(2);
51
+
52
+ rerender({ deps: [4] });
53
+ expect(effect).toHaveBeenCalledTimes(3);
54
+ });
55
+
56
+ test('calls cleanup function returned from effect', () => {
57
+ const cleanup = vi.fn();
58
+ const effect = vi.fn(() => cleanup);
59
+ const { rerender, unmount } = renderHook(
60
+ ({ deps }) => useComponentDidUpdate(effect, deps),
61
+ { initialProps: { deps: [1] } },
62
+ );
63
+
64
+ rerender({ deps: [2] });
65
+ expect(effect).toHaveBeenCalledTimes(1);
66
+ expect(cleanup).not.toHaveBeenCalled();
67
+
68
+ rerender({ deps: [3] });
69
+ expect(cleanup).toHaveBeenCalledTimes(1);
70
+ expect(effect).toHaveBeenCalledTimes(2);
71
+
72
+ unmount();
73
+ expect(cleanup).toHaveBeenCalledTimes(2);
74
+ });
75
+
76
+ test('works with multiple dependencies', () => {
77
+ const effect = vi.fn();
78
+ const { rerender } = renderHook(
79
+ ({ deps }) => useComponentDidUpdate(effect, deps),
80
+ { initialProps: { deps: [1, 'a', true] } },
81
+ );
82
+
83
+ expect(effect).not.toHaveBeenCalled();
84
+
85
+ // Change one dependency
86
+ rerender({ deps: [1, 'a', false] });
87
+ expect(effect).toHaveBeenCalledTimes(1);
88
+
89
+ // Change another dependency
90
+ rerender({ deps: [1, 'b', false] });
91
+ expect(effect).toHaveBeenCalledTimes(2);
92
+
93
+ // Change multiple dependencies
94
+ rerender({ deps: [2, 'c', true] });
95
+ expect(effect).toHaveBeenCalledTimes(3);
96
+ });
97
+
98
+ test('works with empty dependency array', () => {
99
+ const effect = vi.fn();
100
+ const { rerender } = renderHook(() => useComponentDidUpdate(effect, []));
101
+
102
+ expect(effect).not.toHaveBeenCalled();
103
+
104
+ rerender();
105
+ expect(effect).not.toHaveBeenCalled();
106
+ });
107
+ });
@@ -0,0 +1,19 @@
1
+ import { useEffect, useRef, type DependencyList, type EffectCallback } from 'react';
2
+
3
+ /**
4
+ * This is a hook that is functionally identical to useEffect, except it only runs on
5
+ * updates, never on first render
6
+ */
7
+ export const useComponentDidUpdate = (effect: EffectCallback, deps: DependencyList) => {
8
+ const isFirstRenderRef = useRef(true);
9
+
10
+ useEffect(() => {
11
+ if (isFirstRenderRef.current) {
12
+ isFirstRenderRef.current = false;
13
+ return;
14
+ }
15
+ else {
16
+ return effect();
17
+ }
18
+ }, deps);
19
+ };