@cloud-ru/uikit-product-modal-predefined 0.9.3 → 0.9.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (222) hide show
  1. package/CHANGELOG.md +11 -0
  2. package/dist/cjs/components/AdaptiveDeleteModal/AdaptiveDeleteModal.d.ts +5 -0
  3. package/dist/cjs/components/AdaptiveDeleteModal/AdaptiveDeleteModal.js +22 -0
  4. package/dist/cjs/components/AdaptiveDeleteModal/index.d.ts +1 -0
  5. package/dist/cjs/components/AdaptiveDeleteModal/index.js +17 -0
  6. package/dist/cjs/components/AdaptiveRecallModal/AdaptiveRecallModal.d.ts +5 -0
  7. package/dist/cjs/components/AdaptiveRecallModal/AdaptiveRecallModal.js +22 -0
  8. package/dist/cjs/components/AdaptiveRecallModal/index.d.ts +1 -0
  9. package/dist/cjs/components/AdaptiveRecallModal/index.js +17 -0
  10. package/dist/cjs/components/AdaptiveReleaseNotesModal/AdaptiveReleaseNotesModal.d.ts +5 -0
  11. package/dist/cjs/components/AdaptiveReleaseNotesModal/AdaptiveReleaseNotesModal.js +22 -0
  12. package/dist/cjs/components/AdaptiveReleaseNotesModal/index.d.ts +1 -0
  13. package/dist/cjs/components/AdaptiveReleaseNotesModal/index.js +17 -0
  14. package/dist/cjs/components/DefaultDeleteModalBody/DefaultDeleteModalBody.d.ts +16 -0
  15. package/dist/cjs/components/DefaultDeleteModalBody/DefaultDeleteModalBody.js +20 -0
  16. package/dist/cjs/components/DefaultDeleteModalBody/index.d.ts +1 -0
  17. package/dist/cjs/components/DefaultDeleteModalBody/index.js +17 -0
  18. package/dist/cjs/components/DefaultDeleteModalBody/styles.module.css +5 -0
  19. package/dist/cjs/components/DefaultRecallModalBody/DefaultRecallModalBody.d.ts +16 -0
  20. package/dist/cjs/components/DefaultRecallModalBody/DefaultRecallModalBody.js +20 -0
  21. package/dist/cjs/components/DefaultRecallModalBody/index.d.ts +1 -0
  22. package/dist/cjs/components/DefaultRecallModalBody/index.js +17 -0
  23. package/dist/cjs/components/DefaultRecallModalBody/styles.module.css +5 -0
  24. package/dist/cjs/components/DeleteModal/DeleteModal.d.ts +26 -0
  25. package/dist/cjs/components/DeleteModal/DeleteModal.js +48 -0
  26. package/dist/cjs/components/DeleteModal/hooks.d.ts +11 -0
  27. package/dist/cjs/components/DeleteModal/hooks.js +33 -0
  28. package/dist/cjs/components/DeleteModal/index.d.ts +1 -0
  29. package/dist/cjs/components/DeleteModal/index.js +17 -0
  30. package/dist/cjs/components/DeleteModal/styles.module.css +29 -0
  31. package/dist/cjs/components/MobileDeleteModal/MobileDeleteModal.d.ts +26 -0
  32. package/dist/cjs/components/MobileDeleteModal/MobileDeleteModal.js +47 -0
  33. package/dist/cjs/components/MobileDeleteModal/hooks.d.ts +11 -0
  34. package/dist/cjs/components/MobileDeleteModal/hooks.js +33 -0
  35. package/dist/cjs/components/MobileDeleteModal/index.d.ts +1 -0
  36. package/dist/cjs/components/MobileDeleteModal/index.js +17 -0
  37. package/dist/cjs/components/MobileDeleteModal/styles.module.css +28 -0
  38. package/dist/cjs/components/MobileRecallModal/MobileRecallModal.d.ts +22 -0
  39. package/dist/cjs/components/MobileRecallModal/MobileRecallModal.js +43 -0
  40. package/dist/cjs/components/MobileRecallModal/hooks.d.ts +8 -0
  41. package/dist/cjs/components/MobileRecallModal/hooks.js +35 -0
  42. package/dist/cjs/components/MobileRecallModal/index.d.ts +1 -0
  43. package/dist/cjs/components/MobileRecallModal/index.js +17 -0
  44. package/dist/cjs/components/MobileRecallModal/styles.module.css +28 -0
  45. package/dist/cjs/components/MobileReleaseNotesModal/MobileReleaseNotesModal.d.ts +2 -0
  46. package/dist/cjs/components/MobileReleaseNotesModal/MobileReleaseNotesModal.js +42 -0
  47. package/dist/cjs/components/MobileReleaseNotesModal/index.d.ts +1 -0
  48. package/dist/cjs/components/MobileReleaseNotesModal/index.js +17 -0
  49. package/dist/cjs/components/MobileReleaseNotesModal/styles.module.css +37 -0
  50. package/dist/cjs/components/RecallModal/RecallModal.d.ts +22 -0
  51. package/dist/cjs/components/RecallModal/RecallModal.js +44 -0
  52. package/dist/cjs/components/RecallModal/hooks.d.ts +8 -0
  53. package/dist/cjs/components/RecallModal/hooks.js +35 -0
  54. package/dist/cjs/components/RecallModal/index.d.ts +1 -0
  55. package/dist/cjs/components/RecallModal/index.js +17 -0
  56. package/dist/cjs/components/RecallModal/styles.module.css +29 -0
  57. package/dist/cjs/components/ReleaseNotesModal/ReleaseNotesModal.d.ts +2 -0
  58. package/dist/cjs/components/ReleaseNotesModal/ReleaseNotesModal.js +46 -0
  59. package/dist/cjs/components/ReleaseNotesModal/index.d.ts +1 -0
  60. package/dist/cjs/components/ReleaseNotesModal/index.js +17 -0
  61. package/dist/cjs/components/ReleaseNotesModal/styles.module.css +35 -0
  62. package/dist/cjs/components/index.d.ts +11 -0
  63. package/dist/cjs/components/index.js +27 -0
  64. package/dist/cjs/constants.d.ts +4 -0
  65. package/dist/cjs/constants.js +7 -0
  66. package/dist/cjs/helperComponents/DataErrorInfoBlock/DataErrorInfoBlock.d.ts +6 -0
  67. package/dist/cjs/helperComponents/DataErrorInfoBlock/DataErrorInfoBlock.js +19 -0
  68. package/dist/cjs/helperComponents/DataErrorInfoBlock/index.d.ts +1 -0
  69. package/dist/cjs/helperComponents/DataErrorInfoBlock/index.js +17 -0
  70. package/dist/cjs/helperComponents/DataErrorInfoBlock/styles.module.css +7 -0
  71. package/dist/cjs/helperComponents/InputConfirm/InputConfirm.d.ts +10 -0
  72. package/dist/cjs/helperComponents/InputConfirm/InputConfirm.js +13 -0
  73. package/dist/cjs/helperComponents/InputConfirm/index.d.ts +1 -0
  74. package/dist/cjs/helperComponents/InputConfirm/index.js +17 -0
  75. package/dist/cjs/helperComponents/InputConfirm/styles.module.css +34 -0
  76. package/dist/cjs/helperComponents/NoDataInfoBlock/NoDataInfoBlock.d.ts +5 -0
  77. package/dist/cjs/helperComponents/NoDataInfoBlock/NoDataInfoBlock.js +14 -0
  78. package/dist/cjs/helperComponents/NoDataInfoBlock/index.d.ts +1 -0
  79. package/dist/cjs/helperComponents/NoDataInfoBlock/index.js +17 -0
  80. package/dist/cjs/helperComponents/NoDataInfoBlock/styles.module.css +4 -0
  81. package/dist/cjs/helperComponents/NoteItem/NoteItem.d.ts +12 -0
  82. package/dist/cjs/helperComponents/NoteItem/NoteItem.js +14 -0
  83. package/dist/cjs/helperComponents/NoteItem/Skeleton.d.ts +1 -0
  84. package/dist/cjs/helperComponents/NoteItem/Skeleton.js +12 -0
  85. package/dist/cjs/helperComponents/NoteItem/index.d.ts +2 -0
  86. package/dist/cjs/helperComponents/NoteItem/index.js +18 -0
  87. package/dist/cjs/helperComponents/NoteItem/styles.module.css +52 -0
  88. package/dist/cjs/helperComponents/NoteItemMobile/NoteItemMobile.d.ts +9 -0
  89. package/dist/cjs/helperComponents/NoteItemMobile/NoteItemMobile.js +19 -0
  90. package/dist/cjs/helperComponents/NoteItemMobile/Skeleton.d.ts +1 -0
  91. package/dist/cjs/helperComponents/NoteItemMobile/Skeleton.js +12 -0
  92. package/dist/cjs/helperComponents/NoteItemMobile/index.d.ts +2 -0
  93. package/dist/cjs/helperComponents/NoteItemMobile/index.js +18 -0
  94. package/dist/cjs/helperComponents/NoteItemMobile/styles.module.css +36 -0
  95. package/dist/cjs/helperComponents/NoteSliderControls/NoteSliderControls.d.ts +8 -0
  96. package/dist/cjs/helperComponents/NoteSliderControls/NoteSliderControls.js +13 -0
  97. package/dist/cjs/helperComponents/NoteSliderControls/index.d.ts +1 -0
  98. package/dist/cjs/helperComponents/NoteSliderControls/index.js +17 -0
  99. package/dist/cjs/helperComponents/NoteSliderControls/styles.module.css +5 -0
  100. package/dist/cjs/helperComponents/index.d.ts +3 -0
  101. package/dist/cjs/helperComponents/index.js +19 -0
  102. package/dist/cjs/helpers/index.d.ts +1 -0
  103. package/dist/cjs/helpers/index.js +17 -0
  104. package/dist/cjs/helpers/isDefined.d.ts +1 -0
  105. package/dist/cjs/helpers/isDefined.js +5 -0
  106. package/dist/cjs/hooks.d.ts +12 -0
  107. package/dist/cjs/hooks.js +41 -0
  108. package/dist/cjs/index.d.ts +1 -0
  109. package/dist/cjs/index.js +17 -0
  110. package/dist/cjs/types.d.ts +17 -0
  111. package/dist/cjs/types.js +2 -0
  112. package/dist/esm/components/AdaptiveDeleteModal/AdaptiveDeleteModal.d.ts +5 -0
  113. package/dist/esm/components/AdaptiveDeleteModal/AdaptiveDeleteModal.js +19 -0
  114. package/dist/esm/components/AdaptiveDeleteModal/index.d.ts +1 -0
  115. package/dist/esm/components/AdaptiveDeleteModal/index.js +1 -0
  116. package/dist/esm/components/AdaptiveRecallModal/AdaptiveRecallModal.d.ts +5 -0
  117. package/dist/esm/components/AdaptiveRecallModal/AdaptiveRecallModal.js +19 -0
  118. package/dist/esm/components/AdaptiveRecallModal/index.d.ts +1 -0
  119. package/dist/esm/components/AdaptiveRecallModal/index.js +1 -0
  120. package/dist/esm/components/AdaptiveReleaseNotesModal/AdaptiveReleaseNotesModal.d.ts +5 -0
  121. package/dist/esm/components/AdaptiveReleaseNotesModal/AdaptiveReleaseNotesModal.js +19 -0
  122. package/dist/esm/components/AdaptiveReleaseNotesModal/index.d.ts +1 -0
  123. package/dist/esm/components/AdaptiveReleaseNotesModal/index.js +1 -0
  124. package/dist/esm/components/DefaultDeleteModalBody/DefaultDeleteModalBody.d.ts +16 -0
  125. package/dist/esm/components/DefaultDeleteModalBody/DefaultDeleteModalBody.js +14 -0
  126. package/dist/esm/components/DefaultDeleteModalBody/index.d.ts +1 -0
  127. package/dist/esm/components/DefaultDeleteModalBody/index.js +1 -0
  128. package/dist/esm/components/DefaultDeleteModalBody/styles.module.css +5 -0
  129. package/dist/esm/components/DefaultRecallModalBody/DefaultRecallModalBody.d.ts +16 -0
  130. package/dist/esm/components/DefaultRecallModalBody/DefaultRecallModalBody.js +14 -0
  131. package/dist/esm/components/DefaultRecallModalBody/index.d.ts +1 -0
  132. package/dist/esm/components/DefaultRecallModalBody/index.js +1 -0
  133. package/dist/esm/components/DefaultRecallModalBody/styles.module.css +5 -0
  134. package/dist/esm/components/DeleteModal/DeleteModal.d.ts +26 -0
  135. package/dist/esm/components/DeleteModal/DeleteModal.js +42 -0
  136. package/dist/esm/components/DeleteModal/hooks.d.ts +11 -0
  137. package/dist/esm/components/DeleteModal/hooks.js +30 -0
  138. package/dist/esm/components/DeleteModal/index.d.ts +1 -0
  139. package/dist/esm/components/DeleteModal/index.js +1 -0
  140. package/dist/esm/components/DeleteModal/styles.module.css +29 -0
  141. package/dist/esm/components/MobileDeleteModal/MobileDeleteModal.d.ts +26 -0
  142. package/dist/esm/components/MobileDeleteModal/MobileDeleteModal.js +41 -0
  143. package/dist/esm/components/MobileDeleteModal/hooks.d.ts +11 -0
  144. package/dist/esm/components/MobileDeleteModal/hooks.js +30 -0
  145. package/dist/esm/components/MobileDeleteModal/index.d.ts +1 -0
  146. package/dist/esm/components/MobileDeleteModal/index.js +1 -0
  147. package/dist/esm/components/MobileDeleteModal/styles.module.css +28 -0
  148. package/dist/esm/components/MobileRecallModal/MobileRecallModal.d.ts +22 -0
  149. package/dist/esm/components/MobileRecallModal/MobileRecallModal.js +37 -0
  150. package/dist/esm/components/MobileRecallModal/hooks.d.ts +8 -0
  151. package/dist/esm/components/MobileRecallModal/hooks.js +32 -0
  152. package/dist/esm/components/MobileRecallModal/index.d.ts +1 -0
  153. package/dist/esm/components/MobileRecallModal/index.js +1 -0
  154. package/dist/esm/components/MobileRecallModal/styles.module.css +28 -0
  155. package/dist/esm/components/MobileReleaseNotesModal/MobileReleaseNotesModal.d.ts +2 -0
  156. package/dist/esm/components/MobileReleaseNotesModal/MobileReleaseNotesModal.js +36 -0
  157. package/dist/esm/components/MobileReleaseNotesModal/index.d.ts +1 -0
  158. package/dist/esm/components/MobileReleaseNotesModal/index.js +1 -0
  159. package/dist/esm/components/MobileReleaseNotesModal/styles.module.css +37 -0
  160. package/dist/esm/components/RecallModal/RecallModal.d.ts +22 -0
  161. package/dist/esm/components/RecallModal/RecallModal.js +38 -0
  162. package/dist/esm/components/RecallModal/hooks.d.ts +8 -0
  163. package/dist/esm/components/RecallModal/hooks.js +32 -0
  164. package/dist/esm/components/RecallModal/index.d.ts +1 -0
  165. package/dist/esm/components/RecallModal/index.js +1 -0
  166. package/dist/esm/components/RecallModal/styles.module.css +29 -0
  167. package/dist/esm/components/ReleaseNotesModal/ReleaseNotesModal.d.ts +2 -0
  168. package/dist/esm/components/ReleaseNotesModal/ReleaseNotesModal.js +40 -0
  169. package/dist/esm/components/ReleaseNotesModal/index.d.ts +1 -0
  170. package/dist/esm/components/ReleaseNotesModal/index.js +1 -0
  171. package/dist/esm/components/ReleaseNotesModal/styles.module.css +35 -0
  172. package/dist/esm/components/index.d.ts +11 -0
  173. package/dist/esm/components/index.js +11 -0
  174. package/dist/esm/constants.d.ts +4 -0
  175. package/dist/esm/constants.js +4 -0
  176. package/dist/esm/helperComponents/DataErrorInfoBlock/DataErrorInfoBlock.d.ts +6 -0
  177. package/dist/esm/helperComponents/DataErrorInfoBlock/DataErrorInfoBlock.js +13 -0
  178. package/dist/esm/helperComponents/DataErrorInfoBlock/index.d.ts +1 -0
  179. package/dist/esm/helperComponents/DataErrorInfoBlock/index.js +1 -0
  180. package/dist/esm/helperComponents/DataErrorInfoBlock/styles.module.css +7 -0
  181. package/dist/esm/helperComponents/InputConfirm/InputConfirm.d.ts +10 -0
  182. package/dist/esm/helperComponents/InputConfirm/InputConfirm.js +7 -0
  183. package/dist/esm/helperComponents/InputConfirm/index.d.ts +1 -0
  184. package/dist/esm/helperComponents/InputConfirm/index.js +1 -0
  185. package/dist/esm/helperComponents/InputConfirm/styles.module.css +34 -0
  186. package/dist/esm/helperComponents/NoDataInfoBlock/NoDataInfoBlock.d.ts +5 -0
  187. package/dist/esm/helperComponents/NoDataInfoBlock/NoDataInfoBlock.js +8 -0
  188. package/dist/esm/helperComponents/NoDataInfoBlock/index.d.ts +1 -0
  189. package/dist/esm/helperComponents/NoDataInfoBlock/index.js +1 -0
  190. package/dist/esm/helperComponents/NoDataInfoBlock/styles.module.css +4 -0
  191. package/dist/esm/helperComponents/NoteItem/NoteItem.d.ts +12 -0
  192. package/dist/esm/helperComponents/NoteItem/NoteItem.js +8 -0
  193. package/dist/esm/helperComponents/NoteItem/Skeleton.d.ts +1 -0
  194. package/dist/esm/helperComponents/NoteItem/Skeleton.js +6 -0
  195. package/dist/esm/helperComponents/NoteItem/index.d.ts +2 -0
  196. package/dist/esm/helperComponents/NoteItem/index.js +2 -0
  197. package/dist/esm/helperComponents/NoteItem/styles.module.css +52 -0
  198. package/dist/esm/helperComponents/NoteItemMobile/NoteItemMobile.d.ts +9 -0
  199. package/dist/esm/helperComponents/NoteItemMobile/NoteItemMobile.js +13 -0
  200. package/dist/esm/helperComponents/NoteItemMobile/Skeleton.d.ts +1 -0
  201. package/dist/esm/helperComponents/NoteItemMobile/Skeleton.js +6 -0
  202. package/dist/esm/helperComponents/NoteItemMobile/index.d.ts +2 -0
  203. package/dist/esm/helperComponents/NoteItemMobile/index.js +2 -0
  204. package/dist/esm/helperComponents/NoteItemMobile/styles.module.css +36 -0
  205. package/dist/esm/helperComponents/NoteSliderControls/NoteSliderControls.d.ts +8 -0
  206. package/dist/esm/helperComponents/NoteSliderControls/NoteSliderControls.js +7 -0
  207. package/dist/esm/helperComponents/NoteSliderControls/index.d.ts +1 -0
  208. package/dist/esm/helperComponents/NoteSliderControls/index.js +1 -0
  209. package/dist/esm/helperComponents/NoteSliderControls/styles.module.css +5 -0
  210. package/dist/esm/helperComponents/index.d.ts +3 -0
  211. package/dist/esm/helperComponents/index.js +3 -0
  212. package/dist/esm/helpers/index.d.ts +1 -0
  213. package/dist/esm/helpers/index.js +1 -0
  214. package/dist/esm/helpers/isDefined.d.ts +1 -0
  215. package/dist/esm/helpers/isDefined.js +1 -0
  216. package/dist/esm/hooks.d.ts +12 -0
  217. package/dist/esm/hooks.js +38 -0
  218. package/dist/esm/index.d.ts +1 -0
  219. package/dist/esm/index.js +1 -0
  220. package/dist/esm/types.d.ts +17 -0
  221. package/dist/esm/types.js +1 -0
  222. package/package.json +10 -9
