@wix/auto-patterns 1.49.0 → 1.51.0

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 (266) hide show
  1. package/dist/cjs/assets/locale/messages_en.json +68 -1
  2. package/dist/cjs/cms-fields/auto-cms-field-types/index.js +3 -1
  3. package/dist/cjs/cms-fields/auto-cms-field-types/index.js.map +1 -1
  4. package/dist/cjs/cms-fields/auto-cms-field-types/media-manager.js +24 -21
  5. package/dist/cjs/cms-fields/auto-cms-field-types/media-manager.js.map +1 -1
  6. package/dist/cjs/cms-fields/auto-cms-field-types/media-types.js.map +1 -1
  7. package/dist/cjs/cms-fields/components/address/input/address-input.st.css.js +3 -3
  8. package/dist/cjs/cms-fields/components/address/input/address-input.st.css.js.map +1 -1
  9. package/dist/cjs/cms-fields/components/audio/actions/actions-menu/actions-menu.st.css.js +3 -3
  10. package/dist/cjs/cms-fields/components/audio/actions/actions-menu/actions-menu.st.css.js.map +1 -1
  11. package/dist/cjs/cms-fields/components/audio/audio-field/form-audio-field.st.css.js +4 -4
  12. package/dist/cjs/cms-fields/components/audio/audio-field/form-audio-field.st.css.js.map +1 -1
  13. package/dist/cjs/cms-fields/components/audio/audio-player/audio-player.st.css.js +2 -2
  14. package/dist/cjs/cms-fields/components/audio/audio-player/audio-player.st.css.js.map +1 -1
  15. package/dist/cjs/cms-fields/components/delete-dialog/delete-dialog.st.css.js +3 -3
  16. package/dist/cjs/cms-fields/components/delete-dialog/delete-dialog.st.css.js.map +1 -1
  17. package/dist/cjs/cms-fields/components/document/form-document-field.st.css.js +7 -7
  18. package/dist/cjs/cms-fields/components/document/form-document-field.st.css.js.map +1 -1
  19. package/dist/cjs/cms-fields/components/exclamation/exclamation.st.css.js +5 -5
  20. package/dist/cjs/cms-fields/components/exclamation/exclamation.st.css.js.map +1 -1
  21. package/dist/cjs/cms-fields/components/highlighted-text/highlighted-text.st.css.js +5 -5
  22. package/dist/cjs/cms-fields/components/highlighted-text/highlighted-text.st.css.js.map +1 -1
  23. package/dist/cjs/cms-fields/components/media-control/paste-url-button.st.css.js +4 -4
  24. package/dist/cjs/cms-fields/components/media-control/paste-url-button.st.css.js.map +1 -1
  25. package/dist/cjs/cms-fields/components/media-gallery/form-media-gallery-field.js +275 -0
  26. package/dist/cjs/cms-fields/components/media-gallery/form-media-gallery-field.js.map +1 -0
  27. package/dist/cjs/cms-fields/components/media-gallery/form-media-gallery-field.st.css +51 -0
  28. package/dist/cjs/cms-fields/components/media-gallery/form-media-gallery-field.st.css.js +30 -0
  29. package/dist/cjs/cms-fields/components/media-gallery/form-media-gallery-field.st.css.js.map +1 -0
  30. package/dist/cjs/cms-fields/components/media-gallery/form-media-gallery-field.uni.driver.js +14 -0
  31. package/dist/cjs/cms-fields/components/media-gallery/form-media-gallery-field.uni.driver.js.map +1 -0
  32. package/dist/cjs/cms-fields/components/media-gallery/form-media-gallery-items-preview.js +134 -0
  33. package/dist/cjs/cms-fields/components/media-gallery/form-media-gallery-items-preview.js.map +1 -0
  34. package/dist/cjs/cms-fields/components/media-gallery/media-gallery-dialog/add-link-modal.js +172 -0
  35. package/dist/cjs/cms-fields/components/media-gallery/media-gallery-dialog/add-link-modal.js.map +1 -0
  36. package/dist/cjs/cms-fields/components/media-gallery/media-gallery-dialog/add-media-button.js +50 -0
  37. package/dist/cjs/cms-fields/components/media-gallery/media-gallery-dialog/add-media-button.js.map +1 -0
  38. package/dist/cjs/cms-fields/components/media-gallery/media-gallery-dialog/content-keys.js +44 -0
  39. package/dist/cjs/cms-fields/components/media-gallery/media-gallery-dialog/content-keys.js.map +1 -0
  40. package/dist/cjs/cms-fields/components/media-gallery/media-gallery-dialog/hooks.js +89 -0
  41. package/dist/cjs/cms-fields/components/media-gallery/media-gallery-dialog/hooks.js.map +1 -0
  42. package/dist/cjs/cms-fields/components/media-gallery/media-gallery-dialog/item-actions.js +61 -0
  43. package/dist/cjs/cms-fields/components/media-gallery/media-gallery-dialog/item-actions.js.map +1 -0
  44. package/dist/cjs/cms-fields/components/media-gallery/media-gallery-dialog/media-gallery-dialog.js +181 -0
  45. package/dist/cjs/cms-fields/components/media-gallery/media-gallery-dialog/media-gallery-dialog.js.map +1 -0
  46. package/dist/cjs/cms-fields/components/media-gallery/media-gallery-dialog/no-items-view.js +71 -0
  47. package/dist/cjs/cms-fields/components/media-gallery/media-gallery-dialog/no-items-view.js.map +1 -0
  48. package/dist/cjs/cms-fields/components/media-gallery/media-gallery-dialog/types.js +4 -0
  49. package/dist/cjs/cms-fields/components/media-gallery/media-gallery-dialog/types.js.map +1 -0
  50. package/dist/cjs/cms-fields/components/media-gallery/media-gallery-dialog/use-add-link-modal.js +24 -0
  51. package/dist/cjs/cms-fields/components/media-gallery/media-gallery-dialog/use-add-link-modal.js.map +1 -0
  52. package/dist/cjs/cms-fields/components/media-gallery/media-gallery-dialog/utils.js +289 -0
  53. package/dist/cjs/cms-fields/components/media-gallery/media-gallery-dialog/utils.js.map +1 -0
  54. package/dist/cjs/cms-fields/components/media-gallery/media-preview-modal.js +274 -0
  55. package/dist/cjs/cms-fields/components/media-gallery/media-preview-modal.js.map +1 -0
  56. package/dist/cjs/cms-fields/components/media-image/media-image.st.css.js +4 -4
  57. package/dist/cjs/cms-fields/components/media-image/media-image.st.css.js.map +1 -1
  58. package/dist/cjs/cms-fields/components/media-loader/media-loader.st.css.js +3 -3
  59. package/dist/cjs/cms-fields/components/media-loader/media-loader.st.css.js.map +1 -1
  60. package/dist/cjs/cms-fields/components/media-tag/web-media-tag/media-tag.st.css.js +2 -2
  61. package/dist/cjs/cms-fields/components/media-tag/web-media-tag/media-tag.st.css.js.map +1 -1
  62. package/dist/cjs/cms-fields/components/multi-document/multi-document-input/form-multi-document.st.css.js +5 -5
  63. package/dist/cjs/cms-fields/components/multi-document/multi-document-input/form-multi-document.st.css.js.map +1 -1
  64. package/dist/cjs/cms-fields/components/rich-content/rich-content-input/default-value-input/rich-content-default-value-input.st.css.js +6 -6
  65. package/dist/cjs/cms-fields/components/rich-content/rich-content-input/default-value-input/rich-content-default-value-input.st.css.js.map +1 -1
  66. package/dist/cjs/cms-fields/components/rich-content/rich-content-input/form-input/rich-content-form-input.st.css.js +5 -5
  67. package/dist/cjs/cms-fields/components/rich-content/rich-content-input/form-input/rich-content-form-input.st.css.js.map +1 -1
  68. package/dist/cjs/cms-fields/components/rich-content/rich-content-input/form-read-only-input/rich-content-form-read-only-input.st.css.js +2 -2
  69. package/dist/cjs/cms-fields/components/rich-content/rich-content-input/form-read-only-input/rich-content-form-read-only-input.st.css.js.map +1 -1
  70. package/dist/cjs/cms-fields/components/rich-content/rich-content-input/rich-content-common/fullscreen-modal/fullscreen-modal.st.css.js +3 -3
  71. package/dist/cjs/cms-fields/components/rich-content/rich-content-input/rich-content-common/fullscreen-modal/fullscreen-modal.st.css.js.map +1 -1
  72. package/dist/cjs/cms-fields/components/rich-content/rich-content-input/rich-content-common/publish-loader/publish-loader.st.css.js +3 -3
  73. package/dist/cjs/cms-fields/components/rich-content/rich-content-input/rich-content-common/publish-loader/publish-loader.st.css.js.map +1 -1
  74. package/dist/cjs/cms-fields/components/rich-content/rich-content-input/rich-content-common/toggle-fullscreen-button/toggle-fullscreen-button.st.css.js +2 -2
  75. package/dist/cjs/cms-fields/components/rich-content/rich-content-input/rich-content-common/toggle-fullscreen-button/toggle-fullscreen-button.st.css.js.map +1 -1
  76. package/dist/cjs/cms-fields/components/rich-content/rich-content-input/rich-content-editor/rich-content-editor.st.css.js +9 -9
  77. package/dist/cjs/cms-fields/components/rich-content/rich-content-input/rich-content-editor/rich-content-editor.st.css.js.map +1 -1
  78. package/dist/cjs/cms-fields/components/rich-content/rich-content-input/rich-content-editor/rich-content-toolbar.st.css.js +4 -4
  79. package/dist/cjs/cms-fields/components/rich-content/rich-content-input/rich-content-editor/rich-content-toolbar.st.css.js.map +1 -1
  80. package/dist/cjs/cms-fields/components/rich-content/rich-content-input/rich-content-viewer/rich-content-viewer.st.css.js +4 -4
  81. package/dist/cjs/cms-fields/components/rich-content/rich-content-input/rich-content-viewer/rich-content-viewer.st.css.js.map +1 -1
  82. package/dist/cjs/cms-fields/components/rich-text/rich-text-input/rich-text-editor/rich-editor.st.css.js +18 -18
  83. package/dist/cjs/cms-fields/components/rich-text/rich-text-input/rich-text-editor/rich-editor.st.css.js.map +1 -1
  84. package/dist/cjs/cms-fields/components/rich-text/rich-text-input/rich-text-editor/rich-text-editor.st.css.js +4 -4
  85. package/dist/cjs/cms-fields/components/rich-text/rich-text-input/rich-text-editor/rich-text-editor.st.css.js.map +1 -1
  86. package/dist/cjs/cms-fields/components/rich-text/rich-text-input/rich-text-editor/toolbar/toolbar.st.css.js +18 -18
  87. package/dist/cjs/cms-fields/components/rich-text/rich-text-input/rich-text-editor/toolbar/toolbar.st.css.js.map +1 -1
  88. package/dist/cjs/cms-fields/components/text/text-view.st.css.js +3 -3
  89. package/dist/cjs/cms-fields/components/text/text-view.st.css.js.map +1 -1
  90. package/dist/cjs/cms-fields/utils/media-item-utils.js +261 -0
  91. package/dist/cjs/cms-fields/utils/media-item-utils.js.map +1 -0
  92. package/dist/cjs/components/AutoPatternsApp/AutoPatternsApp.js +1 -1
  93. package/dist/cjs/components/AutoPatternsApp/AutoPatternsApp.js.map +1 -1
  94. package/dist/cjs/components/AutoPatternsApp/AutoPatternsAppTestPolyfills.js +5 -0
  95. package/dist/cjs/components/AutoPatternsApp/AutoPatternsAppTestPolyfills.js.map +1 -1
  96. package/dist/cjs/components/fields/MediaGallery.js +67 -0
  97. package/dist/cjs/components/fields/MediaGallery.js.map +1 -0
  98. package/dist/cjs/components/fields/index.js +5 -2
  99. package/dist/cjs/components/fields/index.js.map +1 -1
  100. package/dist/cjs/components/layouts/FormField.js +3 -2
  101. package/dist/cjs/components/layouts/FormField.js.map +1 -1
  102. package/dist/cjs/hooks/useColumns.js.map +1 -1
  103. package/dist/cjs/hooks/usePersistedState.js +24 -0
  104. package/dist/cjs/hooks/usePersistedState.js.map +1 -0
  105. package/dist/cjs/services/translations.js.map +1 -1
  106. package/dist/cjs/styles.global.css +1 -1
  107. package/dist/esm/assets/locale/messages_en.json +68 -1
  108. package/dist/esm/cms-fields/auto-cms-field-types/index.js +1 -1
  109. package/dist/esm/cms-fields/auto-cms-field-types/index.js.map +1 -1
  110. package/dist/esm/cms-fields/auto-cms-field-types/media-manager.js +3 -1
  111. package/dist/esm/cms-fields/auto-cms-field-types/media-manager.js.map +1 -1
  112. package/dist/esm/cms-fields/auto-cms-field-types/media-types.js.map +1 -1
  113. package/dist/esm/cms-fields/components/address/input/address-input.st.css.js +3 -3
  114. package/dist/esm/cms-fields/components/address/input/address-input.st.css.js.map +1 -1
  115. package/dist/esm/cms-fields/components/audio/actions/actions-menu/actions-menu.st.css.js +3 -3
  116. package/dist/esm/cms-fields/components/audio/actions/actions-menu/actions-menu.st.css.js.map +1 -1
  117. package/dist/esm/cms-fields/components/audio/audio-field/form-audio-field.st.css.js +4 -4
  118. package/dist/esm/cms-fields/components/audio/audio-field/form-audio-field.st.css.js.map +1 -1
  119. package/dist/esm/cms-fields/components/audio/audio-player/audio-player.st.css.js +2 -2
  120. package/dist/esm/cms-fields/components/audio/audio-player/audio-player.st.css.js.map +1 -1
  121. package/dist/esm/cms-fields/components/delete-dialog/delete-dialog.st.css.js +3 -3
  122. package/dist/esm/cms-fields/components/delete-dialog/delete-dialog.st.css.js.map +1 -1
  123. package/dist/esm/cms-fields/components/document/form-document-field.st.css.js +7 -7
  124. package/dist/esm/cms-fields/components/document/form-document-field.st.css.js.map +1 -1
  125. package/dist/esm/cms-fields/components/exclamation/exclamation.st.css.js +5 -5
  126. package/dist/esm/cms-fields/components/exclamation/exclamation.st.css.js.map +1 -1
  127. package/dist/esm/cms-fields/components/highlighted-text/highlighted-text.st.css.js +5 -5
  128. package/dist/esm/cms-fields/components/highlighted-text/highlighted-text.st.css.js.map +1 -1
  129. package/dist/esm/cms-fields/components/media-control/paste-url-button.st.css.js +4 -4
  130. package/dist/esm/cms-fields/components/media-control/paste-url-button.st.css.js.map +1 -1
  131. package/dist/esm/cms-fields/components/media-gallery/form-media-gallery-field.js +164 -0
  132. package/dist/esm/cms-fields/components/media-gallery/form-media-gallery-field.js.map +1 -0
  133. package/dist/esm/cms-fields/components/media-gallery/form-media-gallery-field.st.css +51 -0
  134. package/dist/esm/cms-fields/components/media-gallery/form-media-gallery-field.st.css.js +26 -0
  135. package/dist/esm/cms-fields/components/media-gallery/form-media-gallery-field.st.css.js.map +1 -0
  136. package/dist/esm/cms-fields/components/media-gallery/form-media-gallery-field.uni.driver.js +10 -0
  137. package/dist/esm/cms-fields/components/media-gallery/form-media-gallery-field.uni.driver.js.map +1 -0
  138. package/dist/esm/cms-fields/components/media-gallery/form-media-gallery-items-preview.js +110 -0
  139. package/dist/esm/cms-fields/components/media-gallery/form-media-gallery-items-preview.js.map +1 -0
  140. package/dist/esm/cms-fields/components/media-gallery/media-gallery-dialog/add-link-modal.js +106 -0
  141. package/dist/esm/cms-fields/components/media-gallery/media-gallery-dialog/add-link-modal.js.map +1 -0
  142. package/dist/esm/cms-fields/components/media-gallery/media-gallery-dialog/add-media-button.js +25 -0
  143. package/dist/esm/cms-fields/components/media-gallery/media-gallery-dialog/add-media-button.js.map +1 -0
  144. package/dist/esm/cms-fields/components/media-gallery/media-gallery-dialog/content-keys.js +40 -0
  145. package/dist/esm/cms-fields/components/media-gallery/media-gallery-dialog/content-keys.js.map +1 -0
  146. package/dist/esm/cms-fields/components/media-gallery/media-gallery-dialog/hooks.js +81 -0
  147. package/dist/esm/cms-fields/components/media-gallery/media-gallery-dialog/hooks.js.map +1 -0
  148. package/dist/esm/cms-fields/components/media-gallery/media-gallery-dialog/item-actions.js +37 -0
  149. package/dist/esm/cms-fields/components/media-gallery/media-gallery-dialog/item-actions.js.map +1 -0
  150. package/dist/esm/cms-fields/components/media-gallery/media-gallery-dialog/media-gallery-dialog.js +152 -0
  151. package/dist/esm/cms-fields/components/media-gallery/media-gallery-dialog/media-gallery-dialog.js.map +1 -0
  152. package/dist/esm/cms-fields/components/media-gallery/media-gallery-dialog/no-items-view.js +34 -0
  153. package/dist/esm/cms-fields/components/media-gallery/media-gallery-dialog/no-items-view.js.map +1 -0
  154. package/dist/esm/cms-fields/components/media-gallery/media-gallery-dialog/types.js +2 -0
  155. package/dist/esm/cms-fields/components/media-gallery/media-gallery-dialog/types.js.map +1 -0
  156. package/dist/esm/cms-fields/components/media-gallery/media-gallery-dialog/use-add-link-modal.js +19 -0
  157. package/dist/esm/cms-fields/components/media-gallery/media-gallery-dialog/use-add-link-modal.js.map +1 -0
  158. package/dist/esm/cms-fields/components/media-gallery/media-gallery-dialog/utils.js +288 -0
  159. package/dist/esm/cms-fields/components/media-gallery/media-gallery-dialog/utils.js.map +1 -0
  160. package/dist/esm/cms-fields/components/media-gallery/media-preview-modal.js +147 -0
  161. package/dist/esm/cms-fields/components/media-gallery/media-preview-modal.js.map +1 -0
  162. package/dist/esm/cms-fields/components/media-image/media-image.st.css.js +4 -4
  163. package/dist/esm/cms-fields/components/media-image/media-image.st.css.js.map +1 -1
  164. package/dist/esm/cms-fields/components/media-loader/media-loader.st.css.js +3 -3
  165. package/dist/esm/cms-fields/components/media-loader/media-loader.st.css.js.map +1 -1
  166. package/dist/esm/cms-fields/components/media-tag/web-media-tag/media-tag.st.css.js +2 -2
  167. package/dist/esm/cms-fields/components/media-tag/web-media-tag/media-tag.st.css.js.map +1 -1
  168. package/dist/esm/cms-fields/components/multi-document/multi-document-input/form-multi-document.st.css.js +5 -5
  169. package/dist/esm/cms-fields/components/multi-document/multi-document-input/form-multi-document.st.css.js.map +1 -1
  170. package/dist/esm/cms-fields/components/rich-content/rich-content-input/default-value-input/rich-content-default-value-input.st.css.js +6 -6
  171. package/dist/esm/cms-fields/components/rich-content/rich-content-input/default-value-input/rich-content-default-value-input.st.css.js.map +1 -1
  172. package/dist/esm/cms-fields/components/rich-content/rich-content-input/form-input/rich-content-form-input.st.css.js +5 -5
  173. package/dist/esm/cms-fields/components/rich-content/rich-content-input/form-input/rich-content-form-input.st.css.js.map +1 -1
  174. package/dist/esm/cms-fields/components/rich-content/rich-content-input/form-read-only-input/rich-content-form-read-only-input.st.css.js +2 -2
  175. package/dist/esm/cms-fields/components/rich-content/rich-content-input/form-read-only-input/rich-content-form-read-only-input.st.css.js.map +1 -1
  176. package/dist/esm/cms-fields/components/rich-content/rich-content-input/rich-content-common/fullscreen-modal/fullscreen-modal.st.css.js +3 -3
  177. package/dist/esm/cms-fields/components/rich-content/rich-content-input/rich-content-common/fullscreen-modal/fullscreen-modal.st.css.js.map +1 -1
  178. package/dist/esm/cms-fields/components/rich-content/rich-content-input/rich-content-common/publish-loader/publish-loader.st.css.js +3 -3
  179. package/dist/esm/cms-fields/components/rich-content/rich-content-input/rich-content-common/publish-loader/publish-loader.st.css.js.map +1 -1
  180. package/dist/esm/cms-fields/components/rich-content/rich-content-input/rich-content-common/toggle-fullscreen-button/toggle-fullscreen-button.st.css.js +2 -2
  181. package/dist/esm/cms-fields/components/rich-content/rich-content-input/rich-content-common/toggle-fullscreen-button/toggle-fullscreen-button.st.css.js.map +1 -1
  182. package/dist/esm/cms-fields/components/rich-content/rich-content-input/rich-content-editor/rich-content-editor.st.css.js +9 -9
  183. package/dist/esm/cms-fields/components/rich-content/rich-content-input/rich-content-editor/rich-content-editor.st.css.js.map +1 -1
  184. package/dist/esm/cms-fields/components/rich-content/rich-content-input/rich-content-editor/rich-content-toolbar.st.css.js +4 -4
  185. package/dist/esm/cms-fields/components/rich-content/rich-content-input/rich-content-editor/rich-content-toolbar.st.css.js.map +1 -1
  186. package/dist/esm/cms-fields/components/rich-content/rich-content-input/rich-content-viewer/rich-content-viewer.st.css.js +4 -4
  187. package/dist/esm/cms-fields/components/rich-content/rich-content-input/rich-content-viewer/rich-content-viewer.st.css.js.map +1 -1
  188. package/dist/esm/cms-fields/components/rich-text/rich-text-input/rich-text-editor/rich-editor.st.css.js +18 -18
  189. package/dist/esm/cms-fields/components/rich-text/rich-text-input/rich-text-editor/rich-editor.st.css.js.map +1 -1
  190. package/dist/esm/cms-fields/components/rich-text/rich-text-input/rich-text-editor/rich-text-editor.st.css.js +4 -4
  191. package/dist/esm/cms-fields/components/rich-text/rich-text-input/rich-text-editor/rich-text-editor.st.css.js.map +1 -1
  192. package/dist/esm/cms-fields/components/rich-text/rich-text-input/rich-text-editor/toolbar/toolbar.st.css.js +18 -18
  193. package/dist/esm/cms-fields/components/rich-text/rich-text-input/rich-text-editor/toolbar/toolbar.st.css.js.map +1 -1
  194. package/dist/esm/cms-fields/components/text/text-view.st.css.js +3 -3
  195. package/dist/esm/cms-fields/components/text/text-view.st.css.js.map +1 -1
  196. package/dist/esm/cms-fields/utils/media-item-utils.js +261 -0
  197. package/dist/esm/cms-fields/utils/media-item-utils.js.map +1 -0
  198. package/dist/esm/components/AutoPatternsApp/AutoPatternsApp.js +1 -1
  199. package/dist/esm/components/AutoPatternsApp/AutoPatternsApp.js.map +1 -1
  200. package/dist/esm/components/AutoPatternsApp/AutoPatternsAppTestPolyfills.js +5 -0
  201. package/dist/esm/components/AutoPatternsApp/AutoPatternsAppTestPolyfills.js.map +1 -1
  202. package/dist/esm/components/fields/MediaGallery.js +48 -0
  203. package/dist/esm/components/fields/MediaGallery.js.map +1 -0
  204. package/dist/esm/components/fields/index.js +1 -0
  205. package/dist/esm/components/fields/index.js.map +1 -1
  206. package/dist/esm/components/layouts/FormField.js +3 -2
  207. package/dist/esm/components/layouts/FormField.js.map +1 -1
  208. package/dist/esm/hooks/useColumns.js +1 -1
  209. package/dist/esm/hooks/useColumns.js.map +1 -1
  210. package/dist/esm/hooks/usePersistedState.js +20 -0
  211. package/dist/esm/hooks/usePersistedState.js.map +1 -0
  212. package/dist/esm/services/translations.js.map +1 -1
  213. package/dist/esm/styles.global.css +1 -1
  214. package/dist/types/cms-fields/auto-cms-field-types/index.d.ts +2 -2
  215. package/dist/types/cms-fields/auto-cms-field-types/index.d.ts.map +1 -1
  216. package/dist/types/cms-fields/auto-cms-field-types/media-manager.d.ts +2 -0
  217. package/dist/types/cms-fields/auto-cms-field-types/media-manager.d.ts.map +1 -1
  218. package/dist/types/cms-fields/auto-cms-field-types/media-types.d.ts +1 -1
  219. package/dist/types/cms-fields/auto-cms-field-types/media-types.d.ts.map +1 -1
  220. package/dist/types/cms-fields/components/audio/audio-field/form-audio-field.st.css.d.ts.map +1 -1
  221. package/dist/types/cms-fields/components/document/form-document-field.st.css.d.ts.map +1 -1
  222. package/dist/types/cms-fields/components/media-gallery/form-media-gallery-field.d.ts +13 -0
  223. package/dist/types/cms-fields/components/media-gallery/form-media-gallery-field.d.ts.map +1 -0
  224. package/dist/types/cms-fields/components/media-gallery/form-media-gallery-field.st.css.d.ts +21 -0
  225. package/dist/types/cms-fields/components/media-gallery/form-media-gallery-field.st.css.d.ts.map +1 -0
  226. package/dist/types/cms-fields/components/media-gallery/form-media-gallery-field.uni.driver.d.ts +33 -0
  227. package/dist/types/cms-fields/components/media-gallery/form-media-gallery-field.uni.driver.d.ts.map +1 -0
  228. package/dist/types/cms-fields/components/media-gallery/form-media-gallery-items-preview.d.ts +8 -0
  229. package/dist/types/cms-fields/components/media-gallery/form-media-gallery-items-preview.d.ts.map +1 -0
  230. package/dist/types/cms-fields/components/media-gallery/media-gallery-dialog/add-link-modal.d.ts +11 -0
  231. package/dist/types/cms-fields/components/media-gallery/media-gallery-dialog/add-link-modal.d.ts.map +1 -0
  232. package/dist/types/cms-fields/components/media-gallery/media-gallery-dialog/add-media-button.d.ts +7 -0
  233. package/dist/types/cms-fields/components/media-gallery/media-gallery-dialog/add-media-button.d.ts.map +1 -0
  234. package/dist/types/cms-fields/components/media-gallery/media-gallery-dialog/content-keys.d.ts +41 -0
  235. package/dist/types/cms-fields/components/media-gallery/media-gallery-dialog/content-keys.d.ts.map +1 -0
  236. package/dist/types/cms-fields/components/media-gallery/media-gallery-dialog/hooks.d.ts +66 -0
  237. package/dist/types/cms-fields/components/media-gallery/media-gallery-dialog/hooks.d.ts.map +1 -0
  238. package/dist/types/cms-fields/components/media-gallery/media-gallery-dialog/item-actions.d.ts +8 -0
  239. package/dist/types/cms-fields/components/media-gallery/media-gallery-dialog/item-actions.d.ts.map +1 -0
  240. package/dist/types/cms-fields/components/media-gallery/media-gallery-dialog/media-gallery-dialog.d.ts +5 -0
  241. package/dist/types/cms-fields/components/media-gallery/media-gallery-dialog/media-gallery-dialog.d.ts.map +1 -0
  242. package/dist/types/cms-fields/components/media-gallery/media-gallery-dialog/no-items-view.d.ts +7 -0
  243. package/dist/types/cms-fields/components/media-gallery/media-gallery-dialog/no-items-view.d.ts.map +1 -0
  244. package/dist/types/cms-fields/components/media-gallery/media-gallery-dialog/types.d.ts +81 -0
  245. package/dist/types/cms-fields/components/media-gallery/media-gallery-dialog/types.d.ts.map +1 -0
  246. package/dist/types/cms-fields/components/media-gallery/media-gallery-dialog/use-add-link-modal.d.ts +10 -0
  247. package/dist/types/cms-fields/components/media-gallery/media-gallery-dialog/use-add-link-modal.d.ts.map +1 -0
  248. package/dist/types/cms-fields/components/media-gallery/media-gallery-dialog/utils.d.ts +23 -0
  249. package/dist/types/cms-fields/components/media-gallery/media-gallery-dialog/utils.d.ts.map +1 -0
  250. package/dist/types/cms-fields/components/media-gallery/media-preview-modal.d.ts +19 -0
  251. package/dist/types/cms-fields/components/media-gallery/media-preview-modal.d.ts.map +1 -0
  252. package/dist/types/cms-fields/components/rich-content/rich-content-input/form-input/rich-content-form-input.st.css.d.ts.map +1 -1
  253. package/dist/types/cms-fields/components/rich-content/rich-content-input/form-read-only-input/rich-content-form-read-only-input.st.css.d.ts.map +1 -1
  254. package/dist/types/cms-fields/components/rich-content/rich-content-input/rich-content-common/fullscreen-modal/fullscreen-modal.st.css.d.ts.map +1 -1
  255. package/dist/types/cms-fields/utils/media-item-utils.d.ts +61 -0
  256. package/dist/types/cms-fields/utils/media-item-utils.d.ts.map +1 -0
  257. package/dist/types/components/fields/MediaGallery.d.ts +8 -0
  258. package/dist/types/components/fields/MediaGallery.d.ts.map +1 -0
  259. package/dist/types/components/fields/index.d.ts +1 -0
  260. package/dist/types/components/fields/index.d.ts.map +1 -1
  261. package/dist/types/components/layouts/FormField.d.ts.map +1 -1
  262. package/dist/types/hooks/usePersistedState.d.ts +2 -0
  263. package/dist/types/hooks/usePersistedState.d.ts.map +1 -0
  264. package/dist/types/services/translations.d.ts +4 -1
  265. package/dist/types/services/translations.d.ts.map +1 -1
  266. package/package.json +5 -5
