@tap-payments/os-micro-frontend-shared 0.1.376-test.1 → 0.1.376-test.1-test.2

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 (68) hide show
  1. package/build/components/FilterDropdown/FilterDropdown.d.ts +4 -11
  2. package/build/components/FilterDropdown/FilterDropdown.js +4 -18
  3. package/build/components/FilterDropdown/style.js +1 -1
  4. package/build/components/RangeCalender/RangeCalender.js +2 -4
  5. package/build/components/TableHeader/FiltersRow.d.ts +1 -1
  6. package/build/components/TableHeader/FiltersRow.js +4 -2
  7. package/build/components/TableHeader/TableHeader.d.ts +1 -1
  8. package/build/components/TableHeader/TableHeader.js +2 -2
  9. package/build/components/TableHeader/TableView/CreateViewDialog.d.ts +3 -0
  10. package/build/components/TableHeader/TableView/CreateViewDialog.js +91 -0
  11. package/build/components/TableHeader/TableView/CustomViews.js +1 -1
  12. package/build/components/TableHeader/TableView/TableView.js +0 -1
  13. package/build/components/TableHeader/TableView/ViewSelector.d.ts +5 -0
  14. package/build/components/TableHeader/TableView/ViewSelector.js +81 -0
  15. package/build/components/TableHeader/TableView/ViewsDropdown.d.ts +5 -0
  16. package/build/components/TableHeader/TableView/ViewsDropdown.js +198 -0
  17. package/build/components/TableHeader/TableView/components/ColumnList.d.ts +3 -0
  18. package/build/components/TableHeader/TableView/components/ColumnList.js +70 -0
  19. package/build/components/TableHeader/TableView/components/ViewsSubmenu.d.ts +3 -0
  20. package/build/components/TableHeader/TableView/components/ViewsSubmenu.js +71 -0
  21. package/build/components/TableHeader/TableView/components/index.d.ts +2 -0
  22. package/build/components/TableHeader/TableView/components/index.js +2 -0
  23. package/build/components/TableHeader/TableView/constants.d.ts +10 -0
  24. package/build/components/TableHeader/TableView/constants.js +10 -0
  25. package/build/components/TableHeader/TableView/data.d.ts +5 -0
  26. package/build/components/TableHeader/TableView/data.js +48 -0
  27. package/build/components/TableHeader/TableView/hooks/index.d.ts +6 -0
  28. package/build/components/TableHeader/TableView/hooks/index.js +6 -0
  29. package/build/components/TableHeader/TableView/hooks/useCreateViewDialog.d.ts +22 -0
  30. package/build/components/TableHeader/TableView/hooks/useCreateViewDialog.js +86 -0
  31. package/build/components/TableHeader/TableView/hooks/useDialogPosition.d.ts +8 -0
  32. package/build/components/TableHeader/TableView/hooks/useDialogPosition.js +16 -0
  33. package/build/components/TableHeader/TableView/hooks/useNestedSubmenu.d.ts +7 -0
  34. package/build/components/TableHeader/TableView/hooks/useNestedSubmenu.js +34 -0
  35. package/build/components/TableHeader/TableView/hooks/useOriginalColumns.d.ts +6 -0
  36. package/build/components/TableHeader/TableView/hooks/useOriginalColumns.js +18 -0
  37. package/build/components/TableHeader/TableView/hooks/useSubmenuHover.d.ts +8 -0
  38. package/build/components/TableHeader/TableView/hooks/useSubmenuHover.js +43 -0
  39. package/build/components/TableHeader/TableView/hooks/useViewSelector.d.ts +50 -0
  40. package/build/components/TableHeader/TableView/hooks/useViewSelector.js +239 -0
  41. package/build/components/TableHeader/TableView/hooks/useViewsManager.d.ts +20 -0
  42. package/build/components/TableHeader/TableView/hooks/useViewsManager.js +96 -0
  43. package/build/components/TableHeader/TableView/index.d.ts +12 -3
  44. package/build/components/TableHeader/TableView/index.js +13 -3
  45. package/build/components/TableHeader/TableView/styles.d.ts +127 -0
  46. package/build/components/TableHeader/TableView/styles.js +426 -0
  47. package/build/components/TableHeader/TableView/types.d.ts +183 -0
  48. package/build/components/TableHeader/TableView/utils.d.ts +121 -0
  49. package/build/components/TableHeader/TableView/utils.js +463 -0
  50. package/build/components/TableHeader/index.d.ts +1 -0
  51. package/build/components/TableHeader/type.d.ts +15 -1
  52. package/build/components/index.d.ts +0 -1
  53. package/build/components/index.js +0 -1
  54. package/build/constants/assets.d.ts +1 -2
  55. package/build/constants/assets.js +1 -2
  56. package/build/types/index.d.ts +0 -1
  57. package/build/types/index.js +0 -1
  58. package/build/utils/date.d.ts +0 -5
  59. package/build/utils/date.js +0 -37
  60. package/package.json +3 -2
  61. package/build/components/MultiDatakeyDonut/MultiDatakeyDonut.d.ts +0 -12
  62. package/build/components/MultiDatakeyDonut/MultiDatakeyDonut.js +0 -19
  63. package/build/components/MultiDatakeyDonut/index.d.ts +0 -1
  64. package/build/components/MultiDatakeyDonut/index.js +0 -1
  65. package/build/components/MultiDatakeyDonut/style.d.ts +0 -10
  66. package/build/components/MultiDatakeyDonut/style.js +0 -23
  67. package/build/types/toggleOptions.d.ts +0 -2
  68. /package/build/{types/toggleOptions.js → components/TableHeader/TableView/types.js} +0 -0
@@ -1,17 +1,10 @@
1
- import { ReactNode } from 'react';
2
- import { BoxProps } from '@mui/material/Box';
3
- import { SxProps } from '@mui/material';
4
- interface FilterDropdownProps extends BoxProps {
1
+ /// <reference types="react" />
2
+ interface FilterDropdownProps {
3
+ children?: React.ReactNode;
5
4
  onConfirm: () => void;
6
5
  onCancel: () => void;
7
6
  isOkayButDisabled?: boolean;
8
7
  isDisabled?: boolean;
9
- icon?: string;
10
- title?: string;
11
- menuStyle?: SxProps;
12
- hideTitle?: boolean;
13
- renderButton?: ReactNode;
14
- onOpenChange?: (isOpen: boolean) => void;
15
8
  }
16
- export default function FilterDropdown({ onConfirm, onCancel, isOkayButDisabled, children, isDisabled, icon, title, menuStyle, hideTitle, renderButton, onOpenChange, ...props }: Readonly<FilterDropdownProps>): import("react/jsx-runtime").JSX.Element;
9
+ export default function FilterDropdown({ onConfirm, onCancel, isOkayButDisabled, children, isDisabled }: Readonly<FilterDropdownProps>): import("react/jsx-runtime").JSX.Element;
17
10
  export {};
@@ -1,24 +1,12 @@
1
- var __rest = (this && this.__rest) || function (s, e) {
2
- var t = {};
3
- for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
4
- t[p] = s[p];
5
- if (s != null && typeof Object.getOwnPropertySymbols === "function")
6
- for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
7
- if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
8
- t[p[i]] = s[p[i]];
9
- }
10
- return t;
11
- };
12
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
13
- import { useState, useEffect } from 'react';
14
2
  import Box from '@mui/material/Box';
15
- import ClickAwayListener from '@mui/material/ClickAwayListener';
16
3
  import { useTranslation } from 'react-i18next';
4
+ import { useState, useEffect } from 'react';
5
+ import { ClickAwayListener } from '@mui/material';
17
6
  import { darkFilterIcon } from '../../constants/index.js';
