@owp/core 2.5.22 → 2.5.24
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/_virtual/index15.js +2 -2
- package/dist/_virtual/index16.js +4 -4
- package/dist/_virtual/index17.js +4 -4
- package/dist/_virtual/index18.js +4 -4
- package/dist/_virtual/index19.js +4 -4
- package/dist/_virtual/index5.js +2 -2
- package/dist/components/OwpCommonCode/OwpCommonCodeQuerySelector.js +15 -13
- package/dist/components/OwpCommonCode/OwpCommonCodeQuerySelector.js.map +1 -1
- package/dist/components/OwpCommonCode/OwpCommonCodeSelector.js +21 -19
- package/dist/components/OwpCommonCode/OwpCommonCodeSelector.js.map +1 -1
- package/dist/components/OwpExportExcelButton/OwpExportExcelButton.js +1 -1
- package/dist/components/OwpExportExcelButton/OwpExportExcelButton.js.map +1 -1
- package/dist/components/OwpLanguageSwitcherSelect/OwpLanguageSwitcherSelect.js +1 -1
- package/dist/components/OwpLanguageSwitcherSelect/OwpLanguageSwitcherSelect.js.map +1 -1
- package/dist/components/OwpLoading/OwpLoading.js +1 -1
- package/dist/components/OwpLoading/OwpLoading.js.map +1 -1
- package/dist/components/OwpMrtTable/OwpMrtTable.js +21 -21
- package/dist/components/OwpMrtTable/OwpMrtTable.js.map +1 -1
- package/dist/components/OwpOptionSelector/OwpOptionSelector.js +14 -12
- package/dist/components/OwpOptionSelector/OwpOptionSelector.js.map +1 -1
- package/dist/components/OwpPageTitle/OwpPageTitle.js +1 -1
- package/dist/components/OwpPageTitle/OwpPageTitle.js.map +1 -1
- package/dist/components/OwpPicker/OwpDatePicker.js +81 -82
- package/dist/components/OwpPicker/OwpDatePicker.js.map +1 -1
- package/dist/components/OwpPicker/OwpTimePicker.js +82 -83
- package/dist/components/OwpPicker/OwpTimePicker.js.map +1 -1
- package/dist/components/OwpPicker/OwpWeekDatePicker.js +24 -25
- package/dist/components/OwpPicker/OwpWeekDatePicker.js.map +1 -1
- package/dist/components/OwpSearchFilter/OwpSearchFilter.js +1 -1
- package/dist/components/OwpSearchFilter/OwpSearchFilter.js.map +1 -1
- package/dist/components/OwpSection/OwpSection.js +1 -1
- package/dist/components/OwpSection/OwpSection.js.map +1 -1
- package/dist/components/OwpSelectorBase/OwpSelectorAutocomplete.js +155 -157
- package/dist/components/OwpSelectorBase/OwpSelectorAutocomplete.js.map +1 -1
- package/dist/components/OwpSelectorBase/OwpSelectorSelect.js +95 -81
- package/dist/components/OwpSelectorBase/OwpSelectorSelect.js.map +1 -1
- package/dist/components/OwpSuspense/OwpSuspense.js +43 -43
- package/dist/components/OwpSuspense/OwpSuspense.js.map +1 -1
- package/dist/components/OwpTable/OwpDataTable.js +13 -12
- package/dist/components/OwpTable/OwpDataTable.js.map +1 -1
- package/dist/components/OwpTable/OwpFieldTable.js +64 -78
- package/dist/components/OwpTable/OwpFieldTable.js.map +1 -1
- package/dist/components/OwpTable/OwpTable.js +56 -55
- package/dist/components/OwpTable/OwpTable.js.map +1 -1
- package/dist/components/OwpTable/internal/OwpTableBase.js +20 -19
- package/dist/components/OwpTable/internal/OwpTableBase.js.map +1 -1
- package/dist/components/OwpTable/internal/defaultTableStyle.js +6 -7
- package/dist/components/OwpTable/internal/defaultTableStyle.js.map +1 -1
- package/dist/components/OwpTable/utils/tableSx.js +16 -6
- package/dist/components/OwpTable/utils/tableSx.js.map +1 -1
- package/dist/components/OwpTreeGrid/OwpTreeGrid.js +105 -104
- package/dist/components/OwpTreeGrid/OwpTreeGrid.js.map +1 -1
- package/dist/components/OwpTreeGrid/internal/hooks/useOwpTreeGridDatePickerEditor.js +55 -56
- package/dist/components/OwpTreeGrid/internal/hooks/useOwpTreeGridDatePickerEditor.js.map +1 -1
- package/dist/components/OwpTreeGrid/internal/treeGridRuntime.js +10 -10
- package/dist/components/OwpTreeGrid/internal/treeGridTheme.js +253 -252
- package/dist/components/OwpTreeGrid/internal/treeGridTheme.js.map +1 -1
- package/dist/constants/table.js +5 -0
- package/dist/constants/table.js.map +1 -0
- package/dist/constants.js +25 -23
- package/dist/constants.js.map +1 -1
- package/dist/contexts/OwpUiProvider.js +5 -5
- package/dist/contexts/OwpUiProvider.js.map +1 -1
- package/dist/hooks/{useAccessTokenGuard.js → internal/useAccessTokenGuard.js} +2 -2
- package/dist/hooks/internal/useAccessTokenGuard.js.map +1 -0
- package/dist/hooks/{useCurrentLanguage.js → internal/useCurrentLanguage.js} +2 -2
- package/dist/hooks/internal/useCurrentLanguage.js.map +1 -0
- package/dist/hooks/internal/useHeaderWrapState.js.map +1 -0
- package/dist/hooks/internal/useNavbar.js +24 -0
- package/dist/hooks/internal/useNavbar.js.map +1 -0
- package/dist/hooks/{useNavigationActiveRouteRemount.js → internal/useNavigationActiveRouteRemount.js} +1 -1
- package/dist/hooks/internal/useNavigationActiveRouteRemount.js.map +1 -0
- package/dist/hooks/{useShortcuts.js → internal/useShortcuts.js} +3 -3
- package/dist/hooks/internal/useShortcuts.js.map +1 -0
- package/dist/hooks/internal/useThemeMediaQuery.js.map +1 -0
- package/dist/hooks/internal/useTimeout.js.map +1 -0
- package/dist/hooks/useInitApp.js.map +1 -1
- package/dist/hooks.js +53 -81
- package/dist/hooks.js.map +1 -1
- package/dist/layout/Layout.js +1 -1
- package/dist/layout/Layout.js.map +1 -1
- package/dist/layout/components/layouts/NavbarToggleFabLayout.js +2 -2
- package/dist/layout/components/layouts/NavbarToggleFabLayout.js.map +1 -1
- package/dist/layout/components/layouts/NavbarWrapperLayout.js +2 -2
- package/dist/layout/components/layouts/NavbarWrapperLayout.js.map +1 -1
- package/dist/layout/components/navbar/NavbarToggleButton.js +2 -2
- package/dist/layout/components/navbar/NavbarToggleButton.js.map +1 -1
- package/dist/layout/components/navbar/style/NavbarStyle.js +1 -1
- package/dist/layout/components/navbar/style/NavbarStyle.js.map +1 -1
- package/dist/layout/components/navbar/style/NavbarStyleContent.js +1 -1
- package/dist/layout/components/navbar/style/NavbarStyleContent.js.map +1 -1
- package/dist/layout/components/navigation/Navigation.js +2 -2
- package/dist/layout/components/navigation/Navigation.js.map +1 -1
- package/dist/layout/components/navigation/vertical/types/NavVerticalCollapse.js +1 -1
- package/dist/layout/components/navigation/vertical/types/NavVerticalCollapse.js.map +1 -1
- package/dist/layout/components/navigation/vertical/types/NavVerticalGroup.js +1 -1
- package/dist/layout/components/navigation/vertical/types/NavVerticalGroup.js.map +1 -1
- package/dist/layout/components/navigation/vertical/types/NavVerticalItem.js +1 -1
- package/dist/layout/components/navigation/vertical/types/NavVerticalItem.js.map +1 -1
- package/dist/layout/components/toggles/LanguageSwitcherToggle.js +1 -1
- package/dist/layout/components/toggles/LanguageSwitcherToggle.js.map +1 -1
- package/dist/layout/components/toggles/NavigationSearchToggle.js +3 -3
- package/dist/layout/components/toggles/NavigationShortcutsToggle.js +1 -1
- package/dist/layout/components/toggles/NavigationShortcutsToggle.js.map +1 -1
- package/dist/node_modules/.pnpm/jsbarcode@3.12.1/node_modules/jsbarcode/bin/barcodes/CODE128/constants.js +1 -1
- package/dist/node_modules/.pnpm/jsbarcode@3.12.1/node_modules/jsbarcode/bin/barcodes/CODE93/constants.js +1 -1
- package/dist/node_modules/.pnpm/jsbarcode@3.12.1/node_modules/jsbarcode/bin/barcodes/EAN_UPC/constants.js +1 -1
- package/dist/node_modules/.pnpm/jsbarcode@3.12.1/node_modules/jsbarcode/bin/barcodes/ITF/constants.js +1 -1
- package/dist/node_modules/.pnpm/jsbarcode@3.12.1/node_modules/jsbarcode/bin/renderers/index.js +1 -1
- package/dist/node_modules/.pnpm/react-is@16.13.1/node_modules/react-is/index.js +1 -1
- package/dist/node_modules/.pnpm/react-overlays@5.2.1_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/react-overlays/esm/Portal.js +1 -1
- package/dist/owp-app.css +1 -1
- package/dist/types/components/OwpCommonCode/OwpCommonCodeQuerySelector.d.ts +5 -3
- package/dist/types/components/OwpCommonCode/OwpCommonCodeSelector.d.ts +5 -3
- package/dist/types/components/OwpOptionSelector/OwpOptionSelector.d.ts +4 -1
- package/dist/types/components/OwpSelectorBase/types/index.d.ts +1 -1
- package/dist/types/components/OwpSelectorBase/types/types.d.ts +3 -0
- package/dist/types/components/OwpTable/internal/defaultTableStyle.d.ts +0 -1
- package/dist/types/components/OwpTable/utils/tableSx.d.ts +15 -0
- package/dist/types/constants/index.d.ts +1 -0
- package/dist/types/constants/table.d.ts +1 -0
- package/dist/types/hooks/index.d.ts +0 -10
- package/dist/types/hooks/{useNavbar.d.ts → internal/useNavbar.d.ts} +1 -1
- package/dist/types/utils/treeGridUtil.d.ts +0 -14
- package/dist/utils/{exceljsBrowser.js → internal/exceljsBrowser.js} +1 -1
- package/dist/utils/internal/exceljsBrowser.js.map +1 -0
- package/dist/utils/internal/jszipBrowser.js.map +1 -0
- package/dist/utils/internal/treeGridBodyRowsEvent.js.map +1 -0
- package/dist/utils/treeGridExportExcelUtil.js +1 -1
- package/dist/utils/treeGridExportExcelUtil.js.map +1 -1
- package/dist/utils/treeGridUtil.js +1 -6
- package/dist/utils/treeGridUtil.js.map +1 -1
- package/dist/utils/zipUtil.js +1 -1
- package/dist/utils/zipUtil.js.map +1 -1
- package/dist/utils.js +70 -75
- package/package.json +1 -1
- package/dist/hooks/useAccessTokenGuard.js.map +0 -1
- package/dist/hooks/useCurrentLanguage.js.map +0 -1
- package/dist/hooks/useDebounce.js +0 -24
- package/dist/hooks/useDebounce.js.map +0 -1
- package/dist/hooks/useDeepCompareEffect.js +0 -38
- package/dist/hooks/useDeepCompareEffect.js.map +0 -1
- package/dist/hooks/useHeaderWrapState.js.map +0 -1
- package/dist/hooks/useNavbar.js +0 -24
- package/dist/hooks/useNavbar.js.map +0 -1
- package/dist/hooks/useNavigationActiveRouteRemount.js.map +0 -1
- package/dist/hooks/usePrevious.js +0 -14
- package/dist/hooks/usePrevious.js.map +0 -1
- package/dist/hooks/useShortcuts.js.map +0 -1
- package/dist/hooks/useThemeMediaQuery.js.map +0 -1
- package/dist/hooks/useTimeout.js.map +0 -1
- package/dist/types/hooks/useDebounce.d.ts +0 -7
- package/dist/types/hooks/useDeepCompareEffect.d.ts +0 -22
- package/dist/types/hooks/usePrevious.d.ts +0 -5
- package/dist/types/utils/dayjsBrowser.d.ts +0 -1
- package/dist/utils/exceljsBrowser.js.map +0 -1
- package/dist/utils/jszipBrowser.js.map +0 -1
- package/dist/utils/treeGridBodyRowsEvent.js.map +0 -1
- /package/dist/hooks/{useHeaderWrapState.js → internal/useHeaderWrapState.js} +0 -0
- /package/dist/hooks/{useThemeMediaQuery.js → internal/useThemeMediaQuery.js} +0 -0
- /package/dist/hooks/{useTimeout.js → internal/useTimeout.js} +0 -0
- /package/dist/types/hooks/{useAccessTokenGuard.d.ts → internal/useAccessTokenGuard.d.ts} +0 -0
- /package/dist/types/hooks/{useCurrentLanguage.d.ts → internal/useCurrentLanguage.d.ts} +0 -0
- /package/dist/types/hooks/{useHeaderWrapState.d.ts → internal/useHeaderWrapState.d.ts} +0 -0
- /package/dist/types/hooks/{useNavigationActiveRouteRemount.d.ts → internal/useNavigationActiveRouteRemount.d.ts} +0 -0
- /package/dist/types/hooks/{useShortcuts.d.ts → internal/useShortcuts.d.ts} +0 -0
- /package/dist/types/hooks/{useThemeMediaQuery.d.ts → internal/useThemeMediaQuery.d.ts} +0 -0
- /package/dist/types/hooks/{useTimeout.d.ts → internal/useTimeout.d.ts} +0 -0
- /package/dist/types/utils/{exceljsBrowser.d.ts → internal/exceljsBrowser.d.ts} +0 -0
- /package/dist/types/utils/{jszipBrowser.d.ts → internal/jszipBrowser.d.ts} +0 -0
- /package/dist/types/utils/{treeGridBodyRowsEvent.d.ts → internal/treeGridBodyRowsEvent.d.ts} +0 -0
- /package/dist/utils/{jszipBrowser.js → internal/jszipBrowser.js} +0 -0
- /package/dist/utils/{treeGridBodyRowsEvent.js → internal/treeGridBodyRowsEvent.js} +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"OwpMrtTable.js","sources":["../../../src/components/OwpMrtTable/OwpMrtTable.tsx"],"sourcesContent":["import ArrowDropDownRoundedIcon from '@mui/icons-material/ArrowDropDownRounded';\nimport UnfoldMoreRoundedIcon from '@mui/icons-material/UnfoldMoreRounded';\nimport GlobalStyles from '@mui/material/GlobalStyles';\nimport {\n resolveOwpGridTheme,\n type OwpResolvedGridThemeConfigType,\n} from '@/constants/gridTheme';\nimport {\n getTreeGridFontFaceStyles,\n} from '@/constants/treeGrid';\nimport { OwpSvgIcon } from '@/components/OwpSvgIcon';\nimport { useGetCurrentLanguage } from '@/hooks/useCurrentLanguage';\nimport { useGetCurrentSettings } from '@/hooks/useOwpSettings';\nimport { useOwpTranslation } from '@/hooks/useOwpTranslation';\nimport type {\n BoxProps,\n CheckboxProps,\n PaperProps,\n RadioProps,\n SvgIconProps,\n TableCellProps,\n TableContainerProps,\n TableProps,\n TableRowProps,\n} from '@mui/material';\nimport clsx from 'clsx';\nimport type { Theme } from '@mui/material/styles';\nimport { defaults as defaultsFC, isArray, isNumber } from 'es-toolkit/compat';\nimport {\n MaterialReactTable,\n type MaterialReactTableProps,\n MRT_BottomToolbar,\n type MRT_Cell,\n type MRT_Column,\n type MRT_Icons,\n type MRT_Row,\n type MRT_RowData,\n type MRT_TableInstance,\n useMaterialReactTable,\n} from 'material-react-table';\nimport { MRT_Localization_KO } from 'material-react-table/locales/ko';\nimport { useMemo } from 'react';\nimport {\n getTreeGridBodyCellSx,\n getTreeGridBodyRowSx,\n getTreeGridContainerSx,\n getTreeGridHeaderCellSx,\n getTreeGridTypographySx,\n TREEGRID_TABLE_BODY_BORDER_COLOR,\n TREEGRID_TABLE_HEADER_BORDER_COLOR,\n} from '../OwpTable/internal/treeGridTableStyle';\nimport { DEFAULT_TABLE_RADIUS } from '../OwpTable/internal/defaultTableStyle';\nimport { OwpTableTotalCount } from '../OwpTable/internal/OwpTableTotalCount';\nimport { toTableRadiusCssValue } from '../OwpTable/utils/tableSx';\nimport { OwpMrtTableNoDataOverlay } from './internal/OwpMrtTableNoDataOverlay';\nimport OwpMrtTableTopToolbar from './internal/OwpMrtTableTopToolbar';\n\ntype PropsWithSx = {\n className?: string;\n sx?: unknown;\n};\n\ntype HeadCellArgs<TData extends MRT_RowData> = {\n column: MRT_Column<TData>;\n table: MRT_TableInstance<TData>;\n};\n\ntype BodyCellArgs<TData extends MRT_RowData> = {\n cell: MRT_Cell<TData>;\n column: MRT_Column<TData>;\n row: MRT_Row<TData>;\n table: MRT_TableInstance<TData>;\n};\n\ntype BodyRowArgs<TData extends MRT_RowData> = {\n isDetailPanel?: boolean;\n row: MRT_Row<TData>;\n staticRowIndex: number;\n table: MRT_TableInstance<TData>;\n};\n\ntype TableInstanceArgs<TData extends MRT_RowData> = {\n table: MRT_TableInstance<TData>;\n};\n\ntype SelectAllCheckboxArgs<TData extends MRT_RowData> = {\n table: MRT_TableInstance<TData>;\n};\n\ntype SelectCheckboxArgs<TData extends MRT_RowData> = {\n row: MRT_Row<TData>;\n staticRowIndex?: number;\n table: MRT_TableInstance<TData>;\n};\n\nexport type OwpMrtTableHeaderCellStyle = {\n backgroundColor?: string;\n color?: string;\n fontSize?: number | string;\n fontWeight?: number | string;\n height?: number | string;\n};\n\ntype DataTableProps<TData extends MRT_RowData> = MaterialReactTableProps<TData> & {\n canHideTotalCountFooterBorder?: boolean;\n canUseNoDataOverlay?: boolean;\n canUseTableRadius?: boolean;\n canTotalCountRow?: boolean;\n canUseTreeGridStyle?: boolean;\n headerCellStyle?: OwpMrtTableHeaderCellStyle;\n tableBorderRadius?: string | number;\n totalCount?: number;\n};\n\nexport type OwpMrtTableProps<TData extends MRT_RowData> = DataTableProps<TData>;\n\nconst treeGridSortIconColor = '#cbd5e1';\n\nconst getResolvedTreeGridHeaderTextSx = (\n treeGridTheme: OwpResolvedGridThemeConfigType,\n headerCellStyle?: OwpMrtTableHeaderCellStyle,\n) => ({\n ...getTreeGridTypographySx(\n headerCellStyle?.fontSize ?? treeGridTheme.header.fontSize,\n headerCellStyle?.fontWeight ?? treeGridTheme.header.fontWeight,\n ),\n color: headerCellStyle?.color ?? treeGridTheme.header.color,\n});\n\nconst getHeaderCellTextStyleSx = (headerCellStyle?: OwpMrtTableHeaderCellStyle) => ({\n color: headerCellStyle?.color,\n fontSize: headerCellStyle?.fontSize,\n fontWeight: headerCellStyle?.fontWeight,\n});\n\nconst getHeaderCellHeightStyleSx = (headerCellStyle?: OwpMrtTableHeaderCellStyle) =>\n headerCellStyle?.height\n ? {\n height: headerCellStyle.height,\n minHeight: headerCellStyle.height,\n }\n : undefined;\n\nconst getHeaderCellBackgroundColor = (headerCellStyle?: OwpMrtTableHeaderCellStyle) =>\n headerCellStyle?.backgroundColor\n ? `${headerCellStyle.backgroundColor} !important`\n : undefined;\n\nconst getHeaderCellOverrideSx = (headerCellStyle?: OwpMrtTableHeaderCellStyle) => {\n const backgroundColor = getHeaderCellBackgroundColor(headerCellStyle);\n const textStyleSx = getHeaderCellTextStyleSx(headerCellStyle);\n const heightStyleSx = getHeaderCellHeightStyleSx(headerCellStyle);\n const contentMinHeight = headerCellStyle?.height ? '100%' : undefined;\n\n return {\n ...textStyleSx,\n ...heightStyleSx,\n backgroundColor,\n '& .Mui-TableHeadCell-Content': {\n ...textStyleSx,\n ...heightStyleSx,\n alignItems: 'center',\n backgroundColor,\n display: 'flex',\n },\n '& .Mui-TableHeadCell-Content-Labels': {\n alignItems: 'center',\n backgroundColor,\n display: 'flex',\n height: headerCellStyle?.height ? '100%' : undefined,\n },\n '& .Mui-TableHeadCell-Content-Wrapper': {\n ...textStyleSx,\n alignItems: 'center',\n backgroundColor,\n display: 'flex',\n minHeight: contentMinHeight,\n },\n '& .MuiTableSortLabel-root': {\n color: headerCellStyle?.color,\n },\n '& .MuiTableSortLabel-root:hover': {\n color: headerCellStyle?.color,\n },\n '& .MuiTableSortLabel-root.Mui-active': {\n color: headerCellStyle?.color,\n },\n '& .MuiTableSortLabel-icon': {\n color: headerCellStyle?.color ? `${headerCellStyle.color} !important` : undefined,\n },\n };\n};\n\nconst mergeSxValues = (...styles: Array<unknown>): unknown => {\n const mergedStyles = styles.flatMap((style) => {\n if (!style) {\n return [];\n }\n\n return isArray(style) ? style : [style];\n });\n\n if (mergedStyles.length === 0) {\n return undefined;\n }\n\n return (theme: Theme) =>\n mergedStyles.reduce<Record<string, unknown>>((acc, style) => {\n const resolvedStyle =\n typeof style === 'function' ? (style as (theme: Theme) => unknown)(theme) : style;\n\n if (!resolvedStyle || isArray(resolvedStyle)) {\n return acc;\n }\n\n return {\n ...acc,\n ...(resolvedStyle as Record<string, unknown>),\n };\n }, {});\n};\n\nconst resolvePropValue = <TArgs, TProps>(\n prop: ((args: TArgs) => TProps) | TProps | undefined,\n args: TArgs,\n): TProps | undefined => {\n if (typeof prop === 'function') {\n return (prop as (args: TArgs) => TProps)(args);\n }\n\n return prop;\n};\n\nconst mergeComponentProps = <TProps extends PropsWithSx>(\n ...propsList: Array<TProps | undefined>\n): TProps => {\n const resolvedProps = propsList.filter(Boolean) as TProps[];\n const mergedProps = resolvedProps.reduce((acc, currentProps) => {\n return {\n ...acc,\n ...currentProps,\n };\n }, {} as TProps);\n\n const className = clsx(resolvedProps.map((currentProps) => currentProps.className));\n const sx = mergeSxValues(...resolvedProps.map((currentProps) => currentProps.sx));\n\n if (className) {\n mergedProps.className = className as TProps['className'];\n }\n\n if (sx) {\n mergedProps.sx = sx as TProps['sx'];\n }\n\n return mergedProps;\n};\n\nconst mergeResolvedProps = <TArgs, TProps extends PropsWithSx>(\n args: TArgs,\n ...propsList: Array<((args: TArgs) => TProps) | TProps | undefined>\n): TProps => {\n return mergeComponentProps(\n ...propsList.map((currentProps) => resolvePropValue<TArgs, TProps>(currentProps, args)),\n );\n};\n\nconst defaultTableIcons: Partial<MRT_Icons> = {\n ArrowDownwardIcon: (props) => (\n <OwpSvgIcon size={20} {...props}>\n heroicons-outline:arrow-down-circle\n </OwpSvgIcon>\n ),\n ClearAllIcon: () => <OwpSvgIcon size={20}>heroicons-outline:adjustments-horizontal</OwpSvgIcon>,\n DensityLargeIcon: () => <OwpSvgIcon size={20}>heroicons-outline:bars-3-bottom-left</OwpSvgIcon>,\n DensityMediumIcon: () => <OwpSvgIcon size={20}>heroicons-outline:bars-3</OwpSvgIcon>,\n DensitySmallIcon: () => <OwpSvgIcon size={20}>heroicons-outline:bars-2</OwpSvgIcon>,\n DragHandleIcon: () => (\n <OwpSvgIcon className=\"rotate-45\" size={14}>\n heroicons-outline:arrows-pointing-out\n </OwpSvgIcon>\n ),\n FilterListIcon: (props) => (\n <OwpSvgIcon size={16} {...props}>\n heroicons-outline:funnel\n </OwpSvgIcon>\n ),\n FilterListOffIcon: () => <OwpSvgIcon size={20}>heroicons-outline:funnel</OwpSvgIcon>,\n FullscreenExitIcon: () => <OwpSvgIcon size={20}>heroicons-outline:arrows-pointing-in</OwpSvgIcon>,\n FullscreenIcon: () => <OwpSvgIcon size={20}>heroicons-outline:arrows-pointing-out</OwpSvgIcon>,\n SearchIcon: (props) => (\n <OwpSvgIcon color=\"action\" size={20} {...props}>\n heroicons-outline:magnifying-glass\n </OwpSvgIcon>\n ),\n SearchOffIcon: () => <OwpSvgIcon size={20}>heroicons-outline:magnifying-glass</OwpSvgIcon>,\n ViewColumnIcon: () => <OwpSvgIcon size={20}>heroicons-outline:view-columns</OwpSvgIcon>,\n MoreVertIcon: () => <OwpSvgIcon size={20}>heroicons-outline:ellipsis-vertical</OwpSvgIcon>,\n MoreHorizIcon: () => <OwpSvgIcon size={20}>heroicons-outline:ellipsis-horizontal</OwpSvgIcon>,\n SortIcon: (props) => (\n <OwpSvgIcon size={20} {...props}>\n heroicons-outline:arrows-up-down\n </OwpSvgIcon>\n ),\n PushPinIcon: (props) => (\n <OwpSvgIcon size={20} {...props}>\n heroicons-outline:bookmark\n </OwpSvgIcon>\n ),\n VisibilityOffIcon: () => <OwpSvgIcon size={20}>heroicons-outline:eye-slash</OwpSvgIcon>,\n};\n\nconst TreeGridArrowDownwardIcon = (props: SvgIconProps) => {\n return <ArrowDropDownRoundedIcon fontSize=\"small\" {...props} />;\n};\n\nconst TreeGridSyncAltIcon = (props: SvgIconProps & { direction?: string }) => {\n const { direction, ...iconProps } = props;\n\n void direction;\n\n return <UnfoldMoreRoundedIcon fontSize=\"small\" {...iconProps} />;\n};\n\nconst treeGridTableIcons: Partial<MRT_Icons> = {\n ArrowDownwardIcon: TreeGridArrowDownwardIcon,\n SyncAltIcon: TreeGridSyncAltIcon,\n};\n\nconst defaultBottomToolbarProps: BoxProps = {\n className: 'flex items-center min-h-56 h-56',\n};\n\nconst defaultPaperProps: PaperProps = {\n elevation: 0,\n square: true,\n className: 'flex flex-col flex-auto h-full',\n};\n\nconst getTreeGridPaperProps = (\n treeGridTheme: OwpResolvedGridThemeConfigType,\n): PaperProps => ({\n sx: {\n ...getTreeGridContainerSx(treeGridTheme),\n display: 'flex',\n height: '100%',\n flexDirection: 'column',\n border: `1px solid ${TREEGRID_TABLE_BODY_BORDER_COLOR}`,\n borderRadius: 0,\n boxShadow: 'none',\n },\n});\n\nconst totalCountFooterBorderlessPaperProps: PaperProps = {\n sx: {\n border: 0,\n },\n};\n\nconst getTotalCountFooterBorderlessContainerProps = (): TableContainerProps => ({\n sx: {\n borderTop: `1px solid ${TREEGRID_TABLE_BODY_BORDER_COLOR}`,\n borderRight: `1px solid ${TREEGRID_TABLE_BODY_BORDER_COLOR}`,\n borderLeft: `1px solid ${TREEGRID_TABLE_BODY_BORDER_COLOR}`,\n },\n});\n\nconst defaultContainerProps: TableContainerProps = {\n className: 'flex-auto',\n};\n\nconst getTableRadiusPaperProps = (tableBorderRadius: string | number): PaperProps => ({\n square: false,\n sx: {\n borderRadius: toTableRadiusCssValue(tableBorderRadius),\n overflow: 'hidden',\n },\n});\n\nconst tableRadiusContainerProps: TableContainerProps = {\n sx: {\n borderRadius: 'inherit',\n },\n};\n\nconst treeGridSelectColumnWidth = 40;\n\nconst treeGridSelectColumnCellSx = {\n width: treeGridSelectColumnWidth,\n minWidth: treeGridSelectColumnWidth,\n maxWidth: treeGridSelectColumnWidth,\n} as const;\n\nconst treeGridContainerProps: TableContainerProps = {\n sx: {\n flex: 1,\n minHeight: 0,\n overflowX: 'hidden',\n overflowY: 'auto',\n },\n};\n\nconst getTreeGridHeadRowProps = (\n headerCellStyle?: OwpMrtTableHeaderCellStyle,\n): TableRowProps => ({\n sx: {\n backgroundColor: headerCellStyle?.backgroundColor,\n boxShadow: 'none',\n },\n});\n\nconst defaultSelectCheckboxProps: CheckboxProps = {\n className: 'w-48',\n};\n\nconst treeGridSelectCheckboxProps: CheckboxProps = {\n sx: {\n display: 'flex',\n m: 0,\n mx: 'auto',\n },\n};\n\nconst getTreeGridTableProps = (\n treeGridTheme: OwpResolvedGridThemeConfigType,\n): TableProps => ({\n sx: {\n ...getTreeGridContainerSx(treeGridTheme),\n borderSpacing: 0,\n width: '100%',\n tableLayout: 'fixed',\n '& .MuiTableHead-root .MuiTableCell-root': {\n ...getTreeGridHeaderCellSx(treeGridTheme),\n py: 0.75,\n wordBreak: 'keep-all',\n },\n '& .MuiTableHead-root .MuiTableRow-root:first-of-type .MuiTableCell-root:first-of-type': {\n borderLeft: `1px solid ${TREEGRID_TABLE_HEADER_BORDER_COLOR}`,\n },\n '& .MuiTableHead-root .MuiTableRow-root:first-of-type .MuiTableCell-root:last-of-type': {\n borderRight: `1px solid ${TREEGRID_TABLE_HEADER_BORDER_COLOR}`,\n },\n '& .MuiTableHead-root .MuiIconButton-root': {\n display: 'none',\n },\n '& .MuiTableBody-root .MuiTableCell-root': {\n backgroundColor: treeGridTheme.row.backgroundColor,\n color: treeGridTheme.body.color,\n p: 0,\n verticalAlign: 'middle',\n borderRight: `1px solid ${TREEGRID_TABLE_BODY_BORDER_COLOR}`,\n borderBottom: `1px solid ${TREEGRID_TABLE_BODY_BORDER_COLOR}`,\n overflowWrap: 'anywhere',\n },\n '& .MuiTableBody-root .MuiTableCell-root:last-of-type': {\n borderRight: 'none',\n },\n },\n});\n\nconst treeGridTableRadiusProps: TableProps = {\n sx: {\n '& .MuiTableHead-root .MuiTableCell-root': {\n borderTop: 'none',\n },\n '& .MuiTableHead-root .MuiTableRow-root .MuiTableCell-root + .MuiTableCell-root': {\n borderLeft: '1px solid',\n borderLeftColor: 'divider',\n },\n '& .MuiTableHead-root .MuiTableRow-root:first-of-type .MuiTableCell-root:first-of-type': {\n borderLeft: 'none',\n },\n '& .MuiTableHead-root .MuiTableRow-root:first-of-type .MuiTableCell-root:last-of-type': {\n borderRight: 'none',\n },\n },\n};\n\nconst treeGridTableRadiusBottomEdgeProps: TableProps = {\n sx: {\n '& .MuiTableBody-root .MuiTableRow-root:last-of-type .MuiTableCell-root': {\n borderBottom: 'none',\n },\n },\n};\n\nconst getDefaultBodyRowProps = <TData extends MRT_RowData>({\n row,\n table,\n}: BodyRowArgs<TData>): TableRowProps => {\n const { density } = table.getState();\n\n if (density === 'compact') {\n return {\n sx: {\n backgroundColor: 'initial',\n opacity: 1,\n boxShadow: 'none',\n height: row.getIsPinned() ? `${37}px` : undefined,\n },\n };\n }\n\n return {\n sx: {\n backgroundColor: 'initial',\n opacity: 1,\n boxShadow: 'none',\n height: row.getIsPinned() ? `${density === 'comfortable' ? 53 : 69}px` : undefined,\n },\n };\n};\n\nconst getDefaultHeadCellProps = <TData extends MRT_RowData>(\n { column }: HeadCellArgs<TData>,\n headerCellStyle?: OwpMrtTableHeaderCellStyle,\n): TableCellProps => {\n const headerCellBackgroundColor = getHeaderCellBackgroundColor(headerCellStyle);\n\n return {\n sx: {\n '& .Mui-TableHeadCell-Content-Labels': {\n flex: 1,\n justifyContent: 'space-between',\n },\n '& .Mui-TableHeadCell-Content-Actions': {\n '& > button': {\n marginX: '2px',\n },\n },\n '& .MuiFormHelperText-root': {\n textAlign: 'center',\n marginX: 0,\n color: (theme: Theme) => theme.palette.text.disabled,\n fontSize: 11,\n },\n ...getHeaderCellOverrideSx(headerCellStyle),\n backgroundColor: (theme) =>\n headerCellBackgroundColor ??\n (column.getIsPinned() ? theme.palette.background.paper : 'inherit'),\n },\n };\n};\n\nconst getTreeGridHeadCellProps = <TData extends MRT_RowData>(\n { column }: HeadCellArgs<TData>,\n treeGridTheme: OwpResolvedGridThemeConfigType,\n headerCellStyle?: OwpMrtTableHeaderCellStyle,\n): TableCellProps => {\n const isSelectColumn = column.id === 'mrt-row-select';\n const resolvedHeaderTextSx = getResolvedTreeGridHeaderTextSx(treeGridTheme, headerCellStyle);\n const resolvedSortIconColor = headerCellStyle?.color ?? treeGridSortIconColor;\n const headerHeightStyleSx = getHeaderCellHeightStyleSx(headerCellStyle);\n const contentMinHeight = headerCellStyle?.height ? '100%' : undefined;\n\n return {\n align: 'center',\n sx: {\n ...(isSelectColumn ? treeGridSelectColumnCellSx : {}),\n ...resolvedHeaderTextSx,\n ...getHeaderCellOverrideSx(headerCellStyle),\n backgroundColor: getHeaderCellBackgroundColor(headerCellStyle),\n '& .Mui-TableHeadCell-Content': {\n ...resolvedHeaderTextSx,\n ...headerHeightStyleSx,\n alignItems: 'center',\n backgroundColor: 'inherit',\n display: 'flex',\n justifyContent: 'center',\n position: 'relative',\n width: '100%',\n },\n '& .Mui-TableHeadCell-Content-Labels': {\n alignItems: 'center',\n backgroundColor: 'inherit',\n display: 'flex',\n flex: 1,\n justifyContent: 'center',\n maxWidth: '100%',\n minWidth: 0,\n overflow: 'hidden',\n position: 'relative',\n pl: 0,\n pr: isSelectColumn ? 0 : '24px',\n height: headerCellStyle?.height ? '100%' : undefined,\n width: '100%',\n },\n '& .Mui-TableHeadCell-Content-Wrapper': {\n ...resolvedHeaderTextSx,\n alignItems: 'center',\n backgroundColor: 'inherit',\n display: 'flex',\n minHeight: contentMinHeight,\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n },\n '&& .MuiBadge-root': isSelectColumn\n ? undefined\n : {\n alignItems: 'center',\n display: 'inline-flex',\n justifyContent: 'center',\n position: 'absolute',\n pointerEvents: 'none',\n right: '6px',\n top: '50%',\n transform: 'translateY(-50%)',\n width: '16px',\n },\n '&& .MuiTableSortLabel-root': {\n alignItems: 'center',\n color: resolvedSortIconColor,\n display: 'inline-flex',\n justifyContent: 'center',\n minWidth: '16px',\n opacity: '1 !important',\n overflow: 'visible',\n width: '16px',\n },\n '&& .MuiTableSortLabel-root:hover': {\n color: resolvedSortIconColor,\n },\n '&& .MuiTableSortLabel-root.Mui-active': {\n color: resolvedSortIconColor,\n },\n '&& .MuiTableSortLabel-icon': {\n color: `${resolvedSortIconColor} !important`,\n display: 'block',\n fontSize: '18px',\n margin: 0,\n opacity: '1 !important',\n overflow: 'visible',\n },\n '& .MuiButtonBase-root': isSelectColumn\n ? {\n display: 'flex',\n margin: '0 auto',\n }\n : undefined,\n },\n };\n};\n\nconst getTreeGridBodyCellProps = <TData extends MRT_RowData>(\n { column }: BodyCellArgs<TData>,\n treeGridTheme: OwpResolvedGridThemeConfigType,\n): TableCellProps => {\n const treeGridBodyCellSx = { ...getTreeGridBodyCellSx(treeGridTheme) };\n\n Reflect.deleteProperty(treeGridBodyCellSx, 'padding');\n Reflect.deleteProperty(treeGridBodyCellSx, 'borderBottom');\n Reflect.deleteProperty(treeGridBodyCellSx, 'borderLeft');\n Reflect.deleteProperty(treeGridBodyCellSx, 'borderRight');\n\n if (column.id !== 'mrt-row-select') {\n return {\n sx: treeGridBodyCellSx,\n };\n }\n\n return {\n align: 'center',\n sx: {\n ...treeGridBodyCellSx,\n ...treeGridSelectColumnCellSx,\n '& > .MuiButtonBase-root, & .MuiButtonBase-root': {\n display: 'flex',\n margin: '0 auto',\n },\n },\n };\n};\n\nconst tableBodyTabNavigableFieldSelector = [\n 'tbody td input:not([type=\"hidden\"])',\n 'tbody td textarea',\n 'tbody td [contenteditable=\"true\"]',\n 'tbody td [role=\"combobox\"]',\n].join(', ');\n\ntype TableBodyCellKeyDownCaptureEvent = Parameters<\n NonNullable<TableCellProps['onKeyDownCapture']>\n>[0];\n\n/**\n * 테이블 본문 입력 가능 필드 여부 판별\n * @param element 포커스 후보 요소\n */\nconst isTabNavigableTableBodyField = (element: HTMLElement) => {\n if (element.tabIndex < 0) {\n return false;\n }\n\n if (element.getAttribute('aria-disabled') === 'true') {\n return false;\n }\n\n if (element.getAttribute('aria-readonly') === 'true') {\n return false;\n }\n\n if (element instanceof HTMLInputElement || element instanceof HTMLTextAreaElement) {\n if (element.disabled || element.readOnly) {\n return false;\n }\n }\n\n if (element instanceof HTMLSelectElement && element.disabled) {\n return false;\n }\n\n if (element instanceof HTMLInputElement) {\n if (\n ['button', 'checkbox', 'file', 'hidden', 'radio', 'reset', 'submit'].includes(element.type)\n ) {\n return false;\n }\n }\n\n return element.getClientRects().length > 0;\n};\n\n/**\n * 테이블 본문 기준 현재 포커스 입력 필드 조회\n * @param target 키 이벤트 target\n */\nconst getCurrentTableBodyField = (target: EventTarget | null) => {\n if (!(target instanceof Element)) {\n return null;\n }\n\n const currentField = target.matches(tableBodyTabNavigableFieldSelector)\n ? target\n : target.closest(tableBodyTabNavigableFieldSelector);\n\n return currentField instanceof HTMLElement && isTabNavigableTableBodyField(currentField)\n ? currentField\n : null;\n};\n\n/**\n * 테이블 본문 입력 필드 Tab 이동 처리\n * @param event body cell keydown capture event\n */\nconst handleTableBodyFieldTabNavigation = (event: TableBodyCellKeyDownCaptureEvent) => {\n if (event.key !== 'Tab' || event.altKey || event.ctrlKey || event.metaKey) {\n return;\n }\n\n const currentField = getCurrentTableBodyField(event.target);\n\n if (!currentField) {\n return;\n }\n\n const tableElement = currentField.closest('table');\n\n if (!tableElement) {\n return;\n }\n\n const fields = Array.from(\n tableElement.querySelectorAll<HTMLElement>(tableBodyTabNavigableFieldSelector),\n ).filter(isTabNavigableTableBodyField);\n\n const currentIndex = fields.indexOf(currentField);\n\n if (currentIndex < 0) {\n return;\n }\n\n const nextField = fields[currentIndex + (event.shiftKey ? -1 : 1)];\n\n if (!nextField) {\n return;\n }\n\n event.preventDefault();\n\n queueMicrotask(() => {\n if (document.contains(nextField)) {\n nextField.focus();\n }\n });\n};\n\n/**\n * MRT 기반 공통 테이블 렌더 함수\n * @param props Material React Table props\n */\nfunction DataTable<TData extends MRT_RowData>(props: DataTableProps<TData>) {\n const { t } = useOwpTranslation();\n const currentSettings = useGetCurrentSettings();\n const {\n canHideTotalCountFooterBorder = false,\n canUseNoDataOverlay = false,\n canUseTableRadius = false,\n canTotalCountRow = true,\n canUseTreeGridStyle = true,\n columns,\n data,\n headerCellStyle,\n tableBorderRadius = DEFAULT_TABLE_RADIUS,\n totalCount,\n ...rest\n } = props;\n\n const {\n icons: restIcons,\n initialState: restInitialState,\n muiBottomToolbarProps: restBottomToolbarProps,\n muiSelectAllCheckboxProps: restSelectAllCheckboxProps,\n muiSelectCheckboxProps: restSelectCheckboxProps,\n displayColumnDefOptions: restDisplayColumnDefOptions,\n muiTableBodyCellProps: restTableBodyCellProps,\n muiTableBodyRowProps: restTableBodyRowProps,\n muiTableContainerProps: restTableContainerProps,\n muiTableHeadCellProps: restTableHeadCellProps,\n muiTableHeadRowProps: restTableHeadRowProps,\n muiTablePaperProps: restTablePaperProps,\n muiTableProps: restTableProps,\n renderBottomToolbar: restRenderBottomToolbar,\n renderEmptyRowsFallback: restRenderEmptyRowsFallback,\n ...restOptions\n } = rest;\n\n const resolvedData = isArray(data) ? data : [];\n const treeGridTheme = useMemo(\n () => resolveOwpGridTheme(currentSettings?.theme?.main?.grid),\n [currentSettings],\n );\n const resolvedHeaderCellStyle = useMemo<OwpMrtTableHeaderCellStyle | undefined>(() => {\n if (!canUseTreeGridStyle) {\n return headerCellStyle;\n }\n\n return {\n backgroundColor: headerCellStyle?.backgroundColor ?? treeGridTheme.header.backgroundColor,\n color: headerCellStyle?.color ?? treeGridTheme.header.color,\n fontSize: headerCellStyle?.fontSize ?? treeGridTheme.header.fontSize,\n fontWeight: headerCellStyle?.fontWeight ?? treeGridTheme.header.fontWeight,\n height: headerCellStyle?.height ?? treeGridTheme.header.height,\n };\n }, [canUseTreeGridStyle, headerCellStyle, treeGridTheme]);\n const isNoDataOverlayVisible = isArray(data) && data.length === 0;\n const shouldHideTotalCountFooterBorder = canUseTreeGridStyle || canHideTotalCountFooterBorder;\n const shouldApplyTotalCountFooterBorderlessLayout =\n canTotalCountRow && shouldHideTotalCountFooterBorder;\n const shouldUseNoDataOverlay = canUseTreeGridStyle || canUseNoDataOverlay;\n const shouldUseRadiusOuterBorder = canUseTreeGridStyle && canUseTableRadius;\n const displayColumnDefOptions = canUseTreeGridStyle\n ? {\n ...(restDisplayColumnDefOptions ?? {}),\n 'mrt-row-select': {\n header: '',\n size: treeGridSelectColumnWidth,\n minSize: treeGridSelectColumnWidth,\n maxSize: treeGridSelectColumnWidth,\n ...(restDisplayColumnDefOptions?.['mrt-row-select'] ?? {}),\n },\n }\n : restDisplayColumnDefOptions;\n\n const initialState = defaultsFC(\n { ...(restInitialState ?? {}) },\n {\n density: canUseTreeGridStyle ? 'compact' : 'spacious',\n showColumnFilters: false,\n showGlobalFilter: !canUseTreeGridStyle,\n columnPinning: {\n left: ['mrt-row-expand', 'mrt-row-select'],\n right: ['mrt-row-actions'],\n },\n pagination: {\n pageSize: 15,\n },\n enableFullScreenToggle: false,\n },\n );\n\n const defaultOptions = defaultsFC(\n {\n ...restOptions,\n displayColumnDefOptions,\n initialState,\n },\n {\n displayColumnDefOptions,\n initialState,\n layoutMode: canUseTreeGridStyle ? 'semantic' : undefined,\n enablePagination: canUseTreeGridStyle ? false : undefined,\n enableBottomToolbar: canUseTreeGridStyle ? false : undefined,\n enableTopToolbar: canUseTreeGridStyle ? false : undefined,\n enableColumnActions: canUseTreeGridStyle ? false : undefined,\n enableColumnDragging: canUseTreeGridStyle ? false : undefined,\n enableColumnFilters: canUseTreeGridStyle ? false : undefined,\n enableColumnOrdering: canUseTreeGridStyle ? false : true,\n enableDensityToggle: canUseTreeGridStyle ? false : undefined,\n enableFullScreenToggle: false,\n enableGlobalFilter: canUseTreeGridStyle ? false : undefined,\n enableGrouping: canUseTreeGridStyle ? false : true,\n enableHiding: canUseTreeGridStyle ? false : undefined,\n enableColumnPinning: canUseTreeGridStyle ? false : true,\n enableFacetedValues: canUseTreeGridStyle ? false : true,\n enableMultiRowSelection: canUseTreeGridStyle ? true : undefined,\n enableRowActions: canUseTreeGridStyle ? false : true,\n enableRowSelection: true,\n enableRowDragging: canUseTreeGridStyle ? false : undefined,\n enableRowOrdering: canUseTreeGridStyle ? false : undefined,\n enableSelectAll: canUseTreeGridStyle ? false : undefined,\n enableStickyHeader: true,\n enableToolbarInternalActions: canUseTreeGridStyle ? false : undefined,\n getRowId: canUseTreeGridStyle\n ? (row: TData) => String((row as TData & { id: string | number }).id)\n : undefined,\n paginationDisplayMode: 'pages',\n positionToolbarAlertBanner: 'top',\n muiPaginationProps: {\n color: 'secondary',\n rowsPerPageOptions: [10, 20, 30],\n shape: 'rounded',\n variant: 'outlined',\n showRowsPerPage: false,\n },\n muiSearchTextFieldProps: {\n placeholder: 'Search',\n sx: { minWidth: '300px' },\n variant: 'outlined',\n size: 'small',\n },\n muiFilterTextFieldProps: {\n variant: 'outlined',\n size: 'small',\n sx: {\n '& .MuiInputBase-root': {\n padding: '0px 8px',\n height: '32px!important',\n minHeight: '32px!important',\n },\n },\n },\n mrtTheme: (theme: Theme) => ({\n baseBackgroundColor: theme.palette.background.paper,\n menuBackgroundColor: theme.palette.background.paper,\n pinnedRowBackgroundColor: theme.palette.background.paper,\n pinnedColumnBackgroundColor: theme.palette.background.paper,\n }),\n renderTopToolbar: (toolbarProps: { table: MRT_TableInstance<TData> }) => (\n <OwpMrtTableTopToolbar {...toolbarProps} />\n ),\n } as Partial<DataTableProps<TData>>,\n );\n\n const shouldRenderBaseBottomToolbar = defaultOptions.enableBottomToolbar !== false;\n const resolvedTotalCount = isNumber(totalCount) ? totalCount : resolvedData.length;\n const shouldHideLastBodyRowBorderForRadius =\n shouldUseRadiusOuterBorder && !canTotalCountRow && !shouldRenderBaseBottomToolbar;\n\n const renderBaseBottomToolbar = (table: MRT_TableInstance<TData>) => {\n if (!shouldRenderBaseBottomToolbar) {\n return null;\n }\n\n if (typeof restRenderBottomToolbar === 'function') {\n return restRenderBottomToolbar({ table });\n }\n\n return restRenderBottomToolbar ?? <MRT_BottomToolbar table={table} />;\n };\n\n const getResolvedBodyCellProps = (args: BodyCellArgs<TData>) => {\n const mergedProps = mergeResolvedProps<BodyCellArgs<TData>, TableCellProps>(\n args,\n canUseTreeGridStyle\n ? (nextArgs) => getTreeGridBodyCellProps(nextArgs, treeGridTheme)\n : undefined,\n restTableBodyCellProps,\n );\n const { onKeyDownCapture, ...restMergedProps } = mergedProps;\n\n return {\n ...restMergedProps,\n onKeyDownCapture: (event: TableBodyCellKeyDownCaptureEvent) => {\n onKeyDownCapture?.(event);\n\n if (event.defaultPrevented || event.isPropagationStopped()) {\n return;\n }\n\n handleTableBodyFieldTabNavigation(event);\n },\n } satisfies TableCellProps;\n };\n\n const getResolvedBodyRowProps = (args: BodyRowArgs<TData>) =>\n mergeResolvedProps<BodyRowArgs<TData>, TableRowProps>(\n args,\n getDefaultBodyRowProps,\n canUseTreeGridStyle\n ? () =>\n ({\n sx: getTreeGridBodyRowSx(treeGridTheme, {\n canHover: true,\n selected: args.row.getIsSelected(),\n }),\n }) satisfies TableRowProps\n : undefined,\n restTableBodyRowProps,\n );\n\n const getResolvedHeadRowProps = () => {\n if (!resolvedHeaderCellStyle?.backgroundColor) {\n return undefined;\n }\n\n return {\n sx: {\n backgroundColor: `${resolvedHeaderCellStyle.backgroundColor} !important`,\n },\n } satisfies TableRowProps;\n };\n\n const table = useMaterialReactTable<TData>({\n ...defaultOptions,\n columns,\n data: resolvedData,\n enableBottomToolbar: canTotalCountRow ? true : defaultOptions.enableBottomToolbar,\n icons: {\n ...defaultTableIcons,\n ...(canUseTreeGridStyle ? treeGridTableIcons : {}),\n ...(restIcons ?? {}),\n },\n muiBottomToolbarProps: (args: TableInstanceArgs<TData>) =>\n mergeResolvedProps<TableInstanceArgs<TData>, BoxProps>(\n args,\n defaultBottomToolbarProps,\n restBottomToolbarProps,\n ),\n muiSelectAllCheckboxProps: (args: SelectAllCheckboxArgs<TData>) =>\n mergeResolvedProps<SelectAllCheckboxArgs<TData>, CheckboxProps>(\n args,\n defaultSelectCheckboxProps,\n canUseTreeGridStyle ? treeGridSelectCheckboxProps : undefined,\n restSelectAllCheckboxProps,\n ),\n muiSelectCheckboxProps: (args: SelectCheckboxArgs<TData>) =>\n mergeResolvedProps<SelectCheckboxArgs<TData>, CheckboxProps | RadioProps>(\n args,\n defaultSelectCheckboxProps,\n canUseTreeGridStyle ? treeGridSelectCheckboxProps : undefined,\n restSelectCheckboxProps,\n ),\n muiTableBodyCellProps: (args: BodyCellArgs<TData>) => getResolvedBodyCellProps(args),\n muiTableBodyRowProps: (args: BodyRowArgs<TData>) => getResolvedBodyRowProps(args),\n muiTableContainerProps: (args: TableInstanceArgs<TData>) =>\n mergeResolvedProps<TableInstanceArgs<TData>, TableContainerProps>(\n args,\n defaultContainerProps,\n canUseTreeGridStyle ? treeGridContainerProps : undefined,\n canUseTreeGridStyle ? { sx: getTreeGridContainerSx(treeGridTheme) } : undefined,\n canUseTableRadius ? tableRadiusContainerProps : undefined,\n restTableContainerProps,\n shouldApplyTotalCountFooterBorderlessLayout && !shouldUseRadiusOuterBorder\n ? getTotalCountFooterBorderlessContainerProps()\n : undefined,\n ),\n muiTableHeadRowProps: (args) =>\n mergeResolvedProps(\n args,\n canUseTreeGridStyle ? getTreeGridHeadRowProps(resolvedHeaderCellStyle) : undefined,\n getResolvedHeadRowProps(),\n restTableHeadRowProps,\n ),\n muiTableHeadCellProps: (args: HeadCellArgs<TData>) =>\n mergeResolvedProps<HeadCellArgs<TData>, TableCellProps>(\n args,\n (nextArgs) => getDefaultHeadCellProps(nextArgs, resolvedHeaderCellStyle),\n canUseTreeGridStyle\n ? (nextArgs) => getTreeGridHeadCellProps(nextArgs, treeGridTheme, resolvedHeaderCellStyle)\n : undefined,\n restTableHeadCellProps,\n ),\n muiTablePaperProps: (args: TableInstanceArgs<TData>) =>\n mergeResolvedProps<TableInstanceArgs<TData>, PaperProps>(\n args,\n defaultPaperProps,\n canUseTreeGridStyle ? getTreeGridPaperProps(treeGridTheme) : undefined,\n canUseTableRadius ? getTableRadiusPaperProps(tableBorderRadius) : undefined,\n restTablePaperProps,\n shouldApplyTotalCountFooterBorderlessLayout && !shouldUseRadiusOuterBorder\n ? totalCountFooterBorderlessPaperProps\n : undefined,\n ),\n muiTableProps: (args: TableInstanceArgs<TData>) =>\n mergeResolvedProps<TableInstanceArgs<TData>, TableProps>(\n args,\n canUseTreeGridStyle ? getTreeGridTableProps(treeGridTheme) : undefined,\n shouldUseRadiusOuterBorder ? treeGridTableRadiusProps : undefined,\n shouldHideLastBodyRowBorderForRadius ? treeGridTableRadiusBottomEdgeProps : undefined,\n restTableProps,\n ),\n renderBottomToolbar: canTotalCountRow\n ? ({ table }) => (\n <>\n {renderBaseBottomToolbar(table)}\n <OwpTableTotalCount totalCount={resolvedTotalCount} />\n </>\n )\n : restRenderBottomToolbar,\n renderEmptyRowsFallback: shouldUseNoDataOverlay ? () => <></> : restRenderEmptyRowsFallback,\n });\n\n return (\n <>\n {canUseTreeGridStyle && <GlobalStyles styles={getTreeGridFontFaceStyles()} />}\n <MaterialReactTable table={table} />\n {shouldUseNoDataOverlay && (\n <OwpMrtTableNoDataOverlay\n visible={isNoDataOverlayVisible}\n message={t('Message.조회된 결과가 없습니다.')}\n table={table}\n />\n )}\n </>\n );\n}\n\nconst hasTableInstance = <TData extends MRT_RowData>(\n props: OwpMrtTableProps<TData>,\n): props is OwpMrtTableProps<TData> & { table: MRT_TableInstance<TData> } => {\n return 'table' in props && props.table !== undefined;\n};\n\n/**\n * MRT 기반 공통 테이블 컴포넌트\n * @param props 컴포넌트 props\n */\nconst OwpMrtTable = <TData extends MRT_RowData>(props: OwpMrtTableProps<TData>) => {\n const currentLanguage = useGetCurrentLanguage();\n\n if (hasTableInstance(props)) {\n return <MaterialReactTable table={props.table} />;\n }\n\n return (\n <DataTable<TData>\n {...props}\n localization={\n props.localization ?? (currentLanguage.id === 'kr' ? MRT_Localization_KO : undefined)\n }\n />\n );\n};\n\nexport { OwpMrtTable };\n"],"names":["treeGridSortIconColor","getResolvedTreeGridHeaderTextSx","__name","treeGridTheme","headerCellStyle","getTreeGridTypographySx","getHeaderCellTextStyleSx","getHeaderCellHeightStyleSx","getHeaderCellBackgroundColor","getHeaderCellOverrideSx","backgroundColor","textStyleSx","heightStyleSx","contentMinHeight","mergeSxValues","styles","mergedStyles","style","isArray","theme","acc","resolvedStyle","resolvePropValue","prop","args","mergeComponentProps","propsList","resolvedProps","mergedProps","currentProps","className","clsx","sx","mergeResolvedProps","defaultTableIcons","props","jsx","OwpSvgIcon","TreeGridArrowDownwardIcon","ArrowDropDownRoundedIcon","TreeGridSyncAltIcon","direction","iconProps","UnfoldMoreRoundedIcon","treeGridTableIcons","defaultBottomToolbarProps","defaultPaperProps","getTreeGridPaperProps","getTreeGridContainerSx","TREEGRID_TABLE_BODY_BORDER_COLOR","totalCountFooterBorderlessPaperProps","getTotalCountFooterBorderlessContainerProps","defaultContainerProps","getTableRadiusPaperProps","tableBorderRadius","toTableRadiusCssValue","tableRadiusContainerProps","treeGridSelectColumnWidth","treeGridSelectColumnCellSx","treeGridContainerProps","getTreeGridHeadRowProps","defaultSelectCheckboxProps","treeGridSelectCheckboxProps","getTreeGridTableProps","getTreeGridHeaderCellSx","TREEGRID_TABLE_HEADER_BORDER_COLOR","treeGridTableRadiusProps","treeGridTableRadiusBottomEdgeProps","getDefaultBodyRowProps","row","table","density","getDefaultHeadCellProps","column","headerCellBackgroundColor","getTreeGridHeadCellProps","isSelectColumn","resolvedHeaderTextSx","resolvedSortIconColor","headerHeightStyleSx","getTreeGridBodyCellProps","treeGridBodyCellSx","getTreeGridBodyCellSx","tableBodyTabNavigableFieldSelector","isTabNavigableTableBodyField","element","getCurrentTableBodyField","target","currentField","handleTableBodyFieldTabNavigation","event","tableElement","fields","currentIndex","nextField","DataTable","t","useOwpTranslation","currentSettings","useGetCurrentSettings","canHideTotalCountFooterBorder","canUseNoDataOverlay","canUseTableRadius","canTotalCountRow","canUseTreeGridStyle","columns","data","DEFAULT_TABLE_RADIUS","totalCount","rest","restIcons","restInitialState","restBottomToolbarProps","restSelectAllCheckboxProps","restSelectCheckboxProps","restDisplayColumnDefOptions","restTableBodyCellProps","restTableBodyRowProps","restTableContainerProps","restTableHeadCellProps","restTableHeadRowProps","restTablePaperProps","restTableProps","restRenderBottomToolbar","restRenderEmptyRowsFallback","restOptions","resolvedData","useMemo","resolveOwpGridTheme","_b","_a","resolvedHeaderCellStyle","isNoDataOverlayVisible","shouldApplyTotalCountFooterBorderlessLayout","shouldUseNoDataOverlay","shouldUseRadiusOuterBorder","displayColumnDefOptions","initialState","defaultsFC","defaultOptions","toolbarProps","OwpMrtTableTopToolbar","shouldRenderBaseBottomToolbar","resolvedTotalCount","isNumber","shouldHideLastBodyRowBorderForRadius","renderBaseBottomToolbar","MRT_BottomToolbar","getResolvedBodyCellProps","nextArgs","onKeyDownCapture","restMergedProps","getResolvedBodyRowProps","getTreeGridBodyRowSx","getResolvedHeadRowProps","useMaterialReactTable","jsxs","Fragment","OwpTableTotalCount","GlobalStyles","getTreeGridFontFaceStyles","MaterialReactTable","OwpMrtTableNoDataOverlay","hasTableInstance","OwpMrtTable","currentLanguage","useGetCurrentLanguage","MRT_Localization_KO"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"OwpMrtTable.js","sources":["../../../src/components/OwpMrtTable/OwpMrtTable.tsx"],"sourcesContent":["import ArrowDropDownRoundedIcon from '@mui/icons-material/ArrowDropDownRounded';\nimport UnfoldMoreRoundedIcon from '@mui/icons-material/UnfoldMoreRounded';\nimport GlobalStyles from '@mui/material/GlobalStyles';\nimport {\n resolveOwpGridTheme,\n type OwpResolvedGridThemeConfigType,\n} from '@/constants/gridTheme';\nimport { DEFAULT_TABLE_RADIUS } from '@/constants/table';\nimport {\n getTreeGridFontFaceStyles,\n} from '@/constants/treeGrid';\nimport { OwpSvgIcon } from '@/components/OwpSvgIcon';\nimport { useGetCurrentLanguage } from '@/hooks/internal/useCurrentLanguage';\nimport { useGetCurrentSettings } from '@/hooks/useOwpSettings';\nimport { useOwpTranslation } from '@/hooks/useOwpTranslation';\nimport type {\n BoxProps,\n CheckboxProps,\n PaperProps,\n RadioProps,\n SvgIconProps,\n TableCellProps,\n TableContainerProps,\n TableProps,\n TableRowProps,\n} from '@mui/material';\nimport clsx from 'clsx';\nimport type { Theme } from '@mui/material/styles';\nimport { defaults as defaultsFC, isArray, isNumber } from 'es-toolkit/compat';\nimport {\n MaterialReactTable,\n type MaterialReactTableProps,\n MRT_BottomToolbar,\n type MRT_Cell,\n type MRT_Column,\n type MRT_Icons,\n type MRT_Row,\n type MRT_RowData,\n type MRT_TableInstance,\n useMaterialReactTable,\n} from 'material-react-table';\nimport { MRT_Localization_KO } from 'material-react-table/locales/ko';\nimport { useMemo } from 'react';\nimport {\n getTreeGridBodyCellSx,\n getTreeGridBodyRowSx,\n getTreeGridContainerSx,\n getTreeGridHeaderCellSx,\n getTreeGridTypographySx,\n TREEGRID_TABLE_BODY_BORDER_COLOR,\n TREEGRID_TABLE_HEADER_BORDER_COLOR,\n} from '../OwpTable/internal/treeGridTableStyle';\nimport { OwpTableTotalCount } from '../OwpTable/internal/OwpTableTotalCount';\nimport { toTableRadiusCssValue } from '../OwpTable/utils/tableSx';\nimport { OwpMrtTableNoDataOverlay } from './internal/OwpMrtTableNoDataOverlay';\nimport OwpMrtTableTopToolbar from './internal/OwpMrtTableTopToolbar';\n\ntype PropsWithSx = {\n className?: string;\n sx?: unknown;\n};\n\ntype HeadCellArgs<TData extends MRT_RowData> = {\n column: MRT_Column<TData>;\n table: MRT_TableInstance<TData>;\n};\n\ntype BodyCellArgs<TData extends MRT_RowData> = {\n cell: MRT_Cell<TData>;\n column: MRT_Column<TData>;\n row: MRT_Row<TData>;\n table: MRT_TableInstance<TData>;\n};\n\ntype BodyRowArgs<TData extends MRT_RowData> = {\n isDetailPanel?: boolean;\n row: MRT_Row<TData>;\n staticRowIndex: number;\n table: MRT_TableInstance<TData>;\n};\n\ntype TableInstanceArgs<TData extends MRT_RowData> = {\n table: MRT_TableInstance<TData>;\n};\n\ntype SelectAllCheckboxArgs<TData extends MRT_RowData> = {\n table: MRT_TableInstance<TData>;\n};\n\ntype SelectCheckboxArgs<TData extends MRT_RowData> = {\n row: MRT_Row<TData>;\n staticRowIndex?: number;\n table: MRT_TableInstance<TData>;\n};\n\nexport type OwpMrtTableHeaderCellStyle = {\n backgroundColor?: string;\n color?: string;\n fontSize?: number | string;\n fontWeight?: number | string;\n height?: number | string;\n};\n\ntype DataTableProps<TData extends MRT_RowData> = MaterialReactTableProps<TData> & {\n canHideTotalCountFooterBorder?: boolean;\n canUseNoDataOverlay?: boolean;\n canUseTableRadius?: boolean;\n canTotalCountRow?: boolean;\n canUseTreeGridStyle?: boolean;\n headerCellStyle?: OwpMrtTableHeaderCellStyle;\n tableBorderRadius?: string | number;\n totalCount?: number;\n};\n\nexport type OwpMrtTableProps<TData extends MRT_RowData> = DataTableProps<TData>;\n\nconst treeGridSortIconColor = '#cbd5e1';\n\nconst getResolvedTreeGridHeaderTextSx = (\n treeGridTheme: OwpResolvedGridThemeConfigType,\n headerCellStyle?: OwpMrtTableHeaderCellStyle,\n) => ({\n ...getTreeGridTypographySx(\n headerCellStyle?.fontSize ?? treeGridTheme.header.fontSize,\n headerCellStyle?.fontWeight ?? treeGridTheme.header.fontWeight,\n ),\n color: headerCellStyle?.color ?? treeGridTheme.header.color,\n});\n\nconst getHeaderCellTextStyleSx = (headerCellStyle?: OwpMrtTableHeaderCellStyle) => ({\n color: headerCellStyle?.color,\n fontSize: headerCellStyle?.fontSize,\n fontWeight: headerCellStyle?.fontWeight,\n});\n\nconst getHeaderCellHeightStyleSx = (headerCellStyle?: OwpMrtTableHeaderCellStyle) =>\n headerCellStyle?.height\n ? {\n height: headerCellStyle.height,\n minHeight: headerCellStyle.height,\n }\n : undefined;\n\nconst getHeaderCellBackgroundColor = (headerCellStyle?: OwpMrtTableHeaderCellStyle) =>\n headerCellStyle?.backgroundColor\n ? `${headerCellStyle.backgroundColor} !important`\n : undefined;\n\nconst getHeaderCellOverrideSx = (headerCellStyle?: OwpMrtTableHeaderCellStyle) => {\n const backgroundColor = getHeaderCellBackgroundColor(headerCellStyle);\n const textStyleSx = getHeaderCellTextStyleSx(headerCellStyle);\n const heightStyleSx = getHeaderCellHeightStyleSx(headerCellStyle);\n const contentMinHeight = headerCellStyle?.height ? '100%' : undefined;\n\n return {\n ...textStyleSx,\n ...heightStyleSx,\n backgroundColor,\n '& .Mui-TableHeadCell-Content': {\n ...textStyleSx,\n ...heightStyleSx,\n alignItems: 'center',\n backgroundColor,\n display: 'flex',\n },\n '& .Mui-TableHeadCell-Content-Labels': {\n alignItems: 'center',\n backgroundColor,\n display: 'flex',\n height: headerCellStyle?.height ? '100%' : undefined,\n },\n '& .Mui-TableHeadCell-Content-Wrapper': {\n ...textStyleSx,\n alignItems: 'center',\n backgroundColor,\n display: 'flex',\n minHeight: contentMinHeight,\n },\n '& .MuiTableSortLabel-root': {\n color: headerCellStyle?.color,\n },\n '& .MuiTableSortLabel-root:hover': {\n color: headerCellStyle?.color,\n },\n '& .MuiTableSortLabel-root.Mui-active': {\n color: headerCellStyle?.color,\n },\n '& .MuiTableSortLabel-icon': {\n color: headerCellStyle?.color ? `${headerCellStyle.color} !important` : undefined,\n },\n };\n};\n\nconst mergeSxValues = (...styles: Array<unknown>): unknown => {\n const mergedStyles = styles.flatMap((style) => {\n if (!style) {\n return [];\n }\n\n return isArray(style) ? style : [style];\n });\n\n if (mergedStyles.length === 0) {\n return undefined;\n }\n\n return (theme: Theme) =>\n mergedStyles.reduce<Record<string, unknown>>((acc, style) => {\n const resolvedStyle =\n typeof style === 'function' ? (style as (theme: Theme) => unknown)(theme) : style;\n\n if (!resolvedStyle || isArray(resolvedStyle)) {\n return acc;\n }\n\n return {\n ...acc,\n ...(resolvedStyle as Record<string, unknown>),\n };\n }, {});\n};\n\nconst resolvePropValue = <TArgs, TProps>(\n prop: ((args: TArgs) => TProps) | TProps | undefined,\n args: TArgs,\n): TProps | undefined => {\n if (typeof prop === 'function') {\n return (prop as (args: TArgs) => TProps)(args);\n }\n\n return prop;\n};\n\nconst mergeComponentProps = <TProps extends PropsWithSx>(\n ...propsList: Array<TProps | undefined>\n): TProps => {\n const resolvedProps = propsList.filter(Boolean) as TProps[];\n const mergedProps = resolvedProps.reduce((acc, currentProps) => {\n return {\n ...acc,\n ...currentProps,\n };\n }, {} as TProps);\n\n const className = clsx(resolvedProps.map((currentProps) => currentProps.className));\n const sx = mergeSxValues(...resolvedProps.map((currentProps) => currentProps.sx));\n\n if (className) {\n mergedProps.className = className as TProps['className'];\n }\n\n if (sx) {\n mergedProps.sx = sx as TProps['sx'];\n }\n\n return mergedProps;\n};\n\nconst mergeResolvedProps = <TArgs, TProps extends PropsWithSx>(\n args: TArgs,\n ...propsList: Array<((args: TArgs) => TProps) | TProps | undefined>\n): TProps => {\n return mergeComponentProps(\n ...propsList.map((currentProps) => resolvePropValue<TArgs, TProps>(currentProps, args)),\n );\n};\n\nconst defaultTableIcons: Partial<MRT_Icons> = {\n ArrowDownwardIcon: (props) => (\n <OwpSvgIcon size={20} {...props}>\n heroicons-outline:arrow-down-circle\n </OwpSvgIcon>\n ),\n ClearAllIcon: () => <OwpSvgIcon size={20}>heroicons-outline:adjustments-horizontal</OwpSvgIcon>,\n DensityLargeIcon: () => <OwpSvgIcon size={20}>heroicons-outline:bars-3-bottom-left</OwpSvgIcon>,\n DensityMediumIcon: () => <OwpSvgIcon size={20}>heroicons-outline:bars-3</OwpSvgIcon>,\n DensitySmallIcon: () => <OwpSvgIcon size={20}>heroicons-outline:bars-2</OwpSvgIcon>,\n DragHandleIcon: () => (\n <OwpSvgIcon className=\"rotate-45\" size={14}>\n heroicons-outline:arrows-pointing-out\n </OwpSvgIcon>\n ),\n FilterListIcon: (props) => (\n <OwpSvgIcon size={16} {...props}>\n heroicons-outline:funnel\n </OwpSvgIcon>\n ),\n FilterListOffIcon: () => <OwpSvgIcon size={20}>heroicons-outline:funnel</OwpSvgIcon>,\n FullscreenExitIcon: () => <OwpSvgIcon size={20}>heroicons-outline:arrows-pointing-in</OwpSvgIcon>,\n FullscreenIcon: () => <OwpSvgIcon size={20}>heroicons-outline:arrows-pointing-out</OwpSvgIcon>,\n SearchIcon: (props) => (\n <OwpSvgIcon color=\"action\" size={20} {...props}>\n heroicons-outline:magnifying-glass\n </OwpSvgIcon>\n ),\n SearchOffIcon: () => <OwpSvgIcon size={20}>heroicons-outline:magnifying-glass</OwpSvgIcon>,\n ViewColumnIcon: () => <OwpSvgIcon size={20}>heroicons-outline:view-columns</OwpSvgIcon>,\n MoreVertIcon: () => <OwpSvgIcon size={20}>heroicons-outline:ellipsis-vertical</OwpSvgIcon>,\n MoreHorizIcon: () => <OwpSvgIcon size={20}>heroicons-outline:ellipsis-horizontal</OwpSvgIcon>,\n SortIcon: (props) => (\n <OwpSvgIcon size={20} {...props}>\n heroicons-outline:arrows-up-down\n </OwpSvgIcon>\n ),\n PushPinIcon: (props) => (\n <OwpSvgIcon size={20} {...props}>\n heroicons-outline:bookmark\n </OwpSvgIcon>\n ),\n VisibilityOffIcon: () => <OwpSvgIcon size={20}>heroicons-outline:eye-slash</OwpSvgIcon>,\n};\n\nconst TreeGridArrowDownwardIcon = (props: SvgIconProps) => {\n return <ArrowDropDownRoundedIcon fontSize=\"small\" {...props} />;\n};\n\nconst TreeGridSyncAltIcon = (props: SvgIconProps & { direction?: string }) => {\n const { direction, ...iconProps } = props;\n\n void direction;\n\n return <UnfoldMoreRoundedIcon fontSize=\"small\" {...iconProps} />;\n};\n\nconst treeGridTableIcons: Partial<MRT_Icons> = {\n ArrowDownwardIcon: TreeGridArrowDownwardIcon,\n SyncAltIcon: TreeGridSyncAltIcon,\n};\n\nconst defaultBottomToolbarProps: BoxProps = {\n className: 'flex items-center min-h-56 h-56',\n};\n\nconst defaultPaperProps: PaperProps = {\n elevation: 0,\n square: true,\n className: 'flex flex-col flex-auto h-full',\n};\n\nconst getTreeGridPaperProps = (\n treeGridTheme: OwpResolvedGridThemeConfigType,\n): PaperProps => ({\n sx: {\n ...getTreeGridContainerSx(treeGridTheme),\n display: 'flex',\n height: '100%',\n flexDirection: 'column',\n border: `1px solid ${TREEGRID_TABLE_BODY_BORDER_COLOR}`,\n borderRadius: 0,\n boxShadow: 'none',\n },\n});\n\nconst totalCountFooterBorderlessPaperProps: PaperProps = {\n sx: {\n border: 0,\n },\n};\n\nconst getTotalCountFooterBorderlessContainerProps = (): TableContainerProps => ({\n sx: {\n borderTop: `1px solid ${TREEGRID_TABLE_BODY_BORDER_COLOR}`,\n borderRight: `1px solid ${TREEGRID_TABLE_BODY_BORDER_COLOR}`,\n borderLeft: `1px solid ${TREEGRID_TABLE_BODY_BORDER_COLOR}`,\n },\n});\n\nconst defaultContainerProps: TableContainerProps = {\n className: 'flex-auto',\n};\n\nconst getTableRadiusPaperProps = (tableBorderRadius: string | number): PaperProps => ({\n square: false,\n sx: {\n borderRadius: toTableRadiusCssValue(tableBorderRadius),\n overflow: 'hidden',\n },\n});\n\nconst tableRadiusContainerProps: TableContainerProps = {\n sx: {\n borderRadius: 'inherit',\n },\n};\n\nconst treeGridSelectColumnWidth = 40;\n\nconst treeGridSelectColumnCellSx = {\n width: treeGridSelectColumnWidth,\n minWidth: treeGridSelectColumnWidth,\n maxWidth: treeGridSelectColumnWidth,\n} as const;\n\nconst treeGridContainerProps: TableContainerProps = {\n sx: {\n flex: 1,\n minHeight: 0,\n overflowX: 'hidden',\n overflowY: 'auto',\n },\n};\n\nconst getTreeGridHeadRowProps = (\n headerCellStyle?: OwpMrtTableHeaderCellStyle,\n): TableRowProps => ({\n sx: {\n backgroundColor: headerCellStyle?.backgroundColor,\n boxShadow: 'none',\n },\n});\n\nconst defaultSelectCheckboxProps: CheckboxProps = {\n className: 'w-48',\n};\n\nconst treeGridSelectCheckboxProps: CheckboxProps = {\n sx: {\n display: 'flex',\n m: 0,\n mx: 'auto',\n },\n};\n\nconst getTreeGridTableProps = (\n treeGridTheme: OwpResolvedGridThemeConfigType,\n): TableProps => ({\n sx: {\n ...getTreeGridContainerSx(treeGridTheme),\n borderSpacing: 0,\n width: '100%',\n tableLayout: 'fixed',\n '& .MuiTableHead-root .MuiTableCell-root': {\n ...getTreeGridHeaderCellSx(treeGridTheme),\n py: 0.75,\n wordBreak: 'keep-all',\n },\n '& .MuiTableHead-root .MuiTableRow-root:first-of-type .MuiTableCell-root:first-of-type': {\n borderLeft: `1px solid ${TREEGRID_TABLE_HEADER_BORDER_COLOR}`,\n },\n '& .MuiTableHead-root .MuiTableRow-root:first-of-type .MuiTableCell-root:last-of-type': {\n borderRight: `1px solid ${TREEGRID_TABLE_HEADER_BORDER_COLOR}`,\n },\n '& .MuiTableHead-root .MuiIconButton-root': {\n display: 'none',\n },\n '& .MuiTableBody-root .MuiTableCell-root': {\n backgroundColor: treeGridTheme.row.backgroundColor,\n color: treeGridTheme.body.color,\n p: 0,\n verticalAlign: 'middle',\n borderRight: `1px solid ${TREEGRID_TABLE_BODY_BORDER_COLOR}`,\n borderBottom: `1px solid ${TREEGRID_TABLE_BODY_BORDER_COLOR}`,\n overflowWrap: 'anywhere',\n },\n '& .MuiTableBody-root .MuiTableCell-root:last-of-type': {\n borderRight: 'none',\n },\n },\n});\n\nconst treeGridTableRadiusProps: TableProps = {\n sx: {\n '& .MuiTableHead-root .MuiTableCell-root': {\n borderTop: 'none',\n },\n '& .MuiTableHead-root .MuiTableRow-root .MuiTableCell-root + .MuiTableCell-root': {\n borderLeft: '1px solid',\n borderLeftColor: 'divider',\n },\n '& .MuiTableHead-root .MuiTableRow-root:first-of-type .MuiTableCell-root:first-of-type': {\n borderLeft: 'none',\n },\n '& .MuiTableHead-root .MuiTableRow-root:first-of-type .MuiTableCell-root:last-of-type': {\n borderRight: 'none',\n },\n },\n};\n\nconst treeGridTableRadiusBottomEdgeProps: TableProps = {\n sx: {\n '& .MuiTableBody-root .MuiTableRow-root:last-of-type .MuiTableCell-root': {\n borderBottom: 'none',\n },\n },\n};\n\nconst getDefaultBodyRowProps = <TData extends MRT_RowData>({\n row,\n table,\n}: BodyRowArgs<TData>): TableRowProps => {\n const { density } = table.getState();\n\n if (density === 'compact') {\n return {\n sx: {\n backgroundColor: 'initial',\n opacity: 1,\n boxShadow: 'none',\n height: row.getIsPinned() ? `${37}px` : undefined,\n },\n };\n }\n\n return {\n sx: {\n backgroundColor: 'initial',\n opacity: 1,\n boxShadow: 'none',\n height: row.getIsPinned() ? `${density === 'comfortable' ? 53 : 69}px` : undefined,\n },\n };\n};\n\nconst getDefaultHeadCellProps = <TData extends MRT_RowData>(\n { column }: HeadCellArgs<TData>,\n headerCellStyle?: OwpMrtTableHeaderCellStyle,\n): TableCellProps => {\n const headerCellBackgroundColor = getHeaderCellBackgroundColor(headerCellStyle);\n\n return {\n sx: {\n '& .Mui-TableHeadCell-Content-Labels': {\n flex: 1,\n justifyContent: 'space-between',\n },\n '& .Mui-TableHeadCell-Content-Actions': {\n '& > button': {\n marginX: '2px',\n },\n },\n '& .MuiFormHelperText-root': {\n textAlign: 'center',\n marginX: 0,\n color: (theme: Theme) => theme.palette.text.disabled,\n fontSize: 11,\n },\n ...getHeaderCellOverrideSx(headerCellStyle),\n backgroundColor: (theme) =>\n headerCellBackgroundColor ??\n (column.getIsPinned() ? theme.palette.background.paper : 'inherit'),\n },\n };\n};\n\nconst getTreeGridHeadCellProps = <TData extends MRT_RowData>(\n { column }: HeadCellArgs<TData>,\n treeGridTheme: OwpResolvedGridThemeConfigType,\n headerCellStyle?: OwpMrtTableHeaderCellStyle,\n): TableCellProps => {\n const isSelectColumn = column.id === 'mrt-row-select';\n const resolvedHeaderTextSx = getResolvedTreeGridHeaderTextSx(treeGridTheme, headerCellStyle);\n const resolvedSortIconColor = headerCellStyle?.color ?? treeGridSortIconColor;\n const headerHeightStyleSx = getHeaderCellHeightStyleSx(headerCellStyle);\n const contentMinHeight = headerCellStyle?.height ? '100%' : undefined;\n\n return {\n align: 'center',\n sx: {\n ...(isSelectColumn ? treeGridSelectColumnCellSx : {}),\n ...resolvedHeaderTextSx,\n ...getHeaderCellOverrideSx(headerCellStyle),\n backgroundColor: getHeaderCellBackgroundColor(headerCellStyle),\n '& .Mui-TableHeadCell-Content': {\n ...resolvedHeaderTextSx,\n ...headerHeightStyleSx,\n alignItems: 'center',\n backgroundColor: 'inherit',\n display: 'flex',\n justifyContent: 'center',\n position: 'relative',\n width: '100%',\n },\n '& .Mui-TableHeadCell-Content-Labels': {\n alignItems: 'center',\n backgroundColor: 'inherit',\n display: 'flex',\n flex: 1,\n justifyContent: 'center',\n maxWidth: '100%',\n minWidth: 0,\n overflow: 'hidden',\n position: 'relative',\n pl: 0,\n pr: isSelectColumn ? 0 : '24px',\n height: headerCellStyle?.height ? '100%' : undefined,\n width: '100%',\n },\n '& .Mui-TableHeadCell-Content-Wrapper': {\n ...resolvedHeaderTextSx,\n alignItems: 'center',\n backgroundColor: 'inherit',\n display: 'flex',\n minHeight: contentMinHeight,\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n },\n '&& .MuiBadge-root': isSelectColumn\n ? undefined\n : {\n alignItems: 'center',\n display: 'inline-flex',\n justifyContent: 'center',\n position: 'absolute',\n pointerEvents: 'none',\n right: '6px',\n top: '50%',\n transform: 'translateY(-50%)',\n width: '16px',\n },\n '&& .MuiTableSortLabel-root': {\n alignItems: 'center',\n color: resolvedSortIconColor,\n display: 'inline-flex',\n justifyContent: 'center',\n minWidth: '16px',\n opacity: '1 !important',\n overflow: 'visible',\n width: '16px',\n },\n '&& .MuiTableSortLabel-root:hover': {\n color: resolvedSortIconColor,\n },\n '&& .MuiTableSortLabel-root.Mui-active': {\n color: resolvedSortIconColor,\n },\n '&& .MuiTableSortLabel-icon': {\n color: `${resolvedSortIconColor} !important`,\n display: 'block',\n fontSize: '18px',\n margin: 0,\n opacity: '1 !important',\n overflow: 'visible',\n },\n '& .MuiButtonBase-root': isSelectColumn\n ? {\n display: 'flex',\n margin: '0 auto',\n }\n : undefined,\n },\n };\n};\n\nconst getTreeGridBodyCellProps = <TData extends MRT_RowData>(\n { column }: BodyCellArgs<TData>,\n treeGridTheme: OwpResolvedGridThemeConfigType,\n): TableCellProps => {\n const treeGridBodyCellSx = { ...getTreeGridBodyCellSx(treeGridTheme) };\n\n Reflect.deleteProperty(treeGridBodyCellSx, 'padding');\n Reflect.deleteProperty(treeGridBodyCellSx, 'borderBottom');\n Reflect.deleteProperty(treeGridBodyCellSx, 'borderLeft');\n Reflect.deleteProperty(treeGridBodyCellSx, 'borderRight');\n\n if (column.id !== 'mrt-row-select') {\n return {\n sx: treeGridBodyCellSx,\n };\n }\n\n return {\n align: 'center',\n sx: {\n ...treeGridBodyCellSx,\n ...treeGridSelectColumnCellSx,\n '& > .MuiButtonBase-root, & .MuiButtonBase-root': {\n display: 'flex',\n margin: '0 auto',\n },\n },\n };\n};\n\nconst tableBodyTabNavigableFieldSelector = [\n 'tbody td input:not([type=\"hidden\"])',\n 'tbody td textarea',\n 'tbody td [contenteditable=\"true\"]',\n 'tbody td [role=\"combobox\"]',\n].join(', ');\n\ntype TableBodyCellKeyDownCaptureEvent = Parameters<\n NonNullable<TableCellProps['onKeyDownCapture']>\n>[0];\n\n/**\n * 테이블 본문 입력 가능 필드 여부 판별\n * @param element 포커스 후보 요소\n */\nconst isTabNavigableTableBodyField = (element: HTMLElement) => {\n if (element.tabIndex < 0) {\n return false;\n }\n\n if (element.getAttribute('aria-disabled') === 'true') {\n return false;\n }\n\n if (element.getAttribute('aria-readonly') === 'true') {\n return false;\n }\n\n if (element instanceof HTMLInputElement || element instanceof HTMLTextAreaElement) {\n if (element.disabled || element.readOnly) {\n return false;\n }\n }\n\n if (element instanceof HTMLSelectElement && element.disabled) {\n return false;\n }\n\n if (element instanceof HTMLInputElement) {\n if (\n ['button', 'checkbox', 'file', 'hidden', 'radio', 'reset', 'submit'].includes(element.type)\n ) {\n return false;\n }\n }\n\n return element.getClientRects().length > 0;\n};\n\n/**\n * 테이블 본문 기준 현재 포커스 입력 필드 조회\n * @param target 키 이벤트 target\n */\nconst getCurrentTableBodyField = (target: EventTarget | null) => {\n if (!(target instanceof Element)) {\n return null;\n }\n\n const currentField = target.matches(tableBodyTabNavigableFieldSelector)\n ? target\n : target.closest(tableBodyTabNavigableFieldSelector);\n\n return currentField instanceof HTMLElement && isTabNavigableTableBodyField(currentField)\n ? currentField\n : null;\n};\n\n/**\n * 테이블 본문 입력 필드 Tab 이동 처리\n * @param event body cell keydown capture event\n */\nconst handleTableBodyFieldTabNavigation = (event: TableBodyCellKeyDownCaptureEvent) => {\n if (event.key !== 'Tab' || event.altKey || event.ctrlKey || event.metaKey) {\n return;\n }\n\n const currentField = getCurrentTableBodyField(event.target);\n\n if (!currentField) {\n return;\n }\n\n const tableElement = currentField.closest('table');\n\n if (!tableElement) {\n return;\n }\n\n const fields = Array.from(\n tableElement.querySelectorAll<HTMLElement>(tableBodyTabNavigableFieldSelector),\n ).filter(isTabNavigableTableBodyField);\n\n const currentIndex = fields.indexOf(currentField);\n\n if (currentIndex < 0) {\n return;\n }\n\n const nextField = fields[currentIndex + (event.shiftKey ? -1 : 1)];\n\n if (!nextField) {\n return;\n }\n\n event.preventDefault();\n\n queueMicrotask(() => {\n if (document.contains(nextField)) {\n nextField.focus();\n }\n });\n};\n\n/**\n * MRT 기반 공통 테이블 렌더 함수\n * @param props Material React Table props\n */\nfunction DataTable<TData extends MRT_RowData>(props: DataTableProps<TData>) {\n const { t } = useOwpTranslation();\n const currentSettings = useGetCurrentSettings();\n const {\n canHideTotalCountFooterBorder = false,\n canUseNoDataOverlay = false,\n canUseTableRadius = false,\n canTotalCountRow = true,\n canUseTreeGridStyle = true,\n columns,\n data,\n headerCellStyle,\n tableBorderRadius = DEFAULT_TABLE_RADIUS,\n totalCount,\n ...rest\n } = props;\n\n const {\n icons: restIcons,\n initialState: restInitialState,\n muiBottomToolbarProps: restBottomToolbarProps,\n muiSelectAllCheckboxProps: restSelectAllCheckboxProps,\n muiSelectCheckboxProps: restSelectCheckboxProps,\n displayColumnDefOptions: restDisplayColumnDefOptions,\n muiTableBodyCellProps: restTableBodyCellProps,\n muiTableBodyRowProps: restTableBodyRowProps,\n muiTableContainerProps: restTableContainerProps,\n muiTableHeadCellProps: restTableHeadCellProps,\n muiTableHeadRowProps: restTableHeadRowProps,\n muiTablePaperProps: restTablePaperProps,\n muiTableProps: restTableProps,\n renderBottomToolbar: restRenderBottomToolbar,\n renderEmptyRowsFallback: restRenderEmptyRowsFallback,\n ...restOptions\n } = rest;\n\n const resolvedData = isArray(data) ? data : [];\n const treeGridTheme = useMemo(\n () => resolveOwpGridTheme(currentSettings?.theme?.main?.grid),\n [currentSettings],\n );\n const resolvedHeaderCellStyle = useMemo<OwpMrtTableHeaderCellStyle | undefined>(() => {\n if (!canUseTreeGridStyle) {\n return headerCellStyle;\n }\n\n return {\n backgroundColor: headerCellStyle?.backgroundColor ?? treeGridTheme.header.backgroundColor,\n color: headerCellStyle?.color ?? treeGridTheme.header.color,\n fontSize: headerCellStyle?.fontSize ?? treeGridTheme.header.fontSize,\n fontWeight: headerCellStyle?.fontWeight ?? treeGridTheme.header.fontWeight,\n height: headerCellStyle?.height ?? treeGridTheme.header.height,\n };\n }, [canUseTreeGridStyle, headerCellStyle, treeGridTheme]);\n const isNoDataOverlayVisible = isArray(data) && data.length === 0;\n const shouldHideTotalCountFooterBorder = canUseTreeGridStyle || canHideTotalCountFooterBorder;\n const shouldApplyTotalCountFooterBorderlessLayout =\n canTotalCountRow && shouldHideTotalCountFooterBorder;\n const shouldUseNoDataOverlay = canUseTreeGridStyle || canUseNoDataOverlay;\n const shouldUseRadiusOuterBorder = canUseTreeGridStyle && canUseTableRadius;\n const displayColumnDefOptions = canUseTreeGridStyle\n ? {\n ...(restDisplayColumnDefOptions ?? {}),\n 'mrt-row-select': {\n header: '',\n size: treeGridSelectColumnWidth,\n minSize: treeGridSelectColumnWidth,\n maxSize: treeGridSelectColumnWidth,\n ...(restDisplayColumnDefOptions?.['mrt-row-select'] ?? {}),\n },\n }\n : restDisplayColumnDefOptions;\n\n const initialState = defaultsFC(\n { ...(restInitialState ?? {}) },\n {\n density: canUseTreeGridStyle ? 'compact' : 'spacious',\n showColumnFilters: false,\n showGlobalFilter: !canUseTreeGridStyle,\n columnPinning: {\n left: ['mrt-row-expand', 'mrt-row-select'],\n right: ['mrt-row-actions'],\n },\n pagination: {\n pageSize: 15,\n },\n enableFullScreenToggle: false,\n },\n );\n\n const defaultOptions = defaultsFC(\n {\n ...restOptions,\n displayColumnDefOptions,\n initialState,\n },\n {\n displayColumnDefOptions,\n initialState,\n layoutMode: canUseTreeGridStyle ? 'semantic' : undefined,\n enablePagination: canUseTreeGridStyle ? false : undefined,\n enableBottomToolbar: canUseTreeGridStyle ? false : undefined,\n enableTopToolbar: canUseTreeGridStyle ? false : undefined,\n enableColumnActions: canUseTreeGridStyle ? false : undefined,\n enableColumnDragging: canUseTreeGridStyle ? false : undefined,\n enableColumnFilters: canUseTreeGridStyle ? false : undefined,\n enableColumnOrdering: canUseTreeGridStyle ? false : true,\n enableDensityToggle: canUseTreeGridStyle ? false : undefined,\n enableFullScreenToggle: false,\n enableGlobalFilter: canUseTreeGridStyle ? false : undefined,\n enableGrouping: canUseTreeGridStyle ? false : true,\n enableHiding: canUseTreeGridStyle ? false : undefined,\n enableColumnPinning: canUseTreeGridStyle ? false : true,\n enableFacetedValues: canUseTreeGridStyle ? false : true,\n enableMultiRowSelection: canUseTreeGridStyle ? true : undefined,\n enableRowActions: canUseTreeGridStyle ? false : true,\n enableRowSelection: true,\n enableRowDragging: canUseTreeGridStyle ? false : undefined,\n enableRowOrdering: canUseTreeGridStyle ? false : undefined,\n enableSelectAll: canUseTreeGridStyle ? false : undefined,\n enableStickyHeader: true,\n enableToolbarInternalActions: canUseTreeGridStyle ? false : undefined,\n getRowId: canUseTreeGridStyle\n ? (row: TData) => String((row as TData & { id: string | number }).id)\n : undefined,\n paginationDisplayMode: 'pages',\n positionToolbarAlertBanner: 'top',\n muiPaginationProps: {\n color: 'secondary',\n rowsPerPageOptions: [10, 20, 30],\n shape: 'rounded',\n variant: 'outlined',\n showRowsPerPage: false,\n },\n muiSearchTextFieldProps: {\n placeholder: 'Search',\n sx: { minWidth: '300px' },\n variant: 'outlined',\n size: 'small',\n },\n muiFilterTextFieldProps: {\n variant: 'outlined',\n size: 'small',\n sx: {\n '& .MuiInputBase-root': {\n padding: '0px 8px',\n height: '32px!important',\n minHeight: '32px!important',\n },\n },\n },\n mrtTheme: (theme: Theme) => ({\n baseBackgroundColor: theme.palette.background.paper,\n menuBackgroundColor: theme.palette.background.paper,\n pinnedRowBackgroundColor: theme.palette.background.paper,\n pinnedColumnBackgroundColor: theme.palette.background.paper,\n }),\n renderTopToolbar: (toolbarProps: { table: MRT_TableInstance<TData> }) => (\n <OwpMrtTableTopToolbar {...toolbarProps} />\n ),\n } as Partial<DataTableProps<TData>>,\n );\n\n const shouldRenderBaseBottomToolbar = defaultOptions.enableBottomToolbar !== false;\n const resolvedTotalCount = isNumber(totalCount) ? totalCount : resolvedData.length;\n const shouldHideLastBodyRowBorderForRadius =\n shouldUseRadiusOuterBorder && !canTotalCountRow && !shouldRenderBaseBottomToolbar;\n\n const renderBaseBottomToolbar = (table: MRT_TableInstance<TData>) => {\n if (!shouldRenderBaseBottomToolbar) {\n return null;\n }\n\n if (typeof restRenderBottomToolbar === 'function') {\n return restRenderBottomToolbar({ table });\n }\n\n return restRenderBottomToolbar ?? <MRT_BottomToolbar table={table} />;\n };\n\n const getResolvedBodyCellProps = (args: BodyCellArgs<TData>) => {\n const mergedProps = mergeResolvedProps<BodyCellArgs<TData>, TableCellProps>(\n args,\n canUseTreeGridStyle\n ? (nextArgs) => getTreeGridBodyCellProps(nextArgs, treeGridTheme)\n : undefined,\n restTableBodyCellProps,\n );\n const { onKeyDownCapture, ...restMergedProps } = mergedProps;\n\n return {\n ...restMergedProps,\n onKeyDownCapture: (event: TableBodyCellKeyDownCaptureEvent) => {\n onKeyDownCapture?.(event);\n\n if (event.defaultPrevented || event.isPropagationStopped()) {\n return;\n }\n\n handleTableBodyFieldTabNavigation(event);\n },\n } satisfies TableCellProps;\n };\n\n const getResolvedBodyRowProps = (args: BodyRowArgs<TData>) =>\n mergeResolvedProps<BodyRowArgs<TData>, TableRowProps>(\n args,\n getDefaultBodyRowProps,\n canUseTreeGridStyle\n ? () =>\n ({\n sx: getTreeGridBodyRowSx(treeGridTheme, {\n canHover: true,\n selected: args.row.getIsSelected(),\n }),\n }) satisfies TableRowProps\n : undefined,\n restTableBodyRowProps,\n );\n\n const getResolvedHeadRowProps = () => {\n if (!resolvedHeaderCellStyle?.backgroundColor) {\n return undefined;\n }\n\n return {\n sx: {\n backgroundColor: `${resolvedHeaderCellStyle.backgroundColor} !important`,\n },\n } satisfies TableRowProps;\n };\n\n const table = useMaterialReactTable<TData>({\n ...defaultOptions,\n columns,\n data: resolvedData,\n enableBottomToolbar: canTotalCountRow ? true : defaultOptions.enableBottomToolbar,\n icons: {\n ...defaultTableIcons,\n ...(canUseTreeGridStyle ? treeGridTableIcons : {}),\n ...(restIcons ?? {}),\n },\n muiBottomToolbarProps: (args: TableInstanceArgs<TData>) =>\n mergeResolvedProps<TableInstanceArgs<TData>, BoxProps>(\n args,\n defaultBottomToolbarProps,\n restBottomToolbarProps,\n ),\n muiSelectAllCheckboxProps: (args: SelectAllCheckboxArgs<TData>) =>\n mergeResolvedProps<SelectAllCheckboxArgs<TData>, CheckboxProps>(\n args,\n defaultSelectCheckboxProps,\n canUseTreeGridStyle ? treeGridSelectCheckboxProps : undefined,\n restSelectAllCheckboxProps,\n ),\n muiSelectCheckboxProps: (args: SelectCheckboxArgs<TData>) =>\n mergeResolvedProps<SelectCheckboxArgs<TData>, CheckboxProps | RadioProps>(\n args,\n defaultSelectCheckboxProps,\n canUseTreeGridStyle ? treeGridSelectCheckboxProps : undefined,\n restSelectCheckboxProps,\n ),\n muiTableBodyCellProps: (args: BodyCellArgs<TData>) => getResolvedBodyCellProps(args),\n muiTableBodyRowProps: (args: BodyRowArgs<TData>) => getResolvedBodyRowProps(args),\n muiTableContainerProps: (args: TableInstanceArgs<TData>) =>\n mergeResolvedProps<TableInstanceArgs<TData>, TableContainerProps>(\n args,\n defaultContainerProps,\n canUseTreeGridStyle ? treeGridContainerProps : undefined,\n canUseTreeGridStyle ? { sx: getTreeGridContainerSx(treeGridTheme) } : undefined,\n canUseTableRadius ? tableRadiusContainerProps : undefined,\n restTableContainerProps,\n shouldApplyTotalCountFooterBorderlessLayout && !shouldUseRadiusOuterBorder\n ? getTotalCountFooterBorderlessContainerProps()\n : undefined,\n ),\n muiTableHeadRowProps: (args) =>\n mergeResolvedProps(\n args,\n canUseTreeGridStyle ? getTreeGridHeadRowProps(resolvedHeaderCellStyle) : undefined,\n getResolvedHeadRowProps(),\n restTableHeadRowProps,\n ),\n muiTableHeadCellProps: (args: HeadCellArgs<TData>) =>\n mergeResolvedProps<HeadCellArgs<TData>, TableCellProps>(\n args,\n (nextArgs) => getDefaultHeadCellProps(nextArgs, resolvedHeaderCellStyle),\n canUseTreeGridStyle\n ? (nextArgs) => getTreeGridHeadCellProps(nextArgs, treeGridTheme, resolvedHeaderCellStyle)\n : undefined,\n restTableHeadCellProps,\n ),\n muiTablePaperProps: (args: TableInstanceArgs<TData>) =>\n mergeResolvedProps<TableInstanceArgs<TData>, PaperProps>(\n args,\n defaultPaperProps,\n canUseTreeGridStyle ? getTreeGridPaperProps(treeGridTheme) : undefined,\n canUseTableRadius ? getTableRadiusPaperProps(tableBorderRadius) : undefined,\n restTablePaperProps,\n shouldApplyTotalCountFooterBorderlessLayout && !shouldUseRadiusOuterBorder\n ? totalCountFooterBorderlessPaperProps\n : undefined,\n ),\n muiTableProps: (args: TableInstanceArgs<TData>) =>\n mergeResolvedProps<TableInstanceArgs<TData>, TableProps>(\n args,\n canUseTreeGridStyle ? getTreeGridTableProps(treeGridTheme) : undefined,\n shouldUseRadiusOuterBorder ? treeGridTableRadiusProps : undefined,\n shouldHideLastBodyRowBorderForRadius ? treeGridTableRadiusBottomEdgeProps : undefined,\n restTableProps,\n ),\n renderBottomToolbar: canTotalCountRow\n ? ({ table }) => (\n <>\n {renderBaseBottomToolbar(table)}\n <OwpTableTotalCount totalCount={resolvedTotalCount} />\n </>\n )\n : restRenderBottomToolbar,\n renderEmptyRowsFallback: shouldUseNoDataOverlay ? () => <></> : restRenderEmptyRowsFallback,\n });\n\n return (\n <>\n {canUseTreeGridStyle && <GlobalStyles styles={getTreeGridFontFaceStyles()} />}\n <MaterialReactTable table={table} />\n {shouldUseNoDataOverlay && (\n <OwpMrtTableNoDataOverlay\n visible={isNoDataOverlayVisible}\n message={t('Message.조회된 결과가 없습니다.')}\n table={table}\n />\n )}\n </>\n );\n}\n\nconst hasTableInstance = <TData extends MRT_RowData>(\n props: OwpMrtTableProps<TData>,\n): props is OwpMrtTableProps<TData> & { table: MRT_TableInstance<TData> } => {\n return 'table' in props && props.table !== undefined;\n};\n\n/**\n * MRT 기반 공통 테이블 컴포넌트\n * @param props 컴포넌트 props\n */\nconst OwpMrtTable = <TData extends MRT_RowData>(props: OwpMrtTableProps<TData>) => {\n const currentLanguage = useGetCurrentLanguage();\n\n if (hasTableInstance(props)) {\n return <MaterialReactTable table={props.table} />;\n }\n\n return (\n <DataTable<TData>\n {...props}\n localization={\n props.localization ?? (currentLanguage.id === 'kr' ? MRT_Localization_KO : undefined)\n }\n />\n );\n};\n\nexport { OwpMrtTable };\n"],"names":["treeGridSortIconColor","getResolvedTreeGridHeaderTextSx","__name","treeGridTheme","headerCellStyle","getTreeGridTypographySx","getHeaderCellTextStyleSx","getHeaderCellHeightStyleSx","getHeaderCellBackgroundColor","getHeaderCellOverrideSx","backgroundColor","textStyleSx","heightStyleSx","contentMinHeight","mergeSxValues","styles","mergedStyles","style","isArray","theme","acc","resolvedStyle","resolvePropValue","prop","args","mergeComponentProps","propsList","resolvedProps","mergedProps","currentProps","className","clsx","sx","mergeResolvedProps","defaultTableIcons","props","jsx","OwpSvgIcon","TreeGridArrowDownwardIcon","ArrowDropDownRoundedIcon","TreeGridSyncAltIcon","direction","iconProps","UnfoldMoreRoundedIcon","treeGridTableIcons","defaultBottomToolbarProps","defaultPaperProps","getTreeGridPaperProps","getTreeGridContainerSx","TREEGRID_TABLE_BODY_BORDER_COLOR","totalCountFooterBorderlessPaperProps","getTotalCountFooterBorderlessContainerProps","defaultContainerProps","getTableRadiusPaperProps","tableBorderRadius","toTableRadiusCssValue","tableRadiusContainerProps","treeGridSelectColumnWidth","treeGridSelectColumnCellSx","treeGridContainerProps","getTreeGridHeadRowProps","defaultSelectCheckboxProps","treeGridSelectCheckboxProps","getTreeGridTableProps","getTreeGridHeaderCellSx","TREEGRID_TABLE_HEADER_BORDER_COLOR","treeGridTableRadiusProps","treeGridTableRadiusBottomEdgeProps","getDefaultBodyRowProps","row","table","density","getDefaultHeadCellProps","column","headerCellBackgroundColor","getTreeGridHeadCellProps","isSelectColumn","resolvedHeaderTextSx","resolvedSortIconColor","headerHeightStyleSx","getTreeGridBodyCellProps","treeGridBodyCellSx","getTreeGridBodyCellSx","tableBodyTabNavigableFieldSelector","isTabNavigableTableBodyField","element","getCurrentTableBodyField","target","currentField","handleTableBodyFieldTabNavigation","event","tableElement","fields","currentIndex","nextField","DataTable","t","useOwpTranslation","currentSettings","useGetCurrentSettings","canHideTotalCountFooterBorder","canUseNoDataOverlay","canUseTableRadius","canTotalCountRow","canUseTreeGridStyle","columns","data","DEFAULT_TABLE_RADIUS","totalCount","rest","restIcons","restInitialState","restBottomToolbarProps","restSelectAllCheckboxProps","restSelectCheckboxProps","restDisplayColumnDefOptions","restTableBodyCellProps","restTableBodyRowProps","restTableContainerProps","restTableHeadCellProps","restTableHeadRowProps","restTablePaperProps","restTableProps","restRenderBottomToolbar","restRenderEmptyRowsFallback","restOptions","resolvedData","useMemo","resolveOwpGridTheme","_b","_a","resolvedHeaderCellStyle","isNoDataOverlayVisible","shouldApplyTotalCountFooterBorderlessLayout","shouldUseNoDataOverlay","shouldUseRadiusOuterBorder","displayColumnDefOptions","initialState","defaultsFC","defaultOptions","toolbarProps","OwpMrtTableTopToolbar","shouldRenderBaseBottomToolbar","resolvedTotalCount","isNumber","shouldHideLastBodyRowBorderForRadius","renderBaseBottomToolbar","MRT_BottomToolbar","getResolvedBodyCellProps","nextArgs","onKeyDownCapture","restMergedProps","getResolvedBodyRowProps","getTreeGridBodyRowSx","getResolvedHeadRowProps","useMaterialReactTable","jsxs","Fragment","OwpTableTotalCount","GlobalStyles","getTreeGridFontFaceStyles","MaterialReactTable","OwpMrtTableNoDataOverlay","hasTableInstance","OwpMrtTable","currentLanguage","useGetCurrentLanguage","MRT_Localization_KO"],"mappings":"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"}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
var
|
|
2
|
-
var m = (l, r) =>
|
|
3
|
-
import { jsx as
|
|
4
|
-
import { OwpSelectorBase as
|
|
5
|
-
import { useMemo as
|
|
6
|
-
const
|
|
1
|
+
var w = Object.defineProperty;
|
|
2
|
+
var m = (l, r) => w(l, "name", { value: r, configurable: !0 });
|
|
3
|
+
import { jsx as x } from "../../node_modules/.pnpm/@emotion_react@11.14.0_@types_react@19.2.14_react@19.2.4/node_modules/@emotion/react/jsx-runtime/dist/emotion-react-jsx-runtime.browser.esm.js";
|
|
4
|
+
import { OwpSelectorBase as S } from "../OwpSelectorBase/OwpSelectorBase.js";
|
|
5
|
+
import { useMemo as j } from "react";
|
|
6
|
+
const k = /* @__PURE__ */ m(({
|
|
7
7
|
className: l,
|
|
8
8
|
defaultValue: r,
|
|
9
9
|
error: d,
|
|
@@ -16,9 +16,10 @@ const T = /* @__PURE__ */ m(({
|
|
|
16
16
|
required: c,
|
|
17
17
|
showAllOption: u = !0,
|
|
18
18
|
value: O,
|
|
19
|
+
valueTextAlign: f,
|
|
19
20
|
...s
|
|
20
21
|
}) => {
|
|
21
|
-
const
|
|
22
|
+
const v = j(
|
|
22
23
|
() => a.map((e) => ({
|
|
23
24
|
disabled: e.disabled,
|
|
24
25
|
label: e.label,
|
|
@@ -26,8 +27,8 @@ const T = /* @__PURE__ */ m(({
|
|
|
26
27
|
})),
|
|
27
28
|
[a]
|
|
28
29
|
);
|
|
29
|
-
return /* @__PURE__ */
|
|
30
|
-
|
|
30
|
+
return /* @__PURE__ */ x(
|
|
31
|
+
S,
|
|
31
32
|
{
|
|
32
33
|
className: l,
|
|
33
34
|
defaultValue: r,
|
|
@@ -41,18 +42,19 @@ const T = /* @__PURE__ */ m(({
|
|
|
41
42
|
onChange: /* @__PURE__ */ m((e) => {
|
|
42
43
|
t == null || t(e, null);
|
|
43
44
|
}, "onChange"),
|
|
44
|
-
options:
|
|
45
|
+
options: v,
|
|
45
46
|
required: c,
|
|
46
47
|
selectProps: {
|
|
47
48
|
...s
|
|
48
49
|
},
|
|
49
50
|
selectorType: "select",
|
|
50
51
|
showAllOption: u,
|
|
51
|
-
value: O
|
|
52
|
+
value: O,
|
|
53
|
+
valueTextAlign: f
|
|
52
54
|
}
|
|
53
55
|
);
|
|
54
56
|
}, "OwpOptionSelector");
|
|
55
57
|
export {
|
|
56
|
-
|
|
58
|
+
k as OwpOptionSelector
|
|
57
59
|
};
|
|
58
60
|
//# sourceMappingURL=OwpOptionSelector.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"OwpOptionSelector.js","sources":["../../../src/components/OwpOptionSelector/OwpOptionSelector.tsx"],"sourcesContent":["import { OwpSelectorBase } from '@/components/OwpSelectorBase/OwpSelectorBase';\nimport { type SelectChangeEvent, type SelectProps } from '@mui/material';\nimport { type ReactNode, useMemo } from 'react';\n\nexport interface OwpOptionSelectorOption {\n value: string;\n label: ReactNode;\n disabled?: boolean;\n}\n\nexport interface OwpOptionSelectorProps extends Omit<\n SelectProps<string>,\n 'defaultValue' | 'multiple' | 'onChange' | 'renderValue' | 'value'\n> {\n label?: string;\n defaultValue?: string;\n helperText?: string;\n multiple?: boolean;\n onChange?: (event: SelectChangeEvent<string>, child: ReactNode) => void;\n options: OwpOptionSelectorOption[];\n showAllOption?: boolean;\n value?: string;\n}\n\n/**\n * 옵션 선택기\n * @param props 옵션 선택기 props\n */\nconst OwpOptionSelector = ({\n className,\n defaultValue,\n error,\n fullWidth,\n helperText,\n label,\n multiple,\n onChange,\n options,\n required,\n showAllOption = true,\n value,\n ...selectProps\n}: OwpOptionSelectorProps) => {\n const selectorOptions = useMemo(\n () =>\n options.map((option) => ({\n disabled: option.disabled,\n label: option.label,\n value: option.value,\n })),\n [options],\n );\n\n return (\n <OwpSelectorBase\n className={className}\n defaultValue={defaultValue}\n disabled={selectProps.disabled}\n error={error}\n fullWidth={fullWidth}\n helperText={helperText}\n label={label}\n multiple={multiple}\n name={selectProps.name}\n onChange={(event) => {\n onChange?.(event as SelectChangeEvent<string>, null);\n }}\n options={selectorOptions}\n required={required}\n selectProps={{\n ...selectProps,\n }}\n selectorType=\"select\"\n showAllOption={showAllOption}\n value={value}\n />\n );\n};\n\nexport { OwpOptionSelector };\n"],"names":["OwpOptionSelector","__name","className","defaultValue","error","fullWidth","helperText","label","multiple","onChange","options","required","showAllOption","value","selectProps","selectorOptions","useMemo","option","jsx","OwpSelectorBase","event"],"mappings":";;;;;
|
|
1
|
+
{"version":3,"file":"OwpOptionSelector.js","sources":["../../../src/components/OwpOptionSelector/OwpOptionSelector.tsx"],"sourcesContent":["import { OwpSelectorBase } from '@/components/OwpSelectorBase/OwpSelectorBase';\nimport type { OwpSelectorValueTextAlign } from '@/components/OwpSelectorBase/types';\nimport { type SelectChangeEvent, type SelectProps } from '@mui/material';\nimport { type ReactNode, useMemo } from 'react';\n\nexport interface OwpOptionSelectorOption {\n value: string;\n label: ReactNode;\n disabled?: boolean;\n}\n\nexport interface OwpOptionSelectorProps extends Omit<\n SelectProps<string>,\n 'defaultValue' | 'multiple' | 'onChange' | 'renderValue' | 'value'\n> {\n label?: string;\n defaultValue?: string;\n helperText?: string;\n multiple?: boolean;\n onChange?: (event: SelectChangeEvent<string>, child: ReactNode) => void;\n options: OwpOptionSelectorOption[];\n showAllOption?: boolean;\n value?: string;\n /** 단일 선택 값 텍스트 정렬 */\n valueTextAlign?: OwpSelectorValueTextAlign;\n}\n\n/**\n * 옵션 선택기\n * @param props 옵션 선택기 props\n */\nconst OwpOptionSelector = ({\n className,\n defaultValue,\n error,\n fullWidth,\n helperText,\n label,\n multiple,\n onChange,\n options,\n required,\n showAllOption = true,\n value,\n valueTextAlign,\n ...selectProps\n}: OwpOptionSelectorProps) => {\n const selectorOptions = useMemo(\n () =>\n options.map((option) => ({\n disabled: option.disabled,\n label: option.label,\n value: option.value,\n })),\n [options],\n );\n\n return (\n <OwpSelectorBase\n className={className}\n defaultValue={defaultValue}\n disabled={selectProps.disabled}\n error={error}\n fullWidth={fullWidth}\n helperText={helperText}\n label={label}\n multiple={multiple}\n name={selectProps.name}\n onChange={(event) => {\n onChange?.(event as SelectChangeEvent<string>, null);\n }}\n options={selectorOptions}\n required={required}\n selectProps={{\n ...selectProps,\n }}\n selectorType=\"select\"\n showAllOption={showAllOption}\n value={value}\n valueTextAlign={valueTextAlign}\n />\n );\n};\n\nexport { OwpOptionSelector };\n"],"names":["OwpOptionSelector","__name","className","defaultValue","error","fullWidth","helperText","label","multiple","onChange","options","required","showAllOption","value","valueTextAlign","selectProps","selectorOptions","useMemo","option","jsx","OwpSelectorBase","event"],"mappings":";;;;;AA+BA,MAAMA,IAAoB,gBAAAC,EAAA,CAAC;AAAA,EACzB,WAAAC;AAAA,EACA,cAAAC;AAAA,EACA,OAAAC;AAAA,EACA,WAAAC;AAAA,EACA,YAAAC;AAAA,EACA,OAAAC;AAAA,EACA,UAAAC;AAAA,EACA,UAAAC;AAAA,EACA,SAAAC;AAAA,EACA,UAAAC;AAAA,EACA,eAAAC,IAAgB;AAAA,EAChB,OAAAC;AAAA,EACA,gBAAAC;AAAA,EACA,GAAGC;AACL,MAA8B;AAC5B,QAAMC,IAAkBC;AAAA,IACtB,MACEP,EAAQ,IAAI,CAACQ,OAAY;AAAA,MACvB,UAAUA,EAAO;AAAA,MACjB,OAAOA,EAAO;AAAA,MACd,OAAOA,EAAO;AAAA,IAAA,EACd;AAAA,IACJ,CAACR,CAAO;AAAA,EAAA;AAGV,SACE,gBAAAS;AAAA,IAACC;AAAA,IAAA;AAAA,MACC,WAAAlB;AAAA,MACA,cAAAC;AAAA,MACA,UAAUY,EAAY;AAAA,MACtB,OAAAX;AAAA,MACA,WAAAC;AAAA,MACA,YAAAC;AAAA,MACA,OAAAC;AAAA,MACA,UAAAC;AAAA,MACA,MAAMO,EAAY;AAAA,MAClB,UAAU,gBAAAd,EAAA,CAACoB,MAAU;AACnB,QAAAZ,KAAA,QAAAA,EAAWY,GAAoC;AAAA,MACjD,GAFU;AAAA,MAGV,SAASL;AAAA,MACT,UAAAL;AAAA,MACA,aAAa;AAAA,QACX,GAAGI;AAAA,MAAA;AAAA,MAEL,cAAa;AAAA,MACb,eAAAH;AAAA,MACA,OAAAC;AAAA,MACA,gBAAAC;AAAA,IAAA;AAAA,EAAA;AAGN,GAnD0B;"}
|
|
@@ -4,7 +4,7 @@ import { jsxs as c, jsx as s } from "../../node_modules/.pnpm/@emotion_react@11.
|
|
|
4
4
|
import { clsx as i } from "../../node_modules/.pnpm/clsx@2.1.1/node_modules/clsx/dist/clsx.js";
|
|
5
5
|
import w from "../../node_modules/.pnpm/@mui_icons-material@7.3.9_@mui_material@7.3.9_@emotion_react@11.14.0_@types_react@19.2._dc2be6bc014bebdac88a574e3e02c144/node_modules/@mui/icons-material/esm/Fitbit.js";
|
|
6
6
|
import { CircularProgress as N } from "@mui/material";
|
|
7
|
-
import { useHeaderWrapState as y } from "../../hooks/useHeaderWrapState.js";
|
|
7
|
+
import { useHeaderWrapState as y } from "../../hooks/internal/useHeaderWrapState.js";
|
|
8
8
|
const P = /* @__PURE__ */ o(({ title: e, leftSlot: r, centerSlot: l, actions: n, loading: f }) => {
|
|
9
9
|
const m = e != null && e !== "", d = !!(r || l), { containerRef: t, titleRef: x, slotsRef: p, actionsRef: u, isWrapped: a } = y([
|
|
10
10
|
e,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"OwpPageTitle.js","sources":["../../../src/components/OwpPageTitle/OwpPageTitle.tsx"],"sourcesContent":["import clsx from 'clsx';\nimport FitbitIcon from '@mui/icons-material/Fitbit';\nimport { CircularProgress } from '@mui/material';\nimport type { ReactNode } from 'react';\nimport { useHeaderWrapState } from '@/hooks/useHeaderWrapState';\n\ninterface OwpPageTitleProps {\n title?: ReactNode;\n leftSlot?: ReactNode;\n centerSlot?: ReactNode;\n actions?: ReactNode;\n loading?: boolean;\n}\n\n/**\n * OwpPageTitle 컴포넌트\n * @param title 제목\n * @param leftSlot leftSlot 값\n * @param centerSlot centerSlot 값\n * @param actions 액션 영역\n * @param loading 로딩 상태\n */\nconst OwpPageTitle = ({ title, leftSlot, centerSlot, actions, loading }: OwpPageTitleProps) => {\n const hasTitle = title !== undefined && title !== null && title !== '';\n const hasSlots = Boolean(leftSlot || centerSlot);\n const { containerRef, titleRef, slotsRef, actionsRef, isWrapped } = useHeaderWrapState([\n title,\n leftSlot,\n centerSlot,\n actions,\n loading,\n ]);\n\n return (\n <div\n ref={containerRef}\n className={clsx(\n 'min-h-[44px] w-full',\n isWrapped\n ? 'flex flex-col gap-8'\n : 'grid grid-cols-[auto_minmax(0,1fr)_auto] items-center gap-x-12 gap-y-8',\n )}\n >\n {hasTitle && (\n <div\n ref={titleRef}\n className={clsx(\n 'flex shrink-0 items-center gap-12 whitespace-nowrap',\n isWrapped ? 'order-1 self-start' : 'col-start-1',\n )}\n >\n {loading ? (\n <CircularProgress className=\"shrink-0\" size={32} sx={{ color: 'secondary.main' }} />\n ) : (\n <FitbitIcon className=\"shrink-0\" sx={{ fontSize: 32, color: 'secondary.main' }} />\n )}\n <h5 className=\"shrink-0 whitespace-nowrap text-3xl font-medium\">{title}</h5>\n </div>\n )}\n {hasSlots && (\n <div\n ref={slotsRef}\n className={clsx(\n 'flex max-w-full',\n isWrapped ? 'order-2 self-end justify-end' : 'col-start-2 justify-self-center',\n )}\n >\n <div\n className={clsx(\n 'flex max-w-full items-center gap-12',\n isWrapped ? 'flex-wrap justify-end' : 'flex-nowrap justify-center',\n )}\n >\n {leftSlot && <div className=\"max-w-full\">{leftSlot}</div>}\n {centerSlot && <div className=\"max-w-full\">{centerSlot}</div>}\n </div>\n </div>\n )}\n {actions && (\n <div\n ref={actionsRef}\n className={clsx(\n 'flex max-w-full justify-end',\n isWrapped ? 'order-3 self-end' : 'col-start-3 justify-self-end',\n )}\n >\n {actions}\n </div>\n )}\n </div>\n );\n};\n\nexport { OwpPageTitle };\n"],"names":["OwpPageTitle","__name","title","leftSlot","centerSlot","actions","loading","hasTitle","hasSlots","containerRef","titleRef","slotsRef","actionsRef","isWrapped","useHeaderWrapState","jsxs","clsx","jsx","CircularProgress","FitbitIcon"],"mappings":";;;;;;;AAsBA,MAAMA,IAAe,gBAAAC,EAAA,CAAC,EAAE,OAAAC,GAAO,UAAAC,GAAU,YAAAC,GAAY,SAAAC,GAAS,SAAAC,QAAiC;AAC7F,QAAMC,IAAkCL,KAAU,QAAQA,MAAU,IAC9DM,IAAW,GAAQL,KAAYC,IAC/B,EAAE,cAAAK,GAAc,UAAAC,GAAU,UAAAC,GAAU,YAAAC,GAAY,WAAAC,EAAA,IAAcC,EAAmB;AAAA,IACrFZ;AAAA,IACAC;AAAA,IACAC;AAAA,IACAC;AAAA,IACAC;AAAA,EAAA,CACD;AAED,SACE,gBAAAS;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,KAAKN;AAAA,MACL,WAAWO;AAAA,QACT;AAAA,QACAH,IACI,wBACA;AAAA,MAAA;AAAA,MAGL,UAAA;AAAA,QAAAN,KACC,gBAAAQ;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,KAAKL;AAAA,YACL,WAAWM;AAAA,cACT;AAAA,cACAH,IAAY,uBAAuB;AAAA,YAAA;AAAA,YAGpC,UAAA;AAAA,cAAAP,IACC,gBAAAW,EAACC,KAAiB,WAAU,YAAW,MAAM,IAAI,IAAI,EAAE,OAAO,iBAAA,EAAiB,CAAG,IAElF,gBAAAD,EAACE,GAAA,EAAW,WAAU,YAAW,IAAI,EAAE,UAAU,IAAI,OAAO,iBAAA,EAAiB,CAAG;AAAA,cAElF,gBAAAF,EAAC,MAAA,EAAG,WAAU,mDAAmD,UAAAf,EAAA,CAAM;AAAA,YAAA;AAAA,UAAA;AAAA,QAAA;AAAA,QAG1EM,KACC,gBAAAS;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,KAAKN;AAAA,YACL,WAAWK;AAAA,cACT;AAAA,cACAH,IAAY,iCAAiC;AAAA,YAAA;AAAA,YAG/C,UAAA,gBAAAE;AAAA,cAAC;AAAA,cAAA;AAAA,gBACC,WAAWC;AAAA,kBACT;AAAA,kBACAH,IAAY,0BAA0B;AAAA,gBAAA;AAAA,gBAGvC,UAAA;AAAA,kBAAAV,KAAY,gBAAAc,EAAC,OAAA,EAAI,WAAU,cAAc,UAAAd,GAAS;AAAA,kBAClDC,KAAc,gBAAAa,EAAC,OAAA,EAAI,WAAU,cAAc,UAAAb,EAAA,CAAW;AAAA,gBAAA;AAAA,cAAA;AAAA,YAAA;AAAA,UACzD;AAAA,QAAA;AAAA,QAGHC,KACC,gBAAAY;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,KAAKL;AAAA,YACL,WAAWI;AAAA,cACT;AAAA,cACAH,IAAY,qBAAqB;AAAA,YAAA;AAAA,YAGlC,UAAAR;AAAA,UAAA;AAAA,QAAA;AAAA,MACH;AAAA,IAAA;AAAA,EAAA;AAIR,GArEqB;"}
|
|
1
|
+
{"version":3,"file":"OwpPageTitle.js","sources":["../../../src/components/OwpPageTitle/OwpPageTitle.tsx"],"sourcesContent":["import clsx from 'clsx';\nimport FitbitIcon from '@mui/icons-material/Fitbit';\nimport { CircularProgress } from '@mui/material';\nimport type { ReactNode } from 'react';\nimport { useHeaderWrapState } from '@/hooks/internal/useHeaderWrapState';\n\ninterface OwpPageTitleProps {\n title?: ReactNode;\n leftSlot?: ReactNode;\n centerSlot?: ReactNode;\n actions?: ReactNode;\n loading?: boolean;\n}\n\n/**\n * OwpPageTitle 컴포넌트\n * @param title 제목\n * @param leftSlot leftSlot 값\n * @param centerSlot centerSlot 값\n * @param actions 액션 영역\n * @param loading 로딩 상태\n */\nconst OwpPageTitle = ({ title, leftSlot, centerSlot, actions, loading }: OwpPageTitleProps) => {\n const hasTitle = title !== undefined && title !== null && title !== '';\n const hasSlots = Boolean(leftSlot || centerSlot);\n const { containerRef, titleRef, slotsRef, actionsRef, isWrapped } = useHeaderWrapState([\n title,\n leftSlot,\n centerSlot,\n actions,\n loading,\n ]);\n\n return (\n <div\n ref={containerRef}\n className={clsx(\n 'min-h-[44px] w-full',\n isWrapped\n ? 'flex flex-col gap-8'\n : 'grid grid-cols-[auto_minmax(0,1fr)_auto] items-center gap-x-12 gap-y-8',\n )}\n >\n {hasTitle && (\n <div\n ref={titleRef}\n className={clsx(\n 'flex shrink-0 items-center gap-12 whitespace-nowrap',\n isWrapped ? 'order-1 self-start' : 'col-start-1',\n )}\n >\n {loading ? (\n <CircularProgress className=\"shrink-0\" size={32} sx={{ color: 'secondary.main' }} />\n ) : (\n <FitbitIcon className=\"shrink-0\" sx={{ fontSize: 32, color: 'secondary.main' }} />\n )}\n <h5 className=\"shrink-0 whitespace-nowrap text-3xl font-medium\">{title}</h5>\n </div>\n )}\n {hasSlots && (\n <div\n ref={slotsRef}\n className={clsx(\n 'flex max-w-full',\n isWrapped ? 'order-2 self-end justify-end' : 'col-start-2 justify-self-center',\n )}\n >\n <div\n className={clsx(\n 'flex max-w-full items-center gap-12',\n isWrapped ? 'flex-wrap justify-end' : 'flex-nowrap justify-center',\n )}\n >\n {leftSlot && <div className=\"max-w-full\">{leftSlot}</div>}\n {centerSlot && <div className=\"max-w-full\">{centerSlot}</div>}\n </div>\n </div>\n )}\n {actions && (\n <div\n ref={actionsRef}\n className={clsx(\n 'flex max-w-full justify-end',\n isWrapped ? 'order-3 self-end' : 'col-start-3 justify-self-end',\n )}\n >\n {actions}\n </div>\n )}\n </div>\n );\n};\n\nexport { OwpPageTitle };\n"],"names":["OwpPageTitle","__name","title","leftSlot","centerSlot","actions","loading","hasTitle","hasSlots","containerRef","titleRef","slotsRef","actionsRef","isWrapped","useHeaderWrapState","jsxs","clsx","jsx","CircularProgress","FitbitIcon"],"mappings":";;;;;;;AAsBA,MAAMA,IAAe,gBAAAC,EAAA,CAAC,EAAE,OAAAC,GAAO,UAAAC,GAAU,YAAAC,GAAY,SAAAC,GAAS,SAAAC,QAAiC;AAC7F,QAAMC,IAAkCL,KAAU,QAAQA,MAAU,IAC9DM,IAAW,GAAQL,KAAYC,IAC/B,EAAE,cAAAK,GAAc,UAAAC,GAAU,UAAAC,GAAU,YAAAC,GAAY,WAAAC,EAAA,IAAcC,EAAmB;AAAA,IACrFZ;AAAA,IACAC;AAAA,IACAC;AAAA,IACAC;AAAA,IACAC;AAAA,EAAA,CACD;AAED,SACE,gBAAAS;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,KAAKN;AAAA,MACL,WAAWO;AAAA,QACT;AAAA,QACAH,IACI,wBACA;AAAA,MAAA;AAAA,MAGL,UAAA;AAAA,QAAAN,KACC,gBAAAQ;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,KAAKL;AAAA,YACL,WAAWM;AAAA,cACT;AAAA,cACAH,IAAY,uBAAuB;AAAA,YAAA;AAAA,YAGpC,UAAA;AAAA,cAAAP,IACC,gBAAAW,EAACC,KAAiB,WAAU,YAAW,MAAM,IAAI,IAAI,EAAE,OAAO,iBAAA,EAAiB,CAAG,IAElF,gBAAAD,EAACE,GAAA,EAAW,WAAU,YAAW,IAAI,EAAE,UAAU,IAAI,OAAO,iBAAA,EAAiB,CAAG;AAAA,cAElF,gBAAAF,EAAC,MAAA,EAAG,WAAU,mDAAmD,UAAAf,EAAA,CAAM;AAAA,YAAA;AAAA,UAAA;AAAA,QAAA;AAAA,QAG1EM,KACC,gBAAAS;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,KAAKN;AAAA,YACL,WAAWK;AAAA,cACT;AAAA,cACAH,IAAY,iCAAiC;AAAA,YAAA;AAAA,YAG/C,UAAA,gBAAAE;AAAA,cAAC;AAAA,cAAA;AAAA,gBACC,WAAWC;AAAA,kBACT;AAAA,kBACAH,IAAY,0BAA0B;AAAA,gBAAA;AAAA,gBAGvC,UAAA;AAAA,kBAAAV,KAAY,gBAAAc,EAAC,OAAA,EAAI,WAAU,cAAc,UAAAd,GAAS;AAAA,kBAClDC,KAAc,gBAAAa,EAAC,OAAA,EAAI,WAAU,cAAc,UAAAb,EAAA,CAAW;AAAA,gBAAA;AAAA,cAAA;AAAA,YAAA;AAAA,UACzD;AAAA,QAAA;AAAA,QAGHC,KACC,gBAAAY;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,KAAKL;AAAA,YACL,WAAWI;AAAA,cACT;AAAA,cACAH,IAAY,qBAAqB;AAAA,YAAA;AAAA,YAGlC,UAAAR;AAAA,UAAA;AAAA,QAAA;AAAA,MACH;AAAA,IAAA;AAAA,EAAA;AAIR,GArEqB;"}
|