@ultraviolet/ui 3.0.0-beta.16 → 3.0.0-beta.17
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/ActionBar/styles.css.cjs +1 -0
- package/dist/components/ActionBar/styles.css.js +1 -0
- package/dist/components/Avatar/styles.css.cjs +1 -0
- package/dist/components/Avatar/styles.css.js +1 -0
- package/dist/components/Avatar/variables.css.cjs +0 -1
- package/dist/components/Avatar/variables.css.js +0 -1
- package/dist/components/Banner/styles.css.cjs +0 -1
- package/dist/components/Banner/styles.css.js +0 -1
- package/dist/components/NumberInput/constant.d.ts +5 -0
- package/dist/components/NumberInput/index.cjs +38 -155
- package/dist/components/NumberInput/index.d.ts +1 -5
- package/dist/components/NumberInput/index.js +37 -152
- package/dist/components/NumberInput/styles.css.cjs +14 -0
- package/dist/components/NumberInput/styles.css.d.ts +109 -0
- package/dist/components/NumberInput/styles.css.js +14 -0
- package/dist/components/Popup/styles.css.cjs +0 -1
- package/dist/components/Popup/styles.css.js +0 -1
- package/dist/components/Popup/variables.css.cjs +1 -0
- package/dist/components/Popup/variables.css.js +1 -0
- package/dist/components/SelectableCard/styles.css.cjs +0 -1
- package/dist/components/SelectableCard/styles.css.js +0 -1
- package/dist/components/SelectableCard/variables.css.cjs +1 -0
- package/dist/components/SelectableCard/variables.css.js +1 -0
- package/dist/components/Text/style.css.cjs +1 -0
- package/dist/components/Text/style.css.js +1 -0
- package/dist/components/Text/variables.css.cjs +0 -1
- package/dist/components/Text/variables.css.js +0 -1
- package/dist/components/TextArea/index.cjs +34 -99
- package/dist/components/TextArea/index.js +34 -97
- package/dist/components/TextArea/styles.css.cjs +12 -0
- package/dist/components/TextArea/styles.css.d.ts +15 -0
- package/dist/components/TextArea/styles.css.js +12 -0
- package/dist/ui.css +1 -1
- package/package.json +2 -2
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
"use client";
|
|
2
2
|
import { jsxs, jsx } from "@emotion/react/jsx-runtime";
|
|
3
|
-
import _styled from "@emotion/styled/base";
|
|
4
|
-
import { useTheme } from "@emotion/react";
|
|
5
3
|
import { CloseIcon, CheckCircleIcon, AlertCircleIcon } from "@ultraviolet/icons";
|
|
4
|
+
import { assignInlineVars } from "@vanilla-extract/dynamic";
|
|
6
5
|
import { forwardRef, useId, useRef, useImperativeHandle, useEffect, useMemo } from "react";
|
|
6
|
+
import { useTheme } from "../../theme/ThemeProvider.js";
|
|
7
7
|
import { Button } from "../Button/index.js";
|
|
8
8
|
import { SIZE_HEIGHT } from "../Button/constants.js";
|
|
9
9
|
import { Label } from "../Label/index.js";
|
|
@@ -11,82 +11,8 @@ import { Row } from "../Row/index.js";
|
|
|
11
11
|
import { Stack } from "../Stack/index.js";
|
|
12
12
|
import { Text } from "../Text/index.js";
|
|
13
13
|
import { Tooltip } from "../Tooltip/index.js";
|
|
14
|
-
|
|
15
|
-
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).";
|
|
16
|
-
}
|
|
14
|
+
import { textareaWrapper, textArea, paddingRightVar, textAreaClearableContainer } from "./styles.css.js";
|
|
17
15
|
const STATE_ICON_SIZE = "small";
|
|
18
|
-
const StyledTextAreaWrapper = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
|
|
19
|
-
target: "enu776d2"
|
|
20
|
-
} : {
|
|
21
|
-
target: "enu776d2",
|
|
22
|
-
label: "StyledTextAreaWrapper"
|
|
23
|
-
})(process.env.NODE_ENV === "production" ? {
|
|
24
|
-
name: "1kzcmo2",
|
|
25
|
-
styles: "position:relative;display:flex;width:100%"
|
|
26
|
-
} : {
|
|
27
|
-
name: "1kzcmo2",
|
|
28
|
-
styles: "position:relative;display:flex;width:100%/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/TextArea/index.tsx"],"names":[],"mappings":"AAwBwC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/TextArea/index.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { AlertCircleIcon, CheckCircleIcon, CloseIcon } from '@ultraviolet/icons'\nimport type { DOMAttributes, ReactNode } from 'react'\nimport {\n  forwardRef,\n  useEffect,\n  useId,\n  useImperativeHandle,\n  useMemo,\n  useRef,\n} from 'react'\nimport { Button } from '../Button'\nimport { SIZE_HEIGHT as ButtonSizeHeight } from '../Button/constants'\nimport { Label } from '../Label'\nimport { Row } from '../Row'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst STATE_ICON_SIZE = 'small'\n\nconst StyledTextAreaWrapper = styled.div`\n  position: relative;\n  display: flex;\n  width: 100%;\n`\n\nconst StyledTextAreaAbsoluteStack = styled(Stack)`\n  position: absolute;\n  top: ${({ theme }) => theme.space['1.5']};\n  right: ${({ theme }) => theme.space['1']};\n`\n\ntype StyledTextAreaProps = {\n  hasSentimentIcon: boolean\n  isClearable: boolean\n}\nconst StyledTextArea = styled('textarea', {\n  shouldForwardProp: prop =>\n    !['hasSentimentIcon', 'isClearable'].includes(prop),\n})<StyledTextAreaProps>`\n  width: 100%;\n  resize: vertical;\n  background: ${({ theme }) => theme.colors.neutral.background};\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  color: ${({ theme }) => theme.colors.neutral.text};\n  &::placeholder {\n    color: ${({ theme }) => theme.colors.neutral.textWeak};\n  }\n  border-radius: ${({ theme }) => theme.radii.default};\n  padding: ${({ theme }) =>\n    `${theme.space['1.5']} ${theme.space['1']} ${theme.space['1.5']} ${theme.space['2']}`};\n  padding-right: ${({ theme, isClearable, hasSentimentIcon }) =>\n    /* including 1 optional if both element is visible + 1 because content is absolute 1space unit from right */\n    `calc(${theme.space[isClearable && hasSentimentIcon ? '4' : '3']} + ${\n      isClearable ? `${ButtonSizeHeight.xsmall}px` : '0px'\n    } + ${hasSentimentIcon ? `${STATE_ICON_SIZE}px` : '0px'})`};\n\n  &[data-success='true'] {\n    border-color: ${({ theme }) => theme.colors.success.border};\n  }\n\n  &[data-error='true'] {\n    border-color: ${({ theme }) => theme.colors.danger.border};\n  }\n\n  &[data-readonly='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n  }\n\n  &:disabled {\n    background: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    &::placeholder {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n\n  &:not(:disabled) {\n    &:hover {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    &:focus {\n      outline: none;\n      border-color: ${({ theme }) => theme.colors.primary.border};\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n  }\n`\n\ntype LabelProps =\n  | {\n      label: string\n      'aria-label'?: never\n    }\n  | {\n      label?: never\n      'aria-label': string\n    }\n\ntype TextAreaProps = {\n  id?: string\n  className?: string\n  tabIndex?: number\n  autoFocus?: boolean\n  value?: string\n  onChange: (newValue: string) => void\n  placeholder?: string\n  /**\n   * Override others properties : readyOnly, success, error.\n   */\n  disabled?: boolean\n  /**\n   * Override others properties : success, error.\n   * Ignored if following props are provided : disabled.\n   */\n  readOnly?: boolean\n  /**\n   * Override others properties : error, helper.\n   * Ignored if following props are provided : disabled, readyOnly.\n   */\n  success?: string\n  /**\n   * Override others properties : helper.\n   * Ignored if following props are provided : disabled, readyOnly, success.\n   */\n  error?: string\n  /**\n   * Ignored if following props are provided : readyOnly, success.\n   */\n  helper?: ReactNode\n  /**\n   * Number of rows to display. If 'auto', the textarea will grow with the content and won't be resizable\n   */\n  rows?: number | 'auto'\n  /**\n   * Text area will grow with the content with a maximum number of rows.\n   */\n  maxRows?: number\n  minLength?: number\n  maxLength?: number\n  tooltip?: string\n  required?: boolean\n  'data-testid'?: string\n  name?: string\n  onFocus?: DOMAttributes<HTMLTextAreaElement>['onFocus']\n  onBlur?: DOMAttributes<HTMLTextAreaElement>['onBlur']\n  onKeyDown?: DOMAttributes<HTMLTextAreaElement>['onKeyDown']\n  clearable?: boolean\n  labelDescription?: ReactNode\n} & LabelProps\n\n/**\n * This component offers an extended textarea HTML\n */\nexport const TextArea = forwardRef<HTMLTextAreaElement, TextAreaProps>(\n  (\n    {\n      id,\n      className,\n      tabIndex,\n      value,\n      onChange,\n      placeholder,\n      rows = 3,\n      maxRows,\n      disabled = false,\n      readOnly = false,\n      success,\n      error,\n      helper,\n      minLength,\n      maxLength,\n      tooltip,\n      label,\n      autoFocus,\n      required = false,\n      'data-testid': dataTestId,\n      name,\n      onFocus,\n      onBlur,\n      onKeyDown,\n      clearable = false,\n      labelDescription,\n      'aria-label': ariaLabel,\n    },\n    ref,\n  ) => {\n    const localId = useId()\n    const theme = useTheme()\n    const textAreaRef = useRef<HTMLTextAreaElement>(null)\n    useImperativeHandle(ref, () => textAreaRef.current as HTMLTextAreaElement)\n\n    useEffect(() => {\n      const textArea = textAreaRef.current\n      const padding = theme.space['1.5']\n\n      if (textArea && rows === 'auto' && !maxRows) {\n        textArea.style.height = 'auto'\n        textArea.style.resize = 'none'\n        textArea.style.height = `${textArea.scrollHeight + 2}px`\n      } else if (textArea && maxRows) {\n        const lineHeight = Number.parseFloat(\n          getComputedStyle(textArea).lineHeight,\n        )\n\n        textArea.style.height = 'auto'\n        const maxHeight = maxRows * lineHeight\n\n        textArea.style.height = `${textArea.scrollHeight + 2}px`\n        textArea.style.maxHeight = `calc(${maxHeight}px + 2*${padding})`\n\n        if (typeof rows === 'number') {\n          const minHeight = rows * lineHeight\n          textArea.style.minHeight = `calc(${minHeight}px + 2*${padding})`\n        }\n      }\n    }, [value, rows, theme, maxRows, textAreaRef.current?.value])\n\n    const sentiment = useMemo(() => {\n      if (error) {\n        return 'danger'\n      }\n\n      if (success) {\n        return 'success'\n      }\n\n      return 'neutral'\n    }, [error, success])\n    const notice = success || error || helper\n\n    const computedClearable = clearable && !!value\n\n    return (\n      <Stack className={className} gap=\"0.5\">\n        {label || labelDescription ? (\n          <Label\n            htmlFor={id ?? localId}\n            labelDescription={labelDescription}\n            required={required}\n          >\n            {label}\n          </Label>\n        ) : null}\n        <Tooltip text={tooltip}>\n          <StyledTextAreaWrapper>\n            <StyledTextArea\n              aria-invalid={!!error}\n              aria-label={ariaLabel}\n              autoFocus={autoFocus}\n              data-error={!!error}\n              data-readonly={readOnly}\n              data-success={!!success}\n              data-testid={dataTestId}\n              disabled={disabled}\n              hasSentimentIcon={!!success || !!error}\n              id={id ?? localId}\n              isClearable={!!computedClearable}\n              maxLength={maxLength}\n              minLength={minLength}\n              name={name}\n              onBlur={onBlur}\n              onChange={event => {\n                onChange(event.currentTarget.value)\n              }}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              placeholder={placeholder}\n              ref={textAreaRef}\n              rows={rows !== 'auto' ? rows : 1}\n              tabIndex={tabIndex}\n              value={value}\n            />\n            <StyledTextAreaAbsoluteStack\n              alignItems=\"center\"\n              direction=\"row\"\n              gap=\"1\"\n            >\n              {computedClearable ? (\n                <Button\n                  aria-label=\"clear value\"\n                  onClick={() => {\n                    onChange('')\n                  }}\n                  sentiment=\"neutral\"\n                  size=\"xsmall\"\n                  variant=\"ghost\"\n                >\n                  <CloseIcon />\n                </Button>\n              ) : null}\n              {success ? (\n                <CheckCircleIcon sentiment=\"success\" size={STATE_ICON_SIZE} />\n              ) : null}\n              {error ? <AlertCircleIcon sentiment=\"danger\" /> : null}\n            </StyledTextAreaAbsoluteStack>\n          </StyledTextAreaWrapper>\n        </Tooltip>\n\n        {notice || maxLength ? (\n          <Row gap=\"1\" templateColumns=\"minmax(0, 1fr) min-content\">\n            <div>\n              {error || success || typeof helper === 'string' ? (\n                <Text\n                  as=\"p\"\n                  disabled={disabled}\n                  prominence={!error && !success ? 'weak' : 'default'}\n                  sentiment={sentiment}\n                  variant=\"caption\"\n                >\n                  {error || success || helper}\n                </Text>\n              ) : null}\n              {!error && !success && typeof helper !== 'string' && helper\n                ? helper\n                : null}\n            </div>\n            {maxLength ? (\n              <Text\n                as=\"div\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n                variant=\"caption\"\n              >\n                {value?.length ?? 0}/{maxLength}\n              </Text>\n            ) : null}\n          </Row>\n        ) : null}\n      </Stack>\n    )\n  },\n)\n"]} */",
|
|
29
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
30
|
-
});
|
|
31
|
-
const StyledTextAreaAbsoluteStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
|
|
32
|
-
target: "enu776d1"
|
|
33
|
-
} : {
|
|
34
|
-
target: "enu776d1",
|
|
35
|
-
label: "StyledTextAreaAbsoluteStack"
|
|
36
|
-
})("position:absolute;top:", ({
|
|
37
|
-
theme
|
|
38
|
-
}) => theme.space["1.5"], ";right:", ({
|
|
39
|
-
theme
|
|
40
|
-
}) => theme.space["1"], ";" + (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/TextArea/index.tsx"],"names":[],"mappings":"AA8BiD","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/TextArea/index.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { AlertCircleIcon, CheckCircleIcon, CloseIcon } from '@ultraviolet/icons'\nimport type { DOMAttributes, ReactNode } from 'react'\nimport {\n  forwardRef,\n  useEffect,\n  useId,\n  useImperativeHandle,\n  useMemo,\n  useRef,\n} from 'react'\nimport { Button } from '../Button'\nimport { SIZE_HEIGHT as ButtonSizeHeight } from '../Button/constants'\nimport { Label } from '../Label'\nimport { Row } from '../Row'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst STATE_ICON_SIZE = 'small'\n\nconst StyledTextAreaWrapper = styled.div`\n  position: relative;\n  display: flex;\n  width: 100%;\n`\n\nconst StyledTextAreaAbsoluteStack = styled(Stack)`\n  position: absolute;\n  top: ${({ theme }) => theme.space['1.5']};\n  right: ${({ theme }) => theme.space['1']};\n`\n\ntype StyledTextAreaProps = {\n  hasSentimentIcon: boolean\n  isClearable: boolean\n}\nconst StyledTextArea = styled('textarea', {\n  shouldForwardProp: prop =>\n    !['hasSentimentIcon', 'isClearable'].includes(prop),\n})<StyledTextAreaProps>`\n  width: 100%;\n  resize: vertical;\n  background: ${({ theme }) => theme.colors.neutral.background};\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  color: ${({ theme }) => theme.colors.neutral.text};\n  &::placeholder {\n    color: ${({ theme }) => theme.colors.neutral.textWeak};\n  }\n  border-radius: ${({ theme }) => theme.radii.default};\n  padding: ${({ theme }) =>\n    `${theme.space['1.5']} ${theme.space['1']} ${theme.space['1.5']} ${theme.space['2']}`};\n  padding-right: ${({ theme, isClearable, hasSentimentIcon }) =>\n    /* including 1 optional if both element is visible + 1 because content is absolute 1space unit from right */\n    `calc(${theme.space[isClearable && hasSentimentIcon ? '4' : '3']} + ${\n      isClearable ? `${ButtonSizeHeight.xsmall}px` : '0px'\n    } + ${hasSentimentIcon ? `${STATE_ICON_SIZE}px` : '0px'})`};\n\n  &[data-success='true'] {\n    border-color: ${({ theme }) => theme.colors.success.border};\n  }\n\n  &[data-error='true'] {\n    border-color: ${({ theme }) => theme.colors.danger.border};\n  }\n\n  &[data-readonly='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n  }\n\n  &:disabled {\n    background: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    &::placeholder {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n\n  &:not(:disabled) {\n    &:hover {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    &:focus {\n      outline: none;\n      border-color: ${({ theme }) => theme.colors.primary.border};\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n  }\n`\n\ntype LabelProps =\n  | {\n      label: string\n      'aria-label'?: never\n    }\n  | {\n      label?: never\n      'aria-label': string\n    }\n\ntype TextAreaProps = {\n  id?: string\n  className?: string\n  tabIndex?: number\n  autoFocus?: boolean\n  value?: string\n  onChange: (newValue: string) => void\n  placeholder?: string\n  /**\n   * Override others properties : readyOnly, success, error.\n   */\n  disabled?: boolean\n  /**\n   * Override others properties : success, error.\n   * Ignored if following props are provided : disabled.\n   */\n  readOnly?: boolean\n  /**\n   * Override others properties : error, helper.\n   * Ignored if following props are provided : disabled, readyOnly.\n   */\n  success?: string\n  /**\n   * Override others properties : helper.\n   * Ignored if following props are provided : disabled, readyOnly, success.\n   */\n  error?: string\n  /**\n   * Ignored if following props are provided : readyOnly, success.\n   */\n  helper?: ReactNode\n  /**\n   * Number of rows to display. If 'auto', the textarea will grow with the content and won't be resizable\n   */\n  rows?: number | 'auto'\n  /**\n   * Text area will grow with the content with a maximum number of rows.\n   */\n  maxRows?: number\n  minLength?: number\n  maxLength?: number\n  tooltip?: string\n  required?: boolean\n  'data-testid'?: string\n  name?: string\n  onFocus?: DOMAttributes<HTMLTextAreaElement>['onFocus']\n  onBlur?: DOMAttributes<HTMLTextAreaElement>['onBlur']\n  onKeyDown?: DOMAttributes<HTMLTextAreaElement>['onKeyDown']\n  clearable?: boolean\n  labelDescription?: ReactNode\n} & LabelProps\n\n/**\n * This component offers an extended textarea HTML\n */\nexport const TextArea = forwardRef<HTMLTextAreaElement, TextAreaProps>(\n  (\n    {\n      id,\n      className,\n      tabIndex,\n      value,\n      onChange,\n      placeholder,\n      rows = 3,\n      maxRows,\n      disabled = false,\n      readOnly = false,\n      success,\n      error,\n      helper,\n      minLength,\n      maxLength,\n      tooltip,\n      label,\n      autoFocus,\n      required = false,\n      'data-testid': dataTestId,\n      name,\n      onFocus,\n      onBlur,\n      onKeyDown,\n      clearable = false,\n      labelDescription,\n      'aria-label': ariaLabel,\n    },\n    ref,\n  ) => {\n    const localId = useId()\n    const theme = useTheme()\n    const textAreaRef = useRef<HTMLTextAreaElement>(null)\n    useImperativeHandle(ref, () => textAreaRef.current as HTMLTextAreaElement)\n\n    useEffect(() => {\n      const textArea = textAreaRef.current\n      const padding = theme.space['1.5']\n\n      if (textArea && rows === 'auto' && !maxRows) {\n        textArea.style.height = 'auto'\n        textArea.style.resize = 'none'\n        textArea.style.height = `${textArea.scrollHeight + 2}px`\n      } else if (textArea && maxRows) {\n        const lineHeight = Number.parseFloat(\n          getComputedStyle(textArea).lineHeight,\n        )\n\n        textArea.style.height = 'auto'\n        const maxHeight = maxRows * lineHeight\n\n        textArea.style.height = `${textArea.scrollHeight + 2}px`\n        textArea.style.maxHeight = `calc(${maxHeight}px + 2*${padding})`\n\n        if (typeof rows === 'number') {\n          const minHeight = rows * lineHeight\n          textArea.style.minHeight = `calc(${minHeight}px + 2*${padding})`\n        }\n      }\n    }, [value, rows, theme, maxRows, textAreaRef.current?.value])\n\n    const sentiment = useMemo(() => {\n      if (error) {\n        return 'danger'\n      }\n\n      if (success) {\n        return 'success'\n      }\n\n      return 'neutral'\n    }, [error, success])\n    const notice = success || error || helper\n\n    const computedClearable = clearable && !!value\n\n    return (\n      <Stack className={className} gap=\"0.5\">\n        {label || labelDescription ? (\n          <Label\n            htmlFor={id ?? localId}\n            labelDescription={labelDescription}\n            required={required}\n          >\n            {label}\n          </Label>\n        ) : null}\n        <Tooltip text={tooltip}>\n          <StyledTextAreaWrapper>\n            <StyledTextArea\n              aria-invalid={!!error}\n              aria-label={ariaLabel}\n              autoFocus={autoFocus}\n              data-error={!!error}\n              data-readonly={readOnly}\n              data-success={!!success}\n              data-testid={dataTestId}\n              disabled={disabled}\n              hasSentimentIcon={!!success || !!error}\n              id={id ?? localId}\n              isClearable={!!computedClearable}\n              maxLength={maxLength}\n              minLength={minLength}\n              name={name}\n              onBlur={onBlur}\n              onChange={event => {\n                onChange(event.currentTarget.value)\n              }}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              placeholder={placeholder}\n              ref={textAreaRef}\n              rows={rows !== 'auto' ? rows : 1}\n              tabIndex={tabIndex}\n              value={value}\n            />\n            <StyledTextAreaAbsoluteStack\n              alignItems=\"center\"\n              direction=\"row\"\n              gap=\"1\"\n            >\n              {computedClearable ? (\n                <Button\n                  aria-label=\"clear value\"\n                  onClick={() => {\n                    onChange('')\n                  }}\n                  sentiment=\"neutral\"\n                  size=\"xsmall\"\n                  variant=\"ghost\"\n                >\n                  <CloseIcon />\n                </Button>\n              ) : null}\n              {success ? (\n                <CheckCircleIcon sentiment=\"success\" size={STATE_ICON_SIZE} />\n              ) : null}\n              {error ? <AlertCircleIcon sentiment=\"danger\" /> : null}\n            </StyledTextAreaAbsoluteStack>\n          </StyledTextAreaWrapper>\n        </Tooltip>\n\n        {notice || maxLength ? (\n          <Row gap=\"1\" templateColumns=\"minmax(0, 1fr) min-content\">\n            <div>\n              {error || success || typeof helper === 'string' ? (\n                <Text\n                  as=\"p\"\n                  disabled={disabled}\n                  prominence={!error && !success ? 'weak' : 'default'}\n                  sentiment={sentiment}\n                  variant=\"caption\"\n                >\n                  {error || success || helper}\n                </Text>\n              ) : null}\n              {!error && !success && typeof helper !== 'string' && helper\n                ? helper\n                : null}\n            </div>\n            {maxLength ? (\n              <Text\n                as=\"div\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n                variant=\"caption\"\n              >\n                {value?.length ?? 0}/{maxLength}\n              </Text>\n            ) : null}\n          </Row>\n        ) : null}\n      </Stack>\n    )\n  },\n)\n"]} */"));
|
|
41
|
-
const StyledTextArea = /* @__PURE__ */ _styled("textarea", process.env.NODE_ENV === "production" ? {
|
|
42
|
-
shouldForwardProp: (prop) => !["hasSentimentIcon", "isClearable"].includes(prop),
|
|
43
|
-
target: "enu776d0"
|
|
44
|
-
} : {
|
|
45
|
-
shouldForwardProp: (prop) => !["hasSentimentIcon", "isClearable"].includes(prop),
|
|
46
|
-
target: "enu776d0",
|
|
47
|
-
label: "StyledTextArea"
|
|
48
|
-
})("width:100%;resize:vertical;background:", ({
|
|
49
|
-
theme
|
|
50
|
-
}) => theme.colors.neutral.background, ";border:1px solid ", ({
|
|
51
|
-
theme
|
|
52
|
-
}) => theme.colors.neutral.border, ";color:", ({
|
|
53
|
-
theme
|
|
54
|
-
}) => theme.colors.neutral.text, ";&::placeholder{color:", ({
|
|
55
|
-
theme
|
|
56
|
-
}) => theme.colors.neutral.textWeak, ";}border-radius:", ({
|
|
57
|
-
theme
|
|
58
|
-
}) => theme.radii.default, ";padding:", ({
|
|
59
|
-
theme
|
|
60
|
-
}) => `${theme.space["1.5"]} ${theme.space["1"]} ${theme.space["1.5"]} ${theme.space["2"]}`, ";padding-right:", ({
|
|
61
|
-
theme,
|
|
62
|
-
isClearable,
|
|
63
|
-
hasSentimentIcon
|
|
64
|
-
}) => (
|
|
65
|
-
/* including 1 optional if both element is visible + 1 because content is absolute 1space unit from right */
|
|
66
|
-
`calc(${theme.space[isClearable && hasSentimentIcon ? "4" : "3"]} + ${isClearable ? `${SIZE_HEIGHT.xsmall}px` : "0px"} + ${hasSentimentIcon ? `${STATE_ICON_SIZE}px` : "0px"})`
|
|
67
|
-
), ";&[data-success='true']{border-color:", ({
|
|
68
|
-
theme
|
|
69
|
-
}) => theme.colors.success.border, ";}&[data-error='true']{border-color:", ({
|
|
70
|
-
theme
|
|
71
|
-
}) => theme.colors.danger.border, ";}&[data-readonly='true']{background:", ({
|
|
72
|
-
theme
|
|
73
|
-
}) => theme.colors.neutral.backgroundWeak, ";border-color:", ({
|
|
74
|
-
theme
|
|
75
|
-
}) => theme.colors.neutral.border, ";}&:disabled{background:", ({
|
|
76
|
-
theme
|
|
77
|
-
}) => theme.colors.neutral.backgroundDisabled, ";border-color:", ({
|
|
78
|
-
theme
|
|
79
|
-
}) => theme.colors.neutral.borderDisabled, ";color:", ({
|
|
80
|
-
theme
|
|
81
|
-
}) => theme.colors.neutral.textDisabled, ";&::placeholder{color:", ({
|
|
82
|
-
theme
|
|
83
|
-
}) => theme.colors.neutral.textWeakDisabled, ";}}&:not(:disabled){&:hover{border-color:", ({
|
|
84
|
-
theme
|
|
85
|
-
}) => theme.colors.primary.border, ";}&:focus{outline:none;border-color:", ({
|
|
86
|
-
theme
|
|
87
|
-
}) => theme.colors.primary.border, ";box-shadow:", ({
|
|
88
|
-
theme
|
|
89
|
-
}) => theme.shadows.focusPrimary, ";}}" + (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/TextArea/index.tsx"],"names":[],"mappings":"AA2CuB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/TextArea/index.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { AlertCircleIcon, CheckCircleIcon, CloseIcon } from '@ultraviolet/icons'\nimport type { DOMAttributes, ReactNode } from 'react'\nimport {\n  forwardRef,\n  useEffect,\n  useId,\n  useImperativeHandle,\n  useMemo,\n  useRef,\n} from 'react'\nimport { Button } from '../Button'\nimport { SIZE_HEIGHT as ButtonSizeHeight } from '../Button/constants'\nimport { Label } from '../Label'\nimport { Row } from '../Row'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst STATE_ICON_SIZE = 'small'\n\nconst StyledTextAreaWrapper = styled.div`\n  position: relative;\n  display: flex;\n  width: 100%;\n`\n\nconst StyledTextAreaAbsoluteStack = styled(Stack)`\n  position: absolute;\n  top: ${({ theme }) => theme.space['1.5']};\n  right: ${({ theme }) => theme.space['1']};\n`\n\ntype StyledTextAreaProps = {\n  hasSentimentIcon: boolean\n  isClearable: boolean\n}\nconst StyledTextArea = styled('textarea', {\n  shouldForwardProp: prop =>\n    !['hasSentimentIcon', 'isClearable'].includes(prop),\n})<StyledTextAreaProps>`\n  width: 100%;\n  resize: vertical;\n  background: ${({ theme }) => theme.colors.neutral.background};\n  border: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  color: ${({ theme }) => theme.colors.neutral.text};\n  &::placeholder {\n    color: ${({ theme }) => theme.colors.neutral.textWeak};\n  }\n  border-radius: ${({ theme }) => theme.radii.default};\n  padding: ${({ theme }) =>\n    `${theme.space['1.5']} ${theme.space['1']} ${theme.space['1.5']} ${theme.space['2']}`};\n  padding-right: ${({ theme, isClearable, hasSentimentIcon }) =>\n    /* including 1 optional if both element is visible + 1 because content is absolute 1space unit from right */\n    `calc(${theme.space[isClearable && hasSentimentIcon ? '4' : '3']} + ${\n      isClearable ? `${ButtonSizeHeight.xsmall}px` : '0px'\n    } + ${hasSentimentIcon ? `${STATE_ICON_SIZE}px` : '0px'})`};\n\n  &[data-success='true'] {\n    border-color: ${({ theme }) => theme.colors.success.border};\n  }\n\n  &[data-error='true'] {\n    border-color: ${({ theme }) => theme.colors.danger.border};\n  }\n\n  &[data-readonly='true'] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n    border-color: ${({ theme }) => theme.colors.neutral.border};\n  }\n\n  &:disabled {\n    background: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n    border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    &::placeholder {\n      color: ${({ theme }) => theme.colors.neutral.textWeakDisabled};\n    }\n  }\n\n  &:not(:disabled) {\n    &:hover {\n      border-color: ${({ theme }) => theme.colors.primary.border};\n    }\n\n    &:focus {\n      outline: none;\n      border-color: ${({ theme }) => theme.colors.primary.border};\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n  }\n`\n\ntype LabelProps =\n  | {\n      label: string\n      'aria-label'?: never\n    }\n  | {\n      label?: never\n      'aria-label': string\n    }\n\ntype TextAreaProps = {\n  id?: string\n  className?: string\n  tabIndex?: number\n  autoFocus?: boolean\n  value?: string\n  onChange: (newValue: string) => void\n  placeholder?: string\n  /**\n   * Override others properties : readyOnly, success, error.\n   */\n  disabled?: boolean\n  /**\n   * Override others properties : success, error.\n   * Ignored if following props are provided : disabled.\n   */\n  readOnly?: boolean\n  /**\n   * Override others properties : error, helper.\n   * Ignored if following props are provided : disabled, readyOnly.\n   */\n  success?: string\n  /**\n   * Override others properties : helper.\n   * Ignored if following props are provided : disabled, readyOnly, success.\n   */\n  error?: string\n  /**\n   * Ignored if following props are provided : readyOnly, success.\n   */\n  helper?: ReactNode\n  /**\n   * Number of rows to display. If 'auto', the textarea will grow with the content and won't be resizable\n   */\n  rows?: number | 'auto'\n  /**\n   * Text area will grow with the content with a maximum number of rows.\n   */\n  maxRows?: number\n  minLength?: number\n  maxLength?: number\n  tooltip?: string\n  required?: boolean\n  'data-testid'?: string\n  name?: string\n  onFocus?: DOMAttributes<HTMLTextAreaElement>['onFocus']\n  onBlur?: DOMAttributes<HTMLTextAreaElement>['onBlur']\n  onKeyDown?: DOMAttributes<HTMLTextAreaElement>['onKeyDown']\n  clearable?: boolean\n  labelDescription?: ReactNode\n} & LabelProps\n\n/**\n * This component offers an extended textarea HTML\n */\nexport const TextArea = forwardRef<HTMLTextAreaElement, TextAreaProps>(\n  (\n    {\n      id,\n      className,\n      tabIndex,\n      value,\n      onChange,\n      placeholder,\n      rows = 3,\n      maxRows,\n      disabled = false,\n      readOnly = false,\n      success,\n      error,\n      helper,\n      minLength,\n      maxLength,\n      tooltip,\n      label,\n      autoFocus,\n      required = false,\n      'data-testid': dataTestId,\n      name,\n      onFocus,\n      onBlur,\n      onKeyDown,\n      clearable = false,\n      labelDescription,\n      'aria-label': ariaLabel,\n    },\n    ref,\n  ) => {\n    const localId = useId()\n    const theme = useTheme()\n    const textAreaRef = useRef<HTMLTextAreaElement>(null)\n    useImperativeHandle(ref, () => textAreaRef.current as HTMLTextAreaElement)\n\n    useEffect(() => {\n      const textArea = textAreaRef.current\n      const padding = theme.space['1.5']\n\n      if (textArea && rows === 'auto' && !maxRows) {\n        textArea.style.height = 'auto'\n        textArea.style.resize = 'none'\n        textArea.style.height = `${textArea.scrollHeight + 2}px`\n      } else if (textArea && maxRows) {\n        const lineHeight = Number.parseFloat(\n          getComputedStyle(textArea).lineHeight,\n        )\n\n        textArea.style.height = 'auto'\n        const maxHeight = maxRows * lineHeight\n\n        textArea.style.height = `${textArea.scrollHeight + 2}px`\n        textArea.style.maxHeight = `calc(${maxHeight}px + 2*${padding})`\n\n        if (typeof rows === 'number') {\n          const minHeight = rows * lineHeight\n          textArea.style.minHeight = `calc(${minHeight}px + 2*${padding})`\n        }\n      }\n    }, [value, rows, theme, maxRows, textAreaRef.current?.value])\n\n    const sentiment = useMemo(() => {\n      if (error) {\n        return 'danger'\n      }\n\n      if (success) {\n        return 'success'\n      }\n\n      return 'neutral'\n    }, [error, success])\n    const notice = success || error || helper\n\n    const computedClearable = clearable && !!value\n\n    return (\n      <Stack className={className} gap=\"0.5\">\n        {label || labelDescription ? (\n          <Label\n            htmlFor={id ?? localId}\n            labelDescription={labelDescription}\n            required={required}\n          >\n            {label}\n          </Label>\n        ) : null}\n        <Tooltip text={tooltip}>\n          <StyledTextAreaWrapper>\n            <StyledTextArea\n              aria-invalid={!!error}\n              aria-label={ariaLabel}\n              autoFocus={autoFocus}\n              data-error={!!error}\n              data-readonly={readOnly}\n              data-success={!!success}\n              data-testid={dataTestId}\n              disabled={disabled}\n              hasSentimentIcon={!!success || !!error}\n              id={id ?? localId}\n              isClearable={!!computedClearable}\n              maxLength={maxLength}\n              minLength={minLength}\n              name={name}\n              onBlur={onBlur}\n              onChange={event => {\n                onChange(event.currentTarget.value)\n              }}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              placeholder={placeholder}\n              ref={textAreaRef}\n              rows={rows !== 'auto' ? rows : 1}\n              tabIndex={tabIndex}\n              value={value}\n            />\n            <StyledTextAreaAbsoluteStack\n              alignItems=\"center\"\n              direction=\"row\"\n              gap=\"1\"\n            >\n              {computedClearable ? (\n                <Button\n                  aria-label=\"clear value\"\n                  onClick={() => {\n                    onChange('')\n                  }}\n                  sentiment=\"neutral\"\n                  size=\"xsmall\"\n                  variant=\"ghost\"\n                >\n                  <CloseIcon />\n                </Button>\n              ) : null}\n              {success ? (\n                <CheckCircleIcon sentiment=\"success\" size={STATE_ICON_SIZE} />\n              ) : null}\n              {error ? <AlertCircleIcon sentiment=\"danger\" /> : null}\n            </StyledTextAreaAbsoluteStack>\n          </StyledTextAreaWrapper>\n        </Tooltip>\n\n        {notice || maxLength ? (\n          <Row gap=\"1\" templateColumns=\"minmax(0, 1fr) min-content\">\n            <div>\n              {error || success || typeof helper === 'string' ? (\n                <Text\n                  as=\"p\"\n                  disabled={disabled}\n                  prominence={!error && !success ? 'weak' : 'default'}\n                  sentiment={sentiment}\n                  variant=\"caption\"\n                >\n                  {error || success || helper}\n                </Text>\n              ) : null}\n              {!error && !success && typeof helper !== 'string' && helper\n                ? helper\n                : null}\n            </div>\n            {maxLength ? (\n              <Text\n                as=\"div\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n                variant=\"caption\"\n              >\n                {value?.length ?? 0}/{maxLength}\n              </Text>\n            ) : null}\n          </Row>\n        ) : null}\n      </Stack>\n    )\n  },\n)\n"]} */"));
|
|
90
16
|
const TextArea = forwardRef(({
|
|
91
17
|
id,
|
|
92
18
|
className,
|
|
@@ -121,23 +47,29 @@ const TextArea = forwardRef(({
|
|
|
121
47
|
const textAreaRef = useRef(null);
|
|
122
48
|
useImperativeHandle(ref, () => textAreaRef.current);
|
|
123
49
|
useEffect(() => {
|
|
124
|
-
const
|
|
50
|
+
const textArea2 = textAreaRef.current;
|
|
125
51
|
const padding = theme.space["1.5"];
|
|
126
|
-
if (
|
|
127
|
-
|
|
128
|
-
textArea.style.resize = "none";
|
|
129
|
-
textArea.style.height = `${textArea.scrollHeight + 2}px`;
|
|
130
|
-
} else if (textArea && maxRows) {
|
|
131
|
-
const lineHeight = Number.parseFloat(getComputedStyle(textArea).lineHeight);
|
|
132
|
-
textArea.style.height = "auto";
|
|
133
|
-
const maxHeight = maxRows * lineHeight;
|
|
134
|
-
textArea.style.height = `${textArea.scrollHeight + 2}px`;
|
|
135
|
-
textArea.style.maxHeight = `calc(${maxHeight}px + 2*${padding})`;
|
|
136
|
-
if (typeof rows === "number") {
|
|
137
|
-
const minHeight = rows * lineHeight;
|
|
138
|
-
textArea.style.minHeight = `calc(${minHeight}px + 2*${padding})`;
|
|
139
|
-
}
|
|
52
|
+
if (!textArea2) {
|
|
53
|
+
return;
|
|
140
54
|
}
|
|
55
|
+
const updateHeight = () => {
|
|
56
|
+
if (textArea2 && rows === "auto" && !maxRows) {
|
|
57
|
+
textArea2.style.height = "auto";
|
|
58
|
+
textArea2.style.resize = "none";
|
|
59
|
+
textArea2.style.height = `${textArea2.scrollHeight + 2}px`;
|
|
60
|
+
} else if (textArea2 && maxRows) {
|
|
61
|
+
const lineHeight = Number.parseFloat(getComputedStyle(textArea2).lineHeight);
|
|
62
|
+
textArea2.style.height = "auto";
|
|
63
|
+
const maxHeight = maxRows * lineHeight;
|
|
64
|
+
textArea2.style.height = `${textArea2.scrollHeight + 2}px`;
|
|
65
|
+
textArea2.style.maxHeight = `calc(${maxHeight}px + 2*${padding})`;
|
|
66
|
+
if (typeof rows === "number") {
|
|
67
|
+
const minHeight = rows * lineHeight;
|
|
68
|
+
textArea2.style.minHeight = `calc(${minHeight}px + 2*${padding})`;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
};
|
|
72
|
+
requestAnimationFrame(updateHeight);
|
|
141
73
|
}, [value, rows, theme, maxRows, textAreaRef.current?.value]);
|
|
142
74
|
const sentiment = useMemo(() => {
|
|
143
75
|
if (error) {
|
|
@@ -152,15 +84,20 @@ const TextArea = forwardRef(({
|
|
|
152
84
|
const computedClearable = clearable && !!value;
|
|
153
85
|
return /* @__PURE__ */ jsxs(Stack, { className, gap: "0.5", children: [
|
|
154
86
|
label || labelDescription ? /* @__PURE__ */ jsx(Label, { htmlFor: id ?? localId, labelDescription, required, children: label }) : null,
|
|
155
|
-
/* @__PURE__ */ jsx(Tooltip, { text: tooltip, children: /* @__PURE__ */ jsxs(
|
|
156
|
-
/* @__PURE__ */ jsx(
|
|
87
|
+
/* @__PURE__ */ jsx(Tooltip, { text: tooltip, children: /* @__PURE__ */ jsxs("div", { className: textareaWrapper, children: [
|
|
88
|
+
/* @__PURE__ */ jsx("textarea", { "aria-invalid": !!error, "aria-label": ariaLabel, autoFocus, className: textArea({
|
|
89
|
+
error: !!error,
|
|
90
|
+
success: !!success
|
|
91
|
+
}), "data-testid": dataTestId, disabled, id: id ?? localId, maxLength, minLength, name, onBlur, onChange: (event) => {
|
|
157
92
|
onChange(event.currentTarget.value);
|
|
158
|
-
}, onFocus, onKeyDown, placeholder, ref: textAreaRef, rows: rows !== "auto" ? rows : 1,
|
|
159
|
-
|
|
93
|
+
}, onFocus, onKeyDown, placeholder, readOnly: !!readOnly, ref: textAreaRef, rows: rows !== "auto" ? rows : 1, style: assignInlineVars({
|
|
94
|
+
[paddingRightVar]: `calc(${theme.space[computedClearable && (!!success || !!error) ? "4" : "3"]} + ${computedClearable ? `${SIZE_HEIGHT.xsmall}px` : "0px"} + ${!!success || !!error ? `${STATE_ICON_SIZE}px` : "0px"})`
|
|
95
|
+
}), tabIndex, value }),
|
|
96
|
+
/* @__PURE__ */ jsxs(Stack, { alignItems: "center", className: textAreaClearableContainer, direction: "row", gap: "1", children: [
|
|
160
97
|
computedClearable ? /* @__PURE__ */ jsx(Button, { "aria-label": "clear value", onClick: () => {
|
|
161
98
|
onChange("");
|
|
162
99
|
}, sentiment: "neutral", size: "xsmall", variant: "ghost", children: /* @__PURE__ */ jsx(CloseIcon, {}) }) : null,
|
|
163
|
-
success ? /* @__PURE__ */ jsx(CheckCircleIcon, { sentiment: "success", size: STATE_ICON_SIZE }) : null,
|
|
100
|
+
success && !error ? /* @__PURE__ */ jsx(CheckCircleIcon, { sentiment: "success", size: STATE_ICON_SIZE }) : null,
|
|
164
101
|
error ? /* @__PURE__ */ jsx(AlertCircleIcon, { sentiment: "danger" }) : null
|
|
165
102
|
] })
|
|
166
103
|
] }) }),
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
+
;/* empty css */
|
|
4
|
+
const createRuntimeFn = require("@vanilla-extract/recipes/createRuntimeFn");
|
|
5
|
+
var paddingRightVar = "var(--uv_hlf4vn0)";
|
|
6
|
+
var textareaWrapper = "uv_hlf4vn1";
|
|
7
|
+
var textAreaClearableContainer = "uv_hlf4vn2";
|
|
8
|
+
var textArea = createRuntimeFn.createRuntimeFn({ defaultClassName: "uv_hlf4vn3", variantClassNames: { success: { true: "uv_hlf4vn4" }, error: { true: "uv_hlf4vn5" } }, defaultVariants: { success: false, error: false }, compoundVariants: [] });
|
|
9
|
+
exports.paddingRightVar = paddingRightVar;
|
|
10
|
+
exports.textArea = textArea;
|
|
11
|
+
exports.textAreaClearableContainer = textAreaClearableContainer;
|
|
12
|
+
exports.textareaWrapper = textareaWrapper;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export declare const paddingRightVar: `var(--${string})`;
|
|
2
|
+
export declare const textareaWrapper: string;
|
|
3
|
+
export declare const textAreaClearableContainer: string;
|
|
4
|
+
export declare const textArea: import("@vanilla-extract/recipes").RuntimeFn<{
|
|
5
|
+
success: {
|
|
6
|
+
true: {
|
|
7
|
+
borderColor: `var(--${string})`;
|
|
8
|
+
};
|
|
9
|
+
};
|
|
10
|
+
error: {
|
|
11
|
+
true: {
|
|
12
|
+
borderColor: `var(--${string})`;
|
|
13
|
+
};
|
|
14
|
+
};
|
|
15
|
+
}>;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/* empty css */
|
|
2
|
+
import { createRuntimeFn } from "@vanilla-extract/recipes/createRuntimeFn";
|
|
3
|
+
var paddingRightVar = "var(--uv_hlf4vn0)";
|
|
4
|
+
var textareaWrapper = "uv_hlf4vn1";
|
|
5
|
+
var textAreaClearableContainer = "uv_hlf4vn2";
|
|
6
|
+
var textArea = createRuntimeFn({ defaultClassName: "uv_hlf4vn3", variantClassNames: { success: { true: "uv_hlf4vn4" }, error: { true: "uv_hlf4vn5" } }, defaultVariants: { success: false, error: false }, compoundVariants: [] });
|
|
7
|
+
export {
|
|
8
|
+
paddingRightVar,
|
|
9
|
+
textArea,
|
|
10
|
+
textAreaClearableContainer,
|
|
11
|
+
textareaWrapper
|
|
12
|
+
};
|