@bigbinary/neetoui 7.0.3 → 7.0.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/Accordion.js +2 -290
- package/dist/Accordion.js.map +1 -1
- package/dist/ActionDropdown.js +1 -1
- package/dist/Alert.js +1 -1
- package/dist/Button.js +1 -1
- package/dist/Checkbox.js +1 -1
- package/dist/ColorPicker.js +1 -1
- package/dist/DatePicker.js +4 -4
- package/dist/DateTimePicker.js +4 -4
- package/dist/Dropdown.js +1 -1
- package/dist/{HeaderCellMenu-810f0594.js → HeaderCellMenu-4e7c17aa.js} +1 -1
- package/dist/{HeaderCellMenu-810f0594.js.map → HeaderCellMenu-4e7c17aa.js.map} +1 -1
- package/dist/Input.js +1 -1
- package/dist/Label.js +1 -1
- package/dist/Modal.js +1 -1
- package/dist/MultiEmailInput.js +1 -1
- package/dist/NoData.js +1 -1
- package/dist/Pane.js +1 -1
- package/dist/ProgressBar.js +1 -1
- package/dist/Radio.js +1 -1
- package/dist/Select.js +1 -1
- package/dist/Slider.js +1 -1
- package/dist/Switch.js +1 -1
- package/dist/Table.js +2 -2
- package/dist/{Textarea-e836f83e.js → Textarea-938a680f.js} +1 -1
- package/dist/{Textarea-e836f83e.js.map → Textarea-938a680f.js.map} +1 -1
- package/dist/Textarea.js +2 -2
- package/dist/TimePicker.js +4 -4
- package/dist/TimePickerInput.js +1 -1
- package/dist/TreeSelect.js +1 -1
- package/dist/cjs/Accordion.js +3 -309
- package/dist/cjs/Accordion.js.map +1 -1
- package/dist/cjs/ActionDropdown.js +1 -1
- package/dist/cjs/Alert.js +1 -1
- package/dist/cjs/Button.js +4 -4
- package/dist/cjs/Button.js.map +1 -1
- package/dist/cjs/Checkbox.js +1 -1
- package/dist/cjs/ColorPicker.js +1 -1
- package/dist/cjs/DatePicker.js +4 -4
- package/dist/cjs/DateTimePicker.js +4 -4
- package/dist/cjs/Dropdown.js +1 -1
- package/dist/cjs/{HeaderCellMenu-1b56b4e1.js → HeaderCellMenu-a3d12310.js} +1 -1
- package/dist/cjs/{HeaderCellMenu-1b56b4e1.js.map → HeaderCellMenu-a3d12310.js.map} +1 -1
- package/dist/cjs/Input.js +1 -1
- package/dist/cjs/Label.js +1 -1
- package/dist/cjs/Modal.js +1 -1
- package/dist/cjs/MultiEmailInput.js +1 -1
- package/dist/cjs/NoData.js +1 -1
- package/dist/cjs/Pane.js +1 -1
- package/dist/cjs/ProgressBar.js +2 -2
- package/dist/cjs/ProgressBar.js.map +1 -1
- package/dist/cjs/Radio.js +1 -1
- package/dist/cjs/Select.js +1 -1
- package/dist/cjs/Slider.js +1 -1
- package/dist/cjs/Switch.js +1 -1
- package/dist/cjs/Table.js +2 -2
- package/dist/cjs/{Textarea-2711696e.js → Textarea-0975f6d6.js} +1 -1
- package/dist/cjs/{Textarea-2711696e.js.map → Textarea-0975f6d6.js.map} +1 -1
- package/dist/cjs/Textarea.js +2 -2
- package/dist/cjs/TimePicker.js +4 -4
- package/dist/cjs/TimePickerInput.js +1 -1
- package/dist/cjs/TreeSelect.js +1 -1
- package/dist/cjs/formik/ActionBlock.js +1 -1
- package/dist/cjs/formik/BlockNavigation.js +1 -1
- package/dist/cjs/formik/Button.js +1 -1
- package/dist/cjs/formik/Checkbox.js +1 -1
- package/dist/cjs/formik/Input.js +1 -1
- package/dist/cjs/formik/MultiEmailInput.js +1 -1
- package/dist/cjs/formik/Radio.js +1 -1
- package/dist/cjs/formik/Select.js +1 -1
- package/dist/cjs/formik/Slider.js +1 -1
- package/dist/cjs/formik/Switch.js +1 -1
- package/dist/cjs/formik/Textarea.js +2 -2
- package/dist/cjs/formik/TreeSelect.js +1 -1
- package/dist/cjs/formik/index.js +2 -2
- package/dist/cjs/{index-0d54eb09.js → index-327e31a2.js} +4 -3
- package/dist/cjs/{index-0d54eb09.js.map → index-327e31a2.js.map} +1 -1
- package/dist/cjs/index.js +4 -4
- package/dist/formik/ActionBlock.js +1 -1
- package/dist/formik/BlockNavigation.js +1 -1
- package/dist/formik/Button.js +1 -1
- package/dist/formik/Checkbox.js +1 -1
- package/dist/formik/Input.js +1 -1
- package/dist/formik/MultiEmailInput.js +1 -1
- package/dist/formik/Radio.js +1 -1
- package/dist/formik/Select.js +1 -1
- package/dist/formik/Slider.js +1 -1
- package/dist/formik/Switch.js +1 -1
- package/dist/formik/Textarea.js +2 -2
- package/dist/formik/TreeSelect.js +1 -1
- package/dist/formik/index.js +2 -2
- package/dist/{index-4a662f27.js → index-eb249a9f.js} +4 -3
- package/dist/{index-4a662f27.js.map → index-eb249a9f.js.map} +1 -1
- package/dist/index.js +4 -4
- package/package.json +3 -2
- package/dist/cjs/motion-a1906aff.js +0 -8892
- package/dist/cjs/motion-a1906aff.js.map +0 -1
- package/dist/motion-087daf52.js +0 -8862
- package/dist/motion-087daf52.js.map +0 -1
package/dist/Label.js
CHANGED
|
@@ -9,7 +9,7 @@ import Popover from './Popover.js';
|
|
|
9
9
|
import Tooltip from './Tooltip.js';
|
|
10
10
|
import Typography from './Typography.js';
|
|
11
11
|
import 'react-router-dom';
|
|
12
|
-
import '
|
|
12
|
+
import 'framer-motion';
|
|
13
13
|
import '@babel/runtime/helpers/slicedToArray';
|
|
14
14
|
import '@tippyjs/react';
|
|
15
15
|
import 'tippy.js';
|
package/dist/Modal.js
CHANGED
|
@@ -28,7 +28,7 @@ import 'dayjs/plugin/utc';
|
|
|
28
28
|
import 'dayjs/plugin/weekday';
|
|
29
29
|
import 'dayjs/plugin/weekOfYear';
|
|
30
30
|
import '@bigbinary/neeto-cist';
|
|
31
|
-
import '
|
|
31
|
+
import 'framer-motion';
|
|
32
32
|
import './Tooltip.js';
|
|
33
33
|
import '@tippyjs/react';
|
|
34
34
|
import 'tippy.js';
|
package/dist/MultiEmailInput.js
CHANGED
package/dist/NoData.js
CHANGED
|
@@ -7,7 +7,7 @@ import Button from './Button.js';
|
|
|
7
7
|
import Typography from './Typography.js';
|
|
8
8
|
import '@babel/runtime/helpers/defineProperty';
|
|
9
9
|
import 'react-router-dom';
|
|
10
|
-
import '
|
|
10
|
+
import 'framer-motion';
|
|
11
11
|
import './Tooltip.js';
|
|
12
12
|
import '@babel/runtime/helpers/slicedToArray';
|
|
13
13
|
import '@tippyjs/react';
|
package/dist/Pane.js
CHANGED
|
@@ -27,7 +27,7 @@ import 'dayjs/plugin/utc';
|
|
|
27
27
|
import 'dayjs/plugin/weekday';
|
|
28
28
|
import 'dayjs/plugin/weekOfYear';
|
|
29
29
|
import '@bigbinary/neeto-cist';
|
|
30
|
-
import '
|
|
30
|
+
import 'framer-motion';
|
|
31
31
|
import './Tooltip.js';
|
|
32
32
|
import '@tippyjs/react';
|
|
33
33
|
import 'tippy.js';
|
package/dist/ProgressBar.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import React__default from 'react';
|
|
2
2
|
import classnames from 'classnames';
|
|
3
|
-
import {
|
|
3
|
+
import { motion } from 'framer-motion';
|
|
4
4
|
|
|
5
5
|
var ProgressBar = function ProgressBar(_ref) {
|
|
6
6
|
var progressPercentage = _ref.progressPercentage,
|
package/dist/Radio.js
CHANGED
|
@@ -13,7 +13,7 @@ import { h as hyphenize } from './index-9d5142b4.js';
|
|
|
13
13
|
import 'qs';
|
|
14
14
|
import '@bigbinary/neeto-icons';
|
|
15
15
|
import './Button.js';
|
|
16
|
-
import '
|
|
16
|
+
import 'framer-motion';
|
|
17
17
|
import './Tooltip.js';
|
|
18
18
|
import '@tippyjs/react';
|
|
19
19
|
import 'tippy.js';
|
package/dist/Select.js
CHANGED
package/dist/Slider.js
CHANGED
package/dist/Switch.js
CHANGED
package/dist/Table.js
CHANGED
|
@@ -18,7 +18,7 @@ import { u as useQueryParams } from './useQueryParams-dcb34865.js';
|
|
|
18
18
|
import Button from './Button.js';
|
|
19
19
|
import Callout from './Callout.js';
|
|
20
20
|
import Typography from './Typography.js';
|
|
21
|
-
import { T as TABLE_SORT_ORDERS, U as URL_SORT_ORDERS, H as HeaderCellMenu } from './HeaderCellMenu-
|
|
21
|
+
import { T as TABLE_SORT_ORDERS, U as URL_SORT_ORDERS, H as HeaderCellMenu } from './HeaderCellMenu-4e7c17aa.js';
|
|
22
22
|
import _toConsumableArray from '@babel/runtime/helpers/toConsumableArray';
|
|
23
23
|
import { Resizable } from 'react-resizable';
|
|
24
24
|
import '@babel/runtime/helpers/classCallCheck';
|
|
@@ -29,7 +29,7 @@ import 'dayjs/plugin/utc';
|
|
|
29
29
|
import 'dayjs/plugin/weekday';
|
|
30
30
|
import 'dayjs/plugin/weekOfYear';
|
|
31
31
|
import 'qs';
|
|
32
|
-
import '
|
|
32
|
+
import 'framer-motion';
|
|
33
33
|
import './Tooltip.js';
|
|
34
34
|
import '@tippyjs/react';
|
|
35
35
|
import 'tippy.js';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Textarea-e836f83e.js","sources":["../src/hooks/useSyncedRef.js","../src/components/Textarea.jsx"],"sourcesContent":["import { useEffect, useRef } from \"react\";\n\nconst useSyncedRef = ref => {\n const innerRef = useRef();\n\n useEffect(() => {\n if (!ref) return;\n\n if (typeof ref === \"function\") {\n ref(innerRef.current);\n } else {\n ref.current = innerRef.current;\n }\n });\n\n return innerRef;\n};\n\nexport default useSyncedRef;\n","import React, { useState, useEffect, forwardRef } from \"react\";\n\nimport classnames from \"classnames\";\nimport PropTypes from \"prop-types\";\n\nimport { useSyncedRef, useId } from \"hooks\";\nimport { hyphenize } from \"utils\";\n\nimport Label from \"./Label\";\n\nconst SIZES = { small: \"small\", medium: \"medium\", large: \"large\" };\n\nconst ROWS = { small: 1, medium: 3, large: 4 };\n\nconst RESIZE = { vertical: \"vertical\", none: \"none\" };\n\nconst Textarea = forwardRef(\n (\n {\n size = SIZES.medium,\n resize = RESIZE.vertical,\n suffix = null,\n prefix = null,\n disabled = false,\n required = false,\n nakedTextarea = false,\n helpText = \"\",\n error = \"\",\n label = \"\",\n className = \"\",\n maxLength,\n unlimitedChars = false,\n labelProps,\n onBlur,\n disableTrimOnBlur = false,\n ...otherProps\n },\n ref\n ) => {\n const [valueInternal, setValueInternal] = useState(\"\");\n\n const value = otherProps.value ?? valueInternal ?? \"\";\n\n const id = useId(otherProps.id);\n const errorId = `error_${id}`;\n const helpTextId = `helpText_${id}`;\n const textareaRef = useSyncedRef(ref);\n\n const valueLength = value?.toString().length || 0;\n const isCharacterLimitVisible = valueLength >= maxLength * 0.85;\n const maxLengthError = unlimitedChars && valueLength > maxLength;\n\n const onChangeInternal = e => setValueInternal(e.target.value);\n const onChange = otherProps.onChange ?? onChangeInternal;\n const isMaxLengthPresent = !!maxLength || maxLength === 0;\n\n useEffect(() => {\n textareaRef.current.style.minHeight = \"22px\";\n textareaRef.current.style.height = \"auto\";\n const scrollHeight = textareaRef.current.scrollHeight;\n textareaRef.current.style.height = `${scrollHeight + 1}px`;\n }, [value]);\n\n const handleTrimmedChangeOnBlur = e => {\n if (disableTrimOnBlur || typeof value !== \"string\") return;\n\n const trimmedValue = value.trim();\n if (value === trimmedValue) return;\n\n e.target.value = trimmedValue;\n onChange(e);\n };\n\n const handleOnBlur = e => {\n handleTrimmedChangeOnBlur(e);\n onBlur?.(e);\n };\n\n return (\n <div className={classnames([\"neeto-ui-input__wrapper\", className])}>\n <div className=\"neeto-ui-input__label-wrapper\">\n {label && (\n <Label\n {...{ required }}\n data-cy={`${hyphenize(label)}-label`}\n htmlFor={id}\n {...labelProps}\n >\n {label}\n </Label>\n )}\n {isCharacterLimitVisible && (\n <p\n className={classnames(\"neeto-ui-input__max-length\", {\n \"neeto-ui-input__max-length--error\": maxLengthError,\n })}\n >\n {valueLength}/{maxLength}\n </p>\n )}\n </div>\n <div\n data-cy={`${hyphenize(label)}-text-input`}\n className={classnames(\"neeto-ui-input\", \"neeto-ui-input--textarea\", {\n \"neeto-ui-input--error\": !!error,\n \"neeto-ui-input--disabled\": !!disabled,\n \"neeto-ui-input--naked\": !!nakedTextarea,\n \"neeto-ui-input--small\": size === SIZES.small,\n \"neeto-ui-input--medium\": size === SIZES.medium,\n \"neeto-ui-input--large\": size === SIZES.large,\n \"neeto-ui-input--resize--vertical\": resize === RESIZE.vertical,\n \"neeto-ui-input--resize--none\": resize === RESIZE.none,\n })}\n >\n {prefix && <div className=\"neeto-ui-input__prefix\">{prefix}</div>}\n <textarea\n ref={textareaRef}\n rows={ROWS[size]}\n {...{\n disabled,\n ...(isMaxLengthPresent && !unlimitedChars && { maxLength }),\n ...otherProps,\n onChange,\n value,\n }}\n onBlur={handleOnBlur}\n />\n {suffix && <div className=\"neeto-ui-input__suffix\">{suffix}</div>}\n </div>\n {!!error && (\n <p\n className=\"neeto-ui-input__error\"\n data-cy={`${hyphenize(label)}-input-error`}\n id={errorId}\n >\n {error}\n </p>\n )}\n {helpText && (\n <p className=\"neeto-ui-input__help-text\" id={helpTextId}>\n {helpText}\n </p>\n )}\n </div>\n );\n }\n);\n\nTextarea.displayName = \"Textarea\";\n\nTextarea.propTypes = {\n /**\n * To specify the row height of the Textarea.\n */\n rows: PropTypes.number,\n /**\n * To specify the size of Textarea.\n */\n size: PropTypes.oneOf(Object.values(SIZES)),\n /**\n * To specify the label shown above the Textarea.\n */\n label: PropTypes.string,\n /**\n * To specify the label props to be passed to the Label component.\n */\n labelProps: PropTypes.object,\n /**\n * To provide the value of the Textarea.\n */\n value: PropTypes.string,\n /**\n * To provide the error message shown below the Textarea.\n */\n error: PropTypes.string,\n /**\n * To provide the placeholder text for the Textarea.\n */\n placeholder: PropTypes.string,\n /**\n * To specify whether the Textarea is required.\n */\n required: PropTypes.bool,\n /**\n * To specify whether the Textarea is disabled.\n */\n disabled: PropTypes.bool,\n /**\n * To provide additional classnames to the Textarea container.\n */\n className: PropTypes.string,\n /**\n * The resize property sets whether the Textarea is resizable.\n */\n resize: PropTypes.oneOf(Object.values(RESIZE)),\n /**\n * To specify the text that appears below the Textarea.\n */\n helpText: PropTypes.string,\n /**\n * To create a Textarea without any borders.\n */\n nakedTextarea: PropTypes.bool,\n /**\n * To specify a maximum character limit to the Textarea. Charater limit is visible only if the Textarea value is greater than or equal to 85% of the maximum character limit.\n */\n maxLength: PropTypes.number,\n /**\n * To be used along with maxLength prop. When set to true the character limit will not be enforced and character count will be shown in error state if the character limit is exceeded.\n */\n unlimitedChars: PropTypes.bool,\n /**\n * To specify the content to be added at the end of the Textarea.\n */\n suffix: PropTypes.node,\n /**\n * To specify the content to be added at the beginning of the Textarea.\n */\n prefix: PropTypes.node,\n /**\n * To disable leading and trailing white spaces onBlur.\n */\n disableTrimOnBlur: PropTypes.bool,\n};\n\nexport default Textarea;\n"],"names":["useSyncedRef","ref","innerRef","useRef","useEffect","current","SIZES","small","medium","large","ROWS","RESIZE","vertical","none","Textarea","forwardRef","_ref","_ref2","_otherProps$value","_otherProps$onChange","_ref$size","size","_ref$resize","resize","_ref$suffix","suffix","_ref$prefix","prefix","_ref$disabled","disabled","_ref$required","required","_ref$nakedTextarea","nakedTextarea","_ref$helpText","helpText","_ref$error","error","_ref$label","label","_ref$className","className","maxLength","_ref$unlimitedChars","unlimitedChars","labelProps","onBlur","_ref$disableTrimOnBlu","disableTrimOnBlur","otherProps","_objectWithoutProperties","_excluded","_useState","useState","_useState2","_slicedToArray","valueInternal","setValueInternal","value","id","useId","errorId","concat","helpTextId","textareaRef","valueLength","toString","length","isCharacterLimitVisible","maxLengthError","onChangeInternal","e","target","onChange","isMaxLengthPresent","style","minHeight","height","scrollHeight","handleTrimmedChangeOnBlur","trimmedValue","trim","handleOnBlur","React","createElement","classnames","Label","_extends","hyphenize","htmlFor","rows","_objectSpread","displayName"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"Textarea-938a680f.js","sources":["../src/hooks/useSyncedRef.js","../src/components/Textarea.jsx"],"sourcesContent":["import { useEffect, useRef } from \"react\";\n\nconst useSyncedRef = ref => {\n const innerRef = useRef();\n\n useEffect(() => {\n if (!ref) return;\n\n if (typeof ref === \"function\") {\n ref(innerRef.current);\n } else {\n ref.current = innerRef.current;\n }\n });\n\n return innerRef;\n};\n\nexport default useSyncedRef;\n","import React, { useState, useEffect, forwardRef } from \"react\";\n\nimport classnames from \"classnames\";\nimport PropTypes from \"prop-types\";\n\nimport { useSyncedRef, useId } from \"hooks\";\nimport { hyphenize } from \"utils\";\n\nimport Label from \"./Label\";\n\nconst SIZES = { small: \"small\", medium: \"medium\", large: \"large\" };\n\nconst ROWS = { small: 1, medium: 3, large: 4 };\n\nconst RESIZE = { vertical: \"vertical\", none: \"none\" };\n\nconst Textarea = forwardRef(\n (\n {\n size = SIZES.medium,\n resize = RESIZE.vertical,\n suffix = null,\n prefix = null,\n disabled = false,\n required = false,\n nakedTextarea = false,\n helpText = \"\",\n error = \"\",\n label = \"\",\n className = \"\",\n maxLength,\n unlimitedChars = false,\n labelProps,\n onBlur,\n disableTrimOnBlur = false,\n ...otherProps\n },\n ref\n ) => {\n const [valueInternal, setValueInternal] = useState(\"\");\n\n const value = otherProps.value ?? valueInternal ?? \"\";\n\n const id = useId(otherProps.id);\n const errorId = `error_${id}`;\n const helpTextId = `helpText_${id}`;\n const textareaRef = useSyncedRef(ref);\n\n const valueLength = value?.toString().length || 0;\n const isCharacterLimitVisible = valueLength >= maxLength * 0.85;\n const maxLengthError = unlimitedChars && valueLength > maxLength;\n\n const onChangeInternal = e => setValueInternal(e.target.value);\n const onChange = otherProps.onChange ?? onChangeInternal;\n const isMaxLengthPresent = !!maxLength || maxLength === 0;\n\n useEffect(() => {\n textareaRef.current.style.minHeight = \"22px\";\n textareaRef.current.style.height = \"auto\";\n const scrollHeight = textareaRef.current.scrollHeight;\n textareaRef.current.style.height = `${scrollHeight + 1}px`;\n }, [value]);\n\n const handleTrimmedChangeOnBlur = e => {\n if (disableTrimOnBlur || typeof value !== \"string\") return;\n\n const trimmedValue = value.trim();\n if (value === trimmedValue) return;\n\n e.target.value = trimmedValue;\n onChange(e);\n };\n\n const handleOnBlur = e => {\n handleTrimmedChangeOnBlur(e);\n onBlur?.(e);\n };\n\n return (\n <div className={classnames([\"neeto-ui-input__wrapper\", className])}>\n <div className=\"neeto-ui-input__label-wrapper\">\n {label && (\n <Label\n {...{ required }}\n data-cy={`${hyphenize(label)}-label`}\n htmlFor={id}\n {...labelProps}\n >\n {label}\n </Label>\n )}\n {isCharacterLimitVisible && (\n <p\n className={classnames(\"neeto-ui-input__max-length\", {\n \"neeto-ui-input__max-length--error\": maxLengthError,\n })}\n >\n {valueLength}/{maxLength}\n </p>\n )}\n </div>\n <div\n data-cy={`${hyphenize(label)}-text-input`}\n className={classnames(\"neeto-ui-input\", \"neeto-ui-input--textarea\", {\n \"neeto-ui-input--error\": !!error,\n \"neeto-ui-input--disabled\": !!disabled,\n \"neeto-ui-input--naked\": !!nakedTextarea,\n \"neeto-ui-input--small\": size === SIZES.small,\n \"neeto-ui-input--medium\": size === SIZES.medium,\n \"neeto-ui-input--large\": size === SIZES.large,\n \"neeto-ui-input--resize--vertical\": resize === RESIZE.vertical,\n \"neeto-ui-input--resize--none\": resize === RESIZE.none,\n })}\n >\n {prefix && <div className=\"neeto-ui-input__prefix\">{prefix}</div>}\n <textarea\n ref={textareaRef}\n rows={ROWS[size]}\n {...{\n disabled,\n ...(isMaxLengthPresent && !unlimitedChars && { maxLength }),\n ...otherProps,\n onChange,\n value,\n }}\n onBlur={handleOnBlur}\n />\n {suffix && <div className=\"neeto-ui-input__suffix\">{suffix}</div>}\n </div>\n {!!error && (\n <p\n className=\"neeto-ui-input__error\"\n data-cy={`${hyphenize(label)}-input-error`}\n id={errorId}\n >\n {error}\n </p>\n )}\n {helpText && (\n <p className=\"neeto-ui-input__help-text\" id={helpTextId}>\n {helpText}\n </p>\n )}\n </div>\n );\n }\n);\n\nTextarea.displayName = \"Textarea\";\n\nTextarea.propTypes = {\n /**\n * To specify the row height of the Textarea.\n */\n rows: PropTypes.number,\n /**\n * To specify the size of Textarea.\n */\n size: PropTypes.oneOf(Object.values(SIZES)),\n /**\n * To specify the label shown above the Textarea.\n */\n label: PropTypes.string,\n /**\n * To specify the label props to be passed to the Label component.\n */\n labelProps: PropTypes.object,\n /**\n * To provide the value of the Textarea.\n */\n value: PropTypes.string,\n /**\n * To provide the error message shown below the Textarea.\n */\n error: PropTypes.string,\n /**\n * To provide the placeholder text for the Textarea.\n */\n placeholder: PropTypes.string,\n /**\n * To specify whether the Textarea is required.\n */\n required: PropTypes.bool,\n /**\n * To specify whether the Textarea is disabled.\n */\n disabled: PropTypes.bool,\n /**\n * To provide additional classnames to the Textarea container.\n */\n className: PropTypes.string,\n /**\n * The resize property sets whether the Textarea is resizable.\n */\n resize: PropTypes.oneOf(Object.values(RESIZE)),\n /**\n * To specify the text that appears below the Textarea.\n */\n helpText: PropTypes.string,\n /**\n * To create a Textarea without any borders.\n */\n nakedTextarea: PropTypes.bool,\n /**\n * To specify a maximum character limit to the Textarea. Charater limit is visible only if the Textarea value is greater than or equal to 85% of the maximum character limit.\n */\n maxLength: PropTypes.number,\n /**\n * To be used along with maxLength prop. When set to true the character limit will not be enforced and character count will be shown in error state if the character limit is exceeded.\n */\n unlimitedChars: PropTypes.bool,\n /**\n * To specify the content to be added at the end of the Textarea.\n */\n suffix: PropTypes.node,\n /**\n * To specify the content to be added at the beginning of the Textarea.\n */\n prefix: PropTypes.node,\n /**\n * To disable leading and trailing white spaces onBlur.\n */\n disableTrimOnBlur: PropTypes.bool,\n};\n\nexport default Textarea;\n"],"names":["useSyncedRef","ref","innerRef","useRef","useEffect","current","SIZES","small","medium","large","ROWS","RESIZE","vertical","none","Textarea","forwardRef","_ref","_ref2","_otherProps$value","_otherProps$onChange","_ref$size","size","_ref$resize","resize","_ref$suffix","suffix","_ref$prefix","prefix","_ref$disabled","disabled","_ref$required","required","_ref$nakedTextarea","nakedTextarea","_ref$helpText","helpText","_ref$error","error","_ref$label","label","_ref$className","className","maxLength","_ref$unlimitedChars","unlimitedChars","labelProps","onBlur","_ref$disableTrimOnBlu","disableTrimOnBlur","otherProps","_objectWithoutProperties","_excluded","_useState","useState","_useState2","_slicedToArray","valueInternal","setValueInternal","value","id","useId","errorId","concat","helpTextId","textareaRef","valueLength","toString","length","isCharacterLimitVisible","maxLengthError","onChangeInternal","e","target","onChange","isMaxLengthPresent","style","minHeight","height","scrollHeight","handleTrimmedChangeOnBlur","trimmedValue","trim","handleOnBlur","React","createElement","classnames","Label","_extends","hyphenize","htmlFor","rows","_objectSpread","displayName"],"mappings":"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"}
|
package/dist/Textarea.js
CHANGED
|
@@ -10,7 +10,7 @@ import '@bigbinary/neeto-hotkeys';
|
|
|
10
10
|
import './overlayManager.js';
|
|
11
11
|
import './index-9d5142b4.js';
|
|
12
12
|
import 'qs';
|
|
13
|
-
export { T as default } from './Textarea-
|
|
13
|
+
export { T as default } from './Textarea-938a680f.js';
|
|
14
14
|
import './Label.js';
|
|
15
15
|
import '@babel/runtime/helpers/classCallCheck';
|
|
16
16
|
import '@babel/runtime/helpers/createClass';
|
|
@@ -23,7 +23,7 @@ import '@bigbinary/neeto-cist';
|
|
|
23
23
|
import 'ramda';
|
|
24
24
|
import '@bigbinary/neeto-icons';
|
|
25
25
|
import './Button.js';
|
|
26
|
-
import '
|
|
26
|
+
import 'framer-motion';
|
|
27
27
|
import './Tooltip.js';
|
|
28
28
|
import '@tippyjs/react';
|
|
29
29
|
import 'tippy.js';
|
package/dist/TimePicker.js
CHANGED
|
@@ -22,7 +22,7 @@ import 'react-colorful';
|
|
|
22
22
|
import './tinycolor-282c618c.js';
|
|
23
23
|
import './Dropdown.js';
|
|
24
24
|
import './index-9d5142b4.js';
|
|
25
|
-
export { T as default } from './index-
|
|
25
|
+
export { T as default } from './index-eb249a9f.js';
|
|
26
26
|
import './Input.js';
|
|
27
27
|
import './Label.js';
|
|
28
28
|
import './MultiEmailInput.js';
|
|
@@ -31,10 +31,11 @@ import './useId-c1d20bba.js';
|
|
|
31
31
|
import '@bigbinary/neeto-hotkeys';
|
|
32
32
|
import './overlayManager.js';
|
|
33
33
|
import 'qs';
|
|
34
|
-
import './Textarea-
|
|
34
|
+
import './Textarea-938a680f.js';
|
|
35
35
|
import '@babel/runtime/helpers/toConsumableArray';
|
|
36
36
|
import './Pane.js';
|
|
37
37
|
import './Popover.js';
|
|
38
|
+
import 'framer-motion';
|
|
38
39
|
import './Radio.js';
|
|
39
40
|
import '@bigbinary/neeto-cist';
|
|
40
41
|
import '@babel/runtime/helpers/esm/objectSpread2';
|
|
@@ -57,14 +58,13 @@ import './Switch.js';
|
|
|
57
58
|
import './Tab.js';
|
|
58
59
|
import 'antd/lib/table';
|
|
59
60
|
import 'react-drag-listview';
|
|
60
|
-
import './HeaderCellMenu-
|
|
61
|
+
import './HeaderCellMenu-4e7c17aa.js';
|
|
61
62
|
import 'react-resizable';
|
|
62
63
|
import './Tag.js';
|
|
63
64
|
import './TimePickerInput.js';
|
|
64
65
|
import './Toastr.js';
|
|
65
66
|
import 'antd/lib/tree';
|
|
66
67
|
import './TreeSelect.js';
|
|
67
|
-
import './motion-087daf52.js';
|
|
68
68
|
import 'dayjs';
|
|
69
69
|
import 'dayjs/plugin/localeData';
|
|
70
70
|
import 'dayjs/plugin/utc';
|
package/dist/TimePickerInput.js
CHANGED
|
@@ -18,7 +18,7 @@ import { h as hyphenize, n as noop } from './index-9d5142b4.js';
|
|
|
18
18
|
import 'qs';
|
|
19
19
|
import { Close, Clock } from '@bigbinary/neeto-icons';
|
|
20
20
|
import './Button.js';
|
|
21
|
-
import '
|
|
21
|
+
import 'framer-motion';
|
|
22
22
|
import './Tooltip.js';
|
|
23
23
|
import '@tippyjs/react';
|
|
24
24
|
import 'tippy.js';
|
package/dist/TreeSelect.js
CHANGED
package/dist/cjs/Accordion.js
CHANGED
|
@@ -7,324 +7,18 @@ var _objectWithoutProperties = require('@babel/runtime/helpers/objectWithoutProp
|
|
|
7
7
|
var React = require('react');
|
|
8
8
|
var classnames = require('classnames');
|
|
9
9
|
var ramda = require('ramda');
|
|
10
|
+
var framerMotion = require('framer-motion');
|
|
10
11
|
var neetoIcons = require('@bigbinary/neeto-icons');
|
|
11
|
-
var motion = require('./motion-a1906aff.js');
|
|
12
12
|
|
|
13
13
|
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
14
14
|
|
|
15
|
-
function _interopNamespace(e) {
|
|
16
|
-
if (e && e.__esModule) return e;
|
|
17
|
-
var n = Object.create(null);
|
|
18
|
-
if (e) {
|
|
19
|
-
Object.keys(e).forEach(function (k) {
|
|
20
|
-
if (k !== 'default') {
|
|
21
|
-
var d = Object.getOwnPropertyDescriptor(e, k);
|
|
22
|
-
Object.defineProperty(n, k, d.get ? d : {
|
|
23
|
-
enumerable: true,
|
|
24
|
-
get: function () { return e[k]; }
|
|
25
|
-
});
|
|
26
|
-
}
|
|
27
|
-
});
|
|
28
|
-
}
|
|
29
|
-
n["default"] = e;
|
|
30
|
-
return Object.freeze(n);
|
|
31
|
-
}
|
|
32
|
-
|
|
33
15
|
var _extends__default = /*#__PURE__*/_interopDefaultLegacy(_extends);
|
|
34
16
|
var _defineProperty__default = /*#__PURE__*/_interopDefaultLegacy(_defineProperty);
|
|
35
17
|
var _slicedToArray__default = /*#__PURE__*/_interopDefaultLegacy(_slicedToArray);
|
|
36
18
|
var _objectWithoutProperties__default = /*#__PURE__*/_interopDefaultLegacy(_objectWithoutProperties);
|
|
37
|
-
var React__namespace = /*#__PURE__*/_interopNamespace(React);
|
|
38
19
|
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
39
20
|
var classnames__default = /*#__PURE__*/_interopDefaultLegacy(classnames);
|
|
40
21
|
|
|
41
|
-
function useIsMounted() {
|
|
42
|
-
const isMounted = React.useRef(false);
|
|
43
|
-
motion.useIsomorphicLayoutEffect(() => {
|
|
44
|
-
isMounted.current = true;
|
|
45
|
-
return () => {
|
|
46
|
-
isMounted.current = false;
|
|
47
|
-
};
|
|
48
|
-
}, []);
|
|
49
|
-
return isMounted;
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
function useForceUpdate() {
|
|
53
|
-
const isMounted = useIsMounted();
|
|
54
|
-
const [forcedRenderCount, setForcedRenderCount] = React.useState(0);
|
|
55
|
-
const forceRender = React.useCallback(() => {
|
|
56
|
-
isMounted.current && setForcedRenderCount(forcedRenderCount + 1);
|
|
57
|
-
}, [forcedRenderCount]);
|
|
58
|
-
/**
|
|
59
|
-
* Defer this to the end of the next animation frame in case there are multiple
|
|
60
|
-
* synchronous calls.
|
|
61
|
-
*/
|
|
62
|
-
const deferredForceRender = React.useCallback(() => motion.frame.postRender(forceRender), [forceRender]);
|
|
63
|
-
return [deferredForceRender, forcedRenderCount];
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
/**
|
|
67
|
-
* Measurement functionality has to be within a separate component
|
|
68
|
-
* to leverage snapshot lifecycle.
|
|
69
|
-
*/
|
|
70
|
-
class PopChildMeasure extends React__namespace.Component {
|
|
71
|
-
getSnapshotBeforeUpdate(prevProps) {
|
|
72
|
-
const element = this.props.childRef.current;
|
|
73
|
-
if (element && prevProps.isPresent && !this.props.isPresent) {
|
|
74
|
-
const size = this.props.sizeRef.current;
|
|
75
|
-
size.height = element.offsetHeight || 0;
|
|
76
|
-
size.width = element.offsetWidth || 0;
|
|
77
|
-
size.top = element.offsetTop;
|
|
78
|
-
size.left = element.offsetLeft;
|
|
79
|
-
}
|
|
80
|
-
return null;
|
|
81
|
-
}
|
|
82
|
-
/**
|
|
83
|
-
* Required with getSnapshotBeforeUpdate to stop React complaining.
|
|
84
|
-
*/
|
|
85
|
-
componentDidUpdate() { }
|
|
86
|
-
render() {
|
|
87
|
-
return this.props.children;
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
function PopChild({ children, isPresent }) {
|
|
91
|
-
const id = React.useId();
|
|
92
|
-
const ref = React.useRef(null);
|
|
93
|
-
const size = React.useRef({
|
|
94
|
-
width: 0,
|
|
95
|
-
height: 0,
|
|
96
|
-
top: 0,
|
|
97
|
-
left: 0,
|
|
98
|
-
});
|
|
99
|
-
/**
|
|
100
|
-
* We create and inject a style block so we can apply this explicit
|
|
101
|
-
* sizing in a non-destructive manner by just deleting the style block.
|
|
102
|
-
*
|
|
103
|
-
* We can't apply size via render as the measurement happens
|
|
104
|
-
* in getSnapshotBeforeUpdate (post-render), likewise if we apply the
|
|
105
|
-
* styles directly on the DOM node, we might be overwriting
|
|
106
|
-
* styles set via the style prop.
|
|
107
|
-
*/
|
|
108
|
-
React.useInsertionEffect(() => {
|
|
109
|
-
const { width, height, top, left } = size.current;
|
|
110
|
-
if (isPresent || !ref.current || !width || !height)
|
|
111
|
-
return;
|
|
112
|
-
ref.current.dataset.motionPopId = id;
|
|
113
|
-
const style = document.createElement("style");
|
|
114
|
-
document.head.appendChild(style);
|
|
115
|
-
if (style.sheet) {
|
|
116
|
-
style.sheet.insertRule(`
|
|
117
|
-
[data-motion-pop-id="${id}"] {
|
|
118
|
-
position: absolute !important;
|
|
119
|
-
width: ${width}px !important;
|
|
120
|
-
height: ${height}px !important;
|
|
121
|
-
top: ${top}px !important;
|
|
122
|
-
left: ${left}px !important;
|
|
123
|
-
}
|
|
124
|
-
`);
|
|
125
|
-
}
|
|
126
|
-
return () => {
|
|
127
|
-
document.head.removeChild(style);
|
|
128
|
-
};
|
|
129
|
-
}, [isPresent]);
|
|
130
|
-
return (React__namespace.createElement(PopChildMeasure, { isPresent: isPresent, childRef: ref, sizeRef: size }, React__namespace.cloneElement(children, { ref })));
|
|
131
|
-
}
|
|
132
|
-
|
|
133
|
-
const PresenceChild = ({ children, initial, isPresent, onExitComplete, custom, presenceAffectsLayout, mode, }) => {
|
|
134
|
-
const presenceChildren = motion.useConstant(newChildrenMap);
|
|
135
|
-
const id = React.useId();
|
|
136
|
-
const context = React.useMemo(() => ({
|
|
137
|
-
id,
|
|
138
|
-
initial,
|
|
139
|
-
isPresent,
|
|
140
|
-
custom,
|
|
141
|
-
onExitComplete: (childId) => {
|
|
142
|
-
presenceChildren.set(childId, true);
|
|
143
|
-
for (const isComplete of presenceChildren.values()) {
|
|
144
|
-
if (!isComplete)
|
|
145
|
-
return; // can stop searching when any is incomplete
|
|
146
|
-
}
|
|
147
|
-
onExitComplete && onExitComplete();
|
|
148
|
-
},
|
|
149
|
-
register: (childId) => {
|
|
150
|
-
presenceChildren.set(childId, false);
|
|
151
|
-
return () => presenceChildren.delete(childId);
|
|
152
|
-
},
|
|
153
|
-
}),
|
|
154
|
-
/**
|
|
155
|
-
* If the presence of a child affects the layout of the components around it,
|
|
156
|
-
* we want to make a new context value to ensure they get re-rendered
|
|
157
|
-
* so they can detect that layout change.
|
|
158
|
-
*/
|
|
159
|
-
presenceAffectsLayout ? undefined : [isPresent]);
|
|
160
|
-
React.useMemo(() => {
|
|
161
|
-
presenceChildren.forEach((_, key) => presenceChildren.set(key, false));
|
|
162
|
-
}, [isPresent]);
|
|
163
|
-
/**
|
|
164
|
-
* If there's no `motion` components to fire exit animations, we want to remove this
|
|
165
|
-
* component immediately.
|
|
166
|
-
*/
|
|
167
|
-
React__namespace.useEffect(() => {
|
|
168
|
-
!isPresent &&
|
|
169
|
-
!presenceChildren.size &&
|
|
170
|
-
onExitComplete &&
|
|
171
|
-
onExitComplete();
|
|
172
|
-
}, [isPresent]);
|
|
173
|
-
if (mode === "popLayout") {
|
|
174
|
-
children = React__namespace.createElement(PopChild, { isPresent: isPresent }, children);
|
|
175
|
-
}
|
|
176
|
-
return (React__namespace.createElement(motion.PresenceContext.Provider, { value: context }, children));
|
|
177
|
-
};
|
|
178
|
-
function newChildrenMap() {
|
|
179
|
-
return new Map();
|
|
180
|
-
}
|
|
181
|
-
|
|
182
|
-
function useUnmountEffect(callback) {
|
|
183
|
-
return React.useEffect(() => () => callback(), []);
|
|
184
|
-
}
|
|
185
|
-
|
|
186
|
-
const getChildKey = (child) => child.key || "";
|
|
187
|
-
function updateChildLookup(children, allChildren) {
|
|
188
|
-
children.forEach((child) => {
|
|
189
|
-
const key = getChildKey(child);
|
|
190
|
-
allChildren.set(key, child);
|
|
191
|
-
});
|
|
192
|
-
}
|
|
193
|
-
function onlyElements(children) {
|
|
194
|
-
const filtered = [];
|
|
195
|
-
// We use forEach here instead of map as map mutates the component key by preprending `.$`
|
|
196
|
-
React.Children.forEach(children, (child) => {
|
|
197
|
-
if (React.isValidElement(child))
|
|
198
|
-
filtered.push(child);
|
|
199
|
-
});
|
|
200
|
-
return filtered;
|
|
201
|
-
}
|
|
202
|
-
/**
|
|
203
|
-
* `AnimatePresence` enables the animation of components that have been removed from the tree.
|
|
204
|
-
*
|
|
205
|
-
* When adding/removing more than a single child, every child **must** be given a unique `key` prop.
|
|
206
|
-
*
|
|
207
|
-
* Any `motion` components that have an `exit` property defined will animate out when removed from
|
|
208
|
-
* the tree.
|
|
209
|
-
*
|
|
210
|
-
* ```jsx
|
|
211
|
-
* import { motion, AnimatePresence } from 'framer-motion'
|
|
212
|
-
*
|
|
213
|
-
* export const Items = ({ items }) => (
|
|
214
|
-
* <AnimatePresence>
|
|
215
|
-
* {items.map(item => (
|
|
216
|
-
* <motion.div
|
|
217
|
-
* key={item.id}
|
|
218
|
-
* initial={{ opacity: 0 }}
|
|
219
|
-
* animate={{ opacity: 1 }}
|
|
220
|
-
* exit={{ opacity: 0 }}
|
|
221
|
-
* />
|
|
222
|
-
* ))}
|
|
223
|
-
* </AnimatePresence>
|
|
224
|
-
* )
|
|
225
|
-
* ```
|
|
226
|
-
*
|
|
227
|
-
* You can sequence exit animations throughout a tree using variants.
|
|
228
|
-
*
|
|
229
|
-
* If a child contains multiple `motion` components with `exit` props, it will only unmount the child
|
|
230
|
-
* once all `motion` components have finished animating out. Likewise, any components using
|
|
231
|
-
* `usePresence` all need to call `safeToRemove`.
|
|
232
|
-
*
|
|
233
|
-
* @public
|
|
234
|
-
*/
|
|
235
|
-
const AnimatePresence = ({ children, custom, initial = true, onExitComplete, exitBeforeEnter, presenceAffectsLayout = true, mode = "sync", }) => {
|
|
236
|
-
motion.invariant(!exitBeforeEnter);
|
|
237
|
-
// We want to force a re-render once all exiting animations have finished. We
|
|
238
|
-
// either use a local forceRender function, or one from a parent context if it exists.
|
|
239
|
-
const forceRender = React.useContext(motion.LayoutGroupContext).forceRender || useForceUpdate()[0];
|
|
240
|
-
const isMounted = useIsMounted();
|
|
241
|
-
// Filter out any children that aren't ReactElements. We can only track ReactElements with a props.key
|
|
242
|
-
const filteredChildren = onlyElements(children);
|
|
243
|
-
let childrenToRender = filteredChildren;
|
|
244
|
-
const exitingChildren = React.useRef(new Map()).current;
|
|
245
|
-
// Keep a living record of the children we're actually rendering so we
|
|
246
|
-
// can diff to figure out which are entering and exiting
|
|
247
|
-
const presentChildren = React.useRef(childrenToRender);
|
|
248
|
-
// A lookup table to quickly reference components by key
|
|
249
|
-
const allChildren = React.useRef(new Map()).current;
|
|
250
|
-
// If this is the initial component render, just deal with logic surrounding whether
|
|
251
|
-
// we play onMount animations or not.
|
|
252
|
-
const isInitialRender = React.useRef(true);
|
|
253
|
-
motion.useIsomorphicLayoutEffect(() => {
|
|
254
|
-
isInitialRender.current = false;
|
|
255
|
-
updateChildLookup(filteredChildren, allChildren);
|
|
256
|
-
presentChildren.current = childrenToRender;
|
|
257
|
-
});
|
|
258
|
-
useUnmountEffect(() => {
|
|
259
|
-
isInitialRender.current = true;
|
|
260
|
-
allChildren.clear();
|
|
261
|
-
exitingChildren.clear();
|
|
262
|
-
});
|
|
263
|
-
if (isInitialRender.current) {
|
|
264
|
-
return (React__namespace.createElement(React__namespace.Fragment, null, childrenToRender.map((child) => (React__namespace.createElement(PresenceChild, { key: getChildKey(child), isPresent: true, initial: initial ? undefined : false, presenceAffectsLayout: presenceAffectsLayout, mode: mode }, child)))));
|
|
265
|
-
}
|
|
266
|
-
// If this is a subsequent render, deal with entering and exiting children
|
|
267
|
-
childrenToRender = [...childrenToRender];
|
|
268
|
-
// Diff the keys of the currently-present and target children to update our
|
|
269
|
-
// exiting list.
|
|
270
|
-
const presentKeys = presentChildren.current.map(getChildKey);
|
|
271
|
-
const targetKeys = filteredChildren.map(getChildKey);
|
|
272
|
-
// Diff the present children with our target children and mark those that are exiting
|
|
273
|
-
const numPresent = presentKeys.length;
|
|
274
|
-
for (let i = 0; i < numPresent; i++) {
|
|
275
|
-
const key = presentKeys[i];
|
|
276
|
-
if (targetKeys.indexOf(key) === -1 && !exitingChildren.has(key)) {
|
|
277
|
-
exitingChildren.set(key, undefined);
|
|
278
|
-
}
|
|
279
|
-
}
|
|
280
|
-
// If we currently have exiting children, and we're deferring rendering incoming children
|
|
281
|
-
// until after all current children have exiting, empty the childrenToRender array
|
|
282
|
-
if (mode === "wait" && exitingChildren.size) {
|
|
283
|
-
childrenToRender = [];
|
|
284
|
-
}
|
|
285
|
-
// Loop through all currently exiting components and clone them to overwrite `animate`
|
|
286
|
-
// with any `exit` prop they might have defined.
|
|
287
|
-
exitingChildren.forEach((component, key) => {
|
|
288
|
-
// If this component is actually entering again, early return
|
|
289
|
-
if (targetKeys.indexOf(key) !== -1)
|
|
290
|
-
return;
|
|
291
|
-
const child = allChildren.get(key);
|
|
292
|
-
if (!child)
|
|
293
|
-
return;
|
|
294
|
-
const insertionIndex = presentKeys.indexOf(key);
|
|
295
|
-
let exitingComponent = component;
|
|
296
|
-
if (!exitingComponent) {
|
|
297
|
-
const onExit = () => {
|
|
298
|
-
allChildren.delete(key);
|
|
299
|
-
exitingChildren.delete(key);
|
|
300
|
-
// Remove this child from the present children
|
|
301
|
-
const removeIndex = presentChildren.current.findIndex((presentChild) => presentChild.key === key);
|
|
302
|
-
presentChildren.current.splice(removeIndex, 1);
|
|
303
|
-
// Defer re-rendering until all exiting children have indeed left
|
|
304
|
-
if (!exitingChildren.size) {
|
|
305
|
-
presentChildren.current = filteredChildren;
|
|
306
|
-
if (isMounted.current === false)
|
|
307
|
-
return;
|
|
308
|
-
forceRender();
|
|
309
|
-
onExitComplete && onExitComplete();
|
|
310
|
-
}
|
|
311
|
-
};
|
|
312
|
-
exitingComponent = (React__namespace.createElement(PresenceChild, { key: getChildKey(child), isPresent: false, onExitComplete: onExit, custom: custom, presenceAffectsLayout: presenceAffectsLayout, mode: mode }, child));
|
|
313
|
-
exitingChildren.set(key, exitingComponent);
|
|
314
|
-
}
|
|
315
|
-
childrenToRender.splice(insertionIndex, 0, exitingComponent);
|
|
316
|
-
});
|
|
317
|
-
// Add `MotionContext` even to children that don't need it to ensure we're rendering
|
|
318
|
-
// the same tree between renders
|
|
319
|
-
childrenToRender = childrenToRender.map((child) => {
|
|
320
|
-
const key = child.key;
|
|
321
|
-
return exitingChildren.has(key) ? (child) : (React__namespace.createElement(PresenceChild, { key: getChildKey(child), isPresent: true, presenceAffectsLayout: presenceAffectsLayout, mode: mode }, child));
|
|
322
|
-
});
|
|
323
|
-
return (React__namespace.createElement(React__namespace.Fragment, null, exitingChildren.size
|
|
324
|
-
? childrenToRender
|
|
325
|
-
: childrenToRender.map((child) => React.cloneElement(child))));
|
|
326
|
-
};
|
|
327
|
-
|
|
328
22
|
var _excluded$1 = ["open", "children", "className"];
|
|
329
23
|
var Collapse = function Collapse(_ref) {
|
|
330
24
|
var _ref$open = _ref.open,
|
|
@@ -333,7 +27,7 @@ var Collapse = function Collapse(_ref) {
|
|
|
333
27
|
_ref$className = _ref.className,
|
|
334
28
|
className = _ref$className === void 0 ? "" : _ref$className,
|
|
335
29
|
otherProps = _objectWithoutProperties__default["default"](_ref, _excluded$1);
|
|
336
|
-
return /*#__PURE__*/React__default["default"].createElement(AnimatePresence, null, open && /*#__PURE__*/React__default["default"].createElement(
|
|
30
|
+
return /*#__PURE__*/React__default["default"].createElement(framerMotion.AnimatePresence, null, open && /*#__PURE__*/React__default["default"].createElement(framerMotion.motion.div, _extends__default["default"]({
|
|
337
31
|
animate: {
|
|
338
32
|
opacity: 1,
|
|
339
33
|
height: "auto"
|
|
@@ -394,7 +88,7 @@ var Item = function Item(_ref) {
|
|
|
394
88
|
})
|
|
395
89
|
}, /*#__PURE__*/React__default["default"].createElement("div", _extends__default["default"]({}, titleProps, {
|
|
396
90
|
className: "neeto-ui-accordion__item-handle neeto-ui-flex neeto-ui-flex-grow neeto-ui-items-center neeto-ui-break-words"
|
|
397
|
-
}), title), /*#__PURE__*/React__default["default"].createElement(
|
|
91
|
+
}), title), /*#__PURE__*/React__default["default"].createElement(framerMotion.motion.div, {
|
|
398
92
|
animate: isOpen ? "open" : "collapsed",
|
|
399
93
|
className: "neeto-ui-accordion__item-toggle-icon neeto-ui-flex-grow-0",
|
|
400
94
|
transition: {
|