@onewelcome/react-lib-components 8.3.0 → 8.5.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/dist/cjs/Button/BaseButton.cjs.js +1 -1
- package/dist/cjs/Button/BaseButton.cjs.js.map +1 -1
- package/dist/cjs/Button/Spinner.cjs.js +1 -1
- package/dist/cjs/Button/Spinner.cjs.js.map +1 -1
- package/dist/cjs/DataGrid/DataGridBody/DataGridCell/DataGridCell.module.scss.cjs.js +1 -1
- package/dist/cjs/DataGrid/DataGridBody/DataGridRow/DataGridRow.module.scss.cjs.js +1 -1
- package/dist/cjs/DataGrid/DataGridFilters/DataGridFilters.interfaces.cjs.js.map +1 -1
- package/dist/cjs/DataGrid/DataGridFilters/DataGridSearchbar.cjs.js.map +1 -1
- package/dist/cjs/DataGrid/DataGridFilters/FilterKeyMapper.cjs.js +2 -0
- package/dist/cjs/DataGrid/DataGridFilters/FilterKeyMapper.cjs.js.map +1 -0
- package/dist/cjs/DataGrid/DataGridHeader/DataGridHeader.module.scss.cjs.js +1 -1
- package/dist/cjs/Form/FileUpload/FileItem/FileItem.cjs.js +1 -1
- package/dist/cjs/Form/FileUpload/FileItem/FileItem.cjs.js.map +1 -1
- package/dist/cjs/Form/FileUpload/FileItem/FileItem.module.scss.cjs.js +1 -1
- package/dist/cjs/Form/FileUpload/FileUpload.cjs.js +1 -1
- package/dist/cjs/Form/FileUpload/FileUpload.cjs.js.map +1 -1
- package/dist/cjs/Form/FileUpload/FileUpload.module.scss.cjs.js +1 -1
- package/dist/cjs/Icon/Icon.cjs.js +1 -1
- package/dist/cjs/Icon/Icon.cjs.js.map +1 -1
- package/dist/cjs/Icon/Icon.module.scss.cjs.js +1 -1
- package/dist/cjs/Notifications/BaseModal/BaseModal.cjs.js +1 -1
- package/dist/cjs/Notifications/BaseModal/BaseModal.cjs.js.map +1 -1
- package/dist/cjs/Notifications/BaseModal/BaseModalHeader/BaseModalHeader.cjs.js +1 -1
- package/dist/cjs/Notifications/BaseModal/BaseModalHeader/BaseModalHeader.cjs.js.map +1 -1
- package/dist/cjs/Notifications/SideSheet/SideSheet.cjs.js +2 -0
- package/dist/cjs/Notifications/SideSheet/SideSheet.cjs.js.map +1 -0
- package/dist/cjs/Notifications/SideSheet/SideSheet.module.scss.cjs.js +2 -0
- package/dist/cjs/Notifications/SideSheet/SideSheet.module.scss.cjs.js.map +1 -0
- package/dist/cjs/Notifications/SideSheet/SideSheetContent/SideSheetContent.cjs.js +2 -0
- package/dist/cjs/Notifications/SideSheet/SideSheetContent/SideSheetContent.cjs.js.map +1 -0
- package/dist/cjs/Notifications/SideSheet/SideSheetContent/SideSheetContent.module.scss.cjs.js +2 -0
- package/dist/cjs/Notifications/SideSheet/SideSheetContent/SideSheetContent.module.scss.cjs.js.map +1 -0
- package/dist/cjs/Notifications/SideSheet/SideSheetHeader/SideSheetHeader.cjs.js +2 -0
- package/dist/cjs/Notifications/SideSheet/SideSheetHeader/SideSheetHeader.cjs.js.map +1 -0
- package/dist/cjs/Notifications/SideSheet/SideSheetHeader/SideSheetHeader.module.scss.cjs.js +2 -0
- package/dist/cjs/Notifications/SideSheet/SideSheetHeader/SideSheetHeader.module.scss.cjs.js.map +1 -0
- package/dist/cjs/Notifications/SlideInModal/SlideInModal.cjs.js.map +1 -1
- package/dist/cjs/Spinner/Spinner.cjs.js +2 -0
- package/dist/cjs/Spinner/Spinner.cjs.js.map +1 -0
- package/dist/cjs/Spinner/Spinner.module.scss.cjs.js +2 -0
- package/dist/cjs/Spinner/Spinner.module.scss.cjs.js.map +1 -0
- package/dist/cjs/_BaseStyling_/BaseStyling.cjs.js +1 -1
- package/dist/cjs/_BaseStyling_/BaseStyling.cjs.js.map +1 -1
- package/dist/cjs/src/components/Button/Spinner.d.ts +1 -1
- package/dist/cjs/src/components/DataGrid/DataGridFilters/DataGridFilters.interfaces.d.ts +4 -0
- package/dist/cjs/src/components/DataGrid/DataGridFilters/DataGridSearchbar.d.ts +1 -1
- package/dist/cjs/src/components/DataGrid/DataGridFilters/FilterKeyMapper.d.ts +14 -0
- package/dist/cjs/src/components/DataGrid/DataGridFilters/FilterKeyMapper.test.d.ts +1 -0
- package/dist/cjs/src/components/DataGrid/testUtils.d.ts +3 -1
- package/dist/cjs/src/components/Form/Select/MultiSelect/MultiSelect.test.d.ts +1 -2
- package/dist/cjs/src/components/Form/Select/SingleSelect/Select.test.d.ts +1 -2
- package/dist/cjs/src/components/Icon/Icon.d.ts +4 -1
- package/dist/cjs/src/components/Notifications/BaseModal/BaseModal.d.ts +1 -0
- package/dist/cjs/src/components/Notifications/BaseModal/BaseModalHeader/BaseModalHeader.d.ts +1 -0
- package/dist/cjs/src/components/Notifications/SideSheet/SideSheet.d.ts +10 -0
- package/dist/cjs/src/components/Notifications/SideSheet/SideSheet.test.d.ts +1 -0
- package/dist/cjs/src/components/Notifications/SideSheet/SideSheetActions/SideSheetActions.d.ts +2 -0
- package/dist/cjs/src/components/Notifications/SideSheet/SideSheetContent/SideSheetContent.d.ts +4 -0
- package/dist/cjs/src/components/Notifications/SideSheet/SideSheetHeader/SideSheetHeader.d.ts +4 -0
- package/dist/cjs/src/components/Spinner/Spinner.d.ts +6 -0
- package/dist/cjs/src/components/Spinner/Spinner.test.d.ts +1 -0
- package/dist/cjs/src/components/Typography/Typography.d.ts +1 -1
- package/dist/cjs/src/components/_BaseStyling_/BaseStyling.d.ts +2 -0
- package/dist/cjs/src/hooks/useUploadFile.cjs.js +2 -0
- package/dist/cjs/src/hooks/useUploadFile.cjs.js.map +1 -0
- package/dist/cjs/src/hooks/useUploadFile.d.ts +10 -4
- package/dist/cjs/src/index.cjs.js +1 -1
- package/dist/cjs/src/index.d.ts +19 -2
- package/dist/cjs/src/util/helper.cjs.js +1 -1
- package/dist/cjs/src/util/helper.cjs.js.map +1 -1
- package/dist/cjs/src/util/helper.d.ts +0 -3
- package/dist/esm/Button/BaseButton.esm.js +2 -2
- package/dist/esm/Button/BaseButton.esm.js.map +1 -1
- package/dist/esm/Button/Spinner.esm.js +2 -2
- package/dist/esm/Button/Spinner.esm.js.map +1 -1
- package/dist/esm/DataGrid/DataGridBody/DataGridCell/DataGridCell.module.scss.esm.js +1 -1
- package/dist/esm/DataGrid/DataGridBody/DataGridRow/DataGridRow.module.scss.esm.js +1 -1
- package/dist/esm/DataGrid/DataGridFilters/DataGridFilters.interfaces.esm.js.map +1 -1
- package/dist/esm/DataGrid/DataGridFilters/DataGridSearchbar.esm.js.map +1 -1
- package/dist/esm/DataGrid/DataGridFilters/FilterKeyMapper.esm.js +46 -0
- package/dist/esm/DataGrid/DataGridFilters/FilterKeyMapper.esm.js.map +1 -0
- package/dist/esm/DataGrid/DataGridHeader/DataGridHeader.module.scss.esm.js +2 -2
- package/dist/esm/Form/FileUpload/FileItem/FileItem.esm.js +4 -3
- package/dist/esm/Form/FileUpload/FileItem/FileItem.esm.js.map +1 -1
- package/dist/esm/Form/FileUpload/FileItem/FileItem.module.scss.esm.js +1 -1
- package/dist/esm/Form/FileUpload/FileUpload.esm.js +8 -7
- package/dist/esm/Form/FileUpload/FileUpload.esm.js.map +1 -1
- package/dist/esm/Form/FileUpload/FileUpload.module.scss.esm.js +2 -2
- package/dist/esm/Icon/Icon.esm.js +3 -0
- package/dist/esm/Icon/Icon.esm.js.map +1 -1
- package/dist/esm/Icon/Icon.module.scss.esm.js +2 -2
- package/dist/esm/Notifications/BaseModal/BaseModal.esm.js +2 -2
- package/dist/esm/Notifications/BaseModal/BaseModal.esm.js.map +1 -1
- package/dist/esm/Notifications/BaseModal/BaseModalHeader/BaseModalHeader.esm.js +4 -3
- package/dist/esm/Notifications/BaseModal/BaseModalHeader/BaseModalHeader.esm.js.map +1 -1
- package/dist/esm/Notifications/SideSheet/SideSheet.esm.js +59 -0
- package/dist/esm/Notifications/SideSheet/SideSheet.esm.js.map +1 -0
- package/dist/esm/Notifications/SideSheet/SideSheet.module.scss.esm.js +8 -0
- package/dist/esm/Notifications/SideSheet/SideSheet.module.scss.esm.js.map +1 -0
- package/dist/esm/Notifications/SideSheet/SideSheetContent/SideSheetContent.esm.js +23 -0
- package/dist/esm/Notifications/SideSheet/SideSheetContent/SideSheetContent.esm.js.map +1 -0
- package/dist/esm/Notifications/SideSheet/SideSheetContent/SideSheetContent.module.scss.esm.js +8 -0
- package/dist/esm/Notifications/SideSheet/SideSheetContent/SideSheetContent.module.scss.esm.js.map +1 -0
- package/dist/esm/Notifications/SideSheet/SideSheetHeader/SideSheetHeader.esm.js +23 -0
- package/dist/esm/Notifications/SideSheet/SideSheetHeader/SideSheetHeader.esm.js.map +1 -0
- package/dist/esm/Notifications/SideSheet/SideSheetHeader/SideSheetHeader.module.scss.esm.js +8 -0
- package/dist/esm/Notifications/SideSheet/SideSheetHeader/SideSheetHeader.module.scss.esm.js.map +1 -0
- package/dist/esm/Notifications/SlideInModal/SlideInModal.esm.js +3 -0
- package/dist/esm/Notifications/SlideInModal/SlideInModal.esm.js.map +1 -1
- package/dist/esm/Spinner/Spinner.esm.js +29 -0
- package/dist/esm/Spinner/Spinner.esm.js.map +1 -0
- package/dist/esm/Spinner/Spinner.module.scss.esm.js +8 -0
- package/dist/esm/Spinner/Spinner.module.scss.esm.js.map +1 -0
- package/dist/esm/_BaseStyling_/BaseStyling.esm.js +2 -0
- package/dist/esm/_BaseStyling_/BaseStyling.esm.js.map +1 -1
- package/dist/esm/src/components/Button/Spinner.d.ts +1 -1
- package/dist/esm/src/components/DataGrid/DataGridFilters/DataGridFilters.interfaces.d.ts +4 -0
- package/dist/esm/src/components/DataGrid/DataGridFilters/DataGridSearchbar.d.ts +1 -1
- package/dist/esm/src/components/DataGrid/DataGridFilters/FilterKeyMapper.d.ts +14 -0
- package/dist/esm/src/components/DataGrid/DataGridFilters/FilterKeyMapper.test.d.ts +1 -0
- package/dist/esm/src/components/DataGrid/testUtils.d.ts +3 -1
- package/dist/esm/src/components/Form/Select/MultiSelect/MultiSelect.test.d.ts +1 -2
- package/dist/esm/src/components/Form/Select/SingleSelect/Select.test.d.ts +1 -2
- package/dist/esm/src/components/Icon/Icon.d.ts +4 -1
- package/dist/esm/src/components/Notifications/BaseModal/BaseModal.d.ts +1 -0
- package/dist/esm/src/components/Notifications/BaseModal/BaseModalHeader/BaseModalHeader.d.ts +1 -0
- package/dist/esm/src/components/Notifications/SideSheet/SideSheet.d.ts +10 -0
- package/dist/esm/src/components/Notifications/SideSheet/SideSheet.test.d.ts +1 -0
- package/dist/esm/src/components/Notifications/SideSheet/SideSheetActions/SideSheetActions.d.ts +2 -0
- package/dist/esm/src/components/Notifications/SideSheet/SideSheetContent/SideSheetContent.d.ts +4 -0
- package/dist/esm/src/components/Notifications/SideSheet/SideSheetHeader/SideSheetHeader.d.ts +4 -0
- package/dist/esm/src/components/Spinner/Spinner.d.ts +6 -0
- package/dist/esm/src/components/Spinner/Spinner.test.d.ts +1 -0
- package/dist/esm/src/components/Typography/Typography.d.ts +1 -1
- package/dist/esm/src/components/_BaseStyling_/BaseStyling.d.ts +2 -0
- package/dist/esm/src/hooks/useUploadFile.d.ts +10 -4
- package/dist/esm/src/hooks/useUploadFile.esm.js +101 -0
- package/dist/esm/src/hooks/useUploadFile.esm.js.map +1 -0
- package/dist/esm/src/index.d.ts +19 -2
- package/dist/esm/src/index.esm.js +8 -1
- package/dist/esm/src/index.esm.js.map +1 -1
- package/dist/esm/src/util/helper.d.ts +0 -3
- package/dist/esm/src/util/helper.esm.js +10 -1
- package/dist/esm/src/util/helper.esm.js.map +1 -1
- package/dist/lib/style-inject.js +48 -41
- package/dist/lib/style-inject.js.map +1 -1
- package/package.json +22 -22
- package/src/components/Button/BaseButton.tsx +2 -2
- package/src/components/Button/Spinner.tsx +1 -1
- package/src/components/DataGrid/DataGridBody/DataGridCell/DataGridCell.module.scss +1 -1
- package/src/components/DataGrid/DataGridBody/DataGridRow/DataGridRow.module.scss +8 -24
- package/src/components/DataGrid/DataGridFilters/DataGridFilters.interfaces.ts +5 -0
- package/src/components/DataGrid/DataGridFilters/DataGridSearchbar.tsx +5 -2
- package/src/components/DataGrid/DataGridFilters/FilterKeyMapper.ts +48 -0
- package/src/components/DataGrid/DataGridHeader/DataGridHeader.module.scss +9 -8
- package/src/components/DataGrid/dataGridMixins.module.scss +33 -0
- package/src/components/DataGrid/testUtils.ts +39 -32
- package/src/components/Form/FileUpload/FileItem/FileItem.module.scss +6 -3
- package/src/components/Form/FileUpload/FileItem/FileItem.tsx +3 -1
- package/src/components/Form/FileUpload/FileUpload.module.scss +12 -5
- package/src/components/Form/FileUpload/FileUpload.tsx +10 -7
- package/src/components/Icon/Icon.module.scss +12 -0
- package/src/components/Icon/Icon.tsx +4 -1
- package/src/components/Notifications/BaseModal/BaseModal.tsx +10 -6
- package/src/components/Notifications/BaseModal/BaseModalHeader/BaseModalHeader.tsx +14 -2
- package/src/components/Notifications/SideSheet/SideSheet.module.scss +96 -0
- package/src/components/Notifications/SideSheet/SideSheet.tsx +114 -0
- package/src/components/Notifications/SideSheet/SideSheetActions/SideSheetActions.tsx +18 -0
- package/src/components/Notifications/SideSheet/SideSheetContent/SideSheetContent.module.scss +19 -0
- package/src/components/Notifications/SideSheet/SideSheetContent/SideSheetContent.tsx +25 -0
- package/src/components/Notifications/SideSheet/SideSheetHeader/SideSheetHeader.module.scss +19 -0
- package/src/components/Notifications/SideSheet/SideSheetHeader/SideSheetHeader.tsx +25 -0
- package/src/components/Notifications/SlideInModal/SlideInModal.tsx +3 -0
- package/src/components/Spinner/Spinner.module.scss +33 -0
- package/src/components/Spinner/Spinner.tsx +61 -0
- package/src/components/_BaseStyling_/BaseStyling.tsx +4 -0
- package/src/font/icomoon.eot +0 -0
- package/src/font/icomoon.svg +3 -0
- package/src/font/icomoon.ttf +0 -0
- package/src/font/icomoon.woff +0 -0
- package/src/font/selection.json +1 -1
- package/src/hooks/useUploadFile.tsx +27 -25
- package/src/index.ts +29 -2
- package/src/util/helper.tsx +0 -6
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"homepage": "http://onewelcome.github.io/react-lib-components",
|
|
3
3
|
"name": "@onewelcome/react-lib-components",
|
|
4
|
-
"version": "8.
|
|
4
|
+
"version": "8.5.0",
|
|
5
5
|
"license": "Apache-2.0",
|
|
6
6
|
"author": "OneWelcome B.V.",
|
|
7
7
|
"main": "dist/cjs/src/index.cjs.js",
|
|
@@ -53,16 +53,16 @@
|
|
|
53
53
|
"node": ">=16"
|
|
54
54
|
},
|
|
55
55
|
"devDependencies": {
|
|
56
|
-
"@babel/core": "^7.24.
|
|
57
|
-
"@babel/preset-env": "^7.24.
|
|
56
|
+
"@babel/core": "^7.24.7",
|
|
57
|
+
"@babel/preset-env": "^7.24.7",
|
|
58
58
|
"@babel/preset-react": "^7.24.7",
|
|
59
59
|
"@babel/preset-typescript": "^7.24.7",
|
|
60
|
-
"@chromatic-com/storybook": "^1.6.
|
|
60
|
+
"@chromatic-com/storybook": "^1.6.0",
|
|
61
61
|
"@mdx-js/react": "^3.0.1",
|
|
62
62
|
"@onewelcome/eslint-config-shared-codestyle": "^9.2.3",
|
|
63
63
|
"@onewelcome/storybook-addon-basestyling": "^2.0.0",
|
|
64
|
-
"@rollup/plugin-commonjs": "^
|
|
65
|
-
"@rollup/plugin-node-resolve": "^15.2.
|
|
64
|
+
"@rollup/plugin-commonjs": "^28.0.1",
|
|
65
|
+
"@rollup/plugin-node-resolve": "^15.2.3",
|
|
66
66
|
"@rollup/plugin-terser": "^0.4.4",
|
|
67
67
|
"@rollup/plugin-typescript": "^11.1.6",
|
|
68
68
|
"@storybook/addon-a11y": "^8.1.11",
|
|
@@ -78,29 +78,29 @@
|
|
|
78
78
|
"@storybook/react": "^8.1.11",
|
|
79
79
|
"@storybook/react-webpack5": "^8.1.11",
|
|
80
80
|
"@storybook/theming": "^8.1.11",
|
|
81
|
-
"@testing-library/dom": "^10.3.
|
|
82
|
-
"@testing-library/jest-dom": "^6.4.
|
|
83
|
-
"@testing-library/react": "^16.0.
|
|
81
|
+
"@testing-library/dom": "^10.3.0",
|
|
82
|
+
"@testing-library/jest-dom": "^6.4.6",
|
|
83
|
+
"@testing-library/react": "^16.0.0",
|
|
84
84
|
"@testing-library/user-event": "^14.5.2",
|
|
85
|
-
"@types/jest": "^29.5.
|
|
85
|
+
"@types/jest": "^29.5.12",
|
|
86
86
|
"@types/mdx": "^2.0.13",
|
|
87
|
-
"@types/react": "^18.3.
|
|
87
|
+
"@types/react": "^18.3.3",
|
|
88
88
|
"@types/react-dom": "^18.3.0",
|
|
89
89
|
"@types/react-router": "^5.1.20",
|
|
90
90
|
"@types/react-router-dom": "^5.3.3",
|
|
91
91
|
"@typescript-eslint/eslint-plugin": "^7.15.0",
|
|
92
92
|
"@typescript-eslint/parser": "^7.15.0",
|
|
93
93
|
"babel-loader": "^9.1.3",
|
|
94
|
-
"chromatic": "^11.5.
|
|
94
|
+
"chromatic": "^11.5.4",
|
|
95
95
|
"css-loader": "^7.1.2",
|
|
96
|
-
"eslint": "^8.57.
|
|
96
|
+
"eslint": "^8.57.0",
|
|
97
97
|
"eslint-config-prettier": "^9.1.0",
|
|
98
98
|
"eslint-plugin-cypress": "^3.3.0",
|
|
99
99
|
"eslint-plugin-export-scope": "^2.4.0",
|
|
100
100
|
"eslint-plugin-jest": "^28.6.0",
|
|
101
101
|
"eslint-plugin-license-header": "^0.6.1",
|
|
102
102
|
"eslint-plugin-prettier": "^5.1.3",
|
|
103
|
-
"eslint-plugin-react": "^7.34.
|
|
103
|
+
"eslint-plugin-react": "^7.34.3",
|
|
104
104
|
"eslint-plugin-react-hooks": "^4.6.2",
|
|
105
105
|
"eslint-plugin-storybook": "^0.8.0",
|
|
106
106
|
"husky": "^9.1.6",
|
|
@@ -109,30 +109,30 @@
|
|
|
109
109
|
"jest-environment-jsdom": "^29.7.0",
|
|
110
110
|
"jest-junit": "^16.0.0",
|
|
111
111
|
"jest-sonar-reporter": "^2.0.0",
|
|
112
|
-
"lint-staged": "^15.2.
|
|
113
|
-
"mini-css-extract-plugin": "^2.9.
|
|
112
|
+
"lint-staged": "^15.2.7",
|
|
113
|
+
"mini-css-extract-plugin": "^2.9.0",
|
|
114
114
|
"npm-run-all": "^4.1.5",
|
|
115
|
-
"postcss": "^8.4.
|
|
115
|
+
"postcss": "^8.4.39",
|
|
116
116
|
"postcss-modules": "^6.0.0",
|
|
117
117
|
"postcss-url": "^10.1.3",
|
|
118
|
-
"prettier": "^3.3.
|
|
118
|
+
"prettier": "^3.3.2",
|
|
119
119
|
"react": "^18.3.1",
|
|
120
120
|
"react-dom": "^18.3.1",
|
|
121
121
|
"react-is": "^18.3.1",
|
|
122
122
|
"react-router-dom": "^6.24.1",
|
|
123
123
|
"remark-gfm": "^4.0.0",
|
|
124
124
|
"rimraf": "^6.0.1",
|
|
125
|
-
"rollup": "^4.18.
|
|
125
|
+
"rollup": "^4.18.0",
|
|
126
126
|
"rollup-plugin-postcss": "^4.0.2",
|
|
127
|
-
"sass": "1.77.
|
|
127
|
+
"sass": "1.77.6",
|
|
128
128
|
"sass-loader": "^14.2.1",
|
|
129
|
-
"size-limit": "^11.1.
|
|
129
|
+
"size-limit": "^11.1.4",
|
|
130
130
|
"storybook": "^8.1.11",
|
|
131
131
|
"storybook-addon-mock": "^5.0.0",
|
|
132
132
|
"storybook-addon-pseudo-states": "^3.1.1",
|
|
133
133
|
"style-loader": "^4.0.0",
|
|
134
134
|
"ts-jest": "^29.1.5",
|
|
135
135
|
"tslib": "^2.6.3",
|
|
136
|
-
"typescript": "^5.5.
|
|
136
|
+
"typescript": "^5.5.3"
|
|
137
137
|
}
|
|
138
138
|
}
|
|
@@ -16,7 +16,7 @@
|
|
|
16
16
|
|
|
17
17
|
import React, { ForwardRefRenderFunction, ComponentPropsWithRef, Fragment } from "react";
|
|
18
18
|
import classes from "./BaseButton.module.scss";
|
|
19
|
-
import {
|
|
19
|
+
import { ButtonSpinner } from "./Spinner";
|
|
20
20
|
|
|
21
21
|
export interface Props extends ComponentPropsWithRef<"button"> {
|
|
22
22
|
type?: "submit" | "button" | "reset";
|
|
@@ -49,7 +49,7 @@ const BaseButtonComponent: ForwardRefRenderFunction<HTMLButtonElement, Props> =
|
|
|
49
49
|
{loading ? (
|
|
50
50
|
<Fragment>
|
|
51
51
|
<div className={classes["content-hidden"]}>{children}</div>
|
|
52
|
-
<
|
|
52
|
+
<ButtonSpinner className={classes["spinner"]} />
|
|
53
53
|
</Fragment>
|
|
54
54
|
) : (
|
|
55
55
|
children
|
|
@@ -13,6 +13,8 @@
|
|
|
13
13
|
* See the License for the specific language governing permissions and
|
|
14
14
|
* limitations under the License.
|
|
15
15
|
*/
|
|
16
|
+
@use "../../dataGridMixins.module";
|
|
17
|
+
|
|
16
18
|
$nesting-limit: 6;
|
|
17
19
|
|
|
18
20
|
.row {
|
|
@@ -23,29 +25,11 @@ $nesting-limit: 6;
|
|
|
23
25
|
background-color: var(--data-grid-row-hover-background-color);
|
|
24
26
|
}
|
|
25
27
|
|
|
26
|
-
@mixin borderAfter($i, $no-offset: false) {
|
|
27
|
-
content: "";
|
|
28
|
-
position: absolute;
|
|
29
|
-
|
|
30
|
-
@if $no-offset {
|
|
31
|
-
width: 100%;
|
|
32
|
-
left: 0;
|
|
33
|
-
} @else if $i > 0 {
|
|
34
|
-
width: calc(100% - calc(3.0625rem + $i * 4.125rem));
|
|
35
|
-
left: calc(3.0625rem + $i * 4.125rem);
|
|
36
|
-
} @else {
|
|
37
|
-
width: calc(100% - 3.0625rem);
|
|
38
|
-
left: 3.0625rem;
|
|
39
|
-
}
|
|
40
|
-
bottom: 0;
|
|
41
|
-
border-bottom: 1px solid var(--light-grey-border);
|
|
42
|
-
}
|
|
43
|
-
|
|
44
28
|
@mixin border-x {
|
|
45
29
|
@for $i from 0 through $nesting-limit {
|
|
46
30
|
&.border-#{$i} {
|
|
47
|
-
|
|
48
|
-
@include borderAfter($i);
|
|
31
|
+
&::after {
|
|
32
|
+
@include dataGridMixins.borderAfter($i);
|
|
49
33
|
}
|
|
50
34
|
}
|
|
51
35
|
}
|
|
@@ -54,14 +38,14 @@ $nesting-limit: 6;
|
|
|
54
38
|
@include border-x();
|
|
55
39
|
|
|
56
40
|
&.border {
|
|
57
|
-
|
|
58
|
-
@include borderAfter(0, true);
|
|
41
|
+
&::after {
|
|
42
|
+
@include dataGridMixins.borderAfter(0, true);
|
|
59
43
|
}
|
|
60
44
|
}
|
|
61
45
|
|
|
62
46
|
&.border-drawer {
|
|
63
|
-
&:not(:
|
|
64
|
-
@include borderAfter(0, true);
|
|
47
|
+
&:not(:nth-last-child(2))::after {
|
|
48
|
+
@include dataGridMixins.borderAfter(0, true);
|
|
65
49
|
}
|
|
66
50
|
}
|
|
67
51
|
}
|
|
@@ -15,10 +15,13 @@
|
|
|
15
15
|
*/
|
|
16
16
|
|
|
17
17
|
import React, { useState, useEffect } from "react";
|
|
18
|
-
import {
|
|
18
|
+
import {
|
|
19
|
+
InputWrapper,
|
|
20
|
+
Props as InputWrapperProps
|
|
21
|
+
} from "../../Form/Wrapper/InputWrapper/InputWrapper";
|
|
19
22
|
import { Icon, Icons } from "../../Icon/Icon";
|
|
20
23
|
import classes from "./DataGridToolbar.module.scss";
|
|
21
|
-
import {
|
|
24
|
+
import { useDebouncedCallback } from "../../../hooks/useDebouncedCallback";
|
|
22
25
|
|
|
23
26
|
export interface DataGridSearchbarProps {
|
|
24
27
|
onSearch: (value: string) => void;
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Copyright 2022 OneWelcome B.V.
|
|
3
|
+
*
|
|
4
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
+
* you may not use this file except in compliance with the License.
|
|
6
|
+
* You may obtain a copy of the License at
|
|
7
|
+
*
|
|
8
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
+
*
|
|
10
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
* See the License for the specific language governing permissions and
|
|
14
|
+
* limitations under the License.
|
|
15
|
+
*/
|
|
16
|
+
|
|
17
|
+
import { KeyValuePair } from "./DataGridFilters.interfaces";
|
|
18
|
+
|
|
19
|
+
export class FilterKeyMapper {
|
|
20
|
+
columnKvPairs = new Map<string, { key: string; value: string }[]>();
|
|
21
|
+
|
|
22
|
+
setColumnKvPairs(columnName: string, kvPairs: { key: string; value: string }[]) {
|
|
23
|
+
this.columnKvPairs.set(columnName, kvPairs);
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
getValues(columnName: string): string[] {
|
|
27
|
+
return this.getKvPairs(columnName).map(kv => kv.value);
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
getKeysForValues(columnName: string, values: string[]): string[] {
|
|
31
|
+
const kvPairs = this.getKvPairs(columnName);
|
|
32
|
+
return values.map(v => {
|
|
33
|
+
const kv = kvPairs?.find(kv => kv.value === v);
|
|
34
|
+
if (kv == undefined) {
|
|
35
|
+
throw new Error(`Column '${columnName}' in FilterKeyMapper does not contain value '${v}'`);
|
|
36
|
+
}
|
|
37
|
+
return kv.key;
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
getKvPairs(columnName: string): KeyValuePair[] {
|
|
42
|
+
const kvPairs = this.columnKvPairs.get(columnName);
|
|
43
|
+
if (kvPairs == undefined) {
|
|
44
|
+
throw new Error(`Column '${columnName}' not found in ${FilterKeyMapper.name}`);
|
|
45
|
+
}
|
|
46
|
+
return kvPairs;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
@@ -13,19 +13,20 @@
|
|
|
13
13
|
* See the License for the specific language governing permissions and
|
|
14
14
|
* limitations under the License.
|
|
15
15
|
*/
|
|
16
|
+
@use "../dataGridMixins.module";
|
|
16
17
|
|
|
17
18
|
.row {
|
|
18
|
-
height:
|
|
19
|
+
height: 3.25rem;
|
|
20
|
+
background-color: var(--color-blue-grey25);
|
|
21
|
+
position: relative;
|
|
22
|
+
border-top: 2px solid var(--light-grey-border);
|
|
23
|
+
|
|
24
|
+
&::after {
|
|
25
|
+
@include dataGridMixins.borderAfter(0, true);
|
|
26
|
+
}
|
|
19
27
|
}
|
|
20
28
|
|
|
21
29
|
.context-menu {
|
|
22
30
|
width: 4.125rem;
|
|
23
31
|
box-sizing: border-box;
|
|
24
32
|
}
|
|
25
|
-
|
|
26
|
-
@media only screen and (min-width: 50em) {
|
|
27
|
-
.thead::after {
|
|
28
|
-
width: calc(100% - 2.5rem);
|
|
29
|
-
left: 1.25rem;
|
|
30
|
-
}
|
|
31
|
-
}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* Copyright 2022 OneWelcome B.V.
|
|
3
|
+
*
|
|
4
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
+
* you may not use this file except in compliance with the License.
|
|
6
|
+
* You may obtain a copy of the License at
|
|
7
|
+
*
|
|
8
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
+
*
|
|
10
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
* See the License for the specific language governing permissions and
|
|
14
|
+
* limitations under the License.
|
|
15
|
+
*/
|
|
16
|
+
|
|
17
|
+
@mixin borderAfter($i, $no-offset: false) {
|
|
18
|
+
content: "";
|
|
19
|
+
position: absolute;
|
|
20
|
+
|
|
21
|
+
@if $no-offset {
|
|
22
|
+
width: 100%;
|
|
23
|
+
left: 0;
|
|
24
|
+
} @else if $i > 0 {
|
|
25
|
+
width: calc(100% - calc(3.0625rem + $i * 4.125rem));
|
|
26
|
+
left: calc(3.0625rem + $i * 4.125rem);
|
|
27
|
+
} @else {
|
|
28
|
+
width: calc(100% - 3.0625rem);
|
|
29
|
+
left: 3.0625rem;
|
|
30
|
+
}
|
|
31
|
+
bottom: 0;
|
|
32
|
+
border-bottom: 2px solid var(--light-grey-border);
|
|
33
|
+
}
|
|
@@ -18,48 +18,39 @@ import { useEffect, useState } from "react";
|
|
|
18
18
|
import { Filter } from "./DataGridFilters/DataGridFilters.interfaces";
|
|
19
19
|
import { useFiltersReducer } from "./DataGridFilters/useFiltersReducer";
|
|
20
20
|
|
|
21
|
+
type OperatorPredicateMap<TOperator extends string> = {
|
|
22
|
+
[op in TOperator]: (v1: string, v2: string) => boolean;
|
|
23
|
+
};
|
|
24
|
+
|
|
25
|
+
const operatorPredicateMap: OperatorPredicateMap<string> = {
|
|
26
|
+
is: (v1, v2) => v1 === v2,
|
|
27
|
+
"is not": (v1, v2) => v1 !== v2
|
|
28
|
+
};
|
|
29
|
+
|
|
30
|
+
function reduceConjunction<T>(arr: T[], fn: (v: T) => boolean) {
|
|
31
|
+
return arr.reduce((acc, val) => fn(val) && acc, true);
|
|
32
|
+
}
|
|
33
|
+
function reduceDisjunction<T>(arr: T[], fn: (v: T) => boolean) {
|
|
34
|
+
return arr.reduce((acc, val) => fn(val) || acc, false);
|
|
35
|
+
}
|
|
36
|
+
|
|
21
37
|
/**
|
|
22
38
|
* @scope .
|
|
23
39
|
* @scopeException stories/DataGrid/DataGrid.stories.tsx
|
|
24
40
|
*/
|
|
25
|
-
export const useMockFilteringLogic = <T
|
|
41
|
+
export const useMockFilteringLogic = <T extends { [k: string]: string }>(
|
|
42
|
+
data: T[],
|
|
43
|
+
filterValues: Filter[] | undefined
|
|
44
|
+
) => {
|
|
26
45
|
const { state, addFilter, editFilter, deleteFilter, clearFilters } =
|
|
27
46
|
useFiltersReducer(filterValues);
|
|
28
47
|
|
|
29
48
|
const [gridData, setGridData] = useState(data);
|
|
30
49
|
|
|
31
|
-
const operatorPredicateMap = {
|
|
32
|
-
is: (v1: string, v2: string) => v1 === v2,
|
|
33
|
-
"is not": (v1: string, v2: string) => v1 !== v2
|
|
34
|
-
};
|
|
35
|
-
|
|
36
50
|
useEffect(() => {
|
|
37
|
-
const filteredData = data
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
state.filters.forEach(filter => {
|
|
41
|
-
shouldBeDiscarded = [
|
|
42
|
-
...shouldBeDiscarded,
|
|
43
|
-
!filter.value.reduce((acc, val) => {
|
|
44
|
-
return (
|
|
45
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
46
|
-
(operatorPredicateMap[filter.operator as keyof typeof operatorPredicateMap] as any)(
|
|
47
|
-
row[filter.column as keyof typeof row],
|
|
48
|
-
val
|
|
49
|
-
) && acc
|
|
50
|
-
);
|
|
51
|
-
}, true)
|
|
52
|
-
];
|
|
53
|
-
});
|
|
54
|
-
|
|
55
|
-
return shouldBeDiscarded.length > 0 &&
|
|
56
|
-
shouldBeDiscarded.reduce((acc, val) => acc || val, false)
|
|
57
|
-
? undefined
|
|
58
|
-
: row;
|
|
59
|
-
})
|
|
60
|
-
.filter(val => {
|
|
61
|
-
return val !== undefined;
|
|
62
|
-
}) as T[];
|
|
51
|
+
const filteredData = data.map(filterRow).filter(val => {
|
|
52
|
+
return val !== undefined;
|
|
53
|
+
});
|
|
63
54
|
setGridData(filteredData);
|
|
64
55
|
}, [state.filters]);
|
|
65
56
|
|
|
@@ -72,4 +63,20 @@ export const useMockFilteringLogic = <T>(data: T[], filterValues: Filter[] | und
|
|
|
72
63
|
setGridData,
|
|
73
64
|
filters: state.filters
|
|
74
65
|
};
|
|
66
|
+
|
|
67
|
+
function filterRow(row: T) {
|
|
68
|
+
let shouldBeDiscarded: boolean[] = [];
|
|
69
|
+
state.filters.forEach(filter => {
|
|
70
|
+
const reduce = filter.operator == "is" ? reduceDisjunction : reduceConjunction;
|
|
71
|
+
const operatorPredicate = operatorPredicateMap[filter.operator];
|
|
72
|
+
shouldBeDiscarded = [
|
|
73
|
+
...shouldBeDiscarded,
|
|
74
|
+
!reduce(filter.value, val => operatorPredicate(row[filter.column], val))
|
|
75
|
+
];
|
|
76
|
+
});
|
|
77
|
+
|
|
78
|
+
return shouldBeDiscarded.length > 0 && shouldBeDiscarded.reduce((acc, val) => acc || val, false)
|
|
79
|
+
? undefined
|
|
80
|
+
: row;
|
|
81
|
+
}
|
|
75
82
|
};
|
|
@@ -87,7 +87,7 @@
|
|
|
87
87
|
align-items: center;
|
|
88
88
|
|
|
89
89
|
.progress-bar {
|
|
90
|
-
height: 3rem;
|
|
90
|
+
min-height: 3rem;
|
|
91
91
|
width: 100%;
|
|
92
92
|
background: transparent;
|
|
93
93
|
|
|
@@ -119,9 +119,9 @@
|
|
|
119
119
|
font-size: 0.875rem;
|
|
120
120
|
|
|
121
121
|
.friendly-name {
|
|
122
|
-
overflow:
|
|
122
|
+
overflow-wrap: anywhere;
|
|
123
123
|
text-overflow: ellipsis;
|
|
124
|
-
|
|
124
|
+
text-wrap: wrap;
|
|
125
125
|
}
|
|
126
126
|
|
|
127
127
|
&.error {
|
|
@@ -169,6 +169,9 @@
|
|
|
169
169
|
display: block;
|
|
170
170
|
margin: 0.3125rem 1.75rem;
|
|
171
171
|
padding: 0;
|
|
172
|
+
overflow-wrap: anywhere;
|
|
173
|
+
text-overflow: ellipsis;
|
|
174
|
+
text-wrap: wrap;
|
|
172
175
|
}
|
|
173
176
|
|
|
174
177
|
.error,
|
|
@@ -195,7 +195,9 @@ const FileItemComponent: ForwardRefRenderFunction<HTMLDivElement, Props> = (
|
|
|
195
195
|
/>
|
|
196
196
|
)}
|
|
197
197
|
<Icon icon={icons.fileIcon} className={classes["file-icon"]} />
|
|
198
|
-
<span className={classes["friendly-name"]}>
|
|
198
|
+
<span className={classes["friendly-name"]}>
|
|
199
|
+
{friendlyName}.{extension}
|
|
200
|
+
</span>
|
|
199
201
|
</Typography>
|
|
200
202
|
);
|
|
201
203
|
};
|
|
@@ -28,8 +28,19 @@
|
|
|
28
28
|
|
|
29
29
|
.file-upload-title {
|
|
30
30
|
margin: 0 0 0.25rem 0;
|
|
31
|
-
font-
|
|
31
|
+
font-family: var(--font-family);
|
|
32
|
+
font-size: var(--form-control-font-size);
|
|
33
|
+
line-height: var(--default-line-height);
|
|
34
|
+
color: var(--color-blue-grey900);
|
|
32
35
|
font-weight: 400;
|
|
36
|
+
display: block;
|
|
37
|
+
|
|
38
|
+
&.required {
|
|
39
|
+
&:after {
|
|
40
|
+
content: " *";
|
|
41
|
+
color: var(--error);
|
|
42
|
+
}
|
|
43
|
+
}
|
|
33
44
|
}
|
|
34
45
|
|
|
35
46
|
&.error {
|
|
@@ -66,10 +77,6 @@
|
|
|
66
77
|
right: 2rem;
|
|
67
78
|
}
|
|
68
79
|
|
|
69
|
-
.file-upload-title-mandatory {
|
|
70
|
-
color: var(--color-red500);
|
|
71
|
-
}
|
|
72
|
-
|
|
73
80
|
& {
|
|
74
81
|
@include transition(all, 0.2s, ease-in-out);
|
|
75
82
|
}
|
|
@@ -28,6 +28,7 @@ import { Props as InputProps } from "../Input/Input";
|
|
|
28
28
|
import { Typography } from "../../Typography/Typography";
|
|
29
29
|
import classes from "./FileUpload.module.scss";
|
|
30
30
|
import { useDetermineStatusIcon } from "../../../hooks/useDetermineStatusIcon";
|
|
31
|
+
import { Label } from "../Label/Label";
|
|
31
32
|
|
|
32
33
|
type FileUploadType = Omit<InputProps, "onDrop" | "type" | "onChange" | "suffix" | "prefix">;
|
|
33
34
|
export type FileType = Omit<FileConfig, "onRequestedFileAction"> &
|
|
@@ -105,6 +106,9 @@ const FileUploadComponent: ForwardRefRenderFunction<HTMLInputElement, Props> = (
|
|
|
105
106
|
}
|
|
106
107
|
disabled && dropzoneContainerClassNames.push(classes["disabled"]);
|
|
107
108
|
success && !error && dropzoneClassNames.push(classes["success"]);
|
|
109
|
+
const inputId = `input-${name}`;
|
|
110
|
+
const labelClasses = [classes["file-upload-title"]];
|
|
111
|
+
isRequired && labelClasses.push(classes["required"]);
|
|
108
112
|
|
|
109
113
|
const getFileList = (files: FileList | null): FileType[] => {
|
|
110
114
|
let savedFiles = fileList ? [...fileList] : [];
|
|
@@ -160,9 +164,9 @@ const FileUploadComponent: ForwardRefRenderFunction<HTMLInputElement, Props> = (
|
|
|
160
164
|
const isAtLeastOneMb = maxFileSizeInBytes >= 1024 * 1024;
|
|
161
165
|
|
|
162
166
|
if (isAtLeastOneMb) {
|
|
163
|
-
sizeMessage = `${(maxFileSizeInBytes / (1024 * 1024)).toFixed(2)}MB`;
|
|
167
|
+
sizeMessage = `${parseFloat((maxFileSizeInBytes / (1024 * 1024)).toFixed(2))}MB`;
|
|
164
168
|
} else {
|
|
165
|
-
sizeMessage = `${(maxFileSizeInBytes / 1024).toFixed(2)}KB`;
|
|
169
|
+
sizeMessage = `${parseFloat((maxFileSizeInBytes / 1024).toFixed(2))}KB`;
|
|
166
170
|
}
|
|
167
171
|
|
|
168
172
|
result.error =
|
|
@@ -228,11 +232,9 @@ const FileUploadComponent: ForwardRefRenderFunction<HTMLInputElement, Props> = (
|
|
|
228
232
|
<div className={classes["file-upload-wrapper"]} {...wrapperProps}>
|
|
229
233
|
<div className={classes["dropzone-wrapper"]}>
|
|
230
234
|
<div className={dropzoneClassNames.join(" ")}>
|
|
231
|
-
<
|
|
232
|
-
{title}
|
|
233
|
-
|
|
234
|
-
</Typography>
|
|
235
|
-
|
|
235
|
+
<Label ref={labelRef} className={`${labelClasses.join(" ")}`} htmlFor={inputId}>
|
|
236
|
+
{title}
|
|
237
|
+
</Label>
|
|
236
238
|
{fileList?.length > 0 && (
|
|
237
239
|
<ul className={classes["file-list"]}>
|
|
238
240
|
{fileList.map(({ name, status, progress, error }) => (
|
|
@@ -271,6 +273,7 @@ const FileUploadComponent: ForwardRefRenderFunction<HTMLInputElement, Props> = (
|
|
|
271
273
|
ref={ref}
|
|
272
274
|
aria-labelledby={labeledBy}
|
|
273
275
|
type="file"
|
|
276
|
+
id={inputId}
|
|
274
277
|
name={name}
|
|
275
278
|
multiple={multiple}
|
|
276
279
|
disabled={disabled}
|
|
@@ -377,3 +377,15 @@
|
|
|
377
377
|
content: "\e950";
|
|
378
378
|
@include fontProperties();
|
|
379
379
|
}
|
|
380
|
+
.icon-sidesheet-handle:before {
|
|
381
|
+
content: "\e951";
|
|
382
|
+
@include fontProperties();
|
|
383
|
+
}
|
|
384
|
+
.icon-pending-circle:before {
|
|
385
|
+
content: "\e952";
|
|
386
|
+
@include fontProperties();
|
|
387
|
+
}
|
|
388
|
+
.icon-minus-circle:before {
|
|
389
|
+
content: "\e953";
|
|
390
|
+
@include fontProperties();
|
|
391
|
+
}
|
|
@@ -100,7 +100,10 @@ export enum Icons {
|
|
|
100
100
|
ZoomIn = "zoom-in",
|
|
101
101
|
ZoomOut = "zoom-out",
|
|
102
102
|
ArrowUp = "arrow-up",
|
|
103
|
-
ExternalLink = "external-link"
|
|
103
|
+
ExternalLink = "external-link",
|
|
104
|
+
SideSheetHandle = "sidesheet-handle",
|
|
105
|
+
PendingCircle = "pending-circle",
|
|
106
|
+
MinusCircle = "minus-circle"
|
|
104
107
|
}
|
|
105
108
|
|
|
106
109
|
type Tag = "span" | "div" | "i";
|
|
@@ -44,6 +44,7 @@ export interface Props extends ComponentPropsWithRef<"div"> {
|
|
|
44
44
|
describedby?: string;
|
|
45
45
|
disableEscapeKeyDown?: boolean;
|
|
46
46
|
disableBackdrop?: boolean;
|
|
47
|
+
hideBackdrop?: boolean;
|
|
47
48
|
forceContainerOpen?: boolean;
|
|
48
49
|
zIndex?: number;
|
|
49
50
|
domRoot?: HTMLElement;
|
|
@@ -84,6 +85,7 @@ const BaseModalComponent: ForwardRefRenderFunction<HTMLDivElement, Props> = (
|
|
|
84
85
|
describedby,
|
|
85
86
|
disableEscapeKeyDown = false,
|
|
86
87
|
disableBackdrop = false,
|
|
88
|
+
hideBackdrop = false,
|
|
87
89
|
forceContainerOpen = false,
|
|
88
90
|
zIndex,
|
|
89
91
|
domRoot,
|
|
@@ -141,12 +143,14 @@ const BaseModalComponent: ForwardRefRenderFunction<HTMLDivElement, Props> = (
|
|
|
141
143
|
onKeyDown={handleEscKeyPress}
|
|
142
144
|
style={{ zIndex }}
|
|
143
145
|
>
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
146
|
+
{!hideBackdrop ? (
|
|
147
|
+
<div
|
|
148
|
+
{...backdropProps}
|
|
149
|
+
aria-hidden={true}
|
|
150
|
+
className={`${classes["backdrop"]} ${backdropProps?.className ?? ""}`}
|
|
151
|
+
onClick={handleBackdropClick}
|
|
152
|
+
></div>
|
|
153
|
+
) : null}
|
|
150
154
|
{forceContainerOpen ? (
|
|
151
155
|
<div
|
|
152
156
|
{...containerProps}
|
|
@@ -23,16 +23,17 @@ import { Typography } from "../../../Typography/Typography";
|
|
|
23
23
|
export interface Props extends ComponentPropsWithRef<"div"> {
|
|
24
24
|
id: string;
|
|
25
25
|
title: string;
|
|
26
|
+
description?: string;
|
|
26
27
|
children?: React.ReactNode;
|
|
27
28
|
onClose?: (event: React.MouseEvent<HTMLButtonElement>) => void;
|
|
28
29
|
}
|
|
29
30
|
|
|
30
31
|
const BaseModalHeaderComponent: ForwardRefRenderFunction<HTMLDivElement, Props> = (
|
|
31
|
-
{ id, title, children, onClose, ...rest }: Props,
|
|
32
|
+
{ id, title, children, onClose, description, className, ...rest }: Props,
|
|
32
33
|
ref
|
|
33
34
|
) => {
|
|
34
35
|
return (
|
|
35
|
-
<div {...rest} ref={ref} className={classes["header"]}>
|
|
36
|
+
<div {...rest} ref={ref} className={`${classes["header"]} ${className}`}>
|
|
36
37
|
<div className={classes["headline"]}>
|
|
37
38
|
<div className={classes["title-wrapper"]}>
|
|
38
39
|
<Typography
|
|
@@ -44,6 +45,17 @@ const BaseModalHeaderComponent: ForwardRefRenderFunction<HTMLDivElement, Props>
|
|
|
44
45
|
>
|
|
45
46
|
{title}
|
|
46
47
|
</Typography>
|
|
48
|
+
{description && (
|
|
49
|
+
<Typography
|
|
50
|
+
id={id}
|
|
51
|
+
className={classes["title"]}
|
|
52
|
+
tag="span"
|
|
53
|
+
spacing={{ marginBottom: 0 }}
|
|
54
|
+
variant="body"
|
|
55
|
+
>
|
|
56
|
+
{description}
|
|
57
|
+
</Typography>
|
|
58
|
+
)}
|
|
47
59
|
</div>
|
|
48
60
|
<IconButton onClick={onClose} className={classes["closeBtn"]} title="close modal">
|
|
49
61
|
<Icon icon={Icons.Times} />
|