@mailstep/design-system 0.6.3-beta.9 → 0.6.4

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 (39) hide show
  1. package/package.json +1 -1
  2. package/ui/Blocks/CommonGrid/CommonGrid.js +0 -13
  3. package/ui/Blocks/CommonGrid/CommonGridContainer.js +1 -2
  4. package/ui/Blocks/CommonGrid/hooks/useManageColumn.d.ts +1 -2
  5. package/ui/Blocks/CommonGrid/hooks/useManageColumn.js +29 -33
  6. package/ui/Blocks/CommonGrid/storybook/stories/loading.stories.js +1 -1
  7. package/ui/Blocks/CommonGrid/storybook/stories/manyColumnsNoScrollLayout.stories.js +1 -1
  8. package/ui/Blocks/CommonGrid/storybook/stories/manyColumnsNormalLayout.stories.js +1 -1
  9. package/ui/Blocks/CommonGrid/storybook/stories/withCustomGridActions.stories.js +1 -1
  10. package/ui/Blocks/CommonGrid/types.d.ts +1 -2
  11. package/ui/Blocks/CommonGrid/utils/index.d.ts +1 -0
  12. package/ui/Blocks/CommonGrid/utils/index.js +13 -0
  13. package/ui/Blocks/Modal/Modal.js +2 -2
  14. package/ui/Blocks/Modal/stories/Modal.stories.js +5 -1
  15. package/ui/Blocks/Modal/styles.d.ts +4 -0
  16. package/ui/Blocks/Modal/styles.js +10 -3
  17. package/ui/Blocks/Tabs/Tabs.js +2 -2
  18. package/ui/Blocks/Tabs/styles.d.ts +1 -0
  19. package/ui/Blocks/Tabs/styles.js +4 -1
  20. package/ui/Blocks/Tabs/types.d.ts +1 -0
  21. package/ui/Elements/ErrorMessage/ErrorMessage.js +1 -1
  22. package/ui/Elements/Text/types.d.ts +2 -2
  23. package/ui/Forms/Checkbox/Checkbox.js +3 -2
  24. package/ui/Forms/Checkbox/stories/Checkbox.stories.js +1 -1
  25. package/ui/Forms/Checkbox/styles.d.ts +1 -1
  26. package/ui/Forms/Checkbox/styles.js +1 -1
  27. package/ui/Forms/RadioButton/RadioButton.js +4 -1
  28. package/ui/Forms/RadioButton/styles.d.ts +1 -1
  29. package/ui/Forms/RadioButton/styles.js +1 -1
  30. package/ui/index.d.ts +1 -3
  31. package/ui/index.es.js +4204 -4193
  32. package/ui/index.js +1 -3
  33. package/ui/index.umd.js +261 -253
  34. package/ui/Elements/Paragraph/Paragraph.d.ts +0 -2
  35. package/ui/Elements/Paragraph/Paragraph.js +0 -3
  36. package/ui/Elements/Paragraph/index.d.ts +0 -3
  37. package/ui/Elements/Paragraph/index.js +0 -3
  38. package/ui/Elements/Paragraph/stories/Paragraph.stories.d.ts +0 -17
  39. package/ui/Elements/Paragraph/stories/Paragraph.stories.js +0 -34
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@mailstep/design-system",
3
- "version": "0.6.3-beta.9",
3
+ "version": "0.6.4",
4
4
  "license": "ISC",
5
5
  "type": "module",
6
6
  "main": "./ui/index.js",
