@salt-ds/core 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -0
- package/dist-cjs/node_modules/style-inject/dist/style-inject.es.js +31 -0
- package/dist-cjs/node_modules/style-inject/dist/style-inject.es.js.map +1 -0
- package/dist-cjs/packages/core/src/aria-announcer/AriaAnnounce.js +22 -0
- package/dist-cjs/packages/core/src/aria-announcer/AriaAnnounce.js.map +1 -0
- package/dist-cjs/packages/core/src/aria-announcer/AriaAnnouncerContext.js +12 -0
- package/dist-cjs/packages/core/src/aria-announcer/AriaAnnouncerContext.js.map +1 -0
- package/dist-cjs/packages/core/src/aria-announcer/AriaAnnouncerProvider.js +78 -0
- package/dist-cjs/packages/core/src/aria-announcer/AriaAnnouncerProvider.js.map +1 -0
- package/dist-cjs/packages/core/src/aria-announcer/useAriaAnnouncer.js +65 -0
- package/dist-cjs/packages/core/src/aria-announcer/useAriaAnnouncer.js.map +1 -0
- package/dist-cjs/packages/core/src/border-item/BorderItem.css.js +9 -0
- package/dist-cjs/packages/core/src/border-item/BorderItem.css.js.map +1 -0
- package/dist-cjs/packages/core/src/border-item/BorderItem.js +54 -0
- package/dist-cjs/packages/core/src/border-item/BorderItem.js.map +1 -0
- package/dist-cjs/packages/core/src/border-layout/BorderLayout.js +59 -0
- package/dist-cjs/packages/core/src/border-layout/BorderLayout.js.map +1 -0
- package/dist-cjs/packages/core/src/breakpoints/Breakpoints.js +15 -0
- package/dist-cjs/packages/core/src/breakpoints/Breakpoints.js.map +1 -0
- package/dist-cjs/packages/core/src/button/Button.css.js +9 -0
- package/dist-cjs/packages/core/src/button/Button.css.js.map +1 -0
- package/dist-cjs/packages/core/src/button/Button.js +60 -0
- package/dist-cjs/packages/core/src/button/Button.js.map +1 -0
- package/dist-cjs/packages/core/src/button/useButton.js +65 -0
- package/dist-cjs/packages/core/src/button/useButton.js.map +1 -0
- package/dist-cjs/packages/core/src/flex-item/FlexItem.css.js +9 -0
- package/dist-cjs/packages/core/src/flex-item/FlexItem.css.js.map +1 -0
- package/dist-cjs/packages/core/src/flex-item/FlexItem.js +56 -0
- package/dist-cjs/packages/core/src/flex-item/FlexItem.js.map +1 -0
- package/dist-cjs/packages/core/src/flex-layout/FlexLayout.css.js +9 -0
- package/dist-cjs/packages/core/src/flex-layout/FlexLayout.css.js.map +1 -0
- package/dist-cjs/packages/core/src/flex-layout/FlexLayout.js +77 -0
- package/dist-cjs/packages/core/src/flex-layout/FlexLayout.js.map +1 -0
- package/dist-cjs/packages/core/src/flow-layout/FlowLayout.js +21 -0
- package/dist-cjs/packages/core/src/flow-layout/FlowLayout.js.map +1 -0
- package/dist-cjs/packages/core/src/grid-item/GridItem.css.js +9 -0
- package/dist-cjs/packages/core/src/grid-item/GridItem.css.js.map +1 -0
- package/dist-cjs/packages/core/src/grid-item/GridItem.js +68 -0
- package/dist-cjs/packages/core/src/grid-item/GridItem.js.map +1 -0
- package/dist-cjs/packages/core/src/grid-layout/GridLayout.css.js +9 -0
- package/dist-cjs/packages/core/src/grid-layout/GridLayout.css.js.map +1 -0
- package/dist-cjs/packages/core/src/grid-layout/GridLayout.js +55 -0
- package/dist-cjs/packages/core/src/grid-layout/GridLayout.js.map +1 -0
- package/dist-cjs/packages/core/src/index.js +118 -0
- package/dist-cjs/packages/core/src/index.js.map +1 -0
- package/dist-cjs/packages/core/src/link/Link.css.js +9 -0
- package/dist-cjs/packages/core/src/link/Link.css.js.map +1 -0
- package/dist-cjs/packages/core/src/link/Link.js +60 -0
- package/dist-cjs/packages/core/src/link/Link.js.map +1 -0
- package/dist-cjs/packages/core/src/salt-provider/SaltProvider.css.js +9 -0
- package/dist-cjs/packages/core/src/salt-provider/SaltProvider.css.js.map +1 -0
- package/dist-cjs/packages/core/src/salt-provider/SaltProvider.js +158 -0
- package/dist-cjs/packages/core/src/salt-provider/SaltProvider.js.map +1 -0
- package/dist-cjs/packages/core/src/stack-layout/StackLayout.js +20 -0
- package/dist-cjs/packages/core/src/stack-layout/StackLayout.js.map +1 -0
- package/dist-cjs/packages/core/src/status-indicator/StatusIndicator.css.js +9 -0
- package/dist-cjs/packages/core/src/status-indicator/StatusIndicator.css.js.map +1 -0
- package/dist-cjs/packages/core/src/status-indicator/StatusIndicator.js +47 -0
- package/dist-cjs/packages/core/src/status-indicator/StatusIndicator.js.map +1 -0
- package/dist-cjs/packages/core/src/status-indicator/ValidationStatus.js +13 -0
- package/dist-cjs/packages/core/src/status-indicator/ValidationStatus.js.map +1 -0
- package/dist-cjs/packages/core/src/text/Display.js +50 -0
- package/dist-cjs/packages/core/src/text/Display.js.map +1 -0
- package/dist-cjs/packages/core/src/text/Headings.js +54 -0
- package/dist-cjs/packages/core/src/text/Headings.js.map +1 -0
- package/dist-cjs/packages/core/src/text/Label.js +19 -0
- package/dist-cjs/packages/core/src/text/Label.js.map +1 -0
- package/dist-cjs/packages/core/src/text/Text.css.js +9 -0
- package/dist-cjs/packages/core/src/text/Text.css.js.map +1 -0
- package/dist-cjs/packages/core/src/text/Text.js +47 -0
- package/dist-cjs/packages/core/src/text/Text.js.map +1 -0
- package/dist-cjs/packages/core/src/theme/Density.js +8 -0
- package/dist-cjs/packages/core/src/theme/Density.js.map +1 -0
- package/dist-cjs/packages/core/src/theme/Mode.js +8 -0
- package/dist-cjs/packages/core/src/theme/Mode.js.map +1 -0
- package/dist-cjs/packages/core/src/theme/Theme.js +19 -0
- package/dist-cjs/packages/core/src/theme/Theme.js.map +1 -0
- package/dist-cjs/packages/core/src/utils/createChainedFunction.js +22 -0
- package/dist-cjs/packages/core/src/utils/createChainedFunction.js.map +1 -0
- package/dist-cjs/packages/core/src/utils/createContext.js +16 -0
- package/dist-cjs/packages/core/src/utils/createContext.js.map +1 -0
- package/dist-cjs/packages/core/src/utils/debounce.js +24 -0
- package/dist-cjs/packages/core/src/utils/debounce.js.map +1 -0
- package/dist-cjs/packages/core/src/utils/makePrefixer.js +8 -0
- package/dist-cjs/packages/core/src/utils/makePrefixer.js.map +1 -0
- package/dist-cjs/packages/core/src/utils/marginMiddleware.js +22 -0
- package/dist-cjs/packages/core/src/utils/marginMiddleware.js.map +1 -0
- package/dist-cjs/packages/core/src/utils/ownerDocument.js +10 -0
- package/dist-cjs/packages/core/src/utils/ownerDocument.js.map +1 -0
- package/dist-cjs/packages/core/src/utils/ownerWindow.js +13 -0
- package/dist-cjs/packages/core/src/utils/ownerWindow.js.map +1 -0
- package/dist-cjs/packages/core/src/utils/setRef.js +14 -0
- package/dist-cjs/packages/core/src/utils/setRef.js.map +1 -0
- package/dist-cjs/packages/core/src/utils/useControlled.js +60 -0
- package/dist-cjs/packages/core/src/utils/useControlled.js.map +1 -0
- package/dist-cjs/packages/core/src/utils/useForkRef.js +21 -0
- package/dist-cjs/packages/core/src/utils/useForkRef.js.map +1 -0
- package/dist-cjs/packages/core/src/utils/useId.js +55 -0
- package/dist-cjs/packages/core/src/utils/useId.js.map +1 -0
- package/dist-cjs/packages/core/src/utils/useIsFocusVisible.js +108 -0
- package/dist-cjs/packages/core/src/utils/useIsFocusVisible.js.map +1 -0
- package/dist-cjs/packages/core/src/utils/useIsomorphicLayoutEffect.js +10 -0
- package/dist-cjs/packages/core/src/utils/useIsomorphicLayoutEffect.js.map +1 -0
- package/dist-cjs/packages/core/src/utils/usePrevious.js +16 -0
- package/dist-cjs/packages/core/src/utils/usePrevious.js.map +1 -0
- package/dist-cjs/packages/core/src/utils/useResponsiveProp.js +71 -0
- package/dist-cjs/packages/core/src/utils/useResponsiveProp.js.map +1 -0
- package/dist-cjs/packages/core/src/viewport/ViewportProvider.js +43 -0
- package/dist-cjs/packages/core/src/viewport/ViewportProvider.js.map +1 -0
- package/dist-es/node_modules/style-inject/dist/style-inject.es.js +29 -0
- package/dist-es/node_modules/style-inject/dist/style-inject.es.js.map +1 -0
- package/dist-es/packages/core/src/aria-announcer/AriaAnnounce.js +18 -0
- package/dist-es/packages/core/src/aria-announcer/AriaAnnounce.js.map +1 -0
- package/dist-es/packages/core/src/aria-announcer/AriaAnnouncerContext.js +8 -0
- package/dist-es/packages/core/src/aria-announcer/AriaAnnouncerContext.js.map +1 -0
- package/dist-es/packages/core/src/aria-announcer/AriaAnnouncerProvider.js +73 -0
- package/dist-es/packages/core/src/aria-announcer/AriaAnnouncerProvider.js.map +1 -0
- package/dist-es/packages/core/src/aria-announcer/useAriaAnnouncer.js +61 -0
- package/dist-es/packages/core/src/aria-announcer/useAriaAnnouncer.js.map +1 -0
- package/dist-es/packages/core/src/border-item/BorderItem.css.js +7 -0
- package/dist-es/packages/core/src/border-item/BorderItem.css.js.map +1 -0
- package/dist-es/packages/core/src/border-item/BorderItem.js +45 -0
- package/dist-es/packages/core/src/border-item/BorderItem.js.map +1 -0
- package/dist-es/packages/core/src/border-layout/BorderLayout.js +51 -0
- package/dist-es/packages/core/src/border-layout/BorderLayout.js.map +1 -0
- package/dist-es/packages/core/src/breakpoints/Breakpoints.js +11 -0
- package/dist-es/packages/core/src/breakpoints/Breakpoints.js.map +1 -0
- package/dist-es/packages/core/src/button/Button.css.js +7 -0
- package/dist-es/packages/core/src/button/Button.css.js.map +1 -0
- package/dist-es/packages/core/src/button/Button.js +51 -0
- package/dist-es/packages/core/src/button/Button.js.map +1 -0
- package/dist-es/packages/core/src/button/useButton.js +61 -0
- package/dist-es/packages/core/src/button/useButton.js.map +1 -0
- package/dist-es/packages/core/src/flex-item/FlexItem.css.js +7 -0
- package/dist-es/packages/core/src/flex-item/FlexItem.css.js.map +1 -0
- package/dist-es/packages/core/src/flex-item/FlexItem.js +47 -0
- package/dist-es/packages/core/src/flex-item/FlexItem.js.map +1 -0
- package/dist-es/packages/core/src/flex-layout/FlexLayout.css.js +7 -0
- package/dist-es/packages/core/src/flex-layout/FlexLayout.css.js.map +1 -0
- package/dist-es/packages/core/src/flex-layout/FlexLayout.js +67 -0
- package/dist-es/packages/core/src/flex-layout/FlexLayout.js.map +1 -0
- package/dist-es/packages/core/src/flow-layout/FlowLayout.js +17 -0
- package/dist-es/packages/core/src/flow-layout/FlowLayout.js.map +1 -0
- package/dist-es/packages/core/src/grid-item/GridItem.css.js +7 -0
- package/dist-es/packages/core/src/grid-item/GridItem.css.js.map +1 -0
- package/dist-es/packages/core/src/grid-item/GridItem.js +59 -0
- package/dist-es/packages/core/src/grid-item/GridItem.js.map +1 -0
- package/dist-es/packages/core/src/grid-layout/GridLayout.css.js +7 -0
- package/dist-es/packages/core/src/grid-layout/GridLayout.css.js.map +1 -0
- package/dist-es/packages/core/src/grid-layout/GridLayout.js +47 -0
- package/dist-es/packages/core/src/grid-layout/GridLayout.js.map +1 -0
- package/dist-es/packages/core/src/index.js +43 -0
- package/dist-es/packages/core/src/index.js.map +1 -0
- package/dist-es/packages/core/src/link/Link.css.js +7 -0
- package/dist-es/packages/core/src/link/Link.css.js.map +1 -0
- package/dist-es/packages/core/src/link/Link.js +52 -0
- package/dist-es/packages/core/src/link/Link.js.map +1 -0
- package/dist-es/packages/core/src/salt-provider/SaltProvider.css.js +7 -0
- package/dist-es/packages/core/src/salt-provider/SaltProvider.css.js.map +1 -0
- package/dist-es/packages/core/src/salt-provider/SaltProvider.js +142 -0
- package/dist-es/packages/core/src/salt-provider/SaltProvider.js.map +1 -0
- package/dist-es/packages/core/src/stack-layout/StackLayout.js +16 -0
- package/dist-es/packages/core/src/stack-layout/StackLayout.js.map +1 -0
- package/dist-es/packages/core/src/status-indicator/StatusIndicator.css.js +7 -0
- package/dist-es/packages/core/src/status-indicator/StatusIndicator.css.js.map +1 -0
- package/dist-es/packages/core/src/status-indicator/StatusIndicator.js +39 -0
- package/dist-es/packages/core/src/status-indicator/StatusIndicator.js.map +1 -0
- package/dist-es/packages/core/src/status-indicator/ValidationStatus.js +9 -0
- package/dist-es/packages/core/src/status-indicator/ValidationStatus.js.map +1 -0
- package/dist-es/packages/core/src/text/Display.js +40 -0
- package/dist-es/packages/core/src/text/Display.js.map +1 -0
- package/dist-es/packages/core/src/text/Headings.js +47 -0
- package/dist-es/packages/core/src/text/Headings.js.map +1 -0
- package/dist-es/packages/core/src/text/Label.js +15 -0
- package/dist-es/packages/core/src/text/Label.js.map +1 -0
- package/dist-es/packages/core/src/text/Text.css.js +7 -0
- package/dist-es/packages/core/src/text/Text.css.js.map +1 -0
- package/dist-es/packages/core/src/text/Text.js +39 -0
- package/dist-es/packages/core/src/text/Text.js.map +1 -0
- package/dist-es/packages/core/src/theme/Density.js +4 -0
- package/dist-es/packages/core/src/theme/Density.js.map +1 -0
- package/dist-es/packages/core/src/theme/Mode.js +4 -0
- package/dist-es/packages/core/src/theme/Mode.js.map +1 -0
- package/dist-es/packages/core/src/theme/Theme.js +15 -0
- package/dist-es/packages/core/src/theme/Theme.js.map +1 -0
- package/dist-es/packages/core/src/utils/createChainedFunction.js +18 -0
- package/dist-es/packages/core/src/utils/createChainedFunction.js.map +1 -0
- package/dist-es/packages/core/src/utils/createContext.js +12 -0
- package/dist-es/packages/core/src/utils/createContext.js.map +1 -0
- package/dist-es/packages/core/src/utils/debounce.js +20 -0
- package/dist-es/packages/core/src/utils/debounce.js.map +1 -0
- package/dist-es/packages/core/src/utils/makePrefixer.js +4 -0
- package/dist-es/packages/core/src/utils/makePrefixer.js.map +1 -0
- package/dist-es/packages/core/src/utils/marginMiddleware.js +18 -0
- package/dist-es/packages/core/src/utils/marginMiddleware.js.map +1 -0
- package/dist-es/packages/core/src/utils/ownerDocument.js +6 -0
- package/dist-es/packages/core/src/utils/ownerDocument.js.map +1 -0
- package/dist-es/packages/core/src/utils/ownerWindow.js +9 -0
- package/dist-es/packages/core/src/utils/ownerWindow.js.map +1 -0
- package/dist-es/packages/core/src/utils/setRef.js +10 -0
- package/dist-es/packages/core/src/utils/setRef.js.map +1 -0
- package/dist-es/packages/core/src/utils/useControlled.js +56 -0
- package/dist-es/packages/core/src/utils/useControlled.js.map +1 -0
- package/dist-es/packages/core/src/utils/useForkRef.js +17 -0
- package/dist-es/packages/core/src/utils/useForkRef.js.map +1 -0
- package/dist-es/packages/core/src/utils/useId.js +30 -0
- package/dist-es/packages/core/src/utils/useId.js.map +1 -0
- package/dist-es/packages/core/src/utils/useIsFocusVisible.js +103 -0
- package/dist-es/packages/core/src/utils/useIsFocusVisible.js.map +1 -0
- package/dist-es/packages/core/src/utils/useIsomorphicLayoutEffect.js +6 -0
- package/dist-es/packages/core/src/utils/useIsomorphicLayoutEffect.js.map +1 -0
- package/dist-es/packages/core/src/utils/usePrevious.js +12 -0
- package/dist-es/packages/core/src/utils/usePrevious.js.map +1 -0
- package/dist-es/packages/core/src/utils/useResponsiveProp.js +64 -0
- package/dist-es/packages/core/src/utils/useResponsiveProp.js.map +1 -0
- package/dist-es/packages/core/src/viewport/ViewportProvider.js +37 -0
- package/dist-es/packages/core/src/viewport/ViewportProvider.js.map +1 -0
- package/dist-types/aria-announcer/AriaAnnounce.d.ts +8 -0
- package/dist-types/aria-announcer/AriaAnnouncerContext.d.ts +6 -0
- package/dist-types/aria-announcer/AriaAnnouncerProvider.d.ts +10 -0
- package/dist-types/aria-announcer/index.d.ts +4 -0
- package/dist-types/aria-announcer/useAriaAnnouncer.d.ts +6 -0
- package/dist-types/border-item/BorderItem.d.ts +27 -0
- package/dist-types/border-item/index.d.ts +1 -0
- package/dist-types/border-layout/BorderLayout.d.ts +25 -0
- package/dist-types/border-layout/index.d.ts +1 -0
- package/dist-types/breakpoints/Breakpoints.d.ts +8 -0
- package/dist-types/breakpoints/index.d.ts +1 -0
- package/dist-types/button/Button.d.ts +20 -0
- package/dist-types/button/index.d.ts +2 -0
- package/dist-types/button/useButton.d.ts +22 -0
- package/dist-types/flex-item/FlexItem.d.ts +23 -0
- package/dist-types/flex-item/index.d.ts +1 -0
- package/dist-types/flex-layout/FlexLayout.d.ts +38 -0
- package/dist-types/flex-layout/index.d.ts +1 -0
- package/dist-types/flow-layout/FlowLayout.d.ts +17 -0
- package/dist-types/flow-layout/index.d.ts +1 -0
- package/dist-types/grid-item/GridItem.d.ts +27 -0
- package/dist-types/grid-item/index.d.ts +1 -0
- package/dist-types/grid-layout/GridLayout.d.ts +28 -0
- package/dist-types/grid-layout/index.d.ts +1 -0
- package/dist-types/index.d.ts +18 -0
- package/dist-types/link/Link.d.ts +14 -0
- package/dist-types/link/index.d.ts +1 -0
- package/dist-types/salt-provider/SaltProvider.d.ts +39 -0
- package/dist-types/salt-provider/index.d.ts +1 -0
- package/dist-types/stack-layout/StackLayout.d.ts +17 -0
- package/dist-types/stack-layout/index.d.ts +1 -0
- package/dist-types/status-indicator/StatusIndicator.d.ts +11 -0
- package/dist-types/status-indicator/ValidationStatus.d.ts +2 -0
- package/dist-types/status-indicator/index.d.ts +2 -0
- package/dist-types/text/Display.d.ts +5 -0
- package/dist-types/text/Headings.d.ts +6 -0
- package/dist-types/text/Label.d.ts +3 -0
- package/dist-types/text/Text.d.ts +20 -0
- package/dist-types/text/index.d.ts +4 -0
- package/dist-types/theme/Density.d.ts +2 -0
- package/dist-types/theme/Mode.d.ts +2 -0
- package/dist-types/theme/Theme.d.ts +3 -0
- package/dist-types/theme/index.d.ts +3 -0
- package/dist-types/utils/createChainedFunction.d.ts +3 -0
- package/dist-types/utils/createContext.d.ts +2 -0
- package/dist-types/utils/debounce.d.ts +4 -0
- package/dist-types/utils/index.d.ts +17 -0
- package/dist-types/utils/inferElementType.d.ts +2 -0
- package/dist-types/utils/makePrefixer.d.ts +2 -0
- package/dist-types/utils/marginMiddleware.d.ts +2 -0
- package/dist-types/utils/ownerDocument.d.ts +1 -0
- package/dist-types/utils/ownerWindow.d.ts +1 -0
- package/dist-types/utils/polymorphicTypes.d.ts +14 -0
- package/dist-types/utils/setRef.d.ts +2 -0
- package/dist-types/utils/useControlled.d.ts +24 -0
- package/dist-types/utils/useForkRef.d.ts +2 -0
- package/dist-types/utils/useId.d.ts +2 -0
- package/dist-types/utils/useIsFocusVisible.d.ts +8 -0
- package/dist-types/utils/useIsomorphicLayoutEffect.d.ts +2 -0
- package/dist-types/utils/usePrevious.d.ts +2 -0
- package/dist-types/utils/useResponsiveProp.d.ts +10 -0
- package/dist-types/viewport/ViewportProvider.d.ts +8 -0
- package/dist-types/viewport/index.d.ts +1 -0
- package/package.json +40 -0
|
@@ -0,0 +1,158 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
6
|
+
var cx = require('classnames');
|
|
7
|
+
var React = require('react');
|
|
8
|
+
require('../aria-announcer/AriaAnnouncerContext.js');
|
|
9
|
+
require('../utils/useId.js');
|
|
10
|
+
var useIsomorphicLayoutEffect = require('../utils/useIsomorphicLayoutEffect.js');
|
|
11
|
+
var ViewportProvider = require('../viewport/ViewportProvider.js');
|
|
12
|
+
var AriaAnnouncerProvider = require('../aria-announcer/AriaAnnouncerProvider.js');
|
|
13
|
+
var Breakpoints = require('../breakpoints/Breakpoints.js');
|
|
14
|
+
require('./SaltProvider.css.js');
|
|
15
|
+
|
|
16
|
+
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
17
|
+
|
|
18
|
+
var cx__default = /*#__PURE__*/_interopDefaultLegacy(cx);
|
|
19
|
+
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
20
|
+
|
|
21
|
+
const DEFAULT_DENSITY = "medium";
|
|
22
|
+
const DEFAULT_THEME_NAME = "salt-theme";
|
|
23
|
+
const DEFAULT_MODE = "light";
|
|
24
|
+
const DensityContext = React.createContext(DEFAULT_DENSITY);
|
|
25
|
+
const ThemeContext = React.createContext({
|
|
26
|
+
theme: "",
|
|
27
|
+
mode: DEFAULT_MODE
|
|
28
|
+
});
|
|
29
|
+
const BreakpointContext = React.createContext(Breakpoints.DEFAULT_BREAKPOINTS);
|
|
30
|
+
const createThemedChildren = (children, themeName, density, mode, applyClassesTo) => {
|
|
31
|
+
var _a;
|
|
32
|
+
const themeNames = themeName === DEFAULT_THEME_NAME ? [DEFAULT_THEME_NAME] : [DEFAULT_THEME_NAME, themeName];
|
|
33
|
+
if (applyClassesTo === "root") {
|
|
34
|
+
return children;
|
|
35
|
+
} else if (applyClassesTo === "child") {
|
|
36
|
+
if (React__default["default"].isValidElement(children)) {
|
|
37
|
+
return React__default["default"].cloneElement(children, {
|
|
38
|
+
className: cx__default["default"](
|
|
39
|
+
(_a = children.props) == null ? void 0 : _a.className,
|
|
40
|
+
...themeNames,
|
|
41
|
+
`salt-density-${density}`
|
|
42
|
+
),
|
|
43
|
+
"data-mode": mode
|
|
44
|
+
});
|
|
45
|
+
} else {
|
|
46
|
+
console.warn(
|
|
47
|
+
`
|
|
48
|
+
SaltProvider can only apply CSS classes for theming to a single nested child element of the SaltProvider.
|
|
49
|
+
Either wrap elements with a single container or consider removing the applyClassesToChild prop, in which case a
|
|
50
|
+
div element will wrap your child elements`
|
|
51
|
+
);
|
|
52
|
+
return children;
|
|
53
|
+
}
|
|
54
|
+
} else {
|
|
55
|
+
return /* @__PURE__ */ jsxRuntime.jsx("div", {
|
|
56
|
+
className: cx__default["default"](
|
|
57
|
+
`salt-provider`,
|
|
58
|
+
...themeNames,
|
|
59
|
+
`salt-density-${density}`
|
|
60
|
+
),
|
|
61
|
+
"data-mode": mode,
|
|
62
|
+
children
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
};
|
|
66
|
+
function SaltProvider({
|
|
67
|
+
applyClassesTo: applyClassesToProp,
|
|
68
|
+
children,
|
|
69
|
+
density: densityProp,
|
|
70
|
+
theme: themeProp,
|
|
71
|
+
mode: modeProp,
|
|
72
|
+
breakpoints: breakpointsProp
|
|
73
|
+
}) {
|
|
74
|
+
var _a;
|
|
75
|
+
const inheritedDensity = React.useContext(DensityContext);
|
|
76
|
+
const { theme: inheritedThemes, mode: inheritedMode } = useTheme();
|
|
77
|
+
const isRoot = inheritedThemes === void 0 || inheritedThemes === "";
|
|
78
|
+
const density = (_a = densityProp != null ? densityProp : inheritedDensity) != null ? _a : DEFAULT_DENSITY;
|
|
79
|
+
const themeName = themeProp != null ? themeProp : inheritedThemes === "" ? DEFAULT_THEME_NAME : inheritedThemes;
|
|
80
|
+
const mode = modeProp != null ? modeProp : inheritedMode;
|
|
81
|
+
const breakpoints = breakpointsProp != null ? breakpointsProp : Breakpoints.DEFAULT_BREAKPOINTS;
|
|
82
|
+
const applyClassesTo = applyClassesToProp != null ? applyClassesToProp : isRoot ? "root" : "scope";
|
|
83
|
+
const themeContextValue = React.useMemo(
|
|
84
|
+
() => ({ theme: themeName, mode }),
|
|
85
|
+
[themeName, mode]
|
|
86
|
+
);
|
|
87
|
+
const themedChildren = createThemedChildren(
|
|
88
|
+
children,
|
|
89
|
+
themeName,
|
|
90
|
+
density,
|
|
91
|
+
mode,
|
|
92
|
+
applyClassesTo
|
|
93
|
+
);
|
|
94
|
+
useIsomorphicLayoutEffect.useIsomorphicLayoutEffect(() => {
|
|
95
|
+
const themeNames = themeName === DEFAULT_THEME_NAME ? [DEFAULT_THEME_NAME] : [DEFAULT_THEME_NAME, themeName];
|
|
96
|
+
if (applyClassesTo === "root") {
|
|
97
|
+
if (isRoot) {
|
|
98
|
+
document.documentElement.classList.add(
|
|
99
|
+
...themeNames,
|
|
100
|
+
`salt-density-${density}`
|
|
101
|
+
);
|
|
102
|
+
document.documentElement.dataset.mode = mode;
|
|
103
|
+
} else {
|
|
104
|
+
console.warn(
|
|
105
|
+
"\nSaltProvider can only apply CSS classes to the root if it is the root level SaltProvider."
|
|
106
|
+
);
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
return () => {
|
|
110
|
+
if (applyClassesTo === "root") {
|
|
111
|
+
document.documentElement.classList.remove(
|
|
112
|
+
...themeNames,
|
|
113
|
+
`salt-density-${density}`
|
|
114
|
+
);
|
|
115
|
+
document.documentElement.dataset.mode = void 0;
|
|
116
|
+
}
|
|
117
|
+
};
|
|
118
|
+
}, [applyClassesTo, density, isRoot, mode, themeName]);
|
|
119
|
+
const saltProvider = /* @__PURE__ */ jsxRuntime.jsx(DensityContext.Provider, {
|
|
120
|
+
value: density,
|
|
121
|
+
children: /* @__PURE__ */ jsxRuntime.jsx(ThemeContext.Provider, {
|
|
122
|
+
value: themeContextValue,
|
|
123
|
+
children: /* @__PURE__ */ jsxRuntime.jsx(BreakpointContext.Provider, {
|
|
124
|
+
value: breakpoints,
|
|
125
|
+
children: /* @__PURE__ */ jsxRuntime.jsx(ViewportProvider.ViewportProvider, {
|
|
126
|
+
children: themedChildren
|
|
127
|
+
})
|
|
128
|
+
})
|
|
129
|
+
})
|
|
130
|
+
});
|
|
131
|
+
if (isRoot) {
|
|
132
|
+
return /* @__PURE__ */ jsxRuntime.jsx(AriaAnnouncerProvider.AriaAnnouncerProvider, {
|
|
133
|
+
children: saltProvider
|
|
134
|
+
});
|
|
135
|
+
} else {
|
|
136
|
+
return saltProvider;
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
const useTheme = () => {
|
|
140
|
+
return React.useContext(ThemeContext);
|
|
141
|
+
};
|
|
142
|
+
function useDensity(density) {
|
|
143
|
+
const densityFromContext = React.useContext(DensityContext);
|
|
144
|
+
return density || densityFromContext || DEFAULT_DENSITY;
|
|
145
|
+
}
|
|
146
|
+
const useBreakpoints = () => {
|
|
147
|
+
return React.useContext(BreakpointContext);
|
|
148
|
+
};
|
|
149
|
+
|
|
150
|
+
exports.BreakpointContext = BreakpointContext;
|
|
151
|
+
exports.DEFAULT_DENSITY = DEFAULT_DENSITY;
|
|
152
|
+
exports.DensityContext = DensityContext;
|
|
153
|
+
exports.SaltProvider = SaltProvider;
|
|
154
|
+
exports.ThemeContext = ThemeContext;
|
|
155
|
+
exports.useBreakpoints = useBreakpoints;
|
|
156
|
+
exports.useDensity = useDensity;
|
|
157
|
+
exports.useTheme = useTheme;
|
|
158
|
+
//# sourceMappingURL=SaltProvider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SaltProvider.js","sources":["../src/salt-provider/SaltProvider.tsx"],"sourcesContent":["import cx from \"classnames\";\nimport React, {\n createContext,\n HTMLAttributes,\n ReactElement,\n ReactNode,\n useContext,\n useMemo,\n} from \"react\";\nimport { AriaAnnouncerProvider } from \"../aria-announcer\";\nimport { Breakpoints, DEFAULT_BREAKPOINTS } from \"../breakpoints\";\nimport { Density, Mode, ThemeName } from \"../theme\";\nimport { ViewportProvider } from \"../viewport\";\nimport { useIsomorphicLayoutEffect } from \"../utils\";\n\nimport \"./SaltProvider.css\";\n\nexport const DEFAULT_DENSITY = \"medium\";\n\nconst DEFAULT_THEME_NAME = \"salt-theme\";\n\nconst DEFAULT_MODE = \"light\";\n\nexport interface ThemeContextProps {\n theme: ThemeName;\n mode: Mode;\n}\n\nexport const DensityContext = createContext<Density>(DEFAULT_DENSITY);\n\nexport const ThemeContext = createContext<ThemeContextProps>({\n theme: \"\",\n mode: DEFAULT_MODE,\n});\n\nexport const BreakpointContext =\n createContext<Breakpoints>(DEFAULT_BREAKPOINTS);\n\nconst createThemedChildren = (\n children: ReactNode,\n themeName: ThemeName,\n density: Density,\n mode: Mode,\n applyClassesTo?: TargetElement\n) => {\n const themeNames =\n themeName === DEFAULT_THEME_NAME\n ? [DEFAULT_THEME_NAME]\n : [DEFAULT_THEME_NAME, themeName];\n if (applyClassesTo === \"root\") {\n return children;\n } else if (applyClassesTo === \"child\") {\n if (React.isValidElement<HTMLAttributes<HTMLElement>>(children)) {\n return React.cloneElement(children, {\n className: cx(\n children.props?.className,\n ...themeNames,\n `salt-density-${density}`\n ),\n // @ts-ignore\n \"data-mode\": mode,\n });\n } else {\n console.warn(\n `\\nSaltProvider can only apply CSS classes for theming to a single nested child element of the SaltProvider.\n Either wrap elements with a single container or consider removing the applyClassesToChild prop, in which case a\n div element will wrap your child elements`\n );\n return children;\n }\n } else {\n return (\n <div\n className={cx(\n `salt-provider`,\n ...themeNames,\n `salt-density-${density}`\n )}\n data-mode={mode}\n >\n {children}\n </div>\n );\n }\n};\n\ntype TargetElement = \"root\" | \"scope\" | \"child\";\n\ntype SaltProviderBaseProps = {\n applyClassesTo?: TargetElement;\n density?: Density;\n theme?: ThemeName;\n mode?: Mode;\n breakpoints?: Breakpoints;\n};\n\ninterface SaltProviderThatAppliesClassesToChild extends SaltProviderBaseProps {\n children: ReactElement;\n applyClassesTo: \"child\";\n}\n\ninterface SaltProviderThatInjectsThemeElement extends SaltProviderBaseProps {\n children: ReactNode;\n}\n\ninterface SaltProviderThatClassesToRoot\n extends SaltProviderThatInjectsThemeElement {\n applyClassesTo: \"root\";\n}\n\ntype SaltProviderProps =\n | SaltProviderThatAppliesClassesToChild\n | SaltProviderThatInjectsThemeElement\n | SaltProviderThatClassesToRoot;\n\nexport function SaltProvider({\n applyClassesTo: applyClassesToProp,\n children,\n density: densityProp,\n theme: themeProp,\n mode: modeProp,\n breakpoints: breakpointsProp,\n}: SaltProviderProps) {\n const inheritedDensity = useContext(DensityContext);\n const { theme: inheritedThemes, mode: inheritedMode } = useTheme();\n\n const isRoot = inheritedThemes === undefined || inheritedThemes === \"\";\n const density = densityProp ?? inheritedDensity ?? DEFAULT_DENSITY;\n const themeName =\n themeProp ??\n (inheritedThemes === \"\" ? DEFAULT_THEME_NAME : inheritedThemes);\n const mode = modeProp ?? inheritedMode;\n const breakpoints = breakpointsProp ?? DEFAULT_BREAKPOINTS;\n\n const applyClassesTo = applyClassesToProp ?? (isRoot ? \"root\" : \"scope\");\n\n const themeContextValue = useMemo(\n () => ({ theme: themeName, mode }),\n [themeName, mode]\n );\n\n const themedChildren = createThemedChildren(\n children,\n themeName,\n density,\n mode,\n applyClassesTo\n );\n\n useIsomorphicLayoutEffect(() => {\n const themeNames =\n themeName === DEFAULT_THEME_NAME\n ? [DEFAULT_THEME_NAME]\n : [DEFAULT_THEME_NAME, themeName];\n if (applyClassesTo === \"root\") {\n if (isRoot) {\n // add the styles we want to apply\n document.documentElement.classList.add(\n ...themeNames,\n `salt-density-${density}`\n );\n document.documentElement.dataset.mode = mode;\n } else {\n console.warn(\n \"\\nSaltProvider can only apply CSS classes to the root if it is the root level SaltProvider.\"\n );\n }\n }\n return () => {\n if (applyClassesTo === \"root\") {\n // When unmounting/remounting, remove the applied styles from the root\n document.documentElement.classList.remove(\n ...themeNames,\n `salt-density-${density}`\n );\n document.documentElement.dataset.mode = undefined;\n }\n };\n }, [applyClassesTo, density, isRoot, mode, themeName]);\n\n const saltProvider = (\n <DensityContext.Provider value={density}>\n <ThemeContext.Provider value={themeContextValue}>\n <BreakpointContext.Provider value={breakpoints}>\n <ViewportProvider>{themedChildren}</ViewportProvider>\n </BreakpointContext.Provider>\n </ThemeContext.Provider>\n </DensityContext.Provider>\n );\n\n if (isRoot) {\n return <AriaAnnouncerProvider>{saltProvider}</AriaAnnouncerProvider>;\n } else {\n return saltProvider;\n }\n}\n\nexport const useTheme = (): ThemeContextProps => {\n return useContext(ThemeContext);\n};\n\n/**\n * `useDensity` merges density value from `DensityContext` with the one from component's props.\n */\nexport function useDensity(density?: Density): Density {\n const densityFromContext = useContext(DensityContext);\n return density || densityFromContext || DEFAULT_DENSITY;\n}\n\nexport const useBreakpoints = (): Breakpoints => {\n return useContext(BreakpointContext);\n};\n"],"names":["createContext","DEFAULT_BREAKPOINTS","React","cx","jsx","useContext","useMemo","useIsomorphicLayoutEffect","ViewportProvider","AriaAnnouncerProvider"],"mappings":"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"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
6
|
+
var React = require('react');
|
|
7
|
+
var FlexLayout = require('../flex-layout/FlexLayout.js');
|
|
8
|
+
|
|
9
|
+
const StackLayout = React.forwardRef(
|
|
10
|
+
function StackLayout2(props, ref) {
|
|
11
|
+
return /* @__PURE__ */ jsxRuntime.jsx(FlexLayout.FlexLayout, {
|
|
12
|
+
direction: "column",
|
|
13
|
+
ref,
|
|
14
|
+
...props
|
|
15
|
+
});
|
|
16
|
+
}
|
|
17
|
+
);
|
|
18
|
+
|
|
19
|
+
exports.StackLayout = StackLayout;
|
|
20
|
+
//# sourceMappingURL=StackLayout.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StackLayout.js","sources":["../src/stack-layout/StackLayout.tsx"],"sourcesContent":["import { ElementType, forwardRef, HTMLAttributes } from \"react\";\nimport { FlexLayout, FlexLayoutProps } from \"../flex-layout\";\n\nexport interface StackLayoutProps extends HTMLAttributes<HTMLDivElement> {\n /**\n * Defines the default behavior for how flex items are laid out along the cross axis on the current line, default is \"stretch\".\n */\n align?: FlexLayoutProps<ElementType>[\"align\"];\n /**\n * Controls the space between items, default is 3.\n */\n gap?: FlexLayoutProps<ElementType>[\"gap\"];\n /**\n * Adds a separator between elements, default is false.\n */\n separators?: FlexLayoutProps<ElementType>[\"separators\"];\n}\n\nexport const StackLayout = forwardRef<HTMLDivElement, StackLayoutProps>(\n function StackLayout(props, ref) {\n return <FlexLayout direction=\"column\" ref={ref} {...props} />;\n }\n);\n"],"names":["forwardRef","StackLayout","jsx","FlexLayout"],"mappings":";;;;;;;;AAkBO,MAAM,WAAc,GAAAA,gBAAA;AAAA,EACzB,SAASC,YAAY,CAAA,KAAA,EAAO,GAAK,EAAA;AAC/B,IAAA,uBAAQC,cAAA,CAAAC,qBAAA,EAAA;AAAA,MAAW,SAAU,EAAA,QAAA;AAAA,MAAS,GAAA;AAAA,MAAW,GAAG,KAAA;AAAA,KAAO,CAAA,CAAA;AAAA,GAC7D;AACF;;;;"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var styleInject_es = require('../../../../node_modules/style-inject/dist/style-inject.es.js');
|
|
4
|
+
|
|
5
|
+
var css_248z = ".saltStatusIndicator {\n --statusIndicator-warning-color: var(--salt-status-warning-foreground);\n --statusIndicator-info-color: var(--salt-status-info-foreground);\n --statusIndicator-success-color: var(--salt-status-success-foreground);\n --statusIndicator-error-color: var(--salt-status-error-foreground);\n}\n\n.saltStatusIndicator-error {\n --saltIcon-color: var(--saltStatusIndicator-color, var(--statusIndicator-error-color));\n}\n\n.saltStatusIndicator-warning {\n --saltIcon-color: var(--saltStatusIndicator-color, var(--statusIndicator-warning-color));\n}\n\n.saltStatusIndicator-success {\n --saltIcon-color: var(--saltStatusIndicator-color, var(--statusIndicator-success-color));\n}\n\n.saltStatusIndicator-info {\n --saltIcon-color: var(--saltStatusIndicator-color, var(--statusIndicator-info-color));\n}\n";
|
|
6
|
+
styleInject_es(css_248z);
|
|
7
|
+
|
|
8
|
+
module.exports = css_248z;
|
|
9
|
+
//# sourceMappingURL=StatusIndicator.css.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StatusIndicator.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
6
|
+
var icons$1 = require('@salt-ds/icons');
|
|
7
|
+
var cx = require('classnames');
|
|
8
|
+
var React = require('react');
|
|
9
|
+
var makePrefixer = require('../utils/makePrefixer.js');
|
|
10
|
+
require('../utils/useId.js');
|
|
11
|
+
require('../salt-provider/SaltProvider.js');
|
|
12
|
+
require('../viewport/ViewportProvider.js');
|
|
13
|
+
require('./StatusIndicator.css.js');
|
|
14
|
+
|
|
15
|
+
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
16
|
+
|
|
17
|
+
var cx__default = /*#__PURE__*/_interopDefaultLegacy(cx);
|
|
18
|
+
|
|
19
|
+
const icons = {
|
|
20
|
+
error: icons$1.ErrorSolidIcon,
|
|
21
|
+
success: icons$1.SuccessTickIcon,
|
|
22
|
+
warning: icons$1.WarningSolidIcon,
|
|
23
|
+
info: icons$1.InfoSolidIcon
|
|
24
|
+
};
|
|
25
|
+
const statusToAriaLabelMap = {
|
|
26
|
+
error: "error",
|
|
27
|
+
success: "success",
|
|
28
|
+
warning: "warning",
|
|
29
|
+
info: "info"
|
|
30
|
+
};
|
|
31
|
+
const withBaseName = makePrefixer.makePrefixer("saltStatusIndicator");
|
|
32
|
+
const StatusIndicator = React.forwardRef(
|
|
33
|
+
function StatusIndicator2({ className, status, size = icons$1.DEFAULT_ICON_SIZE, ...restProps }, ref) {
|
|
34
|
+
const IconComponent = icons[status];
|
|
35
|
+
const ariaLabel = statusToAriaLabelMap[status];
|
|
36
|
+
return /* @__PURE__ */ jsxRuntime.jsx(IconComponent, {
|
|
37
|
+
className: cx__default["default"](withBaseName(), withBaseName(status), className),
|
|
38
|
+
size,
|
|
39
|
+
"aria-label": ariaLabel,
|
|
40
|
+
...restProps,
|
|
41
|
+
ref
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
);
|
|
45
|
+
|
|
46
|
+
exports.StatusIndicator = StatusIndicator;
|
|
47
|
+
//# sourceMappingURL=StatusIndicator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StatusIndicator.js","sources":["../src/status-indicator/StatusIndicator.tsx"],"sourcesContent":["import {\n DEFAULT_ICON_SIZE,\n ErrorSolidIcon,\n IconProps,\n InfoSolidIcon,\n SuccessTickIcon,\n WarningSolidIcon,\n} from \"@salt-ds/icons\";\nimport classnames from \"classnames\";\nimport { forwardRef } from \"react\";\nimport { makePrefixer } from \"../utils\";\nimport { ValidationStatus } from \"./ValidationStatus\";\n\nimport \"./StatusIndicator.css\";\n\nconst icons = {\n error: ErrorSolidIcon,\n success: SuccessTickIcon,\n warning: WarningSolidIcon,\n info: InfoSolidIcon,\n};\n\nexport interface StatusIndicatorProps extends IconProps {\n /**\n * Status indicator to be displayed.\n */\n status: ValidationStatus;\n}\n\nconst statusToAriaLabelMap: Record<ValidationStatus, string> = {\n error: \"error\",\n success: \"success\",\n warning: \"warning\",\n info: \"info\",\n};\n\nconst withBaseName = makePrefixer(\"saltStatusIndicator\");\n\nexport const StatusIndicator = forwardRef<SVGSVGElement, StatusIndicatorProps>(\n function StatusIndicator(\n { className, status, size = DEFAULT_ICON_SIZE, ...restProps },\n ref\n ) {\n const IconComponent = icons[status];\n const ariaLabel = statusToAriaLabelMap[status];\n\n return (\n <IconComponent\n className={classnames(withBaseName(), withBaseName(status), className)}\n size={size}\n aria-label={ariaLabel}\n {...restProps}\n ref={ref}\n />\n );\n }\n);\n"],"names":["ErrorSolidIcon","SuccessTickIcon","WarningSolidIcon","InfoSolidIcon","makePrefixer","forwardRef","StatusIndicator","DEFAULT_ICON_SIZE","jsx","classnames"],"mappings":";;;;;;;;;;;;;;;;;;AAeA,MAAM,KAAQ,GAAA;AAAA,EACZ,KAAO,EAAAA,sBAAA;AAAA,EACP,OAAS,EAAAC,uBAAA;AAAA,EACT,OAAS,EAAAC,wBAAA;AAAA,EACT,IAAM,EAAAC,qBAAA;AACR,CAAA,CAAA;AASA,MAAM,oBAAyD,GAAA;AAAA,EAC7D,KAAO,EAAA,OAAA;AAAA,EACP,OAAS,EAAA,SAAA;AAAA,EACT,OAAS,EAAA,SAAA;AAAA,EACT,IAAM,EAAA,MAAA;AACR,CAAA,CAAA;AAEA,MAAM,YAAA,GAAeC,0BAAa,qBAAqB,CAAA,CAAA;AAEhD,MAAM,eAAkB,GAAAC,gBAAA;AAAA,EAC7B,SAASC,iBACP,EAAE,SAAA,EAAW,QAAQ,IAAO,GAAAC,yBAAA,EAAA,GAAsB,SAAU,EAAA,EAC5D,GACA,EAAA;AACA,IAAA,MAAM,gBAAgB,KAAM,CAAA,MAAA,CAAA,CAAA;AAC5B,IAAA,MAAM,YAAY,oBAAqB,CAAA,MAAA,CAAA,CAAA;AAEvC,IAAA,uBACGC,cAAA,CAAA,aAAA,EAAA;AAAA,MACC,WAAWC,sBAAW,CAAA,YAAA,IAAgB,YAAa,CAAA,MAAM,GAAG,SAAS,CAAA;AAAA,MACrE,IAAA;AAAA,MACA,YAAY,EAAA,SAAA;AAAA,MACX,GAAG,SAAA;AAAA,MACJ,GAAA;AAAA,KACF,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
const VALIDATION_NAMED_STATUS = [
|
|
6
|
+
"error",
|
|
7
|
+
"warning",
|
|
8
|
+
"success",
|
|
9
|
+
"info"
|
|
10
|
+
];
|
|
11
|
+
|
|
12
|
+
exports.VALIDATION_NAMED_STATUS = VALIDATION_NAMED_STATUS;
|
|
13
|
+
//# sourceMappingURL=ValidationStatus.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ValidationStatus.js","sources":["../src/status-indicator/ValidationStatus.ts"],"sourcesContent":["export const VALIDATION_NAMED_STATUS = [\n \"error\",\n \"warning\",\n \"success\",\n \"info\",\n] as const;\n\nexport type ValidationStatus = typeof VALIDATION_NAMED_STATUS[number];\n"],"names":[],"mappings":";;;;AAAO,MAAM,uBAA0B,GAAA;AAAA,EACrC,OAAA;AAAA,EACA,SAAA;AAAA,EACA,SAAA;AAAA,EACA,MAAA;AACF;;;;"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
6
|
+
var React = require('react');
|
|
7
|
+
var makePrefixer = require('../utils/makePrefixer.js');
|
|
8
|
+
require('../utils/useId.js');
|
|
9
|
+
require('../salt-provider/SaltProvider.js');
|
|
10
|
+
require('../viewport/ViewportProvider.js');
|
|
11
|
+
var cx = require('classnames');
|
|
12
|
+
var Text = require('./Text.js');
|
|
13
|
+
|
|
14
|
+
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
15
|
+
|
|
16
|
+
var cx__default = /*#__PURE__*/_interopDefaultLegacy(cx);
|
|
17
|
+
|
|
18
|
+
const withBaseName = makePrefixer.makePrefixer("saltText");
|
|
19
|
+
const Display1 = React.forwardRef(function Display12({ children, className, ...rest }, ref) {
|
|
20
|
+
return /* @__PURE__ */ jsxRuntime.jsx(Text.Text, {
|
|
21
|
+
as: "span",
|
|
22
|
+
className: cx__default["default"](className, withBaseName(`display1`)),
|
|
23
|
+
ref,
|
|
24
|
+
...rest,
|
|
25
|
+
children
|
|
26
|
+
});
|
|
27
|
+
});
|
|
28
|
+
const Display2 = React.forwardRef(function Display22({ children, className, ...rest }, ref) {
|
|
29
|
+
return /* @__PURE__ */ jsxRuntime.jsx(Text.Text, {
|
|
30
|
+
as: "span",
|
|
31
|
+
className: cx__default["default"](className, withBaseName(`display2`)),
|
|
32
|
+
ref,
|
|
33
|
+
...rest,
|
|
34
|
+
children
|
|
35
|
+
});
|
|
36
|
+
});
|
|
37
|
+
const Display3 = React.forwardRef(function Display32({ children, className, ...rest }, ref) {
|
|
38
|
+
return /* @__PURE__ */ jsxRuntime.jsx(Text.Text, {
|
|
39
|
+
as: "span",
|
|
40
|
+
className: cx__default["default"](className, withBaseName(`display3`)),
|
|
41
|
+
ref,
|
|
42
|
+
...rest,
|
|
43
|
+
children
|
|
44
|
+
});
|
|
45
|
+
});
|
|
46
|
+
|
|
47
|
+
exports.Display1 = Display1;
|
|
48
|
+
exports.Display2 = Display2;
|
|
49
|
+
exports.Display3 = Display3;
|
|
50
|
+
//# sourceMappingURL=Display.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Display.js","sources":["../src/text/Display.tsx"],"sourcesContent":["import { makePrefixer } from \"../utils\";\nimport cx from \"classnames\";\nimport { forwardRef } from \"react\";\nimport { Text, TextProps } from \"./Text\";\n\nconst withBaseName = makePrefixer(\"saltText\");\n\nexport const Display1 = forwardRef<\n HTMLSpanElement,\n Omit<TextProps<\"span\">, \"as\">\n>(function Display1({ children, className, ...rest }, ref) {\n return (\n <Text\n as=\"span\"\n className={cx(className, withBaseName(`display1`))}\n ref={ref}\n {...rest}\n >\n {children}\n </Text>\n );\n});\n\nexport const Display2 = forwardRef<\n HTMLSpanElement,\n Omit<TextProps<\"span\">, \"as\">\n>(function Display2({ children, className, ...rest }, ref) {\n return (\n <Text\n as=\"span\"\n className={cx(className, withBaseName(`display2`))}\n ref={ref}\n {...rest}\n >\n {children}\n </Text>\n );\n});\n\nexport const Display3 = forwardRef<\n HTMLSpanElement,\n Omit<TextProps<\"span\">, \"as\">\n>(function Display3({ children, className, ...rest }, ref) {\n return (\n <Text\n as=\"span\"\n className={cx(className, withBaseName(`display3`))}\n ref={ref}\n {...rest}\n >\n {children}\n </Text>\n );\n});\n"],"names":["makePrefixer","forwardRef","Display1","jsx","Text","cx","Display2","Display3"],"mappings":";;;;;;;;;;;;;;;;;AAKA,MAAM,YAAA,GAAeA,0BAAa,UAAU,CAAA,CAAA;AAE/B,MAAA,QAAA,GAAWC,iBAGtB,SAASC,SAAAA,CAAS,EAAE,QAAU,EAAA,SAAA,EAAA,GAAc,IAAK,EAAA,EAAG,GAAK,EAAA;AACzD,EAAA,uBACGC,cAAA,CAAAC,SAAA,EAAA;AAAA,IACC,EAAG,EAAA,MAAA;AAAA,IACH,SAAW,EAAAC,sBAAA,CAAG,SAAW,EAAA,YAAA,CAAa,UAAU,CAAC,CAAA;AAAA,IACjD,GAAA;AAAA,IACC,GAAG,IAAA;AAAA,IAEH,QAAA;AAAA,GACH,CAAA,CAAA;AAEJ,CAAC,EAAA;AAEY,MAAA,QAAA,GAAWJ,iBAGtB,SAASK,SAAAA,CAAS,EAAE,QAAU,EAAA,SAAA,EAAA,GAAc,IAAK,EAAA,EAAG,GAAK,EAAA;AACzD,EAAA,uBACGH,cAAA,CAAAC,SAAA,EAAA;AAAA,IACC,EAAG,EAAA,MAAA;AAAA,IACH,SAAW,EAAAC,sBAAA,CAAG,SAAW,EAAA,YAAA,CAAa,UAAU,CAAC,CAAA;AAAA,IACjD,GAAA;AAAA,IACC,GAAG,IAAA;AAAA,IAEH,QAAA;AAAA,GACH,CAAA,CAAA;AAEJ,CAAC,EAAA;AAEY,MAAA,QAAA,GAAWJ,iBAGtB,SAASM,SAAAA,CAAS,EAAE,QAAU,EAAA,SAAA,EAAA,GAAc,IAAK,EAAA,EAAG,GAAK,EAAA;AACzD,EAAA,uBACGJ,cAAA,CAAAC,SAAA,EAAA;AAAA,IACC,EAAG,EAAA,MAAA;AAAA,IACH,SAAW,EAAAC,sBAAA,CAAG,SAAW,EAAA,YAAA,CAAa,UAAU,CAAC,CAAA;AAAA,IACjD,GAAA;AAAA,IACC,GAAG,IAAA;AAAA,IAEH,QAAA;AAAA,GACH,CAAA,CAAA;AAEJ,CAAC;;;;;;"}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
6
|
+
var React = require('react');
|
|
7
|
+
var Text = require('./Text.js');
|
|
8
|
+
|
|
9
|
+
const H1 = React.forwardRef(
|
|
10
|
+
function H12({ children, ...rest }, ref) {
|
|
11
|
+
return /* @__PURE__ */ jsxRuntime.jsx(Text.Text, {
|
|
12
|
+
as: "h1",
|
|
13
|
+
ref,
|
|
14
|
+
...rest,
|
|
15
|
+
children
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
);
|
|
19
|
+
const H2 = React.forwardRef(
|
|
20
|
+
function H22({ children, ...rest }, ref) {
|
|
21
|
+
return /* @__PURE__ */ jsxRuntime.jsx(Text.Text, {
|
|
22
|
+
as: "h2",
|
|
23
|
+
ref,
|
|
24
|
+
...rest,
|
|
25
|
+
children
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
);
|
|
29
|
+
const H3 = React.forwardRef(
|
|
30
|
+
function H32({ children, ...rest }, ref) {
|
|
31
|
+
return /* @__PURE__ */ jsxRuntime.jsx(Text.Text, {
|
|
32
|
+
as: "h3",
|
|
33
|
+
ref,
|
|
34
|
+
...rest,
|
|
35
|
+
children
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
);
|
|
39
|
+
const H4 = React.forwardRef(
|
|
40
|
+
function H42({ children, ...rest }, ref) {
|
|
41
|
+
return /* @__PURE__ */ jsxRuntime.jsx(Text.Text, {
|
|
42
|
+
as: "h4",
|
|
43
|
+
ref,
|
|
44
|
+
...rest,
|
|
45
|
+
children
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
);
|
|
49
|
+
|
|
50
|
+
exports.H1 = H1;
|
|
51
|
+
exports.H2 = H2;
|
|
52
|
+
exports.H3 = H3;
|
|
53
|
+
exports.H4 = H4;
|
|
54
|
+
//# sourceMappingURL=Headings.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Headings.js","sources":["../src/text/Headings.tsx"],"sourcesContent":["import { forwardRef } from \"react\";\n\nimport { Text, TextProps } from \"./Text\";\n\nexport const H1 = forwardRef<HTMLHeadingElement, Omit<TextProps<\"h1\">, \"as\">>(\n function H1({ children, ...rest }, ref) {\n return (\n <Text as=\"h1\" ref={ref} {...rest}>\n {children}\n </Text>\n );\n }\n);\n\nexport const H2 = forwardRef<HTMLHeadingElement, Omit<TextProps<\"h2\">, \"as\">>(\n function H2({ children, ...rest }, ref) {\n return (\n <Text as=\"h2\" ref={ref} {...rest}>\n {children}\n </Text>\n );\n }\n);\n\nexport const H3 = forwardRef<HTMLHeadingElement, Omit<TextProps<\"h3\">, \"as\">>(\n function H3({ children, ...rest }, ref) {\n return (\n <Text as=\"h3\" ref={ref} {...rest}>\n {children}\n </Text>\n );\n }\n);\n\nexport const H4 = forwardRef<HTMLHeadingElement, Omit<TextProps<\"h4\">, \"as\">>(\n function H4({ children, ...rest }, ref) {\n return (\n <Text as=\"h4\" ref={ref} {...rest}>\n {children}\n </Text>\n );\n }\n);\n"],"names":["forwardRef","H1","jsx","Text","H2","H3","H4"],"mappings":";;;;;;;;AAIO,MAAM,EAAK,GAAAA,gBAAA;AAAA,EAChB,SAASC,GAAG,CAAA,EAAE,QAAa,EAAA,GAAA,IAAA,IAAQ,GAAK,EAAA;AACtC,IAAA,uBACGC,cAAA,CAAAC,SAAA,EAAA;AAAA,MAAK,EAAG,EAAA,IAAA;AAAA,MAAK,GAAA;AAAA,MAAW,GAAG,IAAA;AAAA,MACzB,QAAA;AAAA,KACH,CAAA,CAAA;AAAA,GAEJ;AACF,EAAA;AAEO,MAAM,EAAK,GAAAH,gBAAA;AAAA,EAChB,SAASI,GAAG,CAAA,EAAE,QAAa,EAAA,GAAA,IAAA,IAAQ,GAAK,EAAA;AACtC,IAAA,uBACGF,cAAA,CAAAC,SAAA,EAAA;AAAA,MAAK,EAAG,EAAA,IAAA;AAAA,MAAK,GAAA;AAAA,MAAW,GAAG,IAAA;AAAA,MACzB,QAAA;AAAA,KACH,CAAA,CAAA;AAAA,GAEJ;AACF,EAAA;AAEO,MAAM,EAAK,GAAAH,gBAAA;AAAA,EAChB,SAASK,GAAG,CAAA,EAAE,QAAa,EAAA,GAAA,IAAA,IAAQ,GAAK,EAAA;AACtC,IAAA,uBACGH,cAAA,CAAAC,SAAA,EAAA;AAAA,MAAK,EAAG,EAAA,IAAA;AAAA,MAAK,GAAA;AAAA,MAAW,GAAG,IAAA;AAAA,MACzB,QAAA;AAAA,KACH,CAAA,CAAA;AAAA,GAEJ;AACF,EAAA;AAEO,MAAM,EAAK,GAAAH,gBAAA;AAAA,EAChB,SAASM,GAAG,CAAA,EAAE,QAAa,EAAA,GAAA,IAAA,IAAQ,GAAK,EAAA;AACtC,IAAA,uBACGJ,cAAA,CAAAC,SAAA,EAAA;AAAA,MAAK,EAAG,EAAA,IAAA;AAAA,MAAK,GAAA;AAAA,MAAW,GAAG,IAAA;AAAA,MACzB,QAAA;AAAA,KACH,CAAA,CAAA;AAAA,GAEJ;AACF;;;;;;;"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
6
|
+
var React = require('react');
|
|
7
|
+
var Text = require('./Text.js');
|
|
8
|
+
|
|
9
|
+
const Label = React.forwardRef(function Label2({ children, ...rest }, ref) {
|
|
10
|
+
return /* @__PURE__ */ jsxRuntime.jsx(Text.Text, {
|
|
11
|
+
as: "label",
|
|
12
|
+
ref,
|
|
13
|
+
...rest,
|
|
14
|
+
children
|
|
15
|
+
});
|
|
16
|
+
});
|
|
17
|
+
|
|
18
|
+
exports.Label = Label;
|
|
19
|
+
//# sourceMappingURL=Label.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Label.js","sources":["../src/text/Label.tsx"],"sourcesContent":["import { forwardRef } from \"react\";\nimport { Text, TextProps } from \"./Text\";\n\nexport const Label = forwardRef<\n HTMLLabelElement,\n Omit<TextProps<\"label\">, \"as\">\n>(function Label({ children, ...rest }, ref) {\n return (\n <Text as=\"label\" ref={ref} {...rest}>\n {children}\n </Text>\n );\n});\n"],"names":["forwardRef","Label","jsx","Text"],"mappings":";;;;;;;;AAGa,MAAA,KAAA,GAAQA,iBAGnB,SAASC,MAAAA,CAAM,EAAE,QAAa,EAAA,GAAA,IAAA,IAAQ,GAAK,EAAA;AAC3C,EAAA,uBACGC,cAAA,CAAAC,SAAA,EAAA;AAAA,IAAK,EAAG,EAAA,OAAA;AAAA,IAAQ,GAAA;AAAA,IAAW,GAAG,IAAA;AAAA,IAC5B,QAAA;AAAA,GACH,CAAA,CAAA;AAEJ,CAAC;;;;"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var styleInject_es = require('../../../../node_modules/style-inject/dist/style-inject.es.js');
|
|
4
|
+
|
|
5
|
+
var css_248z = "/* Main css class. Style for body text */\n.saltText {\n font-size: var(--salt-text-fontSize);\n line-height: var(--salt-text-lineHeight);\n color: var(--saltText-color, var(--text-color));\n}\n\n/* Allows truncation */\n.saltText-lineClamp {\n display: -webkit-box;\n -webkit-box-orient: vertical;\n -webkit-line-clamp: var(--text-max-rows, 0);\n overflow: hidden;\n word-break: break-word;\n}\n\n/* Primary variant */\n.saltText-primary {\n --text-color: var(--salt-text-primary-foreground);\n}\n\n/* Secondary variant */\n.saltText-secondary {\n --text-color: var(--salt-text-secondary-foreground);\n}\n\n/* Body emphasis strong */\n.saltText strong {\n font-weight: var(--salt-text-fontWeight-strong);\n}\n/* Body emphasis small */\n.saltText small {\n font-size: inherit;\n font-weight: var(--salt-text-fontWeight-small);\n}\n\n/* Display 1 */\n.saltText-display1.saltText {\n font-size: var(--salt-text-display1-fontSize);\n font-weight: var(--salt-text-display1-fontWeight);\n line-height: var(--salt-text-display1-lineHeight);\n}\n\n/* Display 2 */\n.saltText-display2.saltText {\n font-size: var(--salt-text-display2-fontSize);\n font-weight: var(--salt-text-display2-fontWeight);\n line-height: var(--salt-text-display2-lineHeight);\n}\n\n/* Display 3 */\n.saltText-display3.saltText {\n font-size: var(--salt-text-display3-fontSize);\n font-weight: var(--salt-text-display3-fontWeight);\n line-height: var(--salt-text-display3-lineHeight);\n}\n\n/* Heading 1 */\nh1.saltText,\n.saltText-h1.saltText {\n font-size: var(--salt-text-h1-fontSize);\n font-weight: var(--salt-text-h1-fontWeight);\n line-height: var(--salt-text-h1-lineHeight);\n}\n\n/* H1 emphasis strong */\nh1.saltText strong,\n.saltText-h1.saltText strong {\n font-weight: var(--salt-text-h1-fontWeight-strong);\n}\n/* H1 emphasis small */\nh1.saltText small,\n.saltText-h1.saltText small {\n font-size: inherit;\n font-weight: var(--salt-text-h1-fontWeight-small);\n}\n\n/* Heading 2 */\nh2.saltText,\n.saltText-h2.saltText {\n font-size: var(--salt-text-h2-fontSize);\n font-weight: var(--salt-text-h2-fontWeight);\n line-height: var(--salt-text-h2-lineHeight);\n}\n\n/* H2 emphasis strong */\nh2.saltText strong,\n.saltText-h2.saltText strong {\n font-weight: var(--salt-text-h2-fontWeight-strong);\n}\n/* H2 emphasis small */\nh2.saltText small,\n.saltText-h2.saltText small {\n font-size: inherit;\n font-weight: var(--salt-text-h2-fontWeight-small);\n}\n\n/* Heading 3 */\nh3.saltText,\n.saltText-h3.saltText {\n font-size: var(--salt-text-h3-fontSize);\n font-weight: var(--salt-text-h3-fontWeight);\n line-height: var(--salt-text-h3-lineHeight);\n}\n\n/* H3 emphasis strong */\nh3.saltText strong,\n.saltText-h3.saltText strong {\n font-weight: var(--salt-text-h3-fontWeight-strong);\n}\n/* H3 emphasis small */\nh3.saltText small,\n.saltText-h3.saltText small {\n font-size: inherit;\n font-weight: var(--salt-text-h3-fontWeight-small);\n}\n\n/* Heading 4 */\nh4.saltText,\n.saltText-h4.saltText {\n font-size: var(--salt-text-h4-fontSize);\n font-weight: var(--salt-text-h4-fontWeight);\n line-height: var(--salt-text-h4-lineHeight);\n}\n\n/* H4 emphasis strong */\nh4.saltText strong,\n.saltText-h4.saltText strong {\n font-weight: var(--salt-text-h4-fontWeight-strong);\n}\n/* H4 emphasis small */\nh4.saltText small,\n.saltText-h4.saltText small {\n font-size: inherit;\n font-weight: var(--salt-text-h4-fontWeight-small);\n}\n\n/* Label */\nlabel.saltText,\n.saltText-label.saltText {\n font-size: var(--salt-text-label-fontSize);\n line-height: var(--salt-text-label-lineHeight);\n font-weight: var(--salt-text-fontWeight);\n}\n\n/* Label emphasis strong */\nlabel.saltText strong,\n.saltText-label.saltText strong {\n font-weight: var(--salt-text-fontWeight-strong);\n}\n/* Label emphasis small */\nlabel.saltText small,\n.saltText-label.saltText small {\n font-size: inherit;\n font-weight: var(--salt-text-fontWeight-small);\n}\n";
|
|
6
|
+
styleInject_es(css_248z);
|
|
7
|
+
|
|
8
|
+
module.exports = css_248z;
|
|
9
|
+
//# sourceMappingURL=Text.css.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Text.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
6
|
+
var React = require('react');
|
|
7
|
+
var makePrefixer = require('../utils/makePrefixer.js');
|
|
8
|
+
require('../utils/useId.js');
|
|
9
|
+
require('../salt-provider/SaltProvider.js');
|
|
10
|
+
require('../viewport/ViewportProvider.js');
|
|
11
|
+
var cx = require('classnames');
|
|
12
|
+
require('./Text.css.js');
|
|
13
|
+
|
|
14
|
+
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
15
|
+
|
|
16
|
+
var cx__default = /*#__PURE__*/_interopDefaultLegacy(cx);
|
|
17
|
+
|
|
18
|
+
const withBaseName = makePrefixer.makePrefixer("saltText");
|
|
19
|
+
const Text = React.forwardRef(
|
|
20
|
+
({
|
|
21
|
+
children,
|
|
22
|
+
className,
|
|
23
|
+
as,
|
|
24
|
+
maxRows,
|
|
25
|
+
styleAs,
|
|
26
|
+
variant = "primary",
|
|
27
|
+
style,
|
|
28
|
+
...restProps
|
|
29
|
+
}, ref) => {
|
|
30
|
+
const Component = as || "div";
|
|
31
|
+
const textStyles = { "--text-max-rows": maxRows, ...style };
|
|
32
|
+
return /* @__PURE__ */ jsxRuntime.jsx(Component, {
|
|
33
|
+
className: cx__default["default"](withBaseName(), className, {
|
|
34
|
+
[withBaseName("lineClamp")]: maxRows,
|
|
35
|
+
[withBaseName(styleAs || "")]: styleAs,
|
|
36
|
+
[withBaseName(variant)]: variant
|
|
37
|
+
}),
|
|
38
|
+
...restProps,
|
|
39
|
+
ref,
|
|
40
|
+
style: textStyles,
|
|
41
|
+
children
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
);
|
|
45
|
+
|
|
46
|
+
exports.Text = Text;
|
|
47
|
+
//# sourceMappingURL=Text.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Text.js","sources":["../src/text/Text.tsx"],"sourcesContent":["import {\n makePrefixer,\n PolymorphicComponentPropWithRef,\n PolymorphicRef,\n} from \"../utils\";\nimport cx from \"classnames\";\nimport { ElementType, forwardRef, ReactElement } from \"react\";\n\nimport \"./Text.css\";\n\nexport type TextProps<T extends ElementType> = PolymorphicComponentPropWithRef<\n T,\n {\n /**\n * Apply text truncation by mentioning number of rows to be displayed\n */\n maxRows?: number;\n /**\n * Match styling to another text component's style\n */\n styleAs?:\n | \"h1\"\n | \"h2\"\n | \"h3\"\n | \"h4\"\n | \"label\"\n | \"display1\"\n | \"display2\"\n | \"display3\";\n /**\n * Change text color palette\n */\n variant?: \"primary\" | \"secondary\";\n }\n>;\n\ntype TextComponent = <T extends ElementType = \"div\">(\n props: TextProps<T>\n) => ReactElement | null;\n\nconst withBaseName = makePrefixer(\"saltText\");\n\nexport const Text: TextComponent = forwardRef(\n <T extends ElementType = \"div\">(\n {\n children,\n className,\n as,\n maxRows,\n styleAs,\n variant = \"primary\",\n style,\n ...restProps\n }: TextProps<T>,\n ref?: PolymorphicRef<T>\n ) => {\n const Component = as || \"div\";\n\n const textStyles = { \"--text-max-rows\": maxRows, ...style };\n\n return (\n <Component\n className={cx(withBaseName(), className, {\n [withBaseName(\"lineClamp\")]: maxRows,\n [withBaseName(styleAs || \"\")]: styleAs,\n [withBaseName(variant)]: variant,\n })}\n {...restProps}\n ref={ref}\n style={textStyles}\n >\n {children}\n </Component>\n );\n }\n);\n"],"names":["makePrefixer","forwardRef","jsx","cx"],"mappings":";;;;;;;;;;;;;;;;;AAwCA,MAAM,YAAA,GAAeA,0BAAa,UAAU,CAAA,CAAA;AAErC,MAAM,IAAsB,GAAAC,gBAAA;AAAA,EACjC,CACE;AAAA,IACE,QAAA;AAAA,IACA,SAAA;AAAA,IACA,EAAA;AAAA,IACA,OAAA;AAAA,IACA,OAAA;AAAA,IACA,OAAU,GAAA,SAAA;AAAA,IACV,KAAA;AAAA,IACG,GAAA,SAAA;AAAA,KAEL,GACG,KAAA;AACH,IAAA,MAAM,YAAY,EAAM,IAAA,KAAA,CAAA;AAExB,IAAA,MAAM,UAAa,GAAA,EAAE,iBAAmB,EAAA,OAAA,EAAS,GAAG,KAAM,EAAA,CAAA;AAE1D,IAAA,uBACGC,cAAA,CAAA,SAAA,EAAA;AAAA,MACC,SAAW,EAAAC,sBAAA,CAAG,YAAa,EAAA,EAAG,SAAW,EAAA;AAAA,QACvC,CAAC,YAAa,CAAA,WAAW,CAAI,GAAA,OAAA;AAAA,QAC7B,CAAC,YAAA,CAAa,OAAW,IAAA,EAAE,CAAI,GAAA,OAAA;AAAA,QAC/B,CAAC,YAAa,CAAA,OAAO,CAAI,GAAA,OAAA;AAAA,OAC1B,CAAA;AAAA,MACA,GAAG,SAAA;AAAA,MACJ,GAAA;AAAA,MACA,KAAO,EAAA,UAAA;AAAA,MAEN,QAAA;AAAA,KACH,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Density.js","sources":["../src/theme/Density.ts"],"sourcesContent":["export const DensityValues = [\"high\", \"medium\", \"low\", \"touch\"] as const;\n\nexport type Density = typeof DensityValues[number];\n"],"names":[],"mappings":";;;;AAAO,MAAM,aAAgB,GAAA,CAAC,MAAQ,EAAA,QAAA,EAAU,OAAO,OAAO;;;;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Mode.js","sources":["../src/theme/Mode.ts"],"sourcesContent":["export const ModeValues = [\"light\", \"dark\"] as const;\n\nexport type Mode = typeof ModeValues[number];\n"],"names":[],"mappings":";;;;AAAa,MAAA,UAAA,GAAa,CAAC,OAAA,EAAS,MAAM;;;;"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
const getCharacteristicValue = (themeName, characteristicName, variant, scopeElement) => {
|
|
6
|
+
const cssVariableName = `--salt-${characteristicName}-${variant}`;
|
|
7
|
+
const scopeTarget = scopeElement || document.body.querySelector(`.${themeName}`);
|
|
8
|
+
if (scopeTarget) {
|
|
9
|
+
const style = getComputedStyle(scopeTarget);
|
|
10
|
+
const variableValue = style.getPropertyValue(cssVariableName);
|
|
11
|
+
if (variableValue) {
|
|
12
|
+
return variableValue;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
return null;
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
exports.getCharacteristicValue = getCharacteristicValue;
|
|
19
|
+
//# sourceMappingURL=Theme.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Theme.js","sources":["../src/theme/Theme.ts"],"sourcesContent":["export type characteristic =\n | \"accent\"\n | \"actionable\"\n | \"container\"\n | \"delay\"\n | \"disabled\"\n | \"draggable\"\n | \"target\"\n | \"editable\"\n | \"focused\"\n | \"measured\"\n | \"navigable\"\n | \"overlayable\"\n | \"selectable\"\n | \"separable\"\n | \"taggable\"\n | \"text\"\n | \"status\"\n // The next 4 are foundations, should they really be here?\n | \"icon\"\n | \"shadow\"\n | \"size\"\n | \"spacing\";\n\nexport type ThemeName = string;\n\nexport const getCharacteristicValue = (\n themeName: ThemeName,\n characteristicName: characteristic,\n variant: string,\n scopeElement?: HTMLElement\n): string | null => {\n const cssVariableName = `--salt-${characteristicName}-${variant}`;\n const scopeTarget =\n scopeElement || document.body.querySelector(`.${themeName}`);\n if (scopeTarget) {\n const style = getComputedStyle(scopeTarget);\n const variableValue = style.getPropertyValue(cssVariableName);\n if (variableValue) {\n return variableValue;\n }\n }\n return null;\n};\n"],"names":[],"mappings":";;;;AA0BO,MAAM,sBAAyB,GAAA,CACpC,SACA,EAAA,kBAAA,EACA,SACA,YACkB,KAAA;AAClB,EAAM,MAAA,eAAA,GAAkB,UAAU,kBAAsB,CAAA,CAAA,EAAA,OAAA,CAAA,CAAA,CAAA;AACxD,EAAA,MAAM,cACJ,YAAgB,IAAA,QAAA,CAAS,IAAK,CAAA,aAAA,CAAc,IAAI,SAAW,CAAA,CAAA,CAAA,CAAA;AAC7D,EAAA,IAAI,WAAa,EAAA;AACf,IAAM,MAAA,KAAA,GAAQ,iBAAiB,WAAW,CAAA,CAAA;AAC1C,IAAM,MAAA,aAAA,GAAgB,KAAM,CAAA,gBAAA,CAAiB,eAAe,CAAA,CAAA;AAC5D,IAAA,IAAI,aAAe,EAAA;AACjB,MAAO,OAAA,aAAA,CAAA;AAAA,KACT;AAAA,GACF;AACA,EAAO,OAAA,IAAA,CAAA;AACT;;;;"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
function createChainedFunction(...funcs) {
|
|
6
|
+
return funcs.reduce(
|
|
7
|
+
(acc, func) => {
|
|
8
|
+
if (func == null) {
|
|
9
|
+
return acc;
|
|
10
|
+
}
|
|
11
|
+
return function chainedFunction(...args) {
|
|
12
|
+
acc.apply(this, args);
|
|
13
|
+
func.apply(this, args);
|
|
14
|
+
};
|
|
15
|
+
},
|
|
16
|
+
() => {
|
|
17
|
+
}
|
|
18
|
+
);
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
exports.createChainedFunction = createChainedFunction;
|
|
22
|
+
//# sourceMappingURL=createChainedFunction.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createChainedFunction.js","sources":["../src/utils/createChainedFunction.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\n\ntype ChainedFunction<Args extends any[], This> =\n | ((this: This, ...args: Args) => any)\n | undefined\n | null;\n\nexport function createChainedFunction<Args extends any[], This>(\n ...funcs: ChainedFunction<Args, This>[]\n): (this: This, ...args: Args) => any {\n return funcs.reduce<(this: This, ...args: Args) => any>(\n (acc, func) => {\n if (func == null) {\n return acc;\n }\n\n return function chainedFunction(...args) {\n acc.apply(this, args);\n func.apply(this, args);\n };\n },\n // eslint-disable-next-line @typescript-eslint/no-empty-function\n () => {}\n );\n}\n"],"names":[],"mappings":";;;;AAOO,SAAS,yBACX,KACiC,EAAA;AACpC,EAAA,OAAO,KAAM,CAAA,MAAA;AAAA,IACX,CAAC,KAAK,IAAS,KAAA;AACb,MAAA,IAAI,QAAQ,IAAM,EAAA;AAChB,QAAO,OAAA,GAAA,CAAA;AAAA,OACT;AAEA,MAAO,OAAA,SAAS,mBAAmB,IAAM,EAAA;AACvC,QAAI,GAAA,CAAA,KAAA,CAAM,MAAM,IAAI,CAAA,CAAA;AACpB,QAAK,IAAA,CAAA,KAAA,CAAM,MAAM,IAAI,CAAA,CAAA;AAAA,OACvB,CAAA;AAAA,KACF;AAAA,IAEA,MAAM;AAAA,KAAC;AAAA,GACT,CAAA;AACF;;;;"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var React = require('react');
|
|
6
|
+
|
|
7
|
+
function createContext(name, defaultValue) {
|
|
8
|
+
const context = React.createContext(defaultValue);
|
|
9
|
+
if (process.env.NODE_ENV !== "production") {
|
|
10
|
+
context.displayName = name;
|
|
11
|
+
}
|
|
12
|
+
return context;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
exports.createContext = createContext;
|
|
16
|
+
//# sourceMappingURL=createContext.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createContext.js","sources":["../src/utils/createContext.ts"],"sourcesContent":["import { createContext as createReactContext, Context } from \"react\";\n\nexport function createContext<ContextValueType>(\n name: string,\n defaultValue: ContextValueType\n): Context<ContextValueType> {\n const context = createReactContext<ContextValueType>(defaultValue);\n if (process.env.NODE_ENV !== \"production\") {\n context.displayName = name;\n }\n return context;\n}\n"],"names":["createReactContext"],"mappings":";;;;;;AAEgB,SAAA,aAAA,CACd,MACA,YAC2B,EAAA;AAC3B,EAAM,MAAA,OAAA,GAAUA,oBAAqC,YAAY,CAAA,CAAA;AACjE,EAAI,IAAA,OAAA,CAAQ,GAAI,CAAA,QAAA,KAAa,YAAc,EAAA;AACzC,IAAA,OAAA,CAAQ,WAAc,GAAA,IAAA,CAAA;AAAA,GACxB;AACA,EAAO,OAAA,OAAA,CAAA;AACT;;;;"}
|