@codingfactory/mediables-vue 2.0.1
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.
- package/dist/PixiFrameExporter-BTU38EVl.cjs +2 -0
- package/dist/PixiFrameExporter-BTU38EVl.cjs.map +1 -0
- package/dist/PixiFrameExporter-Bb3QNWP-.js +199 -0
- package/dist/PixiFrameExporter-Bb3QNWP-.js.map +1 -0
- package/dist/adapters/MediablesAdapter.d.ts +19 -0
- package/dist/adapters/SpatieAdapter.d.ts +18 -0
- package/dist/adapters/index.d.ts +18 -0
- package/dist/components/AdminMediaBrowser.vue.d.ts +11 -0
- package/dist/components/AdminMediaBrowserExample.vue.d.ts +2 -0
- package/dist/components/AdminMediaBulkActionsToolbar.vue.d.ts +2 -0
- package/dist/components/AdminMediaGrid.vue.d.ts +17 -0
- package/dist/components/AdminMediaListItem.vue.d.ts +10 -0
- package/dist/components/AdminMediaManager.vue.d.ts +25 -0
- package/dist/components/AdminMediaUploader.vue.d.ts +11 -0
- package/dist/components/AlbumBrowser.vue.d.ts +17 -0
- package/dist/components/AlbumManager.vue.d.ts +16 -0
- package/dist/components/AlbumMediaGrid.vue.d.ts +28 -0
- package/dist/components/AlbumTree.vue.d.ts +35 -0
- package/dist/components/BulkActionsToolbar.vue.d.ts +2 -0
- package/dist/components/ConversionProgressIndicator.vue.d.ts +2 -0
- package/dist/components/Editor.vue.d.ts +29 -0
- package/dist/components/ExampleGridAndList.vue.d.ts +2 -0
- package/dist/components/ExampleUsage.vue.d.ts +2 -0
- package/dist/components/Grid.vue.d.ts +2 -0
- package/dist/components/ImageEditor/ImageEditor.vue.d.ts +3 -0
- package/dist/components/ImageEditorModal.vue.d.ts +16 -0
- package/dist/components/ImagePicker.vue.d.ts +32 -0
- package/dist/components/ImageUploadZone.vue.d.ts +7 -0
- package/dist/components/Item.vue.d.ts +2 -0
- package/dist/components/Library.vue.d.ts +2 -0
- package/dist/components/ManagedMediaGallery.vue.d.ts +12 -0
- package/dist/components/MediaAttacher.vue.d.ts +21 -0
- package/dist/components/MediaBrowser.vue.d.ts +2 -0
- package/dist/components/MediaCard.vue.d.ts +2 -0
- package/dist/components/MediaFilters.vue.d.ts +2 -0
- package/dist/components/MediaGrid.vue.d.ts +31 -0
- package/dist/components/MediaInfoEditor.vue.d.ts +7 -0
- package/dist/components/MediaManager.vue.d.ts +2 -0
- package/dist/components/MediaUploadWithProgress.vue.d.ts +2 -0
- package/dist/components/MediaUploader.vue.d.ts +2 -0
- package/dist/components/MediaWorkspace.vue.d.ts +19 -0
- package/dist/components/Modal.vue.d.ts +2 -0
- package/dist/components/ModelMediaManager.vue.d.ts +80 -0
- package/dist/components/Pagination.vue.d.ts +2 -0
- package/dist/components/Search.vue.d.ts +2 -0
- package/dist/components/VideoEditorSimple.vue.d.ts +2 -0
- package/dist/components/VideoExportPanel.vue.d.ts +2 -0
- package/dist/components/VideoTimeline.vue.d.ts +2 -0
- package/dist/components/VideoTimelineSimple.vue.d.ts +2 -0
- package/dist/components/VideoToolsPanel.vue.d.ts +2 -0
- package/dist/components/albums/AlbumTreeNode.vue.d.ts +23 -0
- package/dist/components/attachment/MediaAttachment.vue.d.ts +23 -0
- package/dist/components/attachment/index.d.ts +4 -0
- package/dist/components/collection/MediaCollection.vue.d.ts +27 -0
- package/dist/components/collection/MediaCollectionDropzone.vue.d.ts +18 -0
- package/dist/components/collection/MediaCollectionItem.vue.d.ts +2 -0
- package/dist/components/collection/index.d.ts +6 -0
- package/dist/components/form/MediaHiddenFields.vue.d.ts +2 -0
- package/dist/components/form/index.d.ts +4 -0
- package/dist/components/image/ImageEditor.vue.d.ts +2 -0
- package/dist/components/image/ImageItem.vue.d.ts +2 -0
- package/dist/components/renderless/MediaAttachmentProvider.vue.d.ts +12 -0
- package/dist/components/renderless/MediaCollectionProvider.vue.d.ts +12 -0
- package/dist/components/renderless/index.d.ts +7 -0
- package/dist/components/timeline/TimeRuler.vue.d.ts +2 -0
- package/dist/components/timeline/VideoTrack.vue.d.ts +2 -0
- package/dist/components/tools/VideoFiltersPanel.vue.d.ts +7 -0
- package/dist/components/tools/VideoTextPanel.vue.d.ts +2 -0
- package/dist/components/video/AudioTrackManager.vue.d.ts +2 -0
- package/dist/components/video/EditorControls.vue.d.ts +2 -0
- package/dist/components/video/ExportPanel.vue.d.ts +2 -0
- package/dist/components/video/FilterSelector.vue.d.ts +2 -0
- package/dist/components/video/LiveStreamManager.vue.d.ts +2 -0
- package/dist/components/video/StreamCredentials.vue.d.ts +2 -0
- package/dist/components/video/StreamStatus.vue.d.ts +2 -0
- package/dist/components/video/TextOverlayPanel.vue.d.ts +2 -0
- package/dist/components/video/ThumbnailPicker.vue.d.ts +2 -0
- package/dist/components/video/TimelineClip.vue.d.ts +2 -0
- package/dist/components/video/TimelineControls.vue.d.ts +2 -0
- package/dist/components/video/TransitionSelector.vue.d.ts +2 -0
- package/dist/components/video/VideoControls.vue.d.ts +2 -0
- package/dist/components/video/VideoEditor.vue.d.ts +8 -0
- package/dist/components/video/VideoEditorDialog.vue.d.ts +12 -0
- package/dist/components/video/VideoFilterCarousel.vue.d.ts +2 -0
- package/dist/components/video/VideoFilterPreview.vue.d.ts +18 -0
- package/dist/components/video/VideoPlayer.vue.d.ts +2 -0
- package/dist/components/video/VideoPreview.vue.d.ts +3 -0
- package/dist/components/video/VideoPreviewCSS.vue.d.ts +2 -0
- package/dist/components/video/VideoPreviewEngine.vue.d.ts +3 -0
- package/dist/components/video/VideoTimeline.vue.d.ts +2 -0
- package/dist/components/video/VideoUploadProgress.vue.d.ts +2 -0
- package/dist/components/video/VideoUploader.vue.d.ts +29 -0
- package/dist/components/video/index.d.ts +19 -0
- package/dist/composables/useAccordion.d.ts +138 -0
- package/dist/composables/useAlbumDragDrop.d.ts +24 -0
- package/dist/composables/useAlbums.d.ts +17 -0
- package/dist/composables/useFloatingPills.d.ts +111 -0
- package/dist/composables/useHaptic.d.ts +10 -0
- package/dist/composables/useImageEditorModal.d.ts +277 -0
- package/dist/composables/useLiveStream.d.ts +66 -0
- package/dist/composables/useMediaAttachment.d.ts +105 -0
- package/dist/composables/useMediaCollection.d.ts +122 -0
- package/dist/composables/useMediaConversionProgress.d.ts +31 -0
- package/dist/composables/useMediaDragSort.d.ts +56 -0
- package/dist/composables/useMediaSelection.d.ts +27 -0
- package/dist/composables/useMediaUploadQueue.d.ts +61 -0
- package/dist/composables/useMediaValidation.d.ts +59 -0
- package/dist/composables/useRadialMenu.d.ts +116 -0
- package/dist/composables/useSanctumClient.d.ts +31 -0
- package/dist/composables/useTheme.d.ts +7 -0
- package/dist/composables/useToast.d.ts +25 -0
- package/dist/composables/useVideoEditor.d.ts +127 -0
- package/dist/composables/useVideoFilters.d.ts +176 -0
- package/dist/composables/useVideoPlayer.d.ts +50 -0
- package/dist/composables/useVideoUpload.d.ts +134 -0
- package/dist/filters/controlMapping.d.ts +31 -0
- package/dist/filters/css-registry.d.ts +83 -0
- package/dist/filters/definitions/adjustment.d.ts +2 -0
- package/dist/filters/definitions/adjustmentAdvanced.d.ts +2 -0
- package/dist/filters/definitions/advancedBloom.d.ts +2 -0
- package/dist/filters/definitions/alpha.d.ts +2 -0
- package/dist/filters/definitions/ascii.d.ts +2 -0
- package/dist/filters/definitions/backdropBlur.d.ts +2 -0
- package/dist/filters/definitions/bevel.d.ts +2 -0
- package/dist/filters/definitions/bloom.d.ts +2 -0
- package/dist/filters/definitions/blur.d.ts +2 -0
- package/dist/filters/definitions/bulgePinch.d.ts +2 -0
- package/dist/filters/definitions/colorGradient.d.ts +2 -0
- package/dist/filters/definitions/colorMap.d.ts +2 -0
- package/dist/filters/definitions/colorMatrix.d.ts +2 -0
- package/dist/filters/definitions/colorOverlay.d.ts +2 -0
- package/dist/filters/definitions/colorReplace.d.ts +2 -0
- package/dist/filters/definitions/convolution.d.ts +2 -0
- package/dist/filters/definitions/crossHatch.d.ts +2 -0
- package/dist/filters/definitions/crt.d.ts +2 -0
- package/dist/filters/definitions/displacement.d.ts +2 -0
- package/dist/filters/definitions/dot.d.ts +2 -0
- package/dist/filters/definitions/dropShadow.d.ts +2 -0
- package/dist/filters/definitions/emboss.d.ts +2 -0
- package/dist/filters/definitions/glitch.d.ts +2 -0
- package/dist/filters/definitions/glow.d.ts +2 -0
- package/dist/filters/definitions/godray.d.ts +2 -0
- package/dist/filters/definitions/grayscale.d.ts +2 -0
- package/dist/filters/definitions/hslAdjustment.d.ts +2 -0
- package/dist/filters/definitions/kawaseBlur.d.ts +2 -0
- package/dist/filters/definitions/lightmap.d.ts +2 -0
- package/dist/filters/definitions/motionBlur.d.ts +2 -0
- package/dist/filters/definitions/multiColorReplace.d.ts +2 -0
- package/dist/filters/definitions/noise.d.ts +2 -0
- package/dist/filters/definitions/oldFilm.d.ts +2 -0
- package/dist/filters/definitions/outline.d.ts +2 -0
- package/dist/filters/definitions/pixelate.d.ts +2 -0
- package/dist/filters/definitions/radialBlur.d.ts +2 -0
- package/dist/filters/definitions/reflection.d.ts +2 -0
- package/dist/filters/definitions/rgbSplit.d.ts +2 -0
- package/dist/filters/definitions/shockwave.d.ts +2 -0
- package/dist/filters/definitions/simplexNoise.d.ts +2 -0
- package/dist/filters/definitions/tiltShift.d.ts +2 -0
- package/dist/filters/definitions/twist.d.ts +2 -0
- package/dist/filters/definitions/vignette.d.ts +2 -0
- package/dist/filters/definitions/zoomBlur.d.ts +2 -0
- package/dist/filters/factory.d.ts +38 -0
- package/dist/filters/filters/controlMapping.d.ts +31 -0
- package/dist/filters/filters/definitions/adjustment.d.ts +2 -0
- package/dist/filters/filters/definitions/adjustmentAdvanced.d.ts +2 -0
- package/dist/filters/filters/definitions/advancedBloom.d.ts +2 -0
- package/dist/filters/filters/definitions/alpha.d.ts +2 -0
- package/dist/filters/filters/definitions/ascii.d.ts +2 -0
- package/dist/filters/filters/definitions/backdropBlur.d.ts +2 -0
- package/dist/filters/filters/definitions/bevel.d.ts +2 -0
- package/dist/filters/filters/definitions/bloom.d.ts +2 -0
- package/dist/filters/filters/definitions/blur.d.ts +2 -0
- package/dist/filters/filters/definitions/bulgePinch.d.ts +2 -0
- package/dist/filters/filters/definitions/colorGradient.d.ts +2 -0
- package/dist/filters/filters/definitions/colorMap.d.ts +2 -0
- package/dist/filters/filters/definitions/colorMatrix.d.ts +2 -0
- package/dist/filters/filters/definitions/colorOverlay.d.ts +2 -0
- package/dist/filters/filters/definitions/colorReplace.d.ts +2 -0
- package/dist/filters/filters/definitions/convolution.d.ts +2 -0
- package/dist/filters/filters/definitions/crossHatch.d.ts +2 -0
- package/dist/filters/filters/definitions/crt.d.ts +2 -0
- package/dist/filters/filters/definitions/displacement.d.ts +2 -0
- package/dist/filters/filters/definitions/dot.d.ts +2 -0
- package/dist/filters/filters/definitions/dropShadow.d.ts +2 -0
- package/dist/filters/filters/definitions/emboss.d.ts +2 -0
- package/dist/filters/filters/definitions/glitch.d.ts +2 -0
- package/dist/filters/filters/definitions/glow.d.ts +2 -0
- package/dist/filters/filters/definitions/godray.d.ts +2 -0
- package/dist/filters/filters/definitions/grayscale.d.ts +2 -0
- package/dist/filters/filters/definitions/hslAdjustment.d.ts +2 -0
- package/dist/filters/filters/definitions/kawaseBlur.d.ts +2 -0
- package/dist/filters/filters/definitions/lightmap.d.ts +2 -0
- package/dist/filters/filters/definitions/motionBlur.d.ts +2 -0
- package/dist/filters/filters/definitions/multiColorReplace.d.ts +2 -0
- package/dist/filters/filters/definitions/noise.d.ts +2 -0
- package/dist/filters/filters/definitions/oldFilm.d.ts +2 -0
- package/dist/filters/filters/definitions/outline.d.ts +2 -0
- package/dist/filters/filters/definitions/pixelate.d.ts +2 -0
- package/dist/filters/filters/definitions/radialBlur.d.ts +2 -0
- package/dist/filters/filters/definitions/reflection.d.ts +2 -0
- package/dist/filters/filters/definitions/rgbSplit.d.ts +2 -0
- package/dist/filters/filters/definitions/shockwave.d.ts +2 -0
- package/dist/filters/filters/definitions/simplexNoise.d.ts +2 -0
- package/dist/filters/filters/definitions/tiltShift.d.ts +2 -0
- package/dist/filters/filters/definitions/twist.d.ts +2 -0
- package/dist/filters/filters/definitions/vignette.d.ts +2 -0
- package/dist/filters/filters/definitions/zoomBlur.d.ts +2 -0
- package/dist/filters/filters/factory.d.ts +36 -0
- package/dist/filters/filters/index.d.ts +93 -0
- package/dist/filters/filters/registry.d.ts +89 -0
- package/dist/filters/index.d.ts +93 -0
- package/dist/filters/registry.d.ts +89 -0
- package/dist/filters/video-compatible.d.ts +77 -0
- package/dist/filters/video-css-filters.d.ts +153 -0
- package/dist/index-6yUGA--H.cjs +42 -0
- package/dist/index-6yUGA--H.cjs.map +1 -0
- package/dist/index-CcGWfCCV.js +7799 -0
- package/dist/index-CcGWfCCV.js.map +1 -0
- package/dist/index-DTUgsw7J.cjs +76 -0
- package/dist/index-DTUgsw7J.cjs.map +1 -0
- package/dist/index-VrUG0lmk.js +28655 -0
- package/dist/index-VrUG0lmk.js.map +1 -0
- package/dist/index.d.ts +62 -0
- package/dist/js/workers/material-color-extractor.js +215 -0
- package/dist/mediables-vanilla.cjs +2 -0
- package/dist/mediables-vanilla.cjs.map +1 -0
- package/dist/mediables-vanilla.mjs +12 -0
- package/dist/mediables-vanilla.mjs.map +1 -0
- package/dist/mediables-vue.cjs +2 -0
- package/dist/mediables-vue.cjs.map +1 -0
- package/dist/mediables-vue.mjs +67 -0
- package/dist/mediables-vue.mjs.map +1 -0
- package/dist/render-page/assets/index-hBfvGPpt.js +48933 -0
- package/dist/render-page/index.html +18 -0
- package/dist/services/VideoJobClient.d.ts +79 -0
- package/dist/stores/albumStore.d.ts +4 -0
- package/dist/stores/mediaVariantStore.d.ts +1 -0
- package/dist/stores/useAdminMediaStore.d.ts +16 -0
- package/dist/stores/useMediaStore.d.ts +25 -0
- package/dist/stores/useVideoStore.d.ts +21 -0
- package/dist/stores/variantPollStore.d.ts +5 -0
- package/dist/stores/video.d.ts +1 -0
- package/dist/style.css +1 -0
- package/dist/types/adapter.d.ts +181 -0
- package/dist/types/album.d.ts +28 -0
- package/dist/types/api.d.ts +88 -0
- package/dist/types/collection.d.ts +306 -0
- package/dist/types/editor.d.ts +172 -0
- package/dist/types/image.d.ts +210 -0
- package/dist/types/index.d.ts +5 -0
- package/dist/types/media.d.ts +107 -0
- package/dist/types/types/address.d.ts +66 -0
- package/dist/types/types/admin/intelligent-po.d.ts +47 -0
- package/dist/types/types/admin/products/index.d.ts +17 -0
- package/dist/types/types/admin/purchase-order.d.ts +50 -0
- package/dist/types/types/admin/receipt.d.ts +86 -0
- package/dist/types/types/admin/vendor.d.ts +61 -0
- package/dist/types/types/ai.d.ts +63 -0
- package/dist/types/types/aiActions.d.ts +42 -0
- package/dist/types/types/aiDesigner.d.ts +77 -0
- package/dist/types/types/api-errors.d.ts +6 -0
- package/dist/types/types/api.d.ts +109 -0
- package/dist/types/types/bundle.d.ts +131 -0
- package/dist/types/types/bundles/analytics.d.ts +64 -0
- package/dist/types/types/bundles.d.ts +108 -0
- package/dist/types/types/cart.d.ts +81 -0
- package/dist/types/types/checkout.d.ts +40 -0
- package/dist/types/types/component-config.d.ts +26 -0
- package/dist/types/types/components.d.ts +32 -0
- package/dist/types/types/content.d.ts +138 -0
- package/dist/types/types/coupon.d.ts +32 -0
- package/dist/types/types/customer-product-history.d.ts +210 -0
- package/dist/types/types/drag-contracts.d.ts +40 -0
- package/dist/types/types/drag-drop.d.ts +19 -0
- package/dist/types/types/editor.d.ts +127 -0
- package/dist/types/types/errors.d.ts +36 -0
- package/dist/types/types/feedback.d.ts +122 -0
- package/dist/types/types/image.d.ts +210 -0
- package/dist/types/types/index.d.ts +62 -0
- package/dist/types/types/instagram.d.ts +86 -0
- package/dist/types/types/ionic-components.d.ts +152 -0
- package/dist/types/types/layout.d.ts +127 -0
- package/dist/types/types/media-gateway.d.ts +34 -0
- package/dist/types/types/media.d.ts +178 -0
- package/dist/types/types/notifications.d.ts +123 -0
- package/dist/types/types/order-management.d.ts +245 -0
- package/dist/types/types/pageBuilder/block.d.ts +34 -0
- package/dist/types/types/pageBuilder/blocks.d.ts +82 -0
- package/dist/types/types/pageBuilder/cache.d.ts +33 -0
- package/dist/types/types/pageBuilder/editor.d.ts +15 -0
- package/dist/types/types/pageBuilder/field.d.ts +11 -0
- package/dist/types/types/pageBuilder/index.d.ts +24 -0
- package/dist/types/types/pageBuilder/revisions.d.ts +40 -0
- package/dist/types/types/pageBuilder/templates.d.ts +62 -0
- package/dist/types/types/pattern.d.ts +40 -0
- package/dist/types/types/payment.d.ts +21 -0
- package/dist/types/types/payments.d.ts +10 -0
- package/dist/types/types/pipeline.d.ts +12 -0
- package/dist/types/types/pixi/filter-args.d.ts +274 -0
- package/dist/types/types/pixi/filters-extended.d.ts +157 -0
- package/dist/types/types/pixi/filters.d.ts +38 -0
- package/dist/types/types/preview.d.ts +36 -0
- package/dist/types/types/pricing.d.ts +31 -0
- package/dist/types/types/quickbooks.d.ts +43 -0
- package/dist/types/types/receipt.d.ts +121 -0
- package/dist/types/types/rewards.d.ts +110 -0
- package/dist/types/types/saved-cart.d.ts +51 -0
- package/dist/types/types/settings.d.ts +63 -0
- package/dist/types/types/shipment.d.ts +62 -0
- package/dist/types/types/shipping.d.ts +98 -0
- package/dist/types/types/sidebar-variations.d.ts +226 -0
- package/dist/types/types/slots.d.ts +2 -0
- package/dist/types/types/specification-types.d.ts +70 -0
- package/dist/types/types/specifications.d.ts +163 -0
- package/dist/types/types/store.d.ts +64 -0
- package/dist/types/types/template.d.ts +8 -0
- package/dist/types/types/user.d.ts +47 -0
- package/dist/types/types/variant-groups.d.ts +158 -0
- package/dist/types/types/wishlist.d.ts +73 -0
- package/dist/types/types/workflow-wizard.d.ts +12 -0
- package/dist/types/video.d.ts +449 -0
- package/dist/utils/category-tree-constants.d.ts +42 -0
- package/dist/utils/cookies.d.ts +3 -0
- package/dist/utils/crypto-polyfill.d.ts +4 -0
- package/dist/utils/datetime.d.ts +43 -0
- package/dist/utils/debounce.d.ts +10 -0
- package/dist/utils/debugConsole.d.ts +69 -0
- package/dist/utils/editor/argHelpers.d.ts +6 -0
- package/dist/utils/formatters.d.ts +105 -0
- package/dist/utils/isPresignedAwsUrl.d.ts +67 -0
- package/dist/utils/media-helpers.d.ts +34 -0
- package/dist/utils/normalisePricing.d.ts +11 -0
- package/dist/utils/recipe-generator.d.ts +34 -0
- package/dist/utils/string.d.ts +29 -0
- package/dist/utils/unwrapApiResponse.d.ts +5 -0
- package/dist/utils/uuid.d.ts +30 -0
- package/dist/utils/validators.d.ts +28 -0
- package/dist/utils/video-export.d.ts +60 -0
- package/dist/v3-ionic-1-demo.html +440 -0
- package/dist/video-engine/VideoEngine.d.ts +267 -0
- package/dist/video-engine/adapters/AudioManager.d.ts +106 -0
- package/dist/video-engine/adapters/CSSFilterAdapter.d.ts +106 -0
- package/dist/video-engine/adapters/ExportManager.d.ts +88 -0
- package/dist/video-engine/adapters/FilterBridge.d.ts +96 -0
- package/dist/video-engine/adapters/MediablesCompositionAdapter.d.ts +56 -0
- package/dist/video-engine/adapters/PixiFrameExporter.d.ts +52 -0
- package/dist/video-engine/adapters/RenderQueue.d.ts +119 -0
- package/dist/video-engine/adapters/TextOverlayManager.d.ts +93 -0
- package/dist/video-engine/adapters/TimelineAdapter.d.ts +58 -0
- package/dist/video-engine/adapters/TransitionManager.d.ts +76 -0
- package/dist/video-engine/adapters/WebCodecsExport.d.ts +36 -0
- package/dist/video-engine/compositions/examples/example.d.ts +2 -0
- package/dist/video-engine/filters/CSSFilterSystem.d.ts +213 -0
- package/dist/video-engine/index.d.ts +14 -0
- package/dist/video-engine/presets/ExportPresets.d.ts +70 -0
- package/dist/video-engine/types/index.d.ts +96 -0
- package/dist/video-engine/types.d.ts +1 -0
- package/dist/video-engine/utils/EventEmitter.d.ts +12 -0
- package/dist/video-engine/utils/MediaSourceResolver.d.ts +9 -0
- package/dist/video-engine/utils/error-reporter.d.ts +159 -0
- package/dist/video-engine/utils/keyboard-shortcuts.d.ts +120 -0
- package/dist/video-engine/utils/pixi-video-fallback.d.ts +2 -0
- package/docs/video-subsystem/README.md +490 -0
- package/docs/video-subsystem/api-reference.md +747 -0
- package/docs/video-subsystem/component-examples.md +1477 -0
- package/docs/video-subsystem/integration-guide.md +1021 -0
- package/package.json +102 -0
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { type VideoUploadApiClient } from '../../composables/useVideoUpload';
|
|
2
|
+
export interface VideoUploaderProps {
|
|
3
|
+
collection?: string;
|
|
4
|
+
multiple?: boolean;
|
|
5
|
+
maxFileSize?: number;
|
|
6
|
+
maxDuration?: number;
|
|
7
|
+
allowedFormats?: string[];
|
|
8
|
+
autoUpload?: boolean;
|
|
9
|
+
resumable?: boolean;
|
|
10
|
+
label?: string;
|
|
11
|
+
description?: string;
|
|
12
|
+
ownerUuid?: string;
|
|
13
|
+
ownerType?: string;
|
|
14
|
+
apiClient?: VideoUploadApiClient;
|
|
15
|
+
}
|
|
16
|
+
declare var __VLS_1: {
|
|
17
|
+
open: any;
|
|
18
|
+
};
|
|
19
|
+
type __VLS_Slots = {} & {
|
|
20
|
+
trigger?: (props: typeof __VLS_1) => any;
|
|
21
|
+
};
|
|
22
|
+
declare const __VLS_component: import("vue").ComponentOptionsBase<any, any, any, any, any, any, any, any, string, {}, {}, string, {}, {}, {}, string, import("vue").ComponentProvideOptions>;
|
|
23
|
+
declare const _default: __VLS_WithSlots<typeof __VLS_component, __VLS_Slots>;
|
|
24
|
+
export default _default;
|
|
25
|
+
type __VLS_WithSlots<T, S> = T & {
|
|
26
|
+
new (): {
|
|
27
|
+
$slots: S;
|
|
28
|
+
};
|
|
29
|
+
};
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Video Components Export
|
|
3
|
+
*
|
|
4
|
+
* Central export file for all video editing components
|
|
5
|
+
*/
|
|
6
|
+
export { default as VideoEditor } from './VideoEditor.vue';
|
|
7
|
+
export { default as VideoPreview } from './VideoPreview.vue';
|
|
8
|
+
export { default as VideoTimeline } from './VideoTimeline.vue';
|
|
9
|
+
export { default as TimelineClip } from './TimelineClip.vue';
|
|
10
|
+
export { default as TimelineControls } from './TimelineControls.vue';
|
|
11
|
+
export { default as FilterSelector } from './FilterSelector.vue';
|
|
12
|
+
export { default as VideoFilterPreview } from './VideoFilterPreview.vue';
|
|
13
|
+
export { default as EditorControls } from './EditorControls.vue';
|
|
14
|
+
export { default as ThumbnailPicker } from './ThumbnailPicker.vue';
|
|
15
|
+
export * from '../../types/video';
|
|
16
|
+
export * from '../../filters/video-compatible';
|
|
17
|
+
export * from '../../utils/recipe-generator';
|
|
18
|
+
export { useVideoEditor } from '../../composables/useVideoEditor';
|
|
19
|
+
export { useVideoFilters } from '../../composables/useVideoFilters';
|
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
export interface PanelGroup {
|
|
2
|
+
id: string;
|
|
3
|
+
name: string;
|
|
4
|
+
icon: string;
|
|
5
|
+
emoji: string;
|
|
6
|
+
description: string;
|
|
7
|
+
filters: FilterConfig[];
|
|
8
|
+
autoExpandTriggers?: string[];
|
|
9
|
+
}
|
|
10
|
+
export interface FilterConfig {
|
|
11
|
+
id: string;
|
|
12
|
+
name: string;
|
|
13
|
+
type: 'slider' | 'preset' | 'toggle' | 'button';
|
|
14
|
+
category: string;
|
|
15
|
+
min?: number;
|
|
16
|
+
max?: number;
|
|
17
|
+
default?: number;
|
|
18
|
+
value?: number;
|
|
19
|
+
presets?: {
|
|
20
|
+
name: string;
|
|
21
|
+
value: any;
|
|
22
|
+
}[];
|
|
23
|
+
}
|
|
24
|
+
export type PanelState = 'collapsed' | 'expanded' | 'minimized' | 'focused';
|
|
25
|
+
interface SmartPanelBehavior {
|
|
26
|
+
idleTimeout: number;
|
|
27
|
+
activeThreshold: number;
|
|
28
|
+
contextualExpand: Record<string, string>;
|
|
29
|
+
keepOpen: string[];
|
|
30
|
+
}
|
|
31
|
+
export declare function useAccordion(): {
|
|
32
|
+
panelGroups: import("vue").Ref<{
|
|
33
|
+
id: string;
|
|
34
|
+
name: string;
|
|
35
|
+
icon: string;
|
|
36
|
+
emoji: string;
|
|
37
|
+
description: string;
|
|
38
|
+
filters: {
|
|
39
|
+
id: string;
|
|
40
|
+
name: string;
|
|
41
|
+
type: "slider" | "preset" | "toggle" | "button";
|
|
42
|
+
category: string;
|
|
43
|
+
min?: number | undefined;
|
|
44
|
+
max?: number | undefined;
|
|
45
|
+
default?: number | undefined;
|
|
46
|
+
value?: number | undefined;
|
|
47
|
+
presets?: {
|
|
48
|
+
name: string;
|
|
49
|
+
value: any;
|
|
50
|
+
}[] | undefined;
|
|
51
|
+
}[];
|
|
52
|
+
autoExpandTriggers?: string[] | undefined;
|
|
53
|
+
}[], PanelGroup[] | {
|
|
54
|
+
id: string;
|
|
55
|
+
name: string;
|
|
56
|
+
icon: string;
|
|
57
|
+
emoji: string;
|
|
58
|
+
description: string;
|
|
59
|
+
filters: {
|
|
60
|
+
id: string;
|
|
61
|
+
name: string;
|
|
62
|
+
type: "slider" | "preset" | "toggle" | "button";
|
|
63
|
+
category: string;
|
|
64
|
+
min?: number | undefined;
|
|
65
|
+
max?: number | undefined;
|
|
66
|
+
default?: number | undefined;
|
|
67
|
+
value?: number | undefined;
|
|
68
|
+
presets?: {
|
|
69
|
+
name: string;
|
|
70
|
+
value: any;
|
|
71
|
+
}[] | undefined;
|
|
72
|
+
}[];
|
|
73
|
+
autoExpandTriggers?: string[] | undefined;
|
|
74
|
+
}[]>;
|
|
75
|
+
expandedPanels: import("vue").Ref<string[], string[]>;
|
|
76
|
+
focusedPanel: import("vue").Ref<string | null, string | null>;
|
|
77
|
+
panelStates: Record<string, PanelState>;
|
|
78
|
+
panelsClass: import("vue").ComputedRef<{
|
|
79
|
+
'panels-collapsed': boolean;
|
|
80
|
+
'panels-one-expanded': boolean;
|
|
81
|
+
'panels-two-expanded': boolean;
|
|
82
|
+
'panels-multiple-expanded': boolean;
|
|
83
|
+
}>;
|
|
84
|
+
imageContainerStyle: import("vue").ComputedRef<{
|
|
85
|
+
height: string;
|
|
86
|
+
transition: string;
|
|
87
|
+
}>;
|
|
88
|
+
expandPanel: (panelId: string) => void;
|
|
89
|
+
collapsePanel: (panelId: string) => void;
|
|
90
|
+
collapseAllPanels: () => void;
|
|
91
|
+
togglePanel: (panelId: string) => void;
|
|
92
|
+
triggerContextualExpansion: (trigger: string) => void;
|
|
93
|
+
applyFilter: (filterId: string, value: any) => void;
|
|
94
|
+
handleDoubleTapImage: () => void;
|
|
95
|
+
handlePanelSwipeUp: (panelId: string) => void;
|
|
96
|
+
handlePanelSwipeDown: (panelId: string) => void;
|
|
97
|
+
getPanelById: (panelId: string) => {
|
|
98
|
+
id: string;
|
|
99
|
+
name: string;
|
|
100
|
+
icon: string;
|
|
101
|
+
emoji: string;
|
|
102
|
+
description: string;
|
|
103
|
+
filters: {
|
|
104
|
+
id: string;
|
|
105
|
+
name: string;
|
|
106
|
+
type: "slider" | "preset" | "toggle" | "button";
|
|
107
|
+
category: string;
|
|
108
|
+
min?: number | undefined;
|
|
109
|
+
max?: number | undefined;
|
|
110
|
+
default?: number | undefined;
|
|
111
|
+
value?: number | undefined;
|
|
112
|
+
presets?: {
|
|
113
|
+
name: string;
|
|
114
|
+
value: any;
|
|
115
|
+
}[] | undefined;
|
|
116
|
+
}[];
|
|
117
|
+
autoExpandTriggers?: string[] | undefined;
|
|
118
|
+
} | undefined;
|
|
119
|
+
getPanelState: (panelId: string) => PanelState;
|
|
120
|
+
isExpanded: (panelId: string) => boolean;
|
|
121
|
+
isFocused: (panelId: string) => boolean;
|
|
122
|
+
updateActivity: () => void;
|
|
123
|
+
isSliderDragging: import("vue").Ref<boolean, boolean>;
|
|
124
|
+
isFilterPreviewActive: import("vue").Ref<boolean, boolean>;
|
|
125
|
+
panelEvents: import("vue").Ref<{
|
|
126
|
+
event: string;
|
|
127
|
+
payload: any;
|
|
128
|
+
}[], {
|
|
129
|
+
event: string;
|
|
130
|
+
payload: any;
|
|
131
|
+
}[] | {
|
|
132
|
+
event: string;
|
|
133
|
+
payload: any;
|
|
134
|
+
}[]>;
|
|
135
|
+
onImageLoaded: () => void;
|
|
136
|
+
smartBehavior: SmartPanelBehavior;
|
|
137
|
+
};
|
|
138
|
+
export {};
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import type { Ref } from 'vue';
|
|
2
|
+
import type { Album } from '@/types/album';
|
|
3
|
+
export interface DragState {
|
|
4
|
+
isDragging: boolean;
|
|
5
|
+
draggedAlbumId: string | null;
|
|
6
|
+
dropTargetId: string | null;
|
|
7
|
+
dropPosition: 'before' | 'after' | 'inside' | null;
|
|
8
|
+
}
|
|
9
|
+
export interface UseAlbumDragDropOptions {
|
|
10
|
+
albumsById: Map<string, Album>;
|
|
11
|
+
childrenByParentId: Map<string | null, string[]>;
|
|
12
|
+
onMove: (albumId: string, newParentId: string | null) => Promise<void>;
|
|
13
|
+
}
|
|
14
|
+
export interface UseAlbumDragDropReturn {
|
|
15
|
+
dragState: Ref<DragState>;
|
|
16
|
+
isDescendant: (ancestorId: string, potentialDescendantId: string) => boolean;
|
|
17
|
+
canDropOn: (draggedId: string, targetId: string | null) => boolean;
|
|
18
|
+
startDrag: (albumId: string) => void;
|
|
19
|
+
endDrag: () => void;
|
|
20
|
+
setDropTarget: (targetId: string | null) => void;
|
|
21
|
+
clearDropTarget: () => void;
|
|
22
|
+
executeDrop: () => Promise<void>;
|
|
23
|
+
}
|
|
24
|
+
export declare function useAlbumDragDrop(options: UseAlbumDragDropOptions): UseAlbumDragDropReturn;
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { Ref } from 'vue';
|
|
2
|
+
import type { Album } from '@/types/album';
|
|
3
|
+
export interface FetchAlbumsParams {
|
|
4
|
+
parent_id?: string | null;
|
|
5
|
+
}
|
|
6
|
+
export interface UseAlbumsReturn {
|
|
7
|
+
albums: Ref<Album[]>;
|
|
8
|
+
albumsById: Ref<Map<string, Album>>;
|
|
9
|
+
rootAlbums: Ref<Album[]>;
|
|
10
|
+
loading: Ref<boolean>;
|
|
11
|
+
error: Ref<string | null>;
|
|
12
|
+
fetchAlbums: (params?: FetchAlbumsParams) => Promise<void>;
|
|
13
|
+
getChildrenOf: (parentId: string | null) => Album[];
|
|
14
|
+
childrenLoaded: (parentId: string) => boolean;
|
|
15
|
+
moveAlbum: (albumId: string, newParentId: string | null) => Promise<void>;
|
|
16
|
+
}
|
|
17
|
+
export declare function useAlbums(): UseAlbumsReturn;
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
import { type FilterDefinition } from '../filters/registry';
|
|
2
|
+
interface FilterPillsState {
|
|
3
|
+
activeFilters: FilterDefinition[];
|
|
4
|
+
filterValues: Record<string, Record<string, any>>;
|
|
5
|
+
expandedPill: string | null;
|
|
6
|
+
scrollOffset: number;
|
|
7
|
+
scrollPosition: 'start' | 'middle' | 'end';
|
|
8
|
+
isDragging: boolean;
|
|
9
|
+
draggedPill: string | null;
|
|
10
|
+
}
|
|
11
|
+
export declare function useFloatingPills(): {
|
|
12
|
+
activeFilters: Readonly<import("vue").Ref<readonly {
|
|
13
|
+
readonly id: string;
|
|
14
|
+
readonly name: string;
|
|
15
|
+
readonly category: string;
|
|
16
|
+
readonly description?: string | undefined;
|
|
17
|
+
readonly thumbnail?: string | undefined;
|
|
18
|
+
readonly createFilter: (params: Record<string, any>) => any;
|
|
19
|
+
readonly defaultParams: {
|
|
20
|
+
readonly [x: string]: any;
|
|
21
|
+
};
|
|
22
|
+
readonly controls: readonly {
|
|
23
|
+
readonly id: string;
|
|
24
|
+
readonly type: "slider" | "toggle" | "color" | "select" | "range" | "button" | "text";
|
|
25
|
+
readonly label: string;
|
|
26
|
+
readonly property?: string | undefined;
|
|
27
|
+
readonly action?: string | undefined;
|
|
28
|
+
readonly min?: number | undefined;
|
|
29
|
+
readonly max?: number | undefined;
|
|
30
|
+
readonly step?: number | undefined;
|
|
31
|
+
readonly default?: number | boolean | string | undefined;
|
|
32
|
+
readonly options?: readonly {
|
|
33
|
+
readonly label: string;
|
|
34
|
+
readonly value: string | number;
|
|
35
|
+
}[] | undefined;
|
|
36
|
+
readonly tooltip?: string | undefined;
|
|
37
|
+
}[];
|
|
38
|
+
}[], readonly {
|
|
39
|
+
readonly id: string;
|
|
40
|
+
readonly name: string;
|
|
41
|
+
readonly category: string;
|
|
42
|
+
readonly description?: string | undefined;
|
|
43
|
+
readonly thumbnail?: string | undefined;
|
|
44
|
+
readonly createFilter: (params: Record<string, any>) => any;
|
|
45
|
+
readonly defaultParams: {
|
|
46
|
+
readonly [x: string]: any;
|
|
47
|
+
};
|
|
48
|
+
readonly controls: readonly {
|
|
49
|
+
readonly id: string;
|
|
50
|
+
readonly type: "slider" | "toggle" | "color" | "select" | "range" | "button" | "text";
|
|
51
|
+
readonly label: string;
|
|
52
|
+
readonly property?: string | undefined;
|
|
53
|
+
readonly action?: string | undefined;
|
|
54
|
+
readonly min?: number | undefined;
|
|
55
|
+
readonly max?: number | undefined;
|
|
56
|
+
readonly step?: number | undefined;
|
|
57
|
+
readonly default?: number | boolean | string | undefined;
|
|
58
|
+
readonly options?: readonly {
|
|
59
|
+
readonly label: string;
|
|
60
|
+
readonly value: string | number;
|
|
61
|
+
}[] | undefined;
|
|
62
|
+
readonly tooltip?: string | undefined;
|
|
63
|
+
}[];
|
|
64
|
+
}[]>>;
|
|
65
|
+
filterValues: Readonly<import("vue").Ref<{
|
|
66
|
+
readonly [x: string]: {
|
|
67
|
+
readonly [x: string]: any;
|
|
68
|
+
};
|
|
69
|
+
}, {
|
|
70
|
+
readonly [x: string]: {
|
|
71
|
+
readonly [x: string]: any;
|
|
72
|
+
};
|
|
73
|
+
}>>;
|
|
74
|
+
expandedPill: Readonly<import("vue").Ref<string | null, string | null>>;
|
|
75
|
+
scrollOffset: Readonly<import("vue").Ref<number, number>>;
|
|
76
|
+
scrollPosition: Readonly<import("vue").Ref<"end" | "middle" | "start", "end" | "middle" | "start">>;
|
|
77
|
+
canScroll: Readonly<import("vue").Ref<boolean, boolean>>;
|
|
78
|
+
touchState: {
|
|
79
|
+
readonly startX: number;
|
|
80
|
+
readonly startY: number;
|
|
81
|
+
readonly currentX: number;
|
|
82
|
+
readonly currentY: number;
|
|
83
|
+
readonly isDragging: boolean;
|
|
84
|
+
readonly dragType: "scroll" | "reorder" | null;
|
|
85
|
+
};
|
|
86
|
+
isDragging: Readonly<import("vue").Ref<boolean, boolean>>;
|
|
87
|
+
draggedPill: Readonly<import("vue").Ref<string | null, string | null>>;
|
|
88
|
+
hasActiveFilters: import("vue").ComputedRef<boolean>;
|
|
89
|
+
pillsState: import("vue").ComputedRef<FilterPillsState>;
|
|
90
|
+
addFilter: (filterId: string) => void;
|
|
91
|
+
removeFilter: (filterId: string) => void;
|
|
92
|
+
expandPill: (filterId: string) => void;
|
|
93
|
+
collapsePill: () => void;
|
|
94
|
+
updateFilterValue: (filterId: string, controlId: string, value: any) => void;
|
|
95
|
+
getCurrentValue: (filterId: string, controlId: string) => string;
|
|
96
|
+
hasValues: (filterId: string) => boolean;
|
|
97
|
+
reorderFilters: (fromIndex: number, toIndex: number) => void;
|
|
98
|
+
updateScrollPosition: (offset: number, containerWidth: number, totalWidth: number) => void;
|
|
99
|
+
resetAllFilters: () => void;
|
|
100
|
+
handleTouchStart: (e: TouchEvent, filterId?: string) => void;
|
|
101
|
+
handleTouchMove: (e: TouchEvent) => {
|
|
102
|
+
deltaX: number;
|
|
103
|
+
deltaY: number;
|
|
104
|
+
distance: number;
|
|
105
|
+
gestureType: "scroll" | "reorder" | null;
|
|
106
|
+
} | undefined;
|
|
107
|
+
handleTouchEnd: (callback?: () => void) => {
|
|
108
|
+
wasTap: boolean;
|
|
109
|
+
};
|
|
110
|
+
};
|
|
111
|
+
export {};
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Haptic feedback composable for providing tactile feedback
|
|
3
|
+
* Provides fallback for web platform where native haptics aren't available
|
|
4
|
+
*/
|
|
5
|
+
export declare function useHaptic(): {
|
|
6
|
+
selection: () => void;
|
|
7
|
+
success: () => void;
|
|
8
|
+
error: () => void;
|
|
9
|
+
notification: () => void;
|
|
10
|
+
};
|
|
@@ -0,0 +1,277 @@
|
|
|
1
|
+
import type { SaveEventPayload } from '../types/editor';
|
|
2
|
+
export interface ImageEditorModalOptions {
|
|
3
|
+
onSave?: (payload: SaveEventPayload) => void | Promise<void>;
|
|
4
|
+
onError?: (error: Error) => void;
|
|
5
|
+
onCancel?: () => void;
|
|
6
|
+
maxFileSize?: number;
|
|
7
|
+
acceptedFormats?: string;
|
|
8
|
+
}
|
|
9
|
+
export declare function useImageEditorModal(options?: ImageEditorModalOptions): {
|
|
10
|
+
isOpen: import("vue").Ref<boolean, boolean>;
|
|
11
|
+
isProcessing: import("vue").Ref<boolean, boolean>;
|
|
12
|
+
uploadedImage: import("vue").Ref<string | {
|
|
13
|
+
readonly lastModified: number;
|
|
14
|
+
readonly name: string;
|
|
15
|
+
readonly webkitRelativePath: string;
|
|
16
|
+
readonly size: number;
|
|
17
|
+
readonly type: string;
|
|
18
|
+
arrayBuffer: {
|
|
19
|
+
(): Promise<ArrayBuffer>;
|
|
20
|
+
(): Promise<ArrayBuffer>;
|
|
21
|
+
};
|
|
22
|
+
bytes: {
|
|
23
|
+
(): Promise<Uint8Array<ArrayBuffer>>;
|
|
24
|
+
(): Promise<Uint8Array<ArrayBuffer>>;
|
|
25
|
+
};
|
|
26
|
+
slice: {
|
|
27
|
+
(start?: number, end?: number, contentType?: string): Blob;
|
|
28
|
+
(start?: number, end?: number, contentType?: string): Blob;
|
|
29
|
+
};
|
|
30
|
+
stream: {
|
|
31
|
+
(): ReadableStream<Uint8Array<ArrayBuffer>>;
|
|
32
|
+
(): ReadableStream<Uint8Array<ArrayBuffer>>;
|
|
33
|
+
};
|
|
34
|
+
text: {
|
|
35
|
+
(): Promise<string>;
|
|
36
|
+
(): Promise<string>;
|
|
37
|
+
};
|
|
38
|
+
} | null, string | File | {
|
|
39
|
+
readonly lastModified: number;
|
|
40
|
+
readonly name: string;
|
|
41
|
+
readonly webkitRelativePath: string;
|
|
42
|
+
readonly size: number;
|
|
43
|
+
readonly type: string;
|
|
44
|
+
arrayBuffer: {
|
|
45
|
+
(): Promise<ArrayBuffer>;
|
|
46
|
+
(): Promise<ArrayBuffer>;
|
|
47
|
+
};
|
|
48
|
+
bytes: {
|
|
49
|
+
(): Promise<Uint8Array<ArrayBuffer>>;
|
|
50
|
+
(): Promise<Uint8Array<ArrayBuffer>>;
|
|
51
|
+
};
|
|
52
|
+
slice: {
|
|
53
|
+
(start?: number, end?: number, contentType?: string): Blob;
|
|
54
|
+
(start?: number, end?: number, contentType?: string): Blob;
|
|
55
|
+
};
|
|
56
|
+
stream: {
|
|
57
|
+
(): ReadableStream<Uint8Array<ArrayBuffer>>;
|
|
58
|
+
(): ReadableStream<Uint8Array<ArrayBuffer>>;
|
|
59
|
+
};
|
|
60
|
+
text: {
|
|
61
|
+
(): Promise<string>;
|
|
62
|
+
(): Promise<string>;
|
|
63
|
+
};
|
|
64
|
+
} | null>;
|
|
65
|
+
editedImage: import("vue").Ref<{
|
|
66
|
+
imageData: string;
|
|
67
|
+
dimensions: {
|
|
68
|
+
width: number;
|
|
69
|
+
height: number;
|
|
70
|
+
};
|
|
71
|
+
metadata: {
|
|
72
|
+
hasCrop: boolean;
|
|
73
|
+
cropRect: {
|
|
74
|
+
x: number;
|
|
75
|
+
y: number;
|
|
76
|
+
width: number;
|
|
77
|
+
height: number;
|
|
78
|
+
} | null;
|
|
79
|
+
filters: string[];
|
|
80
|
+
filterValues: Record<string, Record<string, any>>;
|
|
81
|
+
aspectRatio: string;
|
|
82
|
+
dimensions: {
|
|
83
|
+
width: number;
|
|
84
|
+
height: number;
|
|
85
|
+
};
|
|
86
|
+
};
|
|
87
|
+
} | null, SaveEventPayload | {
|
|
88
|
+
imageData: string;
|
|
89
|
+
dimensions: {
|
|
90
|
+
width: number;
|
|
91
|
+
height: number;
|
|
92
|
+
};
|
|
93
|
+
metadata: {
|
|
94
|
+
hasCrop: boolean;
|
|
95
|
+
cropRect: {
|
|
96
|
+
x: number;
|
|
97
|
+
y: number;
|
|
98
|
+
width: number;
|
|
99
|
+
height: number;
|
|
100
|
+
} | null;
|
|
101
|
+
filters: string[];
|
|
102
|
+
filterValues: Record<string, Record<string, any>>;
|
|
103
|
+
aspectRatio: string;
|
|
104
|
+
dimensions: {
|
|
105
|
+
width: number;
|
|
106
|
+
height: number;
|
|
107
|
+
};
|
|
108
|
+
};
|
|
109
|
+
} | null>;
|
|
110
|
+
error: import("vue").Ref<Error | null, Error | null>;
|
|
111
|
+
hasError: import("vue").ComputedRef<boolean>;
|
|
112
|
+
hasUnsavedChanges: import("vue").ComputedRef<boolean>;
|
|
113
|
+
open: (image?: string | File) => void;
|
|
114
|
+
close: () => void;
|
|
115
|
+
handleSave: (payload: SaveEventPayload) => Promise<SaveEventPayload>;
|
|
116
|
+
handleCancel: () => void;
|
|
117
|
+
handleError: (err: Error) => void;
|
|
118
|
+
clearError: () => void;
|
|
119
|
+
getEditedImage: () => {
|
|
120
|
+
imageData: string;
|
|
121
|
+
dimensions: {
|
|
122
|
+
width: number;
|
|
123
|
+
height: number;
|
|
124
|
+
};
|
|
125
|
+
metadata: {
|
|
126
|
+
hasCrop: boolean;
|
|
127
|
+
cropRect: {
|
|
128
|
+
x: number;
|
|
129
|
+
y: number;
|
|
130
|
+
width: number;
|
|
131
|
+
height: number;
|
|
132
|
+
} | null;
|
|
133
|
+
filters: string[];
|
|
134
|
+
filterValues: Record<string, Record<string, any>>;
|
|
135
|
+
aspectRatio: string;
|
|
136
|
+
dimensions: {
|
|
137
|
+
width: number;
|
|
138
|
+
height: number;
|
|
139
|
+
};
|
|
140
|
+
};
|
|
141
|
+
} | null;
|
|
142
|
+
};
|
|
143
|
+
export declare function useGlobalImageEditor(options?: ImageEditorModalOptions): {
|
|
144
|
+
isOpen: import("vue").Ref<boolean, boolean>;
|
|
145
|
+
isProcessing: import("vue").Ref<boolean, boolean>;
|
|
146
|
+
uploadedImage: import("vue").Ref<string | {
|
|
147
|
+
readonly lastModified: number;
|
|
148
|
+
readonly name: string;
|
|
149
|
+
readonly webkitRelativePath: string;
|
|
150
|
+
readonly size: number;
|
|
151
|
+
readonly type: string;
|
|
152
|
+
arrayBuffer: {
|
|
153
|
+
(): Promise<ArrayBuffer>;
|
|
154
|
+
(): Promise<ArrayBuffer>;
|
|
155
|
+
};
|
|
156
|
+
bytes: {
|
|
157
|
+
(): Promise<Uint8Array<ArrayBuffer>>;
|
|
158
|
+
(): Promise<Uint8Array<ArrayBuffer>>;
|
|
159
|
+
};
|
|
160
|
+
slice: {
|
|
161
|
+
(start?: number, end?: number, contentType?: string): Blob;
|
|
162
|
+
(start?: number, end?: number, contentType?: string): Blob;
|
|
163
|
+
};
|
|
164
|
+
stream: {
|
|
165
|
+
(): ReadableStream<Uint8Array<ArrayBuffer>>;
|
|
166
|
+
(): ReadableStream<Uint8Array<ArrayBuffer>>;
|
|
167
|
+
};
|
|
168
|
+
text: {
|
|
169
|
+
(): Promise<string>;
|
|
170
|
+
(): Promise<string>;
|
|
171
|
+
};
|
|
172
|
+
} | null, string | File | {
|
|
173
|
+
readonly lastModified: number;
|
|
174
|
+
readonly name: string;
|
|
175
|
+
readonly webkitRelativePath: string;
|
|
176
|
+
readonly size: number;
|
|
177
|
+
readonly type: string;
|
|
178
|
+
arrayBuffer: {
|
|
179
|
+
(): Promise<ArrayBuffer>;
|
|
180
|
+
(): Promise<ArrayBuffer>;
|
|
181
|
+
};
|
|
182
|
+
bytes: {
|
|
183
|
+
(): Promise<Uint8Array<ArrayBuffer>>;
|
|
184
|
+
(): Promise<Uint8Array<ArrayBuffer>>;
|
|
185
|
+
};
|
|
186
|
+
slice: {
|
|
187
|
+
(start?: number, end?: number, contentType?: string): Blob;
|
|
188
|
+
(start?: number, end?: number, contentType?: string): Blob;
|
|
189
|
+
};
|
|
190
|
+
stream: {
|
|
191
|
+
(): ReadableStream<Uint8Array<ArrayBuffer>>;
|
|
192
|
+
(): ReadableStream<Uint8Array<ArrayBuffer>>;
|
|
193
|
+
};
|
|
194
|
+
text: {
|
|
195
|
+
(): Promise<string>;
|
|
196
|
+
(): Promise<string>;
|
|
197
|
+
};
|
|
198
|
+
} | null>;
|
|
199
|
+
editedImage: import("vue").Ref<{
|
|
200
|
+
imageData: string;
|
|
201
|
+
dimensions: {
|
|
202
|
+
width: number;
|
|
203
|
+
height: number;
|
|
204
|
+
};
|
|
205
|
+
metadata: {
|
|
206
|
+
hasCrop: boolean;
|
|
207
|
+
cropRect: {
|
|
208
|
+
x: number;
|
|
209
|
+
y: number;
|
|
210
|
+
width: number;
|
|
211
|
+
height: number;
|
|
212
|
+
} | null;
|
|
213
|
+
filters: string[];
|
|
214
|
+
filterValues: Record<string, Record<string, any>>;
|
|
215
|
+
aspectRatio: string;
|
|
216
|
+
dimensions: {
|
|
217
|
+
width: number;
|
|
218
|
+
height: number;
|
|
219
|
+
};
|
|
220
|
+
};
|
|
221
|
+
} | null, SaveEventPayload | {
|
|
222
|
+
imageData: string;
|
|
223
|
+
dimensions: {
|
|
224
|
+
width: number;
|
|
225
|
+
height: number;
|
|
226
|
+
};
|
|
227
|
+
metadata: {
|
|
228
|
+
hasCrop: boolean;
|
|
229
|
+
cropRect: {
|
|
230
|
+
x: number;
|
|
231
|
+
y: number;
|
|
232
|
+
width: number;
|
|
233
|
+
height: number;
|
|
234
|
+
} | null;
|
|
235
|
+
filters: string[];
|
|
236
|
+
filterValues: Record<string, Record<string, any>>;
|
|
237
|
+
aspectRatio: string;
|
|
238
|
+
dimensions: {
|
|
239
|
+
width: number;
|
|
240
|
+
height: number;
|
|
241
|
+
};
|
|
242
|
+
};
|
|
243
|
+
} | null>;
|
|
244
|
+
error: import("vue").Ref<Error | null, Error | null>;
|
|
245
|
+
hasError: import("vue").ComputedRef<boolean>;
|
|
246
|
+
hasUnsavedChanges: import("vue").ComputedRef<boolean>;
|
|
247
|
+
open: (image?: string | File) => void;
|
|
248
|
+
close: () => void;
|
|
249
|
+
handleSave: (payload: SaveEventPayload) => Promise<SaveEventPayload>;
|
|
250
|
+
handleCancel: () => void;
|
|
251
|
+
handleError: (err: Error) => void;
|
|
252
|
+
clearError: () => void;
|
|
253
|
+
getEditedImage: () => {
|
|
254
|
+
imageData: string;
|
|
255
|
+
dimensions: {
|
|
256
|
+
width: number;
|
|
257
|
+
height: number;
|
|
258
|
+
};
|
|
259
|
+
metadata: {
|
|
260
|
+
hasCrop: boolean;
|
|
261
|
+
cropRect: {
|
|
262
|
+
x: number;
|
|
263
|
+
y: number;
|
|
264
|
+
width: number;
|
|
265
|
+
height: number;
|
|
266
|
+
} | null;
|
|
267
|
+
filters: string[];
|
|
268
|
+
filterValues: Record<string, Record<string, any>>;
|
|
269
|
+
aspectRatio: string;
|
|
270
|
+
dimensions: {
|
|
271
|
+
width: number;
|
|
272
|
+
height: number;
|
|
273
|
+
};
|
|
274
|
+
};
|
|
275
|
+
} | null;
|
|
276
|
+
};
|
|
277
|
+
export declare function createImageEditor(options?: ImageEditorModalOptions): (image?: string | File) => Promise<SaveEventPayload>;
|