@uploadcare/file-uploader 0.50.1-alpha.2

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 (631) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +165 -0
  3. package/abstract/ActivityBlock.d.ts +68 -0
  4. package/abstract/ActivityBlock.d.ts.map +1 -0
  5. package/abstract/ActivityBlock.js +207 -0
  6. package/abstract/Block.d.ts +99 -0
  7. package/abstract/Block.d.ts.map +1 -0
  8. package/abstract/Block.js +349 -0
  9. package/abstract/CTX.d.ts +31 -0
  10. package/abstract/CTX.d.ts.map +1 -0
  11. package/abstract/CTX.js +38 -0
  12. package/abstract/LocaleManager.d.ts +38 -0
  13. package/abstract/LocaleManager.d.ts.map +1 -0
  14. package/abstract/LocaleManager.js +127 -0
  15. package/abstract/SecureUploadsManager.d.ts +22 -0
  16. package/abstract/SecureUploadsManager.d.ts.map +1 -0
  17. package/abstract/SecureUploadsManager.js +87 -0
  18. package/abstract/SolutionBlock.d.ts +23 -0
  19. package/abstract/SolutionBlock.d.ts.map +1 -0
  20. package/abstract/SolutionBlock.js +23 -0
  21. package/abstract/TypedCollection.d.ts +127 -0
  22. package/abstract/TypedCollection.d.ts.map +1 -0
  23. package/abstract/TypedCollection.js +245 -0
  24. package/abstract/TypedData.d.ts +47 -0
  25. package/abstract/TypedData.d.ts.map +1 -0
  26. package/abstract/TypedData.js +77 -0
  27. package/abstract/UploaderBlock.d.ts +114 -0
  28. package/abstract/UploaderBlock.d.ts.map +1 -0
  29. package/abstract/UploaderBlock.js +444 -0
  30. package/abstract/UploaderPublicApi.d.ts +90 -0
  31. package/abstract/UploaderPublicApi.d.ts.map +1 -0
  32. package/abstract/UploaderPublicApi.js +316 -0
  33. package/abstract/ValidationManager.d.ts +31 -0
  34. package/abstract/ValidationManager.d.ts.map +1 -0
  35. package/abstract/ValidationManager.js +162 -0
  36. package/abstract/a11y.d.ts +20 -0
  37. package/abstract/a11y.d.ts.map +1 -0
  38. package/abstract/a11y.js +118 -0
  39. package/abstract/buildOutputCollectionState.d.ts +8 -0
  40. package/abstract/buildOutputCollectionState.d.ts.map +1 -0
  41. package/abstract/buildOutputCollectionState.js +136 -0
  42. package/abstract/connectBlocksFrom.d.ts +8 -0
  43. package/abstract/connectBlocksFrom.d.ts.map +1 -0
  44. package/abstract/connectBlocksFrom.js +34 -0
  45. package/abstract/l10nProcessor.d.ts +7 -0
  46. package/abstract/l10nProcessor.d.ts.map +1 -0
  47. package/abstract/l10nProcessor.js +80 -0
  48. package/abstract/localeRegistry.d.ts +5 -0
  49. package/abstract/localeRegistry.d.ts.map +1 -0
  50. package/abstract/localeRegistry.js +63 -0
  51. package/abstract/registerBlocks.d.ts +5 -0
  52. package/abstract/registerBlocks.d.ts.map +1 -0
  53. package/abstract/registerBlocks.js +31 -0
  54. package/abstract/sharedConfigKey.d.ts +2 -0
  55. package/abstract/sharedConfigKey.d.ts.map +1 -0
  56. package/abstract/sharedConfigKey.js +8 -0
  57. package/abstract/uploadEntrySchema.d.ts +64 -0
  58. package/abstract/uploadEntrySchema.d.ts.map +1 -0
  59. package/abstract/uploadEntrySchema.js +138 -0
  60. package/blocks/ActivityHeader/ActivityHeader.d.ts +4 -0
  61. package/blocks/ActivityHeader/ActivityHeader.d.ts.map +1 -0
  62. package/blocks/ActivityHeader/ActivityHeader.js +3 -0
  63. package/blocks/ActivityHeader/activity-header.css +14 -0
  64. package/blocks/CameraSource/CameraSource.d.ts +39 -0
  65. package/blocks/CameraSource/CameraSource.d.ts.map +1 -0
  66. package/blocks/CameraSource/CameraSource.js +253 -0
  67. package/blocks/CameraSource/camera-source.css +107 -0
  68. package/blocks/CloudImageEditor/index.css +1 -0
  69. package/blocks/CloudImageEditor/index.d.ts +2 -0
  70. package/blocks/CloudImageEditor/index.d.ts.map +1 -0
  71. package/blocks/CloudImageEditor/index.js +1 -0
  72. package/blocks/CloudImageEditor/src/CloudImageEditorBlock.d.ts +58 -0
  73. package/blocks/CloudImageEditor/src/CloudImageEditorBlock.d.ts.map +1 -0
  74. package/blocks/CloudImageEditor/src/CloudImageEditorBlock.js +228 -0
  75. package/blocks/CloudImageEditor/src/CropFrame.d.ts +146 -0
  76. package/blocks/CloudImageEditor/src/CropFrame.d.ts.map +1 -0
  77. package/blocks/CloudImageEditor/src/CropFrame.js +511 -0
  78. package/blocks/CloudImageEditor/src/EditorButtonControl.d.ts +10 -0
  79. package/blocks/CloudImageEditor/src/EditorButtonControl.d.ts.map +1 -0
  80. package/blocks/CloudImageEditor/src/EditorButtonControl.js +44 -0
  81. package/blocks/CloudImageEditor/src/EditorCropButtonControl.d.ts +6 -0
  82. package/blocks/CloudImageEditor/src/EditorCropButtonControl.d.ts.map +1 -0
  83. package/blocks/CloudImageEditor/src/EditorCropButtonControl.js +39 -0
  84. package/blocks/CloudImageEditor/src/EditorFilterControl.d.ts +18 -0
  85. package/blocks/CloudImageEditor/src/EditorFilterControl.d.ts.map +1 -0
  86. package/blocks/CloudImageEditor/src/EditorFilterControl.js +155 -0
  87. package/blocks/CloudImageEditor/src/EditorImageCropper.d.ts +106 -0
  88. package/blocks/CloudImageEditor/src/EditorImageCropper.d.ts.map +1 -0
  89. package/blocks/CloudImageEditor/src/EditorImageCropper.js +551 -0
  90. package/blocks/CloudImageEditor/src/EditorImageFader.d.ts +132 -0
  91. package/blocks/CloudImageEditor/src/EditorImageFader.d.ts.map +1 -0
  92. package/blocks/CloudImageEditor/src/EditorImageFader.js +454 -0
  93. package/blocks/CloudImageEditor/src/EditorOperationControl.d.ts +9 -0
  94. package/blocks/CloudImageEditor/src/EditorOperationControl.d.ts.map +1 -0
  95. package/blocks/CloudImageEditor/src/EditorOperationControl.js +39 -0
  96. package/blocks/CloudImageEditor/src/EditorScroller.d.ts +7 -0
  97. package/blocks/CloudImageEditor/src/EditorScroller.d.ts.map +1 -0
  98. package/blocks/CloudImageEditor/src/EditorScroller.js +33 -0
  99. package/blocks/CloudImageEditor/src/EditorSlider.d.ts +24 -0
  100. package/blocks/CloudImageEditor/src/EditorSlider.d.ts.map +1 -0
  101. package/blocks/CloudImageEditor/src/EditorSlider.js +118 -0
  102. package/blocks/CloudImageEditor/src/EditorToolbar.d.ts +104 -0
  103. package/blocks/CloudImageEditor/src/EditorToolbar.d.ts.map +1 -0
  104. package/blocks/CloudImageEditor/src/EditorToolbar.js +441 -0
  105. package/blocks/CloudImageEditor/src/crop-utils.d.ts +123 -0
  106. package/blocks/CloudImageEditor/src/crop-utils.d.ts.map +1 -0
  107. package/blocks/CloudImageEditor/src/crop-utils.js +729 -0
  108. package/blocks/CloudImageEditor/src/cropper-constants.d.ts +11 -0
  109. package/blocks/CloudImageEditor/src/cropper-constants.d.ts.map +1 -0
  110. package/blocks/CloudImageEditor/src/cropper-constants.js +11 -0
  111. package/blocks/CloudImageEditor/src/css/common.css +1157 -0
  112. package/blocks/CloudImageEditor/src/css/icons.css +12 -0
  113. package/blocks/CloudImageEditor/src/css/index.css +2 -0
  114. package/blocks/CloudImageEditor/src/elements/button/BtnUi.d.ts +20 -0
  115. package/blocks/CloudImageEditor/src/elements/button/BtnUi.d.ts.map +1 -0
  116. package/blocks/CloudImageEditor/src/elements/button/BtnUi.js +90 -0
  117. package/blocks/CloudImageEditor/src/elements/line-loader/LineLoaderUi.d.ts +11 -0
  118. package/blocks/CloudImageEditor/src/elements/line-loader/LineLoaderUi.d.ts.map +1 -0
  119. package/blocks/CloudImageEditor/src/elements/line-loader/LineLoaderUi.js +52 -0
  120. package/blocks/CloudImageEditor/src/elements/presence-toggle/PresenceToggle.d.ts +17 -0
  121. package/blocks/CloudImageEditor/src/elements/presence-toggle/PresenceToggle.d.ts.map +1 -0
  122. package/blocks/CloudImageEditor/src/elements/presence-toggle/PresenceToggle.js +71 -0
  123. package/blocks/CloudImageEditor/src/elements/slider/SliderUi.d.ts +16 -0
  124. package/blocks/CloudImageEditor/src/elements/slider/SliderUi.d.ts.map +1 -0
  125. package/blocks/CloudImageEditor/src/elements/slider/SliderUi.js +178 -0
  126. package/blocks/CloudImageEditor/src/index.d.ts +15 -0
  127. package/blocks/CloudImageEditor/src/index.d.ts.map +1 -0
  128. package/blocks/CloudImageEditor/src/index.js +14 -0
  129. package/blocks/CloudImageEditor/src/lib/FocusVisible.d.ts +15 -0
  130. package/blocks/CloudImageEditor/src/lib/FocusVisible.d.ts.map +1 -0
  131. package/blocks/CloudImageEditor/src/lib/FocusVisible.js +33 -0
  132. package/blocks/CloudImageEditor/src/lib/applyFocusVisiblePolyfill.d.ts +10 -0
  133. package/blocks/CloudImageEditor/src/lib/applyFocusVisiblePolyfill.d.ts.map +1 -0
  134. package/blocks/CloudImageEditor/src/lib/applyFocusVisiblePolyfill.js +256 -0
  135. package/blocks/CloudImageEditor/src/lib/classNames.d.ts +3 -0
  136. package/blocks/CloudImageEditor/src/lib/classNames.d.ts.map +1 -0
  137. package/blocks/CloudImageEditor/src/lib/classNames.js +34 -0
  138. package/blocks/CloudImageEditor/src/lib/linspace.d.ts +8 -0
  139. package/blocks/CloudImageEditor/src/lib/linspace.d.ts.map +1 -0
  140. package/blocks/CloudImageEditor/src/lib/linspace.js +14 -0
  141. package/blocks/CloudImageEditor/src/lib/parseCropPreset.d.ts +2 -0
  142. package/blocks/CloudImageEditor/src/lib/parseCropPreset.d.ts.map +1 -0
  143. package/blocks/CloudImageEditor/src/lib/parseCropPreset.js +14 -0
  144. package/blocks/CloudImageEditor/src/lib/parseTabs.d.ts +2 -0
  145. package/blocks/CloudImageEditor/src/lib/parseTabs.d.ts.map +1 -0
  146. package/blocks/CloudImageEditor/src/lib/parseTabs.js +14 -0
  147. package/blocks/CloudImageEditor/src/lib/pick.d.ts +7 -0
  148. package/blocks/CloudImageEditor/src/lib/pick.d.ts.map +1 -0
  149. package/blocks/CloudImageEditor/src/lib/pick.js +15 -0
  150. package/blocks/CloudImageEditor/src/lib/preloadImage.d.ts +11 -0
  151. package/blocks/CloudImageEditor/src/lib/preloadImage.d.ts.map +1 -0
  152. package/blocks/CloudImageEditor/src/lib/preloadImage.js +38 -0
  153. package/blocks/CloudImageEditor/src/lib/transformationUtils.d.ts +14 -0
  154. package/blocks/CloudImageEditor/src/lib/transformationUtils.d.ts.map +1 -0
  155. package/blocks/CloudImageEditor/src/lib/transformationUtils.js +167 -0
  156. package/blocks/CloudImageEditor/src/state.d.ts +38 -0
  157. package/blocks/CloudImageEditor/src/state.d.ts.map +1 -0
  158. package/blocks/CloudImageEditor/src/state.js +92 -0
  159. package/blocks/CloudImageEditor/src/svg-sprite.d.ts +3 -0
  160. package/blocks/CloudImageEditor/src/svg-sprite.d.ts.map +1 -0
  161. package/blocks/CloudImageEditor/src/svg-sprite.js +1 -0
  162. package/blocks/CloudImageEditor/src/template.d.ts +2 -0
  163. package/blocks/CloudImageEditor/src/template.d.ts.map +1 -0
  164. package/blocks/CloudImageEditor/src/template.js +36 -0
  165. package/blocks/CloudImageEditor/src/toolbar-constants.d.ts +58 -0
  166. package/blocks/CloudImageEditor/src/toolbar-constants.d.ts.map +1 -0
  167. package/blocks/CloudImageEditor/src/toolbar-constants.js +114 -0
  168. package/blocks/CloudImageEditor/src/types.d.ts +58 -0
  169. package/blocks/CloudImageEditor/src/types.d.ts.map +1 -0
  170. package/blocks/CloudImageEditor/src/types.js +61 -0
  171. package/blocks/CloudImageEditor/src/util.d.ts +2 -0
  172. package/blocks/CloudImageEditor/src/util.d.ts.map +1 -0
  173. package/blocks/CloudImageEditor/src/util.js +19 -0
  174. package/blocks/CloudImageEditorActivity/CloudImageEditorActivity.d.ts +31 -0
  175. package/blocks/CloudImageEditorActivity/CloudImageEditorActivity.d.ts.map +1 -0
  176. package/blocks/CloudImageEditorActivity/CloudImageEditorActivity.js +113 -0
  177. package/blocks/CloudImageEditorActivity/index.css +13 -0
  178. package/blocks/CloudImageEditorActivity/test.d.ts +2 -0
  179. package/blocks/CloudImageEditorActivity/test.d.ts.map +1 -0
  180. package/blocks/CloudImageEditorActivity/test.js +9 -0
  181. package/blocks/Config/Config.d.ts +67 -0
  182. package/blocks/Config/Config.d.ts.map +1 -0
  183. package/blocks/Config/Config.js +246 -0
  184. package/blocks/Config/config.css +3 -0
  185. package/blocks/Config/initialConfig.d.ts +6 -0
  186. package/blocks/Config/initialConfig.d.ts.map +1 -0
  187. package/blocks/Config/initialConfig.js +69 -0
  188. package/blocks/Config/normalizeConfigValue.d.ts +3 -0
  189. package/blocks/Config/normalizeConfigValue.d.ts.map +1 -0
  190. package/blocks/Config/normalizeConfigValue.js +177 -0
  191. package/blocks/Copyright/Copyright.d.ts +4 -0
  192. package/blocks/Copyright/Copyright.d.ts.map +1 -0
  193. package/blocks/Copyright/Copyright.js +24 -0
  194. package/blocks/Copyright/copyright.css +31 -0
  195. package/blocks/DropArea/DropArea.d.ts +49 -0
  196. package/blocks/DropArea/DropArea.d.ts.map +1 -0
  197. package/blocks/DropArea/DropArea.js +273 -0
  198. package/blocks/DropArea/addDropzone.d.ts +21 -0
  199. package/blocks/DropArea/addDropzone.d.ts.map +1 -0
  200. package/blocks/DropArea/addDropzone.js +137 -0
  201. package/blocks/DropArea/drop-area.css +188 -0
  202. package/blocks/DropArea/getDropItems.d.ts +16 -0
  203. package/blocks/DropArea/getDropItems.d.ts.map +1 -0
  204. package/blocks/DropArea/getDropItems.js +167 -0
  205. package/blocks/ExternalSource/ExternalSource.d.ts +98 -0
  206. package/blocks/ExternalSource/ExternalSource.d.ts.map +1 -0
  207. package/blocks/ExternalSource/ExternalSource.js +268 -0
  208. package/blocks/ExternalSource/buildStyles.d.ts +27 -0
  209. package/blocks/ExternalSource/buildStyles.d.ts.map +1 -0
  210. package/blocks/ExternalSource/buildStyles.js +133 -0
  211. package/blocks/ExternalSource/external-source.css +65 -0
  212. package/blocks/ExternalSource/messages.d.ts +3 -0
  213. package/blocks/ExternalSource/messages.d.ts.map +1 -0
  214. package/blocks/ExternalSource/messages.js +35 -0
  215. package/blocks/ExternalSource/query-string.d.ts +8 -0
  216. package/blocks/ExternalSource/query-string.d.ts.map +1 -0
  217. package/blocks/ExternalSource/query-string.js +14 -0
  218. package/blocks/FileItem/FileItem.d.ts +97 -0
  219. package/blocks/FileItem/FileItem.d.ts.map +1 -0
  220. package/blocks/FileItem/FileItem.js +460 -0
  221. package/blocks/FileItem/file-item.css +140 -0
  222. package/blocks/FormInput/FormInput.d.ts +7 -0
  223. package/blocks/FormInput/FormInput.d.ts.map +1 -0
  224. package/blocks/FormInput/FormInput.js +92 -0
  225. package/blocks/Icon/Icon.d.ts +12 -0
  226. package/blocks/Icon/Icon.d.ts.map +1 -0
  227. package/blocks/Icon/Icon.js +44 -0
  228. package/blocks/Icon/icon.css +12 -0
  229. package/blocks/Img/Img.d.ts +4 -0
  230. package/blocks/Img/Img.d.ts.map +1 -0
  231. package/blocks/Img/Img.js +21 -0
  232. package/blocks/Img/ImgBase.d.ts +80 -0
  233. package/blocks/Img/ImgBase.d.ts.map +1 -0
  234. package/blocks/Img/ImgBase.js +408 -0
  235. package/blocks/Img/ImgConfig.d.ts +31 -0
  236. package/blocks/Img/ImgConfig.d.ts.map +1 -0
  237. package/blocks/Img/ImgConfig.js +102 -0
  238. package/blocks/Img/configurations.d.ts +12 -0
  239. package/blocks/Img/configurations.d.ts.map +1 -0
  240. package/blocks/Img/configurations.js +14 -0
  241. package/blocks/Img/props-map.d.ts +29 -0
  242. package/blocks/Img/props-map.d.ts.map +1 -0
  243. package/blocks/Img/props-map.js +34 -0
  244. package/blocks/Img/test.css +16 -0
  245. package/blocks/Img/utils/parseObjectToString.d.ts +2 -0
  246. package/blocks/Img/utils/parseObjectToString.d.ts.map +1 -0
  247. package/blocks/Img/utils/parseObjectToString.js +13 -0
  248. package/blocks/Modal/Modal.d.ts +24 -0
  249. package/blocks/Modal/Modal.d.ts.map +1 -0
  250. package/blocks/Modal/Modal.js +116 -0
  251. package/blocks/Modal/modal.css +92 -0
  252. package/blocks/ProgressBar/ProgressBar.d.ts +10 -0
  253. package/blocks/ProgressBar/ProgressBar.d.ts.map +1 -0
  254. package/blocks/ProgressBar/ProgressBar.js +38 -0
  255. package/blocks/ProgressBar/progress-bar.css +25 -0
  256. package/blocks/ProgressBarCommon/ProgressBarCommon.d.ts +8 -0
  257. package/blocks/ProgressBarCommon/ProgressBarCommon.d.ts.map +1 -0
  258. package/blocks/ProgressBarCommon/ProgressBarCommon.js +44 -0
  259. package/blocks/ProgressBarCommon/progress-bar-common.css +16 -0
  260. package/blocks/Range/Range.d.ts +16 -0
  261. package/blocks/Range/Range.d.ts.map +1 -0
  262. package/blocks/Range/Range.js +44 -0
  263. package/blocks/Range/range.css +65 -0
  264. package/blocks/Select/Select.d.ts +9 -0
  265. package/blocks/Select/Select.d.ts.map +1 -0
  266. package/blocks/Select/Select.js +35 -0
  267. package/blocks/Select/select.css +22 -0
  268. package/blocks/SimpleBtn/SimpleBtn.d.ts +26 -0
  269. package/blocks/SimpleBtn/SimpleBtn.d.ts.map +1 -0
  270. package/blocks/SimpleBtn/SimpleBtn.js +54 -0
  271. package/blocks/SimpleBtn/simple-btn.css +64 -0
  272. package/blocks/SourceBtn/SourceBtn.d.ts +58 -0
  273. package/blocks/SourceBtn/SourceBtn.d.ts.map +1 -0
  274. package/blocks/SourceBtn/SourceBtn.js +145 -0
  275. package/blocks/SourceBtn/source-btn.css +45 -0
  276. package/blocks/SourceList/SourceList.d.ts +4 -0
  277. package/blocks/SourceList/SourceList.d.ts.map +1 -0
  278. package/blocks/SourceList/SourceList.js +20 -0
  279. package/blocks/StartFrom/StartFrom.d.ts +7 -0
  280. package/blocks/StartFrom/StartFrom.d.ts.map +1 -0
  281. package/blocks/StartFrom/StartFrom.js +14 -0
  282. package/blocks/StartFrom/start-from.css +32 -0
  283. package/blocks/UploadCtxProvider/EventEmitter.d.ts +107 -0
  284. package/blocks/UploadCtxProvider/EventEmitter.d.ts.map +1 -0
  285. package/blocks/UploadCtxProvider/EventEmitter.js +132 -0
  286. package/blocks/UploadCtxProvider/UploadCtxProvider.d.ts +35 -0
  287. package/blocks/UploadCtxProvider/UploadCtxProvider.d.ts.map +1 -0
  288. package/blocks/UploadCtxProvider/UploadCtxProvider.js +45 -0
  289. package/blocks/UploadList/UploadList.d.ts +59 -0
  290. package/blocks/UploadList/UploadList.d.ts.map +1 -0
  291. package/blocks/UploadList/UploadList.js +237 -0
  292. package/blocks/UploadList/upload-list.css +74 -0
  293. package/blocks/UrlSource/UrlSource.d.ts +9 -0
  294. package/blocks/UrlSource/UrlSource.d.ts.map +1 -0
  295. package/blocks/UrlSource/UrlSource.js +61 -0
  296. package/blocks/UrlSource/url-source.css +24 -0
  297. package/blocks/svg-backgrounds/svg-backgrounds.d.ts +17 -0
  298. package/blocks/svg-backgrounds/svg-backgrounds.d.ts.map +1 -0
  299. package/blocks/svg-backgrounds/svg-backgrounds.js +45 -0
  300. package/blocks/themes/uc-basic/common.css +116 -0
  301. package/blocks/themes/uc-basic/config.css +4 -0
  302. package/blocks/themes/uc-basic/index.css +32 -0
  303. package/blocks/themes/uc-basic/svg-sprite.d.ts +3 -0
  304. package/blocks/themes/uc-basic/svg-sprite.d.ts.map +1 -0
  305. package/blocks/themes/uc-basic/svg-sprite.js +1 -0
  306. package/blocks/themes/uc-basic/theme.css +232 -0
  307. package/blocks/utils/UploadSource.d.ts +9 -0
  308. package/blocks/utils/UploadSource.d.ts.map +1 -0
  309. package/blocks/utils/UploadSource.js +8 -0
  310. package/blocks/utils/abilities.d.ts +2 -0
  311. package/blocks/utils/abilities.d.ts.map +1 -0
  312. package/blocks/utils/abilities.js +3 -0
  313. package/blocks/utils/comma-separated.d.ts +3 -0
  314. package/blocks/utils/comma-separated.d.ts.map +1 -0
  315. package/blocks/utils/comma-separated.js +19 -0
  316. package/blocks/utils/debounce.d.ts +10 -0
  317. package/blocks/utils/debounce.d.ts.map +1 -0
  318. package/blocks/utils/debounce.js +22 -0
  319. package/blocks/utils/resizeImage.d.ts +6 -0
  320. package/blocks/utils/resizeImage.d.ts.map +1 -0
  321. package/blocks/utils/resizeImage.js +40 -0
  322. package/blocks/utils/throttle.d.ts +4 -0
  323. package/blocks/utils/throttle.d.ts.map +1 -0
  324. package/blocks/utils/throttle.js +45 -0
  325. package/blocks/utils/userAgent.d.ts +6 -0
  326. package/blocks/utils/userAgent.d.ts.map +1 -0
  327. package/blocks/utils/userAgent.js +14 -0
  328. package/env.d.ts +4 -0
  329. package/env.d.ts.map +1 -0
  330. package/env.js +3 -0
  331. package/index.d.ts +39 -0
  332. package/index.d.ts.map +1 -0
  333. package/index.js +51 -0
  334. package/index.ssr.d.ts +961 -0
  335. package/index.ssr.d.ts.map +1 -0
  336. package/index.ssr.js +1461 -0
  337. package/locales/file-uploader/ar.d.ts +114 -0
  338. package/locales/file-uploader/ar.d.ts.map +1 -0
  339. package/locales/file-uploader/ar.js +113 -0
  340. package/locales/file-uploader/az.d.ts +106 -0
  341. package/locales/file-uploader/az.d.ts.map +1 -0
  342. package/locales/file-uploader/az.js +105 -0
  343. package/locales/file-uploader/ca.d.ts +108 -0
  344. package/locales/file-uploader/ca.d.ts.map +1 -0
  345. package/locales/file-uploader/ca.js +108 -0
  346. package/locales/file-uploader/cs.d.ts +110 -0
  347. package/locales/file-uploader/cs.d.ts.map +1 -0
  348. package/locales/file-uploader/cs.js +110 -0
  349. package/locales/file-uploader/da.d.ts +106 -0
  350. package/locales/file-uploader/da.d.ts.map +1 -0
  351. package/locales/file-uploader/da.js +106 -0
  352. package/locales/file-uploader/de.d.ts +106 -0
  353. package/locales/file-uploader/de.d.ts.map +1 -0
  354. package/locales/file-uploader/de.js +107 -0
  355. package/locales/file-uploader/el.d.ts +106 -0
  356. package/locales/file-uploader/el.d.ts.map +1 -0
  357. package/locales/file-uploader/el.js +107 -0
  358. package/locales/file-uploader/en.d.ts +106 -0
  359. package/locales/file-uploader/en.d.ts.map +1 -0
  360. package/locales/file-uploader/en.js +105 -0
  361. package/locales/file-uploader/es.d.ts +108 -0
  362. package/locales/file-uploader/es.d.ts.map +1 -0
  363. package/locales/file-uploader/es.js +108 -0
  364. package/locales/file-uploader/et.d.ts +106 -0
  365. package/locales/file-uploader/et.d.ts.map +1 -0
  366. package/locales/file-uploader/et.js +105 -0
  367. package/locales/file-uploader/fr.d.ts +108 -0
  368. package/locales/file-uploader/fr.d.ts.map +1 -0
  369. package/locales/file-uploader/fr.js +108 -0
  370. package/locales/file-uploader/he.d.ts +108 -0
  371. package/locales/file-uploader/he.d.ts.map +1 -0
  372. package/locales/file-uploader/he.js +107 -0
  373. package/locales/file-uploader/hy.d.ts +106 -0
  374. package/locales/file-uploader/hy.d.ts.map +1 -0
  375. package/locales/file-uploader/hy.js +105 -0
  376. package/locales/file-uploader/is.d.ts +106 -0
  377. package/locales/file-uploader/is.d.ts.map +1 -0
  378. package/locales/file-uploader/is.js +105 -0
  379. package/locales/file-uploader/it.d.ts +108 -0
  380. package/locales/file-uploader/it.d.ts.map +1 -0
  381. package/locales/file-uploader/it.js +108 -0
  382. package/locales/file-uploader/ja.d.ts +106 -0
  383. package/locales/file-uploader/ja.d.ts.map +1 -0
  384. package/locales/file-uploader/ja.js +105 -0
  385. package/locales/file-uploader/ka.d.ts +106 -0
  386. package/locales/file-uploader/ka.d.ts.map +1 -0
  387. package/locales/file-uploader/ka.js +105 -0
  388. package/locales/file-uploader/kk.d.ts +106 -0
  389. package/locales/file-uploader/kk.d.ts.map +1 -0
  390. package/locales/file-uploader/kk.js +105 -0
  391. package/locales/file-uploader/ko.d.ts +106 -0
  392. package/locales/file-uploader/ko.d.ts.map +1 -0
  393. package/locales/file-uploader/ko.js +104 -0
  394. package/locales/file-uploader/lv.d.ts +108 -0
  395. package/locales/file-uploader/lv.d.ts.map +1 -0
  396. package/locales/file-uploader/lv.js +107 -0
  397. package/locales/file-uploader/nb.d.ts +106 -0
  398. package/locales/file-uploader/nb.d.ts.map +1 -0
  399. package/locales/file-uploader/nb.js +105 -0
  400. package/locales/file-uploader/nl.d.ts +106 -0
  401. package/locales/file-uploader/nl.d.ts.map +1 -0
  402. package/locales/file-uploader/nl.js +106 -0
  403. package/locales/file-uploader/pl.d.ts +110 -0
  404. package/locales/file-uploader/pl.d.ts.map +1 -0
  405. package/locales/file-uploader/pl.js +109 -0
  406. package/locales/file-uploader/pt.d.ts +108 -0
  407. package/locales/file-uploader/pt.d.ts.map +1 -0
  408. package/locales/file-uploader/pt.js +108 -0
  409. package/locales/file-uploader/ro.d.ts +108 -0
  410. package/locales/file-uploader/ro.d.ts.map +1 -0
  411. package/locales/file-uploader/ro.js +108 -0
  412. package/locales/file-uploader/ru.d.ts +110 -0
  413. package/locales/file-uploader/ru.d.ts.map +1 -0
  414. package/locales/file-uploader/ru.js +109 -0
  415. package/locales/file-uploader/sk.d.ts +110 -0
  416. package/locales/file-uploader/sk.d.ts.map +1 -0
  417. package/locales/file-uploader/sk.js +109 -0
  418. package/locales/file-uploader/sr.d.ts +108 -0
  419. package/locales/file-uploader/sr.d.ts.map +1 -0
  420. package/locales/file-uploader/sr.js +107 -0
  421. package/locales/file-uploader/sv.d.ts +106 -0
  422. package/locales/file-uploader/sv.d.ts.map +1 -0
  423. package/locales/file-uploader/sv.js +105 -0
  424. package/locales/file-uploader/tr.d.ts +106 -0
  425. package/locales/file-uploader/tr.d.ts.map +1 -0
  426. package/locales/file-uploader/tr.js +105 -0
  427. package/locales/file-uploader/uk.d.ts +110 -0
  428. package/locales/file-uploader/uk.d.ts.map +1 -0
  429. package/locales/file-uploader/uk.js +109 -0
  430. package/locales/file-uploader/vi.d.ts +106 -0
  431. package/locales/file-uploader/vi.d.ts.map +1 -0
  432. package/locales/file-uploader/vi.js +105 -0
  433. package/locales/file-uploader/zh-TW.d.ts +106 -0
  434. package/locales/file-uploader/zh-TW.d.ts.map +1 -0
  435. package/locales/file-uploader/zh-TW.js +105 -0
  436. package/locales/file-uploader/zh.d.ts +106 -0
  437. package/locales/file-uploader/zh.d.ts.map +1 -0
  438. package/locales/file-uploader/zh.js +105 -0
  439. package/package.json +142 -0
  440. package/solutions/adaptive-image/index.d.ts +3 -0
  441. package/solutions/adaptive-image/index.d.ts.map +1 -0
  442. package/solutions/adaptive-image/index.js +5 -0
  443. package/solutions/cloud-image-editor/CloudImageEditor.d.ts +4 -0
  444. package/solutions/cloud-image-editor/CloudImageEditor.d.ts.map +1 -0
  445. package/solutions/cloud-image-editor/CloudImageEditor.js +12 -0
  446. package/solutions/cloud-image-editor/index.css +2 -0
  447. package/solutions/cloud-image-editor/index.d.ts +6 -0
  448. package/solutions/cloud-image-editor/index.d.ts.map +1 -0
  449. package/solutions/cloud-image-editor/index.js +11 -0
  450. package/solutions/file-uploader/inline/FileUploaderInline.d.ts +27 -0
  451. package/solutions/file-uploader/inline/FileUploaderInline.d.ts.map +1 -0
  452. package/solutions/file-uploader/inline/FileUploaderInline.js +75 -0
  453. package/solutions/file-uploader/inline/index.css +54 -0
  454. package/solutions/file-uploader/inline/index.d.ts +2 -0
  455. package/solutions/file-uploader/inline/index.d.ts.map +1 -0
  456. package/solutions/file-uploader/inline/index.js +1 -0
  457. package/solutions/file-uploader/minimal/FileUploaderMinimal.d.ts +7 -0
  458. package/solutions/file-uploader/minimal/FileUploaderMinimal.d.ts.map +1 -0
  459. package/solutions/file-uploader/minimal/FileUploaderMinimal.js +46 -0
  460. package/solutions/file-uploader/minimal/index.css +137 -0
  461. package/solutions/file-uploader/minimal/index.d.ts +14 -0
  462. package/solutions/file-uploader/minimal/index.d.ts.map +1 -0
  463. package/solutions/file-uploader/minimal/index.js +13 -0
  464. package/solutions/file-uploader/regular/FileUploaderRegular.d.ts +26 -0
  465. package/solutions/file-uploader/regular/FileUploaderRegular.d.ts.map +1 -0
  466. package/solutions/file-uploader/regular/FileUploaderRegular.js +66 -0
  467. package/solutions/file-uploader/regular/index.css +1 -0
  468. package/solutions/file-uploader/regular/index.d.ts +2 -0
  469. package/solutions/file-uploader/regular/index.d.ts.map +1 -0
  470. package/solutions/file-uploader/regular/index.js +1 -0
  471. package/types/events.d.ts +5 -0
  472. package/types/events.js +1 -0
  473. package/types/exported.d.ts +295 -0
  474. package/types/exported.js +1 -0
  475. package/types/global.d.ts +8 -0
  476. package/types/https.d.ts +1 -0
  477. package/types/index.d.ts +2 -0
  478. package/types/index.js +3 -0
  479. package/types/jsx.d.ts +63 -0
  480. package/types/jsx.js +1 -0
  481. package/utils/WindowHeightTracker.d.ts +24 -0
  482. package/utils/WindowHeightTracker.d.ts.map +1 -0
  483. package/utils/WindowHeightTracker.js +51 -0
  484. package/utils/cdn-utils.d.ts +59 -0
  485. package/utils/cdn-utils.d.ts.map +1 -0
  486. package/utils/cdn-utils.js +201 -0
  487. package/utils/cdn-utils.test.d.ts +2 -0
  488. package/utils/cdn-utils.test.d.ts.map +1 -0
  489. package/utils/cdn-utils.test.js +227 -0
  490. package/utils/delay.d.ts +2 -0
  491. package/utils/delay.d.ts.map +1 -0
  492. package/utils/delay.js +4 -0
  493. package/utils/fileTypes.d.ts +8 -0
  494. package/utils/fileTypes.d.ts.map +1 -0
  495. package/utils/fileTypes.js +95 -0
  496. package/utils/fileTypes.test.d.ts +2 -0
  497. package/utils/fileTypes.test.d.ts.map +1 -0
  498. package/utils/fileTypes.test.js +89 -0
  499. package/utils/getLocaleDirection.d.ts +2 -0
  500. package/utils/getLocaleDirection.d.ts.map +1 -0
  501. package/utils/getLocaleDirection.js +18 -0
  502. package/utils/getPluralForm.d.ts +3 -0
  503. package/utils/getPluralForm.d.ts.map +1 -0
  504. package/utils/getPluralForm.js +13 -0
  505. package/utils/getPluralForm.test.d.ts +2 -0
  506. package/utils/getPluralForm.test.d.ts.map +1 -0
  507. package/utils/getPluralForm.test.js +16 -0
  508. package/utils/ifRef.d.ts +7 -0
  509. package/utils/ifRef.d.ts.map +1 -0
  510. package/utils/ifRef.js +9 -0
  511. package/utils/isSecureTokenExpired.d.ts +4 -0
  512. package/utils/isSecureTokenExpired.d.ts.map +1 -0
  513. package/utils/isSecureTokenExpired.js +17 -0
  514. package/utils/isSecureTokenExpired.test.d.ts +2 -0
  515. package/utils/isSecureTokenExpired.test.d.ts.map +1 -0
  516. package/utils/isSecureTokenExpired.test.js +33 -0
  517. package/utils/memoize.d.ts +2 -0
  518. package/utils/memoize.d.ts.map +1 -0
  519. package/utils/memoize.js +23 -0
  520. package/utils/memoize.test.d.ts +2 -0
  521. package/utils/memoize.test.d.ts.map +1 -0
  522. package/utils/memoize.test.js +38 -0
  523. package/utils/mixinClass.d.ts +8 -0
  524. package/utils/mixinClass.d.ts.map +1 -0
  525. package/utils/mixinClass.js +18 -0
  526. package/utils/parseCdnUrl.d.ts +9 -0
  527. package/utils/parseCdnUrl.d.ts.map +1 -0
  528. package/utils/parseCdnUrl.js +20 -0
  529. package/utils/parseCdnUrl.test.d.ts +2 -0
  530. package/utils/parseCdnUrl.test.d.ts.map +1 -0
  531. package/utils/parseCdnUrl.test.js +78 -0
  532. package/utils/parseShrink.d.ts +5 -0
  533. package/utils/parseShrink.d.ts.map +1 -0
  534. package/utils/parseShrink.js +34 -0
  535. package/utils/parseShrink.test.d.ts +2 -0
  536. package/utils/parseShrink.test.d.ts.map +1 -0
  537. package/utils/parseShrink.test.js +26 -0
  538. package/utils/prettyBytes.d.ts +11 -0
  539. package/utils/prettyBytes.d.ts.map +1 -0
  540. package/utils/prettyBytes.js +64 -0
  541. package/utils/prettyBytes.test.d.ts +2 -0
  542. package/utils/prettyBytes.test.d.ts.map +1 -0
  543. package/utils/prettyBytes.test.js +99 -0
  544. package/utils/stringToArray.d.ts +2 -0
  545. package/utils/stringToArray.d.ts.map +1 -0
  546. package/utils/stringToArray.js +11 -0
  547. package/utils/stringToArray.test.d.ts +2 -0
  548. package/utils/stringToArray.test.d.ts.map +1 -0
  549. package/utils/stringToArray.test.js +20 -0
  550. package/utils/template-utils.d.ts +40 -0
  551. package/utils/template-utils.d.ts.map +1 -0
  552. package/utils/template-utils.js +50 -0
  553. package/utils/template-utils.test.d.ts +2 -0
  554. package/utils/template-utils.test.d.ts.map +1 -0
  555. package/utils/template-utils.test.js +56 -0
  556. package/utils/toKebabCase.d.ts +3 -0
  557. package/utils/toKebabCase.d.ts.map +1 -0
  558. package/utils/toKebabCase.js +15 -0
  559. package/utils/toKebabCase.test.d.ts +2 -0
  560. package/utils/toKebabCase.test.d.ts.map +1 -0
  561. package/utils/toKebabCase.test.js +11 -0
  562. package/utils/transparentPixelSrc.d.ts +2 -0
  563. package/utils/transparentPixelSrc.d.ts.map +1 -0
  564. package/utils/transparentPixelSrc.js +2 -0
  565. package/utils/uniqueArray.d.ts +2 -0
  566. package/utils/uniqueArray.d.ts.map +1 -0
  567. package/utils/uniqueArray.js +8 -0
  568. package/utils/uniqueArray.test.d.ts +2 -0
  569. package/utils/uniqueArray.test.d.ts.map +1 -0
  570. package/utils/uniqueArray.test.js +8 -0
  571. package/utils/validators/collection/index.d.ts +3 -0
  572. package/utils/validators/collection/index.d.ts.map +1 -0
  573. package/utils/validators/collection/index.js +2 -0
  574. package/utils/validators/collection/validateCollectionUploadError.d.ts +3 -0
  575. package/utils/validators/collection/validateCollectionUploadError.d.ts.map +1 -0
  576. package/utils/validators/collection/validateCollectionUploadError.js +11 -0
  577. package/utils/validators/collection/validateMultiple.d.ts +3 -0
  578. package/utils/validators/collection/validateMultiple.d.ts.map +1 -0
  579. package/utils/validators/collection/validateMultiple.js +43 -0
  580. package/utils/validators/file/index.d.ts +5 -0
  581. package/utils/validators/file/index.d.ts.map +1 -0
  582. package/utils/validators/file/index.js +4 -0
  583. package/utils/validators/file/validateFileType.d.ts +3 -0
  584. package/utils/validators/file/validateFileType.d.ts.map +1 -0
  585. package/utils/validators/file/validateFileType.js +30 -0
  586. package/utils/validators/file/validateIsImage.d.ts +3 -0
  587. package/utils/validators/file/validateIsImage.d.ts.map +1 -0
  588. package/utils/validators/file/validateIsImage.js +25 -0
  589. package/utils/validators/file/validateMaxSizeLimit.d.ts +3 -0
  590. package/utils/validators/file/validateMaxSizeLimit.d.ts.map +1 -0
  591. package/utils/validators/file/validateMaxSizeLimit.js +15 -0
  592. package/utils/validators/file/validateUploadError.d.ts +3 -0
  593. package/utils/validators/file/validateUploadError.d.ts.map +1 -0
  594. package/utils/validators/file/validateUploadError.js +48 -0
  595. package/utils/waitForAttribute.d.ts +8 -0
  596. package/utils/waitForAttribute.d.ts.map +1 -0
  597. package/utils/waitForAttribute.js +43 -0
  598. package/utils/waitForAttribute.test.d.ts +2 -0
  599. package/utils/waitForAttribute.test.d.ts.map +1 -0
  600. package/utils/waitForAttribute.test.js +78 -0
  601. package/utils/warnOnce.d.ts +3 -0
  602. package/utils/warnOnce.d.ts.map +1 -0
  603. package/utils/warnOnce.js +11 -0
  604. package/utils/wildcardRegexp.d.ts +2 -0
  605. package/utils/wildcardRegexp.d.ts.map +1 -0
  606. package/utils/wildcardRegexp.js +17 -0
  607. package/utils/wildcardRegexp.test.d.ts +2 -0
  608. package/utils/wildcardRegexp.test.d.ts.map +1 -0
  609. package/utils/wildcardRegexp.test.js +19 -0
  610. package/web/blocks.iife.min.js +29 -0
  611. package/web/blocks.min.js +29 -0
  612. package/web/lr-basic.min.css +1 -0
  613. package/web/lr-cloud-image-editor.min.css +1 -0
  614. package/web/lr-cloud-image-editor.min.js +29 -0
  615. package/web/lr-file-uploader-inline.min.css +1 -0
  616. package/web/lr-file-uploader-inline.min.js +29 -0
  617. package/web/lr-file-uploader-minimal.min.css +1 -0
  618. package/web/lr-file-uploader-minimal.min.js +28 -0
  619. package/web/lr-file-uploader-regular.min.css +1 -0
  620. package/web/lr-file-uploader-regular.min.js +29 -0
  621. package/web/lr-img.min.js +28 -0
  622. package/web/uc-basic.min.css +1 -0
  623. package/web/uc-cloud-image-editor.min.css +1 -0
  624. package/web/uc-cloud-image-editor.min.js +29 -0
  625. package/web/uc-file-uploader-inline.min.css +1 -0
  626. package/web/uc-file-uploader-inline.min.js +29 -0
  627. package/web/uc-file-uploader-minimal.min.css +1 -0
  628. package/web/uc-file-uploader-minimal.min.js +28 -0
  629. package/web/uc-file-uploader-regular.min.css +1 -0
  630. package/web/uc-file-uploader-regular.min.js +29 -0
  631. package/web/uc-img.min.js +28 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CameraSource.d.ts","sourceRoot":"","sources":["CameraSource.js"],"names":[],"mappings":"AAMA;IAEE,uBAA+C;IAE/C,eAAe;IACf,0BAAyB;IAEzB,WA0BE;IAbE,qBAAqB;IACrB,sCAAuC;IAc3C,eAAe;IACf,oBAKE;IAEF,eAAe;IACf,sBAME;IAEF,eAAe;IACf,iCAEE;IAEF;;;OAGG;IACH,6BA2BQ;IAER,eAAe;IACf,8BASC;IAED,eAAe;IACf,iBAuCC;IAnBC,eAAe;IACf,gBAA+C;IAC/C,eAAe;IACf,aAAyC;IASvC,eAAe;IACf,mBAAsB;IAQ1B,eAAe;IACf,qBAMC;IAED,eAAe;IACf,cAkBC;IAED,8BAgCC;CACF;;;;8BArN6B,iCAAiC"}