18
7
  import { Menu, CustomBackdrop } from '../index.js';
19
8
  import { CancelButton, FilterButton, Footer, OkayButton, TitleStyled } from './style';
20
- export default function FilterDropdown(_a) {
21
- var { onConfirm, onCancel, isOkayButDisabled, children, isDisabled, icon, title, menuStyle, hideTitle = false, renderButton, onOpenChange } = _a, props = __rest(_a, ["onConfirm", "onCancel", "isOkayButDisabled", "children", "isDisabled", "icon", "title", "menuStyle", "hideTitle", "renderButton", "onOpenChange"]);
9
+ export default function FilterDropdown({ onConfirm, onCancel, isOkayButDisabled, children, isDisabled }) {
22
10
  const [anchorEl, setAnchorEl] = useState(null);
23
11
  const open = Boolean(anchorEl);
24
12
  const { t } = useTranslation();
@@ -44,14 +32,12 @@ export default function FilterDropdown(_a) {
44
32
  return;
45
33
  if (!open) {
46
34
  setAnchorEl(e.currentTarget);
47
- onOpenChange === null || onOpenChange === void 0 ? void 0 : onOpenChange(true);
48
35
  return;
49
36
  }
50
37
  onClose();
51
38
  };
52
39
  const onClose = () => {
53
40
  setAnchorEl(null);
54
- onOpenChange === null || onOpenChange === void 0 ? void 0 : onOpenChange(false);
55
41
  onCancel();
56
42
  };
57
43
  const handleCancel = () => {
@@ -64,5 +50,5 @@ export default function FilterDropdown(_a) {
64
50
  onConfirm();
65
51
  onClose();
66
52
  };
67
- return (_jsx(ClickAwayListener, Object.assign({ onClickAway: handleCancel }, { children: _jsxs(Box, Object.assign({}, props, { children: [_jsx(FilterButton, Object.assign({ className: "filter-button", isActive: open, onClick: onOpen, sx: Object.assign({}, (isDisabled && Object.assign({ pointerEvents: 'none', opacity: 0.5 }, props.sx))) }, { children: renderButton !== null && renderButton !== void 0 ? renderButton : _jsx(Box, { component: "img", src: icon !== null && icon !== void 0 ? icon : darkFilterIcon, alt: "filter" }) })), _jsxs(Menu, Object.assign({ anchorEl: anchorEl, open: open, sx: Object.assign({ marginTop: '8px', marginBottom: '8px', width: 193 }, menuStyle), placement: "bottom-end" }, { children: [!hideTitle && _jsx(TitleStyled, Object.assign({ component: "span" }, { children: title !== null && title !== void 0 ? title : t('filterBy') })), children, _jsxs(Footer, { children: [_jsx(CancelButton, Object.assign({ onClick: handleCancel }, { children: t('cancel') })), _jsx(OkayButton, Object.assign({ disabled: isOkayButDisabled, onClick: handleConfirm }, { children: t('okay') }))] })] })), open && _jsx(CustomBackdrop, { onClick: onClose })] })) })));
53
+ return (_jsx(ClickAwayListener, Object.assign({ onClickAway: handleCancel }, { children: _jsxs(Box, { children: [_jsx(FilterButton, Object.assign({ isActive: open, onClick: onOpen, sx: Object.assign({}, (isDisabled && { pointerEvents: 'none', opacity: 0.5 })) }, { children: _jsx(Box, { component: "img", src: darkFilterIcon, alt: "filter" }) })), _jsxs(Menu, Object.assign({ anchorEl: anchorEl, open: open, sx: { marginTop: '8px', marginBottom: '8px', width: 193 }, placement: "bottom-end" }, { children: [_jsx(TitleStyled, Object.assign({ component: "span" }, { children: t('filterBy') })), children, _jsxs(Footer, { children: [_jsx(CancelButton, Object.assign({ onClick: handleCancel }, { children: t('cancel') })), _jsx(OkayButton, Object.assign({ disabled: isOkayButDisabled, onClick: handleConfirm }, { children: t('okay') }))] })] })), open && _jsx(CustomBackdrop, { onClick: onClose })] }) })));
68
54
  }
@@ -2,7 +2,7 @@ import Box from '@mui/material/Box';
2
2
  import { styled } from '@mui/material/styles';
3
3
  import Button from '@mui/material/Button';
4
4
  import { Text } from '../index.js';
5
- export const FilterButton = styled(Box, { shouldForwardProp: (props) => props !== 'isActive' })(({ theme, isActive }) => (Object.assign({ borderRadius: '4px', border: `1px solid ${theme.palette.divider}`, minHeight: 32, minWidth: 30, display: 'flex', alignItems: 'center', justifyContent: 'center', cursor: 'pointer', backgroundColor: theme.palette.common.white, ':hover': {
5
+ export const FilterButton = styled(Box, { shouldForwardProp: (props) => props !== 'isActive' })(({ theme, isActive }) => (Object.assign({ borderRadius: '4px', border: `1px solid ${theme.palette.divider}`, height: 32, width: 30, display: 'flex', alignItems: 'center', justifyContent: 'center', cursor: 'pointer', backgroundColor: theme.palette.common.white, ':hover': {
6
6
  opacity: 0.7,
7
7
  } }, (isActive && {
8
8
  boxShadow: `0px 0px 4px 0px ${theme.palette.info.dark}80`,
@@ -58,10 +58,8 @@ function RangeCalender({ defaultDate, onDateChange, mode = 'gregorian', onCalend
58
58
  onChangeTimezone === null || onChangeTimezone === void 0 ? void 0 : onChangeTimezone(selectedTimezone);
59
59
  };
60
60
  const getSelectedDate = () => {
61
- const nowYear = dayjs().year();
62
- const formatDate = (date) => (date.year === nowYear ? date.format('MMM D') : date.format('MMM D YYYY'));
63
- const startSelectedTime = formatDate(dates[0]);
64
- const endSelectedTime = dates[1] ? formatDate(dates[1]) : formatDate(dates[0]);
61
+ const startSelectedTime = dates[0].format('MMM D');
62
+ const endSelectedTime = dates[1] ? dates[1].format('MMM D') : dates[0].format('MMM D');
65
63
  return startSelectedTime === endSelectedTime && !noTimezone ? startSelectedTime : `${startSelectedTime} - ${endSelectedTime}`;
66
64
  };
67
65
  const onChange = (newDate) => {
@@ -1,2 +1,2 @@
1
1
  import type { FilterRowProps } from './type';
2
- export default function FiltersRow({ date, calendarMode, onDateChange, onCalendarModeSwitch, tableReportsComponent, tableFilterComponent, isReportsButtonVisible, onViewChange, onSearchChange, onToggleViewButtonClick, rightActions, leftActions, setTableViews, tableViews, resetTableViews, onToggleTextButtonClick, calendarGroupBy, onCalendarGroupChange, maxDateRange, searchPlaceholder, isAcceptance, tableMode, timezone, browserTimezone, defaultCountryTimezone, onChangeTimezone, segmentCountries, }: FilterRowProps): import("react/jsx-runtime").JSX.Element;
2
+ export default function FiltersRow({ date, calendarMode, onDateChange, onCalendarModeSwitch, tableReportsComponent, tableFilterComponent, isReportsButtonVisible, onViewChange, onSearchChange, onToggleViewButtonClick, rightActions, leftActions, setTableViews, tableViews, resetTableViews, onToggleTextButtonClick, calendarGroupBy, onCalendarGroupChange, maxDateRange, searchPlaceholder, isAcceptance, tableMode, timezone, browserTimezone, defaultCountryTimezone, onChangeTimezone, segmentCountries, onCreateCustomView, onEditCustomView, onDeleteCustomView, templates, lang, }: FilterRowProps): import("react/jsx-runtime").JSX.Element;
@@ -4,8 +4,9 @@ import { SearchButton, StyledButton, Icon, RangeCalender } from '../index.js';
4
4
  import { viewIcon } from '../../constants/index.js';
5
5
  import FiltersRowWrapper from './FiltersRowWrapper';
6
6
  import TableView from './TableView';
7
+ import { ViewSelector } from './TableView';
7
8
  import TableModeButton from './TableModeButton';
8
- export default function FiltersRow({ date, calendarMode, onDateChange, onCalendarModeSwitch, tableReportsComponent, tableFilterComponent, isReportsButtonVisible, onViewChange, onSearchChange, onToggleViewButtonClick, rightActions, leftActions, setTableViews, tableViews, resetTableViews, onToggleTextButtonClick, calendarGroupBy, onCalendarGroupChange, maxDateRange = 31, searchPlaceholder, isAcceptance, tableMode = 'default', timezone, browserTimezone, defaultCountryTimezone, onChangeTimezone, segmentCountries, }) {
9
+ export default function FiltersRow({ date, calendarMode, onDateChange, onCalendarModeSwitch, tableReportsComponent, tableFilterComponent, isReportsButtonVisible, onViewChange, onSearchChange, onToggleViewButtonClick, rightActions, leftActions, setTableViews, tableViews, resetTableViews, onToggleTextButtonClick, calendarGroupBy, onCalendarGroupChange, maxDateRange = 31, searchPlaceholder, isAcceptance, tableMode = 'default', timezone, browserTimezone, defaultCountryTimezone, onChangeTimezone, segmentCountries, onCreateCustomView, onEditCustomView, onDeleteCustomView, templates, lang, }) {
9
10
  const [isViewVisible, setIsViewVisible] = useState(false);
10
11
  const timezoneCountriesCodes = useMemo(() => segmentCountries.map(({ code }) => code), [segmentCountries]);
11
12
  const tableModeButton = useMemo(() => _jsx(TableModeButton, { tableMode: tableMode, onToggle: onToggleTextButtonClick }), [tableMode, onToggleTextButtonClick]);
@@ -14,5 +15,6 @@ export default function FiltersRow({ date, calendarMode, onDateChange, onCalenda
14
15
  if (startDate && endDate) {
15
16
  onDateChange === null || onDateChange === void 0 ? void 0 : onDateChange([startDate, endDate]);
16
17
  }
17
- }, mode: calendarMode, onCalendarModeSwitch: onCalendarModeSwitch, maxDateRange: maxDateRange, groupBy: calendarGroupBy, onCalendarGroupChange: onCalendarGroupChange, browserTimezone: browserTimezone, defaultCountryTimezone: defaultCountryTimezone, timezone: timezone, onChangeTimezone: onChangeTimezone, timezoneCountriesCodes: timezoneCountriesCodes })), isReportsButtonVisible && tableReportsComponent, onToggleTextButtonClick && isAcceptance && tableModeButton] })), onToggleViewButtonClick && (_jsx(StyledButton, { children: _jsx(Icon, { src: viewIcon, alt: "view", sx: { width: 14, height: 14 } }) })), onViewChange && (_jsx(TableView, { onViewChange: onViewChange, setIsViewVisible: setIsViewVisible, tableViews: tableViews, setTableViews: setTableViews, resetTableViews: resetTableViews })), rightActions && !isViewVisible && rightActions] }));
18
+ }, mode: calendarMode, onCalendarModeSwitch: onCalendarModeSwitch, maxDateRange: maxDateRange, groupBy: calendarGroupBy, onCalendarGroupChange: onCalendarGroupChange, browserTimezone: browserTimezone, defaultCountryTimezone: defaultCountryTimezone, timezone: timezone, onChangeTimezone: onChangeTimezone, timezoneCountriesCodes: timezoneCountriesCodes })), isReportsButtonVisible && tableReportsComponent, onToggleTextButtonClick && isAcceptance && tableModeButton] })), onToggleViewButtonClick && (_jsx(StyledButton, { children: _jsx(Icon, { src: viewIcon, alt: "view", sx: { width: 14, height: 14 } }) })), onViewChange &&
19
+ (templates ? (_jsx(ViewSelector, { onViewChange: onViewChange, onCreateCustomView: onCreateCustomView, onEditCustomView: onEditCustomView, onDeleteCustomView: onDeleteCustomView, tableMode: tableMode, templates: templates, lang: lang })) : (_jsx(TableView, { onViewChange: onViewChange, setIsViewVisible: setIsViewVisible, tableViews: tableViews, setTableViews: setTableViews, resetTableViews: resetTableViews }))), rightActions && !isViewVisible && rightActions] }));
18
20
  }
