@solostylist/image-editor 1.0.13 → 1.0.15

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 (132) hide show
  1. package/lib/actions/add-filter.js +2 -1
  2. package/lib/actions/enable-text-content-edit.js +2 -1
  3. package/lib/actions/set-canvas-size.d.ts.map +1 -1
  4. package/lib/actions/set-crop.js +6 -1
  5. package/lib/actions/set-shown-image-dimensions.js +3 -2
  6. package/lib/components/app/index.d.ts.map +1 -1
  7. package/lib/components/app/index.js +111 -41
  8. package/lib/components/assembly-point/index.d.ts +1 -2
  9. package/lib/components/assembly-point/index.d.ts.map +1 -1
  10. package/lib/components/assembly-point/index.js +1 -5
  11. package/lib/components/common/annotation-options/index.js +3 -3
  12. package/lib/components/common/annotation-options/shadow-fields.js +2 -2
  13. package/lib/components/common/color-picker-modal/index.js +1 -1
  14. package/lib/components/common/icon-wrapper/index.js +1 -1
  15. package/lib/components/common/image-preview-tile/index.js +1 -1
  16. package/lib/components/common/slider/index.js +4 -4
  17. package/lib/components/feedback-popup/index.js +2 -2
  18. package/lib/components/layers/design-layer/index.d.ts.map +1 -1
  19. package/lib/components/layers/design-layer/index.js +11 -8
  20. package/lib/components/layers/transformers-layer/crop-transformer.js +3 -2
  21. package/lib/components/layers/transformers-layer/index.js +3 -2
  22. package/lib/components/main-canvas/canvas-node.d.ts.map +1 -1
  23. package/lib/components/main-canvas/canvas-node.js +8 -6
  24. package/lib/components/main-canvas/index.d.ts.map +1 -1
  25. package/lib/components/main-canvas/index.js +135 -33
  26. package/lib/components/main-canvas/touch-zooming-events.js +3 -2
  27. package/lib/components/node-controls/index.d.ts.map +1 -1
  28. package/lib/components/node-controls/index.js +4 -3
  29. package/lib/components/tabs/index.d.ts.map +1 -1
  30. package/lib/components/tabs/index.js +165 -23
  31. package/lib/components/tabs-drawer/index.d.ts +3 -3
  32. package/lib/components/tabs-drawer/index.d.ts.map +1 -1
  33. package/lib/components/tabs-drawer/index.js +66 -43
  34. package/lib/components/tools/crop/crop.d.ts.map +1 -1
  35. package/lib/components/tools/crop/crop.js +3 -3
  36. package/lib/components/tools/filters/filter-item.d.ts +4 -3
  37. package/lib/components/tools/filters/filter-item.d.ts.map +1 -1
  38. package/lib/components/tools/filters/filter-item.js +4 -1
  39. package/lib/components/tools/filters/filters.constants.d.ts +2 -2
  40. package/lib/components/tools/filters/filters.constants.d.ts.map +1 -1
  41. package/lib/components/tools/filters/filters.d.ts +4 -1
  42. package/lib/components/tools/filters/filters.d.ts.map +1 -1
  43. package/lib/components/tools/filters/filters.js +9 -3
  44. package/lib/components/tools/image/image-options.js +5 -4
  45. package/lib/components/tools/image/images-gallery.js +1 -1
  46. package/lib/components/tools/pen/pen-options.js +4 -3
  47. package/lib/components/tools/resize/resize.d.ts +1 -1
  48. package/lib/components/tools/resize/resize.d.ts.map +1 -1
  49. package/lib/components/tools/resize/resize.js +5 -2
  50. package/lib/components/tools/rotate/rotate-options.js +1 -1
  51. package/lib/components/tools/text/text-options/handle-text-change-area.d.ts.map +1 -1
  52. package/lib/components/tools/text/text-options/text-alignment-fields.js +1 -1
  53. package/lib/components/tools/text/text-options/text-controls.js +8 -6
  54. package/lib/components/tools/tools.constants.d.ts +2 -2
  55. package/lib/components/tools/tools.constants.d.ts.map +1 -1
  56. package/lib/components/tools/watermark/watermark-padding.js +2 -1
  57. package/lib/components/tools/watermark/watermark.js +9 -8
  58. package/lib/components/tools-bar/index.d.ts.map +1 -1
  59. package/lib/components/tools-bar/index.js +47 -22
  60. package/lib/components/tools-bar/tools-bar-item-button.d.ts.map +1 -1
  61. package/lib/components/tools-bar/tools-bar-item-button.js +8 -3
  62. package/lib/components/topbar/canvas-zooming.d.ts.map +1 -1
  63. package/lib/components/topbar/canvas-zooming.js +5 -5
  64. package/lib/components/topbar/confirmation-modal.js +2 -2
  65. package/lib/components/topbar/image-dimensions-and-display-toggle.d.ts.map +1 -1
  66. package/lib/components/topbar/image-dimensions-and-display-toggle.js +8 -6
  67. package/lib/components/topbar/index.d.ts.map +1 -1
  68. package/lib/components/topbar/index.js +33 -24
  69. package/lib/components/topbar/redo-button.js +1 -1
  70. package/lib/components/topbar/reset-button.js +1 -1
  71. package/lib/components/topbar/save-button.js +9 -6
  72. package/lib/components/topbar/topbar-action-buttons.d.ts +3 -0
  73. package/lib/components/topbar/topbar-action-buttons.d.ts.map +1 -0
  74. package/lib/components/topbar/topbar-action-buttons.js +27 -0
  75. package/lib/components/topbar/undo-button.js +1 -1
  76. package/lib/context/app-provider.d.ts.map +1 -1
  77. package/lib/context/app-provider.js +8 -6
  78. package/lib/context/app-reducer.js +2 -1
  79. package/lib/context/default-config.d.ts.map +1 -1
  80. package/lib/context/default-config.js +1 -1
  81. package/lib/context/default-translations.d.ts +1 -0
  82. package/lib/context/default-translations.d.ts.map +1 -1
  83. package/lib/context/default-translations.js +465 -113
  84. package/lib/context/get-initial-app-state.js +4 -4
  85. package/lib/custom/filters/moon.d.ts.map +1 -1
  86. package/lib/demo/app.d.ts.map +1 -1
  87. package/lib/demo/app.js +62 -18
  88. package/lib/hooks/index.d.ts +1 -0
  89. package/lib/hooks/index.d.ts.map +1 -1
  90. package/lib/hooks/index.js +2 -1
  91. package/lib/hooks/use-annotation/get-new-annotation-preview.js +2 -2
  92. package/lib/hooks/use-annotation/index.d.ts.map +1 -1
  93. package/lib/hooks/use-annotation/index.js +15 -2
  94. package/lib/hooks/use-annotation-events.d.ts.map +1 -1
  95. package/lib/hooks/use-app-reducer.d.ts.map +1 -1
  96. package/lib/hooks/use-app-reducer.js +2 -1
  97. package/lib/hooks/use-image-editor-actions.d.ts +16 -0
  98. package/lib/hooks/use-image-editor-actions.d.ts.map +1 -0
  99. package/lib/hooks/use-image-editor-actions.js +147 -0
  100. package/lib/hooks/use-resize-observer.d.ts.map +1 -1
  101. package/lib/hooks/use-resize-observer.js +2 -3
  102. package/lib/hooks/use-transformed-img-data.d.ts +1 -1
  103. package/lib/hooks/use-transformed-img-data.d.ts.map +1 -1
  104. package/lib/hooks/use-transformed-img-data.js +13 -9
  105. package/lib/types/actions.d.ts +0 -7
  106. package/lib/types/actions.d.ts.map +1 -1
  107. package/lib/types/config.d.ts +52 -3
  108. package/lib/types/config.d.ts.map +1 -1
  109. package/lib/types/state.d.ts +1 -1
  110. package/lib/types/state.d.ts.map +1 -1
  111. package/lib/utils/calculate-zoom-data.js +5 -4
  112. package/lib/utils/crop-image.d.ts +3 -1
  113. package/lib/utils/crop-image.d.ts.map +1 -1
  114. package/lib/utils/crop-image.js +10 -4
  115. package/lib/utils/extract-current-design-state.js +3 -2
  116. package/lib/utils/filter-str-to-class.js +2 -1
  117. package/lib/utils/finetunes-strs-to-classes.js +2 -1
  118. package/lib/utils/get-file-full-name.d.ts.map +1 -1
  119. package/lib/utils/get-file-full-name.js +3 -3
  120. package/lib/utils/get-pointer-offset-position-bounded-to-object.js +2 -1
  121. package/lib/utils/get-proper-dimensions.js +3 -2
  122. package/lib/utils/is-same-image.d.ts +1 -1
  123. package/lib/utils/is-same-image.d.ts.map +1 -1
  124. package/lib/utils/load-image.d.ts +1 -1
  125. package/lib/utils/load-image.d.ts.map +1 -1
  126. package/lib/utils/load-image.js +1 -3
  127. package/lib/utils/restrict-number.js +2 -2
  128. package/lib/utils/serialize-design-state.js +5 -3
  129. package/lib/utils/translator.d.ts +4 -1
  130. package/lib/utils/translator.d.ts.map +1 -1
  131. package/lib/utils/translator.js +11 -2
  132. package/package.json +14 -5
