@salutejs/plasma-new-hope 0.116.0-canary.1344.10266908694.0 → 0.116.1-canary.1345.10268848667.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (118) hide show
  1. package/cjs/components/Accordion/Accordion.tokens.js +0 -1
  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/DatePicker/DatePickerBase.styles.js +1 -1
  6. package/cjs/components/DatePicker/DatePickerBase.styles.js.map +1 -1
  7. package/cjs/components/DatePicker/DatePickerBase.styles_1whkrlf.css +1 -0
  8. package/cjs/components/DatePicker/RangeDate/RangeDate.js +8 -0
  9. package/cjs/components/DatePicker/RangeDate/RangeDate.js.map +1 -1
  10. package/cjs/components/DatePicker/SingleDate/SingleDate.css +4 -4
  11. package/cjs/components/DatePicker/SingleDate/SingleDate.js +4 -0
  12. package/cjs/components/DatePicker/SingleDate/SingleDate.js.map +1 -1
  13. package/cjs/components/DatePicker/SingleDate/SingleDate.styles.js +1 -1
  14. package/cjs/components/DatePicker/SingleDate/SingleDate.styles.js.map +1 -1
  15. package/cjs/components/DatePicker/SingleDate/SingleDate.styles_qt45m5.css +5 -0
  16. package/cjs/components/DatePicker/SingleDate/variations/_size/base.js +1 -1
  17. package/cjs/components/DatePicker/SingleDate/variations/_size/base.js.map +1 -1
  18. package/cjs/components/DatePicker/SingleDate/variations/_size/base_g7zrur.css +1 -0
  19. package/cjs/components/Modal/Modal.js +1 -1
  20. package/cjs/components/Modal/Modal.js.map +1 -1
  21. package/cjs/index.css +4 -4
  22. package/emotion/cjs/components/Accordion/Accordion.tokens.js +0 -1
  23. package/emotion/cjs/components/Accordion/ui/AccordionItem/AccordionItem.styles.js +2 -2
  24. package/emotion/cjs/components/DatePicker/DatePickerBase.styles.js +1 -1
  25. package/emotion/cjs/components/DatePicker/RangeDate/RangeDate.js +8 -0
  26. package/emotion/cjs/components/DatePicker/SingleDate/SingleDate.js +4 -0
  27. package/emotion/cjs/components/DatePicker/SingleDate/SingleDate.styles.js +5 -14
  28. package/emotion/cjs/components/DatePicker/SingleDate/variations/_size/base.js +1 -1
  29. package/emotion/cjs/components/Modal/Modal.js +1 -1
  30. package/emotion/cjs/examples/plasma_b2c/components/Accordion/Accordion.config.js +6 -6
  31. package/emotion/cjs/examples/plasma_b2c/components/DatePicker/DatePicker.config.js +7 -7
  32. package/emotion/cjs/examples/plasma_b2c/components/DatePicker/DatePicker.stories.tsx +80 -1
  33. package/emotion/cjs/examples/plasma_b2c/components/Modal/Modal.stories.tsx +115 -1
  34. package/emotion/cjs/examples/plasma_web/components/Accordion/Accordion.config.js +8 -8
  35. package/emotion/cjs/examples/plasma_web/components/DatePicker/DatePicker.stories.tsx +80 -1
  36. package/emotion/cjs/examples/plasma_web/components/Modal/Modal.stories.tsx +115 -1
  37. package/emotion/es/components/Accordion/Accordion.tokens.js +0 -1
  38. package/emotion/es/components/Accordion/ui/AccordionItem/AccordionItem.styles.js +2 -2
  39. package/emotion/es/components/DatePicker/DatePickerBase.styles.js +1 -1
  40. package/emotion/es/components/DatePicker/RangeDate/RangeDate.js +8 -0
  41. package/emotion/es/components/DatePicker/SingleDate/SingleDate.js +4 -0
  42. package/emotion/es/components/DatePicker/SingleDate/SingleDate.styles.js +6 -15
  43. package/emotion/es/components/DatePicker/SingleDate/variations/_size/base.js +1 -1
  44. package/emotion/es/components/Modal/Modal.js +1 -1
  45. package/emotion/es/examples/plasma_b2c/components/Accordion/Accordion.config.js +6 -6
  46. package/emotion/es/examples/plasma_b2c/components/DatePicker/DatePicker.config.js +7 -7
  47. package/emotion/es/examples/plasma_b2c/components/DatePicker/DatePicker.stories.tsx +80 -1
  48. package/emotion/es/examples/plasma_b2c/components/Modal/Modal.stories.tsx +115 -1
  49. package/emotion/es/examples/plasma_web/components/Accordion/Accordion.config.js +8 -8
  50. package/emotion/es/examples/plasma_web/components/DatePicker/DatePicker.stories.tsx +80 -1
  51. package/emotion/es/examples/plasma_web/components/Modal/Modal.stories.tsx +115 -1
  52. package/es/components/Accordion/Accordion.tokens.js +0 -1
  53. package/es/components/Accordion/Accordion.tokens.js.map +1 -1
  54. package/es/components/Accordion/ui/AccordionItem/AccordionItem.styles.js +2 -2
  55. package/es/components/Accordion/ui/AccordionItem/AccordionItem.styles.js.map +1 -1
  56. package/es/components/DatePicker/DatePickerBase.styles.js +1 -1
  57. package/es/components/DatePicker/DatePickerBase.styles.js.map +1 -1
  58. package/es/components/DatePicker/DatePickerBase.styles_1whkrlf.css +1 -0
  59. package/es/components/DatePicker/RangeDate/RangeDate.js +8 -0
  60. package/es/components/DatePicker/RangeDate/RangeDate.js.map +1 -1
  61. package/es/components/DatePicker/SingleDate/SingleDate.css +4 -4
  62. package/es/components/DatePicker/SingleDate/SingleDate.js +4 -0
  63. package/es/components/DatePicker/SingleDate/SingleDate.js.map +1 -1
  64. package/es/components/DatePicker/SingleDate/SingleDate.styles.js +1 -1
  65. package/es/components/DatePicker/SingleDate/SingleDate.styles.js.map +1 -1
  66. package/es/components/DatePicker/SingleDate/SingleDate.styles_qt45m5.css +5 -0
  67. package/es/components/DatePicker/SingleDate/variations/_size/base.js +1 -1
  68. package/es/components/DatePicker/SingleDate/variations/_size/base.js.map +1 -1
  69. package/es/components/DatePicker/SingleDate/variations/_size/base_g7zrur.css +1 -0
  70. package/es/components/Modal/Modal.js +1 -1
  71. package/es/components/Modal/Modal.js.map +1 -1
  72. package/es/index.css +4 -4
  73. package/package.json +4 -4
  74. package/styled-components/cjs/components/Accordion/Accordion.tokens.js +0 -1
  75. package/styled-components/cjs/components/Accordion/ui/AccordionItem/AccordionItem.styles.js +2 -2
  76. package/styled-components/cjs/components/DatePicker/DatePickerBase.styles.js +1 -1
  77. package/styled-components/cjs/components/DatePicker/RangeDate/RangeDate.js +8 -0
  78. package/styled-components/cjs/components/DatePicker/SingleDate/SingleDate.js +4 -0
  79. package/styled-components/cjs/components/DatePicker/SingleDate/SingleDate.styles.js +2 -2
  80. package/styled-components/cjs/components/DatePicker/SingleDate/variations/_size/base.js +1 -1
  81. package/styled-components/cjs/components/Modal/Modal.js +1 -1
  82. package/styled-components/cjs/examples/plasma_b2c/components/Accordion/Accordion.config.js +2 -2
  83. package/styled-components/cjs/examples/plasma_b2c/components/DatePicker/DatePicker.config.js +1 -1
  84. package/styled-components/cjs/examples/plasma_b2c/components/DatePicker/DatePicker.stories.tsx +80 -1
  85. package/styled-components/cjs/examples/plasma_b2c/components/Modal/Modal.stories.tsx +115 -1
  86. package/styled-components/cjs/examples/plasma_web/components/Accordion/Accordion.config.js +2 -2
  87. package/styled-components/cjs/examples/plasma_web/components/DatePicker/DatePicker.stories.tsx +80 -1
  88. package/styled-components/cjs/examples/plasma_web/components/Modal/Modal.stories.tsx +115 -1
  89. package/styled-components/es/components/Accordion/Accordion.tokens.js +0 -1
  90. package/styled-components/es/components/Accordion/ui/AccordionItem/AccordionItem.styles.js +2 -2
  91. package/styled-components/es/components/DatePicker/DatePickerBase.styles.js +1 -1
  92. package/styled-components/es/components/DatePicker/RangeDate/RangeDate.js +8 -0
  93. package/styled-components/es/components/DatePicker/SingleDate/SingleDate.js +4 -0
  94. package/styled-components/es/components/DatePicker/SingleDate/SingleDate.styles.js +3 -3
  95. package/styled-components/es/components/DatePicker/SingleDate/variations/_size/base.js +1 -1
  96. package/styled-components/es/components/Modal/Modal.js +1 -1
  97. package/styled-components/es/examples/plasma_b2c/components/Accordion/Accordion.config.js +2 -2
  98. package/styled-components/es/examples/plasma_b2c/components/DatePicker/DatePicker.config.js +1 -1
  99. package/styled-components/es/examples/plasma_b2c/components/DatePicker/DatePicker.stories.tsx +80 -1
  100. package/styled-components/es/examples/plasma_b2c/components/Modal/Modal.stories.tsx +115 -1
  101. package/styled-components/es/examples/plasma_web/components/Accordion/Accordion.config.js +2 -2
  102. package/styled-components/es/examples/plasma_web/components/DatePicker/DatePicker.stories.tsx +80 -1
  103. package/styled-components/es/examples/plasma_web/components/Modal/Modal.stories.tsx +115 -1
  104. package/types/components/Accordion/Accordion.tokens.d.ts +0 -1
  105. package/types/components/Accordion/Accordion.tokens.d.ts.map +1 -1
  106. package/types/components/DatePicker/DatePickerBase.styles.d.ts.map +1 -1
  107. package/types/components/DatePicker/RangeDate/RangeDate.d.ts.map +1 -1
  108. package/types/components/DatePicker/SingleDate/SingleDate.d.ts.map +1 -1
  109. package/types/components/DatePicker/SingleDate/SingleDate.styles.d.ts.map +1 -1
  110. package/types/components/DatePicker/SingleDate/variations/_size/base.d.ts.map +1 -1
  111. package/types/examples/plasma_b2c/components/Accordion/Accordion.config.d.ts.map +1 -1
  112. package/types/examples/plasma_web/components/Accordion/Accordion.config.d.ts.map +1 -1
  113. package/cjs/components/DatePicker/DatePickerBase.styles_192va2p.css +0 -1
  114. package/cjs/components/DatePicker/SingleDate/SingleDate.styles_18z9fw1.css +0 -5
  115. package/cjs/components/DatePicker/SingleDate/variations/_size/base_lf7y25.css +0 -1
  116. package/es/components/DatePicker/DatePickerBase.styles_192va2p.css +0 -1
  117. package/es/components/DatePicker/SingleDate/SingleDate.styles_18z9fw1.css +0 -5
  118. package/es/components/DatePicker/SingleDate/variations/_size/base_lf7y25.css +0 -1
