@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,25 @@
|
|
|
1
|
+
export interface Toast {
|
|
2
|
+
id: string;
|
|
3
|
+
message: string;
|
|
4
|
+
type: 'success' | 'error' | 'warning' | 'info';
|
|
5
|
+
duration?: number;
|
|
6
|
+
}
|
|
7
|
+
export declare function useToast(): {
|
|
8
|
+
toasts: import("vue").Ref<{
|
|
9
|
+
id: string;
|
|
10
|
+
message: string;
|
|
11
|
+
type: "success" | "error" | "warning" | "info";
|
|
12
|
+
duration?: number | undefined;
|
|
13
|
+
}[], Toast[] | {
|
|
14
|
+
id: string;
|
|
15
|
+
message: string;
|
|
16
|
+
type: "success" | "error" | "warning" | "info";
|
|
17
|
+
duration?: number | undefined;
|
|
18
|
+
}[]>;
|
|
19
|
+
show: (message: string, type?: Toast["type"], duration?: number) => string;
|
|
20
|
+
remove: (id: string) => void;
|
|
21
|
+
success: (message: string, duration?: number) => string;
|
|
22
|
+
error: (message: string, duration?: number) => string;
|
|
23
|
+
warning: (message: string, duration?: number) => string;
|
|
24
|
+
info: (message: string, duration?: number) => string;
|
|
25
|
+
};
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Video Editor Composable
|
|
3
|
+
*
|
|
4
|
+
* Core logic for video editing operations
|
|
5
|
+
*/
|
|
6
|
+
import type { VideoRecipe, VideoMedia, AppliedFilter, TextOverlayRecipe, AudioTrackRecipe } from '../types/video';
|
|
7
|
+
import { CSSFilterCompositionAdapter } from '../video-engine/adapters/CSSFilterAdapter';
|
|
8
|
+
export declare function useVideoEditor(mediaUuid: string, initialRecipe?: VideoRecipe, initialMedia?: VideoMedia): {
|
|
9
|
+
currentFrame: import("vue").Ref<any, any>;
|
|
10
|
+
playheadPosition: import("vue").ComputedRef<number>;
|
|
11
|
+
timelineClips: import("vue").ComputedRef<{
|
|
12
|
+
id: string;
|
|
13
|
+
type: "clip" | "video";
|
|
14
|
+
timelineStart: number;
|
|
15
|
+
timelineEnd: number;
|
|
16
|
+
startTime?: number | undefined;
|
|
17
|
+
endTime?: number | undefined;
|
|
18
|
+
track?: number | undefined;
|
|
19
|
+
sourceIn: number;
|
|
20
|
+
sourceOut: number;
|
|
21
|
+
sourceMinIn?: number | undefined;
|
|
22
|
+
sourceMaxOut?: number | undefined;
|
|
23
|
+
speed?: number | undefined;
|
|
24
|
+
filters?: {
|
|
25
|
+
id: string;
|
|
26
|
+
filterId: string;
|
|
27
|
+
params: Record<string, any>;
|
|
28
|
+
intensity: number;
|
|
29
|
+
ffmpegCommand?: string | undefined;
|
|
30
|
+
}[] | undefined;
|
|
31
|
+
thumbnail?: string | undefined;
|
|
32
|
+
label?: string | undefined;
|
|
33
|
+
url?: string | undefined;
|
|
34
|
+
muted?: boolean | undefined;
|
|
35
|
+
scale?: number | undefined;
|
|
36
|
+
duration?: number | undefined;
|
|
37
|
+
transform?: {
|
|
38
|
+
x?: number | undefined;
|
|
39
|
+
y?: number | undefined;
|
|
40
|
+
rotation?: number | undefined;
|
|
41
|
+
opacity?: number | undefined;
|
|
42
|
+
scale?: number | undefined;
|
|
43
|
+
} | undefined;
|
|
44
|
+
}[]>;
|
|
45
|
+
totalDuration: import("vue").ComputedRef<number>;
|
|
46
|
+
hasChanges: import("vue").ComputedRef<boolean>;
|
|
47
|
+
isPlaying: import("vue").ComputedRef<boolean>;
|
|
48
|
+
selectedClip: import("vue").ComputedRef<{
|
|
49
|
+
id: string;
|
|
50
|
+
type: "clip" | "video";
|
|
51
|
+
timelineStart: number;
|
|
52
|
+
timelineEnd: number;
|
|
53
|
+
startTime?: number | undefined;
|
|
54
|
+
endTime?: number | undefined;
|
|
55
|
+
track?: number | undefined;
|
|
56
|
+
sourceIn: number;
|
|
57
|
+
sourceOut: number;
|
|
58
|
+
sourceMinIn?: number | undefined;
|
|
59
|
+
sourceMaxOut?: number | undefined;
|
|
60
|
+
speed?: number | undefined;
|
|
61
|
+
filters?: {
|
|
62
|
+
id: string;
|
|
63
|
+
filterId: string;
|
|
64
|
+
params: Record<string, any>;
|
|
65
|
+
intensity: number;
|
|
66
|
+
ffmpegCommand?: string | undefined;
|
|
67
|
+
}[] | undefined;
|
|
68
|
+
thumbnail?: string | undefined;
|
|
69
|
+
label?: string | undefined;
|
|
70
|
+
url?: string | undefined;
|
|
71
|
+
muted?: boolean | undefined;
|
|
72
|
+
scale?: number | undefined;
|
|
73
|
+
duration?: number | undefined;
|
|
74
|
+
transform?: {
|
|
75
|
+
x?: number | undefined;
|
|
76
|
+
y?: number | undefined;
|
|
77
|
+
rotation?: number | undefined;
|
|
78
|
+
opacity?: number | undefined;
|
|
79
|
+
scale?: number | undefined;
|
|
80
|
+
} | undefined;
|
|
81
|
+
} | null>;
|
|
82
|
+
zoomLevel: import("vue").ComputedRef<number>;
|
|
83
|
+
playbackSpeed: import("vue").Ref<number, number>;
|
|
84
|
+
useVideoEngine: import("vue").Ref<boolean, boolean>;
|
|
85
|
+
compositionAdapter: import("vue").ComputedRef<CSSFilterCompositionAdapter | null>;
|
|
86
|
+
fps: import("vue").Ref<number, number>;
|
|
87
|
+
useFrameMode: import("vue").Ref<boolean, boolean>;
|
|
88
|
+
handleTrim: (clipId: string, edge: "start" | "end", newTime: number) => void;
|
|
89
|
+
handleSplit: (time: number) => void;
|
|
90
|
+
handleClipSelect: (clipId: string | null) => void;
|
|
91
|
+
splitAtPlayhead: () => void;
|
|
92
|
+
deleteSelectedClip: () => void;
|
|
93
|
+
duplicateSelectedClip: () => void;
|
|
94
|
+
setFilters: (filters: AppliedFilter[]) => void;
|
|
95
|
+
setTextOverlays: (overlays: TextOverlayRecipe[]) => void;
|
|
96
|
+
setAudioTracks: (tracks: AudioTrackRecipe[]) => void;
|
|
97
|
+
moveClip: (clipId: string, newStart: number) => void;
|
|
98
|
+
saveDraft: () => VideoRecipe;
|
|
99
|
+
clearHasChanges: () => void;
|
|
100
|
+
resetChanges: () => boolean;
|
|
101
|
+
generateRecipe: () => VideoRecipe;
|
|
102
|
+
zoomIn: () => void;
|
|
103
|
+
zoomOut: () => void;
|
|
104
|
+
setZoomLevel: (value: number) => void;
|
|
105
|
+
fitToWindow: () => void;
|
|
106
|
+
togglePlayback: () => void;
|
|
107
|
+
setPlaying: (playing: boolean) => void;
|
|
108
|
+
seekTo: (time: number) => void;
|
|
109
|
+
frameForward: () => void;
|
|
110
|
+
frameBackward: () => void;
|
|
111
|
+
skipToStart: () => void;
|
|
112
|
+
skipToEnd: () => void;
|
|
113
|
+
setPlaybackSpeed: (speed: number) => void;
|
|
114
|
+
undo: () => void;
|
|
115
|
+
redo: () => void;
|
|
116
|
+
canUndo: import("vue").ComputedRef<boolean>;
|
|
117
|
+
canRedo: import("vue").ComputedRef<boolean>;
|
|
118
|
+
initializeComposition: (width?: number, height?: number) => Promise<void>;
|
|
119
|
+
syncCompositionWithState: () => Promise<void>;
|
|
120
|
+
syncWithComposition: (_composition: any) => void;
|
|
121
|
+
convertToFrames: (seconds: number) => number;
|
|
122
|
+
convertToSeconds: (frames: number) => number;
|
|
123
|
+
seekToFrame: (frame: number) => void;
|
|
124
|
+
toggleFrameMode: () => void;
|
|
125
|
+
onCompositionReady: () => void;
|
|
126
|
+
onCompositionError: (error: Error) => void;
|
|
127
|
+
};
|
|
@@ -0,0 +1,176 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Video Filters Composable
|
|
3
|
+
*
|
|
4
|
+
* Keeps video filter definitions aligned with the centralized filter registry
|
|
5
|
+
* used by the image editor, while preserving legacy video-compatible fallbacks
|
|
6
|
+
* for uploader flows and older saved recipes.
|
|
7
|
+
*/
|
|
8
|
+
import type { AppliedFilter } from '../types/video';
|
|
9
|
+
type FilterParamPrimitive = number | boolean | string;
|
|
10
|
+
type FilterParamValue = FilterParamPrimitive | null;
|
|
11
|
+
type FilterParamMap = Record<string, FilterParamValue>;
|
|
12
|
+
interface VideoFilterControl {
|
|
13
|
+
id: string;
|
|
14
|
+
type: string;
|
|
15
|
+
label: string;
|
|
16
|
+
property?: string;
|
|
17
|
+
min?: number;
|
|
18
|
+
max?: number;
|
|
19
|
+
step?: number;
|
|
20
|
+
default?: FilterParamPrimitive;
|
|
21
|
+
unit?: string;
|
|
22
|
+
}
|
|
23
|
+
interface VideoFilterDefinition {
|
|
24
|
+
id: string;
|
|
25
|
+
name: string;
|
|
26
|
+
category: string;
|
|
27
|
+
controls: VideoFilterControl[];
|
|
28
|
+
params: VideoFilterControl[];
|
|
29
|
+
defaultParams: FilterParamMap;
|
|
30
|
+
paramRanges: Record<string, {
|
|
31
|
+
min: number;
|
|
32
|
+
max: number;
|
|
33
|
+
step: number;
|
|
34
|
+
}>;
|
|
35
|
+
}
|
|
36
|
+
interface FilterPresetEntry {
|
|
37
|
+
filterId: string;
|
|
38
|
+
params: FilterParamMap;
|
|
39
|
+
intensity: number;
|
|
40
|
+
}
|
|
41
|
+
interface FilterPreset {
|
|
42
|
+
id: string;
|
|
43
|
+
name: string;
|
|
44
|
+
filters: FilterPresetEntry[];
|
|
45
|
+
created_at: string;
|
|
46
|
+
}
|
|
47
|
+
export declare function useVideoFilters(): {
|
|
48
|
+
videoCompatibleFilters: import("vue").ComputedRef<VideoFilterDefinition[]>;
|
|
49
|
+
activeFilters: import("vue").Ref<{
|
|
50
|
+
id: string;
|
|
51
|
+
filterId: string;
|
|
52
|
+
params: Record<string, any>;
|
|
53
|
+
intensity: number;
|
|
54
|
+
ffmpegCommand?: string | undefined;
|
|
55
|
+
}[], AppliedFilter[] | {
|
|
56
|
+
id: string;
|
|
57
|
+
filterId: string;
|
|
58
|
+
params: Record<string, any>;
|
|
59
|
+
intensity: number;
|
|
60
|
+
ffmpegCommand?: string | undefined;
|
|
61
|
+
}[]>;
|
|
62
|
+
selectedFilter: import("vue").Ref<{
|
|
63
|
+
id: string;
|
|
64
|
+
name: string;
|
|
65
|
+
category: string;
|
|
66
|
+
controls: {
|
|
67
|
+
id: string;
|
|
68
|
+
type: string;
|
|
69
|
+
label: string;
|
|
70
|
+
property?: string | undefined;
|
|
71
|
+
min?: number | undefined;
|
|
72
|
+
max?: number | undefined;
|
|
73
|
+
step?: number | undefined;
|
|
74
|
+
default?: FilterParamPrimitive | undefined;
|
|
75
|
+
unit?: string | undefined;
|
|
76
|
+
}[];
|
|
77
|
+
params: {
|
|
78
|
+
id: string;
|
|
79
|
+
type: string;
|
|
80
|
+
label: string;
|
|
81
|
+
property?: string | undefined;
|
|
82
|
+
min?: number | undefined;
|
|
83
|
+
max?: number | undefined;
|
|
84
|
+
step?: number | undefined;
|
|
85
|
+
default?: FilterParamPrimitive | undefined;
|
|
86
|
+
unit?: string | undefined;
|
|
87
|
+
}[];
|
|
88
|
+
defaultParams: FilterParamMap;
|
|
89
|
+
paramRanges: Record<string, {
|
|
90
|
+
min: number;
|
|
91
|
+
max: number;
|
|
92
|
+
step: number;
|
|
93
|
+
}>;
|
|
94
|
+
} | null, VideoFilterDefinition | {
|
|
95
|
+
id: string;
|
|
96
|
+
name: string;
|
|
97
|
+
category: string;
|
|
98
|
+
controls: {
|
|
99
|
+
id: string;
|
|
100
|
+
type: string;
|
|
101
|
+
label: string;
|
|
102
|
+
property?: string | undefined;
|
|
103
|
+
min?: number | undefined;
|
|
104
|
+
max?: number | undefined;
|
|
105
|
+
step?: number | undefined;
|
|
106
|
+
default?: FilterParamPrimitive | undefined;
|
|
107
|
+
unit?: string | undefined;
|
|
108
|
+
}[];
|
|
109
|
+
params: {
|
|
110
|
+
id: string;
|
|
111
|
+
type: string;
|
|
112
|
+
label: string;
|
|
113
|
+
property?: string | undefined;
|
|
114
|
+
min?: number | undefined;
|
|
115
|
+
max?: number | undefined;
|
|
116
|
+
step?: number | undefined;
|
|
117
|
+
default?: FilterParamPrimitive | undefined;
|
|
118
|
+
unit?: string | undefined;
|
|
119
|
+
}[];
|
|
120
|
+
defaultParams: FilterParamMap;
|
|
121
|
+
paramRanges: Record<string, {
|
|
122
|
+
min: number;
|
|
123
|
+
max: number;
|
|
124
|
+
step: number;
|
|
125
|
+
}>;
|
|
126
|
+
} | null>;
|
|
127
|
+
previewFilter: import("vue").Ref<{
|
|
128
|
+
id: string;
|
|
129
|
+
filterId: string;
|
|
130
|
+
params: Record<string, any>;
|
|
131
|
+
intensity: number;
|
|
132
|
+
ffmpegCommand?: string | undefined;
|
|
133
|
+
} | null, AppliedFilter | {
|
|
134
|
+
id: string;
|
|
135
|
+
filterId: string;
|
|
136
|
+
params: Record<string, any>;
|
|
137
|
+
intensity: number;
|
|
138
|
+
ffmpegCommand?: string | undefined;
|
|
139
|
+
} | null>;
|
|
140
|
+
filterPresets: import("vue").Ref<{
|
|
141
|
+
id: string;
|
|
142
|
+
name: string;
|
|
143
|
+
filters: {
|
|
144
|
+
filterId: string;
|
|
145
|
+
params: FilterParamMap;
|
|
146
|
+
intensity: number;
|
|
147
|
+
}[];
|
|
148
|
+
created_at: string;
|
|
149
|
+
}[], FilterPreset[] | {
|
|
150
|
+
id: string;
|
|
151
|
+
name: string;
|
|
152
|
+
filters: {
|
|
153
|
+
filterId: string;
|
|
154
|
+
params: FilterParamMap;
|
|
155
|
+
intensity: number;
|
|
156
|
+
}[];
|
|
157
|
+
created_at: string;
|
|
158
|
+
}[]>;
|
|
159
|
+
filterParams: FilterParamMap;
|
|
160
|
+
hasActiveFilters: import("vue").ComputedRef<boolean>;
|
|
161
|
+
filtersByCategory: import("vue").ComputedRef<Record<string, VideoFilterDefinition[]>>;
|
|
162
|
+
applyFilter: (filterId?: string) => AppliedFilter | undefined;
|
|
163
|
+
previewFilterEffect: (filterId: string) => void;
|
|
164
|
+
updateFilterParams: (params: Record<string, unknown>) => void;
|
|
165
|
+
removeFilter: (filterId: string) => void;
|
|
166
|
+
reorderFilters: (fromIndex: number, toIndex: number) => void;
|
|
167
|
+
updateFilterIntensity: (filterId: string, intensity: number) => void;
|
|
168
|
+
toggleFilter: (filterId: string) => void;
|
|
169
|
+
clearAllFilters: () => void;
|
|
170
|
+
saveFilterPreset: (name: string) => FilterPreset;
|
|
171
|
+
loadFilterPreset: (presetId: string) => void;
|
|
172
|
+
deleteFilterPreset: (presetId: string) => void;
|
|
173
|
+
getFilterSummary: () => string;
|
|
174
|
+
setActiveFilters(filters: AppliedFilter[]): void;
|
|
175
|
+
};
|
|
176
|
+
export {};
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Composable for video player functionality
|
|
3
|
+
* Handles playback, controls, token refresh, and live streaming
|
|
4
|
+
*/
|
|
5
|
+
import type { VideoPlayerOptions } from '../types/video';
|
|
6
|
+
interface ApiClient {
|
|
7
|
+
get<T>(url: string): Promise<T>;
|
|
8
|
+
}
|
|
9
|
+
interface UseVideoPlayerOptions extends VideoPlayerOptions {
|
|
10
|
+
onPlay?: () => void;
|
|
11
|
+
onPause?: () => void;
|
|
12
|
+
onEnded?: () => void;
|
|
13
|
+
onError?: (error: string) => void;
|
|
14
|
+
onTimeUpdate?: (time: number) => void;
|
|
15
|
+
}
|
|
16
|
+
export declare function useVideoPlayer(options?: UseVideoPlayerOptions): {
|
|
17
|
+
videoEl: import("vue").Ref<HTMLVideoElement | undefined, HTMLVideoElement | undefined>;
|
|
18
|
+
liveVideoEl: import("vue").Ref<HTMLVideoElement | undefined, HTMLVideoElement | undefined>;
|
|
19
|
+
playing: import("vue").Ref<boolean, boolean>;
|
|
20
|
+
currentTime: import("vue").Ref<number, number>;
|
|
21
|
+
duration: import("vue").Ref<number, number>;
|
|
22
|
+
volume: import("vue").Ref<number, number>;
|
|
23
|
+
muted: import("vue").Ref<boolean, boolean>;
|
|
24
|
+
isFullscreen: import("vue").Ref<boolean, boolean>;
|
|
25
|
+
bufferedRanges: import("vue").Ref<TimeRanges | undefined, TimeRanges | undefined>;
|
|
26
|
+
bufferedPercent: import("vue").ComputedRef<number>;
|
|
27
|
+
playbackRate: import("vue").Ref<number, number>;
|
|
28
|
+
isLoading: import("vue").Ref<boolean, boolean>;
|
|
29
|
+
error: import("vue").Ref<string | null, string | null>;
|
|
30
|
+
status: import("vue").Ref<"error" | "paused" | "playing" | "ready" | "ended" | "loading" | "idle" | "live", "error" | "paused" | "playing" | "ready" | "ended" | "loading" | "idle" | "live">;
|
|
31
|
+
currentPlaybackUrl: import("vue").Ref<string, string>;
|
|
32
|
+
tokenExpiresAt: import("vue").Ref<Date | null, Date | null>;
|
|
33
|
+
play: () => Promise<void>;
|
|
34
|
+
pause: () => void;
|
|
35
|
+
togglePlayPause: () => void;
|
|
36
|
+
seek: (time: number) => void;
|
|
37
|
+
skipForward: (seconds?: number) => void;
|
|
38
|
+
skipBackward: (seconds?: number) => void;
|
|
39
|
+
toggleMute: () => void;
|
|
40
|
+
setVolume: (value: number) => void;
|
|
41
|
+
setPlaybackRate: (rate: number) => void;
|
|
42
|
+
toggleFullscreen: () => Promise<void>;
|
|
43
|
+
togglePiP: () => Promise<void>;
|
|
44
|
+
retry: () => Promise<void>;
|
|
45
|
+
refreshToken: () => Promise<void>;
|
|
46
|
+
setupLiveStream: (streamUrl: string) => Promise<void>;
|
|
47
|
+
setApiClient: (client: ApiClient) => void;
|
|
48
|
+
shouldRefreshToken: () => boolean;
|
|
49
|
+
};
|
|
50
|
+
export {};
|
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Composable for video upload functionality
|
|
3
|
+
* Handles direct upload to provider, progress tracking, and resumable uploads
|
|
4
|
+
*/
|
|
5
|
+
import type { VideoMedia, VideoUploadProgress } from '../types/video';
|
|
6
|
+
interface UseVideoUploadOptions {
|
|
7
|
+
collection?: string;
|
|
8
|
+
ownerUuid?: string;
|
|
9
|
+
ownerType?: string;
|
|
10
|
+
maxFileSize?: number;
|
|
11
|
+
maxDuration?: number;
|
|
12
|
+
allowedFormats?: string[];
|
|
13
|
+
autoUpload?: boolean;
|
|
14
|
+
resumable?: boolean;
|
|
15
|
+
chunkSize?: number;
|
|
16
|
+
onUploadStart?: (upload: VideoUploadProgress) => void;
|
|
17
|
+
onUploadProgress?: (upload: VideoUploadProgress) => void;
|
|
18
|
+
onUploadComplete?: (media: VideoMedia) => void;
|
|
19
|
+
onUploadError?: (error: Error, upload: VideoUploadProgress) => void;
|
|
20
|
+
onFilesSelected?: (files: File[]) => void;
|
|
21
|
+
}
|
|
22
|
+
export interface VideoUploadApiClient {
|
|
23
|
+
post<T>(url: string, data: unknown): Promise<T>;
|
|
24
|
+
get<T>(url: string): Promise<T>;
|
|
25
|
+
}
|
|
26
|
+
export declare function useVideoUpload(options?: UseVideoUploadOptions): {
|
|
27
|
+
uploads: import("vue").ComputedRef<{
|
|
28
|
+
id: string;
|
|
29
|
+
file: {
|
|
30
|
+
readonly lastModified: number;
|
|
31
|
+
readonly name: string;
|
|
32
|
+
readonly webkitRelativePath: string;
|
|
33
|
+
readonly size: number;
|
|
34
|
+
readonly type: string;
|
|
35
|
+
arrayBuffer: {
|
|
36
|
+
(): Promise<ArrayBuffer>;
|
|
37
|
+
(): Promise<ArrayBuffer>;
|
|
38
|
+
};
|
|
39
|
+
bytes: {
|
|
40
|
+
(): Promise<Uint8Array<ArrayBuffer>>;
|
|
41
|
+
(): Promise<Uint8Array<ArrayBuffer>>;
|
|
42
|
+
};
|
|
43
|
+
slice: {
|
|
44
|
+
(start?: number, end?: number, contentType?: string): Blob;
|
|
45
|
+
(start?: number, end?: number, contentType?: string): Blob;
|
|
46
|
+
};
|
|
47
|
+
stream: {
|
|
48
|
+
(): ReadableStream<Uint8Array<ArrayBuffer>>;
|
|
49
|
+
(): ReadableStream<Uint8Array<ArrayBuffer>>;
|
|
50
|
+
};
|
|
51
|
+
text: {
|
|
52
|
+
(): Promise<string>;
|
|
53
|
+
(): Promise<string>;
|
|
54
|
+
};
|
|
55
|
+
};
|
|
56
|
+
filename: string;
|
|
57
|
+
progress: number;
|
|
58
|
+
status: "pending" | "uploading" | "processing" | "completed" | "error" | "cancelled";
|
|
59
|
+
error?: string | undefined;
|
|
60
|
+
mediaUuid?: string | undefined;
|
|
61
|
+
media?: {
|
|
62
|
+
uuid: string;
|
|
63
|
+
filename: string;
|
|
64
|
+
url?: string | undefined;
|
|
65
|
+
file?: {
|
|
66
|
+
readonly lastModified: number;
|
|
67
|
+
readonly name: string;
|
|
68
|
+
readonly webkitRelativePath: string;
|
|
69
|
+
readonly size: number;
|
|
70
|
+
readonly type: string;
|
|
71
|
+
arrayBuffer: {
|
|
72
|
+
(): Promise<ArrayBuffer>;
|
|
73
|
+
(): Promise<ArrayBuffer>;
|
|
74
|
+
};
|
|
75
|
+
bytes: {
|
|
76
|
+
(): Promise<Uint8Array<ArrayBuffer>>;
|
|
77
|
+
(): Promise<Uint8Array<ArrayBuffer>>;
|
|
78
|
+
};
|
|
79
|
+
slice: {
|
|
80
|
+
(start?: number, end?: number, contentType?: string): Blob;
|
|
81
|
+
(start?: number, end?: number, contentType?: string): Blob;
|
|
82
|
+
};
|
|
83
|
+
stream: {
|
|
84
|
+
(): ReadableStream<Uint8Array<ArrayBuffer>>;
|
|
85
|
+
(): ReadableStream<Uint8Array<ArrayBuffer>>;
|
|
86
|
+
};
|
|
87
|
+
text: {
|
|
88
|
+
(): Promise<string>;
|
|
89
|
+
(): Promise<string>;
|
|
90
|
+
};
|
|
91
|
+
} | undefined;
|
|
92
|
+
mime_type: string;
|
|
93
|
+
size: number;
|
|
94
|
+
duration: number;
|
|
95
|
+
width: number;
|
|
96
|
+
height: number;
|
|
97
|
+
aspect_ratio: string;
|
|
98
|
+
frame_rate: number;
|
|
99
|
+
bitrate?: number | undefined;
|
|
100
|
+
has_audio: boolean;
|
|
101
|
+
has_captions?: boolean | undefined;
|
|
102
|
+
thumbnail_url?: string | undefined;
|
|
103
|
+
thumbnail_time?: number | undefined;
|
|
104
|
+
poster_url?: string | undefined;
|
|
105
|
+
playback_url?: string | undefined;
|
|
106
|
+
token_expires_at?: string | undefined;
|
|
107
|
+
provider: "local" | "bunny" | "cloudflare";
|
|
108
|
+
provider_asset_id?: string | undefined;
|
|
109
|
+
playback_id?: string | undefined;
|
|
110
|
+
processing_status: "pending" | "processing" | "ready" | "failed";
|
|
111
|
+
processing_progress: number;
|
|
112
|
+
created_at: string;
|
|
113
|
+
updated_at: string;
|
|
114
|
+
} | undefined;
|
|
115
|
+
bytesTotal: number;
|
|
116
|
+
bytesUploaded: number;
|
|
117
|
+
startedAt: Date;
|
|
118
|
+
completedAt?: Date | undefined;
|
|
119
|
+
uploadSpeed?: number | undefined;
|
|
120
|
+
timeRemaining?: number | undefined;
|
|
121
|
+
}[]>;
|
|
122
|
+
isUploading: import("vue").ComputedRef<boolean>;
|
|
123
|
+
totalProgress: import("vue").ComputedRef<number>;
|
|
124
|
+
openFilePicker: () => void;
|
|
125
|
+
handleFileSelect: (files: File[]) => Promise<void>;
|
|
126
|
+
validateFile: (file: File) => boolean;
|
|
127
|
+
startUpload: (file: File) => Promise<void>;
|
|
128
|
+
cancelUpload: (uploadId: string) => void;
|
|
129
|
+
retryUpload: (uploadId: string) => Promise<void>;
|
|
130
|
+
removeUpload: (uploadId: string) => void;
|
|
131
|
+
clearCompleted: () => void;
|
|
132
|
+
setApiClient: (client: VideoUploadApiClient) => void;
|
|
133
|
+
};
|
|
134
|
+
export {};
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Filter Control Mapping System
|
|
3
|
+
* Provides utilities for mapping filter controls to components and validating values
|
|
4
|
+
*/
|
|
5
|
+
import type { ControlDefinition } from './registry';
|
|
6
|
+
/**
|
|
7
|
+
* Map a control type to a component name
|
|
8
|
+
* @param controlType The type of control from the filter definition
|
|
9
|
+
* @returns The name of the Vue component to use for this control
|
|
10
|
+
*/
|
|
11
|
+
export declare function mapControlTypeToComponent(controlType: string): string;
|
|
12
|
+
/**
|
|
13
|
+
* Validate a control value against its definition
|
|
14
|
+
* @param value The value to validate
|
|
15
|
+
* @param control The control definition
|
|
16
|
+
* @returns The validated value (potentially corrected if out of bounds)
|
|
17
|
+
*/
|
|
18
|
+
export declare function validateControlValue(value: any, control: ControlDefinition): any;
|
|
19
|
+
/**
|
|
20
|
+
* Generate a full set of parameters for a filter from its controls
|
|
21
|
+
* @param controls The control definitions
|
|
22
|
+
* @returns An object with the default parameters
|
|
23
|
+
*/
|
|
24
|
+
export declare function generateDefaultParams(controls: ControlDefinition[]): Record<string, any>;
|
|
25
|
+
/**
|
|
26
|
+
* Convert a control value to the appropriate type based on the control definition
|
|
27
|
+
* @param value The value to convert
|
|
28
|
+
* @param control The control definition
|
|
29
|
+
* @returns The converted value
|
|
30
|
+
*/
|
|
31
|
+
export declare function convertControlValue(value: any, control: ControlDefinition): any;
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* CSS Filter Registry System
|
|
3
|
+
* Centralized storage and management for CSS filter definitions
|
|
4
|
+
* Used for video filters to ensure preview matches export
|
|
5
|
+
*/
|
|
6
|
+
/**
|
|
7
|
+
* Interface for a filter control definition
|
|
8
|
+
* Defines the UI representation of a filter parameter
|
|
9
|
+
* Extends FilterControl from CSSFilterSystem with additional optional UI properties
|
|
10
|
+
*/
|
|
11
|
+
export interface ControlDefinition {
|
|
12
|
+
id: string;
|
|
13
|
+
type: 'slider' | 'toggle' | 'color' | 'select' | 'range' | 'button' | 'text' | 'checkbox';
|
|
14
|
+
label: string;
|
|
15
|
+
property: string;
|
|
16
|
+
action?: string;
|
|
17
|
+
min?: number;
|
|
18
|
+
max?: number;
|
|
19
|
+
step?: number;
|
|
20
|
+
default: number | boolean | string;
|
|
21
|
+
unit?: string;
|
|
22
|
+
options?: Array<{
|
|
23
|
+
label: string;
|
|
24
|
+
value: string | number;
|
|
25
|
+
}>;
|
|
26
|
+
tooltip?: string;
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Interface for a CSS filter definition
|
|
30
|
+
* Contains all metadata needed to create and manage a CSS filter
|
|
31
|
+
*/
|
|
32
|
+
export interface CSSFilterRegistryDefinition {
|
|
33
|
+
id: string;
|
|
34
|
+
name: string;
|
|
35
|
+
category: string;
|
|
36
|
+
description?: string;
|
|
37
|
+
thumbnail?: string;
|
|
38
|
+
cssFilterId: string;
|
|
39
|
+
defaultParams: Record<string, any>;
|
|
40
|
+
controls: ControlDefinition[];
|
|
41
|
+
params?: ControlDefinition[];
|
|
42
|
+
}
|
|
43
|
+
export declare const CSS_FILTER_CATEGORIES: {
|
|
44
|
+
id: string;
|
|
45
|
+
name: string;
|
|
46
|
+
icon: string;
|
|
47
|
+
}[];
|
|
48
|
+
/**
|
|
49
|
+
* Register a CSS filter in the global registry
|
|
50
|
+
*/
|
|
51
|
+
export declare function registerCSSFilter(definition: CSSFilterRegistryDefinition): CSSFilterRegistryDefinition;
|
|
52
|
+
/**
|
|
53
|
+
* Get a CSS filter definition by ID
|
|
54
|
+
*/
|
|
55
|
+
export declare function getCSSFilter(id: string): CSSFilterRegistryDefinition | undefined;
|
|
56
|
+
/**
|
|
57
|
+
* Get all registered CSS filter definitions
|
|
58
|
+
*/
|
|
59
|
+
export declare function getAllCSSFilters(): CSSFilterRegistryDefinition[];
|
|
60
|
+
/**
|
|
61
|
+
* Get CSS filters by category
|
|
62
|
+
*/
|
|
63
|
+
export declare function getCSSFiltersByCategory(category: string): CSSFilterRegistryDefinition[];
|
|
64
|
+
/**
|
|
65
|
+
* Initialize CSS filter registry with all available filters
|
|
66
|
+
*/
|
|
67
|
+
export declare function initializeCSSFilterRegistry(): void;
|
|
68
|
+
/**
|
|
69
|
+
* Get registered CSS filters as video filter format
|
|
70
|
+
* (For compatibility with existing components)
|
|
71
|
+
*/
|
|
72
|
+
export declare function getRegisteredCSSFilters(): {
|
|
73
|
+
id: string;
|
|
74
|
+
name: string;
|
|
75
|
+
category: string;
|
|
76
|
+
controls: ControlDefinition[];
|
|
77
|
+
params: ControlDefinition[];
|
|
78
|
+
defaultParams: Record<string, any>;
|
|
79
|
+
}[];
|
|
80
|
+
/**
|
|
81
|
+
* Check if CSS filter registry is initialized
|
|
82
|
+
*/
|
|
83
|
+
export declare function isCSSRegistryInitialized(): boolean;
|