@@ -1,13 +1,15 @@
1
1
  import { useCallback, useMemo } from 'react';
2
+ import CloseIcon from '@mui/icons-material/Close';
2
3
  import Box from '@mui/material/Box';
3
4
  import SwipeableDrawer from '@mui/material/SwipeableDrawer';
4
5
  import ButtonBase from '@mui/material/ButtonBase';
5
6
  import Typography from '@mui/material/Typography';
7
+ import { SIconButton } from '@solostylist/ui-kit';
6
8
  import { useStore } from "../../hooks";
7
9
  import { SELECT_TAB } from "../../actions";
8
10
  import { AVAILABLE_TABS } from "../tabs/tabs.constants";
9
11
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
10
- var TabsDrawer = function TabsDrawer(_ref) {
12
+ var STabsDrawer = function STabsDrawer(_ref) {
11
13
  var _ref$toggleMainMenu = _ref.toggleMainMenu,
12
14
  toggleMainMenu = _ref$toggleMainMenu === void 0 ? function () {} : _ref$toggleMainMenu;
13
15
  var _useStore = useStore(),
@@ -19,10 +21,10 @@ var TabsDrawer = function TabsDrawer(_ref) {
19
21
  _useStore$config = _useStore.config,
20
22
  defaultTabId = _useStore$config.defaultTabId,
21
23
  tabsIds = _useStore$config.tabsIds;
22
- var currentTabId = tabId || defaultTabId;
24
+ var currentTabId = tabId !== null && tabId !== void 0 ? tabId : defaultTabId;
23
25
  var chosenTabs = useMemo(function () {
24
26
  var tabs = [];
25
- var tabsIdsArray = Array.isArray(tabsIds) ? tabsIds : Object.keys(tabsIds || {});
27
+ var tabsIdsArray = Array.isArray(tabsIds) ? tabsIds : Object.keys(tabsIds !== null && tabsIds !== void 0 ? tabsIds : {});
26
28
  if (tabsIdsArray.length > 0) {
27
29
  AVAILABLE_TABS.forEach(function (tab) {
28
30
  var index = tabsIdsArray.indexOf(tab.id);
@@ -59,57 +61,78 @@ var TabsDrawer = function TabsDrawer(_ref) {
59
61
  disableSwipeToOpen: true,
60
62
  sx: {
61
63
  '& .MuiDrawer-paper': {
64
+ maxHeight: '90vh',
62
65
  borderRadius: '16px 16px 0 0',
63
- maxHeight: '50vh',
64
- pb: 2
66
+ overflow: 'hidden',
67
+ display: 'flex',
68
+ flexDirection: 'column',
69
+ backgroundColor: 'background.paper',
70
+ backgroundImage: 'none'
65
71
  }
66
72
  },
67
- children: [_jsx(Box, {
73
+ children: [_jsxs(Box, {
68
74
  sx: {
69
75
  display: 'flex',
70
- justifyContent: 'center',
71
- py: 2
76
+ alignItems: 'center',
77
+ justifyContent: 'space-between',
78
+ px: 3,
79
+ py: 2,
80
+ borderBottom: 1,
81
+ borderColor: 'divider',
82
+ backgroundColor: 'background.paper'
72
83
  },
73
- children: _jsx(Box, {
74
- sx: {
75
- width: 36,
76
- height: 4,
77
- borderRadius: 2,
78
- bgcolor: 'action.disabled'
79
- }
80
- })
84
+ children: [_jsx(Typography, {
85
+ variant: "h4",
86
+ className: "gradient-text",
87
+ children: t('tabs')
88
+ }), _jsx(SIconButton, {
89
+ onClick: function onClick() {
90
+ return toggleMainMenu(false);
91
+ },
92
+ "aria-label": t('close'),
93
+ children: _jsx(CloseIcon, {})
94
+ })]
81
95
  }), _jsx(Box, {
82
96
  sx: {
83
- display: 'grid',
84
- gridTemplateColumns: 'repeat(3, 1fr)',
85
- gap: 1,
97
+ flex: 1,
98
+ overflow: 'auto',
99
+ display: 'flex',
100
+ flexDirection: 'column',
101
+ backgroundColor: 'background.paper',
86
102
  px: 2,
87
- pb: 1
103
+ py: 2
88
104
  },
89
- children: chosenTabs.map(function (tab) {
90
- var isActive = currentTabId === tab.id;
91
- var Icon = tab.icon;
92
- return _jsxs(ButtonBase, {
93
- onClick: function onClick() {
94
- return selectTab(tab.id);
95
- },
96
- sx: {
97
- display: 'flex',
98
- flexDirection: 'column',
99
- alignItems: 'center',
100
- gap: 0.5,
101
- py: 2,
102
- borderRadius: 2,
103
- bgcolor: isActive ? 'primary.main' : 'action.hover',
104
- color: isActive ? 'primary.contrastText' : 'text.primary',
105
- transition: 'all 0.15s ease'
106
- },
107
- children: [_jsx(Icon, {}), _jsx(Typography, {
108
- children: t(tab.labelKey)
109
- })]
110
- }, tab.id);
105
+ children: _jsx(Box, {
106
+ sx: {
107
+ display: 'grid',
108
+ gridTemplateColumns: 'repeat(3, 1fr)',
109
+ gap: 1
110
+ },
111
+ children: chosenTabs.map(function (tab) {
112
+ var isActive = currentTabId === tab.id;
113
+ var Icon = tab.icon;
114
+ return _jsxs(ButtonBase, {
115
+ onClick: function onClick() {
116
+ return selectTab(tab.id);
117
+ },
118
+ sx: {
119
+ display: 'flex',
120
+ flexDirection: 'column',
121
+ alignItems: 'center',
122
+ gap: 0.5,
123
+ py: 2,
124
+ borderRadius: 2,
125
+ bgcolor: isActive ? 'primary.main' : 'action.hover',
126
+ color: isActive ? 'primary.contrastText' : 'text.primary',
127
+ transition: 'all 0.15s ease'
128
+ },
129
+ children: [_jsx(Icon, {}), _jsx(Typography, {
130
+ children: t(tab.labelKey)
131
+ })]
132
+ }, tab.id);
133
+ })
111
134
  })
112
135
  })]
113
136
  });
114
137
  };
115
- export default TabsDrawer;
138
+ export default STabsDrawer;
@@ -1 +1 @@
1
- {"version":3,"file":"crop.d.ts","sourceRoot":"","sources":["../../../../src/components/tools/crop/crop.tsx"],"names":[],"mappings":"AAcA,UAAU,SAAS;IACjB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,UAAU,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,IAAI,CAAC;CACvC;AAED,QAAA,MAAM,IAAI,GAAI,4BAAoC,SAAS,mDA8G1D,CAAC;AAEF,eAAe,IAAI,CAAC"}
1
+ {"version":3,"file":"crop.d.ts","sourceRoot":"","sources":["../../../../src/components/tools/crop/crop.tsx"],"names":[],"mappings":"AAcA,UAAU,SAAS;IACjB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,UAAU,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,IAAI,CAAC;CACvC;AAED,QAAA,MAAM,IAAI,GAAI,4BAAoC,SAAS,mDAgH1D,CAAC;AAEF,eAAe,IAAI,CAAC"}
@@ -2,7 +2,7 @@ import _toConsumableArray from "@babel/runtime/helpers/toConsumableArray";
2
2
  import { CropOutlined as CropIcon } from '@mui/icons-material';
3
3
  import { Box, InputAdornment } from '@mui/material';
4
4
  import { useMemo } from 'react';
5
- import { SSelect } from '@solostylist/ui-kit/core';
5
+ import { SSelect } from '@solostylist/ui-kit';
6
6
  import { SET_CROP, SET_RESIZE, ZOOM_CANVAS } from "../../../actions";
7
7
  import { useStore } from "../../../hooks";
8
8
  import { DEFAULT_ZOOM_FACTOR, ORIGINAL_CROP, TOOLS_IDS } from "../../../utils/constants";
@@ -24,7 +24,7 @@ var Crop = function Crop(_ref) {
24
24
  appliedRatio = _useStore$adjustments4.ratio,
25
25
  shownImageDimensions = _useStore.shownImageDimensions,
26
26
  config = _useStore.config;
27
- var currentRatio = appliedRatio || ORIGINAL_CROP;
27
+ var currentRatio = appliedRatio !== null && appliedRatio !== void 0 ? appliedRatio : ORIGINAL_CROP;
28
28
  var cropConfig = config[TOOLS_IDS.CROP];
29
29
  var allPresets = useMemo(function () {
30
30
  var _cropConfig$presetsIt;
@@ -45,7 +45,7 @@ var Crop = function Crop(_ref) {
45
45
  var options = useMemo(function () {
46
46
  return allPresets.map(function (preset) {
47
47
  return {
48
- label: "".concat(t(preset.titleKey)).concat(preset.descriptionKey ? " (".concat(preset.descriptionKey, ")") : ''),
48
+ label: t(preset.titleKey) + (preset.descriptionKey ? " (".concat(preset.descriptionKey, ")") : ''),
49
49
  value: String(getPresetRatio(preset))
50
50
  };
51
51
  });
@@ -1,10 +1,11 @@
1
+ import { Filter } from 'konva/lib/Node';
1
2
  interface FilterItemProps {
2
3
  filterLabel: string;
3
- filterFn?: ((...args: any[]) => void) | null;
4
+ filterFn?: Filter | null;
4
5
  applyFilter: (filterFn: any) => void;
5
6
  isActive: boolean;
6
- image: HTMLImageElement;
7
+ image: HTMLImageElement | null;
7
8
  }
8
- declare const _default: import("react").MemoExoticComponent<({ filterLabel, filterFn, applyFilter, isActive, image, }: FilterItemProps) => import("react/jsx-runtime").JSX.Element>;
9
+ declare const _default: import("react").MemoExoticComponent<({ filterLabel, filterFn, applyFilter, isActive, image, }: FilterItemProps) => import("react/jsx-runtime").JSX.Element | null>;
9
10
  export default _default;
10
11
  //# sourceMappingURL=filter-item.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"filter-item.d.ts","sourceRoot":"","sources":["../../../../src/components/tools/filters/filter-item.tsx"],"names":[],"mappings":"AAWA,UAAU,eAAe;IACvB,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,EAAE,CAAC,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,IAAI,CAAC,GAAG,IAAI,CAAC;IAC7C,WAAW,EAAE,CAAC,QAAQ,EAAE,GAAG,KAAK,IAAI,CAAC;IACrC,QAAQ,EAAE,OAAO,CAAC;IAClB,KAAK,EAAE,gBAAgB,CAAC;CACzB;uHAQE,eAAe;AA8ElB,wBAAgC"}
1
+ {"version":3,"file":"filter-item.d.ts","sourceRoot":"","sources":["../../../../src/components/tools/filters/filter-item.tsx"],"names":[],"mappings":"AAGA,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;AASxC,UAAU,eAAe;IACvB,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACzB,WAAW,EAAE,CAAC,QAAQ,EAAE,GAAG,KAAK,IAAI,CAAC;IACrC,QAAQ,EAAE,OAAO,CAAC;IAClB,KAAK,EAAE,gBAAgB,GAAG,IAAI,CAAC;CAChC;uHAQE,eAAe;AAkFlB,wBAAgC"}
@@ -4,7 +4,7 @@ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t =
4
4
  import { memo, useCallback, useEffect, useRef } from 'react';
5
5
  import { Layer, Image, Stage } from 'react-konva';
6
6
  import { Typography } from '@mui/material';
7
- import { SFlexBox } from '@solostylist/ui-kit/core';
7
+ import { SFlexBox } from '@solostylist/ui-kit';
8
8
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
9
9
  var MAX_FILTER_PREVIEW_WIDTH = 80;
10
10
  var MAX_FILTER_PREVIEW_HEIGHT = 60;
@@ -14,6 +14,9 @@ var FilterItem = function FilterItem(_ref) {
14
14
  applyFilter = _ref.applyFilter,
15
15
  isActive = _ref.isActive,
16
16
  image = _ref.image;
17
+ if (!image) {
18
+ return null;
19
+ }
17
20
  var imageNodeRef = useRef(null);
18
21
  var handleFilterApplying = useCallback(function () {
19
22
  applyFilter(filterFn);
@@ -1,7 +1,7 @@
1
- type FilterFn = any;
1
+ import { Filter } from 'konva/lib/Node';
2
2
  interface FilterItem {
3
3
  label: string;
4
- filterFn: FilterFn;
4
+ filterFn: Filter | null;
5
5
  }
6
6
  export declare const AVAILABLE_FILTERS: FilterItem[];
7
7
  export {};
@@ -1 +1 @@
1
- {"version":3,"file":"filters.constants.d.ts","sourceRoot":"","sources":["../../../../src/components/tools/filters/filters.constants.ts"],"names":[],"mappings":"AAMA,KAAK,QAAQ,GAAG,GAAG,CAAC;AAEpB,UAAU,UAAU;IAClB,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,QAAQ,CAAC;CACpB;AAGD,eAAO,MAAM,iBAAiB,EAAE,UAAU,EAqLzC,CAAC"}
1
+ {"version":3,"file":"filters.constants.d.ts","sourceRoot":"","sources":["../../../../src/components/tools/filters/filters.constants.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;AAExC,UAAU,UAAU;IAClB,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAC;CACzB;AAGD,eAAO,MAAM,iBAAiB,EAAE,UAAU,EAqLzC,CAAC"}
@@ -1,3 +1,6 @@
1
- declare const Filters: () => import("react/jsx-runtime").JSX.Element;
1
+ interface FiltersProps {
2
+ maxWidth?: string | number;
3
+ }
4
+ declare const Filters: ({ maxWidth }: FiltersProps) => import("react/jsx-runtime").JSX.Element;
2
5
  export default Filters;
3
6
  //# sourceMappingURL=filters.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"filters.d.ts","sourceRoot":"","sources":["../../../../src/components/tools/filters/filters.tsx"],"names":[],"mappings":"AAuCA,QAAA,MAAM,OAAO,+CAkCZ,CAAC;AAEF,eAAe,OAAO,CAAC"}
1
+ {"version":3,"file":"filters.d.ts","sourceRoot":"","sources":["../../../../src/components/tools/filters/filters.tsx"],"names":[],"mappings":"AAuCA,UAAU,YAAY;IACpB,QAAQ,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;CAC5B;AAED,QAAA,MAAM,OAAO,GAAI,cAAc,YAAY,4CAuC1C,CAAC;AAEF,eAAe,OAAO,CAAC"}
@@ -42,7 +42,8 @@ var responsiveSettings = [{
42
42
  slidesToScroll: 2
43
43
  }
44
44
  }];
45
- var Filters = function Filters() {
45
+ var Filters = function Filters(_ref) {
46
+ var maxWidth = _ref.maxWidth;
46
47
  var _useStore = useStore(),
47
48
  originalImage = _useStore.originalImage;
48
49
  var _useFilter = useFilter(),
@@ -52,10 +53,15 @@ var Filters = function Filters() {
52
53
  return _jsx(Box, {
53
54
  sx: {
54
55
  width: '100%',
56
+ maxWidth: maxWidth !== null && maxWidth !== void 0 ? maxWidth : '80vw',
55
57
  flex: '1 1 100%',
56
58
  display: 'block',
57
59
  minWidth: 0,
58
- overflow: 'hidden'
60
+ overflow: 'visible',
61
+ position: 'relative',
62
+ '& .slick-arrow': {
63
+ color: 'var(--s-palete-text-secondary)'
64
+ }
59
65
  },
60
66
  children: _jsx(SCarousel, {
61
67
  slidesToShow: 16,
@@ -67,7 +73,7 @@ var Filters = function Filters() {
67
73
  filterFn: filter.filterFn,
68
74
  applyFilter: applyFilter,
69
75
  isActive: appliedFilter === filter.filterFn,
70
- image: originalImage
76
+ image: originalImage !== null && originalImage !== void 0 ? originalImage : null
71
77
  }, filter.label);
72
78
  })
73
79
  })
@@ -39,10 +39,11 @@ var ImageOptions = function ImageOptions() {
39
39
  addNewImage = _useAnnotation2[2];
40
40
  var requestedImgsCount = useRef(0);
41
41
  var addImgScaled = function addImgScaled(loadedImg) {
42
- var layerWidth = crop.width || shownImageDimensions.width;
43
- var layerHeight = crop.height || shownImageDimensions.height;
44
- var layerCropX = crop.x || 0;
45
- var layerCropY = crop.y || 0;
42
+ var _crop$width, _crop$height, _crop$x, _crop$y;
43
+ var layerWidth = (_crop$width = crop.width) !== null && _crop$width !== void 0 ? _crop$width : shownImageDimensions.width;
44
+ var layerHeight = (_crop$height = crop.height) !== null && _crop$height !== void 0 ? _crop$height : shownImageDimensions.height;
45
+ var layerCropX = (_crop$x = crop.x) !== null && _crop$x !== void 0 ? _crop$x : 0;
46
+ var layerCropY = (_crop$y = crop.y) !== null && _crop$y !== void 0 ? _crop$y : 0;
46
47
  var newImgRatio = Math.min(1, layerWidth / (loadedImg.width + loadedImg.width * ADDED_IMG_SPACING_PERCENT), layerHeight / (loadedImg.height + loadedImg.height * ADDED_IMG_SPACING_PERCENT));
47
48
  addNewImage({
48
49
  image: loadedImg,
@@ -1,5 +1,5 @@
1
1
  import { Popover } from '@mui/material';
2
- import { SFlexBox } from '@solostylist/ui-kit/core';
2
+ import { SFlexBox } from '@solostylist/ui-kit';
3
3
  import ImagePreviewTile from "../../common/image-preview-tile";
4
4
  import { jsx as _jsx } from "react/jsx-runtime";
5
5
  var ImagesGallery = function ImagesGallery(_ref) {
@@ -36,18 +36,19 @@ var PenOptions = function PenOptions() {
36
36
  id: ''
37
37
  });
38
38
  var getPointerPosition = useCallback(function () {
39
+ var _designLayer$attrs$xP, _designLayer$attrs$yP;
39
40
  var canvasBoundingRect = getElemDocumentCoords(canvasRef.current.content);
40
41
  var pos = getPointerOffsetPositionBoundedToObject(previewGroup, canvasBoundingRect);
41
- return [pos.offsetX - (designLayer.attrs.xPadding || 0), pos.offsetY - (designLayer.attrs.yPadding || 0)];
42
+ return [pos.offsetX - ((_designLayer$attrs$xP = designLayer.attrs.xPadding) !== null && _designLayer$attrs$xP !== void 0 ? _designLayer$attrs$xP : 0), pos.offsetY - ((_designLayer$attrs$yP = designLayer.attrs.yPadding) !== null && _designLayer$attrs$yP !== void 0 ? _designLayer$attrs$yP : 0)];
42
43
  }, [designLayer]);
43
44
  var handlePointerMove = useCallback(function () {
44
45
  var _updatedPen$current;
45
46
  if (!((_updatedPen$current = updatedPen.current) !== null && _updatedPen$current !== void 0 && _updatedPen$current.moved)) {
46
- var _updatedPen$current2;
47
+ var _updatedPen$current$p, _updatedPen$current2;
47
48
  updatedPen.current = {
48
49
  moved: true,
49
50
  id: randomId(TOOLS_IDS.PEN),
50
- points: [].concat(_toConsumableArray(((_updatedPen$current2 = updatedPen.current) === null || _updatedPen$current2 === void 0 ? void 0 : _updatedPen$current2.points) || []), _toConsumableArray(getPointerPosition()))
51
+ points: [].concat(_toConsumableArray((_updatedPen$current$p = (_updatedPen$current2 = updatedPen.current) === null || _updatedPen$current2 === void 0 ? void 0 : _updatedPen$current2.points) !== null && _updatedPen$current$p !== void 0 ? _updatedPen$current$p : []), _toConsumableArray(getPointerPosition()))
51
52
  };
52
53
  savePenNoDebounce({
53
54
  id: updatedPen.current.id,
@@ -8,6 +8,6 @@ interface ResizeProps {
8
8
  currentSize?: CurrentSize;
9
9
  hideResetButton?: boolean;
10
10
  }
11
- declare const Resize: ({ onChange, currentSize, hideResetButton, }: ResizeProps) => import("react/jsx-runtime").JSX.Element;
11
+ declare const Resize: ({ onChange, currentSize, hideResetButton, }: ResizeProps) => import("react/jsx-runtime").JSX.Element | null;
12
12
  export default Resize;
13
13
  //# sourceMappingURL=resize.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"resize.d.ts","sourceRoot":"","sources":["../../../../src/components/tools/resize/resize.tsx"],"names":[],"mappings":"AAaA,UAAU,WAAW;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,aAAa,CAAC,EAAE,OAAO,CAAC;CACzB;AAED,UAAU,WAAW;IACnB,QAAQ,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,KAAK,IAAI,CAAC;IACpD,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,eAAe,CAAC,EAAE,OAAO,CAAC;CAC3B;AAED,QAAA,MAAM,MAAM,GAAI,6CAIb,WAAW,4CAqLb,CAAC;AAEF,eAAe,MAAM,CAAC"}
1
+ {"version":3,"file":"resize.d.ts","sourceRoot":"","sources":["../../../../src/components/tools/resize/resize.tsx"],"names":[],"mappings":"AAaA,UAAU,WAAW;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,aAAa,CAAC,EAAE,OAAO,CAAC;CACzB;AAED,UAAU,WAAW;IACnB,QAAQ,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,KAAK,IAAI,CAAC;IACpD,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,eAAe,CAAC,EAAE,OAAO,CAAC;CAC3B;AAED,QAAA,MAAM,MAAM,GAAI,6CAIb,WAAW,mDAyLb,CAAC;AAEF,eAAe,MAAM,CAAC"}
@@ -2,7 +2,7 @@ import _defineProperty from "@babel/runtime/helpers/defineProperty";
2
2
  function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
3
3
  function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
4
4
  import { Refresh, LockOutlined, LockOpenOutlined } from '@mui/icons-material';
5
- import { SFlexBox, SIconButton, STextField } from '@solostylist/ui-kit/core';
5
+ import { SFlexBox, SIconButton, STextField } from '@solostylist/ui-kit';
6
6
  import { SET_RESIZE, ZOOM_CANVAS } from "../../../actions";
7
7
  import { useStore } from "../../../hooks";
8
8
  import { DEFAULT_ZOOM_FACTOR } from "../../../utils/constants";
@@ -27,6 +27,9 @@ var Resize = function Resize(_ref) {
27
27
  _useStore$adjustments2 = _useStore$adjustments.rotation,
28
28
  rotation = _useStore$adjustments2 === void 0 ? 0 : _useStore$adjustments2,
29
29
  t = _useStore.t;
30
+ if (!originalImage) {
31
+ return null;
32
+ }
30
33
  var dimensions = getProperDimensions(((currentSize === null || currentSize === void 0 ? void 0 : currentSize.width) || (currentSize === null || currentSize === void 0 ? void 0 : currentSize.height)) && currentSize || resize, crop, shownImageDimensions, originalImage, rotation);
31
34
  var changeResize = function changeResize(e) {
32
35
  var _currentSize$ratioUnl;
@@ -105,7 +108,7 @@ var Resize = function Resize(_ref) {
105
108
  return _jsxs(SFlexBox, {
106
109
  sx: {
107
110
  gap: 1,
108
- alignItems: 'flex-end'
111
+ alignItems: 'center'
109
112
  },
110
113
  children: [_jsx(STextField, {
111
114
  name: "width",
@@ -6,7 +6,7 @@ import restrictNumber from "../../../utils/restrict-number";
6
6
  import getSizeAfterRotation from "../../../utils/get-size-after-rotation";
7
7
  import { TOOLS_IDS } from "../../../utils/constants";
8
8
  import ToolsBarItemButton from "../../tools-bar/tools-bar-item-button";
9
- import { SFlexBox, SIconButton } from '@solostylist/ui-kit/core';
9
+ import { SFlexBox, SIconButton } from '@solostylist/ui-kit';
10
10
  import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
11
11
  var RotateOptions = function RotateOptions() {
12
12
  var _useStore = useStore(),
@@ -1 +1 @@
1
- {"version":3,"file":"handle-text-change-area.d.ts","sourceRoot":"","sources":["../../../../../src/components/tools/text/text-options/handle-text-change-area.ts"],"names":[],"mappings":"AAMA,iBAAS,oBAAoB,IAAI,IAAI,CAwBpC;AAWD,QAAA,MAAM,kBAAkB,GACtB,YAAY,MAAM,EAClB,aAAa,GAAG,EAChB,oBAAoB,GAAG,EACvB,mBAAmB,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,EAC9C,uBAAuB,MAAM,IAAI,KAChC,IAyHF,CAAC;AAEF,OAAO,EAAE,kBAAkB,EAAE,oBAAoB,EAAE,CAAC"}
1
+ {"version":3,"file":"handle-text-change-area.d.ts","sourceRoot":"","sources":["../../../../../src/components/tools/text/text-options/handle-text-change-area.ts"],"names":[],"mappings":"AAMA,iBAAS,oBAAoB,IAAI,IAAI,CAoBpC;AAWD,QAAA,MAAM,kBAAkB,GACtB,YAAY,MAAM,EAClB,aAAa,GAAG,EAChB,oBAAoB,GAAG,EACvB,mBAAmB,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,EAC9C,uBAAuB,MAAM,IAAI,KAChC,IAyHF,CAAC;AAEF,OAAO,EAAE,kBAAkB,EAAE,oBAAoB,EAAE,CAAC"}
@@ -1,5 +1,5 @@
1
1
  import { FormatAlignCenterOutlined, FormatAlignLeftOutlined } from '@mui/icons-material';
2
- import { SFlexBox } from '@solostylist/ui-kit/core';
2
+ import { SFlexBox } from '@solostylist/ui-kit';
3
3
  import SIconButtonWrapper from "../../../common/icon-wrapper";
4
4
  import { TextAlignment } from "../../../../types/annotations";
5
5
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
@@ -9,11 +9,12 @@ import SIconButtonWrapper from "../../../common/icon-wrapper";
9
9
  import { ENABLE_TEXT_CONTENT_EDIT } from "../../../../actions";
10
10
  import restrictNumber from "../../../../utils/restrict-number";
11
11
  import { useStore } from "../../../../hooks";
12
- import { SFlexBox, SSelect, STextField } from '@solostylist/ui-kit/core';
12
+ import { SFlexBox, SSelect, STextField } from '@solostylist/ui-kit';
13
13
  import { textOptionsPopupComponents, TEXT_POPPABLE_OPTIONS } from "./text-options.constants";
14
14
  import { activateTextChange, deactivateTextChange } from "./handle-text-change-area";
15
15
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
16
16
  var TextControls = function TextControls(_ref) {
17
+ var _config$TOOLS_IDS$TEX, _text$fontSize, _text$fontStyle2, _text$fontStyle3;
17
18
  var text = _ref.text,
18
19
  saveText = _ref.saveText,
19
20
  children = _ref.children;
@@ -23,7 +24,7 @@ var TextControls = function TextControls(_ref) {
23
24
  designLayer = _useStore.designLayer,
24
25
  t = _useStore.t,
25
26
  config = _useStore.config;
26
- var textConfig = config[TOOLS_IDS.TEXT] || {};
27
+ var textConfig = (_config$TOOLS_IDS$TEX = config[TOOLS_IDS.TEXT]) !== null && _config$TOOLS_IDS$TEX !== void 0 ? _config$TOOLS_IDS$TEX : {};
27
28
  var _textConfig$fonts = textConfig.fonts,
28
29
  fonts = _textConfig$fonts === void 0 ? [] : _textConfig$fonts,
29
30
  onFontChange = textConfig.onFontChange;
@@ -90,7 +91,8 @@ var TextControls = function TextControls(_ref) {
90
91
  var canvasStage = designLayer.getStage();
91
92
  var transformersLayer = canvasStage.findOne("#".concat(TRANSFORMERS_LAYER_ID));
92
93
  if (transformersLayer) {
93
- var _ref3 = transformersLayer.children || [];
94
+ var _transformersLayer$ch;
95
+ var _ref3 = (_transformersLayer$ch = transformersLayer.children) !== null && _transformersLayer$ch !== void 0 ? _transformersLayer$ch : [];
94
96
  var _ref4 = _slicedToArray(_ref3, 1);
95
97
  transformer = _ref4[0];
96
98
  activateTextChange(textIdOfEditableContent, canvasStage, transformer, changeTextContent, disableTextEdit);
@@ -124,7 +126,7 @@ var TextControls = function TextControls(_ref) {
124
126
  textAlign: 'left'
125
127
  }
126
128
  }), _jsx(STextField, {
127
- value: text.fontSize || '',
129
+ value: (_text$fontSize = text.fontSize) !== null && _text$fontSize !== void 0 ? _text$fontSize : '',
128
130
  name: "fontSize",
129
131
  onChange: changeTextProps,
130
132
  inputMode: "numeric",
@@ -134,13 +136,13 @@ var TextControls = function TextControls(_ref) {
134
136
  },
135
137
  placeholder: t('size')
136
138
  }), _jsx(SIconButtonWrapper, {
137
- active: (text.fontStyle || '').includes('bold'),
139
+ active: ((_text$fontStyle2 = text.fontStyle) !== null && _text$fontStyle2 !== void 0 ? _text$fontStyle2 : '').includes('bold'),
138
140
  onClick: function onClick() {
139
141
  return changeFontStyle('bold');
140
142
  },
141
143
  children: _jsx(FormatBoldOutlined, {})
142
144
  }), _jsx(SIconButtonWrapper, {
143
- active: (text.fontStyle || '').includes('italic'),
145
+ active: ((_text$fontStyle3 = text.fontStyle) !== null && _text$fontStyle3 !== void 0 ? _text$fontStyle3 : '').includes('italic'),
144
146
  onClick: function onClick() {
145
147
  return changeFontStyle('italic');
146
148
  },
@@ -1,7 +1,7 @@
1
1
  interface ToolItem {
2
2
  id: string;
3
- Item: any;
4
- ItemOptions?: any;
3
+ Item: React.ComponentType<any>;
4
+ ItemOptions?: React.ComponentType<any>;
5
5
  }
6
6
  export declare const TOOLS_ITEMS: Record<string, ToolItem>;
7
7
  export declare const TABS_TOOLS: Record<string, string[]>;
@@ -1 +1 @@
1
- {"version":3,"file":"tools.constants.d.ts","sourceRoot":"","sources":["../../../src/components/tools/tools.constants.ts"],"names":[],"mappings":"AAsBA,UAAU,QAAQ;IAChB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,GAAG,CAAC;IACV,WAAW,CAAC,EAAE,GAAG,CAAC;CACnB;AAED,eAAO,MAAM,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,QAAQ,CA+FhD,CAAC;AAEF,eAAO,MAAM,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,CA2B/C,CAAC"}
1
+ {"version":3,"file":"tools.constants.d.ts","sourceRoot":"","sources":["../../../src/components/tools/tools.constants.ts"],"names":[],"mappings":"AAsBA,UAAU,QAAQ;IAChB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,KAAK,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;IAC/B,WAAW,CAAC,EAAE,KAAK,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;CACxC;AAED,eAAO,MAAM,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,QAAQ,CA+FhD,CAAC;AAEF,eAAO,MAAM,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,CA2B/C,CAAC"}
@@ -7,6 +7,7 @@ import Slider from "../../common/slider";
7
7
  import restrictNumber from "../../../utils/restrict-number";
8
8
  import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
9
9
  var WatermarkPadding = function WatermarkPadding(_ref) {
10
+ var _watermark$padding;
10
11
  var watermark = _ref.watermark,
11
12
  saveWatermark = _ref.saveWatermark,
12
13
  t = _ref.t;
@@ -25,7 +26,7 @@ var WatermarkPadding = function WatermarkPadding(_ref) {
25
26
  padding: restrictNumber(newPadding, 0, 100)
26
27
  });
27
28
  };
28
- var currentPadding = watermark.padding || 0;
29
+ var currentPadding = (_watermark$padding = watermark.padding) !== null && _watermark$padding !== void 0 ? _watermark$padding : 0;
29
30
  return _jsxs(_Fragment, {
30
31
  children: [_jsx(SIconButtonWrapper, {
31
32
  title: t('padding'),
@@ -3,7 +3,7 @@ import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
3
3
  function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
4
4
  function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
5
5
  import { FileUploadOutlined, TextFieldsOutlined } from '@mui/icons-material';
6
- import { SFlexBox } from '@solostylist/ui-kit/core';
6
+ import { SFlexBox } from '@solostylist/ui-kit';
7
7
  import { useEffect, useMemo, useRef, useState } from 'react';
8
8
  import { CLEAR_ANNOTATIONS_SELECTIONS, SELECT_ANNOTATION, SET_ANNOTATION, SET_FEEDBACK } from "../../../actions";
9
9
  import ButtonWithMenu from "../../common/button-with-menu";
@@ -18,6 +18,7 @@ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-run
18
18
  var WATERMARK_IMG_RATIO_FROM_ORIGINAL = 0.33;
19
19
  var WATERMARK_ANNOTATION_ID = 'watermark';
20
20
  var Watermark = function Watermark() {
21
+ var _crop$width, _crop$height, _crop$x, _crop$y, _watermarkConfig$text, _watermarkConfig$imag;
21
22
  var _useStore = useStore(),
22
23
  annotations = _useStore.annotations,
23
24
  shownImageDimensions = _useStore.shownImageDimensions,
@@ -36,12 +37,12 @@ var Watermark = function Watermark() {
36
37
  var watermark = useMemo(function () {
37
38
  return annotations[WATERMARK_ANNOTATION_ID];
38
39
  }, [annotations[WATERMARK_ANNOTATION_ID]]);
39
- var layerWidth = crop.width || shownImageDimensions.width;
40
- var layerHeight = crop.height || shownImageDimensions.height;
41
- var layerCropX = crop.x || 0;
42
- var layerCropY = crop.y || 0;
43
- var watermarkTextRatio = (watermarkConfig === null || watermarkConfig === void 0 ? void 0 : watermarkConfig.textScalingRatio) || WATERMARK_IMG_RATIO_FROM_ORIGINAL;
44
- var watermarkImageRatio = (watermarkConfig === null || watermarkConfig === void 0 ? void 0 : watermarkConfig.imageScalingRatio) || WATERMARK_IMG_RATIO_FROM_ORIGINAL;
40
+ var layerWidth = (_crop$width = crop.width) !== null && _crop$width !== void 0 ? _crop$width : shownImageDimensions.width;
41
+ var layerHeight = (_crop$height = crop.height) !== null && _crop$height !== void 0 ? _crop$height : shownImageDimensions.height;
42
+ var layerCropX = (_crop$x = crop.x) !== null && _crop$x !== void 0 ? _crop$x : 0;
43
+ var layerCropY = (_crop$y = crop.y) !== null && _crop$y !== void 0 ? _crop$y : 0;
44
+ var watermarkTextRatio = (_watermarkConfig$text = watermarkConfig === null || watermarkConfig === void 0 ? void 0 : watermarkConfig.textScalingRatio) !== null && _watermarkConfig$text !== void 0 ? _watermarkConfig$text : WATERMARK_IMG_RATIO_FROM_ORIGINAL;
45
+ var watermarkImageRatio = (_watermarkConfig$imag = watermarkConfig === null || watermarkConfig === void 0 ? void 0 : watermarkConfig.imageScalingRatio) !== null && _watermarkConfig$imag !== void 0 ? _watermarkConfig$imag : WATERMARK_IMG_RATIO_FROM_ORIGINAL;
45
46
  var addTextWatermark = function addTextWatermark() {
46
47
  var _dimensions$width, _dimensions$height;
47
48
  var dimensions = {};
@@ -209,7 +210,7 @@ var Watermark = function Watermark() {
209
210
  children: renderWatermarkPadding()
210
211
  }), _jsxs(SFlexBox, {
211
212
  gap: 1,
212
- mt: 1,
213
+ flexGrow: 1,
213
214
  children: [_jsx(ButtonWithMenu, {
214
215
  label: addWatermarkLabel(),
215
216
  menuItems: menuItems
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/tools-bar/index.tsx"],"names":[],"mappings":"AAUA,QAAA,MAAM,QAAQ,+CAqIb,CAAC;AAEF,eAAe,QAAQ,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/tools-bar/index.tsx"],"names":[],"mappings":"AAeA,QAAA,MAAM,QAAQ,+CA4Kb,CAAC;AAEF,eAAe,QAAQ,CAAC"}