@chayns-components/typewriter 5.0.0-beta.756 → 5.0.0-beta.758

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.
@@ -3,8 +3,9 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.default = exports.TypewriterSpeed = exports.TypewriterResetDelay = void 0;
6
+ exports.default = exports.TypewriterSpeed = exports.TypewriterDelay = void 0;
7
7
  var _core = require("@chayns-components/core");
8
+ var _chaynsApi = require("chayns-api");
8
9
  var _react = _interopRequireWildcard(require("react"));
9
10
  var _reactDom = require("react-dom");
10
11
  var _server = require("react-dom/server");
@@ -13,11 +14,13 @@ var _utils = require("./utils");
13
14
  function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
14
15
  function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
15
16
  // noinspection JSUnusedGlobalSymbols
16
- let TypewriterResetDelay = exports.TypewriterResetDelay = /*#__PURE__*/function (TypewriterResetDelay) {
17
- TypewriterResetDelay[TypewriterResetDelay["Slow"] = 4000] = "Slow";
18
- TypewriterResetDelay[TypewriterResetDelay["Medium"] = 2000] = "Medium";
19
- TypewriterResetDelay[TypewriterResetDelay["Fast"] = 1000] = "Fast";
20
- return TypewriterResetDelay;
17
+ let TypewriterDelay = exports.TypewriterDelay = /*#__PURE__*/function (TypewriterDelay) {
18
+ TypewriterDelay[TypewriterDelay["ExtraSlow"] = 4000] = "ExtraSlow";
19
+ TypewriterDelay[TypewriterDelay["Slow"] = 2000] = "Slow";
20
+ TypewriterDelay[TypewriterDelay["Medium"] = 1000] = "Medium";
21
+ TypewriterDelay[TypewriterDelay["Fast"] = 500] = "Fast";
22
+ TypewriterDelay[TypewriterDelay["ExtraFast"] = 250] = "ExtraFast";
23
+ return TypewriterDelay;
21
24
  }({}); // noinspection JSUnusedGlobalSymbols
22
25
  let TypewriterSpeed = exports.TypewriterSpeed = /*#__PURE__*/function (TypewriterSpeed) {
23
26
  TypewriterSpeed[TypewriterSpeed["ExtraSlow"] = 40] = "ExtraSlow";
@@ -29,9 +32,10 @@ let TypewriterSpeed = exports.TypewriterSpeed = /*#__PURE__*/function (Typewrite
29
32
  }({});
30
33
  const Typewriter = ({
31
34
  children,
35
+ nextTextDelay = TypewriterDelay.Medium,
32
36
  onFinish,
33
37
  pseudoChildren,
34
- resetDelay = TypewriterResetDelay.Medium,
38
+ resetDelay = TypewriterDelay.Medium,
35
39
  shouldForceCursorAnimation = false,
36
40
  shouldHideCursor = false,
37
41
  shouldSortChildrenRandomly = false,
@@ -44,6 +48,8 @@ const Typewriter = ({
44
48
  const [currentChildrenIndex, setCurrentChildrenIndex] = (0, _react.useState)(0);
45
49
  const [shouldCount, setShouldCount] = (0, _react.useState)(true);
46
50
  const [hasRenderedChildrenOnce, setHasRenderedChildrenOnce] = (0, _react.useState)(false);
51
+ const functions = (0, _chaynsApi.useFunctions)();
52
+ const values = (0, _chaynsApi.useValues)();
47
53
  (0, _react.useLayoutEffect)(() => {
48
54
  if (children) {
49
55
  setHasRenderedChildrenOnce(false);
@@ -61,23 +67,29 @@ const Typewriter = ({
61
67
  if (areMultipleChildrenGiven) {
62
68
  const currentChildren = sortedChildren[currentChildrenIndex];
63
69
  if (currentChildren) {
64
- return /*#__PURE__*/_react.default.isValidElement(currentChildren) ? (0, _server.renderToString)( /*#__PURE__*/_react.default.createElement(_core.ColorSchemeProvider, {
70
+ return /*#__PURE__*/_react.default.isValidElement(currentChildren) ? (0, _server.renderToString)( /*#__PURE__*/_react.default.createElement(_chaynsApi.ChaynsProvider, {
71
+ data: values,
72
+ functions: functions
73
+ }, /*#__PURE__*/_react.default.createElement(_core.ColorSchemeProvider, {
65
74
  color: "#005EB8",
66
75
  colorMode: 0,
67
76
  style: {
68
77
  display: 'inline'
69
78
  }
70
- }, currentChildren)) : currentChildren;
79
+ }, currentChildren))) : currentChildren;
71
80
  }
72
81
  return '';
73
82
  }
74
- return /*#__PURE__*/_react.default.isValidElement(sortedChildren) ? (0, _server.renderToString)( /*#__PURE__*/_react.default.createElement(_core.ColorSchemeProvider, {
83
+ return /*#__PURE__*/_react.default.isValidElement(sortedChildren) ? (0, _server.renderToString)( /*#__PURE__*/_react.default.createElement(_chaynsApi.ChaynsProvider, {
84
+ data: values,
85
+ functions: functions
86
+ }, /*#__PURE__*/_react.default.createElement(_core.ColorSchemeProvider, {
75
87
  color: "#005EB8",
76
88
  colorMode: 0,
77
89
  style: {
78
90
  display: 'inline'
79
91
  }
80
- }, sortedChildren)) : sortedChildren;
92
+ }, sortedChildren))) : sortedChildren;
81
93
  }, [areMultipleChildrenGiven, currentChildrenIndex, sortedChildren]);
82
94
  const charactersCount = (0, _react.useMemo)(() => (0, _utils.getCharactersCount)(textContent), [textContent]);
83
95
  const [isResetAnimationActive, setIsResetAnimationActive] = (0, _react.useState)(false);
@@ -115,7 +127,7 @@ const Typewriter = ({
115
127
  setTimeout(() => {
116
128
  setIsResetAnimationActive(false);
117
129
  handleSetNextChildrenIndex();
118
- }, resetDelay);
130
+ }, nextTextDelay);
119
131
  }
120
132
  }
121
133
  return nextState;
@@ -146,7 +158,7 @@ const Typewriter = ({
146
158
  setIsResetAnimationActive(true);
147
159
  } else {
148
160
  setShownCharCount(0);
149
- setTimeout(handleSetNextChildrenIndex, resetDelay / 2);
161
+ setTimeout(handleSetNextChildrenIndex, nextTextDelay);
150
162
  }
151
163
  }, resetDelay);
152
164
  }
@@ -159,7 +171,7 @@ const Typewriter = ({
159
171
  return () => {
160
172
  window.clearInterval(interval);
161
173
  };
162
- }, [shouldStopAnimation, speed, textContent.length, charactersCount, isResetAnimationActive, areMultipleChildrenGiven, resetDelay, childrenCount, handleSetNextChildrenIndex, shouldUseResetAnimation, shouldCount, shouldWaitForContent]);
174
+ }, [shouldStopAnimation, speed, textContent.length, charactersCount, isResetAnimationActive, areMultipleChildrenGiven, resetDelay, childrenCount, handleSetNextChildrenIndex, shouldUseResetAnimation, shouldCount, shouldWaitForContent, nextTextDelay]);
163
175
  (0, _react.useEffect)(() => {
164
176
  if (!isAnimatingText && typeof onFinish === 'function') {
165
177
  onFinish();
@@ -168,13 +180,16 @@ const Typewriter = ({
168
180
  const shownText = (0, _react.useMemo)(() => (0, _utils.getSubTextFromHTML)(textContent, shownCharCount), [shownCharCount, textContent]);
169
181
  const pseudoTextHTML = (0, _react.useMemo)(() => {
170
182
  if (pseudoChildren) {
171
- const pseudoText = /*#__PURE__*/_react.default.isValidElement(pseudoChildren) ? (0, _server.renderToString)( /*#__PURE__*/_react.default.createElement(_core.ColorSchemeProvider, {
183
+ const pseudoText = /*#__PURE__*/_react.default.isValidElement(pseudoChildren) ? (0, _server.renderToString)( /*#__PURE__*/_react.default.createElement(_chaynsApi.ChaynsProvider, {
184
+ data: values,
185
+ functions: functions
186
+ }, /*#__PURE__*/_react.default.createElement(_core.ColorSchemeProvider, {
172
187
  color: "#005EB8",
173
188
  colorMode: 0,
174
189
  style: {
175
190
  display: 'inline'
176
191
  }
177
- }, pseudoChildren)) : pseudoChildren;
192
+ }, pseudoChildren))) : pseudoChildren;
178
193
  if (shouldUseAnimationHeight) {
179
194
  return (0, _utils.getSubTextFromHTML)(pseudoText, shownCharCount);
180
195
  }
@@ -1 +1 @@
1
- {"version":3,"file":"Typewriter.js","names":["_core","require","_react","_interopRequireWildcard","_reactDom","_server","_Typewriter","_utils","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","TypewriterResetDelay","exports","TypewriterSpeed","Typewriter","children","onFinish","pseudoChildren","resetDelay","Medium","shouldForceCursorAnimation","shouldHideCursor","shouldSortChildrenRandomly","shouldUseAnimationHeight","shouldUseResetAnimation","shouldWaitForContent","speed","textStyle","currentChildrenIndex","setCurrentChildrenIndex","useState","shouldCount","setShouldCount","hasRenderedChildrenOnce","setHasRenderedChildrenOnce","useLayoutEffect","useEffect","sortedChildren","useMemo","Array","isArray","shuffleArray","areMultipleChildrenGiven","childrenCount","length","textContent","currentChildren","React","isValidElement","renderToString","createElement","ColorSchemeProvider","color","colorMode","style","display","charactersCount","getCharactersCount","isResetAnimationActive","setIsResetAnimationActive","shownCharCount","setShownCharCount","shouldStopAnimation","setShouldStopAnimation","prevChildren","setPrevChildren","isAnimatingText","handleClick","useCallback","handleSetNextChildrenIndex","newIndex","interval","window","setInterval","prevState","nextState","clearInterval","setTimeout","shownText","getSubTextFromHTML","pseudoTextHTML","pseudoText","StyledTypewriter","onClick","StyledTypewriterText","dangerouslySetInnerHTML","__html","$isAnimatingText","$shouldHideCursor","StyledTypewriterPseudoText","createPortal","position","visibility","document","body","displayName","_default"],"sources":["../../../../src/components/typewriter/Typewriter.tsx"],"sourcesContent":["import { ColorSchemeProvider } from '@chayns-components/core';\nimport React, {\n FC,\n ReactElement,\n useCallback,\n useEffect,\n useLayoutEffect,\n useMemo,\n useState,\n} from 'react';\nimport { createPortal } from 'react-dom';\nimport { renderToString } from 'react-dom/server';\nimport {\n StyledTypewriter,\n StyledTypewriterPseudoText,\n StyledTypewriterText,\n} from './Typewriter.styles';\nimport { getCharactersCount, getSubTextFromHTML, shuffleArray } from './utils';\n\n// noinspection JSUnusedGlobalSymbols\nexport enum TypewriterResetDelay {\n Slow = 4000,\n Medium = 2000,\n Fast = 1000,\n}\n\n// noinspection JSUnusedGlobalSymbols\nexport enum TypewriterSpeed {\n ExtraSlow = 40,\n Slow = 20,\n Medium = 10,\n Fast = 5,\n ExtraFast = 2.5,\n}\n\nexport type TypewriterProps = {\n /**\n * The text to type\n */\n children: ReactElement | ReactElement[] | string | string[];\n /**\n * Function that is executed when the typewriter animation has finished. This function will not\n * be executed if multiple texts are used.\n */\n onFinish?: VoidFunction;\n /**\n * Pseudo-element to be rendered invisible during animation to define the size of the element\n * for the typewriter effect. By default, the \"children\" is used for this purpose.\n */\n pseudoChildren?: ReactElement | string;\n /**\n * Waiting time before the typewriter resets the content if multiple texts are given\n */\n resetDelay?: TypewriterResetDelay;\n /**\n * Specifies whether the cursor should be forced to animate even if no text is currently animated.\n */\n shouldForceCursorAnimation?: boolean;\n /**\n * Specifies whether the cursor should be hidden\n */\n shouldHideCursor?: boolean;\n /**\n * Specifies whether the children should be sorted randomly if there are multiple texts.\n * This makes the typewriter start with a different text each time and also changes them\n * in a random order.\n */\n shouldSortChildrenRandomly?: boolean;\n /**\n * Specifies whether the animation should use its full height or the height of the current\n * chunk.\n */\n shouldUseAnimationHeight?: boolean;\n /**\n * Specifies whether the reset of the text should be animated with a backspace animation for\n * multiple texts.\n */\n shouldUseResetAnimation?: boolean;\n /**\n * Whether the typewriter should wait for new content\n */\n shouldWaitForContent?: boolean;\n /**\n * The speed of the animation. Use the TypewriterSpeed enum for this prop.\n */\n speed?: TypewriterSpeed | number;\n /**\n * The style of the typewriter text element\n */\n textStyle?: React.CSSProperties;\n};\n\nconst Typewriter: FC<TypewriterProps> = ({\n children,\n onFinish,\n pseudoChildren,\n resetDelay = TypewriterResetDelay.Medium,\n shouldForceCursorAnimation = false,\n shouldHideCursor = false,\n shouldSortChildrenRandomly = false,\n shouldUseAnimationHeight = false,\n shouldUseResetAnimation = false,\n shouldWaitForContent,\n speed = TypewriterSpeed.Medium,\n textStyle,\n}) => {\n const [currentChildrenIndex, setCurrentChildrenIndex] = useState(0);\n const [shouldCount, setShouldCount] = useState(true);\n const [hasRenderedChildrenOnce, setHasRenderedChildrenOnce] = useState(false);\n\n useLayoutEffect(() => {\n if (children) {\n setHasRenderedChildrenOnce(false);\n }\n }, [children]);\n\n useEffect(() => {\n if (!hasRenderedChildrenOnce) {\n setHasRenderedChildrenOnce(true);\n }\n }, [hasRenderedChildrenOnce]);\n\n const sortedChildren = useMemo(\n () =>\n Array.isArray(children) && shouldSortChildrenRandomly\n ? shuffleArray<ReactElement | string>(children)\n : children,\n [children, shouldSortChildrenRandomly],\n );\n\n const areMultipleChildrenGiven = Array.isArray(sortedChildren);\n const childrenCount = areMultipleChildrenGiven ? sortedChildren.length : 1;\n\n const textContent = useMemo(() => {\n if (areMultipleChildrenGiven) {\n const currentChildren = sortedChildren[currentChildrenIndex];\n\n if (currentChildren) {\n return React.isValidElement(currentChildren)\n ? renderToString(\n <ColorSchemeProvider\n color=\"#005EB8\"\n colorMode={0}\n style={{ display: 'inline' }}\n >\n {currentChildren}\n </ColorSchemeProvider>,\n )\n : (currentChildren as string);\n }\n\n return '';\n }\n\n return React.isValidElement(sortedChildren)\n ? renderToString(\n <ColorSchemeProvider color=\"#005EB8\" colorMode={0} style={{ display: 'inline' }}>\n {sortedChildren}\n </ColorSchemeProvider>,\n )\n : (sortedChildren as string);\n }, [areMultipleChildrenGiven, currentChildrenIndex, sortedChildren]);\n\n const charactersCount = useMemo(() => getCharactersCount(textContent), [textContent]);\n\n const [isResetAnimationActive, setIsResetAnimationActive] = useState(false);\n const [shownCharCount, setShownCharCount] = useState(\n charactersCount > 0 ? 0 : textContent.length,\n );\n const [shouldStopAnimation, setShouldStopAnimation] = useState(false);\n const [prevChildren, setPrevChildren] = useState<TypewriterProps['children']>(children);\n\n useEffect(() => {\n if (children !== prevChildren) {\n setShouldCount(true);\n setPrevChildren(children);\n }\n }, [children, prevChildren]);\n\n const isAnimatingText =\n shownCharCount < textContent.length ||\n shouldForceCursorAnimation ||\n areMultipleChildrenGiven ||\n textContent.length === 0;\n\n const handleClick = useCallback(() => {\n setShouldStopAnimation(true);\n }, []);\n\n const handleSetNextChildrenIndex = useCallback(\n () =>\n setCurrentChildrenIndex(() => {\n let newIndex = currentChildrenIndex + 1;\n\n if (newIndex > childrenCount - 1) {\n newIndex = 0;\n }\n\n return newIndex;\n }),\n [childrenCount, currentChildrenIndex],\n );\n\n useEffect(() => {\n let interval: number | undefined;\n\n if (shouldStopAnimation || charactersCount === 0) {\n setShownCharCount(textContent.length);\n } else if (isResetAnimationActive) {\n interval = window.setInterval(() => {\n setShownCharCount((prevState) => {\n const nextState = prevState - 1;\n\n if (nextState === 0) {\n window.clearInterval(interval);\n\n if (areMultipleChildrenGiven) {\n setTimeout(() => {\n setIsResetAnimationActive(false);\n handleSetNextChildrenIndex();\n }, resetDelay);\n }\n }\n\n return nextState;\n });\n }, speed);\n } else {\n interval = window.setInterval(() => {\n setShownCharCount((prevState) => {\n let nextState = prevState;\n\n if (shouldCount) {\n nextState = prevState + 1;\n }\n\n if (nextState >= charactersCount) {\n if (shouldWaitForContent) {\n setShouldCount(false);\n } else {\n window.clearInterval(interval);\n\n /**\n * At this point, the next value for \"shownCharCount\" is deliberately set to\n * the length of the textContent in order to correctly display HTML elements\n * after the last letter.\n */\n nextState = textContent.length;\n\n if (areMultipleChildrenGiven) {\n setTimeout(() => {\n if (shouldUseResetAnimation) {\n setIsResetAnimationActive(true);\n } else {\n setShownCharCount(0);\n setTimeout(handleSetNextChildrenIndex, resetDelay / 2);\n }\n }, resetDelay);\n }\n }\n }\n\n return nextState;\n });\n }, speed);\n }\n\n return () => {\n window.clearInterval(interval);\n };\n }, [\n shouldStopAnimation,\n speed,\n textContent.length,\n charactersCount,\n isResetAnimationActive,\n areMultipleChildrenGiven,\n resetDelay,\n childrenCount,\n handleSetNextChildrenIndex,\n shouldUseResetAnimation,\n shouldCount,\n shouldWaitForContent,\n ]);\n\n useEffect(() => {\n if (!isAnimatingText && typeof onFinish === 'function') {\n onFinish();\n }\n }, [isAnimatingText, onFinish]);\n\n const shownText = useMemo(\n () => getSubTextFromHTML(textContent, shownCharCount),\n [shownCharCount, textContent],\n );\n\n const pseudoTextHTML = useMemo(() => {\n if (pseudoChildren) {\n const pseudoText = React.isValidElement(pseudoChildren)\n ? renderToString(\n <ColorSchemeProvider\n color=\"#005EB8\"\n colorMode={0}\n style={{ display: 'inline' }}\n >\n {pseudoChildren}\n </ColorSchemeProvider>,\n )\n : (pseudoChildren as string);\n\n if (shouldUseAnimationHeight) {\n return getSubTextFromHTML(pseudoText, shownCharCount);\n }\n\n return pseudoText;\n }\n\n if (shouldUseAnimationHeight && textContent) {\n return getSubTextFromHTML(textContent, shownCharCount);\n }\n\n return textContent || '&#8203;';\n }, [pseudoChildren, shouldUseAnimationHeight, shownCharCount, textContent]);\n\n return useMemo(\n () => (\n <StyledTypewriter onClick={handleClick}>\n {isAnimatingText ? (\n <StyledTypewriterText\n dangerouslySetInnerHTML={{ __html: shownText }}\n $isAnimatingText\n $shouldHideCursor={shouldHideCursor}\n style={textStyle}\n />\n ) : (\n <StyledTypewriterText style={textStyle}>{sortedChildren}</StyledTypewriterText>\n )}\n {isAnimatingText && (\n <StyledTypewriterPseudoText\n dangerouslySetInnerHTML={{ __html: pseudoTextHTML }}\n $isAnimatingText\n $shouldHideCursor={shouldHideCursor}\n />\n )}\n {/*\n The following is needed because some components like the CodeHighlighter will not render correct\n if the element is not rendered on client before...\n */}\n {!hasRenderedChildrenOnce &&\n createPortal(\n <div style={{ position: 'absolute', visibility: 'hidden' }}>\n {children}\n </div>,\n document.body,\n )}\n </StyledTypewriter>\n ),\n [\n children,\n handleClick,\n hasRenderedChildrenOnce,\n isAnimatingText,\n pseudoTextHTML,\n shouldHideCursor,\n shownText,\n sortedChildren,\n textStyle,\n ],\n );\n};\n\nTypewriter.displayName = 'Typewriter';\n\nexport default Typewriter;\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"Typewriter.js","names":["_core","require","_chaynsApi","_react","_interopRequireWildcard","_reactDom","_server","_Typewriter","_utils","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","TypewriterDelay","exports","TypewriterSpeed","Typewriter","children","nextTextDelay","Medium","onFinish","pseudoChildren","resetDelay","shouldForceCursorAnimation","shouldHideCursor","shouldSortChildrenRandomly","shouldUseAnimationHeight","shouldUseResetAnimation","shouldWaitForContent","speed","textStyle","currentChildrenIndex","setCurrentChildrenIndex","useState","shouldCount","setShouldCount","hasRenderedChildrenOnce","setHasRenderedChildrenOnce","functions","useFunctions","values","useValues","useLayoutEffect","useEffect","sortedChildren","useMemo","Array","isArray","shuffleArray","areMultipleChildrenGiven","childrenCount","length","textContent","currentChildren","React","isValidElement","renderToString","createElement","ChaynsProvider","data","ColorSchemeProvider","color","colorMode","style","display","charactersCount","getCharactersCount","isResetAnimationActive","setIsResetAnimationActive","shownCharCount","setShownCharCount","shouldStopAnimation","setShouldStopAnimation","prevChildren","setPrevChildren","isAnimatingText","handleClick","useCallback","handleSetNextChildrenIndex","newIndex","interval","window","setInterval","prevState","nextState","clearInterval","setTimeout","shownText","getSubTextFromHTML","pseudoTextHTML","pseudoText","StyledTypewriter","onClick","StyledTypewriterText","dangerouslySetInnerHTML","__html","$isAnimatingText","$shouldHideCursor","StyledTypewriterPseudoText","createPortal","position","visibility","document","body","displayName","_default"],"sources":["../../../../src/components/typewriter/Typewriter.tsx"],"sourcesContent":["import { ColorSchemeProvider } from '@chayns-components/core';\nimport { ChaynsProvider, useFunctions, useValues } from 'chayns-api';\nimport React, {\n FC,\n ReactElement,\n useCallback,\n useEffect,\n useLayoutEffect,\n useMemo,\n useState,\n} from 'react';\nimport { createPortal } from 'react-dom';\nimport { renderToString } from 'react-dom/server';\nimport {\n StyledTypewriter,\n StyledTypewriterPseudoText,\n StyledTypewriterText,\n} from './Typewriter.styles';\nimport { getCharactersCount, getSubTextFromHTML, shuffleArray } from './utils';\n\n// noinspection JSUnusedGlobalSymbols\nexport enum TypewriterDelay {\n ExtraSlow = 4000,\n Slow = 2000,\n Medium = 1000,\n Fast = 500,\n ExtraFast = 250,\n}\n\n// noinspection JSUnusedGlobalSymbols\nexport enum TypewriterSpeed {\n ExtraSlow = 40,\n Slow = 20,\n Medium = 10,\n Fast = 5,\n ExtraFast = 2.5,\n}\n\nexport type TypewriterProps = {\n /**\n * The text to type\n */\n children: ReactElement | ReactElement[] | string | string[];\n /**\n * The delay in milliseconds before the next text is shown.\n * This prop is only used if multiple texts are given.\n */\n nextTextDelay?: TypewriterDelay;\n /**\n * Function that is executed when the typewriter animation has finished. This function will not\n * be executed if multiple texts are used.\n */\n onFinish?: VoidFunction;\n /**\n * Pseudo-element to be rendered invisible during animation to define the size of the element\n * for the typewriter effect. By default, the \"children\" is used for this purpose.\n */\n pseudoChildren?: ReactElement | string;\n /**\n * Waiting time in milliseconds before the typewriter resets the text.\n * This prop is only used if multiple texts are given.\n */\n resetDelay?: TypewriterDelay;\n /**\n * Specifies whether the cursor should be forced to animate even if no text is currently animated.\n */\n shouldForceCursorAnimation?: boolean;\n /**\n * Specifies whether the cursor should be hidden\n */\n shouldHideCursor?: boolean;\n /**\n * Specifies whether the children should be sorted randomly if there are multiple texts.\n * This makes the typewriter start with a different text each time and also changes them\n * in a random order.\n */\n shouldSortChildrenRandomly?: boolean;\n /**\n * Specifies whether the animation should use its full height or the height of the current\n * chunk.\n */\n shouldUseAnimationHeight?: boolean;\n /**\n * Specifies whether the reset of the text should be animated with a backspace animation for\n * multiple texts.\n */\n shouldUseResetAnimation?: boolean;\n /**\n * Whether the typewriter should wait for new content\n */\n shouldWaitForContent?: boolean;\n /**\n * The speed of the animation. Use the TypewriterSpeed enum for this prop.\n */\n speed?: TypewriterSpeed | number;\n /**\n * The style of the typewriter text element\n */\n textStyle?: React.CSSProperties;\n};\n\nconst Typewriter: FC<TypewriterProps> = ({\n children,\n nextTextDelay = TypewriterDelay.Medium,\n onFinish,\n pseudoChildren,\n resetDelay = TypewriterDelay.Medium,\n shouldForceCursorAnimation = false,\n shouldHideCursor = false,\n shouldSortChildrenRandomly = false,\n shouldUseAnimationHeight = false,\n shouldUseResetAnimation = false,\n shouldWaitForContent,\n speed = TypewriterSpeed.Medium,\n textStyle,\n}) => {\n const [currentChildrenIndex, setCurrentChildrenIndex] = useState(0);\n const [shouldCount, setShouldCount] = useState(true);\n const [hasRenderedChildrenOnce, setHasRenderedChildrenOnce] = useState(false);\n\n const functions = useFunctions();\n const values = useValues();\n\n useLayoutEffect(() => {\n if (children) {\n setHasRenderedChildrenOnce(false);\n }\n }, [children]);\n\n useEffect(() => {\n if (!hasRenderedChildrenOnce) {\n setHasRenderedChildrenOnce(true);\n }\n }, [hasRenderedChildrenOnce]);\n\n const sortedChildren = useMemo(\n () =>\n Array.isArray(children) && shouldSortChildrenRandomly\n ? shuffleArray<ReactElement | string>(children)\n : children,\n [children, shouldSortChildrenRandomly],\n );\n\n const areMultipleChildrenGiven = Array.isArray(sortedChildren);\n const childrenCount = areMultipleChildrenGiven ? sortedChildren.length : 1;\n\n const textContent = useMemo(() => {\n if (areMultipleChildrenGiven) {\n const currentChildren = sortedChildren[currentChildrenIndex];\n\n if (currentChildren) {\n return React.isValidElement(currentChildren)\n ? renderToString(\n <ChaynsProvider data={values} functions={functions}>\n <ColorSchemeProvider\n color=\"#005EB8\"\n colorMode={0}\n style={{ display: 'inline' }}\n >\n {currentChildren}\n </ColorSchemeProvider>\n </ChaynsProvider>,\n )\n : (currentChildren as string);\n }\n\n return '';\n }\n\n return React.isValidElement(sortedChildren)\n ? renderToString(\n <ChaynsProvider data={values} functions={functions}>\n <ColorSchemeProvider\n color=\"#005EB8\"\n colorMode={0}\n style={{ display: 'inline' }}\n >\n {sortedChildren}\n </ColorSchemeProvider>\n </ChaynsProvider>,\n )\n : (sortedChildren as string);\n }, [areMultipleChildrenGiven, currentChildrenIndex, sortedChildren]);\n\n const charactersCount = useMemo(() => getCharactersCount(textContent), [textContent]);\n\n const [isResetAnimationActive, setIsResetAnimationActive] = useState(false);\n const [shownCharCount, setShownCharCount] = useState(\n charactersCount > 0 ? 0 : textContent.length,\n );\n const [shouldStopAnimation, setShouldStopAnimation] = useState(false);\n const [prevChildren, setPrevChildren] = useState<TypewriterProps['children']>(children);\n\n useEffect(() => {\n if (children !== prevChildren) {\n setShouldCount(true);\n setPrevChildren(children);\n }\n }, [children, prevChildren]);\n\n const isAnimatingText =\n shownCharCount < textContent.length ||\n shouldForceCursorAnimation ||\n areMultipleChildrenGiven ||\n textContent.length === 0;\n\n const handleClick = useCallback(() => {\n setShouldStopAnimation(true);\n }, []);\n\n const handleSetNextChildrenIndex = useCallback(\n () =>\n setCurrentChildrenIndex(() => {\n let newIndex = currentChildrenIndex + 1;\n\n if (newIndex > childrenCount - 1) {\n newIndex = 0;\n }\n\n return newIndex;\n }),\n [childrenCount, currentChildrenIndex],\n );\n\n useEffect(() => {\n let interval: number | undefined;\n\n if (shouldStopAnimation || charactersCount === 0) {\n setShownCharCount(textContent.length);\n } else if (isResetAnimationActive) {\n interval = window.setInterval(() => {\n setShownCharCount((prevState) => {\n const nextState = prevState - 1;\n\n if (nextState === 0) {\n window.clearInterval(interval);\n\n if (areMultipleChildrenGiven) {\n setTimeout(() => {\n setIsResetAnimationActive(false);\n handleSetNextChildrenIndex();\n }, nextTextDelay);\n }\n }\n\n return nextState;\n });\n }, speed);\n } else {\n interval = window.setInterval(() => {\n setShownCharCount((prevState) => {\n let nextState = prevState;\n\n if (shouldCount) {\n nextState = prevState + 1;\n }\n\n if (nextState >= charactersCount) {\n if (shouldWaitForContent) {\n setShouldCount(false);\n } else {\n window.clearInterval(interval);\n\n /**\n * At this point, the next value for \"shownCharCount\" is deliberately set to\n * the length of the textContent in order to correctly display HTML elements\n * after the last letter.\n */\n nextState = textContent.length;\n\n if (areMultipleChildrenGiven) {\n setTimeout(() => {\n if (shouldUseResetAnimation) {\n setIsResetAnimationActive(true);\n } else {\n setShownCharCount(0);\n setTimeout(handleSetNextChildrenIndex, nextTextDelay);\n }\n }, resetDelay);\n }\n }\n }\n\n return nextState;\n });\n }, speed);\n }\n\n return () => {\n window.clearInterval(interval);\n };\n }, [\n shouldStopAnimation,\n speed,\n textContent.length,\n charactersCount,\n isResetAnimationActive,\n areMultipleChildrenGiven,\n resetDelay,\n childrenCount,\n handleSetNextChildrenIndex,\n shouldUseResetAnimation,\n shouldCount,\n shouldWaitForContent,\n nextTextDelay,\n ]);\n\n useEffect(() => {\n if (!isAnimatingText && typeof onFinish === 'function') {\n onFinish();\n }\n }, [isAnimatingText, onFinish]);\n\n const shownText = useMemo(\n () => getSubTextFromHTML(textContent, shownCharCount),\n [shownCharCount, textContent],\n );\n\n const pseudoTextHTML = useMemo(() => {\n if (pseudoChildren) {\n const pseudoText = React.isValidElement(pseudoChildren)\n ? renderToString(\n <ChaynsProvider data={values} functions={functions}>\n <ColorSchemeProvider\n color=\"#005EB8\"\n colorMode={0}\n style={{ display: 'inline' }}\n >\n {pseudoChildren}\n </ColorSchemeProvider>\n </ChaynsProvider>,\n )\n : (pseudoChildren as string);\n\n if (shouldUseAnimationHeight) {\n return getSubTextFromHTML(pseudoText, shownCharCount);\n }\n\n return pseudoText;\n }\n\n if (shouldUseAnimationHeight && textContent) {\n return getSubTextFromHTML(textContent, shownCharCount);\n }\n\n return textContent || '&#8203;';\n }, [pseudoChildren, shouldUseAnimationHeight, shownCharCount, textContent]);\n\n return useMemo(\n () => (\n <StyledTypewriter onClick={handleClick}>\n {isAnimatingText ? (\n <StyledTypewriterText\n dangerouslySetInnerHTML={{ __html: shownText }}\n $isAnimatingText\n $shouldHideCursor={shouldHideCursor}\n style={textStyle}\n />\n ) : (\n <StyledTypewriterText style={textStyle}>{sortedChildren}</StyledTypewriterText>\n )}\n {isAnimatingText && (\n <StyledTypewriterPseudoText\n dangerouslySetInnerHTML={{ __html: pseudoTextHTML }}\n $isAnimatingText\n $shouldHideCursor={shouldHideCursor}\n />\n )}\n {/*\n The following is needed because some components like the CodeHighlighter will not render correct\n if the element is not rendered on client before...\n */}\n {!hasRenderedChildrenOnce &&\n createPortal(\n <div style={{ position: 'absolute', visibility: 'hidden' }}>\n {children}\n </div>,\n document.body,\n )}\n </StyledTypewriter>\n ),\n [\n children,\n handleClick,\n hasRenderedChildrenOnce,\n isAnimatingText,\n pseudoTextHTML,\n shouldHideCursor,\n shownText,\n sortedChildren,\n textStyle,\n ],\n );\n};\n\nTypewriter.displayName = 'Typewriter';\n\nexport default Typewriter;\n"],"mappings":"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","ignoreList":[]}
package/lib/cjs/index.js CHANGED
@@ -9,6 +9,12 @@ Object.defineProperty(exports, "Typewriter", {
9
9
  return _Typewriter.default;
10
10
  }
11
11
  });
12
+ Object.defineProperty(exports, "TypewriterDelay", {
13
+ enumerable: true,
14
+ get: function () {
15
+ return _Typewriter.TypewriterDelay;
16
+ }
17
+ });
12
18
  Object.defineProperty(exports, "TypewriterSpeed", {
13
19
  enumerable: true,
14
20
  get: function () {
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["_Typewriter","_interopRequireWildcard","require","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set"],"sources":["../../src/index.ts"],"sourcesContent":["export { default as Typewriter, TypewriterSpeed } from './components/typewriter/Typewriter';\n"],"mappings":";;;;;;;;;;;;;;;;;AAAA,IAAAA,WAAA,GAAAC,uBAAA,CAAAC,OAAA;AAA4F,SAAAC,yBAAAC,CAAA,6BAAAC,OAAA,mBAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,CAAAC,CAAA,WAAAA,CAAA,GAAAG,CAAA,GAAAD,CAAA,KAAAF,CAAA;AAAA,SAAAH,wBAAAG,CAAA,EAAAE,CAAA,SAAAA,CAAA,IAAAF,CAAA,IAAAA,CAAA,CAAAI,UAAA,SAAAJ,CAAA,eAAAA,CAAA,uBAAAA,CAAA,yBAAAA,CAAA,WAAAK,OAAA,EAAAL,CAAA,QAAAG,CAAA,GAAAJ,wBAAA,CAAAG,CAAA,OAAAC,CAAA,IAAAA,CAAA,CAAAG,GAAA,CAAAN,CAAA,UAAAG,CAAA,CAAAI,GAAA,CAAAP,CAAA,OAAAQ,CAAA,KAAAC,SAAA,UAAAC,CAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,CAAA,IAAAd,CAAA,oBAAAc,CAAA,OAAAC,cAAA,CAAAC,IAAA,CAAAhB,CAAA,EAAAc,CAAA,SAAAG,CAAA,GAAAP,CAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAb,CAAA,EAAAc,CAAA,UAAAG,CAAA,KAAAA,CAAA,CAAAV,GAAA,IAAAU,CAAA,CAAAC,GAAA,IAAAP,MAAA,CAAAC,cAAA,CAAAJ,CAAA,EAAAM,CAAA,EAAAG,CAAA,IAAAT,CAAA,CAAAM,CAAA,IAAAd,CAAA,CAAAc,CAAA,YAAAN,CAAA,CAAAH,OAAA,GAAAL,CAAA,EAAAG,CAAA,IAAAA,CAAA,CAAAe,GAAA,CAAAlB,CAAA,EAAAQ,CAAA,GAAAA,CAAA","ignoreList":[]}
1
+ {"version":3,"file":"index.js","names":["_Typewriter","_interopRequireWildcard","require","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set"],"sources":["../../src/index.ts"],"sourcesContent":["export {\n default as Typewriter,\n TypewriterDelay,\n TypewriterSpeed,\n} from './components/typewriter/Typewriter';\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;AAAA,IAAAA,WAAA,GAAAC,uBAAA,CAAAC,OAAA;AAI4C,SAAAC,yBAAAC,CAAA,6BAAAC,OAAA,mBAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,CAAAC,CAAA,WAAAA,CAAA,GAAAG,CAAA,GAAAD,CAAA,KAAAF,CAAA;AAAA,SAAAH,wBAAAG,CAAA,EAAAE,CAAA,SAAAA,CAAA,IAAAF,CAAA,IAAAA,CAAA,CAAAI,UAAA,SAAAJ,CAAA,eAAAA,CAAA,uBAAAA,CAAA,yBAAAA,CAAA,WAAAK,OAAA,EAAAL,CAAA,QAAAG,CAAA,GAAAJ,wBAAA,CAAAG,CAAA,OAAAC,CAAA,IAAAA,CAAA,CAAAG,GAAA,CAAAN,CAAA,UAAAG,CAAA,CAAAI,GAAA,CAAAP,CAAA,OAAAQ,CAAA,KAAAC,SAAA,UAAAC,CAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,CAAA,IAAAd,CAAA,oBAAAc,CAAA,OAAAC,cAAA,CAAAC,IAAA,CAAAhB,CAAA,EAAAc,CAAA,SAAAG,CAAA,GAAAP,CAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAb,CAAA,EAAAc,CAAA,UAAAG,CAAA,KAAAA,CAAA,CAAAV,GAAA,IAAAU,CAAA,CAAAC,GAAA,IAAAP,MAAA,CAAAC,cAAA,CAAAJ,CAAA,EAAAM,CAAA,EAAAG,CAAA,IAAAT,CAAA,CAAAM,CAAA,IAAAd,CAAA,CAAAc,CAAA,YAAAN,CAAA,CAAAH,OAAA,GAAAL,CAAA,EAAAG,CAAA,IAAAA,CAAA,CAAAe,GAAA,CAAAlB,CAAA,EAAAQ,CAAA,GAAAA,CAAA","ignoreList":[]}
@@ -1,4 +1,5 @@
1
1
  import { ColorSchemeProvider } from '@chayns-components/core';
2
+ import { ChaynsProvider, useFunctions, useValues } from 'chayns-api';
2
3
  import React, { useCallback, useEffect, useLayoutEffect, useMemo, useState } from 'react';
3
4
  import { createPortal } from 'react-dom';
4
5
  import { renderToString } from 'react-dom/server';
@@ -6,11 +7,13 @@ import { StyledTypewriter, StyledTypewriterPseudoText, StyledTypewriterText } fr
6
7
  import { getCharactersCount, getSubTextFromHTML, shuffleArray } from './utils';
7
8
 
8
9
  // noinspection JSUnusedGlobalSymbols
9
- export let TypewriterResetDelay = /*#__PURE__*/function (TypewriterResetDelay) {
10
- TypewriterResetDelay[TypewriterResetDelay["Slow"] = 4000] = "Slow";
11
- TypewriterResetDelay[TypewriterResetDelay["Medium"] = 2000] = "Medium";
12
- TypewriterResetDelay[TypewriterResetDelay["Fast"] = 1000] = "Fast";
13
- return TypewriterResetDelay;
10
+ export let TypewriterDelay = /*#__PURE__*/function (TypewriterDelay) {
11
+ TypewriterDelay[TypewriterDelay["ExtraSlow"] = 4000] = "ExtraSlow";
12
+ TypewriterDelay[TypewriterDelay["Slow"] = 2000] = "Slow";
13
+ TypewriterDelay[TypewriterDelay["Medium"] = 1000] = "Medium";
14
+ TypewriterDelay[TypewriterDelay["Fast"] = 500] = "Fast";
15
+ TypewriterDelay[TypewriterDelay["ExtraFast"] = 250] = "ExtraFast";
16
+ return TypewriterDelay;
14
17
  }({});
15
18
 
16
19
  // noinspection JSUnusedGlobalSymbols
@@ -25,9 +28,10 @@ export let TypewriterSpeed = /*#__PURE__*/function (TypewriterSpeed) {
25
28
  const Typewriter = _ref => {
26
29
  let {
27
30
  children,
31
+ nextTextDelay = TypewriterDelay.Medium,
28
32
  onFinish,
29
33
  pseudoChildren,
30
- resetDelay = TypewriterResetDelay.Medium,
34
+ resetDelay = TypewriterDelay.Medium,
31
35
  shouldForceCursorAnimation = false,
32
36
  shouldHideCursor = false,
33
37
  shouldSortChildrenRandomly = false,
@@ -40,6 +44,8 @@ const Typewriter = _ref => {
40
44
  const [currentChildrenIndex, setCurrentChildrenIndex] = useState(0);
41
45
  const [shouldCount, setShouldCount] = useState(true);
42
46
  const [hasRenderedChildrenOnce, setHasRenderedChildrenOnce] = useState(false);
47
+ const functions = useFunctions();
48
+ const values = useValues();
43
49
  useLayoutEffect(() => {
44
50
  if (children) {
45
51
  setHasRenderedChildrenOnce(false);
@@ -57,23 +63,29 @@ const Typewriter = _ref => {
57
63
  if (areMultipleChildrenGiven) {
58
64
  const currentChildren = sortedChildren[currentChildrenIndex];
59
65
  if (currentChildren) {
60
- return /*#__PURE__*/React.isValidElement(currentChildren) ? renderToString( /*#__PURE__*/React.createElement(ColorSchemeProvider, {
66
+ return /*#__PURE__*/React.isValidElement(currentChildren) ? renderToString( /*#__PURE__*/React.createElement(ChaynsProvider, {
67
+ data: values,
68
+ functions: functions
69
+ }, /*#__PURE__*/React.createElement(ColorSchemeProvider, {
61
70
  color: "#005EB8",
62
71
  colorMode: 0,
63
72
  style: {
64
73
  display: 'inline'
65
74
  }
66
- }, currentChildren)) : currentChildren;
75
+ }, currentChildren))) : currentChildren;
67
76
  }
68
77
  return '';
69
78
  }
70
- return /*#__PURE__*/React.isValidElement(sortedChildren) ? renderToString( /*#__PURE__*/React.createElement(ColorSchemeProvider, {
79
+ return /*#__PURE__*/React.isValidElement(sortedChildren) ? renderToString( /*#__PURE__*/React.createElement(ChaynsProvider, {
80
+ data: values,
81
+ functions: functions
82
+ }, /*#__PURE__*/React.createElement(ColorSchemeProvider, {
71
83
  color: "#005EB8",
72
84
  colorMode: 0,
73
85
  style: {
74
86
  display: 'inline'
75
87
  }
76
- }, sortedChildren)) : sortedChildren;
88
+ }, sortedChildren))) : sortedChildren;
77
89
  }, [areMultipleChildrenGiven, currentChildrenIndex, sortedChildren]);
78
90
  const charactersCount = useMemo(() => getCharactersCount(textContent), [textContent]);
79
91
  const [isResetAnimationActive, setIsResetAnimationActive] = useState(false);
@@ -111,7 +123,7 @@ const Typewriter = _ref => {
111
123
  setTimeout(() => {
112
124
  setIsResetAnimationActive(false);
113
125
  handleSetNextChildrenIndex();
114
- }, resetDelay);
126
+ }, nextTextDelay);
115
127
  }
116
128
  }
117
129
  return nextState;
@@ -142,7 +154,7 @@ const Typewriter = _ref => {
142
154
  setIsResetAnimationActive(true);
143
155
  } else {
144
156
  setShownCharCount(0);
145
- setTimeout(handleSetNextChildrenIndex, resetDelay / 2);
157
+ setTimeout(handleSetNextChildrenIndex, nextTextDelay);
146
158
  }
147
159
  }, resetDelay);
148
160
  }
@@ -155,7 +167,7 @@ const Typewriter = _ref => {
155
167
  return () => {
156
168
  window.clearInterval(interval);
157
169
  };
158
- }, [shouldStopAnimation, speed, textContent.length, charactersCount, isResetAnimationActive, areMultipleChildrenGiven, resetDelay, childrenCount, handleSetNextChildrenIndex, shouldUseResetAnimation, shouldCount, shouldWaitForContent]);
170
+ }, [shouldStopAnimation, speed, textContent.length, charactersCount, isResetAnimationActive, areMultipleChildrenGiven, resetDelay, childrenCount, handleSetNextChildrenIndex, shouldUseResetAnimation, shouldCount, shouldWaitForContent, nextTextDelay]);
159
171
  useEffect(() => {
160
172
  if (!isAnimatingText && typeof onFinish === 'function') {
161
173
  onFinish();
@@ -164,13 +176,16 @@ const Typewriter = _ref => {
164
176
  const shownText = useMemo(() => getSubTextFromHTML(textContent, shownCharCount), [shownCharCount, textContent]);
165
177
  const pseudoTextHTML = useMemo(() => {
166
178
  if (pseudoChildren) {
167
- const pseudoText = /*#__PURE__*/React.isValidElement(pseudoChildren) ? renderToString( /*#__PURE__*/React.createElement(ColorSchemeProvider, {
179
+ const pseudoText = /*#__PURE__*/React.isValidElement(pseudoChildren) ? renderToString( /*#__PURE__*/React.createElement(ChaynsProvider, {
180
+ data: values,
181
+ functions: functions
182
+ }, /*#__PURE__*/React.createElement(ColorSchemeProvider, {
168
183
  color: "#005EB8",
169
184
  colorMode: 0,
170
185
  style: {
171
186
  display: 'inline'
172
187
  }
173
- }, pseudoChildren)) : pseudoChildren;
188
+ }, pseudoChildren))) : pseudoChildren;
174
189
  if (shouldUseAnimationHeight) {
175
190
  return getSubTextFromHTML(pseudoText, shownCharCount);
176
191
  }
@@ -1 +1 @@
1
- {"version":3,"file":"Typewriter.js","names":["ColorSchemeProvider","React","useCallback","useEffect","useLayoutEffect","useMemo","useState","createPortal","renderToString","StyledTypewriter","StyledTypewriterPseudoText","StyledTypewriterText","getCharactersCount","getSubTextFromHTML","shuffleArray","TypewriterResetDelay","TypewriterSpeed","Typewriter","_ref","children","onFinish","pseudoChildren","resetDelay","Medium","shouldForceCursorAnimation","shouldHideCursor","shouldSortChildrenRandomly","shouldUseAnimationHeight","shouldUseResetAnimation","shouldWaitForContent","speed","textStyle","currentChildrenIndex","setCurrentChildrenIndex","shouldCount","setShouldCount","hasRenderedChildrenOnce","setHasRenderedChildrenOnce","sortedChildren","Array","isArray","areMultipleChildrenGiven","childrenCount","length","textContent","currentChildren","isValidElement","createElement","color","colorMode","style","display","charactersCount","isResetAnimationActive","setIsResetAnimationActive","shownCharCount","setShownCharCount","shouldStopAnimation","setShouldStopAnimation","prevChildren","setPrevChildren","isAnimatingText","handleClick","handleSetNextChildrenIndex","newIndex","interval","window","setInterval","prevState","nextState","clearInterval","setTimeout","shownText","pseudoTextHTML","pseudoText","onClick","dangerouslySetInnerHTML","__html","$isAnimatingText","$shouldHideCursor","position","visibility","document","body","displayName"],"sources":["../../../../src/components/typewriter/Typewriter.tsx"],"sourcesContent":["import { ColorSchemeProvider } from '@chayns-components/core';\nimport React, {\n FC,\n ReactElement,\n useCallback,\n useEffect,\n useLayoutEffect,\n useMemo,\n useState,\n} from 'react';\nimport { createPortal } from 'react-dom';\nimport { renderToString } from 'react-dom/server';\nimport {\n StyledTypewriter,\n StyledTypewriterPseudoText,\n StyledTypewriterText,\n} from './Typewriter.styles';\nimport { getCharactersCount, getSubTextFromHTML, shuffleArray } from './utils';\n\n// noinspection JSUnusedGlobalSymbols\nexport enum TypewriterResetDelay {\n Slow = 4000,\n Medium = 2000,\n Fast = 1000,\n}\n\n// noinspection JSUnusedGlobalSymbols\nexport enum TypewriterSpeed {\n ExtraSlow = 40,\n Slow = 20,\n Medium = 10,\n Fast = 5,\n ExtraFast = 2.5,\n}\n\nexport type TypewriterProps = {\n /**\n * The text to type\n */\n children: ReactElement | ReactElement[] | string | string[];\n /**\n * Function that is executed when the typewriter animation has finished. This function will not\n * be executed if multiple texts are used.\n */\n onFinish?: VoidFunction;\n /**\n * Pseudo-element to be rendered invisible during animation to define the size of the element\n * for the typewriter effect. By default, the \"children\" is used for this purpose.\n */\n pseudoChildren?: ReactElement | string;\n /**\n * Waiting time before the typewriter resets the content if multiple texts are given\n */\n resetDelay?: TypewriterResetDelay;\n /**\n * Specifies whether the cursor should be forced to animate even if no text is currently animated.\n */\n shouldForceCursorAnimation?: boolean;\n /**\n * Specifies whether the cursor should be hidden\n */\n shouldHideCursor?: boolean;\n /**\n * Specifies whether the children should be sorted randomly if there are multiple texts.\n * This makes the typewriter start with a different text each time and also changes them\n * in a random order.\n */\n shouldSortChildrenRandomly?: boolean;\n /**\n * Specifies whether the animation should use its full height or the height of the current\n * chunk.\n */\n shouldUseAnimationHeight?: boolean;\n /**\n * Specifies whether the reset of the text should be animated with a backspace animation for\n * multiple texts.\n */\n shouldUseResetAnimation?: boolean;\n /**\n * Whether the typewriter should wait for new content\n */\n shouldWaitForContent?: boolean;\n /**\n * The speed of the animation. Use the TypewriterSpeed enum for this prop.\n */\n speed?: TypewriterSpeed | number;\n /**\n * The style of the typewriter text element\n */\n textStyle?: React.CSSProperties;\n};\n\nconst Typewriter: FC<TypewriterProps> = ({\n children,\n onFinish,\n pseudoChildren,\n resetDelay = TypewriterResetDelay.Medium,\n shouldForceCursorAnimation = false,\n shouldHideCursor = false,\n shouldSortChildrenRandomly = false,\n shouldUseAnimationHeight = false,\n shouldUseResetAnimation = false,\n shouldWaitForContent,\n speed = TypewriterSpeed.Medium,\n textStyle,\n}) => {\n const [currentChildrenIndex, setCurrentChildrenIndex] = useState(0);\n const [shouldCount, setShouldCount] = useState(true);\n const [hasRenderedChildrenOnce, setHasRenderedChildrenOnce] = useState(false);\n\n useLayoutEffect(() => {\n if (children) {\n setHasRenderedChildrenOnce(false);\n }\n }, [children]);\n\n useEffect(() => {\n if (!hasRenderedChildrenOnce) {\n setHasRenderedChildrenOnce(true);\n }\n }, [hasRenderedChildrenOnce]);\n\n const sortedChildren = useMemo(\n () =>\n Array.isArray(children) && shouldSortChildrenRandomly\n ? shuffleArray<ReactElement | string>(children)\n : children,\n [children, shouldSortChildrenRandomly],\n );\n\n const areMultipleChildrenGiven = Array.isArray(sortedChildren);\n const childrenCount = areMultipleChildrenGiven ? sortedChildren.length : 1;\n\n const textContent = useMemo(() => {\n if (areMultipleChildrenGiven) {\n const currentChildren = sortedChildren[currentChildrenIndex];\n\n if (currentChildren) {\n return React.isValidElement(currentChildren)\n ? renderToString(\n <ColorSchemeProvider\n color=\"#005EB8\"\n colorMode={0}\n style={{ display: 'inline' }}\n >\n {currentChildren}\n </ColorSchemeProvider>,\n )\n : (currentChildren as string);\n }\n\n return '';\n }\n\n return React.isValidElement(sortedChildren)\n ? renderToString(\n <ColorSchemeProvider color=\"#005EB8\" colorMode={0} style={{ display: 'inline' }}>\n {sortedChildren}\n </ColorSchemeProvider>,\n )\n : (sortedChildren as string);\n }, [areMultipleChildrenGiven, currentChildrenIndex, sortedChildren]);\n\n const charactersCount = useMemo(() => getCharactersCount(textContent), [textContent]);\n\n const [isResetAnimationActive, setIsResetAnimationActive] = useState(false);\n const [shownCharCount, setShownCharCount] = useState(\n charactersCount > 0 ? 0 : textContent.length,\n );\n const [shouldStopAnimation, setShouldStopAnimation] = useState(false);\n const [prevChildren, setPrevChildren] = useState<TypewriterProps['children']>(children);\n\n useEffect(() => {\n if (children !== prevChildren) {\n setShouldCount(true);\n setPrevChildren(children);\n }\n }, [children, prevChildren]);\n\n const isAnimatingText =\n shownCharCount < textContent.length ||\n shouldForceCursorAnimation ||\n areMultipleChildrenGiven ||\n textContent.length === 0;\n\n const handleClick = useCallback(() => {\n setShouldStopAnimation(true);\n }, []);\n\n const handleSetNextChildrenIndex = useCallback(\n () =>\n setCurrentChildrenIndex(() => {\n let newIndex = currentChildrenIndex + 1;\n\n if (newIndex > childrenCount - 1) {\n newIndex = 0;\n }\n\n return newIndex;\n }),\n [childrenCount, currentChildrenIndex],\n );\n\n useEffect(() => {\n let interval: number | undefined;\n\n if (shouldStopAnimation || charactersCount === 0) {\n setShownCharCount(textContent.length);\n } else if (isResetAnimationActive) {\n interval = window.setInterval(() => {\n setShownCharCount((prevState) => {\n const nextState = prevState - 1;\n\n if (nextState === 0) {\n window.clearInterval(interval);\n\n if (areMultipleChildrenGiven) {\n setTimeout(() => {\n setIsResetAnimationActive(false);\n handleSetNextChildrenIndex();\n }, resetDelay);\n }\n }\n\n return nextState;\n });\n }, speed);\n } else {\n interval = window.setInterval(() => {\n setShownCharCount((prevState) => {\n let nextState = prevState;\n\n if (shouldCount) {\n nextState = prevState + 1;\n }\n\n if (nextState >= charactersCount) {\n if (shouldWaitForContent) {\n setShouldCount(false);\n } else {\n window.clearInterval(interval);\n\n /**\n * At this point, the next value for \"shownCharCount\" is deliberately set to\n * the length of the textContent in order to correctly display HTML elements\n * after the last letter.\n */\n nextState = textContent.length;\n\n if (areMultipleChildrenGiven) {\n setTimeout(() => {\n if (shouldUseResetAnimation) {\n setIsResetAnimationActive(true);\n } else {\n setShownCharCount(0);\n setTimeout(handleSetNextChildrenIndex, resetDelay / 2);\n }\n }, resetDelay);\n }\n }\n }\n\n return nextState;\n });\n }, speed);\n }\n\n return () => {\n window.clearInterval(interval);\n };\n }, [\n shouldStopAnimation,\n speed,\n textContent.length,\n charactersCount,\n isResetAnimationActive,\n areMultipleChildrenGiven,\n resetDelay,\n childrenCount,\n handleSetNextChildrenIndex,\n shouldUseResetAnimation,\n shouldCount,\n shouldWaitForContent,\n ]);\n\n useEffect(() => {\n if (!isAnimatingText && typeof onFinish === 'function') {\n onFinish();\n }\n }, [isAnimatingText, onFinish]);\n\n const shownText = useMemo(\n () => getSubTextFromHTML(textContent, shownCharCount),\n [shownCharCount, textContent],\n );\n\n const pseudoTextHTML = useMemo(() => {\n if (pseudoChildren) {\n const pseudoText = React.isValidElement(pseudoChildren)\n ? renderToString(\n <ColorSchemeProvider\n color=\"#005EB8\"\n colorMode={0}\n style={{ display: 'inline' }}\n >\n {pseudoChildren}\n </ColorSchemeProvider>,\n )\n : (pseudoChildren as string);\n\n if (shouldUseAnimationHeight) {\n return getSubTextFromHTML(pseudoText, shownCharCount);\n }\n\n return pseudoText;\n }\n\n if (shouldUseAnimationHeight && textContent) {\n return getSubTextFromHTML(textContent, shownCharCount);\n }\n\n return textContent || '&#8203;';\n }, [pseudoChildren, shouldUseAnimationHeight, shownCharCount, textContent]);\n\n return useMemo(\n () => (\n <StyledTypewriter onClick={handleClick}>\n {isAnimatingText ? (\n <StyledTypewriterText\n dangerouslySetInnerHTML={{ __html: shownText }}\n $isAnimatingText\n $shouldHideCursor={shouldHideCursor}\n style={textStyle}\n />\n ) : (\n <StyledTypewriterText style={textStyle}>{sortedChildren}</StyledTypewriterText>\n )}\n {isAnimatingText && (\n <StyledTypewriterPseudoText\n dangerouslySetInnerHTML={{ __html: pseudoTextHTML }}\n $isAnimatingText\n $shouldHideCursor={shouldHideCursor}\n />\n )}\n {/*\n The following is needed because some components like the CodeHighlighter will not render correct\n if the element is not rendered on client before...\n */}\n {!hasRenderedChildrenOnce &&\n createPortal(\n <div style={{ position: 'absolute', visibility: 'hidden' }}>\n {children}\n </div>,\n document.body,\n )}\n </StyledTypewriter>\n ),\n [\n children,\n handleClick,\n hasRenderedChildrenOnce,\n isAnimatingText,\n pseudoTextHTML,\n shouldHideCursor,\n shownText,\n sortedChildren,\n textStyle,\n ],\n );\n};\n\nTypewriter.displayName = 'Typewriter';\n\nexport default Typewriter;\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"Typewriter.js","names":["ColorSchemeProvider","ChaynsProvider","useFunctions","useValues","React","useCallback","useEffect","useLayoutEffect","useMemo","useState","createPortal","renderToString","StyledTypewriter","StyledTypewriterPseudoText","StyledTypewriterText","getCharactersCount","getSubTextFromHTML","shuffleArray","TypewriterDelay","TypewriterSpeed","Typewriter","_ref","children","nextTextDelay","Medium","onFinish","pseudoChildren","resetDelay","shouldForceCursorAnimation","shouldHideCursor","shouldSortChildrenRandomly","shouldUseAnimationHeight","shouldUseResetAnimation","shouldWaitForContent","speed","textStyle","currentChildrenIndex","setCurrentChildrenIndex","shouldCount","setShouldCount","hasRenderedChildrenOnce","setHasRenderedChildrenOnce","functions","values","sortedChildren","Array","isArray","areMultipleChildrenGiven","childrenCount","length","textContent","currentChildren","isValidElement","createElement","data","color","colorMode","style","display","charactersCount","isResetAnimationActive","setIsResetAnimationActive","shownCharCount","setShownCharCount","shouldStopAnimation","setShouldStopAnimation","prevChildren","setPrevChildren","isAnimatingText","handleClick","handleSetNextChildrenIndex","newIndex","interval","window","setInterval","prevState","nextState","clearInterval","setTimeout","shownText","pseudoTextHTML","pseudoText","onClick","dangerouslySetInnerHTML","__html","$isAnimatingText","$shouldHideCursor","position","visibility","document","body","displayName"],"sources":["../../../../src/components/typewriter/Typewriter.tsx"],"sourcesContent":["import { ColorSchemeProvider } from '@chayns-components/core';\nimport { ChaynsProvider, useFunctions, useValues } from 'chayns-api';\nimport React, {\n FC,\n ReactElement,\n useCallback,\n useEffect,\n useLayoutEffect,\n useMemo,\n useState,\n} from 'react';\nimport { createPortal } from 'react-dom';\nimport { renderToString } from 'react-dom/server';\nimport {\n StyledTypewriter,\n StyledTypewriterPseudoText,\n StyledTypewriterText,\n} from './Typewriter.styles';\nimport { getCharactersCount, getSubTextFromHTML, shuffleArray } from './utils';\n\n// noinspection JSUnusedGlobalSymbols\nexport enum TypewriterDelay {\n ExtraSlow = 4000,\n Slow = 2000,\n Medium = 1000,\n Fast = 500,\n ExtraFast = 250,\n}\n\n// noinspection JSUnusedGlobalSymbols\nexport enum TypewriterSpeed {\n ExtraSlow = 40,\n Slow = 20,\n Medium = 10,\n Fast = 5,\n ExtraFast = 2.5,\n}\n\nexport type TypewriterProps = {\n /**\n * The text to type\n */\n children: ReactElement | ReactElement[] | string | string[];\n /**\n * The delay in milliseconds before the next text is shown.\n * This prop is only used if multiple texts are given.\n */\n nextTextDelay?: TypewriterDelay;\n /**\n * Function that is executed when the typewriter animation has finished. This function will not\n * be executed if multiple texts are used.\n */\n onFinish?: VoidFunction;\n /**\n * Pseudo-element to be rendered invisible during animation to define the size of the element\n * for the typewriter effect. By default, the \"children\" is used for this purpose.\n */\n pseudoChildren?: ReactElement | string;\n /**\n * Waiting time in milliseconds before the typewriter resets the text.\n * This prop is only used if multiple texts are given.\n */\n resetDelay?: TypewriterDelay;\n /**\n * Specifies whether the cursor should be forced to animate even if no text is currently animated.\n */\n shouldForceCursorAnimation?: boolean;\n /**\n * Specifies whether the cursor should be hidden\n */\n shouldHideCursor?: boolean;\n /**\n * Specifies whether the children should be sorted randomly if there are multiple texts.\n * This makes the typewriter start with a different text each time and also changes them\n * in a random order.\n */\n shouldSortChildrenRandomly?: boolean;\n /**\n * Specifies whether the animation should use its full height or the height of the current\n * chunk.\n */\n shouldUseAnimationHeight?: boolean;\n /**\n * Specifies whether the reset of the text should be animated with a backspace animation for\n * multiple texts.\n */\n shouldUseResetAnimation?: boolean;\n /**\n * Whether the typewriter should wait for new content\n */\n shouldWaitForContent?: boolean;\n /**\n * The speed of the animation. Use the TypewriterSpeed enum for this prop.\n */\n speed?: TypewriterSpeed | number;\n /**\n * The style of the typewriter text element\n */\n textStyle?: React.CSSProperties;\n};\n\nconst Typewriter: FC<TypewriterProps> = ({\n children,\n nextTextDelay = TypewriterDelay.Medium,\n onFinish,\n pseudoChildren,\n resetDelay = TypewriterDelay.Medium,\n shouldForceCursorAnimation = false,\n shouldHideCursor = false,\n shouldSortChildrenRandomly = false,\n shouldUseAnimationHeight = false,\n shouldUseResetAnimation = false,\n shouldWaitForContent,\n speed = TypewriterSpeed.Medium,\n textStyle,\n}) => {\n const [currentChildrenIndex, setCurrentChildrenIndex] = useState(0);\n const [shouldCount, setShouldCount] = useState(true);\n const [hasRenderedChildrenOnce, setHasRenderedChildrenOnce] = useState(false);\n\n const functions = useFunctions();\n const values = useValues();\n\n useLayoutEffect(() => {\n if (children) {\n setHasRenderedChildrenOnce(false);\n }\n }, [children]);\n\n useEffect(() => {\n if (!hasRenderedChildrenOnce) {\n setHasRenderedChildrenOnce(true);\n }\n }, [hasRenderedChildrenOnce]);\n\n const sortedChildren = useMemo(\n () =>\n Array.isArray(children) && shouldSortChildrenRandomly\n ? shuffleArray<ReactElement | string>(children)\n : children,\n [children, shouldSortChildrenRandomly],\n );\n\n const areMultipleChildrenGiven = Array.isArray(sortedChildren);\n const childrenCount = areMultipleChildrenGiven ? sortedChildren.length : 1;\n\n const textContent = useMemo(() => {\n if (areMultipleChildrenGiven) {\n const currentChildren = sortedChildren[currentChildrenIndex];\n\n if (currentChildren) {\n return React.isValidElement(currentChildren)\n ? renderToString(\n <ChaynsProvider data={values} functions={functions}>\n <ColorSchemeProvider\n color=\"#005EB8\"\n colorMode={0}\n style={{ display: 'inline' }}\n >\n {currentChildren}\n </ColorSchemeProvider>\n </ChaynsProvider>,\n )\n : (currentChildren as string);\n }\n\n return '';\n }\n\n return React.isValidElement(sortedChildren)\n ? renderToString(\n <ChaynsProvider data={values} functions={functions}>\n <ColorSchemeProvider\n color=\"#005EB8\"\n colorMode={0}\n style={{ display: 'inline' }}\n >\n {sortedChildren}\n </ColorSchemeProvider>\n </ChaynsProvider>,\n )\n : (sortedChildren as string);\n }, [areMultipleChildrenGiven, currentChildrenIndex, sortedChildren]);\n\n const charactersCount = useMemo(() => getCharactersCount(textContent), [textContent]);\n\n const [isResetAnimationActive, setIsResetAnimationActive] = useState(false);\n const [shownCharCount, setShownCharCount] = useState(\n charactersCount > 0 ? 0 : textContent.length,\n );\n const [shouldStopAnimation, setShouldStopAnimation] = useState(false);\n const [prevChildren, setPrevChildren] = useState<TypewriterProps['children']>(children);\n\n useEffect(() => {\n if (children !== prevChildren) {\n setShouldCount(true);\n setPrevChildren(children);\n }\n }, [children, prevChildren]);\n\n const isAnimatingText =\n shownCharCount < textContent.length ||\n shouldForceCursorAnimation ||\n areMultipleChildrenGiven ||\n textContent.length === 0;\n\n const handleClick = useCallback(() => {\n setShouldStopAnimation(true);\n }, []);\n\n const handleSetNextChildrenIndex = useCallback(\n () =>\n setCurrentChildrenIndex(() => {\n let newIndex = currentChildrenIndex + 1;\n\n if (newIndex > childrenCount - 1) {\n newIndex = 0;\n }\n\n return newIndex;\n }),\n [childrenCount, currentChildrenIndex],\n );\n\n useEffect(() => {\n let interval: number | undefined;\n\n if (shouldStopAnimation || charactersCount === 0) {\n setShownCharCount(textContent.length);\n } else if (isResetAnimationActive) {\n interval = window.setInterval(() => {\n setShownCharCount((prevState) => {\n const nextState = prevState - 1;\n\n if (nextState === 0) {\n window.clearInterval(interval);\n\n if (areMultipleChildrenGiven) {\n setTimeout(() => {\n setIsResetAnimationActive(false);\n handleSetNextChildrenIndex();\n }, nextTextDelay);\n }\n }\n\n return nextState;\n });\n }, speed);\n } else {\n interval = window.setInterval(() => {\n setShownCharCount((prevState) => {\n let nextState = prevState;\n\n if (shouldCount) {\n nextState = prevState + 1;\n }\n\n if (nextState >= charactersCount) {\n if (shouldWaitForContent) {\n setShouldCount(false);\n } else {\n window.clearInterval(interval);\n\n /**\n * At this point, the next value for \"shownCharCount\" is deliberately set to\n * the length of the textContent in order to correctly display HTML elements\n * after the last letter.\n */\n nextState = textContent.length;\n\n if (areMultipleChildrenGiven) {\n setTimeout(() => {\n if (shouldUseResetAnimation) {\n setIsResetAnimationActive(true);\n } else {\n setShownCharCount(0);\n setTimeout(handleSetNextChildrenIndex, nextTextDelay);\n }\n }, resetDelay);\n }\n }\n }\n\n return nextState;\n });\n }, speed);\n }\n\n return () => {\n window.clearInterval(interval);\n };\n }, [\n shouldStopAnimation,\n speed,\n textContent.length,\n charactersCount,\n isResetAnimationActive,\n areMultipleChildrenGiven,\n resetDelay,\n childrenCount,\n handleSetNextChildrenIndex,\n shouldUseResetAnimation,\n shouldCount,\n shouldWaitForContent,\n nextTextDelay,\n ]);\n\n useEffect(() => {\n if (!isAnimatingText && typeof onFinish === 'function') {\n onFinish();\n }\n }, [isAnimatingText, onFinish]);\n\n const shownText = useMemo(\n () => getSubTextFromHTML(textContent, shownCharCount),\n [shownCharCount, textContent],\n );\n\n const pseudoTextHTML = useMemo(() => {\n if (pseudoChildren) {\n const pseudoText = React.isValidElement(pseudoChildren)\n ? renderToString(\n <ChaynsProvider data={values} functions={functions}>\n <ColorSchemeProvider\n color=\"#005EB8\"\n colorMode={0}\n style={{ display: 'inline' }}\n >\n {pseudoChildren}\n </ColorSchemeProvider>\n </ChaynsProvider>,\n )\n : (pseudoChildren as string);\n\n if (shouldUseAnimationHeight) {\n return getSubTextFromHTML(pseudoText, shownCharCount);\n }\n\n return pseudoText;\n }\n\n if (shouldUseAnimationHeight && textContent) {\n return getSubTextFromHTML(textContent, shownCharCount);\n }\n\n return textContent || '&#8203;';\n }, [pseudoChildren, shouldUseAnimationHeight, shownCharCount, textContent]);\n\n return useMemo(\n () => (\n <StyledTypewriter onClick={handleClick}>\n {isAnimatingText ? (\n <StyledTypewriterText\n dangerouslySetInnerHTML={{ __html: shownText }}\n $isAnimatingText\n $shouldHideCursor={shouldHideCursor}\n style={textStyle}\n />\n ) : (\n <StyledTypewriterText style={textStyle}>{sortedChildren}</StyledTypewriterText>\n )}\n {isAnimatingText && (\n <StyledTypewriterPseudoText\n dangerouslySetInnerHTML={{ __html: pseudoTextHTML }}\n $isAnimatingText\n $shouldHideCursor={shouldHideCursor}\n />\n )}\n {/*\n The following is needed because some components like the CodeHighlighter will not render correct\n if the element is not rendered on client before...\n */}\n {!hasRenderedChildrenOnce &&\n createPortal(\n <div style={{ position: 'absolute', visibility: 'hidden' }}>\n {children}\n </div>,\n document.body,\n )}\n </StyledTypewriter>\n ),\n [\n children,\n handleClick,\n hasRenderedChildrenOnce,\n isAnimatingText,\n pseudoTextHTML,\n shouldHideCursor,\n shownText,\n sortedChildren,\n textStyle,\n ],\n );\n};\n\nTypewriter.displayName = 'Typewriter';\n\nexport default Typewriter;\n"],"mappings":"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","ignoreList":[]}
package/lib/esm/index.js CHANGED
@@ -1,2 +1,2 @@
1
- export { default as Typewriter, TypewriterSpeed } from './components/typewriter/Typewriter';
1
+ export { default as Typewriter, TypewriterDelay, TypewriterSpeed } from './components/typewriter/Typewriter';
2
2
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["default","Typewriter","TypewriterSpeed"],"sources":["../../src/index.ts"],"sourcesContent":["export { default as Typewriter, TypewriterSpeed } from './components/typewriter/Typewriter';\n"],"mappings":"AAAA,SAASA,OAAO,IAAIC,UAAU,EAAEC,eAAe,QAAQ,oCAAoC","ignoreList":[]}
1
+ {"version":3,"file":"index.js","names":["default","Typewriter","TypewriterDelay","TypewriterSpeed"],"sources":["../../src/index.ts"],"sourcesContent":["export {\n default as Typewriter,\n TypewriterDelay,\n TypewriterSpeed,\n} from './components/typewriter/Typewriter';\n"],"mappings":"AAAA,SACIA,OAAO,IAAIC,UAAU,EACrBC,eAAe,EACfC,eAAe,QACZ,oCAAoC","ignoreList":[]}
@@ -1,8 +1,10 @@
1
1
  import React, { FC, ReactElement } from 'react';
2
- export declare enum TypewriterResetDelay {
3
- Slow = 4000,
4
- Medium = 2000,
5
- Fast = 1000
2
+ export declare enum TypewriterDelay {
3
+ ExtraSlow = 4000,
4
+ Slow = 2000,
5
+ Medium = 1000,
6
+ Fast = 500,
7
+ ExtraFast = 250
6
8
  }
7
9
  export declare enum TypewriterSpeed {
8
10
  ExtraSlow = 40,
@@ -16,6 +18,11 @@ export type TypewriterProps = {
16
18
  * The text to type
17
19
  */
18
20
  children: ReactElement | ReactElement[] | string | string[];
21
+ /**
22
+ * The delay in milliseconds before the next text is shown.
23
+ * This prop is only used if multiple texts are given.
24
+ */
25
+ nextTextDelay?: TypewriterDelay;
19
26
  /**
20
27
  * Function that is executed when the typewriter animation has finished. This function will not
21
28
  * be executed if multiple texts are used.
@@ -27,9 +34,10 @@ export type TypewriterProps = {
27
34
  */
28
35
  pseudoChildren?: ReactElement | string;
29
36
  /**
30
- * Waiting time before the typewriter resets the content if multiple texts are given
37
+ * Waiting time in milliseconds before the typewriter resets the text.
38
+ * This prop is only used if multiple texts are given.
31
39
  */
32
- resetDelay?: TypewriterResetDelay;
40
+ resetDelay?: TypewriterDelay;
33
41
  /**
34
42
  * Specifies whether the cursor should be forced to animate even if no text is currently animated.
35
43
  */
@@ -1 +1 @@
1
- export { default as Typewriter, TypewriterSpeed } from './components/typewriter/Typewriter';
1
+ export { default as Typewriter, TypewriterDelay, TypewriterSpeed, } from './components/typewriter/Typewriter';
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@chayns-components/typewriter",
3
- "version": "5.0.0-beta.756",
3
+ "version": "5.0.0-beta.758",
4
4
  "description": "A set of beautiful React components for developing your own applications with chayns.",
5
5
  "sideEffects": false,
6
6
  "browserslist": [
@@ -79,5 +79,5 @@
79
79
  "publishConfig": {
80
80
  "access": "public"
81
81
  },
82
- "gitHead": "dfe4e1dc24876fccdc23cc832eb0ef248cede044"
82
+ "gitHead": "ea68df6a80712f52cea9f4f564d169961cabe829"
83
83
  }