@salutejs/plasma-new-hope 0.317.0-canary.1880.14214278787.0 → 0.317.0-canary.1885.14214031918.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.
Files changed (157) hide show
  1. package/cjs/components/Checkbox/Checkbox.js +2 -2
  2. package/cjs/components/Checkbox/Checkbox.js.map +1 -1
  3. package/cjs/engines/linaria.js +4 -2
  4. package/cjs/engines/linaria.js.map +1 -1
  5. package/emotion/cjs/components/Checkbox/Checkbox.js +2 -2
  6. package/emotion/cjs/components/Checkbox/Checkbox.template-doc.mdx +0 -13
  7. package/emotion/cjs/components/Typography/Typography.template-doc.mdx +16 -0
  8. package/emotion/cjs/examples/typography/components/Body/Body.stories.tsx +4 -1
  9. package/emotion/cjs/examples/typography/components/Dspl/Dspl.stories.tsx +4 -1
  10. package/emotion/cjs/examples/typography/components/Heading/Heading.stories.tsx +4 -1
  11. package/emotion/cjs/examples/typography/components/Text/Text.stories.tsx +4 -1
  12. package/emotion/es/components/Checkbox/Checkbox.js +2 -2
  13. package/emotion/es/components/Checkbox/Checkbox.template-doc.mdx +0 -13
  14. package/emotion/es/components/Typography/Typography.template-doc.mdx +16 -0
  15. package/emotion/es/examples/typography/components/Body/Body.stories.tsx +4 -1
  16. package/emotion/es/examples/typography/components/Dspl/Dspl.stories.tsx +4 -1
  17. package/emotion/es/examples/typography/components/Heading/Heading.stories.tsx +4 -1
  18. package/emotion/es/examples/typography/components/Text/Text.stories.tsx +4 -1
  19. package/es/components/Checkbox/Checkbox.js +2 -2
  20. package/es/components/Checkbox/Checkbox.js.map +1 -1
  21. package/es/engines/linaria.js +4 -2
  22. package/es/engines/linaria.js.map +1 -1
  23. package/package.json +2 -2
  24. package/styled-components/cjs/components/Checkbox/Checkbox.js +2 -2
  25. package/styled-components/cjs/components/Checkbox/Checkbox.template-doc.mdx +0 -13
  26. package/styled-components/cjs/components/Typography/Typography.template-doc.mdx +16 -0
  27. package/styled-components/cjs/examples/typography/components/Body/Body.stories.tsx +4 -1
  28. package/styled-components/cjs/examples/typography/components/Dspl/Dspl.stories.tsx +4 -1
  29. package/styled-components/cjs/examples/typography/components/Heading/Heading.stories.tsx +4 -1
  30. package/styled-components/cjs/examples/typography/components/Text/Text.stories.tsx +4 -1
  31. package/styled-components/es/components/Checkbox/Checkbox.js +2 -2
  32. package/styled-components/es/components/Checkbox/Checkbox.template-doc.mdx +0 -13
  33. package/styled-components/es/components/Typography/Typography.template-doc.mdx +16 -0
  34. package/styled-components/es/examples/typography/components/Body/Body.stories.tsx +4 -1
  35. package/styled-components/es/examples/typography/components/Dspl/Dspl.stories.tsx +4 -1
  36. package/styled-components/es/examples/typography/components/Heading/Heading.stories.tsx +4 -1
  37. package/styled-components/es/examples/typography/components/Text/Text.stories.tsx +4 -1
  38. package/types/components/Typography/Body/Body.d.ts +2 -2
  39. package/types/components/Typography/Body/Body.d.ts.map +1 -1
  40. package/types/components/Typography/Dspl/Dspl.d.ts +2 -2
  41. package/types/components/Typography/Dspl/Dspl.d.ts.map +1 -1
  42. package/types/components/Typography/Heading/Heading.d.ts +2 -2
  43. package/types/components/Typography/Heading/Heading.d.ts.map +1 -1
  44. package/types/components/Typography/Text/Text.d.ts +2 -2
  45. package/types/components/Typography/Text/Text.d.ts.map +1 -1
  46. package/types/components/Typography/Typography.d.ts +1 -1
  47. package/types/components/Typography/Typography.d.ts.map +1 -1
  48. package/types/components/Typography/Typography.types.d.ts +2 -1
  49. package/types/components/Typography/Typography.types.d.ts.map +1 -1
  50. package/emotion/cjs/examples/typography/components/Old/Body/Body.config.js +0 -20
  51. package/emotion/cjs/examples/typography/components/Old/Body/Body.js +0 -11
  52. package/emotion/cjs/examples/typography/components/Old/Body/Body.stories.tsx +0 -40
  53. package/emotion/cjs/examples/typography/components/Old/Button/Button.config.js +0 -19
  54. package/emotion/cjs/examples/typography/components/Old/Button/Button.js +0 -11
  55. package/emotion/cjs/examples/typography/components/Old/Button/Button.stories.tsx +0 -40
  56. package/emotion/cjs/examples/typography/components/Old/Caption/Caption.config.js +0 -18
  57. package/emotion/cjs/examples/typography/components/Old/Caption/Caption.js +0 -11
  58. package/emotion/cjs/examples/typography/components/Old/Caption/Caption.stories.tsx +0 -40
  59. package/emotion/cjs/examples/typography/components/Old/Display/Display.config.js +0 -20
  60. package/emotion/cjs/examples/typography/components/Old/Display/Display.js +0 -11
  61. package/emotion/cjs/examples/typography/components/Old/Display/Display.stories.tsx +0 -40
  62. package/emotion/cjs/examples/typography/components/Old/Footnote/Footnote.config.js +0 -19
  63. package/emotion/cjs/examples/typography/components/Old/Footnote/Footnote.js +0 -11
  64. package/emotion/cjs/examples/typography/components/Old/Footnote/Footnote.stories.tsx +0 -40
  65. package/emotion/cjs/examples/typography/components/Old/Headline/Headline.config.js +0 -21
  66. package/emotion/cjs/examples/typography/components/Old/Headline/Headline.js +0 -11
  67. package/emotion/cjs/examples/typography/components/Old/Headline/Headline.stories.tsx +0 -40
  68. package/emotion/cjs/examples/typography/components/Old/Paragraph/Paragraph.config.js +0 -19
  69. package/emotion/cjs/examples/typography/components/Old/Paragraph/Paragraph.js +0 -11
  70. package/emotion/cjs/examples/typography/components/Old/Paragraph/Paragraph.stories.tsx +0 -42
  71. package/emotion/cjs/examples/typography/components/Old/Subtitle/Subtitle.config.js +0 -18
  72. package/emotion/cjs/examples/typography/components/Old/Subtitle/Subtitle.js +0 -11
  73. package/emotion/cjs/examples/typography/components/Old/Subtitle/Subtitle.stories.tsx +0 -39
  74. package/emotion/cjs/examples/typography/components/Old/Underline/Underline.config.js +0 -18
  75. package/emotion/cjs/examples/typography/components/Old/Underline/Underline.js +0 -11
  76. package/emotion/cjs/examples/typography/components/Old/Underline/Underline.stories.tsx +0 -40
  77. package/emotion/es/examples/typography/components/Old/Body/Body.config.js +0 -14
  78. package/emotion/es/examples/typography/components/Old/Body/Body.js +0 -5
  79. package/emotion/es/examples/typography/components/Old/Body/Body.stories.tsx +0 -40
  80. package/emotion/es/examples/typography/components/Old/Button/Button.config.js +0 -13
  81. package/emotion/es/examples/typography/components/Old/Button/Button.js +0 -5
  82. package/emotion/es/examples/typography/components/Old/Button/Button.stories.tsx +0 -40
  83. package/emotion/es/examples/typography/components/Old/Caption/Caption.config.js +0 -12
  84. package/emotion/es/examples/typography/components/Old/Caption/Caption.js +0 -5
  85. package/emotion/es/examples/typography/components/Old/Caption/Caption.stories.tsx +0 -40
  86. package/emotion/es/examples/typography/components/Old/Display/Display.config.js +0 -14
  87. package/emotion/es/examples/typography/components/Old/Display/Display.js +0 -5
  88. package/emotion/es/examples/typography/components/Old/Display/Display.stories.tsx +0 -40
  89. package/emotion/es/examples/typography/components/Old/Footnote/Footnote.config.js +0 -13
  90. package/emotion/es/examples/typography/components/Old/Footnote/Footnote.js +0 -5
  91. package/emotion/es/examples/typography/components/Old/Footnote/Footnote.stories.tsx +0 -40
  92. package/emotion/es/examples/typography/components/Old/Headline/Headline.config.js +0 -15
  93. package/emotion/es/examples/typography/components/Old/Headline/Headline.js +0 -5
  94. package/emotion/es/examples/typography/components/Old/Headline/Headline.stories.tsx +0 -40
  95. package/emotion/es/examples/typography/components/Old/Paragraph/Paragraph.config.js +0 -13
  96. package/emotion/es/examples/typography/components/Old/Paragraph/Paragraph.js +0 -5
  97. package/emotion/es/examples/typography/components/Old/Paragraph/Paragraph.stories.tsx +0 -42
  98. package/emotion/es/examples/typography/components/Old/Subtitle/Subtitle.config.js +0 -12
  99. package/emotion/es/examples/typography/components/Old/Subtitle/Subtitle.js +0 -5
  100. package/emotion/es/examples/typography/components/Old/Subtitle/Subtitle.stories.tsx +0 -39
  101. package/emotion/es/examples/typography/components/Old/Underline/Underline.config.js +0 -12
  102. package/emotion/es/examples/typography/components/Old/Underline/Underline.js +0 -5
  103. package/emotion/es/examples/typography/components/Old/Underline/Underline.stories.tsx +0 -40
  104. package/styled-components/cjs/examples/typography/components/Old/Body/Body.config.js +0 -20
  105. package/styled-components/cjs/examples/typography/components/Old/Body/Body.js +0 -11
  106. package/styled-components/cjs/examples/typography/components/Old/Body/Body.stories.tsx +0 -40
  107. package/styled-components/cjs/examples/typography/components/Old/Button/Button.config.js +0 -19
  108. package/styled-components/cjs/examples/typography/components/Old/Button/Button.js +0 -11
  109. package/styled-components/cjs/examples/typography/components/Old/Button/Button.stories.tsx +0 -40
  110. package/styled-components/cjs/examples/typography/components/Old/Caption/Caption.config.js +0 -18
  111. package/styled-components/cjs/examples/typography/components/Old/Caption/Caption.js +0 -11
  112. package/styled-components/cjs/examples/typography/components/Old/Caption/Caption.stories.tsx +0 -40
  113. package/styled-components/cjs/examples/typography/components/Old/Display/Display.config.js +0 -20
  114. package/styled-components/cjs/examples/typography/components/Old/Display/Display.js +0 -11
  115. package/styled-components/cjs/examples/typography/components/Old/Display/Display.stories.tsx +0 -40
  116. package/styled-components/cjs/examples/typography/components/Old/Footnote/Footnote.config.js +0 -19
  117. package/styled-components/cjs/examples/typography/components/Old/Footnote/Footnote.js +0 -11
  118. package/styled-components/cjs/examples/typography/components/Old/Footnote/Footnote.stories.tsx +0 -40
  119. package/styled-components/cjs/examples/typography/components/Old/Headline/Headline.config.js +0 -21
  120. package/styled-components/cjs/examples/typography/components/Old/Headline/Headline.js +0 -11
  121. package/styled-components/cjs/examples/typography/components/Old/Headline/Headline.stories.tsx +0 -40
  122. package/styled-components/cjs/examples/typography/components/Old/Paragraph/Paragraph.config.js +0 -19
  123. package/styled-components/cjs/examples/typography/components/Old/Paragraph/Paragraph.js +0 -11
  124. package/styled-components/cjs/examples/typography/components/Old/Paragraph/Paragraph.stories.tsx +0 -42
  125. package/styled-components/cjs/examples/typography/components/Old/Subtitle/Subtitle.config.js +0 -18
  126. package/styled-components/cjs/examples/typography/components/Old/Subtitle/Subtitle.js +0 -11
  127. package/styled-components/cjs/examples/typography/components/Old/Subtitle/Subtitle.stories.tsx +0 -39
  128. package/styled-components/cjs/examples/typography/components/Old/Underline/Underline.config.js +0 -18
  129. package/styled-components/cjs/examples/typography/components/Old/Underline/Underline.js +0 -11
  130. package/styled-components/cjs/examples/typography/components/Old/Underline/Underline.stories.tsx +0 -40
  131. package/styled-components/es/examples/typography/components/Old/Body/Body.config.js +0 -14
  132. package/styled-components/es/examples/typography/components/Old/Body/Body.js +0 -5
  133. package/styled-components/es/examples/typography/components/Old/Body/Body.stories.tsx +0 -40
  134. package/styled-components/es/examples/typography/components/Old/Button/Button.config.js +0 -13
  135. package/styled-components/es/examples/typography/components/Old/Button/Button.js +0 -5
  136. package/styled-components/es/examples/typography/components/Old/Button/Button.stories.tsx +0 -40
  137. package/styled-components/es/examples/typography/components/Old/Caption/Caption.config.js +0 -12
  138. package/styled-components/es/examples/typography/components/Old/Caption/Caption.js +0 -5
  139. package/styled-components/es/examples/typography/components/Old/Caption/Caption.stories.tsx +0 -40
  140. package/styled-components/es/examples/typography/components/Old/Display/Display.config.js +0 -14
  141. package/styled-components/es/examples/typography/components/Old/Display/Display.js +0 -5
  142. package/styled-components/es/examples/typography/components/Old/Display/Display.stories.tsx +0 -40
  143. package/styled-components/es/examples/typography/components/Old/Footnote/Footnote.config.js +0 -13
  144. package/styled-components/es/examples/typography/components/Old/Footnote/Footnote.js +0 -5
  145. package/styled-components/es/examples/typography/components/Old/Footnote/Footnote.stories.tsx +0 -40
  146. package/styled-components/es/examples/typography/components/Old/Headline/Headline.config.js +0 -15
  147. package/styled-components/es/examples/typography/components/Old/Headline/Headline.js +0 -5
  148. package/styled-components/es/examples/typography/components/Old/Headline/Headline.stories.tsx +0 -40
  149. package/styled-components/es/examples/typography/components/Old/Paragraph/Paragraph.config.js +0 -13
  150. package/styled-components/es/examples/typography/components/Old/Paragraph/Paragraph.js +0 -5
  151. package/styled-components/es/examples/typography/components/Old/Paragraph/Paragraph.stories.tsx +0 -42
  152. package/styled-components/es/examples/typography/components/Old/Subtitle/Subtitle.config.js +0 -12
  153. package/styled-components/es/examples/typography/components/Old/Subtitle/Subtitle.js +0 -5
  154. package/styled-components/es/examples/typography/components/Old/Subtitle/Subtitle.stories.tsx +0 -39
  155. package/styled-components/es/examples/typography/components/Old/Underline/Underline.config.js +0 -12
  156. package/styled-components/es/examples/typography/components/Old/Underline/Underline.js +0 -5
  157. package/styled-components/es/examples/typography/components/Old/Underline/Underline.stories.tsx +0 -40