@@ -0,0 +1,28 @@
1
+ .description{
2
+ font-family:var(--sans-body-m-font-family, SB Sans Interface);
3
+ font-weight:var(--sans-body-m-font-weight, Regular);
4
+ line-height:var(--sans-body-m-line-height, 20px);
5
+ font-size:var(--sans-body-m-font-size, 14px);
6
+ letter-spacing:var(--sans-body-m-letter-spacing, 0.1px);
7
+ paragraph-spacing:var(--sans-body-m-paragraph-spacing, 7.7px);
8
+ color:var(--sys-neutral-text-support, #6d707f);
9
+ display:flex;
10
+ flex-direction:column;
11
+ width:100%;
12
+ gap:var(--dimension-1m, 8px);
13
+ }
14
+
15
+ .footer{
16
+ width:100%;
17
+ display:flex;
18
+ flex-direction:column;
19
+ gap:var(--dimension-2m, 16px);
20
+ }
21
+
22
+ .footerActions{
23
+ display:flex;
24
+ flex-direction:row-reverse;
25
+ flex-wrap:wrap-reverse;
26
+ align-items:center;
27
+ gap:var(--dimension-1m, 8px);
28
+ }
@@ -0,0 +1,22 @@
1
+ import { ReactNode } from 'react';
2
+ import { MobileModalCustom, MobileModalCustomProps } from '@sbercloud/uikit-product-mobile-modal';
3
+ import { WithSupportProps } from '@sbercloud/uikit-product-utils';
4
+ export type MobileRecallProps = Pick<MobileModalCustomProps, 'open' | 'onClose' | 'mode'> & WithSupportProps<{
5
+ /** Всплывающая подсказка для заголовка */
6
+ titleTooltip?: MobileModalCustom.HeaderProps['titleTooltip'];
7
+ /** Колбек нажатия кнопки отзыва
8
+ * @param onClose колбэк для закрытия модального окна
9
+ */
10
+ onRecall(onClose: () => void): void;
11
+ /** Состояние загрузки кнопки отзыва */
12
+ loading?: boolean;
13
+ /** Описание */
14
+ description?: ReactNode;
15
+ /** Текст для подтверждения отзыва */
16
+ confirmText?: string;
17
+ /** Скрыть кнопку копирования для текста подтверждения */
18
+ hideConfirmCopyButton?: boolean;
19
+ /** Подзаголовок */
20
+ subtitle?: ReactNode;
21
+ }>;
22
+ export declare function MobileRecallModal({ confirmText, titleTooltip, hideConfirmCopyButton, description, onRecall, onClose, open, subtitle, loading, ...restProps }: MobileRecallProps): import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,43 @@
1
+ "use strict";
2
+ var __rest = (this && this.__rest) || function (s, e) {
3
+ var t = {};
4
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
5
+ t[p] = s[p];
6
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
7
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
8
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
9
+ t[p[i]] = s[p[i]];
10
+ }
11
+ return t;
12
+ };
13
+ var __importDefault = (this && this.__importDefault) || function (mod) {
14
+ return (mod && mod.__esModule) ? mod : { "default": mod };
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ exports.MobileRecallModal = MobileRecallModal;
18
+ const jsx_runtime_1 = require("react/jsx-runtime");
19
+ const uikit_product_locale_1 = require("@sbercloud/uikit-product-locale");
20
+ const uikit_product_mobile_modal_1 = require("@sbercloud/uikit-product-mobile-modal");
21
+ const button_1 = require("@snack-uikit/button");
22
+ const helperComponents_1 = require("../../helperComponents");
23
+ const helpers_1 = require("../../helpers");
24
+ const hooks_1 = require("./hooks");
25
+ const styles_module_scss_1 = __importDefault(require('./styles.module.css'));
26
+ function MobileRecallModal(_a) {
27
+ var { confirmText, titleTooltip, hideConfirmCopyButton, description, onRecall, onClose, open, subtitle, loading } = _a, restProps = __rest(_a, ["confirmText", "titleTooltip", "hideConfirmCopyButton", "description", "onRecall", "onClose", "open", "subtitle", "loading"]);
28
+ const { t } = (0, uikit_product_locale_1.useLocale)('ModalPredefined');
29
+ const withInputConfirmation = (0, helpers_1.isDefined)(confirmText);
30
+ const _b = (0, hooks_1.useTextFieldValidation)(confirmText), { reset, handleSubmit } = _b, inputProps = __rest(_b, ["reset", "handleSubmit"]);
31
+ const handleClose = () => {
32
+ onClose();
33
+ reset();
34
+ };
35
+ const handleCancel = () => {
36
+ onClose();
37
+ reset();
38
+ };
39
+ const handleDelete = handleSubmit(() => {
40
+ onRecall(handleClose);
41
+ });
42
+ return ((0, jsx_runtime_1.jsxs)(uikit_product_mobile_modal_1.MobileModalCustom, Object.assign({}, restProps, { open: open, onClose: handleClose, children: [(0, jsx_runtime_1.jsx)(uikit_product_mobile_modal_1.MobileModalCustom.Header, { title: t('recallTitle'), titleTooltip: titleTooltip, subtitle: subtitle }), (0, jsx_runtime_1.jsx)(uikit_product_mobile_modal_1.MobileModalCustom.Body, { content: (0, jsx_runtime_1.jsx)("div", { className: styles_module_scss_1.default.description, children: description }) }), (0, jsx_runtime_1.jsx)(uikit_product_mobile_modal_1.MobileModalCustom.Footer, { actions: (0, jsx_runtime_1.jsxs)("div", { className: styles_module_scss_1.default.footer, children: [withInputConfirmation && ((0, jsx_runtime_1.jsx)(helperComponents_1.InputConfirm, Object.assign({ confirmText: confirmText, hideConfirmCopyButton: hideConfirmCopyButton, labelText: t('recallFieldLabel'), placeholder: t(`enterText.name`) }, inputProps))), (0, jsx_runtime_1.jsxs)("div", { className: styles_module_scss_1.default.footerActions, children: [(0, jsx_runtime_1.jsx)(button_1.ButtonFilled, { label: t('recall'), loading: loading, onClick: handleDelete, size: 'm', appearance: 'destructive', fullWidth: true }), (0, jsx_runtime_1.jsx)(button_1.ButtonOutline, { label: t('cancel'), onClick: handleCancel, appearance: 'neutral', size: 'm', fullWidth: true })] })] }) })] })));
43
+ }
@@ -0,0 +1,8 @@
1
+ export declare function useTextFieldValidation(target: string | undefined): {
2
+ value: string;
3
+ onChange: (newValue: string) => void;
4
+ handleSubmit: (cb: () => void) => () => void;
5
+ reset: () => void;
6
+ ref: import("react").RefObject<HTMLInputElement>;
7
+ error: string;
8
+ };
@@ -0,0 +1,35 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.useTextFieldValidation = useTextFieldValidation;
4
+ const react_1 = require("react");
5
+ const uikit_product_locale_1 = require("@sbercloud/uikit-product-locale");
6
+ function useTextFieldValidation(target) {
7
+ const { t } = (0, uikit_product_locale_1.useLocale)('ModalPredefined');
8
+ const ref = (0, react_1.useRef)(null);
9
+ const [value, setValue] = (0, react_1.useState)('');
10
+ const [error, setError] = (0, react_1.useState)('');
11
+ const onChange = (newValue) => {
12
+ setValue(() => newValue);
13
+ if (target === newValue) {
14
+ setError('');
15
+ }
16
+ };
17
+ const handleSubmit = (cb) => {
18
+ if (target === value || target === undefined) {
19
+ return () => {
20
+ setError('');
21
+ cb();
22
+ };
23
+ }
24
+ return () => {
25
+ var _a;
26
+ setError(t('invalidText.name'));
27
+ (_a = ref.current) === null || _a === void 0 ? void 0 : _a.focus();
28
+ };
29
+ };
30
+ const reset = (0, react_1.useCallback)(() => {
31
+ setValue('');
32
+ setError('');
33
+ }, []);
34
+ return { value, onChange, handleSubmit, reset, ref, error };
35
+ }
@@ -0,0 +1 @@
1
+ export * from './MobileRecallModal';
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./MobileRecallModal"), exports);
@@ -0,0 +1,28 @@
1
+ .description{
2
+ font-family:var(--sans-body-m-font-family, SB Sans Interface);
3
+ font-weight:var(--sans-body-m-font-weight, Regular);
4
+ line-height:var(--sans-body-m-line-height, 20px);
5
+ font-size:var(--sans-body-m-font-size, 14px);
6
+ letter-spacing:var(--sans-body-m-letter-spacing, 0.1px);
7
+ paragraph-spacing:var(--sans-body-m-paragraph-spacing, 7.7px);
8
+ color:var(--sys-neutral-text-support, #6d707f);
9
+ display:flex;
10
+ flex-direction:column;
11
+ width:100%;
12
+ gap:var(--dimension-1m, 8px);
13
+ }
14
+
15
+ .footer{
16
+ width:100%;
17
+ display:flex;
18
+ flex-direction:column;
19
+ gap:var(--dimension-2m, 16px);
20
+ }
21
+
22
+ .footerActions{
23
+ display:flex;
24
+ flex-direction:row-reverse;
25
+ flex-wrap:wrap-reverse;
26
+ align-items:center;
27
+ gap:var(--dimension-1m, 8px);
28
+ }
@@ -0,0 +1,2 @@
1
+ import { ReleaseNotesModalProps } from '../../types';
2
+ export declare function MobileReleaseNotesModal({ items, loading, open, onClose, onReadLaterClick, dataError, onDataErrorRetryClick, }: ReleaseNotesModalProps): import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.MobileReleaseNotesModal = MobileReleaseNotesModal;
7
+ const jsx_runtime_1 = require("react/jsx-runtime");
8
+ const react_1 = require("react");
9
+ const uikit_product_locale_1 = require("@sbercloud/uikit-product-locale");
10
+ const uikit_product_mobile_modal_1 = require("@sbercloud/uikit-product-mobile-modal");
11
+ const button_1 = require("@snack-uikit/button");
12
+ const carousel_1 = require("@snack-uikit/carousel");
13
+ const skeleton_1 = require("@snack-uikit/skeleton");
14
+ const typography_1 = require("@snack-uikit/typography");
15
+ const helperComponents_1 = require("../../helperComponents");
16
+ const NoteItemMobile_1 = require("../../helperComponents/NoteItemMobile");
17
+ const NoteSliderControls_1 = require("../../helperComponents/NoteSliderControls");
18
+ const hooks_1 = require("../../hooks");
19
+ const styles_module_scss_1 = __importDefault(require('./styles.module.css'));
20
+ function MobileReleaseNotesModal({ items, loading, open, onClose, onReadLaterClick, dataError, onDataErrorRetryClick, }) {
21
+ const { t } = (0, uikit_product_locale_1.useLocale)('ModalPredefined');
22
+ const { onCloseInner, onReadLaterClickInner, pageIndex, readablePageNumber, onNextPageClick, onPrevPageClick, setPage, } = (0, hooks_1.useReleaseNotesModal)({ onClose, onReadLaterClick });
23
+ const childrenScrollRefs = (0, react_1.useRef)([]);
24
+ const [, setInitialized] = (0, react_1.useState)(false);
25
+ const onScrollRefInitialized = (0, react_1.useCallback)(() => setInitialized(true), []);
26
+ const content = (0, react_1.useMemo)(() => {
27
+ if (dataError) {
28
+ return ((0, jsx_runtime_1.jsx)("div", { className: styles_module_scss_1.default.infoBlockWrapper, children: (0, jsx_runtime_1.jsx)(helperComponents_1.DataErrorInfoBlock, { isMobile: true, onDataErrorRetryClick: onDataErrorRetryClick }) }));
29
+ }
30
+ if (!loading && items.length < 1) {
31
+ return ((0, jsx_runtime_1.jsx)("div", { className: styles_module_scss_1.default.infoBlockWrapper, children: (0, jsx_runtime_1.jsx)(helperComponents_1.NoDataInfoBlock, { isMobile: true }) }));
32
+ }
33
+ return ((0, jsx_runtime_1.jsx)(skeleton_1.WithSkeleton, { loading: loading, skeleton: (0, jsx_runtime_1.jsx)(NoteItemMobile_1.NoteItemMobileSkeleton, {}), children: (0, jsx_runtime_1.jsx)(carousel_1.Carousel, { arrows: false, pagination: false, swipe: items.length > 1, state: { page: pageIndex, onChange: setPage }, className: styles_module_scss_1.default.mobileCarousel, children: items.map((item, index) => ((0, jsx_runtime_1.jsx)(NoteItemMobile_1.NoteItemMobile, Object.assign({}, item, { childrenScrollRefs: childrenScrollRefs, index: index, onScrollRefInitialized: onScrollRefInitialized }), item.title))) }) }));
34
+ }, [dataError, items, loading, onDataErrorRetryClick, onScrollRefInitialized, pageIndex, setPage]);
35
+ const showFooter = (0, react_1.useMemo)(() => {
36
+ if (loading) {
37
+ return true;
38
+ }
39
+ return Boolean(!dataError && items.length > 0);
40
+ }, [dataError, items.length, loading]);
41
+ return ((0, jsx_runtime_1.jsxs)(uikit_product_mobile_modal_1.MobileModalCustom, { open: open, onClose: onCloseInner, size: 'full', closeButtonEnabled: true, children: [(0, jsx_runtime_1.jsx)(uikit_product_mobile_modal_1.MobileModalCustom.Header, { title: t('whatsNew') }), (0, jsx_runtime_1.jsx)(uikit_product_mobile_modal_1.MobileModalCustom.Body, { className: loading ? undefined : styles_module_scss_1.default.mobileBody, content: content }), showFooter && ((0, jsx_runtime_1.jsx)(uikit_product_mobile_modal_1.MobileModalCustom.Footer, { actions: (0, jsx_runtime_1.jsxs)("div", { className: styles_module_scss_1.default.footerActions, children: [(0, jsx_runtime_1.jsx)("div", { children: onReadLaterClick && ((0, jsx_runtime_1.jsx)(button_1.ButtonFunction, { label: t('readLater'), onClick: onReadLaterClickInner, size: 'm', appearance: 'destructive', disabled: loading, fullWidth: true })) }), items.length > 1 && ((0, jsx_runtime_1.jsxs)("div", { className: styles_module_scss_1.default.footerRight, children: [(0, jsx_runtime_1.jsxs)(typography_1.Typography.SansBodyM, { className: styles_module_scss_1.default.pageCounter, children: [readablePageNumber, " ", t('outOf'), " ", items.length] }), (0, jsx_runtime_1.jsx)(NoteSliderControls_1.NoteSliderControls, { page: readablePageNumber, totalPages: items.length, onNextSlideClick: onNextPageClick, onPrevSlideClick: onPrevPageClick })] }))] }) }))] }));
42
+ }
@@ -0,0 +1 @@
1
+ export * from './MobileReleaseNotesModal';
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./MobileReleaseNotesModal"), exports);
@@ -0,0 +1,37 @@
1
+ .mobileBody{
2
+ padding-right:var(--dimension-1m, 8px);
3
+ }
4
+
5
+ .mobileCarousel{
6
+ height:100%;
7
+ box-sizing:content-box;
8
+ }
9
+ .mobileCarousel > div{
10
+ height:100%;
11
+ }
12
+
13
+ .footerActions{
14
+ display:flex;
15
+ flex-direction:row;
16
+ align-items:center;
17
+ justify-content:space-between;
18
+ width:100%;
19
+ }
20
+
21
+ .footerRight{
22
+ display:flex;
23
+ align-items:center;
24
+ justify-content:flex-end;
25
+ gap:var(--dimension-1m, 8px);
26
+ }
27
+
28
+ .pageCounter{
29
+ color:var(--sys-neutral-text-light, #8b8e9b);
30
+ }
31
+
32
+ .infoBlockWrapper{
33
+ height:100%;
34
+ display:flex;
35
+ flex-direction:column;
36
+ justify-content:center;
37
+ }
@@ -0,0 +1,22 @@
1
+ import { ReactNode } from 'react';
2
+ import { WithSupportProps } from '@sbercloud/uikit-product-utils';
3
+ import { ModalCustom, ModalCustomProps } from '@snack-uikit/modal';
4
+ export type RecallModalProps = Pick<ModalCustomProps, 'open' | 'onClose' | 'mode'> & WithSupportProps<{
5
+ /** Всплывающая подсказка для заголовка */
6
+ titleTooltip?: ModalCustom.HeaderProps['titleTooltip'];
7
+ /** Колбек нажатия кнопки отзыва
8
+ * @param onClose колбэк для закрытия модального окна
9
+ */
10
+ onRecall(onClose: () => void): void;
11
+ /** Состояние загрузки кнопки отзыва */
12
+ loading?: boolean;
13
+ /** Описание */
14
+ description?: ReactNode;
15
+ /** Текст для подтверждения отзыва */
16
+ confirmText?: string;
17
+ /** Скрыть кнопку копирования для текста подтверждения */
18
+ hideConfirmCopyButton?: boolean;
19
+ /** Подзаголовок */
20
+ subtitle?: ReactNode;
21
+ }>;
22
+ export declare function RecallModal({ confirmText, titleTooltip, hideConfirmCopyButton, description, onRecall, onClose, open, loading, subtitle, ...restProps }: RecallModalProps): import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,44 @@
1
+ "use strict";
2
+ var __rest = (this && this.__rest) || function (s, e) {
3
+ var t = {};
4
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
5
+ t[p] = s[p];
6
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
7
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
8
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
9
+ t[p[i]] = s[p[i]];
10
+ }
11
+ return t;
12
+ };
13
+ var __importDefault = (this && this.__importDefault) || function (mod) {
14
+ return (mod && mod.__esModule) ? mod : { "default": mod };
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ exports.RecallModal = RecallModal;
18
+ const jsx_runtime_1 = require("react/jsx-runtime");
19
+ const uikit_product_locale_1 = require("@sbercloud/uikit-product-locale");
20
+ const button_1 = require("@snack-uikit/button");
21
+ const modal_1 = require("@snack-uikit/modal");
22
+ const truncate_string_1 = require("@snack-uikit/truncate-string");
23
+ const helperComponents_1 = require("../../helperComponents");
24
+ const helpers_1 = require("../../helpers");
25
+ const hooks_1 = require("./hooks");
26
+ const styles_module_scss_1 = __importDefault(require('./styles.module.css'));
27
+ function RecallModal(_a) {
28
+ var { confirmText, titleTooltip, hideConfirmCopyButton, description, onRecall, onClose, open, loading, subtitle } = _a, restProps = __rest(_a, ["confirmText", "titleTooltip", "hideConfirmCopyButton", "description", "onRecall", "onClose", "open", "loading", "subtitle"]);
29
+ const { t } = (0, uikit_product_locale_1.useLocale)('ModalPredefined');
30
+ const withInputConfirmation = (0, helpers_1.isDefined)(confirmText);
31
+ const _b = (0, hooks_1.useTextFieldValidation)(confirmText), { reset, handleSubmit } = _b, inputProps = __rest(_b, ["reset", "handleSubmit"]);
32
+ const handleClose = () => {
33
+ onClose();
34
+ reset();
35
+ };
36
+ const handleCancel = () => {
37
+ onClose();
38
+ reset();
39
+ };
40
+ const handleDelete = handleSubmit(() => {
41
+ onRecall(handleClose);
42
+ });
43
+ return ((0, jsx_runtime_1.jsxs)(modal_1.ModalCustom, Object.assign({}, restProps, { open: open, onClose: handleClose, children: [(0, jsx_runtime_1.jsx)(modal_1.ModalCustom.Header, { title: (0, jsx_runtime_1.jsx)(truncate_string_1.TruncateString, { text: t('recallTitle'), maxLines: 2 }), subtitle: subtitle, titleTooltip: titleTooltip }), description && (0, jsx_runtime_1.jsx)(modal_1.ModalCustom.Body, { content: (0, jsx_runtime_1.jsx)("div", { className: styles_module_scss_1.default.description, children: description }) }), (0, jsx_runtime_1.jsx)(modal_1.ModalCustom.Footer, { actions: (0, jsx_runtime_1.jsxs)("div", { className: styles_module_scss_1.default.footer, children: [withInputConfirmation && ((0, jsx_runtime_1.jsx)(helperComponents_1.InputConfirm, Object.assign({ confirmText: confirmText, hideConfirmCopyButton: hideConfirmCopyButton, labelText: t('recallFieldLabel'), placeholder: t(`enterText.name`) }, inputProps))), (0, jsx_runtime_1.jsxs)("div", { className: styles_module_scss_1.default.footerActions, children: [(0, jsx_runtime_1.jsx)(button_1.ButtonFilled, { label: t('recall'), loading: loading, onClick: handleDelete, size: 'm', appearance: 'destructive' }), (0, jsx_runtime_1.jsx)(button_1.ButtonOutline, { label: t('cancel'), onClick: handleCancel, appearance: 'neutral', size: 'm' })] })] }) })] })));
44
+ }
@@ -0,0 +1,8 @@
1
+ export declare function useTextFieldValidation(target: string | undefined): {
2
+ value: string;
3
+ onChange: (newValue: string) => void;
4
+ handleSubmit: (cb: () => void) => () => void;
5
+ reset: () => void;
6
+ ref: import("react").RefObject<HTMLInputElement>;
7
+ error: string;
8
+ };
@@ -0,0 +1,35 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.useTextFieldValidation = useTextFieldValidation;
4
+ const react_1 = require("react");
5
+ const uikit_product_locale_1 = require("@sbercloud/uikit-product-locale");
6
+ function useTextFieldValidation(target) {
7
+ const { t } = (0, uikit_product_locale_1.useLocale)('ModalPredefined');
8
+ const ref = (0, react_1.useRef)(null);
9
+ const [value, setValue] = (0, react_1.useState)('');
10
+ const [error, setError] = (0, react_1.useState)('');
11
+ const onChange = (newValue) => {
12
+ setValue(() => newValue);
13
+ if (target === newValue) {
14
+ setError('');
15
+ }
16
+ };
17
+ const handleSubmit = (cb) => {
18
+ if (target === value || target === undefined) {
19
+ return () => {
20
+ setError('');
21
+ cb();
22
+ };
23
+ }
24
+ return () => {
25
+ var _a;
26
+ setError(t('invalidText.name'));
27
+ (_a = ref.current) === null || _a === void 0 ? void 0 : _a.focus();
28
+ };
29
+ };
30
+ const reset = (0, react_1.useCallback)(() => {
31
+ setValue('');
32
+ setError('');
33
+ }, []);
34
+ return { value, onChange, handleSubmit, reset, ref, error };
35
+ }
@@ -0,0 +1 @@
1
+ export * from './RecallModal';
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./RecallModal"), exports);
@@ -0,0 +1,29 @@
1
+ .description{
2
+ font-family:var(--sans-body-m-font-family, SB Sans Interface);
3
+ font-weight:var(--sans-body-m-font-weight, Regular);
4
+ line-height:var(--sans-body-m-line-height, 20px);
5
+ font-size:var(--sans-body-m-font-size, 14px);
6
+ letter-spacing:var(--sans-body-m-letter-spacing, 0.1px);
7
+ paragraph-spacing:var(--sans-body-m-paragraph-spacing, 7.7px);
8
+ color:var(--sys-neutral-text-support, #6d707f);
9
+ display:flex;
10
+ flex-direction:column;
11
+ width:100%;
12
+ gap:var(--dimension-1m, 8px);
13
+ word-break:break-word;
14
+ }
15
+
16
+ .footer{
17
+ width:100%;
18
+ display:flex;
19
+ flex-direction:column;
20
+ gap:var(--dimension-3m, 24px);
21
+ }
22
+
23
+ .footerActions{
24
+ display:flex;
25
+ flex-direction:row-reverse;
26
+ flex-wrap:wrap-reverse;
27
+ align-items:center;
28
+ gap:var(--dimension-1m, 8px);
29
+ }
@@ -0,0 +1,2 @@
1
+ import { ReleaseNotesModalProps } from '../../types';
2
+ export declare function ReleaseNotesModal({ open, onClose, loading, items, onReadLaterClick, dataError, onDataErrorRetryClick, onSlideChange, }: ReleaseNotesModalProps): import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,46 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.ReleaseNotesModal = ReleaseNotesModal;
7
+ const jsx_runtime_1 = require("react/jsx-runtime");
8
+ const react_1 = require("react");
9
+ const uikit_product_locale_1 = require("@sbercloud/uikit-product-locale");
10
+ const button_1 = require("@snack-uikit/button");
11
+ const carousel_1 = require("@snack-uikit/carousel");
12
+ const modal_1 = require("@snack-uikit/modal");
13
+ const pagination_1 = require("@snack-uikit/pagination");
14
+ const skeleton_1 = require("@snack-uikit/skeleton");
15
+ const helperComponents_1 = require("../../helperComponents");
16
+ const NoteItem_1 = require("../../helperComponents/NoteItem");
17
+ const NoteSliderControls_1 = require("../../helperComponents/NoteSliderControls");
18
+ const hooks_1 = require("../../hooks");
19
+ const styles_module_scss_1 = __importDefault(require('./styles.module.css'));
20
+ function ReleaseNotesModal({ open, onClose, loading, items, onReadLaterClick, dataError, onDataErrorRetryClick, onSlideChange, }) {
21
+ const { t } = (0, uikit_product_locale_1.useLocale)('ModalPredefined');
22
+ const { onCloseInner, onReadLaterClickInner, pageIndex, readablePageNumber, onNextPageClick, onPrevPageClick, setPage, } = (0, hooks_1.useReleaseNotesModal)({ onClose, onReadLaterClick, onSlideChange });
23
+ const handleSlideChange = (0, react_1.useCallback)((slide) => {
24
+ setPage(slide);
25
+ onSlideChange === null || onSlideChange === void 0 ? void 0 : onSlideChange(slide);
26
+ }, [onSlideChange, setPage]);
27
+ const content = (0, react_1.useMemo)(() => {
28
+ if (dataError) {
29
+ return (0, jsx_runtime_1.jsx)(helperComponents_1.DataErrorInfoBlock, { onDataErrorRetryClick: onDataErrorRetryClick });
30
+ }
31
+ if (!loading && items.length < 1) {
32
+ return (0, jsx_runtime_1.jsx)(helperComponents_1.NoDataInfoBlock, {});
33
+ }
34
+ return ((0, jsx_runtime_1.jsx)(skeleton_1.WithSkeleton, { loading: loading, skeleton: (0, jsx_runtime_1.jsx)(NoteItem_1.NoteItemSkeleton, {}), children: (0, jsx_runtime_1.jsx)(carousel_1.Carousel, { className: styles_module_scss_1.default.carousel, arrows: false, pagination: false, state: {
35
+ page: pageIndex,
36
+ onChange: handleSlideChange,
37
+ }, swipe: items.length > 1, children: items.map(item => ((0, jsx_runtime_1.jsx)(NoteItem_1.NoteItem, Object.assign({}, item), item.title))) }) }));
38
+ }, [dataError, handleSlideChange, items, loading, onDataErrorRetryClick, pageIndex]);
39
+ const showFooter = (0, react_1.useMemo)(() => {
40
+ if (loading) {
41
+ return true;
42
+ }
43
+ return Boolean(!dataError && items.length > 0);
44
+ }, [dataError, items.length, loading]);
45
+ return ((0, jsx_runtime_1.jsxs)(modal_1.ModalCustom, { open: open, onClose: onCloseInner, size: 'm', children: [(0, jsx_runtime_1.jsx)(modal_1.ModalCustom.Header, { title: t('whatsNew') }), (0, jsx_runtime_1.jsx)(modal_1.ModalCustom.Body, { content: content }), showFooter && ((0, jsx_runtime_1.jsx)(modal_1.ModalCustom.Footer, { actions: (0, jsx_runtime_1.jsxs)("div", { className: styles_module_scss_1.default.footerActions, children: [(0, jsx_runtime_1.jsx)("div", { className: styles_module_scss_1.default.footerLeft, children: onReadLaterClick && ((0, jsx_runtime_1.jsx)(button_1.ButtonFunction, { label: t('readLater'), onClick: onReadLaterClickInner, size: 'm', appearance: 'neutral', disabled: loading })) }), items.length > 1 && ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [!loading && ((0, jsx_runtime_1.jsx)("div", { className: styles_module_scss_1.default.footerCenter, children: (0, jsx_runtime_1.jsx)(pagination_1.PaginationSlider, { page: readablePageNumber, onChange: page => handleSlideChange(page - 1), total: items.length }) })), (0, jsx_runtime_1.jsx)("div", { className: styles_module_scss_1.default.footerRight, children: (0, jsx_runtime_1.jsx)(NoteSliderControls_1.NoteSliderControls, { page: readablePageNumber, totalPages: items.length, onNextSlideClick: onNextPageClick, onPrevSlideClick: onPrevPageClick }) })] }))] }) }))] }));
46
+ }
@@ -0,0 +1 @@
1
+ export * from './ReleaseNotesModal';
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./ReleaseNotesModal"), exports);
@@ -0,0 +1,35 @@
1
+ .spinnerWrapper{
2
+ width:100%;
3
+ display:flex;
4
+ flex-direction:column;
5
+ align-items:center;
6
+ }
7
+
8
+ .footerActions{
9
+ display:flex;
10
+ flex-direction:row;
11
+ align-items:center;
12
+ justify-content:space-between;
13
+ gap:var(--dimension-1m, 8px);
14
+ width:100%;
15
+ }
16
+
17
+ .footerLeft{
18
+ flex:1;
19
+ }
20
+
21
+ .footerCenter{
22
+ display:flex;
23
+ flex:1;
24
+ justify-content:center;
25
+ }
26
+
27
+ .footerRight{
28
+ display:flex;
29
+ flex:1;
30
+ justify-content:flex-end;
31
+ }
32
+
33
+ .carousel{
34
+ box-sizing:content-box;
35
+ }
@@ -0,0 +1,11 @@
1
+ export * from './DefaultDeleteModalBody';
2
+ export * from './DeleteModal';
3
+ export * from './MobileDeleteModal';
4
+ export * from './AdaptiveDeleteModal';
5
+ export * from './DefaultRecallModalBody';
6
+ export * from './RecallModal';
7
+ export * from './MobileRecallModal';
8
+ export * from './AdaptiveRecallModal';
9
+ export * from './ReleaseNotesModal';
10
+ export * from './MobileReleaseNotesModal';
11
+ export * from './AdaptiveReleaseNotesModal';
@@ -0,0 +1,27 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./DefaultDeleteModalBody"), exports);
18
+ __exportStar(require("./DeleteModal"), exports);
19
+ __exportStar(require("./MobileDeleteModal"), exports);
20
+ __exportStar(require("./AdaptiveDeleteModal"), exports);
21
+ __exportStar(require("./DefaultRecallModalBody"), exports);
22
+ __exportStar(require("./RecallModal"), exports);
23
+ __exportStar(require("./MobileRecallModal"), exports);
24
+ __exportStar(require("./AdaptiveRecallModal"), exports);
25
+ __exportStar(require("./ReleaseNotesModal"), exports);
26
+ __exportStar(require("./MobileReleaseNotesModal"), exports);
27
+ __exportStar(require("./AdaptiveReleaseNotesModal"), exports);
@@ -0,0 +1,4 @@
1
+ export declare const TEST_IDS: {
2
+ approveButton: string;
3
+ closeButton: string;
4
+ };
@@ -0,0 +1,7 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TEST_IDS = void 0;
4
+ exports.TEST_IDS = {
5
+ approveButton: 'delete-modal__approve-button',
6
+ closeButton: 'delete-modal__cancel-button',
7
+ };