@@ -1,5 +1,5 @@
1
1
  import type { TableHeaderProps } from './type';
2
2
  import { type TableHeaderStatus } from '../../types/index.js';
3
- export declare function TableHeader<IStatus extends TableHeaderStatus | TableHeaderStatus[] = undefined>({ date, status, availableStatuses, showMaximizedView, title, calendarMode, tableReportsComponent, tableFilterComponent, onStatusChange, onViewChange, onDateChange, onCalendarModeSwitch, filteredIds, onCancelFilteredIdsClick, isFilteredIdsShown, cardNumber, leftActions, rightActions, isReportsButtonVisible, onSearchChange, onToggleViewButtonClick, leftComponent, tableViews, setTableViews, resetTableViews, onToggleTextButtonClick, calendarGroupBy, onCalendarGroupChange, children, maxDateRange, isAcceptance, startComponent, searchPlaceholder, tableMode, timezone, browserTimezone, defaultCountryTimezone, onChangeTimezone, segmentCountries, ...StatusBarProps }: TableHeaderProps<IStatus>): import("react/jsx-runtime").JSX.Element;
3
+ export declare function TableHeader<IStatus extends TableHeaderStatus | TableHeaderStatus[] = undefined>({ date, status, availableStatuses, showMaximizedView, title, calendarMode, tableReportsComponent, tableFilterComponent, onStatusChange, onViewChange, onDateChange, onCalendarModeSwitch, filteredIds, onCancelFilteredIdsClick, isFilteredIdsShown, cardNumber, leftActions, rightActions, isReportsButtonVisible, onSearchChange, onToggleViewButtonClick, leftComponent, tableViews, setTableViews, resetTableViews, onToggleTextButtonClick, calendarGroupBy, onCalendarGroupChange, children, maxDateRange, isAcceptance, startComponent, searchPlaceholder, tableMode, timezone, browserTimezone, defaultCountryTimezone, onChangeTimezone, segmentCountries, onCreateCustomView, onEditCustomView, onDeleteCustomView, templates, lang, ...StatusBarProps }: TableHeaderProps<IStatus>): import("react/jsx-runtime").JSX.Element;
4
4
  declare const _default: typeof TableHeader;
5
5
  export default _default;
@@ -15,8 +15,8 @@ import { FilteredIds, StatusBar, TableHeaderWrapper } from '../index.js';
15
15
  import FiltersRow from './FiltersRow';
16
16
  import { StatusButtonsContainer, TitleContainer, TableHeaderTitle, TableHeaderRow } from './style';