@@ -39,8 +39,8 @@ var checkboxRoot = function checkboxRoot(Root) {
39
39
  var inputRef = React.useRef(null);
40
40
  var forkRef = plasmaCore.useForkRef(inputRef, ref);
41
41
  React.useEffect(function () {
42
- if (inputRef.current) {
43
- inputRef.current.indeterminate = Boolean(indeterminate);
42
+ if (inputRef.current && indeterminate) {
43
+ inputRef.current.indeterminate = rest.checked === undefined ? Boolean(indeterminate) : rest.checked;
44
44
  }
45
45
  }, [inputRef, indeterminate]);
46
46
  var uniqId = plasmaCore.safeUseId();
@@ -1 +1 @@
1
- {"version":3,"file":"Checkbox.js","sources":["../../../src/components/Checkbox/Checkbox.tsx"],"sourcesContent":["import React, { forwardRef, useEffect, useMemo, useRef } from 'react';\nimport { safeUseId, useForkRef, extractTextFrom } from '@salutejs/plasma-core';\n\nimport type { RootProps } from '../../engines/types';\nimport { cx } from '../../utils';\n\nimport { base as viewCSS } from './variations/_view/base';\nimport { base as sizeCSS } from './variations/_size/base';\nimport { base as disabledCSS } from './variations/_disabled/base';\nimport { base as focusedCSS } from './variations/_focused/base';\nimport { Done, Indeterminate } from './IconsSvg';\nimport {\n StyledContent,\n StyledContentWrapper,\n StyledDescription,\n StyledInput,\n StyledLabel,\n StyledTrigger,\n base,\n StyledTriggerWrapper,\n} from './Checkbox.styles';\nimport type { CheckboxProps } from './Checkbox.types';\nimport { classes } from './Checkbox.tokens';\n\nexport const checkboxRoot = (Root: RootProps<HTMLInputElement, CheckboxProps>) =>\n forwardRef<HTMLInputElement, CheckboxProps>((props, ref) => {\n const {\n size,\n view,\n focused,\n disabled,\n id,\n label,\n description,\n indeterminate,\n style,\n className,\n singleLine = false,\n 'aria-label': ariaLabelExternal,\n ...rest\n } = props;\n\n const inputRef = useRef<HTMLInputElement | null>(null);\n const forkRef = useForkRef(inputRef, ref);\n\n useEffect(() => {\n if (inputRef.current) {\n inputRef.current.indeterminate = Boolean(indeterminate);\n }\n }, [inputRef, indeterminate]);\n\n const uniqId = safeUseId();\n const uniqLabelId = `label-${uniqId}`;\n const uniqDescriptionId = `description-${uniqId}`;\n const checkboxId = id || `input-${uniqId}`;\n\n const ariaLabel = useMemo(() => ariaLabelExternal || extractTextFrom(label), [ariaLabelExternal, label]);\n const isLabelAriaHidden = typeof label === 'string';\n const canFocused = focused ? 0 : -1;\n const hasContent = label || description;\n const singleLineClass = singleLine ? classes.singleLine : undefined;\n const onlyDescriptionClass = !label && description ? classes.onlyDescription : undefined;\n\n return (\n <Root\n view={view}\n size={size}\n disabled={disabled}\n focused={focused}\n style={style}\n className={className}\n tabIndex={-1}\n >\n <StyledInput\n {...rest}\n id={checkboxId}\n ref={forkRef}\n type=\"checkbox\"\n disabled={disabled}\n aria-label={ariaLabel}\n aria-describedby={uniqDescriptionId}\n tabIndex={canFocused}\n />\n <StyledContentWrapper htmlFor={checkboxId} className={singleLineClass}>\n <StyledTriggerWrapper>\n <StyledTrigger className={classes.checkboxTrigger}>\n {indeterminate ? <Indeterminate /> : <Done />}\n </StyledTrigger>\n </StyledTriggerWrapper>\n {hasContent && (\n <StyledContent className={singleLineClass}>\n {label && (\n <StyledLabel\n className={singleLineClass}\n id={uniqLabelId}\n aria-hidden={isLabelAriaHidden}\n >\n {label}\n </StyledLabel>\n )}\n {description && (\n <StyledDescription\n className={cx(singleLineClass, onlyDescriptionClass)}\n id={uniqDescriptionId}\n >\n {description}\n </StyledDescription>\n )}\n </StyledContent>\n )}\n </StyledContentWrapper>\n </Root>\n );\n });\n\nexport const checkboxConfig = {\n name: 'Checkbox',\n tag: 'div',\n layout: checkboxRoot,\n base,\n variations: {\n size: {\n css: sizeCSS,\n },\n view: {\n css: viewCSS,\n },\n disabled: {\n css: disabledCSS,\n },\n focused: {\n css: focusedCSS,\n },\n },\n defaults: {\n size: 'm',\n view: 'accent',\n },\n};\n"],"names":["checkboxRoot","Root","forwardRef","props","ref","size","view","focused","disabled","id","label","description","indeterminate","style","className","_props$singleLine","singleLine","ariaLabelExternal","rest","_objectWithoutProperties","_excluded","inputRef","useRef","forkRef","useForkRef","useEffect","current","Boolean","uniqId","safeUseId","uniqLabelId","concat","uniqDescriptionId","checkboxId","ariaLabel","useMemo","extractTextFrom","isLabelAriaHidden","canFocused","hasContent","singleLineClass","classes","undefined","onlyDescriptionClass","onlyDescription","React","createElement","tabIndex","StyledInput","_extends","type","StyledContentWrapper","htmlFor","StyledTriggerWrapper","StyledTrigger","checkboxTrigger","_Indeterminate","Indeterminate","_Done","Done","StyledContent","StyledLabel","StyledDescription","cx","checkboxConfig","name","tag","layout","base","variations","css","sizeCSS","viewCSS","disabledCSS","focusedCSS","defaults"],"mappings":"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"}
1
+ {"version":3,"file":"Checkbox.js","sources":["../../../src/components/Checkbox/Checkbox.tsx"],"sourcesContent":["import React, { forwardRef, useEffect, useMemo, useRef } from 'react';\nimport { safeUseId, useForkRef, extractTextFrom } from '@salutejs/plasma-core';\n\nimport type { RootProps } from '../../engines/types';\nimport { cx } from '../../utils';\n\nimport { base as viewCSS } from './variations/_view/base';\nimport { base as sizeCSS } from './variations/_size/base';\nimport { base as disabledCSS } from './variations/_disabled/base';\nimport { base as focusedCSS } from './variations/_focused/base';\nimport { Done, Indeterminate } from './IconsSvg';\nimport {\n StyledContent,\n StyledContentWrapper,\n StyledDescription,\n StyledInput,\n StyledLabel,\n StyledTrigger,\n base,\n StyledTriggerWrapper,\n} from './Checkbox.styles';\nimport type { CheckboxProps } from './Checkbox.types';\nimport { classes } from './Checkbox.tokens';\n\nexport const checkboxRoot = (Root: RootProps<HTMLInputElement, CheckboxProps>) =>\n forwardRef<HTMLInputElement, CheckboxProps>((props, ref) => {\n const {\n size,\n view,\n focused,\n disabled,\n id,\n label,\n description,\n indeterminate,\n style,\n className,\n singleLine = false,\n 'aria-label': ariaLabelExternal,\n ...rest\n } = props;\n\n const inputRef = useRef<HTMLInputElement | null>(null);\n const forkRef = useForkRef(inputRef, ref);\n\n useEffect(() => {\n if (inputRef.current && indeterminate) {\n inputRef.current.indeterminate = rest.checked === undefined ? Boolean(indeterminate) : rest.checked;\n }\n }, [inputRef, indeterminate]);\n\n const uniqId = safeUseId();\n const uniqLabelId = `label-${uniqId}`;\n const uniqDescriptionId = `description-${uniqId}`;\n const checkboxId = id || `input-${uniqId}`;\n\n const ariaLabel = useMemo(() => ariaLabelExternal || extractTextFrom(label), [ariaLabelExternal, label]);\n const isLabelAriaHidden = typeof label === 'string';\n const canFocused = focused ? 0 : -1;\n const hasContent = label || description;\n const singleLineClass = singleLine ? classes.singleLine : undefined;\n const onlyDescriptionClass = !label && description ? classes.onlyDescription : undefined;\n\n return (\n <Root\n view={view}\n size={size}\n disabled={disabled}\n focused={focused}\n style={style}\n className={className}\n tabIndex={-1}\n >\n <StyledInput\n {...rest}\n id={checkboxId}\n ref={forkRef}\n type=\"checkbox\"\n disabled={disabled}\n aria-label={ariaLabel}\n aria-describedby={uniqDescriptionId}\n tabIndex={canFocused}\n />\n <StyledContentWrapper htmlFor={checkboxId} className={singleLineClass}>\n <StyledTriggerWrapper>\n <StyledTrigger className={classes.checkboxTrigger}>\n {indeterminate ? <Indeterminate /> : <Done />}\n </StyledTrigger>\n </StyledTriggerWrapper>\n {hasContent && (\n <StyledContent className={singleLineClass}>\n {label && (\n <StyledLabel\n className={singleLineClass}\n id={uniqLabelId}\n aria-hidden={isLabelAriaHidden}\n >\n {label}\n </StyledLabel>\n )}\n {description && (\n <StyledDescription\n className={cx(singleLineClass, onlyDescriptionClass)}\n id={uniqDescriptionId}\n >\n {description}\n </StyledDescription>\n )}\n </StyledContent>\n )}\n </StyledContentWrapper>\n </Root>\n );\n });\n\nexport const checkboxConfig = {\n name: 'Checkbox',\n tag: 'div',\n layout: checkboxRoot,\n base,\n variations: {\n size: {\n css: sizeCSS,\n },\n view: {\n css: viewCSS,\n },\n disabled: {\n css: disabledCSS,\n },\n focused: {\n css: focusedCSS,\n },\n },\n defaults: {\n size: 'm',\n view: 'accent',\n },\n};\n"],"names":["checkboxRoot","Root","forwardRef","props","ref","size","view","focused","disabled","id","label","description","indeterminate","style","className","_props$singleLine","singleLine","ariaLabelExternal","rest","_objectWithoutProperties","_excluded","inputRef","useRef","forkRef","useForkRef","useEffect","current","checked","undefined","Boolean","uniqId","safeUseId","uniqLabelId","concat","uniqDescriptionId","checkboxId","ariaLabel","useMemo","extractTextFrom","isLabelAriaHidden","canFocused","hasContent","singleLineClass","classes","onlyDescriptionClass","onlyDescription","React","createElement","tabIndex","StyledInput","_extends","type","StyledContentWrapper","htmlFor","StyledTriggerWrapper","StyledTrigger","checkboxTrigger","_Indeterminate","Indeterminate","_Done","Done","StyledContent","StyledLabel","StyledDescription","cx","checkboxConfig","name","tag","layout","base","variations","css","sizeCSS","viewCSS","disabledCSS","focusedCSS","defaults"],"mappings":"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"}
@@ -12,7 +12,7 @@ function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
12
12
 
13
13
  var React__default = /*#__PURE__*/_interopDefault(React);
14
14
 
15
- var _excluded = ["className"];
15
+ var _excluded = ["className", "as", "forwardedAs"];
16
16
  /* eslint-disable no-underscore-dangle */
17
17
  var _component = function _component(componentConfig) {
18
18
  var tag = componentConfig.tag,
@@ -21,9 +21,10 @@ var _component = function _component(componentConfig) {
21
21
  intersections = componentConfig.intersections;
22
22
  var staticVariants = utils.getStaticVariants(componentConfig);
23
23
  var dynamicVariants = utils.getDynamicVariants(componentConfig);
24
- var Root = tag;
25
24
  var component = /*#__PURE__*/React.forwardRef(function (props, ref) {
26
25
  var className = props.className,
26
+ as = props.as,
27
+ forwardedAs = props.forwardedAs,
27
28
  rest = _rollupPluginBabelHelpers.objectWithoutProperties(props, _excluded);
28
29
  var variants = dynamicVariants(rest);
29
30
  var intersectionStyles = utils.getIntersectionStyles(rest, intersections);
@@ -51,6 +52,7 @@ var _component = function _component(componentConfig) {
51
52
  }
52
53
  }
53
54
  }
55
+ var Root = as || forwardedAs || tag;
54
56
  return /*#__PURE__*/React__default.default.createElement(Root, _rollupPluginBabelHelpers.extends({
55
57
  className: cls
56
58
  }, htmlAttrs, baseProps));
@@ -1 +1 @@
1
- {"version":3,"file":"linaria.js","sources":["../../src/engines/linaria.tsx"],"sourcesContent":["import React, { forwardRef } from 'react';\nimport { cx } from '@linaria/core';\n\n// TODO: #1008 Избавиться от импортов и переделать addFocus\nimport 'focus-visible';\nimport { getStaticVariants, getDynamicVariants, getIntersectionStyles } from './utils';\nimport type { ComponentConfig, HTMLAnyAttributes } from './types';\n\n/* eslint-disable no-underscore-dangle */\nexport const _component = (componentConfig: ComponentConfig) => {\n const { tag, base, name, intersections } = componentConfig;\n const staticVariants = getStaticVariants(componentConfig);\n const dynamicVariants = getDynamicVariants(componentConfig);\n\n const Root = tag as React.ElementType;\n\n const component = forwardRef<HTMLElement, HTMLAnyAttributes>((props, ref) => {\n const { className, ...rest } = props;\n const variants = dynamicVariants(rest);\n const intersectionStyles = getIntersectionStyles(rest, intersections);\n\n const cls = cx(className, base as string, ...(staticVariants as string[]), ...variants, ...intersectionStyles);\n\n // styled-components do it inside\n // filter props\n const baseProps: HTMLAnyAttributes = {};\n for (const key in rest) {\n if (!(key in componentConfig.variations)) {\n baseProps[key] = rest[key];\n }\n }\n\n baseProps.ref = ref;\n\n // styled-components do it inside\n // add props that should be attr( disabled for example)\n const htmlAttrs: HTMLAnyAttributes = {};\n for (const key in componentConfig.variations || {}) {\n if (key in rest) {\n const variant = componentConfig.variations[key];\n\n const { attrs } = variant;\n if (typeof attrs === 'boolean') {\n htmlAttrs[key] = rest[key];\n }\n }\n }\n\n return <Root className={cls} {...htmlAttrs} {...baseProps} />;\n });\n if (name) {\n component.displayName = name;\n }\n return component;\n};\n"],"names":["_component","componentConfig","tag","base","name","intersections","staticVariants","getStaticVariants","dynamicVariants","getDynamicVariants","Root","component","forwardRef","props","ref","className","rest","_objectWithoutProperties","_excluded","variants","intersectionStyles","getIntersectionStyles","cls","cx","apply","concat","_toConsumableArray","baseProps","key","variations","htmlAttrs","variant","attrs","React","createElement","_extends","displayName"],"mappings":";;;;;;;;;;;;;;;AAQA;IACaA,UAAU,GAAG,SAAbA,UAAUA,CAAIC,eAAgC,EAAK;AAC5D,EAAA,IAAQC,GAAG,GAAgCD,eAAe,CAAlDC,GAAG;IAAEC,IAAI,GAA0BF,eAAe,CAA7CE,IAAI;IAAEC,IAAI,GAAoBH,eAAe,CAAvCG,IAAI;IAAEC,aAAa,GAAKJ,eAAe,CAAjCI,aAAa,CAAA;AACtC,EAAA,IAAMC,cAAc,GAAGC,uBAAiB,CAACN,eAAe,CAAC,CAAA;AACzD,EAAA,IAAMO,eAAe,GAAGC,wBAAkB,CAACR,eAAe,CAAC,CAAA;EAE3D,IAAMS,IAAI,GAAGR,GAAwB,CAAA;EAErC,IAAMS,SAAS,gBAAGC,gBAAU,CAAiC,UAACC,KAAK,EAAEC,GAAG,EAAK;AACzE,IAAA,IAAQC,SAAS,GAAcF,KAAK,CAA5BE,SAAS;AAAKC,MAAAA,IAAI,GAAAC,iDAAA,CAAKJ,KAAK,EAAAK,SAAA,CAAA,CAAA;AACpC,IAAA,IAAMC,QAAQ,GAAGX,eAAe,CAACQ,IAAI,CAAC,CAAA;AACtC,IAAA,IAAMI,kBAAkB,GAAGC,2BAAqB,CAACL,IAAI,EAAEX,aAAa,CAAC,CAAA;IAErE,IAAMiB,GAAG,GAAGC,OAAE,CAAAC,KAAA,CAACT,KAAAA,CAAAA,EAAAA,CAAAA,SAAS,EAAEZ,IAAI,CAAAsB,CAAAA,MAAA,CAAAC,2CAAA,CAAgBpB,cAAc,CAAA,EAAAoB,2CAAA,CAAkBP,QAAQ,CAAAO,EAAAA,2CAAA,CAAKN,kBAAkB,CAAC,CAAA,CAAA,CAAA;;AAE9G;AACA;IACA,IAAMO,SAA4B,GAAG,EAAE,CAAA;AACvC,IAAA,KAAK,IAAMC,GAAG,IAAIZ,IAAI,EAAE;AACpB,MAAA,IAAI,EAAEY,GAAG,IAAI3B,eAAe,CAAC4B,UAAU,CAAC,EAAE;AACtCF,QAAAA,SAAS,CAACC,GAAG,CAAC,GAAGZ,IAAI,CAACY,GAAG,CAAC,CAAA;AAC9B,OAAA;AACJ,KAAA;IAEAD,SAAS,CAACb,GAAG,GAAGA,GAAG,CAAA;;AAEnB;AACA;IACA,IAAMgB,SAA4B,GAAG,EAAE,CAAA;IACvC,KAAK,IAAMF,IAAG,IAAI3B,eAAe,CAAC4B,UAAU,IAAI,EAAE,EAAE;MAChD,IAAID,IAAG,IAAIZ,IAAI,EAAE;AACb,QAAA,IAAMe,OAAO,GAAG9B,eAAe,CAAC4B,UAAU,CAACD,IAAG,CAAC,CAAA;AAE/C,QAAA,IAAQI,KAAK,GAAKD,OAAO,CAAjBC,KAAK,CAAA;AACb,QAAA,IAAI,OAAOA,KAAK,KAAK,SAAS,EAAE;AAC5BF,UAAAA,SAAS,CAACF,IAAG,CAAC,GAAGZ,IAAI,CAACY,IAAG,CAAC,CAAA;AAC9B,SAAA;AACJ,OAAA;AACJ,KAAA;AAEA,IAAA,oBAAOK,sBAAA,CAAAC,aAAA,CAACxB,IAAI,EAAAyB,iCAAA,CAAA;AAACpB,MAAAA,SAAS,EAAEO,GAAAA;AAAI,KAAA,EAAKQ,SAAS,EAAMH,SAAS,CAAG,CAAC,CAAA;AACjE,GAAC,CAAC,CAAA;AACF,EAAA,IAAIvB,IAAI,EAAE;IACNO,SAAS,CAACyB,WAAW,GAAGhC,IAAI,CAAA;AAChC,GAAA;AACA,EAAA,OAAOO,SAAS,CAAA;AACpB;;;;"}
1
+ {"version":3,"file":"linaria.js","sources":["../../src/engines/linaria.tsx"],"sourcesContent":["import React, { forwardRef } from 'react';\nimport { cx } from '@linaria/core';\n\n// TODO: #1008 Избавиться от импортов и переделать addFocus\nimport 'focus-visible';\nimport { getStaticVariants, getDynamicVariants, getIntersectionStyles } from './utils';\nimport type { ComponentConfig, HTMLAnyAttributes } from './types';\n\n/* eslint-disable no-underscore-dangle */\nexport const _component = (componentConfig: ComponentConfig) => {\n const { tag, base, name, intersections } = componentConfig;\n const staticVariants = getStaticVariants(componentConfig);\n const dynamicVariants = getDynamicVariants(componentConfig);\n\n const component = forwardRef<HTMLElement, HTMLAnyAttributes>((props, ref) => {\n const { className, as, forwardedAs, ...rest } = props;\n const variants = dynamicVariants(rest);\n const intersectionStyles = getIntersectionStyles(rest, intersections);\n\n const cls = cx(className, base as string, ...(staticVariants as string[]), ...variants, ...intersectionStyles);\n\n // styled-components do it inside\n // filter props\n const baseProps: HTMLAnyAttributes = {};\n for (const key in rest) {\n if (!(key in componentConfig.variations)) {\n baseProps[key] = rest[key];\n }\n }\n\n baseProps.ref = ref;\n\n // styled-components do it inside\n // add props that should be attr( disabled for example)\n const htmlAttrs: HTMLAnyAttributes = {};\n for (const key in componentConfig.variations || {}) {\n if (key in rest) {\n const variant = componentConfig.variations[key];\n\n const { attrs } = variant;\n if (typeof attrs === 'boolean') {\n htmlAttrs[key] = rest[key];\n }\n }\n }\n\n const Root = as || forwardedAs || (tag as React.ElementType);\n\n return <Root className={cls} {...htmlAttrs} {...baseProps} />;\n });\n if (name) {\n component.displayName = name;\n }\n return component;\n};\n"],"names":["_component","componentConfig","tag","base","name","intersections","staticVariants","getStaticVariants","dynamicVariants","getDynamicVariants","component","forwardRef","props","ref","className","as","forwardedAs","rest","_objectWithoutProperties","_excluded","variants","intersectionStyles","getIntersectionStyles","cls","cx","apply","concat","_toConsumableArray","baseProps","key","variations","htmlAttrs","variant","attrs","Root","React","createElement","_extends","displayName"],"mappings":";;;;;;;;;;;;;;;AAQA;IACaA,UAAU,GAAG,SAAbA,UAAUA,CAAIC,eAAgC,EAAK;AAC5D,EAAA,IAAQC,GAAG,GAAgCD,eAAe,CAAlDC,GAAG;IAAEC,IAAI,GAA0BF,eAAe,CAA7CE,IAAI;IAAEC,IAAI,GAAoBH,eAAe,CAAvCG,IAAI;IAAEC,aAAa,GAAKJ,eAAe,CAAjCI,aAAa,CAAA;AACtC,EAAA,IAAMC,cAAc,GAAGC,uBAAiB,CAACN,eAAe,CAAC,CAAA;AACzD,EAAA,IAAMO,eAAe,GAAGC,wBAAkB,CAACR,eAAe,CAAC,CAAA;EAE3D,IAAMS,SAAS,gBAAGC,gBAAU,CAAiC,UAACC,KAAK,EAAEC,GAAG,EAAK;AACzE,IAAA,IAAQC,SAAS,GAA+BF,KAAK,CAA7CE,SAAS;MAAEC,EAAE,GAA2BH,KAAK,CAAlCG,EAAE;MAAEC,WAAW,GAAcJ,KAAK,CAA9BI,WAAW;AAAKC,MAAAA,IAAI,GAAAC,iDAAA,CAAKN,KAAK,EAAAO,SAAA,CAAA,CAAA;AACrD,IAAA,IAAMC,QAAQ,GAAGZ,eAAe,CAACS,IAAI,CAAC,CAAA;AACtC,IAAA,IAAMI,kBAAkB,GAAGC,2BAAqB,CAACL,IAAI,EAAEZ,aAAa,CAAC,CAAA;IAErE,IAAMkB,GAAG,GAAGC,OAAE,CAAAC,KAAA,CAACX,KAAAA,CAAAA,EAAAA,CAAAA,SAAS,EAAEX,IAAI,CAAAuB,CAAAA,MAAA,CAAAC,2CAAA,CAAgBrB,cAAc,CAAA,EAAAqB,2CAAA,CAAkBP,QAAQ,CAAAO,EAAAA,2CAAA,CAAKN,kBAAkB,CAAC,CAAA,CAAA,CAAA;;AAE9G;AACA;IACA,IAAMO,SAA4B,GAAG,EAAE,CAAA;AACvC,IAAA,KAAK,IAAMC,GAAG,IAAIZ,IAAI,EAAE;AACpB,MAAA,IAAI,EAAEY,GAAG,IAAI5B,eAAe,CAAC6B,UAAU,CAAC,EAAE;AACtCF,QAAAA,SAAS,CAACC,GAAG,CAAC,GAAGZ,IAAI,CAACY,GAAG,CAAC,CAAA;AAC9B,OAAA;AACJ,KAAA;IAEAD,SAAS,CAACf,GAAG,GAAGA,GAAG,CAAA;;AAEnB;AACA;IACA,IAAMkB,SAA4B,GAAG,EAAE,CAAA;IACvC,KAAK,IAAMF,IAAG,IAAI5B,eAAe,CAAC6B,UAAU,IAAI,EAAE,EAAE;MAChD,IAAID,IAAG,IAAIZ,IAAI,EAAE;AACb,QAAA,IAAMe,OAAO,GAAG/B,eAAe,CAAC6B,UAAU,CAACD,IAAG,CAAC,CAAA;AAE/C,QAAA,IAAQI,KAAK,GAAKD,OAAO,CAAjBC,KAAK,CAAA;AACb,QAAA,IAAI,OAAOA,KAAK,KAAK,SAAS,EAAE;AAC5BF,UAAAA,SAAS,CAACF,IAAG,CAAC,GAAGZ,IAAI,CAACY,IAAG,CAAC,CAAA;AAC9B,SAAA;AACJ,OAAA;AACJ,KAAA;AAEA,IAAA,IAAMK,IAAI,GAAGnB,EAAE,IAAIC,WAAW,IAAKd,GAAyB,CAAA;AAE5D,IAAA,oBAAOiC,sBAAA,CAAAC,aAAA,CAACF,IAAI,EAAAG,iCAAA,CAAA;AAACvB,MAAAA,SAAS,EAAES,GAAAA;AAAI,KAAA,EAAKQ,SAAS,EAAMH,SAAS,CAAG,CAAC,CAAA;AACjE,GAAC,CAAC,CAAA;AACF,EAAA,IAAIxB,IAAI,EAAE;IACNM,SAAS,CAAC4B,WAAW,GAAGlC,IAAI,CAAA;AAChC,GAAA;AACA,EAAA,OAAOM,SAAS,CAAA;AACpB;;;;"}
@@ -41,8 +41,8 @@ var checkboxRoot = exports.checkboxRoot = function checkboxRoot(Root) {
41
41
  var inputRef = (0, _react.useRef)(null);
42
42
  var forkRef = (0, _plasmaCore.useForkRef)(inputRef, ref);
43
43
  (0, _react.useEffect)(function () {
44
- if (inputRef.current) {
45
- inputRef.current.indeterminate = Boolean(indeterminate);
44
+ if (inputRef.current && indeterminate) {
45
+ inputRef.current.indeterminate = rest.checked === undefined ? Boolean(indeterminate) : rest.checked;
46
46
  }
47
47
  }, [inputRef, indeterminate]);
48
48
  var uniqId = (0, _plasmaCore.safeUseId)();
@@ -48,16 +48,3 @@ export function App() {
48
48
  );
49
49
  }
50
50
  ```
51
-
52
- Состояние `indeterminate` имеет приоритет и не зависит от свойства `checked`
53
-
54
- ```tsx live
55
- import React from 'react';
56
- import { Checkbox } from '@salutejs/{{ package }}';
57
-
58
- export function App() {
59
- return (
60
- <Checkbox label="Чекбокс" description="Описание" defaultChecked indeterminate checked={false} />
61
- );
62
- }
63
- ```
@@ -23,6 +23,22 @@ title: Typography
23
23
  По умолчанию в типографике если текст превышает ширину элемента, то слова будут переноситься по пробелам.
24
24
  Чтобы запретить перенос по пробелам, необходимо установить свойство `noWrap` в значении `true`.
25
25
 
26
+ ## Смена тега
27
+ Если при использовании компонентов необходимо сменить тег, то можно использовать свойство `as`:
28
+
29
+ ```tsx live
30
+ import React from 'react';
31
+ import { BodyM } from '@salutejs/{{ package }}';
32
+
33
+ export function App() {
34
+ return (
35
+ <BodyM as="h3">
36
+ BodyM
37
+ </BodyM>
38
+ );
39
+ }
40
+ ```
41
+
26
42
  ## Состав
27
43
 
28
44
  ### Hero unit
@@ -9,7 +9,7 @@ import { Body } from './Body';
9
9
  import { config } from './Body.config';
10
10
 
11
11
  const meta: Meta<typeof Body> = {
12
- title: 'Data Display/Typography/Body',
12
+ title: 'typography/Body',
13
13
  decorators: [WithTheme],
14
14
  component: Body,
15
15
  argTypes: {
@@ -19,6 +19,9 @@ const meta: Meta<typeof Body> = {
19
19
  type: 'color',
20
20
  },
21
21
  },
22
+ as: {
23
+ control: 'text',
24
+ },
22
25
  },
23
26
  args: {
24
27
  noWrap: false,
@@ -9,7 +9,7 @@ import { Dspl } from './Dspl';
9
9
  import { config } from './Dspl.config';
10
10
 
11
11
  const meta: Meta<typeof Dspl> = {
12
- title: 'Data Display/Typography/Dspl',
12
+ title: 'typography/Dspl',
13
13
  decorators: [WithTheme],
14
14
  component: Dspl,
15
15
  argTypes: {
@@ -19,6 +19,9 @@ const meta: Meta<typeof Dspl> = {
19
19
  type: 'color',
20
20
  },
21
21
  },
22
+ as: {
23
+ control: 'text',
24
+ },
22
25
  },
23
26
  args: {
24
27
  noWrap: false,
@@ -9,7 +9,7 @@ import { Heading } from './Heading';
9
9
  import { config } from './Heading.config';
10
10
 
11
11
  const meta: Meta<typeof Heading> = {
12
- title: 'Data Display/Typography/Heading',
12
+ title: 'typography/Heading',
13
13
  decorators: [WithTheme],
14
14
  component: Heading,
15
15
  argTypes: {
@@ -19,6 +19,9 @@ const meta: Meta<typeof Heading> = {
19
19
  type: 'color',
20
20
  },
21
21
  },
22
+ as: {
23
+ control: 'text',
24
+ },
22
25
  },
23
26
  args: {
24
27
  noWrap: false,
@@ -9,7 +9,7 @@ import { Text } from './Text';
9
9
  import { config } from './Text.config';
10
10
 
11
11
  const meta: Meta<typeof Text> = {
12
- title: 'Data Display/Typography/Text',
12
+ title: 'typography/Text',
13
13
  decorators: [WithTheme],
14
14
  component: Text,
15
15
  argTypes: {
@@ -19,6 +19,9 @@ const meta: Meta<typeof Text> = {
19
19
  type: 'color',
20
20
  },
21
21
  },
22
+ as: {
23
+ control: 'text',
24
+ },
22
25
  },
23
26
  args: {
24
27
  noWrap: false,
@@ -32,8 +32,8 @@ export var checkboxRoot = function checkboxRoot(Root) {
32
32
  var inputRef = useRef(null);
33
33
  var forkRef = useForkRef(inputRef, ref);
34
34
  useEffect(function () {
35
- if (inputRef.current) {
36
- inputRef.current.indeterminate = Boolean(indeterminate);
35
+ if (inputRef.current && indeterminate) {
36
+ inputRef.current.indeterminate = rest.checked === undefined ? Boolean(indeterminate) : rest.checked;
37
37
  }
38
38
  }, [inputRef, indeterminate]);
39
39
  var uniqId = safeUseId();
@@ -48,16 +48,3 @@ export function App() {
48
48
  );
49
49
  }
50
50
  ```
51
-
52
- Состояние `indeterminate` имеет приоритет и не зависит от свойства `checked`
53
-
54
- ```tsx live
55
- import React from 'react';
56
- import { Checkbox } from '@salutejs/{{ package }}';
57
-
58
- export function App() {
59
- return (
60
- <Checkbox label="Чекбокс" description="Описание" defaultChecked indeterminate checked={false} />
61
- );
62
- }
63
- ```
@@ -23,6 +23,22 @@ title: Typography
23
23
  По умолчанию в типографике если текст превышает ширину элемента, то слова будут переноситься по пробелам.
24
24
  Чтобы запретить перенос по пробелам, необходимо установить свойство `noWrap` в значении `true`.
25
25
 
26
+ ## Смена тега
27
+ Если при использовании компонентов необходимо сменить тег, то можно использовать свойство `as`:
28
+
29
+ ```tsx live
30
+ import React from 'react';
31
+ import { BodyM } from '@salutejs/{{ package }}';
32
+
33
+ export function App() {
34
+ return (
35
+ <BodyM as="h3">
36
+ BodyM
37
+ </BodyM>
38
+ );
39
+ }
40
+ ```
41
+
26
42
  ## Состав
27
43
 
28
44
  ### Hero unit
@@ -9,7 +9,7 @@ import { Body } from './Body';
9
9
  import { config } from './Body.config';
10
10
 
11
11
  const meta: Meta<typeof Body> = {
12
- title: 'Data Display/Typography/Body',
12
+ title: 'typography/Body',
13
13
  decorators: [WithTheme],
14
14
  component: Body,
15
15
  argTypes: {
@@ -19,6 +19,9 @@ const meta: Meta<typeof Body> = {
19
19
  type: 'color',
20
20
  },
21
21
  },
22
+ as: {
23
+ control: 'text',
24
+ },
22
25
  },
23
26
  args: {
24
27
  noWrap: false,
@@ -9,7 +9,7 @@ import { Dspl } from './Dspl';
9
9
  import { config } from './Dspl.config';
10
10
 
11
11
  const meta: Meta<typeof Dspl> = {
12
- title: 'Data Display/Typography/Dspl',
12
+ title: 'typography/Dspl',
13
13
  decorators: [WithTheme],
14
14
  component: Dspl,
15
15
  argTypes: {
@@ -19,6 +19,9 @@ const meta: Meta<typeof Dspl> = {
19
19
  type: 'color',
20
20
  },
21
21
  },
22
+ as: {
23
+ control: 'text',
24
+ },
22
25
  },
23
26
  args: {
24
27
  noWrap: false,
@@ -9,7 +9,7 @@ import { Heading } from './Heading';
9
9
  import { config } from './Heading.config';
10
10
 
11
11
  const meta: Meta<typeof Heading> = {
12
- title: 'Data Display/Typography/Heading',
12
+ title: 'typography/Heading',
13
13
  decorators: [WithTheme],
14
14
  component: Heading,
15
15
  argTypes: {
@@ -19,6 +19,9 @@ const meta: Meta<typeof Heading> = {
19
19
  type: 'color',
20
20
  },
21
21
  },
22
+ as: {
23
+ control: 'text',
24
+ },
22
25
  },
23
26
  args: {
24
27
  noWrap: false,
@@ -9,7 +9,7 @@ import { Text } from './Text';
9
9
  import { config } from './Text.config';
10
10
 
11
11
  const meta: Meta<typeof Text> = {
12
- title: 'Data Display/Typography/Text',
12
+ title: 'typography/Text',
13
13
  decorators: [WithTheme],
14
14
  component: Text,
15
15
  argTypes: {
@@ -19,6 +19,9 @@ const meta: Meta<typeof Text> = {
19
19
  type: 'color',
20
20
  },
21
21
  },
22
+ as: {
23
+ control: 'text',
24
+ },
22
25
  },
23
26
  args: {
24
27
  noWrap: false,
@@ -31,8 +31,8 @@ var checkboxRoot = function checkboxRoot(Root) {
31
31
  var inputRef = useRef(null);
32
32
  var forkRef = useForkRef(inputRef, ref);
33
33
  useEffect(function () {
34
- if (inputRef.current) {
35
- inputRef.current.indeterminate = Boolean(indeterminate);
34
+ if (inputRef.current && indeterminate) {
35
+ inputRef.current.indeterminate = rest.checked === undefined ? Boolean(indeterminate) : rest.checked;
36
36
  }
37
37
  }, [inputRef, indeterminate]);
38
38
  var uniqId = safeUseId();
@@ -1 +1 @@
1
- {"version":3,"file":"Checkbox.js","sources":["../../../src/components/Checkbox/Checkbox.tsx"],"sourcesContent":["import React, { forwardRef, useEffect, useMemo, useRef } from 'react';\nimport { safeUseId, useForkRef, extractTextFrom } from '@salutejs/plasma-core';\n\nimport type { RootProps } from '../../engines/types';\nimport { cx } from '../../utils';\n\nimport { base as viewCSS } from './variations/_view/base';\nimport { base as sizeCSS } from './variations/_size/base';\nimport { base as disabledCSS } from './variations/_disabled/base';\nimport { base as focusedCSS } from './variations/_focused/base';\nimport { Done, Indeterminate } from './IconsSvg';\nimport {\n StyledContent,\n StyledContentWrapper,\n StyledDescription,\n StyledInput,\n StyledLabel,\n StyledTrigger,\n base,\n StyledTriggerWrapper,\n} from './Checkbox.styles';\nimport type { CheckboxProps } from './Checkbox.types';\nimport { classes } from './Checkbox.tokens';\n\nexport const checkboxRoot = (Root: RootProps<HTMLInputElement, CheckboxProps>) =>\n forwardRef<HTMLInputElement, CheckboxProps>((props, ref) => {\n const {\n size,\n view,\n focused,\n disabled,\n id,\n label,\n description,\n indeterminate,\n style,\n className,\n singleLine = false,\n 'aria-label': ariaLabelExternal,\n ...rest\n } = props;\n\n const inputRef = useRef<HTMLInputElement | null>(null);\n const forkRef = useForkRef(inputRef, ref);\n\n useEffect(() => {\n if (inputRef.current) {\n inputRef.current.indeterminate = Boolean(indeterminate);\n }\n }, [inputRef, indeterminate]);\n\n const uniqId = safeUseId();\n const uniqLabelId = `label-${uniqId}`;\n const uniqDescriptionId = `description-${uniqId}`;\n const checkboxId = id || `input-${uniqId}`;\n\n const ariaLabel = useMemo(() => ariaLabelExternal || extractTextFrom(label), [ariaLabelExternal, label]);\n const isLabelAriaHidden = typeof label === 'string';\n const canFocused = focused ? 0 : -1;\n const hasContent = label || description;\n const singleLineClass = singleLine ? classes.singleLine : undefined;\n const onlyDescriptionClass = !label && description ? classes.onlyDescription : undefined;\n\n return (\n <Root\n view={view}\n size={size}\n disabled={disabled}\n focused={focused}\n style={style}\n className={className}\n tabIndex={-1}\n >\n <StyledInput\n {...rest}\n id={checkboxId}\n ref={forkRef}\n type=\"checkbox\"\n disabled={disabled}\n aria-label={ariaLabel}\n aria-describedby={uniqDescriptionId}\n tabIndex={canFocused}\n />\n <StyledContentWrapper htmlFor={checkboxId} className={singleLineClass}>\n <StyledTriggerWrapper>\n <StyledTrigger className={classes.checkboxTrigger}>\n {indeterminate ? <Indeterminate /> : <Done />}\n </StyledTrigger>\n </StyledTriggerWrapper>\n {hasContent && (\n <StyledContent className={singleLineClass}>\n {label && (\n <StyledLabel\n className={singleLineClass}\n id={uniqLabelId}\n aria-hidden={isLabelAriaHidden}\n >\n {label}\n </StyledLabel>\n )}\n {description && (\n <StyledDescription\n className={cx(singleLineClass, onlyDescriptionClass)}\n id={uniqDescriptionId}\n >\n {description}\n </StyledDescription>\n )}\n </StyledContent>\n )}\n </StyledContentWrapper>\n </Root>\n );\n });\n\nexport const checkboxConfig = {\n name: 'Checkbox',\n tag: 'div',\n layout: checkboxRoot,\n base,\n variations: {\n size: {\n css: sizeCSS,\n },\n view: {\n css: viewCSS,\n },\n disabled: {\n css: disabledCSS,\n },\n focused: {\n css: focusedCSS,\n },\n },\n defaults: {\n size: 'm',\n view: 'accent',\n },\n};\n"],"names":["checkboxRoot","Root","forwardRef","props","ref","size","view","focused","disabled","id","label","description","indeterminate","style","className","_props$singleLine","singleLine","ariaLabelExternal","rest","_objectWithoutProperties","_excluded","inputRef","useRef","forkRef","useForkRef","useEffect","current","Boolean","uniqId","safeUseId","uniqLabelId","concat","uniqDescriptionId","checkboxId","ariaLabel","useMemo","extractTextFrom","isLabelAriaHidden","canFocused","hasContent","singleLineClass","classes","undefined","onlyDescriptionClass","onlyDescription","React","createElement","tabIndex","StyledInput","_extends","type","StyledContentWrapper","htmlFor","StyledTriggerWrapper","StyledTrigger","checkboxTrigger","_Indeterminate","Indeterminate","_Done","Done","StyledContent","StyledLabel","StyledDescription","cx","checkboxConfig","name","tag","layout","base","variations","css","sizeCSS","viewCSS","disabledCSS","focusedCSS","defaults"],"mappings":"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"}
1
+ {"version":3,"file":"Checkbox.js","sources":["../../../src/components/Checkbox/Checkbox.tsx"],"sourcesContent":["import React, { forwardRef, useEffect, useMemo, useRef } from 'react';\nimport { safeUseId, useForkRef, extractTextFrom } from '@salutejs/plasma-core';\n\nimport type { RootProps } from '../../engines/types';\nimport { cx } from '../../utils';\n\nimport { base as viewCSS } from './variations/_view/base';\nimport { base as sizeCSS } from './variations/_size/base';\nimport { base as disabledCSS } from './variations/_disabled/base';\nimport { base as focusedCSS } from './variations/_focused/base';\nimport { Done, Indeterminate } from './IconsSvg';\nimport {\n StyledContent,\n StyledContentWrapper,\n StyledDescription,\n StyledInput,\n StyledLabel,\n StyledTrigger,\n base,\n StyledTriggerWrapper,\n} from './Checkbox.styles';\nimport type { CheckboxProps } from './Checkbox.types';\nimport { classes } from './Checkbox.tokens';\n\nexport const checkboxRoot = (Root: RootProps<HTMLInputElement, CheckboxProps>) =>\n forwardRef<HTMLInputElement, CheckboxProps>((props, ref) => {\n const {\n size,\n view,\n focused,\n disabled,\n id,\n label,\n description,\n indeterminate,\n style,\n className,\n singleLine = false,\n 'aria-label': ariaLabelExternal,\n ...rest\n } = props;\n\n const inputRef = useRef<HTMLInputElement | null>(null);\n const forkRef = useForkRef(inputRef, ref);\n\n useEffect(() => {\n if (inputRef.current && indeterminate) {\n inputRef.current.indeterminate = rest.checked === undefined ? Boolean(indeterminate) : rest.checked;\n }\n }, [inputRef, indeterminate]);\n\n const uniqId = safeUseId();\n const uniqLabelId = `label-${uniqId}`;\n const uniqDescriptionId = `description-${uniqId}`;\n const checkboxId = id || `input-${uniqId}`;\n\n const ariaLabel = useMemo(() => ariaLabelExternal || extractTextFrom(label), [ariaLabelExternal, label]);\n const isLabelAriaHidden = typeof label === 'string';\n const canFocused = focused ? 0 : -1;\n const hasContent = label || description;\n const singleLineClass = singleLine ? classes.singleLine : undefined;\n const onlyDescriptionClass = !label && description ? classes.onlyDescription : undefined;\n\n return (\n <Root\n view={view}\n size={size}\n disabled={disabled}\n focused={focused}\n style={style}\n className={className}\n tabIndex={-1}\n >\n <StyledInput\n {...rest}\n id={checkboxId}\n ref={forkRef}\n type=\"checkbox\"\n disabled={disabled}\n aria-label={ariaLabel}\n aria-describedby={uniqDescriptionId}\n tabIndex={canFocused}\n />\n <StyledContentWrapper htmlFor={checkboxId} className={singleLineClass}>\n <StyledTriggerWrapper>\n <StyledTrigger className={classes.checkboxTrigger}>\n {indeterminate ? <Indeterminate /> : <Done />}\n </StyledTrigger>\n </StyledTriggerWrapper>\n {hasContent && (\n <StyledContent className={singleLineClass}>\n {label && (\n <StyledLabel\n className={singleLineClass}\n id={uniqLabelId}\n aria-hidden={isLabelAriaHidden}\n >\n {label}\n </StyledLabel>\n )}\n {description && (\n <StyledDescription\n className={cx(singleLineClass, onlyDescriptionClass)}\n id={uniqDescriptionId}\n >\n {description}\n </StyledDescription>\n )}\n </StyledContent>\n )}\n </StyledContentWrapper>\n </Root>\n );\n });\n\nexport const checkboxConfig = {\n name: 'Checkbox',\n tag: 'div',\n layout: checkboxRoot,\n base,\n variations: {\n size: {\n css: sizeCSS,\n },\n view: {\n css: viewCSS,\n },\n disabled: {\n css: disabledCSS,\n },\n focused: {\n css: focusedCSS,\n },\n },\n defaults: {\n size: 'm',\n view: 'accent',\n },\n};\n"],"names":["checkboxRoot","Root","forwardRef","props","ref","size","view","focused","disabled","id","label","description","indeterminate","style","className","_props$singleLine","singleLine","ariaLabelExternal","rest","_objectWithoutProperties","_excluded","inputRef","useRef","forkRef","useForkRef","useEffect","current","checked","undefined","Boolean","uniqId","safeUseId","uniqLabelId","concat","uniqDescriptionId","checkboxId","ariaLabel","useMemo","extractTextFrom","isLabelAriaHidden","canFocused","hasContent","singleLineClass","classes","onlyDescriptionClass","onlyDescription","React","createElement","tabIndex","StyledInput","_extends","type","StyledContentWrapper","htmlFor","StyledTriggerWrapper","StyledTrigger","checkboxTrigger","_Indeterminate","Indeterminate","_Done","Done","StyledContent","StyledLabel","StyledDescription","cx","checkboxConfig","name","tag","layout","base","variations","css","sizeCSS","viewCSS","disabledCSS","focusedCSS","defaults"],"mappings":"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"}
@@ -4,7 +4,7 @@ import { cx } from '@linaria/core';
4
4
  import 'focus-visible';
5
5
  import { getIntersectionStyles, getStaticVariants, getDynamicVariants } from './utils.js';
6
6
 
7
- var _excluded = ["className"];
7
+ var _excluded = ["className", "as", "forwardedAs"];
8
8
  /* eslint-disable no-underscore-dangle */
9
9
  var _component = function _component(componentConfig) {
10
10
  var tag = componentConfig.tag,
@@ -13,9 +13,10 @@ var _component = function _component(componentConfig) {
13
13
  intersections = componentConfig.intersections;
14
14
  var staticVariants = getStaticVariants(componentConfig);
15
15
  var dynamicVariants = getDynamicVariants(componentConfig);
16
- var Root = tag;
17
16
  var component = /*#__PURE__*/forwardRef(function (props, ref) {
18
17
  var className = props.className,
18
+ as = props.as,
19
+ forwardedAs = props.forwardedAs,
19
20
  rest = _objectWithoutProperties(props, _excluded);
20
21
  var variants = dynamicVariants(rest);
21
22
  var intersectionStyles = getIntersectionStyles(rest, intersections);
@@ -43,6 +44,7 @@ var _component = function _component(componentConfig) {
43
44
  }
44
45
  }
45
46
  }
47
+ var Root = as || forwardedAs || tag;
46
48
  return /*#__PURE__*/React.createElement(Root, _extends({
47
49
  className: cls
48
50
  }, htmlAttrs, baseProps));
@@ -1 +1 @@
1
- {"version":3,"file":"linaria.js","sources":["../../src/engines/linaria.tsx"],"sourcesContent":["import React, { forwardRef } from 'react';\nimport { cx } from '@linaria/core';\n\n// TODO: #1008 Избавиться от импортов и переделать addFocus\nimport 'focus-visible';\nimport { getStaticVariants, getDynamicVariants, getIntersectionStyles } from './utils';\nimport type { ComponentConfig, HTMLAnyAttributes } from './types';\n\n/* eslint-disable no-underscore-dangle */\nexport const _component = (componentConfig: ComponentConfig) => {\n const { tag, base, name, intersections } = componentConfig;\n const staticVariants = getStaticVariants(componentConfig);\n const dynamicVariants = getDynamicVariants(componentConfig);\n\n const Root = tag as React.ElementType;\n\n const component = forwardRef<HTMLElement, HTMLAnyAttributes>((props, ref) => {\n const { className, ...rest } = props;\n const variants = dynamicVariants(rest);\n const intersectionStyles = getIntersectionStyles(rest, intersections);\n\n const cls = cx(className, base as string, ...(staticVariants as string[]), ...variants, ...intersectionStyles);\n\n // styled-components do it inside\n // filter props\n const baseProps: HTMLAnyAttributes = {};\n for (const key in rest) {\n if (!(key in componentConfig.variations)) {\n baseProps[key] = rest[key];\n }\n }\n\n baseProps.ref = ref;\n\n // styled-components do it inside\n // add props that should be attr( disabled for example)\n const htmlAttrs: HTMLAnyAttributes = {};\n for (const key in componentConfig.variations || {}) {\n if (key in rest) {\n const variant = componentConfig.variations[key];\n\n const { attrs } = variant;\n if (typeof attrs === 'boolean') {\n htmlAttrs[key] = rest[key];\n }\n }\n }\n\n return <Root className={cls} {...htmlAttrs} {...baseProps} />;\n });\n if (name) {\n component.displayName = name;\n }\n return component;\n};\n"],"names":["_component","componentConfig","tag","base","name","intersections","staticVariants","getStaticVariants","dynamicVariants","getDynamicVariants","Root","component","forwardRef","props","ref","className","rest","_objectWithoutProperties","_excluded","variants","intersectionStyles","getIntersectionStyles","cls","cx","apply","concat","_toConsumableArray","baseProps","key","variations","htmlAttrs","variant","attrs","React","createElement","_extends","displayName"],"mappings":";;;;;;;AAQA;IACaA,UAAU,GAAG,SAAbA,UAAUA,CAAIC,eAAgC,EAAK;AAC5D,EAAA,IAAQC,GAAG,GAAgCD,eAAe,CAAlDC,GAAG;IAAEC,IAAI,GAA0BF,eAAe,CAA7CE,IAAI;IAAEC,IAAI,GAAoBH,eAAe,CAAvCG,IAAI;IAAEC,aAAa,GAAKJ,eAAe,CAAjCI,aAAa,CAAA;AACtC,EAAA,IAAMC,cAAc,GAAGC,iBAAiB,CAACN,eAAe,CAAC,CAAA;AACzD,EAAA,IAAMO,eAAe,GAAGC,kBAAkB,CAACR,eAAe,CAAC,CAAA;EAE3D,IAAMS,IAAI,GAAGR,GAAwB,CAAA;EAErC,IAAMS,SAAS,gBAAGC,UAAU,CAAiC,UAACC,KAAK,EAAEC,GAAG,EAAK;AACzE,IAAA,IAAQC,SAAS,GAAcF,KAAK,CAA5BE,SAAS;AAAKC,MAAAA,IAAI,GAAAC,wBAAA,CAAKJ,KAAK,EAAAK,SAAA,CAAA,CAAA;AACpC,IAAA,IAAMC,QAAQ,GAAGX,eAAe,CAACQ,IAAI,CAAC,CAAA;AACtC,IAAA,IAAMI,kBAAkB,GAAGC,qBAAqB,CAACL,IAAI,EAAEX,aAAa,CAAC,CAAA;IAErE,IAAMiB,GAAG,GAAGC,EAAE,CAAAC,KAAA,CAACT,KAAAA,CAAAA,EAAAA,CAAAA,SAAS,EAAEZ,IAAI,CAAAsB,CAAAA,MAAA,CAAAC,kBAAA,CAAgBpB,cAAc,CAAA,EAAAoB,kBAAA,CAAkBP,QAAQ,CAAAO,EAAAA,kBAAA,CAAKN,kBAAkB,CAAC,CAAA,CAAA,CAAA;;AAE9G;AACA;IACA,IAAMO,SAA4B,GAAG,EAAE,CAAA;AACvC,IAAA,KAAK,IAAMC,GAAG,IAAIZ,IAAI,EAAE;AACpB,MAAA,IAAI,EAAEY,GAAG,IAAI3B,eAAe,CAAC4B,UAAU,CAAC,EAAE;AACtCF,QAAAA,SAAS,CAACC,GAAG,CAAC,GAAGZ,IAAI,CAACY,GAAG,CAAC,CAAA;AAC9B,OAAA;AACJ,KAAA;IAEAD,SAAS,CAACb,GAAG,GAAGA,GAAG,CAAA;;AAEnB;AACA;IACA,IAAMgB,SAA4B,GAAG,EAAE,CAAA;IACvC,KAAK,IAAMF,IAAG,IAAI3B,eAAe,CAAC4B,UAAU,IAAI,EAAE,EAAE;MAChD,IAAID,IAAG,IAAIZ,IAAI,EAAE;AACb,QAAA,IAAMe,OAAO,GAAG9B,eAAe,CAAC4B,UAAU,CAACD,IAAG,CAAC,CAAA;AAE/C,QAAA,IAAQI,KAAK,GAAKD,OAAO,CAAjBC,KAAK,CAAA;AACb,QAAA,IAAI,OAAOA,KAAK,KAAK,SAAS,EAAE;AAC5BF,UAAAA,SAAS,CAACF,IAAG,CAAC,GAAGZ,IAAI,CAACY,IAAG,CAAC,CAAA;AAC9B,SAAA;AACJ,OAAA;AACJ,KAAA;AAEA,IAAA,oBAAOK,KAAA,CAAAC,aAAA,CAACxB,IAAI,EAAAyB,QAAA,CAAA;AAACpB,MAAAA,SAAS,EAAEO,GAAAA;AAAI,KAAA,EAAKQ,SAAS,EAAMH,SAAS,CAAG,CAAC,CAAA;AACjE,GAAC,CAAC,CAAA;AACF,EAAA,IAAIvB,IAAI,EAAE;IACNO,SAAS,CAACyB,WAAW,GAAGhC,IAAI,CAAA;AAChC,GAAA;AACA,EAAA,OAAOO,SAAS,CAAA;AACpB;;;;"}
1
+ {"version":3,"file":"linaria.js","sources":["../../src/engines/linaria.tsx"],"sourcesContent":["import React, { forwardRef } from 'react';\nimport { cx } from '@linaria/core';\n\n// TODO: #1008 Избавиться от импортов и переделать addFocus\nimport 'focus-visible';\nimport { getStaticVariants, getDynamicVariants, getIntersectionStyles } from './utils';\nimport type { ComponentConfig, HTMLAnyAttributes } from './types';\n\n/* eslint-disable no-underscore-dangle */\nexport const _component = (componentConfig: ComponentConfig) => {\n const { tag, base, name, intersections } = componentConfig;\n const staticVariants = getStaticVariants(componentConfig);\n const dynamicVariants = getDynamicVariants(componentConfig);\n\n const component = forwardRef<HTMLElement, HTMLAnyAttributes>((props, ref) => {\n const { className, as, forwardedAs, ...rest } = props;\n const variants = dynamicVariants(rest);\n const intersectionStyles = getIntersectionStyles(rest, intersections);\n\n const cls = cx(className, base as string, ...(staticVariants as string[]), ...variants, ...intersectionStyles);\n\n // styled-components do it inside\n // filter props\n const baseProps: HTMLAnyAttributes = {};\n for (const key in rest) {\n if (!(key in componentConfig.variations)) {\n baseProps[key] = rest[key];\n }\n }\n\n baseProps.ref = ref;\n\n // styled-components do it inside\n // add props that should be attr( disabled for example)\n const htmlAttrs: HTMLAnyAttributes = {};\n for (const key in componentConfig.variations || {}) {\n if (key in rest) {\n const variant = componentConfig.variations[key];\n\n const { attrs } = variant;\n if (typeof attrs === 'boolean') {\n htmlAttrs[key] = rest[key];\n }\n }\n }\n\n const Root = as || forwardedAs || (tag as React.ElementType);\n\n return <Root className={cls} {...htmlAttrs} {...baseProps} />;\n });\n if (name) {\n component.displayName = name;\n }\n return component;\n};\n"],"names":["_component","componentConfig","tag","base","name","intersections","staticVariants","getStaticVariants","dynamicVariants","getDynamicVariants","component","forwardRef","props","ref","className","as","forwardedAs","rest","_objectWithoutProperties","_excluded","variants","intersectionStyles","getIntersectionStyles","cls","cx","apply","concat","_toConsumableArray","baseProps","key","variations","htmlAttrs","variant","attrs","Root","React","createElement","_extends","displayName"],"mappings":";;;;;;;AAQA;IACaA,UAAU,GAAG,SAAbA,UAAUA,CAAIC,eAAgC,EAAK;AAC5D,EAAA,IAAQC,GAAG,GAAgCD,eAAe,CAAlDC,GAAG;IAAEC,IAAI,GAA0BF,eAAe,CAA7CE,IAAI;IAAEC,IAAI,GAAoBH,eAAe,CAAvCG,IAAI;IAAEC,aAAa,GAAKJ,eAAe,CAAjCI,aAAa,CAAA;AACtC,EAAA,IAAMC,cAAc,GAAGC,iBAAiB,CAACN,eAAe,CAAC,CAAA;AACzD,EAAA,IAAMO,eAAe,GAAGC,kBAAkB,CAACR,eAAe,CAAC,CAAA;EAE3D,IAAMS,SAAS,gBAAGC,UAAU,CAAiC,UAACC,KAAK,EAAEC,GAAG,EAAK;AACzE,IAAA,IAAQC,SAAS,GAA+BF,KAAK,CAA7CE,SAAS;MAAEC,EAAE,GAA2BH,KAAK,CAAlCG,EAAE;MAAEC,WAAW,GAAcJ,KAAK,CAA9BI,WAAW;AAAKC,MAAAA,IAAI,GAAAC,wBAAA,CAAKN,KAAK,EAAAO,SAAA,CAAA,CAAA;AACrD,IAAA,IAAMC,QAAQ,GAAGZ,eAAe,CAACS,IAAI,CAAC,CAAA;AACtC,IAAA,IAAMI,kBAAkB,GAAGC,qBAAqB,CAACL,IAAI,EAAEZ,aAAa,CAAC,CAAA;IAErE,IAAMkB,GAAG,GAAGC,EAAE,CAAAC,KAAA,CAACX,KAAAA,CAAAA,EAAAA,CAAAA,SAAS,EAAEX,IAAI,CAAAuB,CAAAA,MAAA,CAAAC,kBAAA,CAAgBrB,cAAc,CAAA,EAAAqB,kBAAA,CAAkBP,QAAQ,CAAAO,EAAAA,kBAAA,CAAKN,kBAAkB,CAAC,CAAA,CAAA,CAAA;;AAE9G;AACA;IACA,IAAMO,SAA4B,GAAG,EAAE,CAAA;AACvC,IAAA,KAAK,IAAMC,GAAG,IAAIZ,IAAI,EAAE;AACpB,MAAA,IAAI,EAAEY,GAAG,IAAI5B,eAAe,CAAC6B,UAAU,CAAC,EAAE;AACtCF,QAAAA,SAAS,CAACC,GAAG,CAAC,GAAGZ,IAAI,CAACY,GAAG,CAAC,CAAA;AAC9B,OAAA;AACJ,KAAA;IAEAD,SAAS,CAACf,GAAG,GAAGA,GAAG,CAAA;;AAEnB;AACA;IACA,IAAMkB,SAA4B,GAAG,EAAE,CAAA;IACvC,KAAK,IAAMF,IAAG,IAAI5B,eAAe,CAAC6B,UAAU,IAAI,EAAE,EAAE;MAChD,IAAID,IAAG,IAAIZ,IAAI,EAAE;AACb,QAAA,IAAMe,OAAO,GAAG/B,eAAe,CAAC6B,UAAU,CAACD,IAAG,CAAC,CAAA;AAE/C,QAAA,IAAQI,KAAK,GAAKD,OAAO,CAAjBC,KAAK,CAAA;AACb,QAAA,IAAI,OAAOA,KAAK,KAAK,SAAS,EAAE;AAC5BF,UAAAA,SAAS,CAACF,IAAG,CAAC,GAAGZ,IAAI,CAACY,IAAG,CAAC,CAAA;AAC9B,SAAA;AACJ,OAAA;AACJ,KAAA;AAEA,IAAA,IAAMK,IAAI,GAAGnB,EAAE,IAAIC,WAAW,IAAKd,GAAyB,CAAA;AAE5D,IAAA,oBAAOiC,KAAA,CAAAC,aAAA,CAACF,IAAI,EAAAG,QAAA,CAAA;AAACvB,MAAAA,SAAS,EAAES,GAAAA;AAAI,KAAA,EAAKQ,SAAS,EAAMH,SAAS,CAAG,CAAC,CAAA;AACjE,GAAC,CAAC,CAAA;AACF,EAAA,IAAIxB,IAAI,EAAE;IACNM,SAAS,CAAC4B,WAAW,GAAGlC,IAAI,CAAA;AAChC,GAAA;AACA,EAAA,OAAOM,SAAS,CAAA;AACpB;;;;"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@salutejs/plasma-new-hope",
3
- "version": "0.317.0-canary.1880.14214278787.0",
3
+ "version": "0.317.0-canary.1885.14214031918.0",
4
4
  "description": "Salute Design System blueprint",
5
5
  "main": "cjs/index.js",
6
6
  "module": "es/index.js",
@@ -135,5 +135,5 @@
135
135
  "sideEffects": [
136
136
  "*.css"
137
137
  ],
138
- "gitHead": "78f90a1a287b1e1ba3ed06f75719a0728ba22cd2"
138
+ "gitHead": "312757b42933e4c49d691552e7d50dc56b84c15e"
139
139
  }
@@ -41,8 +41,8 @@ var checkboxRoot = exports.checkboxRoot = function checkboxRoot(Root) {
41
41
  var inputRef = (0, _react.useRef)(null);
42
42
  var forkRef = (0, _plasmaCore.useForkRef)(inputRef, ref);
43
43
  (0, _react.useEffect)(function () {
44
- if (inputRef.current) {
45
- inputRef.current.indeterminate = Boolean(indeterminate);
44
+ if (inputRef.current && indeterminate) {
45
+ inputRef.current.indeterminate = rest.checked === undefined ? Boolean(indeterminate) : rest.checked;
46
46
  }
47
47
  }, [inputRef, indeterminate]);
48
48
  var uniqId = (0, _plasmaCore.safeUseId)();
@@ -48,16 +48,3 @@ export function App() {
48
48
  );
49
49
  }
50
50
  ```
51
-
52
- Состояние `indeterminate` имеет приоритет и не зависит от свойства `checked`
53
-
54
- ```tsx live
55
- import React from 'react';
56
- import { Checkbox } from '@salutejs/{{ package }}';
57
-
58
- export function App() {
59
- return (
60
- <Checkbox label="Чекбокс" description="Описание" defaultChecked indeterminate checked={false} />
61
- );
62
- }
63
- ```
@@ -23,6 +23,22 @@ title: Typography
23
23
  По умолчанию в типографике если текст превышает ширину элемента, то слова будут переноситься по пробелам.
24
24
  Чтобы запретить перенос по пробелам, необходимо установить свойство `noWrap` в значении `true`.
25
25
 
26
+ ## Смена тега
27
+ Если при использовании компонентов необходимо сменить тег, то можно использовать свойство `as`:
28
+
29
+ ```tsx live
30
+ import React from 'react';
31
+ import { BodyM } from '@salutejs/{{ package }}';
32
+
33
+ export function App() {
34
+ return (
35
+ <BodyM as="h3">
36
+ BodyM
37
+ </BodyM>
38
+ );
39
+ }
40
+ ```
41
+
26
42
  ## Состав
27
43
 
28
44
  ### Hero unit
@@ -9,7 +9,7 @@ import { Body } from './Body';
9
9
  import { config } from './Body.config';
10
10
 
11
11
  const meta: Meta<typeof Body> = {
12
- title: 'Data Display/Typography/Body',
12
+ title: 'typography/Body',
13
13
  decorators: [WithTheme],
14
14
  component: Body,
15
15
  argTypes: {
@@ -19,6 +19,9 @@ const meta: Meta<typeof Body> = {
19
19
  type: 'color',
20
20
  },
21
21
  },
22
+ as: {
23
+ control: 'text',
24
+ },
22
25
  },
23
26
  args: {
24
27
  noWrap: false,
@@ -9,7 +9,7 @@ import { Dspl } from './Dspl';
9
9
  import { config } from './Dspl.config';
10
10
 
11
11
  const meta: Meta<typeof Dspl> = {
12
- title: 'Data Display/Typography/Dspl',
12
+ title: 'typography/Dspl',
13
13
  decorators: [WithTheme],
14
14
  component: Dspl,
15
15
  argTypes: {
@@ -19,6 +19,9 @@ const meta: Meta<typeof Dspl> = {
19
19
  type: 'color',
20
20
  },
21
21
  },
22
+ as: {
23
+ control: 'text',
24
+ },
22
25
  },
23
26
  args: {
24
27
  noWrap: false,