@salutejs/plasma-new-hope 0.119.0-canary.1347.10280706154.0 → 0.119.0-dev.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (117) hide show
  1. package/cjs/components/Accordion/Accordion.tokens.js +1 -0
  2. package/cjs/components/Accordion/Accordion.tokens.js.map +1 -1
  3. package/cjs/components/Accordion/ui/AccordionItem/AccordionItem.styles.js +2 -2
  4. package/cjs/components/Accordion/ui/AccordionItem/AccordionItem.styles.js.map +1 -1
  5. package/cjs/components/Autocomplete/Autocomplete.js +3 -12
  6. package/cjs/components/Autocomplete/Autocomplete.js.map +1 -1
  7. package/cjs/components/Modal/Modal.js +3 -1
  8. package/cjs/components/Modal/Modal.js.map +1 -1
  9. package/cjs/hooks/useFocusTrap.js +97 -0
  10. package/cjs/hooks/useFocusTrap.js.map +1 -0
  11. package/cjs/index.js +2 -0
  12. package/cjs/index.js.map +1 -1
  13. package/cjs/utils/focusManager.js +56 -0
  14. package/cjs/utils/focusManager.js.map +1 -0
  15. package/cjs/utils/scopeTab.js +37 -0
  16. package/cjs/utils/scopeTab.js.map +1 -0
  17. package/cjs/utils/tabbable.js +51 -0
  18. package/cjs/utils/tabbable.js.map +1 -0
  19. package/emotion/cjs/components/Accordion/Accordion.tokens.js +1 -0
  20. package/emotion/cjs/components/Accordion/ui/AccordionItem/AccordionItem.styles.js +2 -2
  21. package/emotion/cjs/components/Autocomplete/Autocomplete.js +3 -12
  22. package/emotion/cjs/components/Modal/Modal.js +4 -3
  23. package/emotion/cjs/examples/plasma_b2c/components/Accordion/Accordion.config.js +6 -6
  24. package/emotion/cjs/examples/plasma_b2c/components/Modal/Modal.stories.tsx +113 -1
  25. package/emotion/cjs/examples/plasma_web/components/Accordion/Accordion.config.js +8 -8
  26. package/emotion/cjs/examples/plasma_web/components/Modal/Modal.stories.tsx +113 -1
  27. package/emotion/cjs/hooks/index.js +7 -0
  28. package/emotion/cjs/hooks/useFocusTrap.js +95 -0
  29. package/emotion/cjs/utils/focusManager.js +60 -0
  30. package/emotion/cjs/utils/scopeTab.js +35 -0
  31. package/emotion/cjs/utils/tabbable.js +46 -0
  32. package/emotion/cjs/utils/useFocusTrap.js +95 -0
  33. package/emotion/es/components/Accordion/Accordion.tokens.js +1 -0
  34. package/emotion/es/components/Accordion/ui/AccordionItem/AccordionItem.styles.js +2 -2
  35. package/emotion/es/components/Autocomplete/Autocomplete.js +3 -12
  36. package/emotion/es/components/Modal/Modal.js +3 -2
  37. package/emotion/es/examples/plasma_b2c/components/Accordion/Accordion.config.js +6 -6
  38. package/emotion/es/examples/plasma_b2c/components/Modal/Modal.stories.tsx +113 -1
  39. package/emotion/es/examples/plasma_web/components/Accordion/Accordion.config.js +8 -8
  40. package/emotion/es/examples/plasma_web/components/Modal/Modal.stories.tsx +113 -1
  41. package/emotion/es/hooks/index.js +1 -0
  42. package/emotion/es/hooks/useFocusTrap.js +90 -0
  43. package/emotion/es/utils/focusManager.js +55 -0
  44. package/emotion/es/utils/scopeTab.js +30 -0
  45. package/emotion/es/utils/tabbable.js +40 -0
  46. package/emotion/es/utils/useFocusTrap.js +90 -0
  47. package/es/components/Accordion/Accordion.tokens.js +1 -0
  48. package/es/components/Accordion/Accordion.tokens.js.map +1 -1
  49. package/es/components/Accordion/ui/AccordionItem/AccordionItem.styles.js +2 -2
  50. package/es/components/Accordion/ui/AccordionItem/AccordionItem.styles.js.map +1 -1
  51. package/es/components/Autocomplete/Autocomplete.js +3 -12
  52. package/es/components/Autocomplete/Autocomplete.js.map +1 -1
  53. package/es/components/Modal/Modal.js +4 -2
  54. package/es/components/Modal/Modal.js.map +1 -1
  55. package/es/hooks/useFocusTrap.js +93 -0
  56. package/es/hooks/useFocusTrap.js.map +1 -0
  57. package/es/index.js +1 -0
  58. package/es/index.js.map +1 -1
  59. package/es/utils/focusManager.js +52 -0
  60. package/es/utils/focusManager.js.map +1 -0
  61. package/es/utils/scopeTab.js +33 -0
  62. package/es/utils/scopeTab.js.map +1 -0
  63. package/es/utils/tabbable.js +43 -0
  64. package/es/utils/tabbable.js.map +1 -0
  65. package/package.json +4 -4
  66. package/styled-components/cjs/components/Accordion/Accordion.tokens.js +1 -0
  67. package/styled-components/cjs/components/Accordion/ui/AccordionItem/AccordionItem.styles.js +2 -2
  68. package/styled-components/cjs/components/Autocomplete/Autocomplete.js +3 -12
  69. package/styled-components/cjs/components/Modal/Modal.js +4 -3
  70. package/styled-components/cjs/examples/plasma_b2c/components/Accordion/Accordion.config.js +2 -2
  71. package/styled-components/cjs/examples/plasma_b2c/components/Modal/Modal.stories.tsx +113 -1
  72. package/styled-components/cjs/examples/plasma_web/components/Accordion/Accordion.config.js +2 -2
  73. package/styled-components/cjs/examples/plasma_web/components/Modal/Modal.stories.tsx +113 -1
  74. package/styled-components/cjs/hooks/index.js +7 -0
  75. package/styled-components/cjs/hooks/useFocusTrap.js +95 -0
  76. package/styled-components/cjs/utils/focusManager.js +60 -0
  77. package/styled-components/cjs/utils/scopeTab.js +35 -0
  78. package/styled-components/cjs/utils/tabbable.js +46 -0
  79. package/styled-components/cjs/utils/useFocusTrap.js +95 -0
  80. package/styled-components/es/components/Accordion/Accordion.tokens.js +1 -0
  81. package/styled-components/es/components/Accordion/ui/AccordionItem/AccordionItem.styles.js +2 -2
  82. package/styled-components/es/components/Autocomplete/Autocomplete.js +3 -12
  83. package/styled-components/es/components/Modal/Modal.js +3 -2
  84. package/styled-components/es/examples/plasma_b2c/components/Accordion/Accordion.config.js +2 -2
  85. package/styled-components/es/examples/plasma_b2c/components/Modal/Modal.stories.tsx +113 -1
  86. package/styled-components/es/examples/plasma_web/components/Accordion/Accordion.config.js +2 -2
  87. package/styled-components/es/examples/plasma_web/components/Modal/Modal.stories.tsx +113 -1
  88. package/styled-components/es/hooks/index.js +1 -0
  89. package/styled-components/es/hooks/useFocusTrap.js +90 -0
  90. package/styled-components/es/utils/focusManager.js +55 -0
  91. package/styled-components/es/utils/scopeTab.js +30 -0
  92. package/styled-components/es/utils/tabbable.js +40 -0
  93. package/styled-components/es/utils/useFocusTrap.js +90 -0
  94. package/types/components/Accordion/Accordion.tokens.d.ts +1 -0
  95. package/types/components/Accordion/Accordion.tokens.d.ts.map +1 -1
  96. package/types/components/Autocomplete/Autocomplete.d.ts.map +1 -1
  97. package/types/components/Autocomplete/Autocomplete.types.d.ts +0 -4
  98. package/types/components/Autocomplete/Autocomplete.types.d.ts.map +1 -1
  99. package/types/components/Modal/Modal.d.ts.map +1 -1
  100. package/types/examples/plasma_b2c/components/Accordion/Accordion.config.d.ts.map +1 -1
  101. package/types/examples/plasma_web/components/Accordion/Accordion.config.d.ts.map +1 -1
  102. package/types/hooks/index.d.ts +1 -0
  103. package/types/hooks/index.d.ts.map +1 -1
  104. package/types/hooks/useFocusTrap.d.ts +6 -0
  105. package/types/hooks/useFocusTrap.d.ts.map +1 -0
  106. package/types/utils/focusManager.d.ts +15 -0
  107. package/types/utils/focusManager.d.ts.map +1 -0
  108. package/types/utils/scopeTab.d.ts +7 -0
  109. package/types/utils/scopeTab.d.ts.map +1 -0
  110. package/types/utils/tabbable.d.ts +6 -0
  111. package/types/utils/tabbable.d.ts.map +1 -0
  112. package/types/utils/useFocusTrap.d.ts +6 -0
  113. package/types/utils/useFocusTrap.d.ts.map +1 -0
  114. package/emotion/cjs/components/Autocomplete/Autocomplete.template-doc.mdx +0 -561
  115. package/emotion/es/components/Autocomplete/Autocomplete.template-doc.mdx +0 -561
  116. package/styled-components/cjs/components/Autocomplete/Autocomplete.template-doc.mdx +0 -561
  117. package/styled-components/es/components/Autocomplete/Autocomplete.template-doc.mdx +0 -561