@@ -0,0 +1 @@
1
+ {"version":3,"names":["React","useCallback","useEffect","useState","Modal","CustomModalLayout","BounceAnimation","Box","FormField","Input","RadioGroup","useTranslations","LinkTarget","AddLinkModal","_ref","isOpen","onClose","link","onSave","mediaType","t","url","setUrl","target","setTarget","error","setError","animateUrlError","setAnimateUrlError","handleOnSave","normalizedUrl","normalizeUrl","isValidUrl","text","undefined","onEndAnimateUrlError","createElement","onRequestClose","screen","title","subtitle","onCloseButtonClick","primaryButtonText","primaryButtonOnClick","secondaryButtonText","secondaryButtonOnClick","width","content","direction","gap","active","onEnd","required","label","status","statusMessage","value","onChange","e","placeholder","Radio","newTab","currentTab","trimmed","trim","test","URL"],"sources":["../../../../../../src/cms-fields/components/media-gallery/media-gallery-dialog/add-link-modal.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useState } from 'react';\nimport {\n Modal,\n CustomModalLayout,\n BounceAnimation,\n Box,\n FormField,\n Input,\n RadioGroup,\n} from '@wix/design-system';\nimport { useTranslations } from '../../../hooks';\nimport type { OrganizeMediaItem, OrganizeMediaItemLink } from './types';\n\nenum LinkTarget {\n newTab = '_blank',\n currentTab = '_self',\n}\n\nexport interface AddLinkModalProps {\n mediaType?: OrganizeMediaItem['dataType'];\n link?: OrganizeMediaItemLink;\n onSave: (link?: OrganizeMediaItemLink) => void;\n isOpen: boolean;\n onClose: () => void;\n}\n\nexport const AddLinkModal: React.FC<AddLinkModalProps> = ({\n isOpen,\n onClose,\n link,\n onSave,\n mediaType,\n}) => {\n const { t } = useTranslations();\n\n const [url, setUrl] = useState(link?.url ?? '');\n const [target, setTarget] = useState<string>(link?.target ?? '_blank');\n const [error, setError] = useState(false);\n const [animateUrlError, setAnimateUrlError] = useState(false);\n\n useEffect(() => {\n setUrl(link?.url ?? '');\n setTarget(link?.target ?? '_blank');\n setError(false);\n setAnimateUrlError(false);\n }, [link, isOpen]);\n\n const handleOnSave = useCallback(() => {\n const normalizedUrl = normalizeUrl(url);\n if (normalizedUrl && !isValidUrl(normalizedUrl)) {\n setError(true);\n setAnimateUrlError(true);\n return;\n }\n onSave(\n normalizedUrl\n ? {\n url: normalizedUrl,\n text: normalizedUrl,\n target: target as '_blank' | '_self',\n }\n : undefined,\n );\n onClose();\n }, [url, target, onSave, onClose]);\n\n const onEndAnimateUrlError = useCallback(() => setAnimateUrlError(false), []);\n\n return (\n <Modal isOpen={isOpen} onRequestClose={onClose} screen=\"desktop\">\n <CustomModalLayout\n title={\n mediaType === 'Video'\n ? t('CMS.mediaGallery.addLink.titleVideo')\n : t('CMS.mediaGallery.addLink.titleImage')\n }\n subtitle={\n mediaType === 'Video'\n ? t('CMS.mediaGallery.addLink.subtitleVideo')\n : t('CMS.mediaGallery.addLink.subtitleImage')\n }\n onCloseButtonClick={onClose}\n primaryButtonText={t('CMS.mediaGallery.addLink.save')}\n primaryButtonOnClick={handleOnSave}\n secondaryButtonText={t('CMS.mediaGallery.addLink.cancel')}\n secondaryButtonOnClick={onClose}\n width=\"600px\"\n content={\n <Box direction=\"vertical\" gap=\"SP2\">\n <BounceAnimation\n active={animateUrlError}\n onEnd={onEndAnimateUrlError}\n >\n <FormField\n required\n label={t('CMS.mediaGallery.addLink.urlLabel')}\n status={error ? 'error' : undefined}\n statusMessage={\n error ? t('CMS.mediaGallery.addLink.invalidUrl') : undefined\n }\n >\n <Input\n value={url}\n onChange={(e) => {\n setUrl(e.target.value);\n setError(false);\n }}\n placeholder=\"https://\"\n />\n </FormField>\n </BounceAnimation>\n <FormField label={t('CMS.mediaGallery.addLink.targetLabel')}>\n <RadioGroup\n value={target}\n onChange={(value) => setTarget(value as string)}\n >\n <RadioGroup.Radio value={LinkTarget.newTab}>\n {t('CMS.mediaGallery.addLink.newTab')}\n </RadioGroup.Radio>\n <RadioGroup.Radio value={LinkTarget.currentTab}>\n {t('CMS.mediaGallery.addLink.currentTab')}\n </RadioGroup.Radio>\n </RadioGroup>\n </FormField>\n </Box>\n }\n />\n </Modal>\n );\n};\n\nfunction normalizeUrl(url: string): string {\n const trimmed = url.trim();\n if (!trimmed) {\n return '';\n }\n if (/^https?:\\/\\//i.test(trimmed)) {\n return trimmed;\n }\n return `https://${trimmed}`;\n}\n\nfunction isValidUrl(url: string): boolean {\n try {\n new URL(url);\n return true;\n } catch {\n return false;\n }\n}\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,25 @@
1
+ import React from 'react';
2
+ import { Button, Loader } from '@wix/design-system';
3
+ import { Add as AddIcon } from '@wix/wix-ui-icons-common';
4
+ import { useTranslations } from '../../../hooks';
5
+ import { useAddMediaControl } from './hooks';
6
+ export const AddMediaButton = _ref => {
7
+ let {
8
+ onAddMedia
9
+ } = _ref;
10
+ const {
11
+ t
12
+ } = useTranslations();
13
+ const {
14
+ onOpen,
15
+ isLoading
16
+ } = useAddMediaControl(onAddMedia);
17
+ return /*#__PURE__*/React.createElement(Button, {
18
+ prefixIcon: isLoading ? undefined : /*#__PURE__*/React.createElement(AddIcon, null),
19
+ onClick: onOpen,
20
+ dataHook: "media-gallery-add-media-button"
21
+ }, isLoading ? /*#__PURE__*/React.createElement(Loader, {
22
+ size: "tiny"
23
+ }) : t('CMS.mediaGallery.addMedia'));
24
+ };
25
+ //# sourceMappingURL=add-media-button.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["React","Button","Loader","Add","AddIcon","useTranslations","useAddMediaControl","AddMediaButton","_ref","onAddMedia","t","onOpen","isLoading","createElement","prefixIcon","undefined","onClick","dataHook","size"],"sources":["../../../../../../src/cms-fields/components/media-gallery/media-gallery-dialog/add-media-button.tsx"],"sourcesContent":["import React from 'react';\nimport { Button, Loader } from '@wix/design-system';\nimport { Add as AddIcon } from '@wix/wix-ui-icons-common';\nimport { useTranslations } from '../../../hooks';\nimport { useAddMediaControl } from './hooks';\nimport type { OrganizeMediaItem } from './types';\n\nexport interface AddMediaButtonProps {\n onAddMedia: (items: OrganizeMediaItem[]) => void;\n}\n\nexport const AddMediaButton: React.FC<AddMediaButtonProps> = ({\n onAddMedia,\n}) => {\n const { t } = useTranslations();\n const { onOpen, isLoading } = useAddMediaControl(onAddMedia);\n\n return (\n <Button\n prefixIcon={isLoading ? undefined : <AddIcon />}\n onClick={onOpen}\n dataHook=\"media-gallery-add-media-button\"\n >\n {isLoading ? <Loader size=\"tiny\" /> : t('CMS.mediaGallery.addMedia')}\n </Button>\n );\n};\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,MAAM,EAAEC,MAAM,QAAQ,oBAAoB;AACnD,SAASC,GAAG,IAAIC,OAAO,QAAQ,0BAA0B;AACzD,SAASC,eAAe,QAAQ,gBAAgB;AAChD,SAASC,kBAAkB,QAAQ,SAAS;AAO5C,OAAO,MAAMC,cAA6C,GAAGC,IAAA,IAEvD;EAAA,IAFwD;IAC5DC;EACF,CAAC,GAAAD,IAAA;EACC,MAAM;IAAEE;EAAE,CAAC,GAAGL,eAAe,CAAC,CAAC;EAC/B,MAAM;IAAEM,MAAM;IAAEC;EAAU,CAAC,GAAGN,kBAAkB,CAACG,UAAU,CAAC;EAE5D,oBACET,KAAA,CAAAa,aAAA,CAACZ,MAAM;IACLa,UAAU,EAAEF,SAAS,GAAGG,SAAS,gBAAGf,KAAA,CAAAa,aAAA,CAACT,OAAO,MAAE,CAAE;IAChDY,OAAO,EAAEL,MAAO;IAChBM,QAAQ,EAAC;EAAgC,GAExCL,SAAS,gBAAGZ,KAAA,CAAAa,aAAA,CAACX,MAAM;IAACgB,IAAI,EAAC;EAAM,CAAE,CAAC,GAAGR,CAAC,CAAC,2BAA2B,CAC7D,CAAC;AAEb,CAAC","ignoreList":[]}
@@ -0,0 +1,40 @@
1
+ export default {
2
+ emptySearchResultsTitle: 'CMS.mediaGallery.dialog.emptySearchResultsTitle',
3
+ emptySearchResultsSubtitle: 'CMS.mediaGallery.dialog.emptySearchResultsSubtitle',
4
+ modalDone: 'CMS.mediaGallery.dialog.modalDone',
5
+ modalTitle: 'CMS.mediaGallery.dialog.modalTitle',
6
+ selectionSelectAll: 'CMS.mediaGallery.dialog.selectionSelectAll',
7
+ selectionDeselectAll: 'CMS.mediaGallery.dialog.selectionDeselectAll',
8
+ selectionDelete: 'CMS.mediaGallery.dialog.selectionDelete',
9
+ selectionSelected: 'CMS.mediaGallery.dialog.selectionSelected',
10
+ sortLabel: 'CMS.mediaGallery.dialog.sortLabel',
11
+ sortByTitleAsc: 'CMS.mediaGallery.dialog.sortByTitleAsc',
12
+ sortByTitleDesc: 'CMS.mediaGallery.dialog.sortByTitleDesc',
13
+ sortByFilenameAsc: 'CMS.mediaGallery.dialog.sortByFilenameAsc',
14
+ sortByFilenameDesc: 'CMS.mediaGallery.dialog.sortByFilenameDesc',
15
+ searchPlaceholder: 'CMS.mediaGallery.dialog.searchPlaceholder',
16
+ settingsTitle: 'CMS.mediaGallery.dialog.settingsTitle',
17
+ settingsNewItemsDirectionLabel: 'CMS.mediaGallery.dialog.settingsNewItemsDirectionLabel',
18
+ settingsNewItemsDirectionStart: 'CMS.mediaGallery.dialog.settingsNewItemsDirectionStart',
19
+ settingsNewItemsDirectionEnd: 'CMS.mediaGallery.dialog.settingsNewItemsDirectionEnd',
20
+ settingsNewItemsTitleLabel: 'CMS.mediaGallery.dialog.settingsNewItemsTitleLabel',
21
+ settingsNewItemsTitleEmpty: 'CMS.mediaGallery.dialog.settingsNewItemsTitleEmpty',
22
+ settingsNewItemsTitleFilename: 'CMS.mediaGallery.dialog.settingsNewItemsTitleFilename',
23
+ itemTitleLabel: 'CMS.mediaGallery.dialog.itemTitleLabel',
24
+ itemTitlePlaceholder: 'CMS.mediaGallery.dialog.itemTitlePlaceholder',
25
+ itemDescriptionLabel: 'CMS.mediaGallery.dialog.itemDescriptionLabel',
26
+ itemDescriptionPlaceholder: 'CMS.mediaGallery.dialog.itemDescriptionPlaceholder',
27
+ itemAltLabel: 'CMS.mediaGallery.dialog.itemAltLabel',
28
+ itemAltTooltip: 'CMS.mediaGallery.dialog.itemAltTooltip',
29
+ itemAltPlaceholder: 'CMS.mediaGallery.dialog.itemAltPlaceholder',
30
+ itemDeleteTooltip: 'CMS.mediaGallery.dialog.itemDeleteTooltip',
31
+ itemFocalPointTooltip: 'CMS.mediaGallery.dialog.itemFocalPointTooltip',
32
+ masonryLayoutTooltip: 'CMS.mediaGallery.dialog.masonryLayoutTooltip',
33
+ gridLayoutTooltip: 'CMS.mediaGallery.dialog.gridLayoutTooltip',
34
+ modalDoneEmpty: 'CMS.mediaGallery.dialog.modalDoneEmpty',
35
+ externalLinkLabel: 'CMS.mediaGallery.dialog.externalLinkLabel',
36
+ externalLinkButtonEdit: 'CMS.mediaGallery.dialog.externalLinkButtonEdit',
37
+ externalLinkButtonAdd: 'CMS.mediaGallery.dialog.externalLinkButtonAdd',
38
+ externalLinkTextPlaceholder: 'CMS.mediaGallery.dialog.externalLinkTextPlaceholder'
39
+ };
40
+ //# sourceMappingURL=content-keys.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["emptySearchResultsTitle","emptySearchResultsSubtitle","modalDone","modalTitle","selectionSelectAll","selectionDeselectAll","selectionDelete","selectionSelected","sortLabel","sortByTitleAsc","sortByTitleDesc","sortByFilenameAsc","sortByFilenameDesc","searchPlaceholder","settingsTitle","settingsNewItemsDirectionLabel","settingsNewItemsDirectionStart","settingsNewItemsDirectionEnd","settingsNewItemsTitleLabel","settingsNewItemsTitleEmpty","settingsNewItemsTitleFilename","itemTitleLabel","itemTitlePlaceholder","itemDescriptionLabel","itemDescriptionPlaceholder","itemAltLabel","itemAltTooltip","itemAltPlaceholder","itemDeleteTooltip","itemFocalPointTooltip","masonryLayoutTooltip","gridLayoutTooltip","modalDoneEmpty","externalLinkLabel","externalLinkButtonEdit","externalLinkButtonAdd","externalLinkTextPlaceholder"],"sources":["../../../../../../src/cms-fields/components/media-gallery/media-gallery-dialog/content-keys.ts"],"sourcesContent":["export default {\n emptySearchResultsTitle: 'CMS.mediaGallery.dialog.emptySearchResultsTitle',\n emptySearchResultsSubtitle:\n 'CMS.mediaGallery.dialog.emptySearchResultsSubtitle',\n modalDone: 'CMS.mediaGallery.dialog.modalDone',\n modalTitle: 'CMS.mediaGallery.dialog.modalTitle',\n selectionSelectAll: 'CMS.mediaGallery.dialog.selectionSelectAll',\n selectionDeselectAll: 'CMS.mediaGallery.dialog.selectionDeselectAll',\n selectionDelete: 'CMS.mediaGallery.dialog.selectionDelete',\n selectionSelected: 'CMS.mediaGallery.dialog.selectionSelected',\n sortLabel: 'CMS.mediaGallery.dialog.sortLabel',\n sortByTitleAsc: 'CMS.mediaGallery.dialog.sortByTitleAsc',\n sortByTitleDesc: 'CMS.mediaGallery.dialog.sortByTitleDesc',\n sortByFilenameAsc: 'CMS.mediaGallery.dialog.sortByFilenameAsc',\n sortByFilenameDesc: 'CMS.mediaGallery.dialog.sortByFilenameDesc',\n searchPlaceholder: 'CMS.mediaGallery.dialog.searchPlaceholder',\n settingsTitle: 'CMS.mediaGallery.dialog.settingsTitle',\n settingsNewItemsDirectionLabel:\n 'CMS.mediaGallery.dialog.settingsNewItemsDirectionLabel',\n settingsNewItemsDirectionStart:\n 'CMS.mediaGallery.dialog.settingsNewItemsDirectionStart',\n settingsNewItemsDirectionEnd:\n 'CMS.mediaGallery.dialog.settingsNewItemsDirectionEnd',\n settingsNewItemsTitleLabel:\n 'CMS.mediaGallery.dialog.settingsNewItemsTitleLabel',\n settingsNewItemsTitleEmpty:\n 'CMS.mediaGallery.dialog.settingsNewItemsTitleEmpty',\n settingsNewItemsTitleFilename:\n 'CMS.mediaGallery.dialog.settingsNewItemsTitleFilename',\n itemTitleLabel: 'CMS.mediaGallery.dialog.itemTitleLabel',\n itemTitlePlaceholder: 'CMS.mediaGallery.dialog.itemTitlePlaceholder',\n itemDescriptionLabel: 'CMS.mediaGallery.dialog.itemDescriptionLabel',\n itemDescriptionPlaceholder:\n 'CMS.mediaGallery.dialog.itemDescriptionPlaceholder',\n itemAltLabel: 'CMS.mediaGallery.dialog.itemAltLabel',\n itemAltTooltip: 'CMS.mediaGallery.dialog.itemAltTooltip',\n itemAltPlaceholder: 'CMS.mediaGallery.dialog.itemAltPlaceholder',\n itemDeleteTooltip: 'CMS.mediaGallery.dialog.itemDeleteTooltip',\n itemFocalPointTooltip: 'CMS.mediaGallery.dialog.itemFocalPointTooltip',\n masonryLayoutTooltip: 'CMS.mediaGallery.dialog.masonryLayoutTooltip',\n gridLayoutTooltip: 'CMS.mediaGallery.dialog.gridLayoutTooltip',\n modalDoneEmpty: 'CMS.mediaGallery.dialog.modalDoneEmpty',\n externalLinkLabel: 'CMS.mediaGallery.dialog.externalLinkLabel',\n externalLinkButtonEdit: 'CMS.mediaGallery.dialog.externalLinkButtonEdit',\n externalLinkButtonAdd: 'CMS.mediaGallery.dialog.externalLinkButtonAdd',\n externalLinkTextPlaceholder:\n 'CMS.mediaGallery.dialog.externalLinkTextPlaceholder',\n};\n"],"mappings":"AAAA,eAAe;EACbA,uBAAuB,EAAE,iDAAiD;EAC1EC,0BAA0B,EACxB,oDAAoD;EACtDC,SAAS,EAAE,mCAAmC;EAC9CC,UAAU,EAAE,oCAAoC;EAChDC,kBAAkB,EAAE,4CAA4C;EAChEC,oBAAoB,EAAE,8CAA8C;EACpEC,eAAe,EAAE,yCAAyC;EAC1DC,iBAAiB,EAAE,2CAA2C;EAC9DC,SAAS,EAAE,mCAAmC;EAC9CC,cAAc,EAAE,wCAAwC;EACxDC,eAAe,EAAE,yCAAyC;EAC1DC,iBAAiB,EAAE,2CAA2C;EAC9DC,kBAAkB,EAAE,4CAA4C;EAChEC,iBAAiB,EAAE,2CAA2C;EAC9DC,aAAa,EAAE,uCAAuC;EACtDC,8BAA8B,EAC5B,wDAAwD;EAC1DC,8BAA8B,EAC5B,wDAAwD;EAC1DC,4BAA4B,EAC1B,sDAAsD;EACxDC,0BAA0B,EACxB,oDAAoD;EACtDC,0BAA0B,EACxB,oDAAoD;EACtDC,6BAA6B,EAC3B,uDAAuD;EACzDC,cAAc,EAAE,wCAAwC;EACxDC,oBAAoB,EAAE,8CAA8C;EACpEC,oBAAoB,EAAE,8CAA8C;EACpEC,0BAA0B,EACxB,oDAAoD;EACtDC,YAAY,EAAE,sCAAsC;EACpDC,cAAc,EAAE,wCAAwC;EACxDC,kBAAkB,EAAE,4CAA4C;EAChEC,iBAAiB,EAAE,2CAA2C;EAC9DC,qBAAqB,EAAE,+CAA+C;EACtEC,oBAAoB,EAAE,8CAA8C;EACpEC,iBAAiB,EAAE,2CAA2C;EAC9DC,cAAc,EAAE,wCAAwC;EACxDC,iBAAiB,EAAE,2CAA2C;EAC9DC,sBAAsB,EAAE,gDAAgD;EACxEC,qBAAqB,EAAE,+CAA+C;EACtEC,2BAA2B,EACzB;AACJ,CAAC","ignoreList":[]}
@@ -0,0 +1,81 @@
1
+ import { useCallback, useMemo, useState } from 'react';
2
+ import { useMediaControl } from '../../media-control';
3
+ import { MEDIA_TYPES } from '../../../utils/media-utils';
4
+ import { convertMediaControlItemToOrganizeMediaItem } from './utils';
5
+ import contentKeys from './content-keys';
6
+ export const useMediaGalleryDialog = _ref => {
7
+ let {
8
+ initialOpen,
9
+ items,
10
+ ...rest
11
+ } = _ref;
12
+ const [isOpen, setIsOpen] = useState(Boolean(initialOpen));
13
+ const openMediaGalleryDialog = useCallback(() => setIsOpen(true), []);
14
+ const mediaGalleryDialogItems = useMemo(() => items || [], [items]);
15
+ const onMediaGalleryDialogClose = useCallback(() => {
16
+ setIsOpen(false);
17
+ rest.onClose == null || rest.onClose();
18
+ }, [rest.onClose]);
19
+ return {
20
+ openMediaGalleryDialog,
21
+ isOpen,
22
+ onClose: onMediaGalleryDialogClose,
23
+ items: mediaGalleryDialogItems,
24
+ ...rest
25
+ };
26
+ };
27
+
28
+ /**
29
+ * Opens media manager (multi-select) to add new items to the gallery.
30
+ *
31
+ * Note: In cms-web, defaultNewItemName flows from Redux into this hook.
32
+ * In auto-cairo, we don't have Redux for preferences, so the conversion
33
+ * always uses mediaId for `name`. The dialog's `onAddMedia` callback
34
+ * handles the EMPTY case by calling `setItemsEmptyTitles`.
35
+ */
36
+ export const useAddMediaControl = onAddMedia => {
37
+ const onChange = useCallback(value => {
38
+ onAddMedia == null || onAddMedia(value.map(val => convertMediaControlItemToOrganizeMediaItem(val)).filter(Boolean));
39
+ }, [onAddMedia]);
40
+ const {
41
+ callMedia,
42
+ loading
43
+ } = useMediaControl({
44
+ multiSelect: true,
45
+ mediaType: MEDIA_TYPES.GALLERY,
46
+ onChange
47
+ });
48
+ return {
49
+ onOpen: useCallback(() => callMedia(), [callMedia]),
50
+ isLoading: loading
51
+ };
52
+ };
53
+
54
+ /** Opens media manager (single-select) to replace one item */
55
+ export const useReplaceMediaControl = onMediaReplaced => {
56
+ const onChange = useCallback(value => {
57
+ const newItem = convertMediaControlItemToOrganizeMediaItem(value);
58
+ if (newItem) {
59
+ onMediaReplaced == null || onMediaReplaced(newItem);
60
+ }
61
+ }, [onMediaReplaced]);
62
+ const {
63
+ callMedia,
64
+ loading
65
+ } = useMediaControl({
66
+ multiSelect: false,
67
+ mediaType: MEDIA_TYPES.ALL_MEDIA,
68
+ onChange
69
+ });
70
+ return {
71
+ onOpen: useCallback(() => callMedia(), [callMedia]),
72
+ isLoading: loading
73
+ };
74
+ };
75
+
76
+ /** Product requirement: show different text on Done button if there are no items yet */
77
+ export const useContentKeys = items => useMemo(() => ({
78
+ ...contentKeys,
79
+ modalDone: items.length === 0 ? contentKeys.modalDoneEmpty : contentKeys.modalDone
80
+ }), [items]);
81
+ //# sourceMappingURL=hooks.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["useCallback","useMemo","useState","useMediaControl","MEDIA_TYPES","convertMediaControlItemToOrganizeMediaItem","contentKeys","useMediaGalleryDialog","_ref","initialOpen","items","rest","isOpen","setIsOpen","Boolean","openMediaGalleryDialog","mediaGalleryDialogItems","onMediaGalleryDialogClose","onClose","useAddMediaControl","onAddMedia","onChange","value","map","val","filter","callMedia","loading","multiSelect","mediaType","GALLERY","onOpen","isLoading","useReplaceMediaControl","onMediaReplaced","newItem","ALL_MEDIA","useContentKeys","modalDone","length","modalDoneEmpty"],"sources":["../../../../../../src/cms-fields/components/media-gallery/media-gallery-dialog/hooks.ts"],"sourcesContent":["import { useCallback, useMemo, useState } from 'react';\nimport { useMediaControl } from '../../media-control';\nimport { MEDIA_TYPES } from '../../../utils/media-utils';\nimport { convertMediaControlItemToOrganizeMediaItem } from './utils';\nimport type { MediaGalleryDialogProps, OrganizeMediaItem } from './types';\nimport contentKeys from './content-keys';\n\nexport type MediaGalleryDialogHookParams = Partial<\n Omit<MediaGalleryDialogProps, 'isOpen'> & { initialOpen: boolean }\n>;\n\nexport type MediaGalleryDialogHookPayload = MediaGalleryDialogProps & {\n openMediaGalleryDialog: () => void;\n};\n\nexport const useMediaGalleryDialog = ({\n initialOpen,\n items,\n ...rest\n}: MediaGalleryDialogHookParams): MediaGalleryDialogHookPayload => {\n const [isOpen, setIsOpen] = useState(Boolean(initialOpen));\n\n const openMediaGalleryDialog = useCallback(() => setIsOpen(true), []);\n const mediaGalleryDialogItems = useMemo(() => items || [], [items]);\n const onMediaGalleryDialogClose = useCallback(() => {\n setIsOpen(false);\n rest.onClose?.();\n }, [rest.onClose]);\n\n return {\n openMediaGalleryDialog,\n isOpen,\n onClose: onMediaGalleryDialogClose,\n items: mediaGalleryDialogItems,\n ...rest,\n };\n};\n\n/**\n * Opens media manager (multi-select) to add new items to the gallery.\n *\n * Note: In cms-web, defaultNewItemName flows from Redux into this hook.\n * In auto-cairo, we don't have Redux for preferences, so the conversion\n * always uses mediaId for `name`. The dialog's `onAddMedia` callback\n * handles the EMPTY case by calling `setItemsEmptyTitles`.\n */\nexport const useAddMediaControl = (\n onAddMedia?: (newItems: OrganizeMediaItem[]) => void,\n) => {\n const onChange = useCallback(\n (value: string[]) => {\n onAddMedia?.(\n value\n .map((val) => convertMediaControlItemToOrganizeMediaItem(val))\n .filter(Boolean) as OrganizeMediaItem[],\n );\n },\n [onAddMedia],\n );\n\n const { callMedia, loading } = useMediaControl({\n multiSelect: true,\n mediaType: MEDIA_TYPES.GALLERY,\n onChange,\n });\n\n return {\n onOpen: useCallback(() => callMedia(), [callMedia]),\n isLoading: loading,\n };\n};\n\n/** Opens media manager (single-select) to replace one item */\nexport const useReplaceMediaControl = (\n onMediaReplaced?: (newItem: OrganizeMediaItem) => void,\n) => {\n const onChange = useCallback(\n (value: string) => {\n const newItem = convertMediaControlItemToOrganizeMediaItem(value);\n if (newItem) {\n onMediaReplaced?.(newItem);\n }\n },\n [onMediaReplaced],\n );\n\n const { callMedia, loading } = useMediaControl({\n multiSelect: false,\n mediaType: MEDIA_TYPES.ALL_MEDIA,\n onChange,\n });\n\n return {\n onOpen: useCallback(() => callMedia(), [callMedia]),\n isLoading: loading,\n };\n};\n\n/** Product requirement: show different text on Done button if there are no items yet */\nexport const useContentKeys = (items: OrganizeMediaItem[]) =>\n useMemo(\n () => ({\n ...contentKeys,\n modalDone:\n items.length === 0 ? contentKeys.modalDoneEmpty : contentKeys.modalDone,\n }),\n [items],\n );\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,37 @@
1
+ import React, { useCallback } from 'react';
2
+ import { Box, Button, Loader } from '@wix/design-system';
3
+ import { useTranslations } from '../../../hooks';
4
+ import { useReplaceMediaControl } from './hooks';
5
+ export const ItemActions = _ref => {
6
+ let {
7
+ item,
8
+ onReplace
9
+ } = _ref;
10
+ const {
11
+ t
12
+ } = useTranslations();
13
+ const onMediaReplaced = useCallback(newItem => {
14
+ onReplace({
15
+ itemId: item.id ?? '',
16
+ data: newItem
17
+ });
18
+ }, [item.id, onReplace]);
19
+ const {
20
+ onOpen,
21
+ isLoading
22
+ } = useReplaceMediaControl(onMediaReplaced);
23
+ return /*#__PURE__*/React.createElement(Box, {
24
+ align: "center",
25
+ verticalAlign: "middle",
26
+ gap: "SP1",
27
+ paddingRight: "SP1"
28
+ }, /*#__PURE__*/React.createElement(Button, {
29
+ priority: "secondary",
30
+ size: "small",
31
+ onClick: onOpen,
32
+ dataHook: "media-gallery-replace-item"
33
+ }, isLoading ? /*#__PURE__*/React.createElement(Loader, {
34
+ size: "tiny"
35
+ }) : t('CMS.mediaGallery.replaceItem')));
36
+ };
37
+ //# sourceMappingURL=item-actions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["React","useCallback","Box","Button","Loader","useTranslations","useReplaceMediaControl","ItemActions","_ref","item","onReplace","t","onMediaReplaced","newItem","itemId","id","data","onOpen","isLoading","createElement","align","verticalAlign","gap","paddingRight","priority","size","onClick","dataHook"],"sources":["../../../../../../src/cms-fields/components/media-gallery/media-gallery-dialog/item-actions.tsx"],"sourcesContent":["import React, { useCallback } from 'react';\nimport { Box, Button, Loader } from '@wix/design-system';\nimport { useTranslations } from '../../../hooks';\nimport { useReplaceMediaControl } from './hooks';\nimport type { OrganizeMediaItem, OrganizeMediaItemChange } from './types';\n\nexport interface ItemActionsProps {\n item: OrganizeMediaItem;\n onReplace: (change: OrganizeMediaItemChange) => void;\n}\n\nexport const ItemActions: React.FC<ItemActionsProps> = ({\n item,\n onReplace,\n}) => {\n const { t } = useTranslations();\n\n const onMediaReplaced = useCallback(\n (newItem: OrganizeMediaItem) => {\n onReplace({ itemId: item.id ?? '', data: newItem });\n },\n [item.id, onReplace],\n );\n\n const { onOpen, isLoading } = useReplaceMediaControl(onMediaReplaced);\n\n return (\n <Box align=\"center\" verticalAlign=\"middle\" gap=\"SP1\" paddingRight=\"SP1\">\n <Button\n priority=\"secondary\"\n size=\"small\"\n onClick={onOpen}\n dataHook=\"media-gallery-replace-item\"\n >\n {isLoading ? <Loader size=\"tiny\" /> : t('CMS.mediaGallery.replaceItem')}\n </Button>\n </Box>\n );\n};\n"],"mappings":"AAAA,OAAOA,KAAK,IAAIC,WAAW,QAAQ,OAAO;AAC1C,SAASC,GAAG,EAAEC,MAAM,EAAEC,MAAM,QAAQ,oBAAoB;AACxD,SAASC,eAAe,QAAQ,gBAAgB;AAChD,SAASC,sBAAsB,QAAQ,SAAS;AAQhD,OAAO,MAAMC,WAAuC,GAAGC,IAAA,IAGjD;EAAA,IAHkD;IACtDC,IAAI;IACJC;EACF,CAAC,GAAAF,IAAA;EACC,MAAM;IAAEG;EAAE,CAAC,GAAGN,eAAe,CAAC,CAAC;EAE/B,MAAMO,eAAe,GAAGX,WAAW,CAChCY,OAA0B,IAAK;IAC9BH,SAAS,CAAC;MAAEI,MAAM,EAAEL,IAAI,CAACM,EAAE,IAAI,EAAE;MAAEC,IAAI,EAAEH;IAAQ,CAAC,CAAC;EACrD,CAAC,EACD,CAACJ,IAAI,CAACM,EAAE,EAAEL,SAAS,CACrB,CAAC;EAED,MAAM;IAAEO,MAAM;IAAEC;EAAU,CAAC,GAAGZ,sBAAsB,CAACM,eAAe,CAAC;EAErE,oBACEZ,KAAA,CAAAmB,aAAA,CAACjB,GAAG;IAACkB,KAAK,EAAC,QAAQ;IAACC,aAAa,EAAC,QAAQ;IAACC,GAAG,EAAC,KAAK;IAACC,YAAY,EAAC;EAAK,gBACrEvB,KAAA,CAAAmB,aAAA,CAAChB,MAAM;IACLqB,QAAQ,EAAC,WAAW;IACpBC,IAAI,EAAC,OAAO;IACZC,OAAO,EAAET,MAAO;IAChBU,QAAQ,EAAC;EAA4B,GAEpCT,SAAS,gBAAGlB,KAAA,CAAAmB,aAAA,CAACf,MAAM;IAACqB,IAAI,EAAC;EAAM,CAAE,CAAC,GAAGd,CAAC,CAAC,8BAA8B,CAChE,CACL,CAAC;AAEV,CAAC","ignoreList":[]}
@@ -0,0 +1,152 @@
1
+ import React, { useCallback, useEffect, useState, useRef } from 'react';
2
+ import { usePersistedState } from '../../../../hooks/usePersistedState';
3
+ import { OrganizeMedia, ADD_ITEMS_DIRECTION, NAME_NEW_ITEMS } from '@wix/auto-patterns-utils/@wix/auto-patterns-bundled-organize-media';
4
+ import '@wix/auto-patterns-utils/@wix/auto-patterns-bundled-organize-media/dist/esm/index.global.css';
5
+ import { useTranslations } from '../../../hooks';
6
+ import isEqual from 'lodash/isEqual';
7
+ import { applyOrganizeMediaItemsChanges, convertOrganizeMediaItemToWixCodeGalleryItem, convertWixCodeGalleryItemToOrganizeMediaItem, setItemsEmptyTitles } from './utils';
8
+ import { useContentKeys } from './hooks';
9
+ import { AddMediaButton } from './add-media-button';
10
+ import { NoItemsView } from './no-items-view';
11
+ import { ItemActions } from './item-actions';
12
+ import { AddLinkModal } from './add-link-modal';
13
+ import { useAddLinkModal } from './use-add-link-modal';
14
+ const ITEM_EDITING_OPTION = {
15
+ link: false,
16
+ title: true,
17
+ description: true,
18
+ focalPoint: true,
19
+ alt: true,
20
+ externalLink: true
21
+ };
22
+ const toOrganizeMediaItems = items => items.map(convertWixCodeGalleryItemToOrganizeMediaItem).filter(Boolean);
23
+ const fromOrganizeMediaItems = organizeMediaItems => organizeMediaItems.map(convertOrganizeMediaItemToWixCodeGalleryItem).filter(Boolean);
24
+ export const MediaGalleryDialog = _ref => {
25
+ let {
26
+ isOpen,
27
+ items,
28
+ onClose,
29
+ onChange
30
+ } = _ref;
31
+ const {
32
+ t
33
+ } = useTranslations();
34
+ const [organizeMediaItems, setOrganizeMediaItems] = useState(toOrganizeMediaItems(items));
35
+ const [imageAddDirection, setImageAddDirection] = usePersistedState('auto-cairo:media-gallery-dialog-image-add-direction', ADD_ITEMS_DIRECTION.GALLERY_END);
36
+ const [defaultNewItemName, setDefaultNewItemName] = usePersistedState('auto-cairo:media-gallery-dialog-default-new-item-name', NAME_NEW_ITEMS.FILE_NAME);
37
+ const organizeMediaContentKeys = useContentKeys(organizeMediaItems);
38
+ const prevItemsRef = useRef(items);
39
+ useEffect(() => {
40
+ if (!isEqual(items, prevItemsRef.current)) {
41
+ setOrganizeMediaItems(toOrganizeMediaItems(items));
42
+ }
43
+ prevItemsRef.current = items;
44
+ }, [items]);
45
+ const onAddMedia = useCallback(newItems => {
46
+ const itemsToAdd = defaultNewItemName === NAME_NEW_ITEMS.EMPTY ? setItemsEmptyTitles(newItems) : newItems;
47
+ setOrganizeMediaItems(currentItems => {
48
+ const merged = imageAddDirection === ADD_ITEMS_DIRECTION.GALLERY_START ? [...itemsToAdd, ...currentItems] : [...currentItems, ...itemsToAdd];
49
+ return merged.map((item, orderIndex) => ({
50
+ ...item,
51
+ orderIndex
52
+ }));
53
+ });
54
+ }, [defaultNewItemName, imageAddDirection]);
55
+ const onDeleteImages = useCallback(itemIds => {
56
+ setOrganizeMediaItems(currentItems => currentItems.filter(_ref2 => {
57
+ let {
58
+ id
59
+ } = _ref2;
60
+ return !itemIds.includes(id ?? '');
61
+ }).map((item, orderIndex) => ({
62
+ ...item,
63
+ orderIndex
64
+ })));
65
+ }, []);
66
+ const onItemsOrderIndexUpdated = useCallback(changes => {
67
+ setOrganizeMediaItems(currentItems => applyOrganizeMediaItemsChanges(currentItems, changes));
68
+ }, []);
69
+ const onItemUpdated = useCallback(change => {
70
+ setOrganizeMediaItems(currentItems => applyOrganizeMediaItemsChanges(currentItems, [change]));
71
+ }, []);
72
+ const onItemReplaced = useCallback(_ref3 => {
73
+ let {
74
+ itemId,
75
+ data
76
+ } = _ref3;
77
+ setOrganizeMediaItems(currentItems => {
78
+ const itemToReplace = currentItems.find(_ref4 => {
79
+ let {
80
+ id
81
+ } = _ref4;
82
+ return id === itemId;
83
+ });
84
+ const orderIndex = (itemToReplace == null ? void 0 : itemToReplace.orderIndex) ?? data.orderIndex;
85
+ const change = {
86
+ itemId,
87
+ data: {
88
+ ...data,
89
+ orderIndex
90
+ }
91
+ };
92
+ return applyOrganizeMediaItemsChanges(currentItems, [change]);
93
+ });
94
+ }, []);
95
+ const onCloseOrganizeMedia = useCallback(() => {
96
+ onChange == null || onChange(fromOrganizeMediaItems(organizeMediaItems));
97
+ onClose == null || onClose();
98
+ }, [onChange, onClose, organizeMediaItems]);
99
+
100
+ // Link editing: OrganizeMedia fires onLinkButtonClicked, we show AddLinkModal
101
+ const onUpdateLink = useCallback((itemId, link) => {
102
+ setOrganizeMediaItems(currentItems => currentItems.map(item => item.id === itemId ? {
103
+ ...item,
104
+ link
105
+ } : item));
106
+ }, []);
107
+ const {
108
+ onLinkButtonClicked,
109
+ ...addLinkModalProps
110
+ } = useAddLinkModal(onUpdateLink);
111
+ const noItemsViewRenderer = useCallback(() => /*#__PURE__*/React.createElement(NoItemsView, {
112
+ onAddMedia: onAddMedia
113
+ }), [onAddMedia]);
114
+ const uploadMediaRenderer = useCallback(() => /*#__PURE__*/React.createElement(AddMediaButton, {
115
+ onAddMedia: onAddMedia
116
+ }), [onAddMedia]);
117
+ const itemActionsRenderer = useCallback(_ref5 => {
118
+ let {
119
+ item
120
+ } = _ref5;
121
+ return /*#__PURE__*/React.createElement(ItemActions, {
122
+ item: item,
123
+ onReplace: onItemReplaced
124
+ });
125
+ }, [onItemReplaced]);
126
+ return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(OrganizeMedia, {
127
+ t: t,
128
+ contentKeys: organizeMediaContentKeys,
129
+ isOpen: isOpen,
130
+ items: organizeMediaItems,
131
+ baseUrl: "",
132
+ usePaging: true,
133
+ shouldVerifySorting: false,
134
+ shouldShowPhotoRightsNotification: false,
135
+ showItemNameInSettings: false,
136
+ noItemsViewRenderer: noItemsViewRenderer,
137
+ uploadMediaRenderer: uploadMediaRenderer,
138
+ itemActionsRenderer: itemActionsRenderer,
139
+ itemEditingOption: ITEM_EDITING_OPTION,
140
+ imageAddDirection: imageAddDirection,
141
+ defaultNewItemName: defaultNewItemName,
142
+ onImageAddDirectionChange: setImageAddDirection,
143
+ onDefaultNewItemNameChange: setDefaultNewItemName,
144
+ onDeleteImages: onDeleteImages,
145
+ onItemUpdated: onItemUpdated,
146
+ onItemsOrderIndexUpdated: onItemsOrderIndexUpdated,
147
+ onClose: onCloseOrganizeMedia,
148
+ onLinkButtonClicked: onLinkButtonClicked
149
+ }), /*#__PURE__*/React.createElement(AddLinkModal, addLinkModalProps));
150
+ };
151
+ MediaGalleryDialog.displayName = 'MediaGalleryDialog';
152
+ //# sourceMappingURL=media-gallery-dialog.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["React","useCallback","useEffect","useState","useRef","usePersistedState","OrganizeMedia","ADD_ITEMS_DIRECTION","NAME_NEW_ITEMS","useTranslations","isEqual","applyOrganizeMediaItemsChanges","convertOrganizeMediaItemToWixCodeGalleryItem","convertWixCodeGalleryItemToOrganizeMediaItem","setItemsEmptyTitles","useContentKeys","AddMediaButton","NoItemsView","ItemActions","AddLinkModal","useAddLinkModal","ITEM_EDITING_OPTION","link","title","description","focalPoint","alt","externalLink","toOrganizeMediaItems","items","map","filter","Boolean","fromOrganizeMediaItems","organizeMediaItems","MediaGalleryDialog","_ref","isOpen","onClose","onChange","t","setOrganizeMediaItems","imageAddDirection","setImageAddDirection","GALLERY_END","defaultNewItemName","setDefaultNewItemName","FILE_NAME","organizeMediaContentKeys","prevItemsRef","current","onAddMedia","newItems","itemsToAdd","EMPTY","currentItems","merged","GALLERY_START","item","orderIndex","onDeleteImages","itemIds","_ref2","id","includes","onItemsOrderIndexUpdated","changes","onItemUpdated","change","onItemReplaced","_ref3","itemId","data","itemToReplace","find","_ref4","onCloseOrganizeMedia","onUpdateLink","onLinkButtonClicked","addLinkModalProps","noItemsViewRenderer","createElement","uploadMediaRenderer","itemActionsRenderer","_ref5","onReplace","Fragment","contentKeys","baseUrl","usePaging","shouldVerifySorting","shouldShowPhotoRightsNotification","showItemNameInSettings","itemEditingOption","onImageAddDirectionChange","onDefaultNewItemNameChange","displayName"],"sources":["../../../../../../src/cms-fields/components/media-gallery/media-gallery-dialog/media-gallery-dialog.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useState, useRef } from 'react';\nimport { usePersistedState } from '../../../../hooks/usePersistedState';\nimport {\n OrganizeMedia,\n ADD_ITEMS_DIRECTION,\n NAME_NEW_ITEMS,\n} from '@wix/auto-patterns-utils/@wix/auto-patterns-bundled-organize-media';\nimport '@wix/auto-patterns-utils/@wix/auto-patterns-bundled-organize-media/dist/esm/index.global.css';\nimport type { WixCodeGalleryItem } from '../../../auto-cms-field-types';\nimport { useTranslations } from '../../../hooks';\nimport isEqual from 'lodash/isEqual';\n\nimport type {\n MediaGalleryDialogProps,\n OrganizeMediaItem,\n OrganizeMediaItemChange,\n OrganizeMediaItemLink,\n} from './types';\nimport {\n applyOrganizeMediaItemsChanges,\n convertOrganizeMediaItemToWixCodeGalleryItem,\n convertWixCodeGalleryItemToOrganizeMediaItem,\n setItemsEmptyTitles,\n} from './utils';\nimport { useContentKeys } from './hooks';\nimport { AddMediaButton } from './add-media-button';\nimport { NoItemsView } from './no-items-view';\nimport { ItemActions } from './item-actions';\nimport { AddLinkModal } from './add-link-modal';\nimport { useAddLinkModal } from './use-add-link-modal';\n\nconst ITEM_EDITING_OPTION = {\n link: false,\n title: true,\n description: true,\n focalPoint: true,\n alt: true,\n externalLink: true,\n} as const;\n\nconst toOrganizeMediaItems = (items: WixCodeGalleryItem[]) =>\n items\n .map(convertWixCodeGalleryItemToOrganizeMediaItem)\n .filter(Boolean) as OrganizeMediaItem[];\n\nconst fromOrganizeMediaItems = (organizeMediaItems: OrganizeMediaItem[]) =>\n organizeMediaItems\n .map(convertOrganizeMediaItemToWixCodeGalleryItem)\n .filter(Boolean) as WixCodeGalleryItem[];\n\nexport const MediaGalleryDialog: React.FC<MediaGalleryDialogProps> = ({\n isOpen,\n items,\n onClose,\n onChange,\n}) => {\n const { t } = useTranslations();\n\n const [organizeMediaItems, setOrganizeMediaItems] = useState(\n toOrganizeMediaItems(items),\n );\n\n const [imageAddDirection, setImageAddDirection] = usePersistedState(\n 'auto-cairo:media-gallery-dialog-image-add-direction',\n ADD_ITEMS_DIRECTION.GALLERY_END,\n );\n const [defaultNewItemName, setDefaultNewItemName] = usePersistedState(\n 'auto-cairo:media-gallery-dialog-default-new-item-name',\n NAME_NEW_ITEMS.FILE_NAME,\n );\n\n const organizeMediaContentKeys = useContentKeys(organizeMediaItems);\n\n const prevItemsRef = useRef(items);\n useEffect(() => {\n if (!isEqual(items, prevItemsRef.current)) {\n setOrganizeMediaItems(toOrganizeMediaItems(items));\n }\n prevItemsRef.current = items;\n }, [items]);\n\n const onAddMedia = useCallback(\n (newItems: OrganizeMediaItem[]) => {\n const itemsToAdd =\n defaultNewItemName === NAME_NEW_ITEMS.EMPTY\n ? setItemsEmptyTitles(newItems)\n : newItems;\n\n setOrganizeMediaItems((currentItems) => {\n const merged =\n imageAddDirection === ADD_ITEMS_DIRECTION.GALLERY_START\n ? [...itemsToAdd, ...currentItems]\n : [...currentItems, ...itemsToAdd];\n return merged.map((item, orderIndex) => ({\n ...item,\n orderIndex,\n }));\n });\n },\n [defaultNewItemName, imageAddDirection],\n );\n\n const onDeleteImages = useCallback((itemIds: string[]) => {\n setOrganizeMediaItems((currentItems) =>\n currentItems\n .filter(({ id }) => !itemIds.includes(id ?? ''))\n .map((item, orderIndex) => ({ ...item, orderIndex })),\n );\n }, []);\n\n const onItemsOrderIndexUpdated = useCallback(\n (changes: OrganizeMediaItemChange[]) => {\n setOrganizeMediaItems((currentItems) =>\n applyOrganizeMediaItemsChanges(currentItems, changes),\n );\n },\n [],\n );\n\n const onItemUpdated = useCallback((change: OrganizeMediaItemChange) => {\n setOrganizeMediaItems((currentItems) =>\n applyOrganizeMediaItemsChanges(currentItems, [change]),\n );\n }, []);\n\n const onItemReplaced = useCallback(\n ({ itemId, data }: OrganizeMediaItemChange) => {\n setOrganizeMediaItems((currentItems) => {\n const itemToReplace = currentItems.find(({ id }) => id === itemId);\n const orderIndex = itemToReplace?.orderIndex ?? data.orderIndex;\n const change = { itemId, data: { ...data, orderIndex } };\n return applyOrganizeMediaItemsChanges(currentItems, [change]);\n });\n },\n [],\n );\n\n const onCloseOrganizeMedia = useCallback(() => {\n onChange?.(fromOrganizeMediaItems(organizeMediaItems));\n onClose?.();\n }, [onChange, onClose, organizeMediaItems]);\n\n // Link editing: OrganizeMedia fires onLinkButtonClicked, we show AddLinkModal\n const onUpdateLink = useCallback(\n (itemId?: string, link?: OrganizeMediaItemLink) => {\n setOrganizeMediaItems((currentItems) =>\n currentItems.map((item) =>\n item.id === itemId ? { ...item, link } : item,\n ),\n );\n },\n [],\n );\n const { onLinkButtonClicked, ...addLinkModalProps } =\n useAddLinkModal(onUpdateLink);\n\n const noItemsViewRenderer = useCallback(\n () => <NoItemsView onAddMedia={onAddMedia} />,\n [onAddMedia],\n );\n\n const uploadMediaRenderer = useCallback(\n () => <AddMediaButton onAddMedia={onAddMedia} />,\n [onAddMedia],\n );\n\n const itemActionsRenderer = useCallback(\n ({ item }: { item: OrganizeMediaItem }) => (\n <ItemActions item={item} onReplace={onItemReplaced} />\n ),\n [onItemReplaced],\n );\n\n return (\n <>\n <OrganizeMedia\n t={t}\n contentKeys={organizeMediaContentKeys}\n isOpen={isOpen}\n items={organizeMediaItems}\n baseUrl=\"\"\n usePaging\n shouldVerifySorting={false}\n shouldShowPhotoRightsNotification={false}\n showItemNameInSettings={false}\n noItemsViewRenderer={noItemsViewRenderer}\n uploadMediaRenderer={uploadMediaRenderer}\n itemActionsRenderer={itemActionsRenderer}\n itemEditingOption={ITEM_EDITING_OPTION}\n imageAddDirection={imageAddDirection}\n defaultNewItemName={defaultNewItemName}\n onImageAddDirectionChange={setImageAddDirection}\n onDefaultNewItemNameChange={setDefaultNewItemName}\n onDeleteImages={onDeleteImages}\n onItemUpdated={onItemUpdated}\n onItemsOrderIndexUpdated={onItemsOrderIndexUpdated}\n onClose={onCloseOrganizeMedia}\n onLinkButtonClicked={onLinkButtonClicked}\n />\n <AddLinkModal {...addLinkModalProps} />\n </>\n );\n};\n\nMediaGalleryDialog.displayName = 'MediaGalleryDialog';\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,34 @@
1
+ import React from 'react';
2
+ import { EmptyState, Box, TextButton, Loader } from '@wix/design-system';
3
+ import { Add as AddIcon } from '@wix/wix-ui-icons-common';
4
+ import { useTranslations } from '../../../hooks';
5
+ import { useAddMediaControl } from './hooks';
6
+ export const NoItemsView = _ref => {
7
+ let {
8
+ onAddMedia
9
+ } = _ref;
10
+ const {
11
+ t
12
+ } = useTranslations();
13
+ const {
14
+ onOpen,
15
+ isLoading
16
+ } = useAddMediaControl(onAddMedia);
17
+ return /*#__PURE__*/React.createElement(Box, {
18
+ align: "center",
19
+ verticalAlign: "middle",
20
+ padding: "SP5",
21
+ direction: "vertical"
22
+ }, /*#__PURE__*/React.createElement(EmptyState, {
23
+ theme: "section",
24
+ title: t('CMS.mediaGallery.noItems.title'),
25
+ subtitle: t('CMS.mediaGallery.noItems.subtitle')
26
+ }, /*#__PURE__*/React.createElement(TextButton, {
27
+ prefixIcon: isLoading ? undefined : /*#__PURE__*/React.createElement(AddIcon, null),
28
+ onClick: onOpen,
29
+ dataHook: "media-gallery-add-media-button"
30
+ }, isLoading ? /*#__PURE__*/React.createElement(Loader, {
31
+ size: "tiny"
32
+ }) : t('CMS.mediaGallery.noItems.addMedia'))));
33
+ };
34
+ //# sourceMappingURL=no-items-view.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["React","EmptyState","Box","TextButton","Loader","Add","AddIcon","useTranslations","useAddMediaControl","NoItemsView","_ref","onAddMedia","t","onOpen","isLoading","createElement","align","verticalAlign","padding","direction","theme","title","subtitle","prefixIcon","undefined","onClick","dataHook","size"],"sources":["../../../../../../src/cms-fields/components/media-gallery/media-gallery-dialog/no-items-view.tsx"],"sourcesContent":["import React from 'react';\nimport { EmptyState, Box, TextButton, Loader } from '@wix/design-system';\nimport { Add as AddIcon } from '@wix/wix-ui-icons-common';\nimport { useTranslations } from '../../../hooks';\nimport { useAddMediaControl } from './hooks';\nimport type { OrganizeMediaItem } from './types';\n\nexport interface NoItemsViewProps {\n onAddMedia: (items: OrganizeMediaItem[]) => void;\n}\n\nexport const NoItemsView: React.FC<NoItemsViewProps> = ({ onAddMedia }) => {\n const { t } = useTranslations();\n const { onOpen, isLoading } = useAddMediaControl(onAddMedia);\n\n return (\n <Box\n align=\"center\"\n verticalAlign=\"middle\"\n padding=\"SP5\"\n direction=\"vertical\"\n >\n <EmptyState\n theme=\"section\"\n title={t('CMS.mediaGallery.noItems.title')}\n subtitle={t('CMS.mediaGallery.noItems.subtitle')}\n >\n <TextButton\n prefixIcon={isLoading ? undefined : <AddIcon />}\n onClick={onOpen}\n dataHook=\"media-gallery-add-media-button\"\n >\n {isLoading ? (\n <Loader size=\"tiny\" />\n ) : (\n t('CMS.mediaGallery.noItems.addMedia')\n )}\n </TextButton>\n </EmptyState>\n </Box>\n );\n};\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,UAAU,EAAEC,GAAG,EAAEC,UAAU,EAAEC,MAAM,QAAQ,oBAAoB;AACxE,SAASC,GAAG,IAAIC,OAAO,QAAQ,0BAA0B;AACzD,SAASC,eAAe,QAAQ,gBAAgB;AAChD,SAASC,kBAAkB,QAAQ,SAAS;AAO5C,OAAO,MAAMC,WAAuC,GAAGC,IAAA,IAAoB;EAAA,IAAnB;IAAEC;EAAW,CAAC,GAAAD,IAAA;EACpE,MAAM;IAAEE;EAAE,CAAC,GAAGL,eAAe,CAAC,CAAC;EAC/B,MAAM;IAAEM,MAAM;IAAEC;EAAU,CAAC,GAAGN,kBAAkB,CAACG,UAAU,CAAC;EAE5D,oBACEX,KAAA,CAAAe,aAAA,CAACb,GAAG;IACFc,KAAK,EAAC,QAAQ;IACdC,aAAa,EAAC,QAAQ;IACtBC,OAAO,EAAC,KAAK;IACbC,SAAS,EAAC;EAAU,gBAEpBnB,KAAA,CAAAe,aAAA,CAACd,UAAU;IACTmB,KAAK,EAAC,SAAS;IACfC,KAAK,EAAET,CAAC,CAAC,gCAAgC,CAAE;IAC3CU,QAAQ,EAAEV,CAAC,CAAC,mCAAmC;EAAE,gBAEjDZ,KAAA,CAAAe,aAAA,CAACZ,UAAU;IACToB,UAAU,EAAET,SAAS,GAAGU,SAAS,gBAAGxB,KAAA,CAAAe,aAAA,CAACT,OAAO,MAAE,CAAE;IAChDmB,OAAO,EAAEZ,MAAO;IAChBa,QAAQ,EAAC;EAAgC,GAExCZ,SAAS,gBACRd,KAAA,CAAAe,aAAA,CAACX,MAAM;IAACuB,IAAI,EAAC;EAAM,CAAE,CAAC,GAEtBf,CAAC,CAAC,mCAAmC,CAE7B,CACF,CACT,CAAC;AAEV,CAAC","ignoreList":[]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":[],"sources":["../../../../../../src/cms-fields/components/media-gallery/media-gallery-dialog/types.ts"],"sourcesContent":["import type { WixCodeGalleryItem } from '../../../auto-cms-field-types';\n\nexport interface MediaGalleryDialogProps {\n isOpen: boolean;\n items: WixCodeGalleryItem[];\n onClose?: () => void;\n onChange?: (items: WixCodeGalleryItem[]) => void;\n}\n\nexport interface OrganizeMediaItemFocalPoint {\n x: number;\n y: number;\n}\n\nexport interface OrganizeMediaItemPhotoMetadata {\n width: number;\n height: number;\n focalPoint?: OrganizeMediaItemFocalPoint;\n}\n\nexport interface OrganizeMediaItemLink {\n url: string;\n text?: string;\n target: '_blank' | '_self';\n}\n\nexport interface OrganizeMediaItemMetadata {\n title?: string;\n description?: string;\n link?: OrganizeMediaItemLink;\n height?: number;\n width?: number;\n fileName?: string;\n name?: string;\n}\n\nexport interface OrganizeMediaItemPhoto {\n dataType: 'Photo';\n id?: string;\n mediaUrl?: string;\n fileName?: string;\n name?: string;\n orderIndex?: number;\n sortOrder?: number;\n isSecure?: boolean;\n photoMetadata?: OrganizeMediaItemPhotoMetadata;\n title?: string;\n description?: string;\n token?: string;\n alt?: string;\n link?: OrganizeMediaItemLink;\n metaData?: OrganizeMediaItemMetadata;\n}\n\nexport interface OrganizeMediaItemVideoPoster {\n url: string;\n width?: number;\n height?: number;\n}\n\nexport interface OrganizeMediaItemVideoMetadata {\n width: number;\n height: number;\n duration: number;\n posters: OrganizeMediaItemVideoPoster[];\n focalPoint?: OrganizeMediaItemFocalPoint;\n}\n\nexport interface OrganizeMediaItemVideo {\n dataType: 'Video';\n id?: string;\n mediaUrl?: string;\n fileName?: string;\n name?: string;\n orderIndex?: number;\n sortOrder?: number;\n thumbnail?: string;\n videoMetadata?: OrganizeMediaItemVideoMetadata;\n title?: string;\n description?: string;\n alt?: string;\n link?: OrganizeMediaItemLink;\n metaData?: OrganizeMediaItemMetadata;\n}\n\nexport type OrganizeMediaItem = OrganizeMediaItemPhoto | OrganizeMediaItemVideo;\n\nexport interface OrganizeMediaItemChange {\n itemId: string;\n data: Partial<Omit<OrganizeMediaItem, 'id'>>;\n}\n"],"mappings":"","ignoreList":[]}
@@ -0,0 +1,19 @@
1
+ import { useCallback, useState } from 'react';
2
+ export const useAddLinkModal = onUpdateLink => {
3
+ const [mediaItem, setMediaItem] = useState();
4
+ const onClose = useCallback(() => setMediaItem(undefined), []);
5
+ const onLinkButtonClicked = useCallback(item => setMediaItem(item), []);
6
+ const onSave = useCallback(link => {
7
+ onUpdateLink(mediaItem == null ? void 0 : mediaItem.id, link);
8
+ onClose();
9
+ }, [mediaItem == null ? void 0 : mediaItem.id, onUpdateLink, onClose]);
10
+ return {
11
+ onLinkButtonClicked,
12
+ mediaType: mediaItem == null ? void 0 : mediaItem.dataType,
13
+ link: mediaItem == null ? void 0 : mediaItem.link,
14
+ isOpen: Boolean(mediaItem),
15
+ onClose,
16
+ onSave
17
+ };
18
+ };
19
+ //# sourceMappingURL=use-add-link-modal.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["useCallback","useState","useAddLinkModal","onUpdateLink","mediaItem","setMediaItem","onClose","undefined","onLinkButtonClicked","item","onSave","link","id","mediaType","dataType","isOpen","Boolean"],"sources":["../../../../../../src/cms-fields/components/media-gallery/media-gallery-dialog/use-add-link-modal.ts"],"sourcesContent":["import { useCallback, useState } from 'react';\nimport type { OrganizeMediaItem, OrganizeMediaItemLink } from './types';\n\nexport const useAddLinkModal = (\n onUpdateLink: (itemId?: string, link?: OrganizeMediaItemLink) => void,\n) => {\n const [mediaItem, setMediaItem] = useState<OrganizeMediaItem>();\n const onClose = useCallback(() => setMediaItem(undefined), []);\n\n const onLinkButtonClicked = useCallback(\n (item: OrganizeMediaItem) => setMediaItem(item),\n [],\n );\n\n const onSave = useCallback(\n (link?: OrganizeMediaItemLink) => {\n onUpdateLink(mediaItem?.id, link);\n onClose();\n },\n [mediaItem?.id, onUpdateLink, onClose],\n );\n\n return {\n onLinkButtonClicked,\n mediaType: mediaItem?.dataType,\n link: mediaItem?.link,\n isOpen: Boolean(mediaItem),\n onClose,\n onSave,\n };\n};\n"],"mappings":"AAAA,SAASA,WAAW,EAAEC,QAAQ,QAAQ,OAAO;AAG7C,OAAO,MAAMC,eAAe,GAC1BC,YAAqE,IAClE;EACH,MAAM,CAACC,SAAS,EAAEC,YAAY,CAAC,GAAGJ,QAAQ,CAAoB,CAAC;EAC/D,MAAMK,OAAO,GAAGN,WAAW,CAAC,MAAMK,YAAY,CAACE,SAAS,CAAC,EAAE,EAAE,CAAC;EAE9D,MAAMC,mBAAmB,GAAGR,WAAW,CACpCS,IAAuB,IAAKJ,YAAY,CAACI,IAAI,CAAC,EAC/C,EACF,CAAC;EAED,MAAMC,MAAM,GAAGV,WAAW,CACvBW,IAA4B,IAAK;IAChCR,YAAY,CAACC,SAAS,oBAATA,SAAS,CAAEQ,EAAE,EAAED,IAAI,CAAC;IACjCL,OAAO,CAAC,CAAC;EACX,CAAC,EACD,CAACF,SAAS,oBAATA,SAAS,CAAEQ,EAAE,EAAET,YAAY,EAAEG,OAAO,CACvC,CAAC;EAED,OAAO;IACLE,mBAAmB;IACnBK,SAAS,EAAET,SAAS,oBAATA,SAAS,CAAEU,QAAQ;IAC9BH,IAAI,EAAEP,SAAS,oBAATA,SAAS,CAAEO,IAAI;IACrBI,MAAM,EAAEC,OAAO,CAACZ,SAAS,CAAC;IAC1BE,OAAO;IACPI;EACF,CAAC;AACH,CAAC","ignoreList":[]}