td-stylekit 28.22.3 → 28.22.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +7 -0
- package/dist/es/DataGrid/elements.js +24 -25
- package/package.json +1 -1
|
@@ -64,7 +64,7 @@ var ColumnHeaderPopover = ( /*#__PURE__*/0, _base["default"])(_Popover["default"
|
|
|
64
64
|
// Due to changeover to TooltipPopover from OverlayTrigger
|
|
65
65
|
marginTop: -6
|
|
66
66
|
};
|
|
67
|
-
}, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.DataGrid.ColumnHeaderPopover), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AAkBmC","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1],\n    textTransform: 'capitalize'\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
67
|
+
}, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.DataGrid.ColumnHeaderPopover), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AAkBmC","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1]\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
68
68
|
exports.ColumnHeaderPopover = ColumnHeaderPopover;
|
|
69
69
|
ColumnHeaderPopover.displayName = 'ColumnHeaderPopover';
|
|
70
70
|
var ColumnHeaderActionsContainer = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_ENV === "production" ? {
|
|
@@ -77,7 +77,7 @@ var ColumnHeaderActionsContainer = ( /*#__PURE__*/0, _base["default"])('div', pr
|
|
|
77
77
|
return {
|
|
78
78
|
padding: "".concat(theme.space[4], " ").concat(theme.space[3])
|
|
79
79
|
};
|
|
80
|
-
}, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.DataGrid.ColumnHeaderActionsContainer), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AA8B4C","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1],\n    textTransform: 'capitalize'\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
80
|
+
}, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.DataGrid.ColumnHeaderActionsContainer), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AA8B4C","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1]\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
81
81
|
exports.ColumnHeaderActionsContainer = ColumnHeaderActionsContainer;
|
|
82
82
|
ColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer';
|
|
83
83
|
var ColumnHeaderContainer = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_ENV === "production" ? {
|
|
@@ -109,7 +109,7 @@ var ColumnHeaderContainer = ( /*#__PURE__*/0, _base["default"])('div', process.e
|
|
|
109
109
|
return isFirst && {
|
|
110
110
|
paddingLeft: theme.space[5]
|
|
111
111
|
};
|
|
112
|
-
}, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.DataGrid.ColumnHeaderContainer), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AA4CqC","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1],\n    textTransform: 'capitalize'\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
112
|
+
}, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.DataGrid.ColumnHeaderContainer), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AA4CqC","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1]\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
113
113
|
exports.ColumnHeaderContainer = ColumnHeaderContainer;
|
|
114
114
|
ColumnHeaderContainer.displayName = 'ColumnHeaderContainer';
|
|
115
115
|
var ColumnHeaderLabel = ( /*#__PURE__*/0, _base["default"])('span', process.env.NODE_ENV === "production" ? {
|
|
@@ -131,7 +131,7 @@ var ColumnHeaderLabel = ( /*#__PURE__*/0, _base["default"])('span', process.env.
|
|
|
131
131
|
textTransform: 'capitalize',
|
|
132
132
|
userSelect: 'none'
|
|
133
133
|
};
|
|
134
|
-
}, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.DataGrid.ColumnHeaderLabel), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AAqEiC","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1],\n    textTransform: 'capitalize'\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
134
|
+
}, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.DataGrid.ColumnHeaderLabel), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AAqEiC","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1]\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
135
135
|
exports.ColumnHeaderLabel = ColumnHeaderLabel;
|
|
136
136
|
ColumnHeaderLabel.displayName = 'ColumnHeaderLabel';
|
|
137
137
|
var ColumnHeaderIcon = ( /*#__PURE__*/0, _base["default"])('span', process.env.NODE_ENV === "production" ? {
|
|
@@ -151,7 +151,7 @@ var ColumnHeaderIcon = ( /*#__PURE__*/0, _base["default"])('span', process.env.N
|
|
|
151
151
|
pointerEvents: 'none'
|
|
152
152
|
}
|
|
153
153
|
};
|
|
154
|
-
}, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.DataGrid.ColumnHeaderIcon), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AAsFgC","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1],\n    textTransform: 'capitalize'\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
154
|
+
}, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.DataGrid.ColumnHeaderIcon), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AAsFgC","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1]\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
155
155
|
exports.ColumnHeaderIcon = ColumnHeaderIcon;
|
|
156
156
|
ColumnHeaderIcon.displayName = 'ColumnHeaderIcon';
|
|
157
157
|
var Cell = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_ENV === "production" ? {
|
|
@@ -229,7 +229,7 @@ var Cell = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_ENV === "
|
|
|
229
229
|
return indent && {
|
|
230
230
|
paddingLeft: (0, _utils.add)(theme.space[8], theme.space[3])
|
|
231
231
|
};
|
|
232
|
-
}, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.DataGrid.Cell), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AA+GoB","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1],\n    textTransform: 'capitalize'\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
232
|
+
}, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.DataGrid.Cell), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AA+GoB","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1]\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
233
233
|
exports.Cell = Cell;
|
|
234
234
|
Cell.displayName = 'Cell';
|
|
235
235
|
var Row = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_ENV === "production" ? {
|
|
@@ -280,7 +280,7 @@ var Row = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_ENV === "p
|
|
|
280
280
|
// click to select multiple rows
|
|
281
281
|
userSelect: 'none'
|
|
282
282
|
};
|
|
283
|
-
}, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.DataGrid.Row), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AAgLmB","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1],\n    textTransform: 'capitalize'\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
283
|
+
}, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.DataGrid.Row), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AAgLmB","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1]\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
284
284
|
exports.Row = Row;
|
|
285
285
|
Row.displayName = 'Row';
|
|
286
286
|
var TableContainer = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_ENV === "production" ? {
|
|
@@ -288,7 +288,7 @@ var TableContainer = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE
|
|
|
288
288
|
} : {
|
|
289
289
|
target: "e1y3skq15",
|
|
290
290
|
label: "TableContainer"
|
|
291
|
-
})("overflow-x:auto;overflow-y:hidden;border:none;", (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.DataGrid.TableContainer), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AAwN8B","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1],\n    textTransform: 'capitalize'\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
291
|
+
})("overflow-x:auto;overflow-y:hidden;border:none;", (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.DataGrid.TableContainer), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AAwN8B","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1]\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
292
292
|
exports.TableContainer = TableContainer;
|
|
293
293
|
TableContainer.displayName = 'TableContainer';
|
|
294
294
|
var FilterHeader = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_ENV === "production" ? {
|
|
@@ -301,10 +301,9 @@ var FilterHeader = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_E
|
|
|
301
301
|
return {
|
|
302
302
|
color: theme.palette.neutral[9],
|
|
303
303
|
marginBottom: theme.space[3],
|
|
304
|
-
fontSize: theme.fontSize[1]
|
|
305
|
-
textTransform: 'capitalize'
|
|
304
|
+
fontSize: theme.fontSize[1]
|
|
306
305
|
};
|
|
307
|
-
}, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.DataGrid.FilterHeader), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AAmO4B","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1],\n    textTransform: 'capitalize'\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
306
|
+
}, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.DataGrid.FilterHeader), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AAmO4B","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1]\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
308
307
|
exports.FilterHeader = FilterHeader;
|
|
309
308
|
FilterHeader.displayName = 'FilterHeader';
|
|
310
309
|
var FilterButtons = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_ENV === "production" ? {
|
|
@@ -320,7 +319,7 @@ var FilterButtons = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_
|
|
|
320
319
|
marginTop: theme.space[6],
|
|
321
320
|
lineHeight: 1
|
|
322
321
|
};
|
|
323
|
-
}, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.DataGrid.FilterButtons), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AA8O6B","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1],\n    textTransform: 'capitalize'\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
322
|
+
}, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.DataGrid.FilterButtons), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AA6O6B","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1]\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
324
323
|
exports.FilterButtons = FilterButtons;
|
|
325
324
|
FilterButtons.displayName = 'FilterButtons';
|
|
326
325
|
var RightFilterButton = ( /*#__PURE__*/0, _base["default"])(_Button["default"], process.env.NODE_ENV === "production" ? {
|
|
@@ -333,7 +332,7 @@ var RightFilterButton = ( /*#__PURE__*/0, _base["default"])(_Button["default"],
|
|
|
333
332
|
return {
|
|
334
333
|
marginLeft: theme.space[1]
|
|
335
334
|
};
|
|
336
|
-
}, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.DataGrid.RightFilterButton), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AAyPiC","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1],\n    textTransform: 'capitalize'\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
335
|
+
}, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.DataGrid.RightFilterButton), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AAwPiC","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1]\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
337
336
|
exports.RightFilterButton = RightFilterButton;
|
|
338
337
|
RightFilterButton.displayName = 'RightFilterButton';
|
|
339
338
|
var FilterSeparator = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_ENV === "production" ? {
|
|
@@ -348,7 +347,7 @@ var FilterSeparator = ( /*#__PURE__*/0, _base["default"])('div', process.env.NOD
|
|
|
348
347
|
paddingTop: theme.space[4],
|
|
349
348
|
borderTop: "1px solid ".concat(theme.palette.neutral[3])
|
|
350
349
|
};
|
|
351
|
-
}, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.DataGrid.FilterSeparator), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AAiQ+B","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1],\n    textTransform: 'capitalize'\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
350
|
+
}, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.DataGrid.FilterSeparator), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AAgQ+B","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1]\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
352
351
|
exports.FilterSeparator = FilterSeparator;
|
|
353
352
|
FilterSeparator.displayName = 'FilterSeparator';
|
|
354
353
|
var StyledSortButton = ( /*#__PURE__*/0, _base["default"])(_Button["default"], process.env.NODE_ENV === "production" ? {
|
|
@@ -368,7 +367,7 @@ var StyledSortButton = ( /*#__PURE__*/0, _base["default"])(_Button["default"], p
|
|
|
368
367
|
return {
|
|
369
368
|
margin: noIcon ? "".concat(theme.space[1], " 0") : 0
|
|
370
369
|
};
|
|
371
|
-
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AA8QyB","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1],\n    textTransform: 'capitalize'\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
370
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AA6QyB","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1]\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
372
371
|
var SortButton = ( /*#__PURE__*/0, _base["default"])(function (_ref24) {
|
|
373
372
|
var icon = _ref24.icon,
|
|
374
373
|
label = _ref24.label,
|
|
@@ -408,7 +407,7 @@ var SortButton = ( /*#__PURE__*/0, _base["default"])(function (_ref24) {
|
|
|
408
407
|
}), _defineProperty(_ref26, ':hover', {
|
|
409
408
|
color: active ? theme.palette.primary[5] : theme.palette.primary[4]
|
|
410
409
|
}), _ref26;
|
|
411
|
-
}, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.DataGrid.SortButton), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AA0R0B","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1],\n    textTransform: 'capitalize'\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
410
|
+
}, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.DataGrid.SortButton), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AAyR0B","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1]\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
412
411
|
exports.SortButton = SortButton;
|
|
413
412
|
SortButton.displayName = 'SortButton';
|
|
414
413
|
var InlineInput = ( /*#__PURE__*/0, _base["default"])(_Input["default"], process.env.NODE_ENV === "production" ? {
|
|
@@ -431,7 +430,7 @@ var InlineInput = ( /*#__PURE__*/0, _base["default"])(_Input["default"], process
|
|
|
431
430
|
fontSize: theme.fontSize[0],
|
|
432
431
|
lineHeight: theme.lineHeight[5]
|
|
433
432
|
};
|
|
434
|
-
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AAwT2B","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1],\n    textTransform: 'capitalize'\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
433
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AAuT2B","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1]\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
435
434
|
exports.InlineInput = InlineInput;
|
|
436
435
|
InlineInput.displayName = 'InlineInput';
|
|
437
436
|
var SelectWrapper = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_ENV === "production" ? {
|
|
@@ -445,7 +444,7 @@ var SelectWrapper = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_
|
|
|
445
444
|
} : {
|
|
446
445
|
name: "1d3w5wq",
|
|
447
446
|
styles: "width:100%",
|
|
448
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AAwU6B","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1],\n    textTransform: 'capitalize'\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */",
|
|
447
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AAuU6B","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1]\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */",
|
|
449
448
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
450
449
|
});
|
|
451
450
|
exports.SelectWrapper = SelectWrapper;
|
|
@@ -463,7 +462,7 @@ var SymbolDropdownIcon = ( /*#__PURE__*/0, _base["default"])(_Icon["default"].Sm
|
|
|
463
462
|
// Align SymbolDropdownIcon with the one in Select
|
|
464
463
|
marginRight: 1
|
|
465
464
|
};
|
|
466
|
-
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AA6UkC","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1],\n    textTransform: 'capitalize'\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
465
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AA4UkC","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1]\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
467
466
|
exports.SymbolDropdownIcon = SymbolDropdownIcon;
|
|
468
467
|
SymbolDropdownIcon.displayName = 'SymbolDropdownIcon';
|
|
469
468
|
var CellBody = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_ENV === "production" ? {
|
|
@@ -492,7 +491,7 @@ var CellBody = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_ENV =
|
|
|
492
491
|
// Align SymbolDropdownIcon with the one in Select
|
|
493
492
|
alignItems: 'inherit'
|
|
494
493
|
};
|
|
495
|
-
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AA2VwB","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1],\n    textTransform: 'capitalize'\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
494
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AA0VwB","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1]\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
496
495
|
exports.CellBody = CellBody;
|
|
497
496
|
CellBody.displayName = 'CellBody';
|
|
498
497
|
var Spacer = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_ENV === "production" ? {
|
|
@@ -506,7 +505,7 @@ var Spacer = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_ENV ===
|
|
|
506
505
|
width: theme.space[2],
|
|
507
506
|
minWidth: theme.space[2]
|
|
508
507
|
};
|
|
509
|
-
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AAgXsB","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1],\n    textTransform: 'capitalize'\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
508
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AA+WsB","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1]\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
510
509
|
exports.Spacer = Spacer;
|
|
511
510
|
var OperatorSelect = ( /*#__PURE__*/0, _base["default"])(_Select["default"], process.env.NODE_ENV === "production" ? {
|
|
512
511
|
target: "e1y3skq3"
|
|
@@ -518,7 +517,7 @@ var OperatorSelect = ( /*#__PURE__*/0, _base["default"])(_Select["default"], pro
|
|
|
518
517
|
return {
|
|
519
518
|
marginBottom: theme.space[2]
|
|
520
519
|
};
|
|
521
|
-
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AAqX8B","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1],\n    textTransform: 'capitalize'\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */"); // Necessary to adjust the type so it preserves the Input generic behavior
|
|
520
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AAoX8B","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1]\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */"); // Necessary to adjust the type so it preserves the Input generic behavior
|
|
522
521
|
|
|
523
522
|
exports.OperatorSelect = OperatorSelect;
|
|
524
523
|
var CategoryInput = ( /*#__PURE__*/0, _base["default"])(_Input["default"], process.env.NODE_ENV === "production" ? {
|
|
@@ -532,7 +531,7 @@ var CategoryInput = ( /*#__PURE__*/0, _base["default"])(_Input["default"], proce
|
|
|
532
531
|
marginBottom: theme.space[4],
|
|
533
532
|
width: '100%'
|
|
534
533
|
};
|
|
535
|
-
}, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.DataGrid.CategoryInput), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AA0X6B","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1],\n    textTransform: 'capitalize'\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
534
|
+
}, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.DataGrid.CategoryInput), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AAyX6B","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1]\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
536
535
|
exports.CategoryInput = CategoryInput;
|
|
537
536
|
var CategoryCheckbox = ( /*#__PURE__*/0, _base["default"])(_Checkbox["default"], process.env.NODE_ENV === "production" ? {
|
|
538
537
|
target: "e1y3skq1"
|
|
@@ -544,7 +543,7 @@ var CategoryCheckbox = ( /*#__PURE__*/0, _base["default"])(_Checkbox["default"],
|
|
|
544
543
|
return {
|
|
545
544
|
marginBottom: theme.space[2]
|
|
546
545
|
};
|
|
547
|
-
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AAkYgC","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1],\n    textTransform: 'capitalize'\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
546
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AAiYgC","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1]\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
548
547
|
exports.CategoryCheckbox = CategoryCheckbox;
|
|
549
548
|
var CategoryOptionsContainer = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_ENV === "production" ? {
|
|
550
549
|
target: "e1y3skq0"
|
|
@@ -560,5 +559,5 @@ var CategoryOptionsContainer = ( /*#__PURE__*/0, _base["default"])('div', proces
|
|
|
560
559
|
overflowY: 'auto',
|
|
561
560
|
paddingLeft: theme.space[1]
|
|
562
561
|
};
|
|
563
|
-
}, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.DataGrid.CategoryOptionsContainer), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AAsYwC","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1],\n    textTransform: 'capitalize'\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
562
|
+
}, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.DataGrid.CategoryOptionsContainer), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/DataGrid/elements.tsx"],"names":[],"mappings":"AAqYwC","file":"../../../src/DataGrid/elements.tsx","sourcesContent":["import styled, { StyledComponent } from '@emotion/styled'\nimport Popover from '../Popover'\nimport Button from '../Button'\nimport Icon from '../Icon'\nimport Input from '../Input'\nimport Select from '../Select'\nimport Checkbox from '../Checkbox'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport { add } from '../utils'\nimport type { Theme } from '../ThemeProvider'\n\nexport const cellResetStyle = {\n  margin: 0,\n  height: '100%',\n  borderColor: 'inherit',\n  outlineOffset: -4\n}\n\nexport const ColumnHeaderPopover = styled(Popover)<{}>(\n  ({ theme }) => ({\n    border: `1px solid ${theme.palette.neutral[5]}`,\n    borderRadius: theme.radius[1],\n    padding: theme.space[0],\n    // Due to changeover to TooltipPopover from OverlayTrigger\n    marginTop: -6\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderPopover)\n)\nColumnHeaderPopover.displayName = 'ColumnHeaderPopover'\n\nexport const ColumnHeaderActionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    padding: `${theme.space[4]} ${theme.space[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderActionsContainer)\n)\nColumnHeaderActionsContainer.displayName = 'ColumnHeaderActionsContainer'\n\ntype ColumnHeaderContainerProps = {\n  clickable?: boolean\n  active?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n}\nexport const ColumnHeaderContainer = styled('div')<ColumnHeaderContainerProps>(\n  ({ theme, clickable, isLast }) => ({\n    alignItems: 'center',\n    color: theme.palette.neutral[11],\n    cursor: clickable ? 'pointer' : 'default',\n    height: '100%',\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    backgroundColor: theme.palette.neutral[2],\n    borderRight: `1px solid ${\n      isLast ? 'transparent' : theme.palette.neutral[4]\n    }`,\n    padding: theme.space[2],\n    outlineOffset: -4,\n    position: 'relative'\n  }),\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  getOverrides(Overridable.DataGrid.ColumnHeaderContainer)\n)\nColumnHeaderContainer.displayName = 'ColumnHeaderContainer'\n\nexport const ColumnHeaderLabel = styled('span')<{}>(\n  ({ theme }) => ({\n    textAlign: 'left',\n    textOverflow: 'ellipsis',\n    overflow: 'hidden',\n    whiteSpace: 'nowrap',\n    flexGrow: 1,\n    fontFamily: theme.fontFamily.body,\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    textTransform: 'capitalize',\n    userSelect: 'none'\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderLabel)\n)\nColumnHeaderLabel.displayName = 'ColumnHeaderLabel'\n\nexport const ColumnHeaderIcon = styled('span')<{}>(\n  ({ theme }) => ({\n    padding: theme.space[1],\n    color: theme.palette.primary[5],\n    '& svg': {\n      verticalAlign: 'middle',\n      // prevents nested icons from swallowing click events\n      // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n      pointerEvents: 'none'\n    }\n  }),\n  getOverrides(Overridable.DataGrid.ColumnHeaderIcon)\n)\nColumnHeaderIcon.displayName = 'ColumnHeaderIcon'\n\ntype CellProps = {\n  editable?: boolean\n  indent?: boolean\n  input?: boolean\n  isFirst?: boolean\n  isLast?: boolean\n  modified?: boolean\n  rightAlign?: boolean\n  invalid?: boolean\n}\nexport const Cell = styled('div')<CellProps>(\n  ({ theme, rightAlign }) => ({\n    cursor: 'default',\n    display: 'flex',\n    position: 'relative',\n    height: '100%',\n    padding: theme.space[2],\n    borderRight: `1px solid`,\n    borderColor: theme.palette.neutral[4],\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    alignItems: 'baseline',\n    lineHeight: theme.lineHeight[5]\n  }),\n  ({ theme, modified }) =>\n    modified && {\n      '::before': {\n        content: '\"\"',\n        position: 'absolute',\n        bottom: 0,\n        right: 0,\n        borderColor: 'transparent',\n        borderStyle: 'solid',\n        borderWidth: theme.space[1],\n        borderRightColor: theme.color.Orange,\n        borderBottomColor: theme.color.Orange\n      }\n    },\n  ({ theme, editable, input }) =>\n    editable &&\n    !input && {\n      ':hover': {\n        boxShadow: `inset 0 0 0 1px ${theme.color.Maya}`,\n        cursor: 'pointer'\n      }\n    },\n  ({ theme, invalid }) =>\n    invalid && {\n      boxShadow: `inset 0 0 0 1px ${theme.color.Flamingo}`\n    },\n  ({ input }) =>\n    input && {\n      padding: 0,\n      width: '100%'\n    },\n  ({ isLast }) =>\n    isLast && {\n      borderRightColor: 'transparent'\n    },\n  ({ isFirst, theme }) =>\n    isFirst && {\n      paddingLeft: theme.space[5]\n    },\n  ({ indent, theme }) =>\n    indent && {\n      paddingLeft: add(theme.space[8], theme.space[3])\n    },\n  getOverrides(Overridable.DataGrid.Cell)\n)\nCell.displayName = 'Cell'\ntype RowProps = {\n  zebra?: boolean\n  selected?: boolean\n  selecting?: boolean\n  header?: boolean\n}\nexport const Row = styled('div')<RowProps>(\n  ({ theme, zebra }) => ({\n    display: 'flex',\n    backgroundColor: zebra\n      ? theme.palette.neutral[1]\n      : theme.palette.neutral[0],\n    // v5 has no border, but v4 does, need borderColor for cells\n    alignItems: 'center',\n    borderBottom: 'none',\n    borderColor: theme.palette.neutral[4], // for cell inheriting\n    color: theme.palette.neutral[11],\n    flexDirection: 'row',\n    fontSize: theme.fontSize[0],\n    ':focus': {\n      outline: `4px auto ${theme.palette.primary[2]}`,\n      outlineOffset: '-1px'\n    },\n    ':hover': {\n      backgroundColor: theme.palette.primary[1]\n    }\n  }),\n  ({ theme, header }) =>\n    header && {\n      backgroundColor: theme.palette.neutral[2]\n    },\n  ({ theme, selected }) =>\n    selected && {\n      backgroundColor: theme.palette.primary[1],\n      borderColor: 'transparent' // for cell inheriting\n    },\n  ({ selecting }) =>\n    selecting && {\n      // prevent text from getting selected when using shift +\n      // click to select multiple rows\n      userSelect: 'none'\n    },\n  getOverrides(Overridable.DataGrid.Row)\n)\nRow.displayName = 'Row'\n\nexport const TableContainer = styled('div')(\n  {\n    overflowX: 'auto',\n    overflowY: 'hidden',\n    border: 'none'\n  },\n  getOverrides(Overridable.DataGrid.TableContainer)\n)\n\nTableContainer.displayName = 'TableContainer'\n\nexport const FilterHeader = styled('div')<{}>(\n  ({ theme }) => ({\n    color: theme.palette.neutral[9],\n    marginBottom: theme.space[3],\n    fontSize: theme.fontSize[1]\n  }),\n  getOverrides(Overridable.DataGrid.FilterHeader)\n)\nFilterHeader.displayName = 'FilterHeader'\n\nexport const FilterButtons = styled('div')<{}>(\n  ({ theme }) => ({\n    display: 'flex',\n    justifyContent: 'flex-end',\n    marginTop: theme.space[6],\n    lineHeight: 1\n  }),\n  getOverrides(Overridable.DataGrid.FilterButtons)\n)\nFilterButtons.displayName = 'FilterButtons'\n\nexport const RightFilterButton = styled(Button)(\n  ({ theme }) => ({\n    marginLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.RightFilterButton)\n)\nRightFilterButton.displayName = 'RightFilterButton'\n\nexport const FilterSeparator = styled('div')<{}>(\n  ({ theme }) => ({\n    marginTop: theme.space[4],\n    paddingTop: theme.space[4],\n    borderTop: `1px solid ${theme.palette.neutral[3]}`\n  }),\n  getOverrides(Overridable.DataGrid.FilterSeparator)\n)\nFilterSeparator.displayName = 'FilterSeparator'\n\ntype StyledSortButtonProps = {\n  noIcon?: boolean\n}\nconst StyledSortButton = styled(Button, {\n  shouldForwardProp: (prop: string) => !['active', 'noIcon'].includes(prop)\n})<StyledSortButtonProps>(({ theme, noIcon }) => ({\n  margin: noIcon ? `${theme.space[1]} 0` : 0\n}))\n\ntype SortButtonProps = {\n  active?: boolean\n  icon?: React.ReactNode\n  label: string\n  onClick: () => void\n}\nexport const SortButton = styled(\n  ({ icon, label, ...props }: { icon: React.ReactNode; label: string }) => (\n    <StyledSortButton plain noIcon={!icon} {...props}>\n      {icon && <ColumnHeaderIcon>{icon}</ColumnHeaderIcon>}\n      {label}\n    </StyledSortButton>\n  )\n)<SortButtonProps>(\n  ({ active, theme }) => ({\n    backgroundColor: active ? theme.palette.primary[1] : 'transparent',\n    borderRadius: theme.radius[4],\n    color: active ? theme.palette.primary[5] : theme.palette.neutral[11],\n    fontSize: theme.fontSize[1],\n    fontWeight: 600,\n    padding: `${theme.space[1]} ${theme.space[4]} ${theme.space[1]} ${theme.space[2]}`,\n    justifyContent: 'flex-start',\n    [ColumnHeaderIcon as any]: {\n      color: 'inherit'\n    },\n    ':hover': {\n      color: active ? theme.palette.primary[5] : theme.palette.primary[4]\n    }\n  }),\n  getOverrides(Overridable.DataGrid.SortButton)\n)\nSortButton.displayName = 'SortButton'\n\ntype InlineInputProps = {\n  textAlign?: 'right' | 'left'\n}\nexport const InlineInput = styled(Input)<InlineInputProps>(\n  ({ theme, textAlign }) => ({\n    borderRadius: 'none',\n    color: theme.color.Mondo,\n    height: '100%',\n    paddingBottom: 0,\n    paddingTop: 0,\n    textAlign,\n    verticalAlign: 'middle',\n    width: '100%',\n    fontSize: theme.fontSize[0],\n    lineHeight: theme.lineHeight[5]\n  })\n)\nInlineInput.displayName = 'InlineInput'\n\nexport const SelectWrapper = styled('div')<{}>({\n  width: '100%'\n})\nSelectWrapper.displayName = 'SelectWrapper'\n\nexport const SymbolDropdownIcon = styled(Icon.Small.ArrowDown)<{}>(\n  ({ theme }) => ({\n    flexShrink: 0,\n    color: theme.color.LightSecondary,\n    // Align SymbolDropdownIcon with the one in Select\n    marginRight: 1\n  })\n)\nSymbolDropdownIcon.displayName = 'SymbolDropdownIcon'\n\ntype CellBodyProps = {\n  type: string\n  rightAlign?: boolean\n}\nexport const CellBody = styled('div')(\n  ({ rightAlign }: CellBodyProps) => ({\n    display: 'flex',\n    justifyContent: rightAlign ? 'flex-end' : 'flex-start',\n    width: '100%',\n    marginLeft: 1\n  }),\n  ({ rightAlign, type }: CellBodyProps) =>\n    type === 'select' && {\n      justifyContent: rightAlign ? 'flex-end' : 'space-between',\n      // Align to location of select text\n      position: 'relative',\n      top: -1,\n      marginLeft: 3,\n      fontSize: '13px',\n      // Align SymbolDropdownIcon with the one in Select\n      alignItems: 'inherit'\n    }\n)\nCellBody.displayName = 'CellBody'\n\nexport const Spacer = styled('div')<{}>(({ theme }) => ({\n  width: theme.space[2],\n  minWidth: theme.space[2]\n}))\n\nexport const OperatorSelect = styled(Select)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\n// Necessary to adjust the type so it preserves the Input generic behavior\nexport const CategoryInput = styled(Input)(\n  ({ theme }) => ({\n    marginBottom: theme.space[4],\n    width: '100%'\n  }),\n  getOverrides(Overridable.DataGrid.CategoryInput)\n) as typeof Input & StyledComponent<any, {}, Theme>\n\nexport const CategoryCheckbox = styled(Checkbox)<{}>(({ theme }) => ({\n  marginBottom: theme.space[2]\n}))\n\nexport const CategoryOptionsContainer = styled('div')<{}>(\n  ({ theme }) => ({\n    maxHeight: 168,\n    minWidth: 175,\n    maxWidth: 200,\n    overflowY: 'auto',\n    paddingLeft: theme.space[1]\n  }),\n  getOverrides(Overridable.DataGrid.CategoryOptionsContainer)\n)\n"]} */");
|
|
564
563
|
exports.CategoryOptionsContainer = CategoryOptionsContainer;
|