@ultraviolet/ui 1.80.0 → 1.81.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/List/ListContext.cjs +5 -3
- package/dist/components/List/ListContext.d.ts +4 -1
- package/dist/components/List/ListContext.js +5 -3
- package/dist/components/List/Row.cjs +20 -10
- package/dist/components/List/Row.d.ts +3 -0
- package/dist/components/List/Row.js +20 -10
- package/dist/components/List/SkeletonRows.cjs +7 -3
- package/dist/components/List/SkeletonRows.js +7 -3
- package/dist/components/List/index.cjs +19 -3
- package/dist/components/List/index.d.ts +4 -10
- package/dist/components/List/index.js +19 -3
- package/dist/components/List/types.d.ts +9 -0
- package/dist/components/Modal/ModalContent.cjs +1 -1
- package/dist/components/Modal/ModalContent.d.ts +1 -1
- package/dist/components/Modal/ModalContent.js +1 -1
- package/dist/components/Popup/animations.d.ts +12 -2
- package/dist/components/ProgressBar/index.cjs +54 -14
- package/dist/components/ProgressBar/index.d.ts +4 -1
- package/dist/components/ProgressBar/index.js +54 -14
- package/dist/components/Table/Row.cjs +19 -9
- package/dist/components/Table/Row.js +19 -9
- package/dist/components/Table/TableContext.cjs +5 -3
- package/dist/components/Table/TableContext.d.ts +4 -1
- package/dist/components/Table/TableContext.js +5 -3
- package/dist/components/Table/index.cjs +19 -3
- package/dist/components/Table/index.d.ts +4 -11
- package/dist/components/Table/index.js +19 -3
- package/dist/components/Table/types.d.ts +10 -0
- package/dist/components/TagInput/index.cjs +4 -4
- package/dist/components/TagInput/index.js +4 -4
- package/dist/components/VerificationCode/index.cjs +2 -2
- package/dist/components/VerificationCode/index.js +2 -2
- package/dist/utils/animations.d.ts +162 -27
- package/package.json +8 -8
|
@@ -3,6 +3,9 @@ import _styled from "@emotion/styled/base";
|
|
|
3
3
|
import { keyframes } from "@emotion/react";
|
|
4
4
|
import { Stack } from "../Stack/index.js";
|
|
5
5
|
import { Text } from "../Text/index.js";
|
|
6
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__() {
|
|
7
|
+
return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
|
|
8
|
+
}
|
|
6
9
|
const shineAnimation = keyframes`
|
|
7
10
|
from {
|
|
8
11
|
left: -25%;
|
|
@@ -13,9 +16,9 @@ const shineAnimation = keyframes`
|
|
|
13
16
|
}
|
|
14
17
|
`;
|
|
15
18
|
const StyledProgressContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
|
|
16
|
-
target: "
|
|
19
|
+
target: "e1b95x8r4"
|
|
17
20
|
} : {
|
|
18
|
-
target: "
|
|
21
|
+
target: "e1b95x8r4",
|
|
19
22
|
label: "StyledProgressContainer"
|
|
20
23
|
})("overflow:hidden;position:relative;height:", ({
|
|
21
24
|
theme
|
|
@@ -23,18 +26,44 @@ const StyledProgressContainer = /* @__PURE__ */ _styled("div", process.env.NODE_
|
|
|
23
26
|
theme
|
|
24
27
|
}) => theme.radii.default, ";background-color:", ({
|
|
25
28
|
theme
|
|
26
|
-
}) => theme.colors.neutral.backgroundStrong, ";width:100%;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
29
|
+
}) => theme.colors.neutral.backgroundStrong, ";width:100%;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/ProgressBar/index.tsx"],"names":[],"mappings":"AAyB0C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/ProgressBar/index.tsx","sourcesContent":["import { keyframes } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport type { Color } from '../../theme'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst shineAnimation = keyframes`\n  from {\n    left: -25%;\n  }\n\n  to {\n    left: 100%;\n  }\n`\n\nexport const progressBarSentiments = [\n  'primary',\n  'success',\n  'warning',\n  'info',\n  'danger',\n] as const\n\nconst StyledProgressContainer = styled.div`\n  overflow: hidden;\n  position: relative;\n  height: ${({ theme }) => theme.sizing['050']};\n  margin-left: 0;\n  margin-right: 0;\n  border-radius: ${({ theme }) => theme.radii.default};\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundStrong};\n  width: 100%;\n`\nconst StyledStack = styled(Stack)`\n  width: fit-content;\n`\nconst StyledText = styled(Text)`\n  width: max-content;\n`\nconst StyledProgress = styled.div`\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  width: 25%;\n  opacity: 0.8;\n  background: linear-gradient(\n    90deg,\n    rgba(255, 255, 255, 0),\n    rgba(255, 255, 255, 0.3),\n    rgba(255, 255, 255, 0.4),\n    rgba(255, 255, 255, 0.3),\n    rgba(255, 255, 255, 0)\n  );\n  animation: ${shineAnimation} 1s linear infinite;\n`\n\nconst StyledFilled = styled('div', {\n  shouldForwardProp: prop => !['sentiment', 'percentageValue'].includes(prop),\n})<{ sentiment: string; percentageValue: number }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  background-color: ${({ theme, sentiment }) =>\n    theme.colors[sentiment as Color].backgroundStrong ?? 'inherit'};\n  transition: 0.3s width;\n  width: ${({ percentageValue }) => percentageValue}%;\n`\n\ntype ProgressBarProps = {\n  sentiment?: (typeof progressBarSentiments)[number]\n  value?: number\n  showProgress?: boolean\n  prefix?: ReactNode\n  suffix?: ReactNode\n  max?: number\n  label?: string\n  labelDescription?: ReactNode\n  direction?: 'column' | 'row'\n  /** Put ProgressBar in a loading state */\n  progress?: boolean\n  className?: string\n  'data-testid'?: string\n  'aria-labelledby'?: string\n  'aria-label'?: string\n}\n\n/**\n * Progress bar component to display progress of a task. Can be used to display progress of a form or a loading state.\n */\nexport const ProgressBar = ({\n  progress = false,\n  value = 0,\n  sentiment = 'primary',\n  className,\n  'data-testid': dataTestId,\n  showProgress = false,\n  prefix,\n  suffix = '%',\n  max = 100,\n  label,\n  labelDescription,\n  direction = 'column',\n  'aria-labelledby': ariaLabelledBy,\n  'aria-label': ariaLabel,\n}: ProgressBarProps) => (\n  <Stack\n    gap={direction === 'column' ? 1 : 2}\n    direction={direction}\n    alignItems=\"center\"\n  >\n    {direction === 'column' && (label || showProgress) ? (\n      <Stack\n        direction=\"row\"\n        justifyContent={!label && showProgress ? 'right' : 'space-between'}\n        width=\"100%\"\n      >\n        <Stack gap={1} direction=\"row\" alignItems=\"center\">\n          {label ? (\n            <Text as=\"label\" variant=\"bodySmallStrong\" sentiment=\"neutral\">\n              {label}\n            </Text>\n          ) : null}\n          {typeof labelDescription === 'string' ? (\n            <Text as=\"label\" variant=\"bodySmall\">\n              {labelDescription}\n            </Text>\n          ) : null}\n          {labelDescription && typeof labelDescription !== 'string'\n            ? labelDescription\n            : null}\n        </Stack>\n        {showProgress ? (\n          <Text\n            as=\"label\"\n            variant=\"bodySmall\"\n            sentiment=\"neutral\"\n            placement=\"right\"\n          >\n            {prefix}\n            {suffix === '%'\n              ? (100 * Math.max(0, Math.min(max, value))) / max\n              : Math.max(0, Math.min(max, value))}\n            {suffix}\n          </Text>\n        ) : null}\n      </Stack>\n    ) : null}\n    {label && direction === 'row' && labelDescription ? (\n      <StyledStack direction=\"row\" gap={1}>\n        <StyledText as=\"label\" variant=\"bodySmallStrong\" sentiment=\"neutral\">\n          {label}\n        </StyledText>\n        {typeof labelDescription === 'string' ? (\n          <Text as=\"label\" variant=\"bodySmall\">\n            {labelDescription}\n          </Text>\n        ) : (\n          labelDescription\n        )}\n      </StyledStack>\n    ) : null}\n    {label && direction === 'row' && !labelDescription ? (\n      <StyledStack direction=\"row\" gap={1}>\n        <StyledText as=\"label\" variant=\"bodySmallStrong\" sentiment=\"neutral\">\n          {label}\n        </StyledText>\n      </StyledStack>\n    ) : null}\n    <StyledProgressContainer\n      role=\"progressbar\"\n      aria-valuenow={value}\n      aria-valuemin={0}\n      aria-valuemax={max}\n      className={className}\n      data-testid={dataTestId}\n      aria-labelledby={ariaLabelledBy}\n      aria-label={ariaLabel}\n    >\n      {progress ? (\n        <StyledProgress />\n      ) : (\n        <StyledFilled\n          sentiment={sentiment}\n          percentageValue={(100 * Math.max(0, Math.min(max, value))) / max}\n        />\n      )}\n    </StyledProgressContainer>\n    {showProgress && direction === 'row' ? (\n      <StyledStack direction=\"row\" gap={1}>\n        <StyledText as=\"label\" variant=\"bodySmall\" sentiment=\"neutral\">\n          {prefix}\n          {suffix === '%'\n            ? (100 * Math.max(0, Math.min(max, value))) / max\n            : Math.max(0, Math.min(max, value))}\n          {suffix}\n        </StyledText>\n      </StyledStack>\n    ) : null}\n  </Stack>\n)\n"]} */"));
|
|
30
|
+
const StyledStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
|
|
31
|
+
target: "e1b95x8r3"
|
|
32
|
+
} : {
|
|
33
|
+
target: "e1b95x8r3",
|
|
34
|
+
label: "StyledStack"
|
|
35
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
36
|
+
name: "1tjylrs",
|
|
37
|
+
styles: "width:fit-content"
|
|
38
|
+
} : {
|
|
39
|
+
name: "1tjylrs",
|
|
40
|
+
styles: "width:fit-content/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/ProgressBar/index.tsx"],"names":[],"mappings":"AAmCiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/ProgressBar/index.tsx","sourcesContent":["import { keyframes } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport type { Color } from '../../theme'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst shineAnimation = keyframes`\n  from {\n    left: -25%;\n  }\n\n  to {\n    left: 100%;\n  }\n`\n\nexport const progressBarSentiments = [\n  'primary',\n  'success',\n  'warning',\n  'info',\n  'danger',\n] as const\n\nconst StyledProgressContainer = styled.div`\n  overflow: hidden;\n  position: relative;\n  height: ${({ theme }) => theme.sizing['050']};\n  margin-left: 0;\n  margin-right: 0;\n  border-radius: ${({ theme }) => theme.radii.default};\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundStrong};\n  width: 100%;\n`\nconst StyledStack = styled(Stack)`\n  width: fit-content;\n`\nconst StyledText = styled(Text)`\n  width: max-content;\n`\nconst StyledProgress = styled.div`\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  width: 25%;\n  opacity: 0.8;\n  background: linear-gradient(\n    90deg,\n    rgba(255, 255, 255, 0),\n    rgba(255, 255, 255, 0.3),\n    rgba(255, 255, 255, 0.4),\n    rgba(255, 255, 255, 0.3),\n    rgba(255, 255, 255, 0)\n  );\n  animation: ${shineAnimation} 1s linear infinite;\n`\n\nconst StyledFilled = styled('div', {\n  shouldForwardProp: prop => !['sentiment', 'percentageValue'].includes(prop),\n})<{ sentiment: string; percentageValue: number }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  background-color: ${({ theme, sentiment }) =>\n    theme.colors[sentiment as Color].backgroundStrong ?? 'inherit'};\n  transition: 0.3s width;\n  width: ${({ percentageValue }) => percentageValue}%;\n`\n\ntype ProgressBarProps = {\n  sentiment?: (typeof progressBarSentiments)[number]\n  value?: number\n  showProgress?: boolean\n  prefix?: ReactNode\n  suffix?: ReactNode\n  max?: number\n  label?: string\n  labelDescription?: ReactNode\n  direction?: 'column' | 'row'\n  /** Put ProgressBar in a loading state */\n  progress?: boolean\n  className?: string\n  'data-testid'?: string\n  'aria-labelledby'?: string\n  'aria-label'?: string\n}\n\n/**\n * Progress bar component to display progress of a task. Can be used to display progress of a form or a loading state.\n */\nexport const ProgressBar = ({\n  progress = false,\n  value = 0,\n  sentiment = 'primary',\n  className,\n  'data-testid': dataTestId,\n  showProgress = false,\n  prefix,\n  suffix = '%',\n  max = 100,\n  label,\n  labelDescription,\n  direction = 'column',\n  'aria-labelledby': ariaLabelledBy,\n  'aria-label': ariaLabel,\n}: ProgressBarProps) => (\n  <Stack\n    gap={direction === 'column' ? 1 : 2}\n    direction={direction}\n    alignItems=\"center\"\n  >\n    {direction === 'column' && (label || showProgress) ? (\n      <Stack\n        direction=\"row\"\n        justifyContent={!label && showProgress ? 'right' : 'space-between'}\n        width=\"100%\"\n      >\n        <Stack gap={1} direction=\"row\" alignItems=\"center\">\n          {label ? (\n            <Text as=\"label\" variant=\"bodySmallStrong\" sentiment=\"neutral\">\n              {label}\n            </Text>\n          ) : null}\n          {typeof labelDescription === 'string' ? (\n            <Text as=\"label\" variant=\"bodySmall\">\n              {labelDescription}\n            </Text>\n          ) : null}\n          {labelDescription && typeof labelDescription !== 'string'\n            ? labelDescription\n            : null}\n        </Stack>\n        {showProgress ? (\n          <Text\n            as=\"label\"\n            variant=\"bodySmall\"\n            sentiment=\"neutral\"\n            placement=\"right\"\n          >\n            {prefix}\n            {suffix === '%'\n              ? (100 * Math.max(0, Math.min(max, value))) / max\n              : Math.max(0, Math.min(max, value))}\n            {suffix}\n          </Text>\n        ) : null}\n      </Stack>\n    ) : null}\n    {label && direction === 'row' && labelDescription ? (\n      <StyledStack direction=\"row\" gap={1}>\n        <StyledText as=\"label\" variant=\"bodySmallStrong\" sentiment=\"neutral\">\n          {label}\n        </StyledText>\n        {typeof labelDescription === 'string' ? (\n          <Text as=\"label\" variant=\"bodySmall\">\n            {labelDescription}\n          </Text>\n        ) : (\n          labelDescription\n        )}\n      </StyledStack>\n    ) : null}\n    {label && direction === 'row' && !labelDescription ? (\n      <StyledStack direction=\"row\" gap={1}>\n        <StyledText as=\"label\" variant=\"bodySmallStrong\" sentiment=\"neutral\">\n          {label}\n        </StyledText>\n      </StyledStack>\n    ) : null}\n    <StyledProgressContainer\n      role=\"progressbar\"\n      aria-valuenow={value}\n      aria-valuemin={0}\n      aria-valuemax={max}\n      className={className}\n      data-testid={dataTestId}\n      aria-labelledby={ariaLabelledBy}\n      aria-label={ariaLabel}\n    >\n      {progress ? (\n        <StyledProgress />\n      ) : (\n        <StyledFilled\n          sentiment={sentiment}\n          percentageValue={(100 * Math.max(0, Math.min(max, value))) / max}\n        />\n      )}\n    </StyledProgressContainer>\n    {showProgress && direction === 'row' ? (\n      <StyledStack direction=\"row\" gap={1}>\n        <StyledText as=\"label\" variant=\"bodySmall\" sentiment=\"neutral\">\n          {prefix}\n          {suffix === '%'\n            ? (100 * Math.max(0, Math.min(max, value))) / max\n            : Math.max(0, Math.min(max, value))}\n          {suffix}\n        </StyledText>\n      </StyledStack>\n    ) : null}\n  </Stack>\n)\n"]} */",
|
|
41
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
42
|
+
});
|
|
43
|
+
const StyledText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "production" ? {
|
|
44
|
+
target: "e1b95x8r2"
|
|
45
|
+
} : {
|
|
46
|
+
target: "e1b95x8r2",
|
|
47
|
+
label: "StyledText"
|
|
48
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
49
|
+
name: "95qvyx",
|
|
50
|
+
styles: "width:max-content"
|
|
51
|
+
} : {
|
|
52
|
+
name: "95qvyx",
|
|
53
|
+
styles: "width:max-content/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/ProgressBar/index.tsx"],"names":[],"mappings":"AAsC+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/ProgressBar/index.tsx","sourcesContent":["import { keyframes } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport type { Color } from '../../theme'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst shineAnimation = keyframes`\n  from {\n    left: -25%;\n  }\n\n  to {\n    left: 100%;\n  }\n`\n\nexport const progressBarSentiments = [\n  'primary',\n  'success',\n  'warning',\n  'info',\n  'danger',\n] as const\n\nconst StyledProgressContainer = styled.div`\n  overflow: hidden;\n  position: relative;\n  height: ${({ theme }) => theme.sizing['050']};\n  margin-left: 0;\n  margin-right: 0;\n  border-radius: ${({ theme }) => theme.radii.default};\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundStrong};\n  width: 100%;\n`\nconst StyledStack = styled(Stack)`\n  width: fit-content;\n`\nconst StyledText = styled(Text)`\n  width: max-content;\n`\nconst StyledProgress = styled.div`\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  width: 25%;\n  opacity: 0.8;\n  background: linear-gradient(\n    90deg,\n    rgba(255, 255, 255, 0),\n    rgba(255, 255, 255, 0.3),\n    rgba(255, 255, 255, 0.4),\n    rgba(255, 255, 255, 0.3),\n    rgba(255, 255, 255, 0)\n  );\n  animation: ${shineAnimation} 1s linear infinite;\n`\n\nconst StyledFilled = styled('div', {\n  shouldForwardProp: prop => !['sentiment', 'percentageValue'].includes(prop),\n})<{ sentiment: string; percentageValue: number }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  background-color: ${({ theme, sentiment }) =>\n    theme.colors[sentiment as Color].backgroundStrong ?? 'inherit'};\n  transition: 0.3s width;\n  width: ${({ percentageValue }) => percentageValue}%;\n`\n\ntype ProgressBarProps = {\n  sentiment?: (typeof progressBarSentiments)[number]\n  value?: number\n  showProgress?: boolean\n  prefix?: ReactNode\n  suffix?: ReactNode\n  max?: number\n  label?: string\n  labelDescription?: ReactNode\n  direction?: 'column' | 'row'\n  /** Put ProgressBar in a loading state */\n  progress?: boolean\n  className?: string\n  'data-testid'?: string\n  'aria-labelledby'?: string\n  'aria-label'?: string\n}\n\n/**\n * Progress bar component to display progress of a task. Can be used to display progress of a form or a loading state.\n */\nexport const ProgressBar = ({\n  progress = false,\n  value = 0,\n  sentiment = 'primary',\n  className,\n  'data-testid': dataTestId,\n  showProgress = false,\n  prefix,\n  suffix = '%',\n  max = 100,\n  label,\n  labelDescription,\n  direction = 'column',\n  'aria-labelledby': ariaLabelledBy,\n  'aria-label': ariaLabel,\n}: ProgressBarProps) => (\n  <Stack\n    gap={direction === 'column' ? 1 : 2}\n    direction={direction}\n    alignItems=\"center\"\n  >\n    {direction === 'column' && (label || showProgress) ? (\n      <Stack\n        direction=\"row\"\n        justifyContent={!label && showProgress ? 'right' : 'space-between'}\n        width=\"100%\"\n      >\n        <Stack gap={1} direction=\"row\" alignItems=\"center\">\n          {label ? (\n            <Text as=\"label\" variant=\"bodySmallStrong\" sentiment=\"neutral\">\n              {label}\n            </Text>\n          ) : null}\n          {typeof labelDescription === 'string' ? (\n            <Text as=\"label\" variant=\"bodySmall\">\n              {labelDescription}\n            </Text>\n          ) : null}\n          {labelDescription && typeof labelDescription !== 'string'\n            ? labelDescription\n            : null}\n        </Stack>\n        {showProgress ? (\n          <Text\n            as=\"label\"\n            variant=\"bodySmall\"\n            sentiment=\"neutral\"\n            placement=\"right\"\n          >\n            {prefix}\n            {suffix === '%'\n              ? (100 * Math.max(0, Math.min(max, value))) / max\n              : Math.max(0, Math.min(max, value))}\n            {suffix}\n          </Text>\n        ) : null}\n      </Stack>\n    ) : null}\n    {label && direction === 'row' && labelDescription ? (\n      <StyledStack direction=\"row\" gap={1}>\n        <StyledText as=\"label\" variant=\"bodySmallStrong\" sentiment=\"neutral\">\n          {label}\n        </StyledText>\n        {typeof labelDescription === 'string' ? (\n          <Text as=\"label\" variant=\"bodySmall\">\n            {labelDescription}\n          </Text>\n        ) : (\n          labelDescription\n        )}\n      </StyledStack>\n    ) : null}\n    {label && direction === 'row' && !labelDescription ? (\n      <StyledStack direction=\"row\" gap={1}>\n        <StyledText as=\"label\" variant=\"bodySmallStrong\" sentiment=\"neutral\">\n          {label}\n        </StyledText>\n      </StyledStack>\n    ) : null}\n    <StyledProgressContainer\n      role=\"progressbar\"\n      aria-valuenow={value}\n      aria-valuemin={0}\n      aria-valuemax={max}\n      className={className}\n      data-testid={dataTestId}\n      aria-labelledby={ariaLabelledBy}\n      aria-label={ariaLabel}\n    >\n      {progress ? (\n        <StyledProgress />\n      ) : (\n        <StyledFilled\n          sentiment={sentiment}\n          percentageValue={(100 * Math.max(0, Math.min(max, value))) / max}\n        />\n      )}\n    </StyledProgressContainer>\n    {showProgress && direction === 'row' ? (\n      <StyledStack direction=\"row\" gap={1}>\n        <StyledText as=\"label\" variant=\"bodySmall\" sentiment=\"neutral\">\n          {prefix}\n          {suffix === '%'\n            ? (100 * Math.max(0, Math.min(max, value))) / max\n            : Math.max(0, Math.min(max, value))}\n          {suffix}\n        </StyledText>\n      </StyledStack>\n    ) : null}\n  </Stack>\n)\n"]} */",
|
|
54
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
55
|
+
});
|
|
27
56
|
const StyledProgress = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
|
|
28
57
|
target: "e1b95x8r1"
|
|
29
58
|
} : {
|
|
30
59
|
target: "e1b95x8r1",
|
|
31
60
|
label: "StyledProgress"
|
|
32
|
-
})("position:absolute;top:0;left:0;bottom:0;width:25%;opacity:0.8;background:linear-gradient(\n 90deg,\n rgba(255, 255, 255, 0),\n rgba(255, 255, 255, 0.3),\n rgba(255, 255, 255, 0.4),\n rgba(255, 255, 255, 0.3),\n rgba(255, 255, 255, 0)\n );animation:", shineAnimation, " 1s linear infinite;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
61
|
+
})("position:absolute;top:0;left:0;bottom:0;width:25%;opacity:0.8;background:linear-gradient(\n 90deg,\n rgba(255, 255, 255, 0),\n rgba(255, 255, 255, 0.3),\n rgba(255, 255, 255, 0.4),\n rgba(255, 255, 255, 0.3),\n rgba(255, 255, 255, 0)\n );animation:", shineAnimation, " 1s linear infinite;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/ProgressBar/index.tsx"],"names":[],"mappings":"AAyCiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/ProgressBar/index.tsx","sourcesContent":["import { keyframes } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport type { Color } from '../../theme'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst shineAnimation = keyframes`\n  from {\n    left: -25%;\n  }\n\n  to {\n    left: 100%;\n  }\n`\n\nexport const progressBarSentiments = [\n  'primary',\n  'success',\n  'warning',\n  'info',\n  'danger',\n] as const\n\nconst StyledProgressContainer = styled.div`\n  overflow: hidden;\n  position: relative;\n  height: ${({ theme }) => theme.sizing['050']};\n  margin-left: 0;\n  margin-right: 0;\n  border-radius: ${({ theme }) => theme.radii.default};\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundStrong};\n  width: 100%;\n`\nconst StyledStack = styled(Stack)`\n  width: fit-content;\n`\nconst StyledText = styled(Text)`\n  width: max-content;\n`\nconst StyledProgress = styled.div`\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  width: 25%;\n  opacity: 0.8;\n  background: linear-gradient(\n    90deg,\n    rgba(255, 255, 255, 0),\n    rgba(255, 255, 255, 0.3),\n    rgba(255, 255, 255, 0.4),\n    rgba(255, 255, 255, 0.3),\n    rgba(255, 255, 255, 0)\n  );\n  animation: ${shineAnimation} 1s linear infinite;\n`\n\nconst StyledFilled = styled('div', {\n  shouldForwardProp: prop => !['sentiment', 'percentageValue'].includes(prop),\n})<{ sentiment: string; percentageValue: number }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  background-color: ${({ theme, sentiment }) =>\n    theme.colors[sentiment as Color].backgroundStrong ?? 'inherit'};\n  transition: 0.3s width;\n  width: ${({ percentageValue }) => percentageValue}%;\n`\n\ntype ProgressBarProps = {\n  sentiment?: (typeof progressBarSentiments)[number]\n  value?: number\n  showProgress?: boolean\n  prefix?: ReactNode\n  suffix?: ReactNode\n  max?: number\n  label?: string\n  labelDescription?: ReactNode\n  direction?: 'column' | 'row'\n  /** Put ProgressBar in a loading state */\n  progress?: boolean\n  className?: string\n  'data-testid'?: string\n  'aria-labelledby'?: string\n  'aria-label'?: string\n}\n\n/**\n * Progress bar component to display progress of a task. Can be used to display progress of a form or a loading state.\n */\nexport const ProgressBar = ({\n  progress = false,\n  value = 0,\n  sentiment = 'primary',\n  className,\n  'data-testid': dataTestId,\n  showProgress = false,\n  prefix,\n  suffix = '%',\n  max = 100,\n  label,\n  labelDescription,\n  direction = 'column',\n  'aria-labelledby': ariaLabelledBy,\n  'aria-label': ariaLabel,\n}: ProgressBarProps) => (\n  <Stack\n    gap={direction === 'column' ? 1 : 2}\n    direction={direction}\n    alignItems=\"center\"\n  >\n    {direction === 'column' && (label || showProgress) ? (\n      <Stack\n        direction=\"row\"\n        justifyContent={!label && showProgress ? 'right' : 'space-between'}\n        width=\"100%\"\n      >\n        <Stack gap={1} direction=\"row\" alignItems=\"center\">\n          {label ? (\n            <Text as=\"label\" variant=\"bodySmallStrong\" sentiment=\"neutral\">\n              {label}\n            </Text>\n          ) : null}\n          {typeof labelDescription === 'string' ? (\n            <Text as=\"label\" variant=\"bodySmall\">\n              {labelDescription}\n            </Text>\n          ) : null}\n          {labelDescription && typeof labelDescription !== 'string'\n            ? labelDescription\n            : null}\n        </Stack>\n        {showProgress ? (\n          <Text\n            as=\"label\"\n            variant=\"bodySmall\"\n            sentiment=\"neutral\"\n            placement=\"right\"\n          >\n            {prefix}\n            {suffix === '%'\n              ? (100 * Math.max(0, Math.min(max, value))) / max\n              : Math.max(0, Math.min(max, value))}\n            {suffix}\n          </Text>\n        ) : null}\n      </Stack>\n    ) : null}\n    {label && direction === 'row' && labelDescription ? (\n      <StyledStack direction=\"row\" gap={1}>\n        <StyledText as=\"label\" variant=\"bodySmallStrong\" sentiment=\"neutral\">\n          {label}\n        </StyledText>\n        {typeof labelDescription === 'string' ? (\n          <Text as=\"label\" variant=\"bodySmall\">\n            {labelDescription}\n          </Text>\n        ) : (\n          labelDescription\n        )}\n      </StyledStack>\n    ) : null}\n    {label && direction === 'row' && !labelDescription ? (\n      <StyledStack direction=\"row\" gap={1}>\n        <StyledText as=\"label\" variant=\"bodySmallStrong\" sentiment=\"neutral\">\n          {label}\n        </StyledText>\n      </StyledStack>\n    ) : null}\n    <StyledProgressContainer\n      role=\"progressbar\"\n      aria-valuenow={value}\n      aria-valuemin={0}\n      aria-valuemax={max}\n      className={className}\n      data-testid={dataTestId}\n      aria-labelledby={ariaLabelledBy}\n      aria-label={ariaLabel}\n    >\n      {progress ? (\n        <StyledProgress />\n      ) : (\n        <StyledFilled\n          sentiment={sentiment}\n          percentageValue={(100 * Math.max(0, Math.min(max, value))) / max}\n        />\n      )}\n    </StyledProgressContainer>\n    {showProgress && direction === 'row' ? (\n      <StyledStack direction=\"row\" gap={1}>\n        <StyledText as=\"label\" variant=\"bodySmall\" sentiment=\"neutral\">\n          {prefix}\n          {suffix === '%'\n            ? (100 * Math.max(0, Math.min(max, value))) / max\n            : Math.max(0, Math.min(max, value))}\n          {suffix}\n        </StyledText>\n      </StyledStack>\n    ) : null}\n  </Stack>\n)\n"]} */"));
|
|
33
62
|
const StyledFilled = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
|
|
34
|
-
shouldForwardProp: (prop) => !["sentiment", "
|
|
63
|
+
shouldForwardProp: (prop) => !["sentiment", "percentageValue"].includes(prop),
|
|
35
64
|
target: "e1b95x8r0"
|
|
36
65
|
} : {
|
|
37
|
-
shouldForwardProp: (prop) => !["sentiment", "
|
|
66
|
+
shouldForwardProp: (prop) => !["sentiment", "percentageValue"].includes(prop),
|
|
38
67
|
target: "e1b95x8r0",
|
|
39
68
|
label: "StyledFilled"
|
|
40
69
|
})("border-radius:", ({
|
|
@@ -43,8 +72,8 @@ const StyledFilled = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "pr
|
|
|
43
72
|
theme,
|
|
44
73
|
sentiment
|
|
45
74
|
}) => theme.colors[sentiment].backgroundStrong ?? "inherit", ";transition:0.3s width;width:", ({
|
|
46
|
-
|
|
47
|
-
}) =>
|
|
75
|
+
percentageValue
|
|
76
|
+
}) => percentageValue, "%;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/ProgressBar/index.tsx"],"names":[],"mappings":"AA6DkD","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/ProgressBar/index.tsx","sourcesContent":["import { keyframes } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport type { Color } from '../../theme'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst shineAnimation = keyframes`\n  from {\n    left: -25%;\n  }\n\n  to {\n    left: 100%;\n  }\n`\n\nexport const progressBarSentiments = [\n  'primary',\n  'success',\n  'warning',\n  'info',\n  'danger',\n] as const\n\nconst StyledProgressContainer = styled.div`\n  overflow: hidden;\n  position: relative;\n  height: ${({ theme }) => theme.sizing['050']};\n  margin-left: 0;\n  margin-right: 0;\n  border-radius: ${({ theme }) => theme.radii.default};\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundStrong};\n  width: 100%;\n`\nconst StyledStack = styled(Stack)`\n  width: fit-content;\n`\nconst StyledText = styled(Text)`\n  width: max-content;\n`\nconst StyledProgress = styled.div`\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  width: 25%;\n  opacity: 0.8;\n  background: linear-gradient(\n    90deg,\n    rgba(255, 255, 255, 0),\n    rgba(255, 255, 255, 0.3),\n    rgba(255, 255, 255, 0.4),\n    rgba(255, 255, 255, 0.3),\n    rgba(255, 255, 255, 0)\n  );\n  animation: ${shineAnimation} 1s linear infinite;\n`\n\nconst StyledFilled = styled('div', {\n  shouldForwardProp: prop => !['sentiment', 'percentageValue'].includes(prop),\n})<{ sentiment: string; percentageValue: number }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  background-color: ${({ theme, sentiment }) =>\n    theme.colors[sentiment as Color].backgroundStrong ?? 'inherit'};\n  transition: 0.3s width;\n  width: ${({ percentageValue }) => percentageValue}%;\n`\n\ntype ProgressBarProps = {\n  sentiment?: (typeof progressBarSentiments)[number]\n  value?: number\n  showProgress?: boolean\n  prefix?: ReactNode\n  suffix?: ReactNode\n  max?: number\n  label?: string\n  labelDescription?: ReactNode\n  direction?: 'column' | 'row'\n  /** Put ProgressBar in a loading state */\n  progress?: boolean\n  className?: string\n  'data-testid'?: string\n  'aria-labelledby'?: string\n  'aria-label'?: string\n}\n\n/**\n * Progress bar component to display progress of a task. Can be used to display progress of a form or a loading state.\n */\nexport const ProgressBar = ({\n  progress = false,\n  value = 0,\n  sentiment = 'primary',\n  className,\n  'data-testid': dataTestId,\n  showProgress = false,\n  prefix,\n  suffix = '%',\n  max = 100,\n  label,\n  labelDescription,\n  direction = 'column',\n  'aria-labelledby': ariaLabelledBy,\n  'aria-label': ariaLabel,\n}: ProgressBarProps) => (\n  <Stack\n    gap={direction === 'column' ? 1 : 2}\n    direction={direction}\n    alignItems=\"center\"\n  >\n    {direction === 'column' && (label || showProgress) ? (\n      <Stack\n        direction=\"row\"\n        justifyContent={!label && showProgress ? 'right' : 'space-between'}\n        width=\"100%\"\n      >\n        <Stack gap={1} direction=\"row\" alignItems=\"center\">\n          {label ? (\n            <Text as=\"label\" variant=\"bodySmallStrong\" sentiment=\"neutral\">\n              {label}\n            </Text>\n          ) : null}\n          {typeof labelDescription === 'string' ? (\n            <Text as=\"label\" variant=\"bodySmall\">\n              {labelDescription}\n            </Text>\n          ) : null}\n          {labelDescription && typeof labelDescription !== 'string'\n            ? labelDescription\n            : null}\n        </Stack>\n        {showProgress ? (\n          <Text\n            as=\"label\"\n            variant=\"bodySmall\"\n            sentiment=\"neutral\"\n            placement=\"right\"\n          >\n            {prefix}\n            {suffix === '%'\n              ? (100 * Math.max(0, Math.min(max, value))) / max\n              : Math.max(0, Math.min(max, value))}\n            {suffix}\n          </Text>\n        ) : null}\n      </Stack>\n    ) : null}\n    {label && direction === 'row' && labelDescription ? (\n      <StyledStack direction=\"row\" gap={1}>\n        <StyledText as=\"label\" variant=\"bodySmallStrong\" sentiment=\"neutral\">\n          {label}\n        </StyledText>\n        {typeof labelDescription === 'string' ? (\n          <Text as=\"label\" variant=\"bodySmall\">\n            {labelDescription}\n          </Text>\n        ) : (\n          labelDescription\n        )}\n      </StyledStack>\n    ) : null}\n    {label && direction === 'row' && !labelDescription ? (\n      <StyledStack direction=\"row\" gap={1}>\n        <StyledText as=\"label\" variant=\"bodySmallStrong\" sentiment=\"neutral\">\n          {label}\n        </StyledText>\n      </StyledStack>\n    ) : null}\n    <StyledProgressContainer\n      role=\"progressbar\"\n      aria-valuenow={value}\n      aria-valuemin={0}\n      aria-valuemax={max}\n      className={className}\n      data-testid={dataTestId}\n      aria-labelledby={ariaLabelledBy}\n      aria-label={ariaLabel}\n    >\n      {progress ? (\n        <StyledProgress />\n      ) : (\n        <StyledFilled\n          sentiment={sentiment}\n          percentageValue={(100 * Math.max(0, Math.min(max, value))) / max}\n        />\n      )}\n    </StyledProgressContainer>\n    {showProgress && direction === 'row' ? (\n      <StyledStack direction=\"row\" gap={1}>\n        <StyledText as=\"label\" variant=\"bodySmall\" sentiment=\"neutral\">\n          {prefix}\n          {suffix === '%'\n            ? (100 * Math.max(0, Math.min(max, value))) / max\n            : Math.max(0, Math.min(max, value))}\n          {suffix}\n        </StyledText>\n      </StyledStack>\n    ) : null}\n  </Stack>\n)\n"]} */"));
|
|
48
77
|
const ProgressBar = ({
|
|
49
78
|
progress = false,
|
|
50
79
|
value = 0,
|
|
@@ -52,6 +81,9 @@ const ProgressBar = ({
|
|
|
52
81
|
className,
|
|
53
82
|
"data-testid": dataTestId,
|
|
54
83
|
showProgress = false,
|
|
84
|
+
prefix,
|
|
85
|
+
suffix = "%",
|
|
86
|
+
max = 100,
|
|
55
87
|
label,
|
|
56
88
|
labelDescription,
|
|
57
89
|
direction = "column",
|
|
@@ -64,15 +96,23 @@ const ProgressBar = ({
|
|
|
64
96
|
typeof labelDescription === "string" ? /* @__PURE__ */ jsx(Text, { as: "label", variant: "bodySmall", children: labelDescription }) : null,
|
|
65
97
|
labelDescription && typeof labelDescription !== "string" ? labelDescription : null
|
|
66
98
|
] }),
|
|
67
|
-
showProgress ? /* @__PURE__ */
|
|
99
|
+
showProgress ? /* @__PURE__ */ jsxs(Text, { as: "label", variant: "bodySmall", sentiment: "neutral", placement: "right", children: [
|
|
100
|
+
prefix,
|
|
101
|
+
suffix === "%" ? 100 * Math.max(0, Math.min(max, value)) / max : Math.max(0, Math.min(max, value)),
|
|
102
|
+
suffix
|
|
103
|
+
] }) : null
|
|
68
104
|
] }) : null,
|
|
69
|
-
label && direction === "row" && labelDescription ? /* @__PURE__ */ jsxs(
|
|
70
|
-
/* @__PURE__ */ jsx(
|
|
105
|
+
label && direction === "row" && labelDescription ? /* @__PURE__ */ jsxs(StyledStack, { direction: "row", gap: 1, children: [
|
|
106
|
+
/* @__PURE__ */ jsx(StyledText, { as: "label", variant: "bodySmallStrong", sentiment: "neutral", children: label }),
|
|
71
107
|
typeof labelDescription === "string" ? /* @__PURE__ */ jsx(Text, { as: "label", variant: "bodySmall", children: labelDescription }) : labelDescription
|
|
72
108
|
] }) : null,
|
|
73
|
-
label && direction === "row" && !labelDescription ? /* @__PURE__ */ jsx(
|
|
74
|
-
/* @__PURE__ */ jsx(StyledProgressContainer, { role: "progressbar", "aria-valuenow": value, "aria-valuemin": 0, "aria-valuemax":
|
|
75
|
-
showProgress && direction === "row" ? /* @__PURE__ */ jsx(
|
|
109
|
+
label && direction === "row" && !labelDescription ? /* @__PURE__ */ jsx(StyledStack, { direction: "row", gap: 1, children: /* @__PURE__ */ jsx(StyledText, { as: "label", variant: "bodySmallStrong", sentiment: "neutral", children: label }) }) : null,
|
|
110
|
+
/* @__PURE__ */ jsx(StyledProgressContainer, { role: "progressbar", "aria-valuenow": value, "aria-valuemin": 0, "aria-valuemax": max, className, "data-testid": dataTestId, "aria-labelledby": ariaLabelledBy, "aria-label": ariaLabel, children: progress ? /* @__PURE__ */ jsx(StyledProgress, {}) : /* @__PURE__ */ jsx(StyledFilled, { sentiment, percentageValue: 100 * Math.max(0, Math.min(max, value)) / max }) }),
|
|
111
|
+
showProgress && direction === "row" ? /* @__PURE__ */ jsx(StyledStack, { direction: "row", gap: 1, children: /* @__PURE__ */ jsxs(StyledText, { as: "label", variant: "bodySmall", sentiment: "neutral", children: [
|
|
112
|
+
prefix,
|
|
113
|
+
suffix === "%" ? 100 * Math.max(0, Math.min(max, value)) / max : Math.max(0, Math.min(max, value)),
|
|
114
|
+
suffix
|
|
115
|
+
] }) }) : null
|
|
76
116
|
] });
|
|
77
117
|
export {
|
|
78
118
|
ProgressBar
|
|
@@ -27,7 +27,7 @@ const ExpandableWrapper = /* @__PURE__ */ _styled__default.default("tr", process
|
|
|
27
27
|
theme
|
|
28
28
|
}) => theme.radii.default, " ", ({
|
|
29
29
|
theme
|
|
30
|
-
}) => theme.radii.default, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx"],"names":[],"mappings":"AAYmC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx","sourcesContent":["import type { Theme } from '@emotion/react'\nimport { keyframes, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { Children, useCallback, useEffect, useRef } from 'react'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useTableContext } from './TableContext'\nimport { SELECTABLE_CHECKBOX_SIZE } from './constants'\n\nconst ExpandableWrapper = styled.tr`\n  width: 100%;\n  display: table-row;\n  vertical-align: middle;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  padding: ${({ theme }) => theme.space['1']};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\n  width: ${({ theme }) => theme.sizing[SELECTABLE_CHECKBOX_SIZE]};\n`\n\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n\n    rect {\n      ${({ theme, inRange }) => (inRange ? `fill: ${theme.colors.neutral.backgroundHover};stroke: ${theme.colors.neutral.borderHover};` : '')}\n    }\n`\n\n// We start at 5% and finish at 80% to leave the original background color\n// as we can't know if the table will be stripped or not\nconst colorChange = (theme: Theme) => keyframes`\n  5% {\n    background-color: ${theme.colors.primary.background};\n  }\n  80% {\n    background-color: ${theme.colors.primary.background};\n  }\n`\n\nconst StyledTr = styled('tr', {\n  shouldForwardProp: prop => !['highlightAnimation'].includes(prop),\n})<{ highlightAnimation?: boolean }>`\n  animation: ${({ highlightAnimation, theme }) =>\n    highlightAnimation ? colorChange(theme) : undefined}\n    3s linear;\n`\n\nconst NoPaddingCell = styled(Cell, {\n  shouldForwardProp: prop => !['maxWidth'].includes(prop),\n})<{ maxWidth?: string }>`\n  padding: 0;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n\n  max-width: ${({ maxWidth }) => maxWidth};\n`\n\ntype RowProps = {\n  children: ReactNode\n  expandable?: ReactNode\n  className?: string\n  id: string\n  'data-testid'?: string\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  highlightAnimation?: boolean\n  expanded?: boolean\n}\n\nexport const Row = ({\n  children,\n  className,\n  id,\n  selectDisabled,\n  highlightAnimation,\n  expandable,\n  expanded,\n  'data-testid': dataTestid,\n}: RowProps) => {\n  const {\n    selectable,\n    registerExpandableRow,\n    expandedRowIds,\n    expandRow,\n    collapseRow,\n    registerSelectableRow,\n    selectedRowIds,\n    selectRow,\n    unselectRow,\n    expandButton,\n    ref,\n    inRange,\n  } = useTableContext()\n  const rowRef = useRef<HTMLInputElement>(null)\n\n  const hasExpandable = !!expandable\n  useEffect(() => {\n    if (hasExpandable) {\n      const unregisterCallback = registerExpandableRow(id, expanded)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n  useEffect(() => {\n    if (!selectDisabled) {\n      const unregisterCallback = registerSelectableRow(id)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, registerSelectableRow, selectDisabled])\n\n  const toggleRowExpand = useCallback(() => {\n    if (expandedRowIds[id]) {\n      collapseRow(id)\n    } else {\n      expandRow(id)\n    }\n  }, [collapseRow, expandRow, expandedRowIds, id])\n\n  const canClickRowToExpand = hasExpandable && !expandButton\n\n  useEffect(() => {\n    const refAtEffectStart = ref.current\n    const { current } = rowRef\n\n    if (refAtEffectStart && current && !refAtEffectStart.includes(current)) {\n      ref.current.push(current)\n    }\n  }, [ref])\n\n  const theme = useTheme()\n\n  const childrenLength =\n    Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0)\n\n  return (\n    <>\n      <StyledTr\n        className={className}\n        data-testid={dataTestid}\n        highlightAnimation={highlightAnimation}\n        role={canClickRowToExpand ? 'button row' : 'row'}\n      >\n        {selectable ? (\n          <NoPaddingCell maxWidth={theme.sizing[SELECTABLE_CHECKBOX_SIZE]}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <StyledCheckbox\n                  name=\"table-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={selectDisabled !== undefined}\n                  ref={rowRef}\n                  inRange={inRange.includes(id)}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </NoPaddingCell>\n        ) : null}\n        {expandButton ? (\n          <NoPaddingCell>\n            <Button\n              disabled={!expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"xsmall\"\n              sentiment=\"neutral\"\n              variant=\"ghost\"\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n            />\n          </NoPaddingCell>\n        ) : null}\n        {children}\n      </StyledTr>\n      {expandable && expandedRowIds[id] ? (\n        <ExpandableWrapper\n          data-expandable-content\n          onClick={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n          onKeyDown={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n        >\n          <Cell colSpan={childrenLength}>{expandable}</Cell>\n        </ExpandableWrapper>\n      ) : null}\n    </>\n  )\n}\n"]} */"));
|
|
30
|
+
}) => theme.radii.default, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx"],"names":[],"mappings":"AAamC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx","sourcesContent":["import type { Theme } from '@emotion/react'\nimport { keyframes, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { Children, useCallback, useEffect, useRef } from 'react'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useTableContext } from './TableContext'\nimport { SELECTABLE_CHECKBOX_SIZE } from './constants'\nimport type { ColumnProps } from './types'\n\nconst ExpandableWrapper = styled.tr`\n  width: 100%;\n  display: table-row;\n  vertical-align: middle;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  padding: ${({ theme }) => theme.space['1']};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\n  width: ${({ theme }) => theme.sizing[SELECTABLE_CHECKBOX_SIZE]};\n`\n\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n\n    rect {\n      ${({ theme, inRange }) => (inRange ? `fill: ${theme.colors.neutral.backgroundHover};stroke: ${theme.colors.neutral.borderHover};` : '')}\n    }\n`\n\n// We start at 5% and finish at 80% to leave the original background color\n// as we can't know if the table will be stripped or not\nconst colorChange = (theme: Theme) => keyframes`\n  5% {\n    background-color: ${theme.colors.primary.background};\n  }\n  80% {\n    background-color: ${theme.colors.primary.background};\n  }\n`\n\nconst StyledTr = styled('tr', {\n  shouldForwardProp: prop =>\n    !['highlightAnimation', 'columns', 'columnsStartAt'].includes(prop),\n})<{\n  highlightAnimation?: boolean\n  columns: ColumnProps[]\n  columnsStartAt?: number\n}>`\n  animation: ${({ highlightAnimation, theme }) =>\n    highlightAnimation ? colorChange(theme) : undefined}\n    3s linear;\n\n  ${({ columns, columnsStartAt }) =>\n    columns.map(\n      (column, index) => `\n    td:nth-of-type(${index + 1 + (columnsStartAt ?? 0)}) {\n      ${column.width ? `width: ${column.width};` : ''}\n      ${column.minWidth ? `min-width: ${column.minWidth};` : ''}\n      ${column.maxWidth ? `max-width: ${column.maxWidth};` : ''}\n    }\n  `,\n    )}\n`\n\nconst NoPaddingCell = styled(Cell, {\n  shouldForwardProp: prop => !['maxWidth'].includes(prop),\n})<{ maxWidth?: string }>`\n  padding: 0;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n\n  max-width: ${({ maxWidth }) => maxWidth};\n`\n\ntype RowProps = {\n  children: ReactNode\n  expandable?: ReactNode\n  className?: string\n  id: string\n  'data-testid'?: string\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  highlightAnimation?: boolean\n  expanded?: boolean\n}\n\nexport const Row = ({\n  children,\n  className,\n  id,\n  selectDisabled,\n  highlightAnimation,\n  expandable,\n  expanded,\n  'data-testid': dataTestid,\n}: RowProps) => {\n  const {\n    selectable,\n    registerExpandableRow,\n    expandedRowIds,\n    expandRow,\n    collapseRow,\n    registerSelectableRow,\n    selectedRowIds,\n    selectRow,\n    unselectRow,\n    expandButton,\n    ref,\n    inRange,\n    columns,\n  } = useTableContext()\n  const rowRef = useRef<HTMLInputElement>(null)\n\n  const hasExpandable = !!expandable\n  useEffect(() => {\n    if (hasExpandable) {\n      const unregisterCallback = registerExpandableRow(id, expanded)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n  useEffect(() => {\n    if (!selectDisabled) {\n      const unregisterCallback = registerSelectableRow(id)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, registerSelectableRow, selectDisabled])\n\n  const toggleRowExpand = useCallback(() => {\n    if (expandedRowIds[id]) {\n      collapseRow(id)\n    } else {\n      expandRow(id)\n    }\n  }, [collapseRow, expandRow, expandedRowIds, id])\n\n  const canClickRowToExpand = hasExpandable && !expandButton\n\n  useEffect(() => {\n    const refAtEffectStart = ref.current\n    const { current } = rowRef\n\n    if (refAtEffectStart && current && !refAtEffectStart.includes(current)) {\n      ref.current.push(current)\n    }\n  }, [ref])\n\n  const theme = useTheme()\n\n  const childrenLength =\n    Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0)\n\n  return (\n    <>\n      <StyledTr\n        className={className}\n        data-testid={dataTestid}\n        highlightAnimation={highlightAnimation}\n        role={canClickRowToExpand ? 'button row' : 'row'}\n        columns={columns}\n        columnsStartAt={(selectable ? 1 : 0) + (expandButton ? 1 : 0)}\n      >\n        {selectable ? (\n          <NoPaddingCell maxWidth={theme.sizing[SELECTABLE_CHECKBOX_SIZE]}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <StyledCheckbox\n                  name=\"table-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={selectDisabled !== undefined}\n                  ref={rowRef}\n                  inRange={inRange.includes(id)}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </NoPaddingCell>\n        ) : null}\n        {expandButton ? (\n          <NoPaddingCell>\n            <Button\n              disabled={!expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"xsmall\"\n              sentiment=\"neutral\"\n              variant=\"ghost\"\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n            />\n          </NoPaddingCell>\n        ) : null}\n        {children}\n      </StyledTr>\n      {expandable && expandedRowIds[id] ? (\n        <ExpandableWrapper\n          data-expandable-content\n          onClick={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n          onKeyDown={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n        >\n          <Cell colSpan={childrenLength}>{expandable}</Cell>\n        </ExpandableWrapper>\n      ) : null}\n    </>\n  )\n}\n"]} */"));
|
|
31
31
|
const StyledCheckboxContainer = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
|
|
32
32
|
target: "e1qvrbgq3"
|
|
33
33
|
} : {
|
|
@@ -35,7 +35,7 @@ const StyledCheckboxContainer = /* @__PURE__ */ _styled__default.default("div",
|
|
|
35
35
|
label: "StyledCheckboxContainer"
|
|
36
36
|
})("display:flex;width:", ({
|
|
37
37
|
theme
|
|
38
|
-
}) => theme.sizing[constants.SELECTABLE_CHECKBOX_SIZE], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx"],"names":[],"mappings":"AAuB0C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx","sourcesContent":["import type { Theme } from '@emotion/react'\nimport { keyframes, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { Children, useCallback, useEffect, useRef } from 'react'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useTableContext } from './TableContext'\nimport { SELECTABLE_CHECKBOX_SIZE } from './constants'\n\nconst ExpandableWrapper = styled.tr`\n  width: 100%;\n  display: table-row;\n  vertical-align: middle;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  padding: ${({ theme }) => theme.space['1']};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\n  width: ${({ theme }) => theme.sizing[SELECTABLE_CHECKBOX_SIZE]};\n`\n\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n\n    rect {\n      ${({ theme, inRange }) => (inRange ? `fill: ${theme.colors.neutral.backgroundHover};stroke: ${theme.colors.neutral.borderHover};` : '')}\n    }\n`\n\n// We start at 5% and finish at 80% to leave the original background color\n// as we can't know if the table will be stripped or not\nconst colorChange = (theme: Theme) => keyframes`\n  5% {\n    background-color: ${theme.colors.primary.background};\n  }\n  80% {\n    background-color: ${theme.colors.primary.background};\n  }\n`\n\nconst StyledTr = styled('tr', {\n  shouldForwardProp: prop => !['highlightAnimation'].includes(prop),\n})<{ highlightAnimation?: boolean }>`\n  animation: ${({ highlightAnimation, theme }) =>\n    highlightAnimation ? colorChange(theme) : undefined}\n    3s linear;\n`\n\nconst NoPaddingCell = styled(Cell, {\n  shouldForwardProp: prop => !['maxWidth'].includes(prop),\n})<{ maxWidth?: string }>`\n  padding: 0;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n\n  max-width: ${({ maxWidth }) => maxWidth};\n`\n\ntype RowProps = {\n  children: ReactNode\n  expandable?: ReactNode\n  className?: string\n  id: string\n  'data-testid'?: string\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  highlightAnimation?: boolean\n  expanded?: boolean\n}\n\nexport const Row = ({\n  children,\n  className,\n  id,\n  selectDisabled,\n  highlightAnimation,\n  expandable,\n  expanded,\n  'data-testid': dataTestid,\n}: RowProps) => {\n  const {\n    selectable,\n    registerExpandableRow,\n    expandedRowIds,\n    expandRow,\n    collapseRow,\n    registerSelectableRow,\n    selectedRowIds,\n    selectRow,\n    unselectRow,\n    expandButton,\n    ref,\n    inRange,\n  } = useTableContext()\n  const rowRef = useRef<HTMLInputElement>(null)\n\n  const hasExpandable = !!expandable\n  useEffect(() => {\n    if (hasExpandable) {\n      const unregisterCallback = registerExpandableRow(id, expanded)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n  useEffect(() => {\n    if (!selectDisabled) {\n      const unregisterCallback = registerSelectableRow(id)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, registerSelectableRow, selectDisabled])\n\n  const toggleRowExpand = useCallback(() => {\n    if (expandedRowIds[id]) {\n      collapseRow(id)\n    } else {\n      expandRow(id)\n    }\n  }, [collapseRow, expandRow, expandedRowIds, id])\n\n  const canClickRowToExpand = hasExpandable && !expandButton\n\n  useEffect(() => {\n    const refAtEffectStart = ref.current\n    const { current } = rowRef\n\n    if (refAtEffectStart && current && !refAtEffectStart.includes(current)) {\n      ref.current.push(current)\n    }\n  }, [ref])\n\n  const theme = useTheme()\n\n  const childrenLength =\n    Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0)\n\n  return (\n    <>\n      <StyledTr\n        className={className}\n        data-testid={dataTestid}\n        highlightAnimation={highlightAnimation}\n        role={canClickRowToExpand ? 'button row' : 'row'}\n      >\n        {selectable ? (\n          <NoPaddingCell maxWidth={theme.sizing[SELECTABLE_CHECKBOX_SIZE]}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <StyledCheckbox\n                  name=\"table-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={selectDisabled !== undefined}\n                  ref={rowRef}\n                  inRange={inRange.includes(id)}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </NoPaddingCell>\n        ) : null}\n        {expandButton ? (\n          <NoPaddingCell>\n            <Button\n              disabled={!expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"xsmall\"\n              sentiment=\"neutral\"\n              variant=\"ghost\"\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n            />\n          </NoPaddingCell>\n        ) : null}\n        {children}\n      </StyledTr>\n      {expandable && expandedRowIds[id] ? (\n        <ExpandableWrapper\n          data-expandable-content\n          onClick={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n          onKeyDown={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n        >\n          <Cell colSpan={childrenLength}>{expandable}</Cell>\n        </ExpandableWrapper>\n      ) : null}\n    </>\n  )\n}\n"]} */"));
|
|
38
|
+
}) => theme.sizing[constants.SELECTABLE_CHECKBOX_SIZE], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx"],"names":[],"mappings":"AAwB0C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx","sourcesContent":["import type { Theme } from '@emotion/react'\nimport { keyframes, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { Children, useCallback, useEffect, useRef } from 'react'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useTableContext } from './TableContext'\nimport { SELECTABLE_CHECKBOX_SIZE } from './constants'\nimport type { ColumnProps } from './types'\n\nconst ExpandableWrapper = styled.tr`\n  width: 100%;\n  display: table-row;\n  vertical-align: middle;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  padding: ${({ theme }) => theme.space['1']};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\n  width: ${({ theme }) => theme.sizing[SELECTABLE_CHECKBOX_SIZE]};\n`\n\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n\n    rect {\n      ${({ theme, inRange }) => (inRange ? `fill: ${theme.colors.neutral.backgroundHover};stroke: ${theme.colors.neutral.borderHover};` : '')}\n    }\n`\n\n// We start at 5% and finish at 80% to leave the original background color\n// as we can't know if the table will be stripped or not\nconst colorChange = (theme: Theme) => keyframes`\n  5% {\n    background-color: ${theme.colors.primary.background};\n  }\n  80% {\n    background-color: ${theme.colors.primary.background};\n  }\n`\n\nconst StyledTr = styled('tr', {\n  shouldForwardProp: prop =>\n    !['highlightAnimation', 'columns', 'columnsStartAt'].includes(prop),\n})<{\n  highlightAnimation?: boolean\n  columns: ColumnProps[]\n  columnsStartAt?: number\n}>`\n  animation: ${({ highlightAnimation, theme }) =>\n    highlightAnimation ? colorChange(theme) : undefined}\n    3s linear;\n\n  ${({ columns, columnsStartAt }) =>\n    columns.map(\n      (column, index) => `\n    td:nth-of-type(${index + 1 + (columnsStartAt ?? 0)}) {\n      ${column.width ? `width: ${column.width};` : ''}\n      ${column.minWidth ? `min-width: ${column.minWidth};` : ''}\n      ${column.maxWidth ? `max-width: ${column.maxWidth};` : ''}\n    }\n  `,\n    )}\n`\n\nconst NoPaddingCell = styled(Cell, {\n  shouldForwardProp: prop => !['maxWidth'].includes(prop),\n})<{ maxWidth?: string }>`\n  padding: 0;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n\n  max-width: ${({ maxWidth }) => maxWidth};\n`\n\ntype RowProps = {\n  children: ReactNode\n  expandable?: ReactNode\n  className?: string\n  id: string\n  'data-testid'?: string\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  highlightAnimation?: boolean\n  expanded?: boolean\n}\n\nexport const Row = ({\n  children,\n  className,\n  id,\n  selectDisabled,\n  highlightAnimation,\n  expandable,\n  expanded,\n  'data-testid': dataTestid,\n}: RowProps) => {\n  const {\n    selectable,\n    registerExpandableRow,\n    expandedRowIds,\n    expandRow,\n    collapseRow,\n    registerSelectableRow,\n    selectedRowIds,\n    selectRow,\n    unselectRow,\n    expandButton,\n    ref,\n    inRange,\n    columns,\n  } = useTableContext()\n  const rowRef = useRef<HTMLInputElement>(null)\n\n  const hasExpandable = !!expandable\n  useEffect(() => {\n    if (hasExpandable) {\n      const unregisterCallback = registerExpandableRow(id, expanded)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n  useEffect(() => {\n    if (!selectDisabled) {\n      const unregisterCallback = registerSelectableRow(id)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, registerSelectableRow, selectDisabled])\n\n  const toggleRowExpand = useCallback(() => {\n    if (expandedRowIds[id]) {\n      collapseRow(id)\n    } else {\n      expandRow(id)\n    }\n  }, [collapseRow, expandRow, expandedRowIds, id])\n\n  const canClickRowToExpand = hasExpandable && !expandButton\n\n  useEffect(() => {\n    const refAtEffectStart = ref.current\n    const { current } = rowRef\n\n    if (refAtEffectStart && current && !refAtEffectStart.includes(current)) {\n      ref.current.push(current)\n    }\n  }, [ref])\n\n  const theme = useTheme()\n\n  const childrenLength =\n    Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0)\n\n  return (\n    <>\n      <StyledTr\n        className={className}\n        data-testid={dataTestid}\n        highlightAnimation={highlightAnimation}\n        role={canClickRowToExpand ? 'button row' : 'row'}\n        columns={columns}\n        columnsStartAt={(selectable ? 1 : 0) + (expandButton ? 1 : 0)}\n      >\n        {selectable ? (\n          <NoPaddingCell maxWidth={theme.sizing[SELECTABLE_CHECKBOX_SIZE]}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <StyledCheckbox\n                  name=\"table-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={selectDisabled !== undefined}\n                  ref={rowRef}\n                  inRange={inRange.includes(id)}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </NoPaddingCell>\n        ) : null}\n        {expandButton ? (\n          <NoPaddingCell>\n            <Button\n              disabled={!expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"xsmall\"\n              sentiment=\"neutral\"\n              variant=\"ghost\"\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n            />\n          </NoPaddingCell>\n        ) : null}\n        {children}\n      </StyledTr>\n      {expandable && expandedRowIds[id] ? (\n        <ExpandableWrapper\n          data-expandable-content\n          onClick={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n          onKeyDown={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n        >\n          <Cell colSpan={childrenLength}>{expandable}</Cell>\n        </ExpandableWrapper>\n      ) : null}\n    </>\n  )\n}\n"]} */"));
|
|
39
39
|
const StyledCheckbox = /* @__PURE__ */ _styled__default.default(index.Checkbox, process.env.NODE_ENV === "production" ? {
|
|
40
40
|
shouldForwardProp: (prop) => !["inRange"].includes(prop),
|
|
41
41
|
target: "e1qvrbgq2"
|
|
@@ -46,7 +46,7 @@ const StyledCheckbox = /* @__PURE__ */ _styled__default.default(index.Checkbox,
|
|
|
46
46
|
})("rect{", ({
|
|
47
47
|
theme,
|
|
48
48
|
inRange
|
|
49
|
-
}) => inRange ? `fill: ${theme.colors.neutral.backgroundHover};stroke: ${theme.colors.neutral.borderHover};` : "", ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx"],"names":[],"mappings":"AA8BwB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx","sourcesContent":["import type { Theme } from '@emotion/react'\nimport { keyframes, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { Children, useCallback, useEffect, useRef } from 'react'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useTableContext } from './TableContext'\nimport { SELECTABLE_CHECKBOX_SIZE } from './constants'\n\nconst ExpandableWrapper = styled.tr`\n  width: 100%;\n  display: table-row;\n  vertical-align: middle;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  padding: ${({ theme }) => theme.space['1']};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\n  width: ${({ theme }) => theme.sizing[SELECTABLE_CHECKBOX_SIZE]};\n`\n\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n\n    rect {\n      ${({ theme, inRange }) => (inRange ? `fill: ${theme.colors.neutral.backgroundHover};stroke: ${theme.colors.neutral.borderHover};` : '')}\n    }\n`\n\n// We start at 5% and finish at 80% to leave the original background color\n// as we can't know if the table will be stripped or not\nconst colorChange = (theme: Theme) => keyframes`\n  5% {\n    background-color: ${theme.colors.primary.background};\n  }\n  80% {\n    background-color: ${theme.colors.primary.background};\n  }\n`\n\nconst StyledTr = styled('tr', {\n  shouldForwardProp: prop => !['highlightAnimation'].includes(prop),\n})<{ highlightAnimation?: boolean }>`\n  animation: ${({ highlightAnimation, theme }) =>\n    highlightAnimation ? colorChange(theme) : undefined}\n    3s linear;\n`\n\nconst NoPaddingCell = styled(Cell, {\n  shouldForwardProp: prop => !['maxWidth'].includes(prop),\n})<{ maxWidth?: string }>`\n  padding: 0;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n\n  max-width: ${({ maxWidth }) => maxWidth};\n`\n\ntype RowProps = {\n  children: ReactNode\n  expandable?: ReactNode\n  className?: string\n  id: string\n  'data-testid'?: string\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  highlightAnimation?: boolean\n  expanded?: boolean\n}\n\nexport const Row = ({\n  children,\n  className,\n  id,\n  selectDisabled,\n  highlightAnimation,\n  expandable,\n  expanded,\n  'data-testid': dataTestid,\n}: RowProps) => {\n  const {\n    selectable,\n    registerExpandableRow,\n    expandedRowIds,\n    expandRow,\n    collapseRow,\n    registerSelectableRow,\n    selectedRowIds,\n    selectRow,\n    unselectRow,\n    expandButton,\n    ref,\n    inRange,\n  } = useTableContext()\n  const rowRef = useRef<HTMLInputElement>(null)\n\n  const hasExpandable = !!expandable\n  useEffect(() => {\n    if (hasExpandable) {\n      const unregisterCallback = registerExpandableRow(id, expanded)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n  useEffect(() => {\n    if (!selectDisabled) {\n      const unregisterCallback = registerSelectableRow(id)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, registerSelectableRow, selectDisabled])\n\n  const toggleRowExpand = useCallback(() => {\n    if (expandedRowIds[id]) {\n      collapseRow(id)\n    } else {\n      expandRow(id)\n    }\n  }, [collapseRow, expandRow, expandedRowIds, id])\n\n  const canClickRowToExpand = hasExpandable && !expandButton\n\n  useEffect(() => {\n    const refAtEffectStart = ref.current\n    const { current } = rowRef\n\n    if (refAtEffectStart && current && !refAtEffectStart.includes(current)) {\n      ref.current.push(current)\n    }\n  }, [ref])\n\n  const theme = useTheme()\n\n  const childrenLength =\n    Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0)\n\n  return (\n    <>\n      <StyledTr\n        className={className}\n        data-testid={dataTestid}\n        highlightAnimation={highlightAnimation}\n        role={canClickRowToExpand ? 'button row' : 'row'}\n      >\n        {selectable ? (\n          <NoPaddingCell maxWidth={theme.sizing[SELECTABLE_CHECKBOX_SIZE]}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <StyledCheckbox\n                  name=\"table-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={selectDisabled !== undefined}\n                  ref={rowRef}\n                  inRange={inRange.includes(id)}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </NoPaddingCell>\n        ) : null}\n        {expandButton ? (\n          <NoPaddingCell>\n            <Button\n              disabled={!expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"xsmall\"\n              sentiment=\"neutral\"\n              variant=\"ghost\"\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n            />\n          </NoPaddingCell>\n        ) : null}\n        {children}\n      </StyledTr>\n      {expandable && expandedRowIds[id] ? (\n        <ExpandableWrapper\n          data-expandable-content\n          onClick={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n          onKeyDown={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n        >\n          <Cell colSpan={childrenLength}>{expandable}</Cell>\n        </ExpandableWrapper>\n      ) : null}\n    </>\n  )\n}\n"]} */"));
|
|
49
|
+
}) => inRange ? `fill: ${theme.colors.neutral.backgroundHover};stroke: ${theme.colors.neutral.borderHover};` : "", ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx"],"names":[],"mappings":"AA+BwB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx","sourcesContent":["import type { Theme } from '@emotion/react'\nimport { keyframes, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { Children, useCallback, useEffect, useRef } from 'react'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useTableContext } from './TableContext'\nimport { SELECTABLE_CHECKBOX_SIZE } from './constants'\nimport type { ColumnProps } from './types'\n\nconst ExpandableWrapper = styled.tr`\n  width: 100%;\n  display: table-row;\n  vertical-align: middle;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  padding: ${({ theme }) => theme.space['1']};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\n  width: ${({ theme }) => theme.sizing[SELECTABLE_CHECKBOX_SIZE]};\n`\n\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n\n    rect {\n      ${({ theme, inRange }) => (inRange ? `fill: ${theme.colors.neutral.backgroundHover};stroke: ${theme.colors.neutral.borderHover};` : '')}\n    }\n`\n\n// We start at 5% and finish at 80% to leave the original background color\n// as we can't know if the table will be stripped or not\nconst colorChange = (theme: Theme) => keyframes`\n  5% {\n    background-color: ${theme.colors.primary.background};\n  }\n  80% {\n    background-color: ${theme.colors.primary.background};\n  }\n`\n\nconst StyledTr = styled('tr', {\n  shouldForwardProp: prop =>\n    !['highlightAnimation', 'columns', 'columnsStartAt'].includes(prop),\n})<{\n  highlightAnimation?: boolean\n  columns: ColumnProps[]\n  columnsStartAt?: number\n}>`\n  animation: ${({ highlightAnimation, theme }) =>\n    highlightAnimation ? colorChange(theme) : undefined}\n    3s linear;\n\n  ${({ columns, columnsStartAt }) =>\n    columns.map(\n      (column, index) => `\n    td:nth-of-type(${index + 1 + (columnsStartAt ?? 0)}) {\n      ${column.width ? `width: ${column.width};` : ''}\n      ${column.minWidth ? `min-width: ${column.minWidth};` : ''}\n      ${column.maxWidth ? `max-width: ${column.maxWidth};` : ''}\n    }\n  `,\n    )}\n`\n\nconst NoPaddingCell = styled(Cell, {\n  shouldForwardProp: prop => !['maxWidth'].includes(prop),\n})<{ maxWidth?: string }>`\n  padding: 0;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n\n  max-width: ${({ maxWidth }) => maxWidth};\n`\n\ntype RowProps = {\n  children: ReactNode\n  expandable?: ReactNode\n  className?: string\n  id: string\n  'data-testid'?: string\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  highlightAnimation?: boolean\n  expanded?: boolean\n}\n\nexport const Row = ({\n  children,\n  className,\n  id,\n  selectDisabled,\n  highlightAnimation,\n  expandable,\n  expanded,\n  'data-testid': dataTestid,\n}: RowProps) => {\n  const {\n    selectable,\n    registerExpandableRow,\n    expandedRowIds,\n    expandRow,\n    collapseRow,\n    registerSelectableRow,\n    selectedRowIds,\n    selectRow,\n    unselectRow,\n    expandButton,\n    ref,\n    inRange,\n    columns,\n  } = useTableContext()\n  const rowRef = useRef<HTMLInputElement>(null)\n\n  const hasExpandable = !!expandable\n  useEffect(() => {\n    if (hasExpandable) {\n      const unregisterCallback = registerExpandableRow(id, expanded)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n  useEffect(() => {\n    if (!selectDisabled) {\n      const unregisterCallback = registerSelectableRow(id)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, registerSelectableRow, selectDisabled])\n\n  const toggleRowExpand = useCallback(() => {\n    if (expandedRowIds[id]) {\n      collapseRow(id)\n    } else {\n      expandRow(id)\n    }\n  }, [collapseRow, expandRow, expandedRowIds, id])\n\n  const canClickRowToExpand = hasExpandable && !expandButton\n\n  useEffect(() => {\n    const refAtEffectStart = ref.current\n    const { current } = rowRef\n\n    if (refAtEffectStart && current && !refAtEffectStart.includes(current)) {\n      ref.current.push(current)\n    }\n  }, [ref])\n\n  const theme = useTheme()\n\n  const childrenLength =\n    Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0)\n\n  return (\n    <>\n      <StyledTr\n        className={className}\n        data-testid={dataTestid}\n        highlightAnimation={highlightAnimation}\n        role={canClickRowToExpand ? 'button row' : 'row'}\n        columns={columns}\n        columnsStartAt={(selectable ? 1 : 0) + (expandButton ? 1 : 0)}\n      >\n        {selectable ? (\n          <NoPaddingCell maxWidth={theme.sizing[SELECTABLE_CHECKBOX_SIZE]}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <StyledCheckbox\n                  name=\"table-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={selectDisabled !== undefined}\n                  ref={rowRef}\n                  inRange={inRange.includes(id)}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </NoPaddingCell>\n        ) : null}\n        {expandButton ? (\n          <NoPaddingCell>\n            <Button\n              disabled={!expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"xsmall\"\n              sentiment=\"neutral\"\n              variant=\"ghost\"\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n            />\n          </NoPaddingCell>\n        ) : null}\n        {children}\n      </StyledTr>\n      {expandable && expandedRowIds[id] ? (\n        <ExpandableWrapper\n          data-expandable-content\n          onClick={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n          onKeyDown={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n        >\n          <Cell colSpan={childrenLength}>{expandable}</Cell>\n        </ExpandableWrapper>\n      ) : null}\n    </>\n  )\n}\n"]} */"));
|
|
50
50
|
const colorChange = (theme) => react.keyframes`
|
|
51
51
|
5% {
|
|
52
52
|
background-color: ${theme.colors.primary.background};
|
|
@@ -56,16 +56,25 @@ const colorChange = (theme) => react.keyframes`
|
|
|
56
56
|
}
|
|
57
57
|
`;
|
|
58
58
|
const StyledTr = /* @__PURE__ */ _styled__default.default("tr", process.env.NODE_ENV === "production" ? {
|
|
59
|
-
shouldForwardProp: (prop) => !["highlightAnimation"].includes(prop),
|
|
59
|
+
shouldForwardProp: (prop) => !["highlightAnimation", "columns", "columnsStartAt"].includes(prop),
|
|
60
60
|
target: "e1qvrbgq1"
|
|
61
61
|
} : {
|
|
62
|
-
shouldForwardProp: (prop) => !["highlightAnimation"].includes(prop),
|
|
62
|
+
shouldForwardProp: (prop) => !["highlightAnimation", "columns", "columnsStartAt"].includes(prop),
|
|
63
63
|
target: "e1qvrbgq1",
|
|
64
64
|
label: "StyledTr"
|
|
65
65
|
})("animation:", ({
|
|
66
66
|
highlightAnimation,
|
|
67
67
|
theme
|
|
68
|
-
}) => highlightAnimation ? colorChange(theme) : void 0, " 3s linear;"
|
|
68
|
+
}) => highlightAnimation ? colorChange(theme) : void 0, " 3s linear;", ({
|
|
69
|
+
columns,
|
|
70
|
+
columnsStartAt
|
|
71
|
+
}) => columns.map((column, index2) => `
|
|
72
|
+
td:nth-of-type(${index2 + 1 + (columnsStartAt ?? 0)}) {
|
|
73
|
+
${column.width ? `width: ${column.width};` : ""}
|
|
74
|
+
${column.minWidth ? `min-width: ${column.minWidth};` : ""}
|
|
75
|
+
${column.maxWidth ? `max-width: ${column.maxWidth};` : ""}
|
|
76
|
+
}
|
|
77
|
+
`), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx"],"names":[],"mappings":"AAwDE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx","sourcesContent":["import type { Theme } from '@emotion/react'\nimport { keyframes, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { Children, useCallback, useEffect, useRef } from 'react'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useTableContext } from './TableContext'\nimport { SELECTABLE_CHECKBOX_SIZE } from './constants'\nimport type { ColumnProps } from './types'\n\nconst ExpandableWrapper = styled.tr`\n  width: 100%;\n  display: table-row;\n  vertical-align: middle;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  padding: ${({ theme }) => theme.space['1']};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\n  width: ${({ theme }) => theme.sizing[SELECTABLE_CHECKBOX_SIZE]};\n`\n\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n\n    rect {\n      ${({ theme, inRange }) => (inRange ? `fill: ${theme.colors.neutral.backgroundHover};stroke: ${theme.colors.neutral.borderHover};` : '')}\n    }\n`\n\n// We start at 5% and finish at 80% to leave the original background color\n// as we can't know if the table will be stripped or not\nconst colorChange = (theme: Theme) => keyframes`\n  5% {\n    background-color: ${theme.colors.primary.background};\n  }\n  80% {\n    background-color: ${theme.colors.primary.background};\n  }\n`\n\nconst StyledTr = styled('tr', {\n  shouldForwardProp: prop =>\n    !['highlightAnimation', 'columns', 'columnsStartAt'].includes(prop),\n})<{\n  highlightAnimation?: boolean\n  columns: ColumnProps[]\n  columnsStartAt?: number\n}>`\n  animation: ${({ highlightAnimation, theme }) =>\n    highlightAnimation ? colorChange(theme) : undefined}\n    3s linear;\n\n  ${({ columns, columnsStartAt }) =>\n    columns.map(\n      (column, index) => `\n    td:nth-of-type(${index + 1 + (columnsStartAt ?? 0)}) {\n      ${column.width ? `width: ${column.width};` : ''}\n      ${column.minWidth ? `min-width: ${column.minWidth};` : ''}\n      ${column.maxWidth ? `max-width: ${column.maxWidth};` : ''}\n    }\n  `,\n    )}\n`\n\nconst NoPaddingCell = styled(Cell, {\n  shouldForwardProp: prop => !['maxWidth'].includes(prop),\n})<{ maxWidth?: string }>`\n  padding: 0;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n\n  max-width: ${({ maxWidth }) => maxWidth};\n`\n\ntype RowProps = {\n  children: ReactNode\n  expandable?: ReactNode\n  className?: string\n  id: string\n  'data-testid'?: string\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  highlightAnimation?: boolean\n  expanded?: boolean\n}\n\nexport const Row = ({\n  children,\n  className,\n  id,\n  selectDisabled,\n  highlightAnimation,\n  expandable,\n  expanded,\n  'data-testid': dataTestid,\n}: RowProps) => {\n  const {\n    selectable,\n    registerExpandableRow,\n    expandedRowIds,\n    expandRow,\n    collapseRow,\n    registerSelectableRow,\n    selectedRowIds,\n    selectRow,\n    unselectRow,\n    expandButton,\n    ref,\n    inRange,\n    columns,\n  } = useTableContext()\n  const rowRef = useRef<HTMLInputElement>(null)\n\n  const hasExpandable = !!expandable\n  useEffect(() => {\n    if (hasExpandable) {\n      const unregisterCallback = registerExpandableRow(id, expanded)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n  useEffect(() => {\n    if (!selectDisabled) {\n      const unregisterCallback = registerSelectableRow(id)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, registerSelectableRow, selectDisabled])\n\n  const toggleRowExpand = useCallback(() => {\n    if (expandedRowIds[id]) {\n      collapseRow(id)\n    } else {\n      expandRow(id)\n    }\n  }, [collapseRow, expandRow, expandedRowIds, id])\n\n  const canClickRowToExpand = hasExpandable && !expandButton\n\n  useEffect(() => {\n    const refAtEffectStart = ref.current\n    const { current } = rowRef\n\n    if (refAtEffectStart && current && !refAtEffectStart.includes(current)) {\n      ref.current.push(current)\n    }\n  }, [ref])\n\n  const theme = useTheme()\n\n  const childrenLength =\n    Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0)\n\n  return (\n    <>\n      <StyledTr\n        className={className}\n        data-testid={dataTestid}\n        highlightAnimation={highlightAnimation}\n        role={canClickRowToExpand ? 'button row' : 'row'}\n        columns={columns}\n        columnsStartAt={(selectable ? 1 : 0) + (expandButton ? 1 : 0)}\n      >\n        {selectable ? (\n          <NoPaddingCell maxWidth={theme.sizing[SELECTABLE_CHECKBOX_SIZE]}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <StyledCheckbox\n                  name=\"table-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={selectDisabled !== undefined}\n                  ref={rowRef}\n                  inRange={inRange.includes(id)}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </NoPaddingCell>\n        ) : null}\n        {expandButton ? (\n          <NoPaddingCell>\n            <Button\n              disabled={!expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"xsmall\"\n              sentiment=\"neutral\"\n              variant=\"ghost\"\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n            />\n          </NoPaddingCell>\n        ) : null}\n        {children}\n      </StyledTr>\n      {expandable && expandedRowIds[id] ? (\n        <ExpandableWrapper\n          data-expandable-content\n          onClick={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n          onKeyDown={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n        >\n          <Cell colSpan={childrenLength}>{expandable}</Cell>\n        </ExpandableWrapper>\n      ) : null}\n    </>\n  )\n}\n"]} */"));
|
|
69
78
|
const NoPaddingCell = /* @__PURE__ */ _styled__default.default(Cell.Cell, process.env.NODE_ENV === "production" ? {
|
|
70
79
|
shouldForwardProp: (prop) => !["maxWidth"].includes(prop),
|
|
71
80
|
target: "e1qvrbgq0"
|
|
@@ -77,7 +86,7 @@ const NoPaddingCell = /* @__PURE__ */ _styled__default.default(Cell.Cell, proces
|
|
|
77
86
|
theme
|
|
78
87
|
}) => theme.space["2"], ";}max-width:", ({
|
|
79
88
|
maxWidth
|
|
80
|
-
}) => maxWidth, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx"],"names":[],"mappings":"AA0DyB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx","sourcesContent":["import type { Theme } from '@emotion/react'\nimport { keyframes, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { Children, useCallback, useEffect, useRef } from 'react'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useTableContext } from './TableContext'\nimport { SELECTABLE_CHECKBOX_SIZE } from './constants'\n\nconst ExpandableWrapper = styled.tr`\n  width: 100%;\n  display: table-row;\n  vertical-align: middle;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  padding: ${({ theme }) => theme.space['1']};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\n  width: ${({ theme }) => theme.sizing[SELECTABLE_CHECKBOX_SIZE]};\n`\n\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n\n    rect {\n      ${({ theme, inRange }) => (inRange ? `fill: ${theme.colors.neutral.backgroundHover};stroke: ${theme.colors.neutral.borderHover};` : '')}\n    }\n`\n\n// We start at 5% and finish at 80% to leave the original background color\n// as we can't know if the table will be stripped or not\nconst colorChange = (theme: Theme) => keyframes`\n  5% {\n    background-color: ${theme.colors.primary.background};\n  }\n  80% {\n    background-color: ${theme.colors.primary.background};\n  }\n`\n\nconst StyledTr = styled('tr', {\n  shouldForwardProp: prop => !['highlightAnimation'].includes(prop),\n})<{ highlightAnimation?: boolean }>`\n  animation: ${({ highlightAnimation, theme }) =>\n    highlightAnimation ? colorChange(theme) : undefined}\n    3s linear;\n`\n\nconst NoPaddingCell = styled(Cell, {\n  shouldForwardProp: prop => !['maxWidth'].includes(prop),\n})<{ maxWidth?: string }>`\n  padding: 0;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n\n  max-width: ${({ maxWidth }) => maxWidth};\n`\n\ntype RowProps = {\n  children: ReactNode\n  expandable?: ReactNode\n  className?: string\n  id: string\n  'data-testid'?: string\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  highlightAnimation?: boolean\n  expanded?: boolean\n}\n\nexport const Row = ({\n  children,\n  className,\n  id,\n  selectDisabled,\n  highlightAnimation,\n  expandable,\n  expanded,\n  'data-testid': dataTestid,\n}: RowProps) => {\n  const {\n    selectable,\n    registerExpandableRow,\n    expandedRowIds,\n    expandRow,\n    collapseRow,\n    registerSelectableRow,\n    selectedRowIds,\n    selectRow,\n    unselectRow,\n    expandButton,\n    ref,\n    inRange,\n  } = useTableContext()\n  const rowRef = useRef<HTMLInputElement>(null)\n\n  const hasExpandable = !!expandable\n  useEffect(() => {\n    if (hasExpandable) {\n      const unregisterCallback = registerExpandableRow(id, expanded)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n  useEffect(() => {\n    if (!selectDisabled) {\n      const unregisterCallback = registerSelectableRow(id)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, registerSelectableRow, selectDisabled])\n\n  const toggleRowExpand = useCallback(() => {\n    if (expandedRowIds[id]) {\n      collapseRow(id)\n    } else {\n      expandRow(id)\n    }\n  }, [collapseRow, expandRow, expandedRowIds, id])\n\n  const canClickRowToExpand = hasExpandable && !expandButton\n\n  useEffect(() => {\n    const refAtEffectStart = ref.current\n    const { current } = rowRef\n\n    if (refAtEffectStart && current && !refAtEffectStart.includes(current)) {\n      ref.current.push(current)\n    }\n  }, [ref])\n\n  const theme = useTheme()\n\n  const childrenLength =\n    Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0)\n\n  return (\n    <>\n      <StyledTr\n        className={className}\n        data-testid={dataTestid}\n        highlightAnimation={highlightAnimation}\n        role={canClickRowToExpand ? 'button row' : 'row'}\n      >\n        {selectable ? (\n          <NoPaddingCell maxWidth={theme.sizing[SELECTABLE_CHECKBOX_SIZE]}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <StyledCheckbox\n                  name=\"table-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={selectDisabled !== undefined}\n                  ref={rowRef}\n                  inRange={inRange.includes(id)}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </NoPaddingCell>\n        ) : null}\n        {expandButton ? (\n          <NoPaddingCell>\n            <Button\n              disabled={!expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"xsmall\"\n              sentiment=\"neutral\"\n              variant=\"ghost\"\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n            />\n          </NoPaddingCell>\n        ) : null}\n        {children}\n      </StyledTr>\n      {expandable && expandedRowIds[id] ? (\n        <ExpandableWrapper\n          data-expandable-content\n          onClick={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n          onKeyDown={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n        >\n          <Cell colSpan={childrenLength}>{expandable}</Cell>\n        </ExpandableWrapper>\n      ) : null}\n    </>\n  )\n}\n"]} */"));
|
|
89
|
+
}) => maxWidth, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx"],"names":[],"mappings":"AA2EyB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Table/Row.tsx","sourcesContent":["import type { Theme } from '@emotion/react'\nimport { keyframes, useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { Children, useCallback, useEffect, useRef } from 'react'\nimport { Button } from '../Button'\nimport { Checkbox } from '../Checkbox'\nimport { Tooltip } from '../Tooltip'\nimport { Cell } from './Cell'\nimport { useTableContext } from './TableContext'\nimport { SELECTABLE_CHECKBOX_SIZE } from './constants'\nimport type { ColumnProps } from './types'\n\nconst ExpandableWrapper = styled.tr`\n  width: 100%;\n  display: table-row;\n  vertical-align: middle;\n  border-top: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  padding: ${({ theme }) => theme.space['1']};\n  cursor: auto;\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: 0 0 ${({ theme }) => theme.radii.default} ${({ theme }) => theme.radii.default};\n`\n\nconst StyledCheckboxContainer = styled.div`\n  display: flex;\n  width: ${({ theme }) => theme.sizing[SELECTABLE_CHECKBOX_SIZE]};\n`\n\nconst StyledCheckbox = styled(Checkbox, {\n  shouldForwardProp: prop => !['inRange'].includes(prop),\n})<{ inRange: boolean }>`\n\n    rect {\n      ${({ theme, inRange }) => (inRange ? `fill: ${theme.colors.neutral.backgroundHover};stroke: ${theme.colors.neutral.borderHover};` : '')}\n    }\n`\n\n// We start at 5% and finish at 80% to leave the original background color\n// as we can't know if the table will be stripped or not\nconst colorChange = (theme: Theme) => keyframes`\n  5% {\n    background-color: ${theme.colors.primary.background};\n  }\n  80% {\n    background-color: ${theme.colors.primary.background};\n  }\n`\n\nconst StyledTr = styled('tr', {\n  shouldForwardProp: prop =>\n    !['highlightAnimation', 'columns', 'columnsStartAt'].includes(prop),\n})<{\n  highlightAnimation?: boolean\n  columns: ColumnProps[]\n  columnsStartAt?: number\n}>`\n  animation: ${({ highlightAnimation, theme }) =>\n    highlightAnimation ? colorChange(theme) : undefined}\n    3s linear;\n\n  ${({ columns, columnsStartAt }) =>\n    columns.map(\n      (column, index) => `\n    td:nth-of-type(${index + 1 + (columnsStartAt ?? 0)}) {\n      ${column.width ? `width: ${column.width};` : ''}\n      ${column.minWidth ? `min-width: ${column.minWidth};` : ''}\n      ${column.maxWidth ? `max-width: ${column.maxWidth};` : ''}\n    }\n  `,\n    )}\n`\n\nconst NoPaddingCell = styled(Cell, {\n  shouldForwardProp: prop => !['maxWidth'].includes(prop),\n})<{ maxWidth?: string }>`\n  padding: 0;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n\n  max-width: ${({ maxWidth }) => maxWidth};\n`\n\ntype RowProps = {\n  children: ReactNode\n  expandable?: ReactNode\n  className?: string\n  id: string\n  'data-testid'?: string\n  /**\n   * Row cannot be selected if this prop is provided. boolean true disabled selection, a string disable selection and a tooltip will be displayed on checkbox hover.\n   * */\n  selectDisabled?: boolean | string\n  highlightAnimation?: boolean\n  expanded?: boolean\n}\n\nexport const Row = ({\n  children,\n  className,\n  id,\n  selectDisabled,\n  highlightAnimation,\n  expandable,\n  expanded,\n  'data-testid': dataTestid,\n}: RowProps) => {\n  const {\n    selectable,\n    registerExpandableRow,\n    expandedRowIds,\n    expandRow,\n    collapseRow,\n    registerSelectableRow,\n    selectedRowIds,\n    selectRow,\n    unselectRow,\n    expandButton,\n    ref,\n    inRange,\n    columns,\n  } = useTableContext()\n  const rowRef = useRef<HTMLInputElement>(null)\n\n  const hasExpandable = !!expandable\n  useEffect(() => {\n    if (hasExpandable) {\n      const unregisterCallback = registerExpandableRow(id, expanded)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, hasExpandable, registerExpandableRow, expanded, expandRow])\n\n  useEffect(() => {\n    if (!selectDisabled) {\n      const unregisterCallback = registerSelectableRow(id)\n\n      return unregisterCallback\n    }\n\n    return undefined\n  }, [id, registerSelectableRow, selectDisabled])\n\n  const toggleRowExpand = useCallback(() => {\n    if (expandedRowIds[id]) {\n      collapseRow(id)\n    } else {\n      expandRow(id)\n    }\n  }, [collapseRow, expandRow, expandedRowIds, id])\n\n  const canClickRowToExpand = hasExpandable && !expandButton\n\n  useEffect(() => {\n    const refAtEffectStart = ref.current\n    const { current } = rowRef\n\n    if (refAtEffectStart && current && !refAtEffectStart.includes(current)) {\n      ref.current.push(current)\n    }\n  }, [ref])\n\n  const theme = useTheme()\n\n  const childrenLength =\n    Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0)\n\n  return (\n    <>\n      <StyledTr\n        className={className}\n        data-testid={dataTestid}\n        highlightAnimation={highlightAnimation}\n        role={canClickRowToExpand ? 'button row' : 'row'}\n        columns={columns}\n        columnsStartAt={(selectable ? 1 : 0) + (expandButton ? 1 : 0)}\n      >\n        {selectable ? (\n          <NoPaddingCell maxWidth={theme.sizing[SELECTABLE_CHECKBOX_SIZE]}>\n            <StyledCheckboxContainer>\n              <Tooltip\n                text={\n                  typeof selectDisabled === 'string'\n                    ? selectDisabled\n                    : undefined\n                }\n              >\n                <StyledCheckbox\n                  name=\"table-select-checkbox\"\n                  aria-label=\"select\"\n                  checked={selectedRowIds[id]}\n                  value={id}\n                  onChange={() => {\n                    if (selectedRowIds[id]) {\n                      unselectRow(id)\n                    } else {\n                      selectRow(id)\n                    }\n                  }}\n                  disabled={selectDisabled !== undefined}\n                  ref={rowRef}\n                  inRange={inRange.includes(id)}\n                />\n              </Tooltip>\n            </StyledCheckboxContainer>\n          </NoPaddingCell>\n        ) : null}\n        {expandButton ? (\n          <NoPaddingCell>\n            <Button\n              disabled={!expandable}\n              icon={expandedRowIds[id] ? 'arrow-up' : 'arrow-down'}\n              onClick={toggleRowExpand}\n              size=\"xsmall\"\n              sentiment=\"neutral\"\n              variant=\"ghost\"\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n            />\n          </NoPaddingCell>\n        ) : null}\n        {children}\n      </StyledTr>\n      {expandable && expandedRowIds[id] ? (\n        <ExpandableWrapper\n          data-expandable-content\n          onClick={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n          onKeyDown={\n            canClickRowToExpand\n              ? e => {\n                  e.stopPropagation()\n                }\n              : undefined\n          }\n        >\n          <Cell colSpan={childrenLength}>{expandable}</Cell>\n        </ExpandableWrapper>\n      ) : null}\n    </>\n  )\n}\n"]} */"));
|
|
81
90
|
const Row = ({
|
|
82
91
|
children,
|
|
83
92
|
className,
|
|
@@ -100,7 +109,8 @@ const Row = ({
|
|
|
100
109
|
unselectRow,
|
|
101
110
|
expandButton,
|
|
102
111
|
ref,
|
|
103
|
-
inRange
|
|
112
|
+
inRange,
|
|
113
|
+
columns
|
|
104
114
|
} = TableContext.useTableContext();
|
|
105
115
|
const rowRef = React.useRef(null);
|
|
106
116
|
const hasExpandable = !!expandable;
|
|
@@ -138,7 +148,7 @@ const Row = ({
|
|
|
138
148
|
const theme = react.useTheme();
|
|
139
149
|
const childrenLength = React.Children.count(children) + (selectable ? 1 : 0) + (expandButton ? 1 : 0);
|
|
140
150
|
return /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
|
|
141
|
-
/* @__PURE__ */ jsxRuntime.jsxs(StyledTr, { className, "data-testid": dataTestid, highlightAnimation, role: canClickRowToExpand ? "button row" : "row", children: [
|
|
151
|
+
/* @__PURE__ */ jsxRuntime.jsxs(StyledTr, { className, "data-testid": dataTestid, highlightAnimation, role: canClickRowToExpand ? "button row" : "row", columns, columnsStartAt: (selectable ? 1 : 0) + (expandButton ? 1 : 0), children: [
|
|
142
152
|
selectable ? /* @__PURE__ */ jsxRuntime.jsx(NoPaddingCell, { maxWidth: theme.sizing[constants.SELECTABLE_CHECKBOX_SIZE], children: /* @__PURE__ */ jsxRuntime.jsx(StyledCheckboxContainer, { children: /* @__PURE__ */ jsxRuntime.jsx(index$1.Tooltip, { text: typeof selectDisabled === "string" ? selectDisabled : void 0, children: /* @__PURE__ */ jsxRuntime.jsx(StyledCheckbox, { name: "table-select-checkbox", "aria-label": "select", checked: selectedRowIds[id], value: id, onChange: () => {
|
|
143
153
|
if (selectedRowIds[id]) {
|
|
144
154
|
unselectRow(id);
|