17
17
  export function TableHeader(_a) {
18
- var { date, status, availableStatuses, showMaximizedView, title, calendarMode, tableReportsComponent, tableFilterComponent, onStatusChange, onViewChange, onDateChange, onCalendarModeSwitch, filteredIds, onCancelFilteredIdsClick, isFilteredIdsShown, cardNumber, leftActions, rightActions, isReportsButtonVisible, onSearchChange, onToggleViewButtonClick, leftComponent, tableViews, setTableViews, resetTableViews, onToggleTextButtonClick, calendarGroupBy, onCalendarGroupChange, children, maxDateRange, isAcceptance, startComponent, searchPlaceholder, tableMode, timezone, browserTimezone, defaultCountryTimezone, onChangeTimezone, segmentCountries = [] } = _a, StatusBarProps = __rest(_a, ["date", "status", "availableStatuses", "showMaximizedView", "title", "calendarMode", "tableReportsComponent", "tableFilterComponent", "onStatusChange", "onViewChange", "onDateChange", "onCalendarModeSwitch", "filteredIds", "onCancelFilteredIdsClick", "isFilteredIdsShown", "cardNumber", "leftActions", "rightActions", "isReportsButtonVisible", "onSearchChange", "onToggleViewButtonClick", "leftComponent", "tableViews", "setTableViews", "resetTableViews", "onToggleTextButtonClick", "calendarGroupBy", "onCalendarGroupChange", "children", "maxDateRange", "isAcceptance", "startComponent", "searchPlaceholder", "tableMode", "timezone", "browserTimezone", "defaultCountryTimezone", "onChangeTimezone", "segmentCountries"]);
19
- const filtersRow = (_jsx(FiltersRow, { date: date, calendarMode: calendarMode, onDateChange: onDateChange, onCalendarModeSwitch: onCalendarModeSwitch, tableReportsComponent: tableReportsComponent, tableFilterComponent: tableFilterComponent, onViewChange: onViewChange, leftActions: leftActions, rightActions: rightActions, onSearchChange: onSearchChange, onToggleViewButtonClick: onToggleViewButtonClick, isReportsButtonVisible: isReportsButtonVisible, tableViews: tableViews, setTableViews: setTableViews, resetTableViews: resetTableViews, onToggleTextButtonClick: onToggleTextButtonClick, tableMode: tableMode, onCalendarGroupChange: onCalendarGroupChange, calendarGroupBy: calendarGroupBy, maxDateRange: maxDateRange, isAcceptance: isAcceptance, searchPlaceholder: searchPlaceholder, timezone: timezone, browserTimezone: browserTimezone, defaultCountryTimezone: defaultCountryTimezone, onChangeTimezone: onChangeTimezone, segmentCountries: segmentCountries }));
18
+ var { date, status, availableStatuses, showMaximizedView, title, calendarMode, tableReportsComponent, tableFilterComponent, onStatusChange, onViewChange, onDateChange, onCalendarModeSwitch, filteredIds, onCancelFilteredIdsClick, isFilteredIdsShown, cardNumber, leftActions, rightActions, isReportsButtonVisible, onSearchChange, onToggleViewButtonClick, leftComponent, tableViews, setTableViews, resetTableViews, onToggleTextButtonClick, calendarGroupBy, onCalendarGroupChange, children, maxDateRange, isAcceptance, startComponent, searchPlaceholder, tableMode, timezone, browserTimezone, defaultCountryTimezone, onChangeTimezone, segmentCountries = [], onCreateCustomView, onEditCustomView, onDeleteCustomView, templates, lang } = _a, StatusBarProps = __rest(_a, ["date", "status", "availableStatuses", "showMaximizedView", "title", "calendarMode", "tableReportsComponent", "tableFilterComponent", "onStatusChange", "onViewChange", "onDateChange", "onCalendarModeSwitch", "filteredIds", "onCancelFilteredIdsClick", "isFilteredIdsShown", "cardNumber", "leftActions", "rightActions", "isReportsButtonVisible", "onSearchChange", "onToggleViewButtonClick", "leftComponent", "tableViews", "setTableViews", "resetTableViews", "onToggleTextButtonClick", "calendarGroupBy", "onCalendarGroupChange", "children", "maxDateRange", "isAcceptance", "startComponent", "searchPlaceholder", "tableMode", "timezone", "browserTimezone", "defaultCountryTimezone", "onChangeTimezone", "segmentCountries", "onCreateCustomView", "onEditCustomView", "onDeleteCustomView", "templates", "lang"]);
19
+ const filtersRow = (_jsx(FiltersRow, { date: date, calendarMode: calendarMode, onDateChange: onDateChange, onCalendarModeSwitch: onCalendarModeSwitch, tableReportsComponent: tableReportsComponent, tableFilterComponent: tableFilterComponent, onViewChange: onViewChange, leftActions: leftActions, rightActions: rightActions, onSearchChange: onSearchChange, onToggleViewButtonClick: onToggleViewButtonClick, isReportsButtonVisible: isReportsButtonVisible, tableViews: tableViews, setTableViews: setTableViews, resetTableViews: resetTableViews, onToggleTextButtonClick: onToggleTextButtonClick, tableMode: tableMode, onCalendarGroupChange: onCalendarGroupChange, calendarGroupBy: calendarGroupBy, maxDateRange: maxDateRange, isAcceptance: isAcceptance, searchPlaceholder: searchPlaceholder, timezone: timezone, browserTimezone: browserTimezone, defaultCountryTimezone: defaultCountryTimezone, onChangeTimezone: onChangeTimezone, segmentCountries: segmentCountries, onCreateCustomView: onCreateCustomView, onEditCustomView: onEditCustomView, onDeleteCustomView: onDeleteCustomView, templates: templates, lang: lang }));
20
20
  return (_jsxs(TableHeaderWrapper, { children: [showMaximizedView && (_jsxs(TitleContainer, { children: [_jsx("span", { children: !!title && _jsx(TableHeaderTitle, { children: title }) }), filtersRow] }, "TitleContainer")), _jsxs(TableHeaderRow, Object.assign({ as: "section" }, { children: [_jsxs(StatusButtonsContainer, Object.assign({ as: "aside" }, { children: [startComponent, _jsx(StatusBar, Object.assign({ status: status, availableStatuses: availableStatuses, onStatusChange: onStatusChange, isFilteredIdsShown: isFilteredIdsShown }, StatusBarProps)), leftComponent, isFilteredIdsShown && (_jsx(FilteredIds, { cardNumber: cardNumber, Ids: filteredIds, isShown: isFilteredIdsShown, onCancelClick: onCancelFilteredIdsClick }, "FilteredIds"))] })), !showMaximizedView && filtersRow] }), "FiltersWrapper"), children] }));
21
21
  }
22
22
  export default memo(TableHeader);