@@ -1,4 +1,4 @@
1
- import React, { useState } from 'react';
1
+ import React, { useCallback, useRef, useState } from 'react';
2
2
  import styled from '@emotion/styled';
3
3
  import type { ComponentProps } from 'react';
4
4
  import type { StoryObj, Meta } from '@storybook/react';
@@ -6,6 +6,7 @@ import { SSRProvider } from '@salutejs/plasma-core';
6
6
 
7
7
  import { PopupProvider, popupClasses } from '../Popup/Popup';
8
8
  import { Button } from '../Button/Button';
9
+ import { TextField } from '../TextField/TextField';
9
10
  import { WithTheme } from '../../../_helpers';
10
11
 
11
12
  import { Modal, modalClasses } from './Modal';
@@ -206,3 +207,114 @@ export const ModalDemo: StoryObj<StoryModalProps> = {
206
207
  },
207
208
  render: (args) => <StoryModalDemo {...args} />,
208
209
  };
210
+
211
+ const StyledModalAnimation = styled(Modal)`
212
+ /* stylelint-disable */
213
+ && .${popupClasses.root} {
214
+ animation: fadeIn 1s forwards;
215
+ }
216
+
217
+ &&.${popupClasses.endAnimation} .${popupClasses.root} {
218
+ animation: fadeOut 1s forwards;
219
+ }
220
+
221
+ && .${modalClasses.overlay} {
222
+ animation: overlayFadeIn 1s forwards;
223
+ }
224
+
225
+ &&.${popupClasses.endAnimation} .${modalClasses.overlay} {
226
+ animation: overlayFadeOut 1s forwards;
227
+ }
228
+ /* stylelint-enable */
229
+
230
+ @keyframes overlayFadeIn {
231
+ from {
232
+ opacity: 0;
233
+ }
234
+
235
+ to {
236
+ opacity: 1;
237
+ }
238
+ }
239
+
240
+ @keyframes overlayFadeOut {
241
+ from {
242
+ opacity: 1;
243
+ }
244
+
245
+ to {
246
+ opacity: 0;
247
+ }
248
+ }
249
+
250
+ @keyframes fadeIn {
251
+ from {
252
+ opacity: 0;
253
+ transform: translate(-50%, 100%);
254
+ }
255
+
256
+ to {
257
+ opacity: 1;
258
+ transform: translate(-50%, -50%);
259
+ }
260
+ }
261
+
262
+ @keyframes fadeOut {
263
+ from {
264
+ opacity: 1;
265
+ transform: translate(-50%, -50%);
266
+ }
267
+
268
+ to {
269
+ opacity: 0;
270
+ transform: translate(-50%, 100%);
271
+ }
272
+ }
273
+ `;
274
+
275
+ const StoryModalAnimationDemo = ({ placement, offsetX, offsetY, ...rest }: StoryModalProps) => {
276
+ const ref = useRef(null);
277
+ const [isOpen, setIsOpen] = useState(false);
278
+
279
+ const close = useCallback(() => {
280
+ setIsOpen(false);
281
+ }, []);
282
+
283
+ return (
284
+ <SSRProvider>
285
+ <PopupProvider>
286
+ <Button view="default" text="Открыть новое модальное окно" onClick={() => setIsOpen(!isOpen)} />
287
+ <StyledModalAnimation
288
+ id="modal"
289
+ frame="theme-root"
290
+ withAnimation
291
+ onClose={() => setIsOpen(false)}
292
+ isOpen={isOpen}
293
+ placement={placement}
294
+ offset={[offsetX, offsetY]}
295
+ initialFocusRef={ref}
296
+ {...rest}
297
+ >
298
+ <Content>
299
+ <TextField value="Text" onChange={() => {}} />
300
+ <TextField ref={ref} value="Text2" onChange={() => {}} />
301
+ <Button text="Закрыть" onClick={close} />
302
+ </Content>
303
+ </StyledModalAnimation>
304
+ </PopupProvider>
305
+ </SSRProvider>
306
+ );
307
+ };
308
+
309
+ export const ModalBottomAnimation: StoryObj<StoryModalProps> = {
310
+ args: {
311
+ placement: 'bottom',
312
+ withAnimation: true,
313
+ withBlur: false,
314
+ closeOnEsc: true,
315
+ closeOnOverlayClick: true,
316
+ offsetX: 0,
317
+ offsetY: 0,
318
+ },
319
+ render: (args) => <StoryModalAnimationDemo {...args} />,
320
+ };