@@ -0,0 +1,253 @@
1
+ import { UploaderBlock } from '../../abstract/UploaderBlock.js';
2
+ import { ActivityBlock } from '../../abstract/ActivityBlock.js';
3
+ import { canUsePermissionsApi } from '../utils/abilities.js';
4
+ import { debounce } from '../utils/debounce.js';
5
+ import { UploadSource } from '../utils/UploadSource.js';
6
+
7
+ export class CameraSource extends UploaderBlock {
8
+ couldBeCtxOwner = true;
9
+ activityType = ActivityBlock.activities.CAMERA;
10
+
11
+ /** @private */
12
+ _unsubPermissions = null;
13
+
14
+ init$ = {
15
+ ...this.init$,
16
+ video: null,
17
+ videoTransformCss: null,
18
+ shotBtnDisabled: true,
19
+ videoHidden: true,
20
+ messageHidden: true,
21
+ requestBtnHidden: canUsePermissionsApi(),
22
+ cameraSelectOptions: null,
23
+ cameraSelectHidden: true,
24
+ l10nMessage: '',
25
+
26
+ onCameraSelectChange: (e) => {
27
+ /** @type {String} */
28
+ this._selectedCameraId = e.target.value;
29
+ this._capture();
30
+ },
31
+ onCancel: () => {
32
+ this.historyBack();
33
+ },
34
+ onShot: () => {
35
+ this._shot();
36
+ },
37
+ onRequestPermissions: () => {
38
+ this._capture();
39
+ },
40
+ };
41
+
42
+ /** @private */
43
+ _onActivate = () => {
44
+ if (canUsePermissionsApi()) {
45
+ this._subscribePermissions();
46
+ }
47
+ this._capture();
48
+ };
49
+
50
+ /** @private */
51
+ _onDeactivate = () => {
52
+ if (this._unsubPermissions) {
53
+ this._unsubPermissions();
54
+ }
55
+
56
+ this._stopCapture();
57
+ };
58
+
59
+ /** @private */
60
+ _handlePermissionsChange = () => {
61
+ this._capture();
62
+ };
63
+
64
+ /**
65
+ * @private
66
+ * @param {'granted' | 'denied' | 'prompt'} state
67
+ */
68
+ _setPermissionsState = debounce((state) => {
69
+ this.classList.toggle('uc-initialized', state === 'granted');
70
+
71
+ if (state === 'granted') {
72
+ this.set$({
73
+ videoHidden: false,
74
+ shotBtnDisabled: false,
75
+ messageHidden: true,
76
+ });
77
+ } else if (state === 'prompt') {
78
+ this.$.l10nMessage = 'camera-permissions-prompt';
79
+ this.set$({
80
+ videoHidden: true,
81
+ shotBtnDisabled: true,
82
+ messageHidden: false,
83
+ });
84
+ this._stopCapture();
85
+ } else {
86
+ this.$.l10nMessage = 'camera-permissions-denied';
87
+
88
+ this.set$({
89
+ videoHidden: true,
90
+ shotBtnDisabled: true,
91
+ messageHidden: false,
92
+ });
93
+ this._stopCapture();
94
+ }
95
+ }, 300);
96
+
97
+ /** @private */
98
+ async _subscribePermissions() {
99
+ try {
100
+ // @ts-ignore
101
+ let permissionsResponse = await navigator.permissions.query({ name: 'camera' });
102
+ permissionsResponse.addEventListener('change', this._handlePermissionsChange);
103
+ } catch (err) {
104
+ console.log('Failed to use permissions API. Fallback to manual request mode.', err);
105
+ this._capture();
106
+ }
107
+ }
108
+
109
+ /** @private */
110
+ async _capture() {
111
+ let constr = {
112
+ video: {
113
+ width: {
114
+ ideal: 1920,
115
+ },
116
+ height: {
117
+ ideal: 1080,
118
+ },
119
+ frameRate: {
120
+ ideal: 30,
121
+ },
122
+ },
123
+ audio: false,
124
+ };
125
+ if (this._selectedCameraId) {
126
+ constr.video.deviceId = {
127
+ exact: this._selectedCameraId,
128
+ };
129
+ }
130
+ /** @private */
131
+ this._canvas = document.createElement('canvas');
132
+ /** @private */
133
+ this._ctx = this._canvas.getContext('2d');
134
+
135
+ try {
136
+ this._setPermissionsState('prompt');
137
+ let stream = await navigator.mediaDevices.getUserMedia(constr);
138
+ stream.addEventListener('inactive', () => {
139
+ this._setPermissionsState('denied');
140
+ });
141
+ this.$.video = stream;
142
+ /** @private */
143
+ this._capturing = true;
144
+ this._setPermissionsState('granted');
145
+ } catch (err) {
146
+ this._setPermissionsState('denied');
147
+ console.error('Failed to capture camera', err);
148
+ }
149
+ }
150
+
151
+ /** @private */
152
+ _stopCapture() {
153
+ if (this._capturing) {
154
+ this.$.video?.getTracks()[0].stop();
155
+ this.$.video = null;
156
+ this._capturing = false;
157
+ }
158
+ }
159
+
160
+ /** @private */
161
+ _shot() {
162
+ this._canvas.height = this.ref.video['videoHeight'];
163
+ this._canvas.width = this.ref.video['videoWidth'];
164
+ // @ts-ignore
165
+ this._ctx.drawImage(this.ref.video, 0, 0);
166
+ const date = Date.now();
167
+ const name = `camera-${date}.jpeg`;
168
+ const format = 'image/jpeg';
169
+ this._canvas.toBlob((blob) => {
170
+ let file = new File([blob], name, {
171
+ lastModified: date,
172
+ type: format,
173
+ });
174
+ this.api.addFileFromObject(file, { source: UploadSource.CAMERA });
175
+ this.set$({
176
+ '*currentActivity': ActivityBlock.activities.UPLOAD_LIST,
177
+ });
178
+ }, format);
179
+ }
180
+
181
+ async initCallback() {
182
+ super.initCallback();
183
+ this.registerActivity(this.activityType, {
184
+ onActivate: this._onActivate,
185
+ onDeactivate: this._onDeactivate,
186
+ });
187
+
188
+ this.subConfigValue('cameraMirror', (val) => {
189
+ this.$.videoTransformCss = val ? 'scaleX(-1)' : null;
190
+ });
191
+
192
+ try {
193
+ let deviceList = await navigator.mediaDevices.enumerateDevices();
194
+ let cameraSelectOptions = deviceList
195
+ .filter((info) => {
196
+ return info.kind === 'videoinput';
197
+ })
198
+ .map((info, idx) => {
199
+ return {
200
+ text: info.label.trim() || `${this.l10n('caption-camera')} ${idx + 1}`,
201
+ value: info.deviceId,
202
+ };
203
+ });
204
+ if (cameraSelectOptions.length > 1) {
205
+ this.$.cameraSelectOptions = cameraSelectOptions;
206
+ this.$.cameraSelectHidden = false;
207
+ }
208
+ this._selectedCameraId = cameraSelectOptions[0]?.value;
209
+ } catch (err) {
210
+ // mediaDevices isn't available for HTTP
211
+ // TODO: handle this case
212
+ }
213
+ }
214
+ }
215
+
216
+ CameraSource.template = /* HTML */ `
217
+ <uc-activity-header>
218
+ <button type="button" class="uc-mini-btn" set="onclick: *historyBack">
219
+ <uc-icon name="back"></uc-icon>
220
+ </button>
221
+ <div set="@hidden: !cameraSelectHidden">
222
+ <uc-icon name="camera"></uc-icon>
223
+ <span l10n="caption-camera"></span>
224
+ </div>
225
+ <uc-select
226
+ class="uc-camera-select"
227
+ set="$.options: cameraSelectOptions; @hidden: cameraSelectHidden; onchange: onCameraSelectChange"
228
+ >
229
+ </uc-select>
230
+ <button type="button" class="uc-mini-btn uc-close-btn" set="onclick: *closeModal">
231
+ <uc-icon name="close"></uc-icon>
232
+ </button>
233
+ </uc-activity-header>
234
+ <div class="uc-content">
235
+ <video
236
+ autoplay
237
+ playsinline
238
+ set="srcObject: video; style.transform: videoTransformCss; @hidden: videoHidden"
239
+ ref="video"
240
+ ></video>
241
+ <div class="uc-message-box" set="@hidden: messageHidden">
242
+ <span l10n="l10nMessage"></span>
243
+ <button
244
+ type="button"
245
+ set="onclick: onRequestPermissions; @hidden: requestBtnHidden"
246
+ l10n="camera-permissions-request"
247
+ ></button>
248
+ </div>
249
+ <button type="button" class="uc-shot-btn" set="onclick: onShot; @disabled: shotBtnDisabled">
250
+ <uc-icon name="camera"></uc-icon>
251
+ </button>
252
+ </div>
253
+ `;
@@ -0,0 +1,107 @@
1
+ uc-camera-source {
2
+ position: relative;
3
+ display: flex;
4
+ flex-direction: column;
5
+ width: 100%;
6
+ height: 100%;
7
+ max-height: 100%;
8
+ overflow: hidden;
9
+ background-color: var(--uc-background);
10
+ border-radius: var(--uc-radius);
11
+ }
12
+
13
+ [uc-modal] uc-camera-source {
14
+ width: min(calc(var(--uc-dialog-max-width) - var(--uc-padding) * 2), calc(100vw - var(--uc-padding) * 2));
15
+ height: 100vh;
16
+ max-height: var(--modal-max-content-height);
17
+ }
18
+
19
+ uc-camera-source.uc-initialized {
20
+ height: max-content;
21
+ }
22
+
23
+ @media only screen and (max-width: 430px) {
24
+ uc-camera-source {
25
+ width: calc(100vw - var(--uc-padding) * 2);
26
+ height: var(--modal-content-height-fill, 100%);
27
+ }
28
+ }
29
+
30
+ uc-camera-source video {
31
+ display: block;
32
+ width: 100%;
33
+ max-height: 100%;
34
+ object-fit: contain;
35
+ object-position: center center;
36
+ background-color: var(--uc-muted);
37
+ border-radius: var(--uc-radius);
38
+ }
39
+
40
+ uc-camera-source .uc-toolbar {
41
+ position: absolute;
42
+ bottom: 0;
43
+ display: flex;
44
+ justify-content: space-between;
45
+ width: 100%;
46
+ padding: var(--uc-padding);
47
+ background-color: var(--uc-background);
48
+ }
49
+
50
+ uc-camera-source .uc-content {
51
+ display: flex;
52
+ flex: 1;
53
+ justify-content: center;
54
+ width: 100%;
55
+ padding: var(--uc-padding);
56
+ padding-top: 0;
57
+ overflow: hidden;
58
+ }
59
+
60
+ uc-camera-source .uc-message-box {
61
+ display: flex;
62
+ flex-direction: column;
63
+ grid-gap: 40px;
64
+ align-items: center;
65
+ justify-content: center;
66
+ padding: 40px 40px 0;
67
+ color: var(--uc-foreground);
68
+ }
69
+
70
+ uc-camera-source .uc-message-box button {
71
+ color: var(--uc-primary-foreground);
72
+ background-color: var(--uc-primary);
73
+ }
74
+
75
+ uc-camera-source .uc-shot-btn {
76
+ position: absolute;
77
+ bottom: 20px;
78
+ width: 58px;
79
+ height: 58px;
80
+ color: var(--uc-background);
81
+ background-color: var(--uc-foreground);
82
+ border-radius: 50%;
83
+ opacity: 0.85;
84
+ transition:
85
+ bottom var(--uc-transition),
86
+ opacity var(--uc-transition),
87
+ transform var(--uc-transition);
88
+ }
89
+
90
+ uc-camera-source .uc-shot-btn:hover {
91
+ transform: scale(1.05);
92
+ opacity: 1;
93
+ }
94
+
95
+ uc-camera-source .uc-shot-btn:active {
96
+ transform: scale(1);
97
+ opacity: 1;
98
+ }
99
+
100
+ uc-camera-source .uc-shot-btn[disabled] {
101
+ bottom: -80px;
102
+ }
103
+
104
+ uc-camera-source .uc-shot-btn uc-icon svg {
105
+ width: 20px;
106
+ height: 20px;
107
+ }
@@ -0,0 +1 @@
1
+ @import url('./src/css/index.css');
@@ -0,0 +1,2 @@
1
+ export * from "./src/index.js";
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["index.js"],"names":[],"mappings":""}
@@ -0,0 +1 @@
1
+ export * from './src/index.js';
@@ -0,0 +1,58 @@
1
+ export class CloudImageEditorBlock extends Block {
2
+ init$: {
3
+ '*originalUrl': null;
4
+ '*faderEl': null;
5
+ '*cropperEl': null;
6
+ '*imgEl': null;
7
+ '*imgContainerEl': null;
8
+ '*networkProblems': boolean;
9
+ '*imageSize': null;
10
+ '*editorTransformations': import("./types.js").Transformations;
11
+ '*cropPresetList': import("./types.js").CropPresetList;
12
+ '*tabList': ("crop" | "tuning" | "filters")[];
13
+ '*tabId': "crop";
14
+ entry: null;
15
+ extension: null;
16
+ editorMode: boolean;
17
+ modalCaption: string;
18
+ isImage: boolean;
19
+ msg: string;
20
+ src: string;
21
+ fileType: string;
22
+ showLoader: boolean;
23
+ uuid: null;
24
+ cdnUrl: null;
25
+ cropPreset: string;
26
+ tabs: string;
27
+ 'presence.networkProblems': boolean;
28
+ 'presence.modalCaption': boolean;
29
+ 'presence.editorToolbar': boolean;
30
+ 'presence.viewerToolbar': boolean;
31
+ '*on.retryNetwork': () => void;
32
+ '*on.apply': (transformations: import("./types.js").Transformations) => void;
33
+ '*on.cancel': () => void;
34
+ };
35
+ /** @private */
36
+ private _debouncedShowLoader;
37
+ /**
38
+ * @private
39
+ * @param {boolean} show
40
+ */
41
+ private _showLoader;
42
+ /**
43
+ * To proper work, we need non-zero size the element. So, we'll wait for it.
44
+ *
45
+ * @private
46
+ * @returns {Promise<void>}
47
+ */
48
+ private _waitForSize;
49
+ updateImage(): Promise<void>;
50
+ initEditor(): Promise<void>;
51
+ _imgLoading: boolean | undefined;
52
+ }
53
+ export namespace CloudImageEditorBlock {
54
+ export { TEMPLATE as template };
55
+ }
56
+ import { Block } from '../../../abstract/Block.js';
57
+ import { TEMPLATE } from './template.js';
58
+ //# sourceMappingURL=CloudImageEditorBlock.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CloudImageEditorBlock.d.ts","sourceRoot":"","sources":["CloudImageEditorBlock.js"],"names":[],"mappings":"AAmBA;IAOI;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;MAGC;IAGH,eAAe;IACf,6BAAkE;IAElE;;;OAGG;IACH,oBAEC;IAED;;;;;OAKG;IACH,qBAeC;IAYD,6BAkDC;IAED,4BA0FC;IA9EG,iCAAwB;CA+E7B;;;;sBA1NqB,4BAA4B;yBAezB,eAAe"}
@@ -0,0 +1,228 @@
1
+ // @ts-check
2
+ import { Block } from '../../../abstract/Block.js';
3
+ import {
4
+ createCdnUrl,
5
+ createCdnUrlModifiers,
6
+ createOriginalUrl,
7
+ extractOperations,
8
+ extractUuid,
9
+ } from '../../../utils/cdn-utils.js';
10
+ import { TRANSPARENT_PIXEL_SRC } from '../../../utils/transparentPixelSrc.js';
11
+ import { debounce } from '../../utils/debounce.js';
12
+ import { classNames } from './lib/classNames.js';
13
+ import { parseCropPreset } from './lib/parseCropPreset.js';
14
+ import { parseTabs } from './lib/parseTabs.js';
15
+ import { operationsToTransformations, transformationsToOperations } from './lib/transformationUtils.js';
16
+ import { initState } from './state.js';
17
+ import { TEMPLATE } from './template.js';
18
+ import { TabId } from './toolbar-constants.js';
19
+
20
+ export class CloudImageEditorBlock extends Block {
21
+ ctxOwner = true;
22
+ static styleAttrs = ['uc-cloud-image-editor'];
23
+
24
+ constructor() {
25
+ super();
26
+
27
+ this.init$ = {
28
+ ...this.init$,
29
+ ...initState(this),
30
+ };
31
+ }
32
+
33
+ /** @private */
34
+ _debouncedShowLoader = debounce(this._showLoader.bind(this), 300);
35
+
36
+ /**
37
+ * @private
38
+ * @param {boolean} show
39
+ */
40
+ _showLoader(show) {
41
+ this.$.showLoader = show;
42
+ }
43
+
44
+ /**
45
+ * To proper work, we need non-zero size the element. So, we'll wait for it.
46
+ *
47
+ * @private
48
+ * @returns {Promise<void>}
49
+ */
50
+ _waitForSize() {
51
+ const TIMEOUT = 3000;
52
+ return new Promise((resolve, reject) => {
53
+ const timeoutId = setTimeout(() => {
54
+ reject(new Error('[cloud-image-editor] timeout waiting for non-zero container size'));
55
+ }, TIMEOUT);
56
+ const resizeObserver = new ResizeObserver(([element]) => {
57
+ if (element.contentRect.width > 0 && element.contentRect.height > 0) {
58
+ resolve();
59
+ clearTimeout(timeoutId);
60
+ resizeObserver.disconnect();
61
+ }
62
+ });
63
+ resizeObserver.observe(this);
64
+ });
65
+ }
66
+
67
+ initCallback() {
68
+ super.initCallback();
69
+
70
+ this.$['*faderEl'] = this.ref['fader-el'];
71
+ this.$['*cropperEl'] = this.ref['cropper-el'];
72
+ this.$['*imgContainerEl'] = this.ref['img-container-el'];
73
+
74
+ this.initEditor();
75
+ }
76
+
77
+ async updateImage() {
78
+ if (!this.isConnected) {
79
+ return;
80
+ }
81
+ await this._waitForSize();
82
+
83
+ if (this.$.cdnUrl) {
84
+ const uuid = extractUuid(this.$.cdnUrl);
85
+ const originalUrl = createOriginalUrl(this.$.cdnUrl, uuid);
86
+ if (originalUrl === this.$['*originalUrl']) {
87
+ return;
88
+ }
89
+ this.$['*originalUrl'] = originalUrl;
90
+ const operations = extractOperations(this.$.cdnUrl);
91
+ const transformations = operationsToTransformations(operations);
92
+ this.$['*editorTransformations'] = transformations;
93
+ } else if (this.$.uuid) {
94
+ const originalUrl = createOriginalUrl(this.cfg.cdnCname, this.$.uuid);
95
+ if (originalUrl === this.$['*originalUrl']) {
96
+ return;
97
+ }
98
+ this.$['*originalUrl'] = originalUrl;
99
+ this.$['*editorTransformations'] = {};
100
+ } else {
101
+ throw new Error('No UUID nor CDN URL provided');
102
+ }
103
+
104
+ if (this.$['*tabId'] === TabId.CROP) {
105
+ this.$['*cropperEl'].deactivate({ reset: true });
106
+ } else {
107
+ this.$['*faderEl'].deactivate();
108
+ }
109
+
110
+ try {
111
+ const cdnUrl = createCdnUrl(this.$['*originalUrl'], createCdnUrlModifiers('json'));
112
+ const json = await fetch(cdnUrl).then((response) => response.json());
113
+
114
+ const { width, height } = /** @type {{ width: number; height: number }} */ (json);
115
+ this.$['*imageSize'] = { width, height };
116
+
117
+ if (this.$['*tabId'] === TabId.CROP) {
118
+ this.$['*cropperEl'].activate(this.$['*imageSize']);
119
+ } else {
120
+ this.$['*faderEl'].activate({ url: this.$['*originalUrl'] });
121
+ }
122
+ } catch (err) {
123
+ if (err) {
124
+ console.error('Failed to load image info', err);
125
+ }
126
+ }
127
+ }
128
+
129
+ async initEditor() {
130
+ try {
131
+ await this._waitForSize();
132
+ } catch (err) {
133
+ if (this.isConnected) {
134
+ // @ts-ignore TODO: fix this
135
+ console.error(err.message);
136
+ }
137
+ return;
138
+ }
139
+
140
+ this.ref['img-el'].addEventListener('load', () => {
141
+ this._imgLoading = false;
142
+ this._debouncedShowLoader(false);
143
+
144
+ if (this.$.src !== TRANSPARENT_PIXEL_SRC) {
145
+ this.$['*networkProblems'] = false;
146
+ }
147
+ });
148
+
149
+ this.ref['img-el'].addEventListener('error', () => {
150
+ this._imgLoading = false;
151
+ this._debouncedShowLoader(false);
152
+
153
+ this.$['*networkProblems'] = true;
154
+ });
155
+
156
+ this.sub('src', (src) => {
157
+ let el = this.ref['img-el'];
158
+ if (el.src !== src) {
159
+ this._imgLoading = true;
160
+ el.src = src || TRANSPARENT_PIXEL_SRC;
161
+ }
162
+ });
163
+
164
+ this.sub('cropPreset', (val) => {
165
+ this.$['*cropPresetList'] = parseCropPreset(val);
166
+ });
167
+
168
+ this.sub(
169
+ 'tabs',
170
+ /** @param {string} val */ (val) => {
171
+ this.$['*tabList'] = parseTabs(val);
172
+ },
173
+ );
174
+
175
+ this.sub('*tabId', (tabId) => {
176
+ this.ref['img-el'].className = classNames('uc-image', {
177
+ 'uc-image_hidden_to_cropper': tabId === TabId.CROP,
178
+ 'uc-image_hidden_effects': tabId !== TabId.CROP,
179
+ });
180
+ });
181
+
182
+ this.classList.add('uc-editor_ON');
183
+
184
+ this.sub('*networkProblems', (networkProblems) => {
185
+ this.$['presence.networkProblems'] = networkProblems;
186
+ this.$['presence.modalCaption'] = !networkProblems;
187
+ });
188
+
189
+ this.sub(
190
+ '*editorTransformations',
191
+ (transformations) => {
192
+ if (Object.keys(transformations).length === 0) {
193
+ return;
194
+ }
195
+ let originalUrl = this.$['*originalUrl'];
196
+ let cdnUrlModifiers = createCdnUrlModifiers(transformationsToOperations(transformations), 'preview');
197
+ let cdnUrl = createCdnUrl(originalUrl, cdnUrlModifiers);
198
+
199
+ /** @type {import('./types.js').ApplyResult} */
200
+ let eventData = {
201
+ originalUrl,
202
+ cdnUrlModifiers,
203
+ cdnUrl,
204
+ transformations,
205
+ };
206
+ this.dispatchEvent(
207
+ new CustomEvent('change', {
208
+ detail: eventData,
209
+ bubbles: true,
210
+ composed: true,
211
+ }),
212
+ );
213
+ },
214
+ false,
215
+ );
216
+
217
+ this.sub('uuid', (val) => val && this.updateImage());
218
+ this.sub('cdnUrl', (val) => val && this.updateImage());
219
+ }
220
+ }
221
+
222
+ CloudImageEditorBlock.template = TEMPLATE;
223
+ CloudImageEditorBlock.bindAttributes({
224
+ uuid: 'uuid',
225
+ 'cdn-url': 'cdnUrl',
226
+ 'crop-preset': 'cropPreset',
227
+ tabs: 'tabs',
228
+ });