@@ -0,0 +1,3 @@
1
+ import type { CreateCustomViewDialogProps } from './types';
2
+ declare function CreateViewDialog({ open, onClose, onCreate, availableColumns, defaultColumns, editingView, onDelete, tableViews, mode, }: Readonly<CreateCustomViewDialogProps>): import("react/jsx-runtime").JSX.Element | null;
3
+ export default CreateViewDialog;
@@ -0,0 +1,91 @@
1
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
3
+ return new (P || (P = Promise))(function (resolve, reject) {
4
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
5
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
6
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
7
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
8
+ });
9
+ };
10
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
11
+ import React, { useState } from 'react';
12
+ import { Box, Typography, CircularProgress, Dialog } from '@mui/material';
13
+ import { useTranslation } from 'react-i18next';
14
+ import Draggable from 'react-draggable';
15
+ import { InputBase } from '../../index.js';
16
+ import { useToast } from '../../../hooks/index.js';
17
+ import Toolbar, { StyledHeaderWrapperStyled } from '../../Toolbar';
18
+ import { CloseIcon } from '../../ToolbarIcon';
19
+ import { TEMPLATE_NAME_MAX_LENGTH } from './constants';
20
+ import { DialogContentWrapper, ScrollableContent, TitleSection, FooterBar, CreateButtonWrapper, DeleteButton, CreateButton, getDialogPaperStyle, dialogSx, } from './styles';
21
+ import { DIALOG_WIDTH, DIALOG_HEIGHT } from './constants';
22
+ import { useCreateViewDialog } from './hooks';
23
+ import { ColumnList } from './components/ColumnList';
24
+ import { convertColumnsToLayoutSection } from './utils';
25
+ function CreateViewDialog({ open, onClose, onCreate, availableColumns = [], defaultColumns = [], editingView, onDelete, tableViews = [], mode = 'sheet', }) {
26
+ const { t } = useTranslation();
27
+ const toast = useToast();
28
+ const [isDeleting, setIsDeleting] = useState(false);
29
+ const [isLoading, setIsLoading] = useState(false);
30
+ // Reset loading state when dialog closes
31
+ React.useEffect(() => {
32
+ if (!open) {
33
+ setIsDeleting(false);
34
+ setIsLoading(false);
35
+ }
36
+ }, [open]);
37
+ const { templateName, setTemplateName, selectedColumns, columnNames, allSelected, someSelected, isNameValid, hoveredColumn, anchorEl, openSubmenu, closeSubmenu, cancelClose, handleReorder, handleColumnToggle, handleSubItemToggle, handleSelectAll, handleResetToDefault, } = useCreateViewDialog({
38
+ open,
39
+ availableColumns,
40
+ defaultColumns,
41
+ editingView,
42
+ tableViews,
43
+ });
44
+ const handleCreate = () => __awaiter(this, void 0, void 0, function* () {
45
+ if (!isNameValid || isLoading || isDeleting)
46
+ return;
47
+ setIsLoading(true);
48
+ try {
49
+ const columnsToCreate = selectedColumns.filter((col) => col.selected);
50
+ const layout = convertColumnsToLayoutSection(columnsToCreate, mode);
51
+ yield (onCreate === null || onCreate === void 0 ? void 0 : onCreate({ name: templateName, selectedColumns: columnsToCreate, layout }));
52
+ onClose();
53
+ }
54
+ catch (error) {
55
+ const errorMessage = error instanceof Error ? error.message : 'Failed to save view. Please try again.';
56
+ toast.error(errorMessage);
57
+ }
58
+ finally {
59
+ setIsLoading(false);
60
+ }
61
+ });
62
+ const handleDelete = () => __awaiter(this, void 0, void 0, function* () {
63
+ if (!editingView || isDeleting || isLoading)
64
+ return;
65
+ const templateId = editingView.templateId || editingView.id;
66
+ setIsDeleting(true);
67
+ try {
68
+ yield (onDelete === null || onDelete === void 0 ? void 0 : onDelete(templateId));
69
+ onClose();
70
+ }
71
+ catch (error) {
72
+ const errorMessage = error instanceof Error ? error.message : 'Failed to delete view. Please try again.';
73
+ toast.error(errorMessage);
74
+ }
75
+ finally {
76
+ setIsDeleting(false);
77
+ }
78
+ });
79
+ if (!open)
80
+ return null;
81
+ return (_jsx(Draggable, Object.assign({ handle: "#draggable-dialog-title", cancel: '[class*="MuiDialogContent-root"]' }, { children: _jsxs(Dialog, Object.assign({ disableEnforceFocus: true, open: open, onClose: onClose, hideBackdrop: true, PaperProps: { style: getDialogPaperStyle(DIALOG_WIDTH, DIALOG_HEIGHT) }, sx: dialogSx, TransitionProps: {
82
+ timeout: 0,
83
+ }, slotProps: {
84
+ backdrop: {
85
+ sx: {
86
+ transition: 'none',
87
+ },
88
+ },
89
+ } }, { children: [_jsx(StyledHeaderWrapperStyled, Object.assign({ id: "draggable-dialog-title", style: { cursor: 'move' } }, { children: _jsx(Toolbar, { isHovered: true, title: editingView ? 'Edit Custom View' : t('createCustomView') || 'Create Custom View', leftActions: _jsx(CloseIcon, { onClick: onClose }) }) })), _jsxs(DialogContentWrapper, { children: [_jsxs(ScrollableContent, { children: [_jsxs(TitleSection, { children: [_jsxs(Box, { children: [_jsx(Typography, Object.assign({ sx: { fontSize: 24, fontWeight: 700, color: '#9F9F9F', lineHeight: '0.7' } }, { children: "Custom" })), _jsx(Typography, Object.assign({ sx: { fontSize: 24, fontWeight: 700, color: '#20232B', lineHeight: 1.2 } }, { children: "View" }))] }), editingView && (_jsx(DeleteButton, Object.assign({ onClick: handleDelete, disabled: isDeleting || isLoading }, { children: isDeleting ? (_jsxs(Box, Object.assign({ sx: { display: 'flex', alignItems: 'center', gap: 1 } }, { children: [_jsx(CircularProgress, { size: 14, color: "inherit" }), _jsx("span", { children: "Deleting..." })] }))) : ('Delete View') })))] }), _jsx(Box, Object.assign({ sx: { mb: 3 } }, { children: _jsx(InputBase, { name: "templateName", label: "Name", value: templateName, onChange: (value) => setTemplateName(value), hasError: false, inputProps: { maxLength: TEMPLATE_NAME_MAX_LENGTH }, required: true }) })), _jsx(ColumnList, { selectedColumns: selectedColumns, columnNames: columnNames, allSelected: allSelected, someSelected: someSelected, hoveredColumn: hoveredColumn, anchorEl: anchorEl, onReorder: handleReorder, onColumnToggle: handleColumnToggle, onSubItemToggle: handleSubItemToggle, onSelectAll: handleSelectAll, onResetToDefault: handleResetToDefault, onSubmenuEnter: openSubmenu, onSubmenuLeave: closeSubmenu, onCancelClose: cancelClose })] }), _jsx(FooterBar, {}), _jsx(CreateButtonWrapper, { children: _jsx(CreateButton, Object.assign({ variant: "contained", onClick: handleCreate, disabled: !isNameValid || isLoading || isDeleting, title: !isNameValid ? `Name is required. Current: "${templateName}"` : undefined }, { children: isLoading ? (_jsxs(Box, Object.assign({ sx: { display: 'flex', alignItems: 'center', gap: 1 } }, { children: [_jsx(CircularProgress, { size: 14, color: "inherit" }), _jsx("span", { children: editingView ? 'Saving...' : 'Creating...' })] }))) : editingView ? ('Update View') : ('Create View') })) })] })] })) })));
90
+ }
91
+ export default CreateViewDialog;
@@ -4,7 +4,7 @@ import { useTranslation } from 'react-i18next';
4
4
  import { Reorder } from 'framer-motion';
5
5
  import { CustomBackdrop, Menu } from '../../index.js';
6
6
  import { downArrowIcon } from '../../../constants/index.js';
7
- import { ButtonStyled, ListStyled, DropdownStyled } from './style';
7
+ import { ButtonStyled, ListStyled, DropdownStyled } from './styles';
8
8
  import { useSubMenu, useViewColumns } from './hooks';
9
9
  import ColumnItem from './ColumnItem';