@@ -45,19 +45,6 @@ var CommonGrid = function (_a) {
45
45
  var clearUxState = gridActions.clearUxState, handleUxChange = gridActions.handleUxChange, _g = gridActions.addFilter, addFilter = _g === void 0 ? defaultVoidFunction : _g, _h = gridActions.addSorting, addSorting = _h === void 0 ? defaultVoidFunction : _h, _j = gridActions.setColumnWidth, setColumnWidth = _j === void 0 ? defaultVoidFunction : _j, _k = gridActions.setColumnsOrder, setColumnsOrder = _k === void 0 ? defaultVoidFunction : _k;
46
46
  var handleRowsKeyDown = useRowsKeyControls(rowsData, uxState, handleUxChange);
47
47
  useUxReset(rowsData, uxState, clearUxState);
48
- var checksColumnsOrder = React.useCallback(function (colsOrder) {
49
- var stickyRightColls = columnsDefinitions.filter(function (col) { return col.sticky === true && col.stickTo === 'right'; });
50
- var stickyLeftColls = columnsDefinitions.filter(function (col) { return col.sticky === true && col.stickTo !== 'right'; });
51
- if (stickyLeftColls.length > 1 || stickyRightColls.length > 1) {
52
- console.error('Grid can have only sticky column on each side.');
53
- }
54
- if (stickyLeftColls.length && colsOrder.indexOf(stickyLeftColls[0].name) !== 0) {
55
- console.error('The left sticky column should be the first one in a row');
56
- }
57
- if (stickyRightColls.length && colsOrder.indexOf(stickyRightColls[0].name) !== colsOrder.length - 1) {
58
- console.error('The Right sticky column should be the last one in a row');
59
- }
60
- }, [columnsDefinitions]);
61
48
  var GridMessage;
62
49
  var messageClass = 'info';
63
50
  if (isLoading)
@@ -40,7 +40,7 @@ import ManageColumnForm from './components/ManageColumnForm';
40
40
  import { Trans } from '@lingui/react';
41
41
  import { Settings2 } from '../../Elements/Icon/icons/Settings2';
42
42
  var StyledCommonGrid = function (props) {
43
- var _a = props.optimizeFilters, optimizeFilters = _a === void 0 ? false : _a, extraControlButtons = props.extraControlButtons, eshopSelect = props.eshopSelect, onBatchAction = props.onBatchAction, processCheckedValues = props.processCheckedValues, processCheckedValuesTitle = props.processCheckedValuesTitle, hideControlButtons = props.hideControlButtons, floatingButtonProps = props.floatingButtonProps, queryRowsParam = props.queryRowsParam, customPaginationHandler = props.customPaginationHandler, hideColumnConfig = props.hideColumnConfig, passDownProps = __rest(props, ["optimizeFilters", "extraControlButtons", "eshopSelect", "onBatchAction", "processCheckedValues", "processCheckedValuesTitle", "hideControlButtons", "floatingButtonProps", "queryRowsParam", "customPaginationHandler", "hideColumnConfig"]);
43
+ var _a = props.optimizeFilters, optimizeFilters = _a === void 0 ? false : _a, extraControlButtons = props.extraControlButtons, eshopSelect = props.eshopSelect, onBatchAction = props.onBatchAction, processCheckedValues = props.processCheckedValues, processCheckedValuesTitle = props.processCheckedValuesTitle, hideControlButtons = props.hideControlButtons, floatingButtonProps = props.floatingButtonProps, queryRowsParam = props.queryRowsParam, customPaginationHandler = props.customPaginationHandler, passDownProps = __rest(props, ["optimizeFilters", "extraControlButtons", "eshopSelect", "onBatchAction", "processCheckedValues", "processCheckedValuesTitle", "hideControlButtons", "floatingButtonProps", "queryRowsParam", "customPaginationHandler"]);
44
44
  var gridActions = passDownProps.gridActions, gridSelectors = passDownProps.gridSelectors, rowsData = passDownProps.rowsData, actionColumnDefinition = passDownProps.actionColumnDefinition;
45
45
  var _b = useGetGridHeight(), gridHeight = _b.gridHeight, gridRef = _b.gridRef, paginationRef = _b.paginationRef;
46
46
  useEffect(function () {
@@ -60,7 +60,6 @@ var StyledCommonGrid = function (props) {
60
60
  gridActions: gridActions,
61
61
  gridSelectors: gridSelectors,
62
62
  onClose: onClose,
63
- hideColumnConfig: hideColumnConfig,
64
63
  }), columnsConfigValues = _d.columnsConfigValues, setColumnsConfigOptions = _d.setColumnsConfigOptions, onConfirmForm = _d.onConfirmForm, resetColumnConfig = _d.resetColumnConfig, handleDragEnd = _d.handleDragEnd, onCloseForm = _d.onCloseForm, displayColumnsDefinitions = _d.displayColumnsDefinitions, manageColumnsFormDefinitions = _d.manageColumnsFormDefinitions;
65
64
  return (_jsxs(ContentContainer, { children: [_jsxs(CommonGridWrap, { children: [_jsx(HidePrint, { children: _jsxs(StyledButtonStrip, { className: "buttonsStrip", children: [!hideControlButtons && (_jsx(ControlButtons, { extraControlButtons: extraControlButtons, gridActions: gridActions, gridSelectors: gridSelectors, eshopSelect: eshopSelect })), _jsx(StyledColumnButton, { type: "button", sizing: "iconLg", appearance: "ghost", icon: _jsx(Settings2, {}), onClick: openManageColumnForm, children: _jsx(H6, { variant: "semiBold", children: _jsx(Trans, { id: "manageColumn.title", message: "Manage column" }) }) })] }) }), _jsx(CommonGridWithStyles, __assign({}, passDownProps, modifiedPassDownProps, { filters: filters, gridRef: gridRef, height: gridHeight, floatingButtonProps: floatingButtonProps, handleDragEnd: handleDragEnd(false), displayColumnsDefinitions: displayColumnsDefinitions, hasColouredRows: true }))] }), _jsx(HidePrint, { children: _jsxs(BottomWrapper, { ref: paginationRef, isFixed: !!gridHeight, children: [processCheckedValues && (_jsx(ActionHead, { rowsData: rowsData, onBatchAction: onBatchAction, gridActions: gridActions, gridSelectors: gridSelectors, actionColumn: actionColumnDefinition, processCheckedValues: processCheckedValues, processCheckedValuesTitle: processCheckedValuesTitle })), _jsxs(x.div, { display: "flex", justifyContent: "center", alignItems: "center", className: "paginatorWrapper", w: "100%", h: window.innerWidth > 1204 ? '60px' : '32px', children: [_jsx(Pagination, { page: gridSelectors === null || gridSelectors === void 0 ? void 0 : gridSelectors.page, itemCount: passDownProps === null || passDownProps === void 0 ? void 0 : passDownProps.totalRowsCount, itemPerPage: (gridSelectors === null || gridSelectors === void 0 ? void 0 : gridSelectors.rowsPerPage) || 10, onPageChange: gridActions === null || gridActions === void 0 ? void 0 : gridActions.setPage, customPaginationHandler: customPaginationHandler }), _jsx(TablePagination, { gridActions: gridActions, gridSelectors: gridSelectors, customPaginationHandler: customPaginationHandler })] })] }) }), manageColumnFormVisible && (_jsx(Modal, { title: _jsx(Trans, { id: "manageColumn.title", message: "Manage columns" }), onClose: onCloseForm, onCancel: onCloseForm, onExtraAction: resetColumnConfig, onConfirm: onConfirmForm, width: "auto", minWidth: "350px", hasFooter: true, extraActionLabel: _jsx(Trans, { id: "dataGrid.buttonClearConfig", message: "Reset config" }), cancelLabel: _jsx(Trans, { id: "form.buttonCancel", message: "Cancel" }), confirmLabel: _jsx(Trans, { id: "form.buttonConfirm", message: "Confirm" }), children: _jsx(ManageColumnForm, { columns: manageColumnsFormDefinitions, columnsConfigValues: columnsConfigValues, setColumnsConfigOptions: setColumnsConfigOptions, handleDragEnd: handleDragEnd(true) }) }))] }));
66
65
  };
@@ -6,9 +6,8 @@ type Props = {
6
6
  gridActions: GridActionsType;
7
7
  gridSelectors: GridSelectorsType;
8
8
  onClose?: () => void;
9
- hideColumnConfig?: boolean;
10
9
  };
11
- declare const useManageColumn: ({ columns, gridSelectors, gridActions, onClose, hideColumnConfig }: Props) => {
10
+ declare const useManageColumn: ({ columns, gridSelectors, gridActions, onClose }: Props) => {
12
11
  columnsConfigValues: string[];
13
12
  setColumnsConfigOptions: import("react").Dispatch<import("react").SetStateAction<{
14
13
  [x: string]: {
@@ -18,20 +18,16 @@ var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
18
18
  }
19
19
  return to.concat(ar || Array.prototype.slice.call(from));
20
20
  };
21
- import { useCallback, useMemo, useState } from 'react';
22
- import { isColumnOn } from '../utils';
21
+ import { useCallback, useEffect, useMemo, useState } from 'react';
22
+ import { checksColumnsOrder, isColumnOn } from '../utils';
23
23
  var useManageColumn = function (_a) {
24
- var columns = _a.columns, gridSelectors = _a.gridSelectors, gridActions = _a.gridActions, onClose = _a.onClose, hideColumnConfig = _a.hideColumnConfig;
24
+ var columns = _a.columns, gridSelectors = _a.gridSelectors, gridActions = _a.gridActions, onClose = _a.onClose;
25
25
  var resetGrid = gridActions.resetGrid, setColumnConfig = gridActions.setColumnConfig, setColumnsOrder = gridActions.setColumnsOrder;
26
26
  var columnConfig = gridSelectors.columnConfig, columnsOrder = gridSelectors.columnsOrder;
27
- var initialColumnsOrder = useMemo(function () { return columns.map(function (col) { return col.name; }); }, []);
27
+ var initialColumnsOrder = useMemo(function () { return columns === null || columns === void 0 ? void 0 : columns.map(function (col) { return col.name; }); }, [columns]);
28
28
  var columnsOrderValue = (columnsOrder === null || columnsOrder === void 0 ? void 0 : columnsOrder.length) ? columnsOrder : initialColumnsOrder;
29
- var _b = useState(__assign({}, columnConfig)), columnsConfigOptions = _b[0], setColumnsConfigOptions = _b[1];
29
+ var _b = useState(__assign({}, (columnConfig !== null && columnConfig !== void 0 ? columnConfig : {}))), columnsConfigOptions = _b[0], setColumnsConfigOptions = _b[1];
30
30
  var _c = useState(columnsOrderValue), updatedColumnsOrder = _c[0], setUpdatedColumnsOrder = _c[1];
31
- console.log(9, 'columnConfig', columnConfig);
32
- console.log('columnsOrder', columnsOrder);
33
- console.log('columnsConfigOptions', columnsConfigOptions);
34
- console.log('updatedColumnsOrder', updatedColumnsOrder);
35
31
  var columnsConfigValues = useMemo(function () {
36
32
  return columns === null || columns === void 0 ? void 0 : columns.filter(function (column) {
37
33
  var _a;
@@ -41,19 +37,29 @@ var useManageColumn = function (_a) {
41
37
  }, [columnConfig, columns]);
42
38
  var onConfirmForm = useCallback(function () {
43
39
  setColumnConfig === null || setColumnConfig === void 0 ? void 0 : setColumnConfig(columnsConfigOptions);
44
- setColumnsOrder === null || setColumnsOrder === void 0 ? void 0 : setColumnsOrder(updatedColumnsOrder);
40
+ setColumnsOrder === null || setColumnsOrder === void 0 ? void 0 : setColumnsOrder(columnsConfigValues);
45
41
  onClose === null || onClose === void 0 ? void 0 : onClose();
46
- }, [columnsConfigOptions, updatedColumnsOrder, onClose, setColumnConfig]);
42
+ }, [columnsConfigOptions, updatedColumnsOrder, onClose, setColumnConfig, setColumnsOrder]);
47
43
  var resetColumnConfig = useCallback(function () {
48
44
  setUpdatedColumnsOrder(initialColumnsOrder);
49
45
  resetGrid === null || resetGrid === void 0 ? void 0 : resetGrid();
50
46
  onClose === null || onClose === void 0 ? void 0 : onClose();
51
- setColumnsConfigOptions(columnConfig || {});
52
- }, [onClose, resetGrid]);
47
+ setColumnsConfigOptions({});
48
+ }, [onClose, resetGrid, initialColumnsOrder, columnConfig]);
53
49
  var onCloseForm = useCallback(function () {
54
- setUpdatedColumnsOrder(columnsOrder !== null && columnsOrder !== void 0 ? columnsOrder : []);
50
+ setUpdatedColumnsOrder(columnsOrderValue);
55
51
  onClose === null || onClose === void 0 ? void 0 : onClose();
56
- }, []);
52
+ setColumnsConfigOptions({});
53
+ }, [columnsOrderValue, onClose]);
54
+ var getSortedColumns = useCallback(function (orderValues, isManageModal) {
55
+ return (!isManageModal ? columns.filter(function (column) { return isColumnOn(column, columnConfig); }) : columns).toSorted(function (col1, col2) {
56
+ var i = (orderValues || []).indexOf(col1.name);
57
+ var j = (orderValues || []).indexOf(col2.name);
58
+ return i > j ? 1 : i < j ? -1 : 0;
59
+ });
60
+ }, [columnConfig, columns]);
61
+ var displayColumnsDefinitions = useMemo(function () { return getSortedColumns(columnsOrderValue, false); }, [columnsOrderValue]);
62
+ var manageColumnsFormDefinitions = useMemo(function () { return getSortedColumns(updatedColumnsOrder, true); }, [updatedColumnsOrder]);
57
63
  var handleDragEnd = useCallback(function (isManageModal) {
58
64
  if (isManageModal === void 0) { isManageModal = false; }
59
65
  return function (item) {
@@ -63,33 +69,23 @@ var useManageColumn = function (_a) {
63
69
  if (to === from || !destination) {
64
70
  return;
65
71
  }
66
- var newOrderColumns = __spreadArray([], (isManageModal ? updatedColumnsOrder : columnsOrder !== null && columnsOrder !== void 0 ? columnsOrder : []), true);
72
+ var columns = isManageModal ? manageColumnsFormDefinitions : displayColumnsDefinitions;
73
+ var newOrderColumns = __spreadArray([], (isManageModal ? updatedColumnsOrder : columnsOrderValue), true);
67
74
  var fromIndex = newOrderColumns.findIndex(function (column) { return columns[from].name === column; });
68
- var toIndex = newOrderColumns.findIndex(function (column) { return to && columns[to].name === column; });
75
+ var toIndex = newOrderColumns.findIndex(function (column) { return columns[to !== null && to !== void 0 ? to : 0].name === column; });
69
76
  // move column from a position to the new position
70
77
  var column = newOrderColumns[fromIndex];
71
78
  newOrderColumns.splice(fromIndex, 1);
72
- newOrderColumns.splice(toIndex < 0 ? 0 : toIndex, 0, column);
79
+ newOrderColumns.splice(toIndex === -1 ? 0 : toIndex, 0, column);
73
80
  if (!isManageModal) {
74
81
  setColumnsOrder === null || setColumnsOrder === void 0 ? void 0 : setColumnsOrder(newOrderColumns);
75
82
  }
76
83
  setUpdatedColumnsOrder(newOrderColumns);
77
84
  };
78
- }, [columns, updatedColumnsOrder]);
79
- var displayColumnsDefinitions = useMemo(function () {
80
- return (!hideColumnConfig ? columns.filter(function (column) { return isColumnOn(column, columnConfig); }) : columns).sort(function (col1, col2) {
81
- var i = (columnsOrder || []).indexOf(col1.name);
82
- var j = (columnsOrder || []).indexOf(col2.name);
83
- return i > j ? 1 : i < j ? -1 : 0;
84
- });
85
- }, [hideColumnConfig, columnConfig, columns, columnsOrder]);
86
- var manageColumnsFormDefinitions = useMemo(function () {
87
- return (!hideColumnConfig ? columns.filter(function (column) { return isColumnOn(column, columnConfig); }) : columns).sort(function (col1, col2) {
88
- var i = (updatedColumnsOrder || []).indexOf(col1.name);
89
- var j = (updatedColumnsOrder || []).indexOf(col2.name);
90
- return i > j ? 1 : i < j ? -1 : 0;
91
- });
92
- }, [hideColumnConfig, columnConfig, columns, columnsOrder]);
85
+ }, [updatedColumnsOrder, columnsOrderValue, setColumnsOrder, manageColumnsFormDefinitions, displayColumnsDefinitions]);
86
+ useEffect(function () {
87
+ checksColumnsOrder(columnsOrderValue, columns);
88
+ }, []);
93
89
  return {
94
90
  columnsConfigValues: columnsConfigValues,
95
91
  setColumnsConfigOptions: setColumnsConfigOptions,
@@ -6,7 +6,7 @@ import { LinguiContainer } from '../utils/linguiContainer';
6
6
  export default {
7
7
  title: '@Blocks/CommonGrid',
8
8
  };
9
- export var LoadingState = function () { return (_jsx(LinguiContainer, { children: _jsx(CommonGrid, { columnsDefinitions: columnDefinitions, rowsData: createRandomData(10), gridSelectors: gridSelectors, gridActions: gridDummyActions, isLoading: true, hideColumnConfig: true }) })); };
9
+ export var LoadingState = function () { return (_jsx(LinguiContainer, { children: _jsx(CommonGrid, { columnsDefinitions: columnDefinitions, rowsData: createRandomData(10), gridSelectors: gridSelectors, gridActions: gridDummyActions, isLoading: true }) })); };
10
10
  LoadingState.story = {
11
11
  name: 'Loading state',
12
12
  };
@@ -6,7 +6,7 @@ import { LinguiContainer } from '../utils/linguiContainer';
6
6
  export default {
7
7
  title: '@Blocks/CommonGrid',
8
8
  };
9
- export var ManyColumnsNoScrollLayout = function () { return (_jsx(LinguiContainer, { children: _jsx(CommonGrid, { rowsData: createOversizedRandomData(5), columnsDefinitions: oversizedColumnDefinition, columnLayout: "no-scroll", hideColumnConfig: true, gridSelectors: gridSelectors, gridActions: gridDummyActions }) })); };
9
+ export var ManyColumnsNoScrollLayout = function () { return (_jsx(LinguiContainer, { children: _jsx(CommonGrid, { rowsData: createOversizedRandomData(5), columnsDefinitions: oversizedColumnDefinition, columnLayout: "no-scroll", gridSelectors: gridSelectors, gridActions: gridDummyActions }) })); };
10
10
  ManyColumnsNoScrollLayout.story = {
11
11
  name: 'many columns no-scroll layout',
12
12
  };
@@ -6,7 +6,7 @@ import { LinguiContainer } from '../utils/linguiContainer';
6
6
  export default {
7
7
  title: '@Blocks/CommonGrid',
8
8
  };
9
- export var ManyColumnsNormalLayoutANoControls = function () { return (_jsx(LinguiContainer, { children: _jsx(CommonGrid, { rowsData: createOversizedRandomData(5), columnsDefinitions: oversizedColumnDefinition, hideColumnConfig: true, gridSelectors: gridSelectors, gridActions: gridDummyActions }) })); };
9
+ export var ManyColumnsNormalLayoutANoControls = function () { return (_jsx(LinguiContainer, { children: _jsx(CommonGrid, { rowsData: createOversizedRandomData(5), columnsDefinitions: oversizedColumnDefinition, gridSelectors: gridSelectors, gridActions: gridDummyActions }) })); };
10
10
  ManyColumnsNormalLayoutANoControls.story = {
11
11
  name: 'many columns normal layout a no controls',
12
12
  };
@@ -8,7 +8,7 @@ export default {
8
8
  title: '@Blocks/CommonGrid',
9
9
  };
10
10
  export var WithCustomGridActions = function () {
11
- return (_jsx(LinguiContainer, { children: _jsx(CommonGrid, { columnsDefinitions: columnDefinitions, rowsData: createRandomData(10), onRowAction: onRowAction, gridSelectors: gridSelectors, gridActions: gridDummyActions, hideColumnConfig: true }) }));
11
+ return (_jsx(LinguiContainer, { children: _jsx(CommonGrid, { columnsDefinitions: columnDefinitions, rowsData: createRandomData(10), onRowAction: onRowAction, gridSelectors: gridSelectors, gridActions: gridDummyActions }) }));
12
12
  };
13
13
  WithCustomGridActions.story = {
14
14
  name: 'With custom grid actions',
@@ -255,7 +255,6 @@ export type CommonGridProps<TData extends RowProps = RowProps> = {
255
255
  onBatchAction?: OnBatchActionFn;
256
256
  columnLayout?: ColumnLayout;
257
257
  confirmOnReset?: () => boolean;
258
- hideColumnConfig?: boolean;
259
258
  className?: string;
260
259
  gridRef?: React.MutableRefObject<HTMLElement>;
261
260
  minColumnWidth?: number;
@@ -299,7 +298,7 @@ export type GridProps = Omit<CommonGridProps, 'filters'> & {
299
298
  queryRowsParam?: number | string;
300
299
  customPaginationHandler?: (page: number, rows: number) => void;
301
300
  };
302
- export type PageGridProps = Omit<GridProps, 'rowsData' | 'totalRowsCount' | 'columnsDefinitions' | 'actionColumnDefinition' | 'hideColumnConfig' | 'minColumnWidth' | 'columnLayout'>;
301
+ export type PageGridProps = Omit<GridProps, 'rowsData' | 'totalRowsCount' | 'columnsDefinitions' | 'actionColumnDefinition' | 'minColumnWidth' | 'columnLayout'>;
303
302
  export type Item = {
304
303
  label: string | JSX.Element;
305
304
  value: string;
@@ -18,3 +18,4 @@ export declare const getStickyCollClassNames: (sticky: boolean, stickTo?: StickT
18
18
  export declare const GRID_MIN_ROWS = 6;
19
19
  export declare const rowHeight = 40;
20
20
  export declare const getFilters: (optimizeFilters: boolean) => FiltersConfig;
21
+ export declare const checksColumnsOrder: (colsOrder: string[], columnsDefinitions: ColumnDefinition[]) => void;
@@ -77,3 +77,16 @@ export var getFilters = function (optimizeFilters) {
77
77
  filters.text.defaultExtraProps = { defaultComparator: 'eq' };
78
78
  return filters;
79
79
  };
80
+ export var checksColumnsOrder = function (colsOrder, columnsDefinitions) {
81
+ var stickyRightColls = columnsDefinitions.filter(function (col) { return col.sticky === true && col.stickTo === 'right'; });
82
+ var stickyLeftColls = columnsDefinitions.filter(function (col) { return col.sticky === true && col.stickTo !== 'right'; });
83
+ if (stickyLeftColls.length > 1 || stickyRightColls.length > 1) {
84
+ console.error('Grid can have only sticky column on each side.');
85
+ }
86
+ if (stickyLeftColls.length && colsOrder.indexOf(stickyLeftColls[0].name) !== 0) {
87
+ console.error('The left sticky column should be the first one in a row');
88
+ }
89
+ if (stickyRightColls.length && colsOrder.indexOf(stickyRightColls[0].name) !== colsOrder.length - 1) {
90
+ console.error('The Right sticky column should be the last one in a row');
91
+ }
92
+ };
@@ -2,7 +2,7 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
2
  import { memo, useCallback, useMemo, useEffect } from 'react';
3
3
  import { Icon, Cancel } from '../../Elements/Icon';
4
4
  import { H2, H5 } from '../../Elements/Typography';
5
- import { DialogOverlay, DialogWindow, HeaderContainer, ButtonsContainer, ContentContainer, TitleContainer, CloseButton, } from './styles';
5
+ import { DialogOverlay, DialogWindow, HeaderContainer, ButtonsContainer, ContentContainer, TitleContainer, CloseButton, ButtonsWrapper, } from './styles';
6
6
  import { x } from '@xstyled/styled-components';
7
7
  import { Button } from '../../Elements/Button';
8
8
  import { Portal } from '../../Elements/Portal';
@@ -32,5 +32,5 @@ export var Modal = memo(function (_a) {
32
32
  if (!isShown) {
33
33
  return null;
34
34
  }
35
- return (_jsx(Portal, { children: _jsx(DialogOverlay, { backgroundColor: overlayColor, children: _jsxs(DialogWindow, { ref: dialogRef, style: dialogStyle, "$backgroundColor": background, top: top, "data-cy": "dialogWindow", onClick: closeEverywhere ? closeDialog : undefined, "$minWidth": minWidth, "$minHeight": minHeight, "$maxWidth": maxWidth, "$maxHeight": maxHeight, variant: variant, children: [title && hasHeader && (_jsx(HeaderContainer, { variant: variant, children: _jsxs(TitleContainer, { children: [titleIcon && (_jsx(x.div, { as: "span", className: "icon", children: typeof titleIcon === 'string' ? _jsx(Icon, { icon: titleIcon, fill: "blue2" }) : titleIcon })), variant == 'default' ? (_jsx(H2, { mt: 0, mb: 0, variant: "bold", children: title })) : (_jsx(H5, { mt: 0, mb: 0, variant: "bold", children: title }))] }) })), withCloseIcon && (_jsx(CloseButton, { onClick: closeDialog, "data-cy": "dialogCloseBtn", children: _jsx(Cancel, { width: "11px", height: "11px" }) })), _jsx(ContentContainer, { variant: variant, children: children }), hasFooter && (onExtraAction || onCancel || onConfirm) && (_jsxs(ButtonsContainer, { hasSpaceBetween: !!onExtraAction, children: [onExtraAction && (_jsx(Button, { type: "button", onClick: onExtraAction, isLoading: isLoading, "data-cy": "extraActionBtn", appearance: "ghostDanger", children: extraActionLabel })), _jsxs(x.div, { children: [onCancel && (_jsx(Button, { type: "button", onClick: onCancel, isLoading: isLoading, "data-cy": "cancelBtn", appearance: "primaryLight", children: cancelLabel ? cancelLabel : 'Cancel' })), onConfirm && (_jsx(Button, { type: "button", onClick: onDialogConfirmClick, isLoading: isLoading, disabled: isConfirmDisabled, "data-cy": "submitBtn", children: confirmLabel ? confirmLabel : 'Submit' }))] })] }))] }) }) }));
35
+ return (_jsx(Portal, { children: _jsx(DialogOverlay, { backgroundColor: overlayColor, children: _jsxs(DialogWindow, { ref: dialogRef, style: dialogStyle, "$backgroundColor": background, top: top, "data-cy": "dialogWindow", onClick: closeEverywhere ? closeDialog : undefined, "$minWidth": minWidth, "$minHeight": minHeight, "$maxWidth": maxWidth, "$maxHeight": maxHeight, variant: variant, children: [title && hasHeader && (_jsx(HeaderContainer, { variant: variant, children: _jsxs(TitleContainer, { children: [titleIcon && (_jsx(x.div, { as: "span", className: "icon", children: typeof titleIcon === 'string' ? _jsx(Icon, { icon: titleIcon, fill: "blue2" }) : titleIcon })), variant == 'default' ? (_jsx(H2, { mt: 0, mb: 0, variant: "bold", children: title })) : (_jsx(H5, { mt: 0, mb: 0, variant: "bold", children: title }))] }) })), withCloseIcon && (_jsx(CloseButton, { onClick: closeDialog, "data-cy": "dialogCloseBtn", children: _jsx(Cancel, { width: "11px", height: "11px" }) })), _jsx(ContentContainer, { variant: variant, children: children }), hasFooter && (onExtraAction || onCancel || onConfirm) && (_jsxs(ButtonsContainer, { hasSpaceBetween: !!onExtraAction, children: [onExtraAction && (_jsx(Button, { type: "button", onClick: onExtraAction, isLoading: isLoading, "data-cy": "extraActionBtn", appearance: "ghostDanger", children: extraActionLabel })), _jsxs(ButtonsWrapper, { hasExtraAction: !!onExtraAction, hasBothButtons: !!onCancel && !!onConfirm, children: [onCancel && (_jsx(Button, { type: "button", onClick: onCancel, isLoading: isLoading, "data-cy": "cancelBtn", appearance: "primaryLight", children: cancelLabel ? cancelLabel : 'Cancel' })), onConfirm && (_jsx(Button, { type: "button", onClick: onDialogConfirmClick, isLoading: isLoading, disabled: isConfirmDisabled, "data-cy": "submitBtn", children: confirmLabel ? confirmLabel : 'Submit' }))] })] }))] }) }) }));
36
36
  });
@@ -32,7 +32,7 @@ export var ModalTopPosition = {
32
32
  title: 'Modal default version',
33
33
  children: _jsx(_Fragment, { children: "Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed condimentum id eros ac consequat." }),
34
34
  variant: 'default',
35
- top: '0'
35
+ top: '0',
36
36
  },
37
37
  };
38
38
  export var ModalWithCloseAndConfirmBtns = {
@@ -40,6 +40,10 @@ export var ModalWithCloseAndConfirmBtns = {
40
40
  children: _jsx(_Fragment, { children: "Modal with narrow width" }),
41
41
  title: 'Modal title',
42
42
  width: 'narrow',
43
+ withCloseIcon: true,
44
+ onCancel: function () { return console.log('Cancel'); },
45
+ onConfirm: function () { return console.log('Confirm'); },
46
+ onExtraAction: undefined,
43
47
  },
44
48
  };
45
49
  export var ModalWithoutCloseButton = {
@@ -21,4 +21,8 @@ export declare const TitleContainer: import("styled-components").StyledComponent
21
21
  export declare const ButtonsContainer: import("styled-components").StyledComponent<"div", import("@xstyled/system").Theme, {
22
22
  hasSpaceBetween: boolean;
23
23
  }, never>;
24
+ export declare const ButtonsWrapper: import("styled-components").StyledComponent<"div", import("@xstyled/system").Theme, {
25
+ hasExtraAction: boolean;
26
+ hasBothButtons: boolean;
27
+ }, never>;
24
28
  export declare const CloseButton: import("styled-components").StyledComponent<"div", import("@xstyled/system").Theme, {}, never>;
@@ -67,9 +67,16 @@ export var ContentContainer = styled.div(templateObject_13 || (templateObject_13
67
67
  return variantStyles(Component.ContentContainer, variant);
68
68
  });
69
69
  export var TitleContainer = styled.div(templateObject_14 || (templateObject_14 = __makeTemplateObject(["\n display: flex;\n flex-flow: row;\n align-items: center;\n color: typoPrimary;\n padding-right: 34px;\n\n > div:first-of-type {\n margin-right: 0.5em;\n display: block;\n }\n\n .icon {\n font-size: 24px;\n margin-right: 15px;\n display: flex;\n\n @media (max-width: 576px) {\n font-size: 18px;\n margin-right: 12px;\n }\n }\n"], ["\n display: flex;\n flex-flow: row;\n align-items: center;\n color: typoPrimary;\n padding-right: 34px;\n\n > div:first-of-type {\n margin-right: 0.5em;\n display: block;\n }\n\n .icon {\n font-size: 24px;\n margin-right: 15px;\n display: flex;\n\n @media (max-width: 576px) {\n font-size: 18px;\n margin-right: 12px;\n }\n }\n"])));
70
- export var ButtonsContainer = styled.div(templateObject_15 || (templateObject_15 = __makeTemplateObject(["\n display: flex;\n align-items: center;\n padding: 1.5rem;\n border-top: 1px solid ", ";\n text-align: right;\n justify-content: ", ";\n > div > * {\n margin: 0 0.5em;\n }\n\n @media (max-width: 576px) {\n display: flex;\n justify-content: space-around;\n padding: 32px 18px 18px;\n\n > * {\n margin: 0;\n }\n }\n"], ["\n display: flex;\n align-items: center;\n padding: 1.5rem;\n border-top: 1px solid ", ";\n text-align: right;\n justify-content: ", ";\n > div > * {\n margin: 0 0.5em;\n }\n\n @media (max-width: 576px) {\n display: flex;\n justify-content: space-around;\n padding: 32px 18px 18px;\n\n > * {\n margin: 0;\n }\n }\n"])), th.color('lightGray6'), function (_a) {
70
+ export var ButtonsContainer = styled.div(templateObject_15 || (templateObject_15 = __makeTemplateObject(["\n display: flex;\n align-items: center;\n padding: 1.5rem;\n border-top: 1px solid ", ";\n text-align: right;\n justify-content: ", ";\n\n @media (max-width: 576px) {\n display: flex;\n justify-content: space-around;\n padding: 32px 18px 18px;\n\n > * {\n margin: 0;\n }\n }\n"], ["\n display: flex;\n align-items: center;\n padding: 1.5rem;\n border-top: 1px solid ", ";\n text-align: right;\n justify-content: ", ";\n\n @media (max-width: 576px) {\n display: flex;\n justify-content: space-around;\n padding: 32px 18px 18px;\n\n > * {\n margin: 0;\n }\n }\n"])), th.color('lightGray6'), function (_a) {
71
71
  var hasSpaceBetween = _a.hasSpaceBetween;
72
72
  return (hasSpaceBetween ? 'space-between' : 'flex-end');
73
73
  });
74
- export var CloseButton = styled.div(templateObject_16 || (templateObject_16 = __makeTemplateObject(["\n position: absolute;\n z-index: 2;\n background-color: bgLightGray1;\n cursor: pointer;\n display: flex;\n align-items: center;\n justify-content: center;\n border-radius: 50%;\n top: 11px;\n right: 20px;\n width: 34px;\n height: 34px;\n"], ["\n position: absolute;\n z-index: 2;\n background-color: bgLightGray1;\n cursor: pointer;\n display: flex;\n align-items: center;\n justify-content: center;\n border-radius: 50%;\n top: 11px;\n right: 20px;\n width: 34px;\n height: 34px;\n"])));
75
- var templateObject_1, templateObject_2, templateObject_3, templateObject_4, templateObject_5, templateObject_6, templateObject_7, templateObject_8, templateObject_9, templateObject_10, templateObject_11, templateObject_12, templateObject_13, templateObject_14, templateObject_15, templateObject_16;
74
+ export var ButtonsWrapper = styled.div(templateObject_16 || (templateObject_16 = __makeTemplateObject(["\n width: ", ";\n display: flex;\n justify-content: inherit;\n column-gap: 8px;\n\n @media (max-width: 576px) {\n & > button {\n width: ", ";\n }\n }\n"], ["\n width: ", ";\n display: flex;\n justify-content: inherit;\n column-gap: 8px;\n\n @media (max-width: 576px) {\n & > button {\n width: ", ";\n }\n }\n"])), function (_a) {
75
+ var hasExtraAction = _a.hasExtraAction;
76
+ return (hasExtraAction ? 'auto' : '100%');
77
+ }, function (_a) {
78
+ var hasBothButtons = _a.hasBothButtons;
79
+ return (hasBothButtons ? '50%' : 'auto');
80
+ });
81
+ export var CloseButton = styled.div(templateObject_17 || (templateObject_17 = __makeTemplateObject(["\n position: absolute;\n z-index: 2;\n background-color: bgLightGray1;\n cursor: pointer;\n display: flex;\n align-items: center;\n justify-content: center;\n border-radius: 50%;\n top: 11px;\n right: 20px;\n width: 34px;\n height: 34px;\n"], ["\n position: absolute;\n z-index: 2;\n background-color: bgLightGray1;\n cursor: pointer;\n display: flex;\n align-items: center;\n justify-content: center;\n border-radius: 50%;\n top: 11px;\n right: 20px;\n width: 34px;\n height: 34px;\n"])));
82
+ var templateObject_1, templateObject_2, templateObject_3, templateObject_4, templateObject_5, templateObject_6, templateObject_7, templateObject_8, templateObject_9, templateObject_10, templateObject_11, templateObject_12, templateObject_13, templateObject_14, templateObject_15, templateObject_16, templateObject_17;
@@ -5,11 +5,11 @@ import { Text } from '../../Elements/Text';
5
5
  import { Icon } from '../../Elements/Icon';
6
6
  var Tab = function (_a) {
7
7
  var tabDefinition = _a.tabDefinition, value = _a.value, isActive = _a.isActive, onTabSwitch = _a.onTabSwitch;
8
- var icon = tabDefinition.icon, label = tabDefinition.label, badgeCount = tabDefinition.badgeCount;
8
+ var icon = tabDefinition.icon, label = tabDefinition.label, badgeCount = tabDefinition.badgeCount, disabled = tabDefinition.disabled;
9
9
  var handleOnClick = useCallback(function () {
10
10
  onTabSwitch(value);
11
11
  }, [onTabSwitch, value]);
12
- return (_jsx(StyledTabWrapper, { children: _jsxs(StyledTab, { onClick: handleOnClick, active: isActive, children: [icon && (_jsx(StyledImageBox, { children: _jsx(Icon, { icon: icon }) })), _jsx(Text, { children: label }), isActive && badgeCount && badgeCount > 0 && (_jsx(RoundedWrap, { children: _jsx(Text, { variant: "medium", children: badgeCount }) }))] }) }));
12
+ return (_jsx(StyledTabWrapper, { children: _jsxs(StyledTab, { onClick: !disabled ? handleOnClick : undefined, active: isActive, disabled: disabled, children: [icon && (_jsx(StyledImageBox, { children: _jsx(Icon, { icon: icon }) })), _jsx(Text, { children: label }), isActive && badgeCount && badgeCount > 0 && (_jsx(RoundedWrap, { children: _jsx(Text, { variant: "medium", children: badgeCount }) }))] }) }));
13
13
  };
14
14
  export var Tabs = function (_a) {
15
15
  var tabsDefinition = _a.tabsDefinition, activeTab = _a.activeTab, onTabSwitch = _a.onTabSwitch, mb = _a.mb;
@@ -4,6 +4,7 @@ export declare const StyledTabWrapper: import("styled-components").StyledCompone
4
4
  export declare const RoundedWrap: import("styled-components").StyledComponent<"div", import("@xstyled/system").Theme, {}, never>;
5
5
  export declare const Tab: import("styled-components").StyledComponent<"div", import("@xstyled/system").Theme, {
6
6
  active: boolean;
7
+ disabled?: boolean | undefined;
7
8
  }, never>;
8
9
  export declare const TabPanel: import("styled-components").StyledComponent<"div", import("@xstyled/system").Theme, {
9
10
  $mb?: string | undefined;
@@ -7,7 +7,10 @@ export var StyledImageBox = styled(x.div)(templateObject_1 || (templateObject_1
7
7
  export var StyledTabWrapper = styled.div(templateObject_2 || (templateObject_2 = __makeTemplateObject(["\n display: flex;\n flex-direction: row;\n align-items: baseline;\n"], ["\n display: flex;\n flex-direction: row;\n align-items: baseline;\n"])));
8
8
  export var RoundedWrap = styled.div(templateObject_3 || (templateObject_3 = __makeTemplateObject(["\n display: flex !important;\n justify-content: center;\n align-items: center;\n height: 23px;\n background-color: ", ";\n border-radius: 29px;\n padding: 3px 10px;\n margin-left: 8px;\n"], ["\n display: flex !important;\n justify-content: center;\n align-items: center;\n height: 23px;\n background-color: ", ";\n border-radius: 29px;\n padding: 3px 10px;\n margin-left: 8px;\n"])), th.color('lightGray7'));
9
9
  var activeTab = css(templateObject_4 || (templateObject_4 = __makeTemplateObject(["\n color: ", ";\n position: relative;\n &:after {\n content: '';\n position: absolute;\n bottom: 2;\n left: 0;\n right: 0;\n background-color: ", ";\n height: 4px;\n border-radius: 6px 6px 0px 0px;\n }\n & > div {\n display: inline;\n color: ", ";\n }\n"], ["\n color: ", ";\n position: relative;\n &:after {\n content: '';\n position: absolute;\n bottom: 2;\n left: 0;\n right: 0;\n background-color: ", ";\n height: 4px;\n border-radius: 6px 6px 0px 0px;\n }\n & > div {\n display: inline;\n color: ", ";\n }\n"])), th.color('red1'), th.color('red1'), th.color('typoPrimary'));
10
- export var Tab = styled.div(templateObject_5 || (templateObject_5 = __makeTemplateObject(["\n display: inline-flex;\n align-items: center;\n justify-content: center;\n cursor: pointer;\n padding: 0.6rem;\n transition: 200ms;\n color: ", ";\n font-weight: bold;\n font-size: 14px;\n height: 46px;\n letter-spacing: 0.03em;\n margin-top: 10px;\n min-width: 120px;\n & > div {\n display: none;\n }\n &:not(:last-child) {\n margin-right: 0.5rem;\n }\n\n :hover {\n color: ", ";\n }\n\n :active {\n ", "\n }\n\n ", "\n"], ["\n display: inline-flex;\n align-items: center;\n justify-content: center;\n cursor: pointer;\n padding: 0.6rem;\n transition: 200ms;\n color: ", ";\n font-weight: bold;\n font-size: 14px;\n height: 46px;\n letter-spacing: 0.03em;\n margin-top: 10px;\n min-width: 120px;\n & > div {\n display: none;\n }\n &:not(:last-child) {\n margin-right: 0.5rem;\n }\n\n :hover {\n color: ", ";\n }\n\n :active {\n ", "\n }\n\n ", "\n"])), th.color('gray'), th.color('typoPrimary'), activeTab, function (_a) {
10
+ export var Tab = styled.div(templateObject_5 || (templateObject_5 = __makeTemplateObject(["\n display: inline-flex;\n align-items: center;\n justify-content: center;\n cursor: pointer;\n padding: 0.6rem;\n transition: 200ms;\n color: ", ";\n font-weight: bold;\n font-size: 14px;\n height: 46px;\n letter-spacing: 0.03em;\n margin-top: 10px;\n min-width: 120px;\n & > div {\n display: none;\n }\n &:not(:last-child) {\n margin-right: 0.5rem;\n }\n\n :hover {\n color: ", ";\n }\n\n :active {\n ", "\n }\n\n ", "\n"], ["\n display: inline-flex;\n align-items: center;\n justify-content: center;\n cursor: pointer;\n padding: 0.6rem;\n transition: 200ms;\n color: ", ";\n font-weight: bold;\n font-size: 14px;\n height: 46px;\n letter-spacing: 0.03em;\n margin-top: 10px;\n min-width: 120px;\n & > div {\n display: none;\n }\n &:not(:last-child) {\n margin-right: 0.5rem;\n }\n\n :hover {\n color: ", ";\n }\n\n :active {\n ", "\n }\n\n ", "\n"])), th.color('gray'), th.color('typoPrimary'), function (_a) {
11
+ var disabled = _a.disabled;
12
+ return !disabled && activeTab;
13
+ }, function (_a) {
11
14
  var active = _a.active;
12
15
  return (active ? activeTab : '');
13
16
  });
@@ -4,6 +4,7 @@ export type TabDefinition = {
4
4
  icon?: string;
5
5
  badgeCount?: number;
6
6
  default?: true;
7
+ disabled?: boolean;
7
8
  };
8
9
  export type TabsProps = {
9
10
  tabsDefinition: TabDefinition[];
@@ -11,7 +11,7 @@ var ErrorWrap = styled.div(templateObject_2 || (templateObject_2 = __makeTemplat
11
11
  var StyledWrapper = styled.div(templateObject_3 || (templateObject_3 = __makeTemplateObject(["\n .inline {\n margin-top: 1;\n svg {\n margin-right: 2;\n }\n }\n .tooltip {\n ", "\n svg {\n position: absolute;\n top: 0;\n right: 0;\n }\n }\n"], ["\n .inline {\n margin-top: 1;\n svg {\n margin-right: 2;\n }\n }\n .tooltip {\n ", "\n svg {\n position: absolute;\n top: 0;\n right: 0;\n }\n }\n"])), tooltip);
12
12
  var ErrorMessage = function (_a) {
13
13
  var children = _a.children, appearance = _a.appearance;
14
- return (_jsx(StyledWrapper, { children: _jsxs(ErrorWrap, { className: appearance, children: [_jsx(Icon, { icon: "danger" }), _jsx("span", { children: children })] }) }));
14
+ return (_jsx(StyledWrapper, { children: _jsxs(ErrorWrap, { className: appearance, children: [_jsx(Icon, { icon: "deleteX" }), _jsx("span", { children: children })] }) }));
15
15
  };
16
16
  export default ErrorMessage;
17
17
  var templateObject_1, templateObject_2, templateObject_3;
@@ -1,6 +1,6 @@
1
- /// <reference types="react" />
1
+ import { ReactNode } from 'react';
2
2
  export type TextProps = {
3
- children?: string | number | JSX.Element | (JSX.Element | undefined)[];
3
+ children?: ReactNode | ReactNode[];
4
4
  fontSize?: number;
5
5
  fontWeight?: string;
6
6
  variant?: 'normal' | 'medium' | 'semiBold' | 'bold';
@@ -1,11 +1,12 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { memo } from 'react';
2
+ import { memo, useId } from 'react';
3
3
  import { CheckboxWrap, CheckIcon, FakeInput, Label } from './styles';
4
4
  import { th, useTheme } from '@xstyled/styled-components';
5
5
  var Checkbox = function (_a) {
6
6
  var name = _a.name, label = _a.label, onChange = _a.onChange, checked = _a.checked, defaultChecked = _a.defaultChecked, _b = _a.size, size = _b === void 0 ? 4 : _b, className = _a.className, disabled = _a.disabled, inputRef = _a.inputRef, readOnly = _a.readOnly, _c = _a.minusIcon, minusIcon = _c === void 0 ? false : _c;
7
7
  var theme = useTheme();
8
8
  var themeSize = th.fontSize(size)({ theme: theme });
9
- return (_jsxs(CheckboxWrap, { size: themeSize, className: className, children: [_jsx("input", { type: "checkbox", ref: inputRef, name: name, checked: checked, defaultChecked: defaultChecked, disabled: disabled, onChange: onChange, value: "", readOnly: readOnly, "data-cy": name && "".concat(name, "Checkbox") }), _jsx(FakeInput, { size: themeSize, children: _jsx(CheckIcon, { icon: minusIcon ? 'minus' : 'check', size: themeSize }) }), label && _jsx(Label, { children: label })] }));
9
+ var id = useId();
10
+ return (_jsxs(CheckboxWrap, { size: themeSize, className: className, children: [_jsx("input", { type: "checkbox", ref: inputRef, name: name, checked: checked, defaultChecked: defaultChecked, disabled: disabled, onChange: onChange, value: "", readOnly: readOnly, "data-cy": name && "".concat(name, "Checkbox"), id: id }), _jsx(FakeInput, { size: themeSize, children: _jsx(CheckIcon, { icon: minusIcon ? 'minus' : 'check', size: themeSize }) }), label && _jsx(Label, { htmlFor: id, children: label })] }));
10
11
  };
11
12
  export default memo(Checkbox);
@@ -9,7 +9,7 @@ export default meta;
9
9
  export var CheckboxChecked = {
10
10
  args: {
11
11
  checked: true,
12
- onChange: function () { },
12
+ onChange: function () { return console.log('Clicked'); },
13
13
  label: 'Checked',
14
14
  },
15
15
  };
@@ -8,4 +8,4 @@ export declare const CheckIcon: import("styled-components").StyledComponent<({ i
8
8
  export declare const CheckboxWrap: import("styled-components").StyledComponent<"div", import("@xstyled/system").Theme, {
9
9
  size: string | number;
10
10
  }, never>;
11
- export declare const Label: import("styled-components").StyledComponent<"span", import("@xstyled/system").Theme, {}, never>;
11
+ export declare const Label: import("styled-components").StyledComponent<"label", import("@xstyled/system").Theme, {}, never>;
@@ -22,5 +22,5 @@ export var CheckboxWrap = styled.div(templateObject_3 || (templateObject_3 = __m
22
22
  var size = _a.size;
23
23
  return size;
24
24
  });
25
- export var Label = styled.span(templateObject_4 || (templateObject_4 = __makeTemplateObject(["\n margin: 0;\n margin-left: 8px;\n font-size: 14px;\n"], ["\n margin: 0;\n margin-left: 8px;\n font-size: 14px;\n"])));
25
+ export var Label = styled.label(templateObject_4 || (templateObject_4 = __makeTemplateObject(["\n margin: 0;\n margin-left: 8px;\n font-size: 14px;\n"], ["\n margin: 0;\n margin-left: 8px;\n font-size: 14px;\n"])));
26
26
  var templateObject_1, templateObject_2, templateObject_3, templateObject_4;
@@ -22,8 +22,11 @@ var __rest = (this && this.__rest) || function (s, e) {
22
22
  };
23
23
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
24
24
  import { CenterDot, Item, Label, PaintoverLayer, StyledRadio, Wrapper } from './styles';
25
+ import { useId } from 'react';
25
26
  var RadioButton = function (_a) {
26
27
  var label = _a.label, id = _a.id, name = _a.name, _b = _a.disabled, disabled = _b === void 0 ? false : _b, onChange = _a.onChange, rest = __rest(_a, ["label", "id", "name", "disabled", "onChange"]);
27
- return (_jsxs(Wrapper, { children: [_jsxs(Item, { children: [_jsx(StyledRadio, __assign({ type: "radio", id: id, name: name, disabled: disabled, onChange: onChange }, rest)), _jsx(PaintoverLayer, { disabled: disabled, children: _jsx(CenterDot, {}) })] }), label && _jsx(Label, { children: label })] }));
28
+ var customId = useId();
29
+ var inputId = id || customId;
30
+ return (_jsxs(Wrapper, { children: [_jsxs(Item, { children: [_jsx(StyledRadio, __assign({ type: "radio", id: inputId, name: name, disabled: disabled, onChange: onChange }, rest)), _jsx(PaintoverLayer, { disabled: disabled, children: _jsx(CenterDot, {}) })] }), label && _jsx(Label, { htmlFor: inputId, children: label })] }));
28
31
  };
29
32
  export default RadioButton;
@@ -7,4 +7,4 @@ export declare const CenterDot: import("styled-components").StyledComponent<"spa
7
7
  export declare const StyledRadio: import("styled-components").StyledComponent<"input", import("@xstyled/system").Theme, {
8
8
  disabled: boolean;
9
9
  }, never>;
10
- export declare const Label: import("styled-components").StyledComponent<"span", import("@xstyled/system").Theme, {}, never>;
10
+ export declare const Label: import("styled-components").StyledComponent<"label", import("@xstyled/system").Theme, {}, never>;
@@ -11,5 +11,5 @@ export var StyledRadio = styled.input(templateObject_5 || (templateObject_5 = __
11
11
  var disabled = _a.disabled;
12
12
  return (disabled ? 'default' : 'pointer');
13
13
  });
14
- export var Label = styled.span(templateObject_6 || (templateObject_6 = __makeTemplateObject(["\n margin: 0;\n margin-left: 8px;\n font-size: 14px;\n"], ["\n margin: 0;\n margin-left: 8px;\n font-size: 14px;\n"])));
14
+ export var Label = styled.label(templateObject_6 || (templateObject_6 = __makeTemplateObject(["\n margin: 0;\n margin-left: 8px;\n font-size: 14px;\n"], ["\n margin: 0;\n margin-left: 8px;\n font-size: 14px;\n"])));
15
15
  var templateObject_1, templateObject_2, templateObject_3, templateObject_4, templateObject_5, templateObject_6;
package/ui/index.d.ts CHANGED
@@ -18,7 +18,6 @@ import Line from './Elements/Line';
18
18
  import Link from './Elements/Link';
19
19
  import Logo from './Elements/Logo';
20
20
  import Pagination from './Elements/Pagination';
21
- import Paragraph from './Elements/Paragraph';
22
21
  import Portal from './Elements/Portal';
23
22
  import ProgressBar from './Elements/ProgressBar';
24
23
  import SimpleLink from './Elements/SimpleLink';
@@ -41,7 +40,7 @@ import MultiSelect from './Elements/MultiSelect';
41
40
  import Select from './Elements/Select';
42
41
  import DropdownSelect from './Elements/DropdownSelect';
43
42
  import TextArea from './Forms/TextArea';
44
- export { DropdownSelect, DatePicker, CommonGrid, Popover, SingleSelect, MultiSelect, Select, Card, CornerDialog, ImageList, LightBox, Modal, Tabs, Alert, Avatar, Badge, BorderedBox, Button, Dropdown, ErrorMessage, Icon, Image, Label, Line, Link, Logo, Pagination, Paragraph, Portal, ProgressBar, SimpleLink, SpaceAround, Spinner, Tag, Toast, Toggle, Typography, Checkbox, Input, RadioButton, ThemeProvider, utils, TextArea, };
43
+ export { DropdownSelect, DatePicker, CommonGrid, Popover, SingleSelect, MultiSelect, Select, Card, CornerDialog, ImageList, LightBox, Modal, Tabs, Alert, Avatar, Badge, BorderedBox, Button, Dropdown, ErrorMessage, Icon, Image, Label, Line, Link, Logo, Pagination, Portal, ProgressBar, SimpleLink, SpaceAround, Spinner, Tag, Toast, Toggle, Typography, Checkbox, Input, RadioButton, ThemeProvider, utils, TextArea, };
45
44
  export * from './Blocks/CornerDialog';
46
45
  export * from './Blocks/ImageList';
47
46
  export * from './Blocks/LightBox';
@@ -62,7 +61,6 @@ export * from './Elements/Line';
62
61
  export * from './Elements/Link';
63
62
  export * from './Elements/Logo';
64
63
  export * from './Elements/Pagination';
65
- export * from './Elements/Paragraph';
66
64
  export * from './Elements/Portal';
67
65
  export * from './Elements/ProgressBar';
68
66
  export * from './Elements/SimpleLink';