@@ -1,4 +1,4 @@
1
- import React, { ComponentProps, useRef, useState } from 'react';
1
+ import React, { ComponentProps, useEffect, useRef, useState } from 'react';
2
2
  import type { StoryObj, Meta } from '@storybook/react';
3
3
  import { action } from '@storybook/addon-actions';
4
4
  import { IconPlaceholder } from '@salutejs/plasma-sb-utils';
@@ -263,3 +263,82 @@ export const Range: StoryObj<StoryPropsRange> = {
263
263
  },
264
264
  render: (args) => <StoryRange {...args} />,
265
265
  };
266
+
267
+ const StoryDeferred = ({
268
+ enableContentLeft,
269
+ enableContentRight,
270
+ valueError,
271
+ valueSuccess,
272
+ size,
273
+ ...rest
274
+ }: StoryPropsDefault) => {
275
+ const [isOpen, setIsOpen] = useState(false);
276
+
277
+ const [defVal, setDefVal] = useState<Date | undefined>(undefined);
278
+
279
+ const iconSize = size === 'xs' ? 'xs' : 's';
280
+
281
+ useEffect(() => {
282
+ setTimeout(() => {
283
+ setDefVal(new Date(2024, 5, 14));
284
+ }, 5000);
285
+ }, []);
286
+
287
+ return (
288
+ <>
289
+ <h3>Асинхронная установка даты по умолчанию</h3>
290
+ <DatePicker
291
+ defaultDate={defVal}
292
+ isOpen={isOpen}
293
+ size={size}
294
+ valueError={valueError}
295
+ valueSuccess={valueSuccess}
296
+ contentLeft={enableContentLeft ? <IconPlaceholder size={iconSize} /> : undefined}
297
+ contentRight={enableContentRight ? <IconPlaceholder size={iconSize} /> : undefined}
298
+ onBlur={onBlur}
299
+ onFocus={onFocus}
300
+ onToggle={(is) => setIsOpen(is)}
301
+ onChangeValue={(e, currentValue) => {
302
+ onChangeValue(e, currentValue);
303
+ }}
304
+ onCommitDate={() => setIsOpen(false)}
305
+ {...rest}
306
+ />
307
+ </>
308
+ );
309
+ };
310
+
311
+ export const Deferred: StoryObj<StoryPropsDefault> = {
312
+ argTypes: {
313
+ defaultDate: {
314
+ control: {
315
+ type: 'date',
316
+ },
317
+ },
318
+ labelPlacement: {
319
+ options: labelPlacements,
320
+ control: {
321
+ type: 'inline-radio',
322
+ },
323
+ },
324
+ },
325
+ args: {
326
+ label: 'Лейбл',
327
+ leftHelper: 'Подсказка к полю',
328
+ placeholder: '30.05.2024',
329
+ size: 'l',
330
+ view: 'default',
331
+ labelPlacement: 'outer',
332
+ min: new Date(2024, 1, 1),
333
+ max: new Date(2024, 12, 29),
334
+ maskWithFormat: false,
335
+ disabled: false,
336
+ readOnly: false,
337
+ textBefore: '',
338
+ enableContentLeft: true,
339
+ enableContentRight: true,
340
+ valueError: false,
341
+ valueSuccess: false,
342
+ },
343
+ render: (args) => <StoryDeferred {...args} />,
344
+ };
@@ -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,116 @@ 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
+ {/* <StyledWrapper> */}
286
+ <PopupProvider>
287
+ <Button view="default" text="Открыть новое модальное окно" onClick={() => setIsOpen(!isOpen)} />
288
+ <StyledModalAnimation
289
+ id="modal"
290
+ frame="theme-root"
291
+ withAnimation
292
+ onClose={() => setIsOpen(false)}
293
+ isOpen={isOpen}
294
+ placement={placement}
295
+ offset={[offsetX, offsetY]}
296
+ initialFocusRef={ref}
297
+ {...rest}
298
+ >
299
+ <Content>
300
+ <TextField value="Text" onChange={() => {}} />
301
+ <TextField ref={ref} value="Text2" onChange={() => {}} />
302
+ <Button text="Закрыть" onClick={close} />
303
+ </Content>
304
+ </StyledModalAnimation>
305
+ </PopupProvider>
306
+ {/* </StyledWrapper> */}
307
+ </SSRProvider>
308
+ );
309
+ };
310
+
311
+ export const ModalBottomAnimation: StoryObj<StoryModalProps> = {
312
+ args: {
313
+ placement: 'bottom',
314
+ withAnimation: true,
315
+ withBlur: false,
316
+ closeOnEsc: true,
317
+ closeOnOverlayClick: true,
318
+ offsetX: 0,
319
+ offsetY: 0,
320
+ },
321
+ render: (args) => <StoryModalAnimationDemo {...args} />,
322
+ };