10
10
  function CustomViews({ open, onSelect, setTableViews, tableViews, anchorEl, onClose }) {
@@ -28,7 +28,6 @@ function TableView({ onViewChange, setIsViewVisible, setTableViews, tableViews,
28
28
  const onClose = () => {
29
29
  setAnchorViewEl(null);
30
30
  setIsViewVisible(false);
31
- // to be removed
32
31
  setSelectedViewInfo({ label: 'Default', id: 'default' });
33
32
  };
34
33
  const handleSelectedViewInfo = (selected) => {
@@ -0,0 +1,5 @@
1
+ /// <reference types="react" />
2
+ import type { ViewSelectorProps } from './types';
3
+ declare function ViewSelector({ onViewChange, onCreateCustomView, onEditCustomView, onDeleteCustomView, tableMode, templates, lang, }: ViewSelectorProps): import("react/jsx-runtime").JSX.Element;
4
+ declare const _default: import("react").MemoExoticComponent<typeof ViewSelector>;
5
+ export default _default;
@@ -0,0 +1,81 @@
1
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
3
+ return new (P || (P = Promise))(function (resolve, reject) {
4
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
5
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
6
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
7
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
8
+ });
9
+ };
10
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
11
+ import { memo, useCallback } from 'react';
12
+ import { useTranslation } from 'react-i18next';
13
+ import ClickAwayListener from '@mui/material/ClickAwayListener';
14
+ import { Icon, StyledButton } from '../../index.js';
15
+ import { viewIcon } from '../../../constants/index.js';
16
+ import ViewsDropdown from './ViewsDropdown';
17
+ import CreateViewDialog from './CreateViewDialog';
18
+ import { ViewWrapper } from './styles';
19
+ import { useViewsManager } from './hooks';
20
+ import { useViewSelector } from './hooks/useViewSelector';
21
+ function ViewSelector({ onViewChange, onCreateCustomView, onEditCustomView, onDeleteCustomView, tableMode = 'default', templates, lang = 'en', }) {
22
+ const { t } = useTranslation();
23
+ // Use tableMode directly - no conversion needed
24
+ const { defaultColumns, updateDefaultColumns, defaultTemplate, customViews, allTemplates, setInternalCustomViews } = useViewsManager({
25
+ tableMode,
26
+ templates,
27
+ lang,
28
+ });
29
+ // Callback when default template is modified and saved
30
+ const handleSaveDefaultColumns = useCallback((columns) => __awaiter(this, void 0, void 0, function* () {
31
+ if (!(defaultTemplate === null || defaultTemplate === void 0 ? void 0 : defaultTemplate.templateId))
32
+ return;
33
+ // Update local state first
34
+ updateDefaultColumns(columns);
35
+ // Build layout for API
36
+ // Map TableMode to layout section code: 'default' → 'Advanced', 'sheet' → 'Sheet'
37
+ const layout = {
38
+ code: tableMode === 'sheet' ? 'Sheet' : 'Advanced',
39
+ columns: columns.map((col, idx) => {
40
+ var _a, _b;
41
+ return ({
42
+ code: col.name,
43
+ name: [{ text: typeof col.label === 'string' ? col.label : col.name, lang }],
44
+ order: idx + 1,
45
+ default: (_a = col.selected) !== null && _a !== void 0 ? _a : false,
46
+ fields: (_b = col.menuItems) === null || _b === void 0 ? void 0 : _b.map((item) => {
47
+ var _a;
48
+ return ({
49
+ code: item.name,
50
+ name: [{ text: typeof item.label === 'string' ? item.label : item.name, lang }],
51
+ order: null,
52
+ default: (_a = item.selected) !== null && _a !== void 0 ? _a : false,
53
+ });
54
+ }),
55
+ });
56
+ }),
57
+ };
58
+ // Call parent to persist
59
+ yield (onEditCustomView === null || onEditCustomView === void 0 ? void 0 : onEditCustomView(defaultTemplate.templateId, {
60
+ name: defaultTemplate.label,
61
+ selectedColumns: columns,
62
+ layout,
63
+ }));
64
+ }), [defaultTemplate, tableMode, lang, onEditCustomView, updateDefaultColumns]);
65
+ const { anchorViewEl, defaultViewEl, setDefaultViewElement, isCreateDialogOpen, editingView, selectedViewInfo, shouldUseCurrentState, currentViewColumns, handleViewButtonClick, handleCloseViewDropdown, handleSelectedViewInfo, handleOpenCreateDialog, handleOpenEditDialog, handleCloseCreateDialog, handleSaveView, handleDeleteView, handleResetViews, updateSelectedView, updateCurrentViewColumns, } = useViewSelector({
66
+ mode: tableMode,
67
+ onViewChange,
68
+ onCreateCustomView,
69
+ onEditCustomView,
70
+ onDeleteCustomView,
71
+ customViews,
72
+ defaultColumns,
73
+ defaultTemplate,
74
+ allTemplates,
75
+ setInternalCustomViews,
76
+ });
77
+ return (_jsxs(_Fragment, { children: [_jsx(ClickAwayListener, Object.assign({ onClickAway: handleCloseViewDropdown }, { children: _jsxs(ViewWrapper, Object.assign({ sx: { width: '32px' }, "data-testid": "ViewSelector" }, { children: [_jsx(StyledButton, Object.assign({ title: t('tableView'), "data-testid": "ViewSelector_button", onClick: handleViewButtonClick }, { children: _jsx(Icon, { src: viewIcon, alt: "view", sx: { width: 14, height: 14 } }) })), _jsx(ViewsDropdown, { open: Boolean(defaultViewEl), anchorEl: anchorViewEl, setSelectedViewInfo: handleSelectedViewInfo, selectedViewInfo: selectedViewInfo, onSelect: (e) => {
78
+ setDefaultViewElement(defaultViewEl ? null : e.currentTarget);
79
+ }, setViews: handleResetViews, onCreateCustomView: handleOpenCreateDialog, customViews: customViews, onEditCustomView: handleOpenEditDialog, onSaveDefaultColumns: handleSaveDefaultColumns, defaultColumns: defaultColumns, setDefaultColumns: updateDefaultColumns, updateSelectedView: updateSelectedView, mode: tableMode, defaultTemplate: defaultTemplate })] })) })), _jsx(CreateViewDialog, { open: isCreateDialogOpen, onClose: handleCloseCreateDialog, availableColumns: defaultColumns, defaultColumns: defaultColumns, onCreate: handleSaveView, editingView: editingView, onDelete: handleDeleteView, tableViews: shouldUseCurrentState ? currentViewColumns : undefined, mode: tableMode })] }));
80
+ }
81
+ export default memo(ViewSelector);
@@ -0,0 +1,5 @@
1
+ import React from 'react';
2
+ import type { ViewsDropdownProps } from './types';
3
+ declare function ViewsDropdown({ open, selectedViewInfo, setSelectedViewInfo, onSelect, setViews, anchorEl, onCreateCustomView, customViews, onEditCustomView, onSaveDefaultColumns, defaultColumns, setDefaultColumns, updateSelectedView, mode, defaultTemplate, }: Readonly<ViewsDropdownProps>): import("react/jsx-runtime").JSX.Element;
4
+ declare const _default: React.MemoExoticComponent<typeof ViewsDropdown>;
5
+ export default _default;
@@ -0,0 +1,198 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import React, { useMemo } from 'react';
3
+ import Popper from '@mui/material/Popper';
4
+ import Box from '@mui/material/Box';
5
+ import Typography from '@mui/material/Typography';
6
+ import Divider from '@mui/material/Divider';
7
+ import Button from '@mui/material/Button';
8
+ import { useTranslation } from 'react-i18next';
9
+ import { bluePlusIcon, editIcon, smallBlueCheckIcon, blackRightArrowIcon } from '../../../constants/index.js';
10
+ import { Menu, Tooltip } from '../../index.js';
11
+ import { useSubmenuHover, useOriginalColumns } from './hooks';
12
+ import { MAX_CUSTOM_VIEWS } from './constants';
13
+ import { ViewsSubmenu } from './components/ViewsSubmenu';
14
+ import { ListStyled, DropdownStyled, MenuItem as StyledMenuItem, Space, SpaceAfter, SubmenuContainer, SaveCustomViewBox, SaveCustomViewInnerBox, ButtonsContainer, CancelButtonSx, OkayButtonSx, ModifiedTextSx, } from './styles';
15
+ import { deepCloneColumns, toggleSingleColumn, toggleSubItem, getSubmenuItems, hasSubmenu, areAllCurrentColumnsSelected, areSomeCurrentColumnsSelected, toggleAllCurrentColumns, areColumnsEqual, } from './utils';
16
+ function ViewsDropdown({ open, selectedViewInfo, setSelectedViewInfo, onSelect, setViews, anchorEl, onCreateCustomView, customViews = [], onEditCustomView, onSaveDefaultColumns, defaultColumns = [], setDefaultColumns, updateSelectedView, mode = 'default', defaultTemplate, }) {
17
+ const { t } = useTranslation();
18
+ const { hoveredColumn: hoveredItem, anchorEl: submenuAnchorEl, openSubmenu: handleMenuItemHover, closeSubmenu: handleMenuItemLeave, cancelClose: handleSubmenuEnter, forceClose: forceCloseSubmenu, } = useSubmenuHover();
19
+ const [hoveredCustomView, setHoveredCustomView] = React.useState(null);
20
+ const [isModified, setIsModified] = React.useState(false);
21
+ // Track original columns when submenu opens
22
+ const { originalColumns, saveOriginalState, clearOriginalState } = useOriginalColumns(defaultColumns);
23
+ // Build the view list (default template + custom views)
24
+ // Use actual defaultTemplate from props instead of static defaultViewList
25
+ const viewList = useMemo(() => {
26
+ const list = [];
27
+ if (defaultTemplate) {
28
+ list.push(defaultTemplate);
29
+ }
30
+ return [...list, ...customViews];
31
+ }, [defaultTemplate, customViews]);
32
+ // Get columns for hovered submenu
33
+ const currentSubmenuColumns = useMemo(() => {
34
+ if (!hoveredItem)
35
+ return [];
36
+ const item = viewList.find((i) => i.id === hoveredItem);
37
+ return item ? getSubmenuItems(item, defaultColumns) : [];
38
+ }, [hoveredItem, defaultColumns, viewList]);
39
+ const allCurrentSelected = useMemo(() => areAllCurrentColumnsSelected(currentSubmenuColumns), [currentSubmenuColumns]);
40
+ const someCurrentSelected = useMemo(() => areSomeCurrentColumnsSelected(currentSubmenuColumns, allCurrentSelected), [currentSubmenuColumns, allCurrentSelected]);
41
+ // Check if columns have been modified from original
42
+ const hasChanges = useMemo(() => {
43
+ if (originalColumns.length === 0)
44
+ return false;
45
+ return !areColumnsEqual(defaultColumns, originalColumns);
46
+ }, [defaultColumns, originalColumns]);
47
+ // Handle clicking on a view item
48
+ const handleViewClick = (item) => {
49
+ forceCloseSubmenu();
50
+ clearOriginalState();
51
+ let viewToPass;
52
+ if (item.default) {
53
+ // For default template, use defaultColumns (which is the default template's working copy)
54
+ const columns = defaultColumns.length > 0 ? defaultColumns : (defaultTemplate === null || defaultTemplate === void 0 ? void 0 : defaultTemplate.submenu) || [];
55
+ viewToPass = Object.assign(Object.assign({}, item), { submenu: deepCloneColumns(columns), columns: columns.map((col) => col.name) });
56
+ }
57
+ else if (item.isCustom) {
58
+ viewToPass = item;
59
+ }
60
+ setSelectedViewInfo(item, viewToPass);
61
+ };
62
+ // Toggle column selection
63
+ const toggleColumnSelection = (columnName) => {
64
+ if (!setDefaultColumns)
65
+ return;
66
+ const newColumns = toggleSingleColumn(defaultColumns, columnName);
67
+ setDefaultColumns(newColumns);
68
+ };
69
+ // Toggle nested item
70
+ const toggleNestedItem = (columnName, subItemName) => {
71
+ if (!setDefaultColumns)
72
+ return;
73
+ const newColumns = toggleSubItem(defaultColumns, columnName, subItemName);
74
+ setDefaultColumns(newColumns);
75
+ };
76
+ // Reorder columns
77
+ const handleReorder = (reorderedColumnNames) => {
78
+ if (!setDefaultColumns)
79
+ return;
80
+ const reorderedColumns = reorderedColumnNames
81
+ .map((name) => defaultColumns.find((column) => column.name === name))
82
+ .filter((column) => Boolean(column));
83
+ setDefaultColumns(reorderedColumns);
84
+ };
85
+ // Select all columns
86
+ const handleSelectAll = () => {
87
+ if (!setDefaultColumns)
88
+ return;
89
+ const newColumns = toggleAllCurrentColumns(defaultColumns, !allCurrentSelected);
90
+ setDefaultColumns(newColumns);
91
+ };
92
+ // Reset to original
93
+ const handleReset = () => {
94
+ if (!setDefaultColumns || originalColumns.length === 0)
95
+ return;
96
+ setDefaultColumns(deepCloneColumns(originalColumns));
97
+ };
98
+ // Open submenu
99
+ const handleOpenSubmenu = (itemId, element) => {
100
+ saveOriginalState();
101
+ handleMenuItemHover(itemId, element);
102
+ };
103
+ // Close submenu and restore if no changes saved
104
+ const handleSubmenuLeave = () => {
105
+ // Restore original columns if not saved
106
+ if (originalColumns.length > 0 && setDefaultColumns) {
107
+ setDefaultColumns(deepCloneColumns(originalColumns));
108
+ }
109
+ clearOriginalState();
110
+ forceCloseSubmenu();
111
+ };
112
+ // Cancel changes
113
+ const handleCancel = () => {
114
+ if (setDefaultColumns && originalColumns.length > 0) {
115
+ setDefaultColumns(deepCloneColumns(originalColumns));
116
+ }
117
+ clearOriginalState();
118
+ forceCloseSubmenu();
119
+ };
120
+ // Save changes
121
+ const handleOkay = () => {
122
+ var _a;
123
+ // Check if we're viewing the default template
124
+ const isViewingDefault = selectedViewInfo.id === (defaultTemplate === null || defaultTemplate === void 0 ? void 0 : defaultTemplate.id) || selectedViewInfo.id === 'default' || (defaultTemplate === null || defaultTemplate === void 0 ? void 0 : defaultTemplate.default) === true;
125
+ console.log('🔵 handleOkay:', {
126
+ isViewingDefault,
127
+ hasChanges,
128
+ selectedViewInfoId: selectedViewInfo.id,
129
+ defaultTemplateId: defaultTemplate === null || defaultTemplate === void 0 ? void 0 : defaultTemplate.id,
130
+ columnsCount: defaultColumns.length,
131
+ });
132
+ if (isViewingDefault && defaultTemplate && defaultColumns.length > 0) {
133
+ // Save changes if any
134
+ if (hasChanges) {
135
+ onSaveDefaultColumns === null || onSaveDefaultColumns === void 0 ? void 0 : onSaveDefaultColumns(defaultColumns);
136
+ setIsModified(true);
137
+ }
138
+ // ALWAYS update the selected view to reflect current column state
139
+ // CRITICAL: Create a NEW object with NEW array references to trigger re-renders
140
+ if (updateSelectedView) {
141
+ const updatedView = Object.assign(Object.assign({}, defaultTemplate), { id: defaultTemplate.id + '', submenu: [...deepCloneColumns(defaultColumns)], columns: [...defaultColumns.map((col) => col.name)] });
142
+ console.log('🟢 Calling updateSelectedView with:', (_a = updatedView.submenu) === null || _a === void 0 ? void 0 : _a.length, 'columns');
143
+ updateSelectedView(updatedView);
144
+ }
145
+ }
146
+ clearOriginalState();
147
+ forceCloseSubmenu();
148
+ };
149
+ // Save as custom view
150
+ const handleSaveAsCustomView = (e) => {
151
+ e.stopPropagation();
152
+ clearOriginalState();
153
+ forceCloseSubmenu();
154
+ onCreateCustomView === null || onCreateCustomView === void 0 ? void 0 : onCreateCustomView(true);
155
+ };
156
+ const shouldDimNewCustomView = customViews.length >= MAX_CUSTOM_VIEWS;
157
+ return (_jsxs(DropdownStyled, Object.assign({ "data-testid": "ViewsDropdown" }, { children: [_jsx(Popper, Object.assign({ open: open, anchorEl: anchorEl, placement: "bottom-start" }, { children: _jsxs(ListStyled, { children: [_jsx(Typography, Object.assign({ sx: {
158
+ paddingX: 1.25,
159
+ py: 1.1,
160
+ fontWeight: 500,
161
+ fontSize: 11,
162
+ color: '#8D8D94',
163
+ } }, { children: "View" })), _jsx(Divider, {}), viewList.map((item) => (_jsxs(StyledMenuItem, Object.assign({ onMouseEnter: (e) => {
164
+ if (item.isCustom) {
165
+ setHoveredCustomView(item.id);
166
+ }
167
+ else if (hasSubmenu(item, defaultColumns)) {
168
+ handleOpenSubmenu(item.id, e.currentTarget);
169
+ }
170
+ }, onMouseLeave: () => {
171
+ if (item.isCustom) {
172
+ setHoveredCustomView(null);
173
+ }
174
+ else if (hasSubmenu(item, defaultColumns)) {
175
+ handleMenuItemLeave();
176
+ }
177
+ }, onClick: () => handleViewClick(item), sx: { position: 'relative', cursor: 'pointer', pr: 1.5 } }, { children: [item.id === selectedViewInfo.id ? _jsx("img", { style: { width: 15, height: 15 }, src: smallBlueCheckIcon, alt: "check" }) : _jsx(Space, {}), _jsxs("span", Object.assign({ style: { flex: 1, fontSize: 11 } }, { children: [item.label, item.default && item.id === selectedViewInfo.id && isModified && _jsx("span", Object.assign({ style: ModifiedTextSx }, { children: "(Modified)" }))] })), item.isCustom && hoveredCustomView === item.id && (_jsx("img", { src: editIcon, alt: "edit", style: { width: 12, height: 12, cursor: 'pointer' }, onClick: (e) => {
178
+ e.stopPropagation();
179
+ onEditCustomView === null || onEditCustomView === void 0 ? void 0 : onEditCustomView(item);
180
+ } })), !item.isCustom && hasSubmenu(item, defaultColumns) && _jsx("img", { src: blackRightArrowIcon, alt: "arrow", style: { height: 12 } })] }), item.id))), _jsx(Tooltip, Object.assign({ title: "Limit reached. Delete a view to create a new one.", placement: "left", disableHoverListener: !shouldDimNewCustomView }, { children: _jsxs(StyledMenuItem, Object.assign({ sx: {
181
+ border: 'none',
182
+ opacity: shouldDimNewCustomView ? 0.5 : 1,
183
+ cursor: shouldDimNewCustomView ? 'not-allowed' : 'pointer',
184
+ }, onClick: (e) => {
185
+ if (shouldDimNewCustomView) {
186
+ e.stopPropagation();
187
+ return;
188
+ }
189
+ e.stopPropagation();
190
+ handleSubmenuLeave();
191
+ onCreateCustomView === null || onCreateCustomView === void 0 ? void 0 : onCreateCustomView(false);
192
+ } }, { children: [_jsx(Space, {}), _jsxs(Box, Object.assign({ sx: { display: 'flex', alignItems: 'center', gap: 0.5 } }, { children: [_jsx("img", { src: bluePlusIcon, alt: "icon", style: { opacity: shouldDimNewCustomView ? 0.5 : 1, width: 10, height: 10 } }), _jsx("span", Object.assign({ style: { color: shouldDimNewCustomView ? '#999' : '#1F88D0', fontSize: 11, fontWeight: 500 } }, { children: t('New Custom View') }))] })), _jsx(SpaceAfter, {})] })) }))] }) })), hoveredItem && submenuAnchorEl && currentSubmenuColumns.length > 0 && (_jsx(Menu, Object.assign({ open: Boolean(hoveredItem), anchorEl: submenuAnchorEl, placement: "auto-end", onMouseEnter: handleSubmenuEnter, onMouseLeave: handleSubmenuLeave, modifiers: [
193
+ { name: 'offset', options: { offset: [-4, 0] } },
194
+ { name: 'preventOverflow', enabled: true },
195
+ { name: 'flip', enabled: true },
196
+ ] }, { children: _jsxs(SubmenuContainer, { children: [_jsx(ViewsSubmenu, { columns: currentSubmenuColumns, allCurrentSelected: allCurrentSelected, someCurrentSelected: someCurrentSelected, onSelectAll: handleSelectAll, onReset: handleReset, onColumnToggle: toggleColumnSelection, onNestedItemToggle: toggleNestedItem, onReorder: handleReorder, anchorEl: submenuAnchorEl, isModified: hasChanges }), _jsx(SaveCustomViewBox, { children: _jsx(Tooltip, Object.assign({ title: "Limit reached. Delete a view to create a new one.", placement: "left", disableHoverListener: !shouldDimNewCustomView }, { children: _jsxs(SaveCustomViewInnerBox, Object.assign({ disabled: shouldDimNewCustomView, onClick: shouldDimNewCustomView ? undefined : handleSaveAsCustomView }, { children: [_jsx(Typography, Object.assign({ sx: { fontSize: 11, color: 'text.secondary' } }, { children: "Save as a custom view" })), _jsxs(Box, Object.assign({ sx: { display: 'flex', alignItems: 'center', gap: 0.5 } }, { children: [_jsx("img", { src: bluePlusIcon, alt: "add", style: { width: 10, height: 10, opacity: shouldDimNewCustomView ? 0.5 : 1 } }), _jsx(Typography, Object.assign({ sx: { fontSize: 10, fontWeight: 600, color: shouldDimNewCustomView ? '#999' : '#1F88D0' } }, { children: "Custom View" }))] }))] })) })) }), _jsxs(ButtonsContainer, { children: [_jsx(Button, Object.assign({ variant: "text", onClick: handleCancel, sx: CancelButtonSx }, { children: "Cancel" })), _jsx(Button, Object.assign({ variant: "contained", onClick: handleOkay, sx: OkayButtonSx }, { children: "Okay" }))] })] }) })))] })));
197
+ }
198
+ export default React.memo(ViewsDropdown);
@@ -0,0 +1,3 @@
1
+ import React from 'react';
2
+ import type { ColumnListProps } from '../types';
3
+ export declare const ColumnList: React.FC<ColumnListProps>;