origam 2.3.0 → 2.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +158 -1
- package/dist/src/assets/css/tokens/dark.css +424 -58
- package/dist/src/assets/css/tokens/light.css +212 -29
- package/dist/src/assets/locales/en.json +36 -0
- package/dist/src/assets/locales/fr.json +33 -0
- package/dist/src/assets/locales/index.js +2 -2
- package/dist/src/assets/scss/tokens/_dark.scss +212 -29
- package/dist/src/assets/scss/tokens/_light.scss +212 -29
- package/dist/src/components/Alert/OrigamAlert.vue +5 -4
- package/dist/src/components/App/OrigamApp.vue +38 -1
- package/dist/src/components/App/OrigamAppBar.vue +2 -2
- package/dist/src/components/Audio/OrigamAudio.vue +1465 -0
- package/dist/src/components/Audio/index.cjs +13 -0
- package/dist/src/components/Audio/index.d.ts +1 -0
- package/dist/src/components/Audio/index.js +1 -0
- package/dist/src/components/Avatar/OrigamAvatar.vue +3 -3
- package/dist/src/components/Avatar/OrigamAvatarGroup.vue +2 -2
- package/dist/src/components/Badge/OrigamBadge.vue +2 -2
- package/dist/src/components/Blockquote/OrigamBlockquote.vue +291 -0
- package/dist/src/components/Blockquote/index.cjs +13 -0
- package/dist/src/components/Blockquote/index.d.ts +1 -0
- package/dist/src/components/Blockquote/index.js +1 -0
- package/dist/src/components/BottomNav/OrigamBottomNav.vue +3 -2
- package/dist/src/components/Bracket/OrigamBracket.vue +64 -9
- package/dist/src/components/Bracket/OrigamBracketRound.vue +2 -0
- package/dist/src/components/Breadcrumb/OrigamBreadcrumb.vue +5 -3
- package/dist/src/components/Breadcrumb/OrigamBreadcrumbDivider.vue +1 -1
- package/dist/src/components/Breadcrumb/OrigamBreadcrumbItem.vue +3 -3
- package/dist/src/components/Btn/OrigamBtn.vue +14 -4
- package/dist/src/components/Btn/OrigamBtnGroup.vue +3 -2
- package/dist/src/components/Btn/OrigamBtnToggle.vue +2 -2
- package/dist/src/components/Calendar/OrigamCalendar.vue +1175 -0
- package/dist/src/components/Calendar/index.cjs +13 -0
- package/dist/src/components/Calendar/index.d.ts +1 -0
- package/dist/src/components/Calendar/index.js +1 -0
- package/dist/src/components/Card/OrigamCard.vue +2 -2
- package/dist/src/components/Card/OrigamCardHeader.vue +1 -1
- package/dist/src/components/Carousel/OrigamCarousel.vue +6 -1
- package/dist/src/components/Carousel/OrigamCarouselItem.vue +2 -2
- package/dist/src/components/Chart/OrigamChart.vue +882 -0
- package/dist/src/components/Chart/OrigamChartAxis.vue +141 -0
- package/dist/src/components/Chart/OrigamChartBoxPlot.vue +894 -0
- package/dist/src/components/Chart/OrigamChartBullet.vue +836 -0
- package/dist/src/components/Chart/OrigamChartCandlestick.vue +745 -0
- package/dist/src/components/Chart/OrigamChartCartesian.vue +1450 -0
- package/dist/src/components/Chart/OrigamChartGauge.vue +402 -0
- package/dist/src/components/Chart/OrigamChartHeatmap.vue +697 -0
- package/dist/src/components/Chart/OrigamChartHoneycomb.vue +723 -0
- package/dist/src/components/Chart/OrigamChartLegend.vue +59 -0
- package/dist/src/components/Chart/OrigamChartMap.vue +738 -0
- package/dist/src/components/Chart/OrigamChartPareto.vue +949 -0
- package/dist/src/components/Chart/OrigamChartPictorial.vue +1024 -0
- package/dist/src/components/Chart/OrigamChartPolar.vue +735 -0
- package/dist/src/components/Chart/OrigamChartPolarBar.vue +719 -0
- package/dist/src/components/Chart/OrigamChartPyramid.vue +706 -0
- package/dist/src/components/Chart/OrigamChartRadar.vue +504 -0
- package/dist/src/components/Chart/OrigamChartRangeSelector.vue +122 -0
- package/dist/src/components/Chart/OrigamChartSankey.vue +943 -0
- package/dist/src/components/Chart/OrigamChartSparkline.vue +474 -0
- package/dist/src/components/Chart/OrigamChartStreamgraph.vue +872 -0
- package/dist/src/components/Chart/OrigamChartSunburst.vue +865 -0
- package/dist/src/components/Chart/OrigamChartTooltip.vue +55 -0
- package/dist/src/components/Chart/OrigamChartTreemap.vue +744 -0
- package/dist/src/components/Chart/OrigamChartVariwide.vue +815 -0
- package/dist/src/components/Chart/OrigamChartWordCloud.vue +671 -0
- package/dist/src/components/Chart/index.cjs +188 -0
- package/dist/src/components/Chart/index.d.ts +26 -0
- package/dist/src/components/Chart/index.js +26 -0
- package/dist/src/components/Checkbox/OrigamCheckbox.vue +2 -2
- package/dist/src/components/Checkbox/OrigamCheckboxBtn.vue +2 -2
- package/dist/src/components/Chip/OrigamChip.vue +9 -7
- package/dist/src/components/Chip/OrigamChipGroup.vue +15 -3
- package/dist/src/components/Clipboard/OrigamClipboard.vue +195 -0
- package/dist/src/components/Clipboard/index.cjs +13 -0
- package/dist/src/components/Clipboard/index.d.ts +1 -0
- package/dist/src/components/Clipboard/index.js +1 -0
- package/dist/src/components/Code/OrigamCode.vue +79 -69
- package/dist/src/components/ColorPicker/OrigamColorPicker.vue +3 -2
- package/dist/src/components/ColorPicker/OrigamColorPickerCanvas.vue +75 -1
- package/dist/src/components/ColorPickerField/OrigamColorPickerField.vue +2 -2
- package/dist/src/components/CommandPalette/OrigamCommandPalette.vue +22 -16
- package/dist/src/components/ConfirmWrapper/OrigamConfirmWrapper.vue +1 -1
- package/dist/src/components/ContextualMenu/OrigamContextualMenu.vue +2 -2
- package/dist/src/components/Counter/OrigamCounter.vue +1 -1
- package/dist/src/components/DataList/OrigamDataList.vue +2 -2
- package/dist/src/components/DataList/OrigamDataText.vue +2 -2
- package/dist/src/components/DataList/OrigamDataTitle.vue +2 -2
- package/dist/src/components/DataTable/OrigamDataTable.vue +9 -3
- package/dist/src/components/DataTable/OrigamDataTableColumnCell.vue +1 -0
- package/dist/src/components/DataTable/OrigamDataTableFooter.vue +1 -1
- package/dist/src/components/DataTable/OrigamDataTableGroupHeaderRow.vue +1 -1
- package/dist/src/components/DataTable/OrigamDataTableHeaderCell.vue +2 -1
- package/dist/src/components/DataTable/OrigamDataTableHeaders.vue +1 -1
- package/dist/src/components/DataTable/OrigamDataTableHeadersCell.vue +1 -1
- package/dist/src/components/DataTable/OrigamDataTableHeadersCellMobile.vue +2 -2
- package/dist/src/components/DataTable/OrigamDataTableRow.vue +6 -1
- package/dist/src/components/DataTable/OrigamDataTableRows.vue +5 -3
- package/dist/src/components/DatePicker/OrigamDatePicker.vue +22 -12
- package/dist/src/components/DatePicker/OrigamDatePickerHeader.vue +1 -1
- package/dist/src/components/DatePicker/OrigamDatePickerMonth.vue +20 -15
- package/dist/src/components/DatePicker/OrigamDatePickerMonths.vue +1 -1
- package/dist/src/components/DatePicker/OrigamDatePickerYears.vue +1 -1
- package/dist/src/components/DatePickerField/OrigamDatePickerField.vue +5 -5
- package/dist/src/components/Dialog/OrigamDialog.vue +12 -4
- package/dist/src/components/Dialog/OrigamDialogConfirmation.vue +2 -2
- package/dist/src/components/Divider/OrigamDivider.vue +2 -2
- package/dist/src/components/Drawer/OrigamDrawer.vue +10 -2
- package/dist/src/components/EmptyState/OrigamEmptyState.vue +231 -0
- package/dist/src/components/EmptyState/index.cjs +13 -0
- package/dist/src/components/EmptyState/index.d.ts +1 -0
- package/dist/src/components/EmptyState/index.js +1 -0
- package/dist/src/components/ExpansionPanel/OrigamExpansionPanel.vue +2 -2
- package/dist/src/components/ExpansionPanel/OrigamExpansionPanelContent.vue +5 -2
- package/dist/src/components/ExpansionPanel/OrigamExpansionPanelHeader.vue +4 -2
- package/dist/src/components/ExpansionPanel/OrigamExpansionPanels.vue +2 -2
- package/dist/src/components/Field/OrigamField.vue +2 -2
- package/dist/src/components/FileField/OrigamFileField.vue +2 -2
- package/dist/src/components/FileField/OrigamFileFieldDragNDropItem.vue +2 -2
- package/dist/src/components/FileField/OrigamFileFieldListItem.vue +2 -2
- package/dist/src/components/Grid/OrigamGrid.vue +197 -0
- package/dist/src/components/Grid/OrigamGridItem.vue +69 -0
- package/dist/src/components/Grid/index.cjs +20 -0
- package/dist/src/components/Grid/index.d.ts +2 -0
- package/dist/src/components/Grid/index.js +2 -0
- package/dist/src/components/Grids/OrigamCol.vue +2 -2
- package/dist/src/components/Grids/OrigamRow.vue +1 -1
- package/dist/src/components/Icon/OrigamClassIcon.vue +14 -2
- package/dist/src/components/Icon/OrigamComponentIcon.vue +14 -2
- package/dist/src/components/Icon/OrigamIcon.vue +21 -2
- package/dist/src/components/Icon/OrigamLigatureIcon.vue +14 -2
- package/dist/src/components/Icon/OrigamSvgIcon.vue +15 -3
- package/dist/src/components/Img/OrigamImg.vue +2 -2
- package/dist/src/components/InfiniteScroll/OrigamInfiniteScroll.vue +4 -4
- package/dist/src/components/InlineEdit/OrigamInlineEdit.vue +477 -0
- package/dist/src/components/InlineEdit/index.cjs +13 -0
- package/dist/src/components/InlineEdit/index.d.ts +1 -0
- package/dist/src/components/InlineEdit/index.js +1 -0
- package/dist/src/components/Input/OrigamInput.vue +2 -2
- package/dist/src/components/Kbd/OrigamKbd.vue +2 -2
- package/dist/src/components/Label/OrigamLabel.vue +2 -2
- package/dist/src/components/Layout/OrigamLayout.vue +73 -4
- package/dist/src/components/Lazy/OrigamLazy.vue +1 -0
- package/dist/src/components/List/OrigamList.vue +3 -2
- package/dist/src/components/List/OrigamListGroup.vue +2 -2
- package/dist/src/components/List/OrigamListItem.vue +3 -2
- package/dist/src/components/List/OrigamListSubheader.vue +2 -2
- package/dist/src/components/Loader/OrigamLoader.vue +3 -1
- package/dist/src/components/Main/OrigamMain.vue +12 -2
- package/dist/src/components/Masonry/OrigamMasonry.vue +277 -0
- package/dist/src/components/Masonry/index.cjs +13 -0
- package/dist/src/components/Masonry/index.d.ts +1 -0
- package/dist/src/components/Masonry/index.js +1 -0
- package/dist/src/components/Media/OrigamMediaController.vue +529 -0
- package/dist/src/components/Media/OrigamMediaScrubber.vue +441 -0
- package/dist/src/components/Media/OrigamMediaVolumeControl.vue +151 -0
- package/dist/src/components/Media/index.cjs +27 -0
- package/dist/src/components/Media/index.d.ts +3 -0
- package/dist/src/components/Media/index.js +3 -0
- package/dist/src/components/Menu/OrigamMenu.vue +23 -5
- package/dist/src/components/Messages/OrigamMessages.vue +2 -2
- package/dist/src/components/NumberField/OrigamNumberField.vue +6 -6
- package/dist/src/components/NumberFormat/OrigamNumberFormat.vue +97 -0
- package/dist/src/components/NumberFormat/index.cjs +13 -0
- package/dist/src/components/NumberFormat/index.d.ts +1 -0
- package/dist/src/components/NumberFormat/index.js +1 -0
- package/dist/src/components/OtpInputField/OrigamOtpInputField.vue +12 -12
- package/dist/src/components/Overlay/OrigamOverlay.vue +1 -1
- package/dist/src/components/Overlay/OrigamOverlayScrim.vue +2 -1
- package/dist/src/components/Pagination/OrigamPagination.vue +4 -10
- package/dist/src/components/Parallax/OrigamParallax.vue +32 -4
- package/dist/src/components/PasswordField/OrigamPasswordField.vue +6 -6
- package/dist/src/components/Picker/OrigamPicker.vue +5 -5
- package/dist/src/components/Picker/OrigamPickerTitle.vue +2 -2
- package/dist/src/components/Progress/OrigamProgress.vue +3 -1
- package/dist/src/components/Progress/OrigamProgressCircular.vue +8 -1
- package/dist/src/components/Progress/OrigamProgressLinear.vue +13 -1
- package/dist/src/components/QRCode/OrigamQrCode.vue +246 -0
- package/dist/src/components/QRCode/index.cjs +13 -0
- package/dist/src/components/QRCode/index.js +1 -0
- package/dist/src/components/Radio/OrigamRadio.vue +2 -2
- package/dist/src/components/Radio/OrigamRadioBtn.vue +2 -2
- package/dist/src/components/Radio/OrigamRadioGroup.vue +2 -2
- package/dist/src/components/RatingField/OrigamRatingField.vue +20 -20
- package/dist/src/components/RatingField/OrigamRatingFieldItem.vue +1 -1
- package/dist/src/components/Select/OrigamSelect.vue +46 -12
- package/dist/src/components/SelectionControl/OrigamSelectionControl.vue +6 -2
- package/dist/src/components/SelectionControl/OrigamSelectionControlGroup.vue +2 -1
- package/dist/src/components/Sheet/OrigamSheet.vue +3 -3
- package/dist/src/components/Skeleton/OrigamSkeleton.vue +9 -2
- package/dist/src/components/SliderField/OrigamSliderField.vue +1065 -330
- package/dist/src/components/SliderField/OrigamSliderFieldTrack.vue +33 -45
- package/dist/src/components/SliderField/index.cjs +0 -7
- package/dist/src/components/SliderField/index.d.ts +0 -1
- package/dist/src/components/SliderField/index.js +0 -1
- package/dist/src/components/Snackbar/OrigamSnackbar.vue +255 -265
- package/dist/src/components/Snackbar/OrigamSnackbarGroup.vue +238 -0
- package/dist/src/components/Snackbar/OrigamSnackbarItem.vue +270 -0
- package/dist/src/components/Snackbar/index.cjs +14 -0
- package/dist/src/components/Snackbar/index.d.ts +2 -0
- package/dist/src/components/Snackbar/index.js +2 -0
- package/dist/src/components/Stepper/OrigamStepper.vue +66 -7
- package/dist/src/components/Switch/OrigamSwitch.vue +128 -11
- package/dist/src/components/Switch/OrigamSwitchTrack.vue +13 -2
- package/dist/src/components/SystemBar/OrigamSystemBar.vue +2 -2
- package/dist/src/components/Table/OrigamTable.vue +34 -1
- package/dist/src/components/Tabs/OrigamTabs.vue +2 -2
- package/dist/src/components/TextField/OrigamTextField.vue +4 -2
- package/dist/src/components/TextMask/OrigamTextMask.vue +157 -0
- package/dist/src/components/TextMask/index.cjs +13 -0
- package/dist/src/components/TextMask/index.d.ts +1 -0
- package/dist/src/components/TextMask/index.js +1 -0
- package/dist/src/components/TextareaField/OrigamTextareaField.vue +4 -2
- package/dist/src/components/Timeline/OrigamTimeline.vue +1 -1
- package/dist/src/components/Timeline/OrigamTimelineItem.vue +1 -1
- package/dist/src/components/Title/OrigamTitle.vue +2 -2
- package/dist/src/components/Toolbar/OrigamToolbar.vue +2 -2
- package/dist/src/components/Tooltip/OrigamTooltip.vue +2 -2
- package/dist/src/components/Treeview/OrigamTreeview.vue +2 -4
- package/dist/src/components/Video/OrigamVideo.vue +1087 -0
- package/dist/src/components/Video/index.cjs +13 -0
- package/dist/src/components/Video/index.d.ts +1 -0
- package/dist/src/components/Video/index.js +1 -0
- package/dist/src/components/Watermark/OrigamWatermark.vue +187 -0
- package/dist/src/components/Watermark/index.cjs +13 -0
- package/dist/src/components/Watermark/index.d.ts +1 -0
- package/dist/src/components/Watermark/index.js +1 -0
- package/dist/src/components/index.cjs +165 -11
- package/dist/src/components/index.d.ts +15 -1
- package/dist/src/components/index.js +15 -1
- package/dist/src/composables/Audio/use-audio-player.composable.cjs +26 -0
- package/dist/src/composables/Audio/use-audio-player.composable.d.ts +29 -0
- package/dist/src/composables/Audio/use-audio-player.composable.js +17 -0
- package/dist/src/composables/Audio/use-waveform.composable.cjs +91 -0
- package/dist/src/composables/Audio/use-waveform.composable.d.ts +32 -0
- package/dist/src/composables/Audio/use-waveform.composable.js +81 -0
- package/dist/src/composables/Calendar/calendar.composable.cjs +184 -0
- package/dist/src/composables/Calendar/calendar.composable.d.ts +72 -0
- package/dist/src/composables/Calendar/calendar.composable.js +182 -0
- package/dist/src/composables/Chart/chart-gauge.composable.cjs +54 -0
- package/dist/src/composables/Chart/chart-gauge.composable.d.ts +21 -0
- package/dist/src/composables/Chart/chart-gauge.composable.js +47 -0
- package/dist/src/composables/Chart/chart-zoom.composable.cjs +93 -0
- package/dist/src/composables/Chart/chart-zoom.composable.d.ts +34 -0
- package/dist/src/composables/Chart/chart-zoom.composable.js +87 -0
- package/dist/src/composables/Chart/chart.composable.cjs +893 -0
- package/dist/src/composables/Chart/chart.composable.d.ts +97 -0
- package/dist/src/composables/Chart/chart.composable.js +829 -0
- package/dist/src/composables/Clipboard/clipboard.composable.cjs +78 -0
- package/dist/src/composables/Clipboard/clipboard.composable.d.ts +21 -0
- package/dist/src/composables/Clipboard/clipboard.composable.js +79 -0
- package/dist/src/composables/Code/code.composable.cjs +21 -17
- package/dist/src/composables/Code/code.composable.js +13 -9
- package/dist/src/composables/Commons/audio.composable.d.ts +2 -2
- package/dist/src/composables/Commons/color.composable.cjs +47 -12
- package/dist/src/composables/Commons/color.composable.js +47 -12
- package/dist/src/composables/Commons/{calendar.composable.cjs → date-picker-calendar.composable.cjs} +2 -2
- package/dist/src/composables/Commons/{calendar.composable.d.ts → date-picker-calendar.composable.d.ts} +2 -2
- package/dist/src/composables/Commons/{calendar.composable.js → date-picker-calendar.composable.js} +1 -1
- package/dist/src/composables/Commons/elevation.composable.cjs +4 -5
- package/dist/src/composables/Commons/elevation.composable.js +1 -18
- package/dist/src/composables/CssSupport/cssSupport.composable.cjs +5 -26
- package/dist/src/composables/CssSupport/cssSupport.composable.d.ts +1 -23
- package/dist/src/composables/CssSupport/cssSupport.composable.js +1 -22
- package/dist/src/composables/DataTable/headers.composable.d.ts +28 -28
- package/dist/src/composables/InlineEdit/inline-edit.composable.cjs +87 -0
- package/dist/src/composables/InlineEdit/inline-edit.composable.d.ts +36 -0
- package/dist/src/composables/InlineEdit/inline-edit.composable.js +86 -0
- package/dist/src/composables/Masonry/masonry.composable.cjs +160 -0
- package/dist/src/composables/Masonry/masonry.composable.d.ts +132 -0
- package/dist/src/composables/Masonry/masonry.composable.js +160 -0
- package/dist/src/composables/Media/use-media-player.composable.cjs +286 -0
- package/dist/src/composables/Media/use-media-player.composable.d.ts +43 -0
- package/dist/src/composables/Media/use-media-player.composable.js +289 -0
- package/dist/src/composables/NumberFormat/number-format.composable.cjs +165 -0
- package/dist/src/composables/NumberFormat/number-format.composable.d.ts +33 -0
- package/dist/src/composables/NumberFormat/number-format.composable.js +146 -0
- package/dist/src/composables/QrCode/qr-code.composable.cjs +111 -0
- package/dist/src/composables/QrCode/qr-code.composable.d.ts +31 -0
- package/dist/src/composables/QrCode/qr-code.composable.js +120 -0
- package/dist/src/composables/Sheet/sheetSwipe.composable.cjs +5 -5
- package/dist/src/composables/Sheet/sheetSwipe.composable.d.ts +1 -1
- package/dist/src/composables/Sheet/sheetSwipe.composable.js +3 -3
- package/dist/src/composables/SliderField/slider-field.composable.cjs +0 -213
- package/dist/src/composables/SliderField/slider-field.composable.d.ts +11 -5
- package/dist/src/composables/SliderField/slider-field.composable.js +2 -191
- package/dist/src/composables/{SnackbarStack/snackbar-stack.composable.cjs → Snackbar/snackbar-group.composable.cjs} +10 -10
- package/dist/src/composables/{SnackbarStack/snackbar-stack.composable.d.ts → Snackbar/snackbar-group.composable.d.ts} +14 -14
- package/dist/src/composables/{SnackbarStack/snackbar-stack.composable.js → Snackbar/snackbar-group.composable.js} +9 -9
- package/dist/src/composables/Theme/theme.composable.cjs +5 -6
- package/dist/src/composables/Theme/theme.composable.js +1 -2
- package/dist/src/composables/Video/video-player.composable.cjs +129 -0
- package/dist/src/composables/Video/video-player.composable.d.ts +44 -0
- package/dist/src/composables/Video/video-player.composable.js +128 -0
- package/dist/src/composables/Watermark/watermark.composable.cjs +147 -0
- package/dist/src/composables/Watermark/watermark.composable.d.ts +28 -0
- package/dist/src/composables/Watermark/watermark.composable.js +158 -0
- package/dist/src/composables/index.cjs +237 -8
- package/dist/src/composables/index.d.ts +14 -2
- package/dist/src/composables/index.js +14 -2
- package/dist/src/consts/Audio/audio.const.cjs +25 -0
- package/dist/src/consts/Audio/audio.const.d.ts +30 -0
- package/dist/src/consts/Audio/audio.const.js +19 -0
- package/dist/src/consts/Blockquote/blockquote.const.cjs +32 -0
- package/dist/src/consts/Blockquote/blockquote.const.d.ts +37 -0
- package/dist/src/consts/Blockquote/blockquote.const.js +30 -0
- package/dist/src/consts/Chart/chart.const.cjs +26 -0
- package/dist/src/consts/Chart/chart.const.d.ts +32 -0
- package/dist/src/consts/Chart/chart.const.js +9 -0
- package/dist/src/consts/Chart/country-centroids.const.cjs +43 -0
- package/dist/src/consts/Chart/country-centroids.const.d.ts +10 -0
- package/dist/src/consts/Chart/country-centroids.const.js +37 -0
- package/dist/src/consts/Chart/pictorial-icons.const.cjs +12 -0
- package/dist/src/consts/Chart/pictorial-icons.const.d.ts +18 -0
- package/dist/src/consts/Chart/pictorial-icons.const.js +6 -0
- package/dist/src/consts/Chart/world-geographic.const.cjs +152 -0
- package/dist/src/consts/Chart/world-geographic.const.d.ts +22 -0
- package/dist/src/consts/Chart/world-geographic.const.js +1722 -0
- package/dist/src/consts/Chart/world-map.const.cjs +43 -0
- package/dist/src/consts/Chart/world-map.const.d.ts +14 -0
- package/dist/src/consts/Chart/world-map.const.js +37 -0
- package/dist/src/consts/Clipboard/clipboard.const.cjs +7 -0
- package/dist/src/consts/Clipboard/clipboard.const.d.ts +6 -0
- package/dist/src/consts/Clipboard/clipboard.const.js +1 -0
- package/dist/src/consts/Code/code.const.cjs +3 -6
- package/dist/src/consts/Code/code.const.d.ts +8 -12
- package/dist/src/consts/Code/code.const.js +3 -6
- package/dist/src/consts/Commons/elevation.const.cjs +8 -0
- package/dist/src/consts/Commons/elevation.const.d.ts +17 -0
- package/dist/src/consts/Commons/elevation.const.js +18 -0
- package/dist/src/consts/CssSupport/css-support.const.cjs +29 -0
- package/dist/src/consts/CssSupport/css-support.const.d.ts +40 -0
- package/dist/src/consts/CssSupport/css-support.const.js +23 -0
- package/dist/src/consts/DataTable/select.const.cjs +2 -1
- package/dist/src/consts/DataTable/select.const.d.ts +2 -1
- package/dist/src/consts/DataTable/select.const.js +1 -0
- package/dist/src/consts/EmptyState/empty-state.const.cjs +32 -0
- package/dist/src/consts/EmptyState/empty-state.const.d.ts +29 -0
- package/dist/src/consts/EmptyState/empty-state.const.js +39 -0
- package/dist/src/consts/Grid/grid.const.cjs +28 -0
- package/dist/src/consts/Grid/grid.const.d.ts +49 -0
- package/dist/src/consts/Grid/grid.const.js +46 -0
- package/dist/src/consts/Masonry/masonry.const.cjs +14 -0
- package/dist/src/consts/Masonry/masonry.const.d.ts +27 -0
- package/dist/src/consts/Masonry/masonry.const.js +11 -0
- package/dist/src/consts/Media/media.const.cjs +8 -0
- package/dist/src/consts/Media/media.const.d.ts +14 -0
- package/dist/src/consts/Media/media.const.js +2 -0
- package/dist/src/consts/NumberFormat/number-format.const.cjs +9 -0
- package/dist/src/consts/NumberFormat/number-format.const.d.ts +19 -0
- package/dist/src/consts/NumberFormat/number-format.const.js +3 -0
- package/dist/src/consts/QrCode/qr-code.const.cjs +12 -0
- package/dist/src/consts/QrCode/qr-code.const.d.ts +33 -0
- package/dist/src/consts/QrCode/qr-code.const.js +6 -0
- package/dist/src/consts/Sheet/sheet-swipe.const.cjs +7 -0
- package/dist/src/consts/Sheet/sheet-swipe.const.d.ts +11 -0
- package/dist/src/consts/Sheet/sheet-swipe.const.js +1 -0
- package/dist/src/consts/Snackbar/snackbar-group.const.cjs +12 -0
- package/dist/src/consts/Snackbar/snackbar-group.const.d.ts +33 -0
- package/dist/src/consts/Snackbar/snackbar-group.const.js +18 -0
- package/dist/src/consts/Video/video.const.cjs +7 -0
- package/dist/src/consts/Video/video.const.d.ts +7 -0
- package/dist/src/consts/Video/video.const.js +1 -0
- package/dist/src/consts/Watermark/watermark.const.cjs +16 -0
- package/dist/src/consts/Watermark/watermark.const.d.ts +27 -0
- package/dist/src/consts/Watermark/watermark.const.js +10 -0
- package/dist/src/consts/index.cjs +188 -12
- package/dist/src/consts/index.d.ts +18 -2
- package/dist/src/consts/index.js +18 -2
- package/dist/src/enums/Audio/audio-loop-mode.enum.cjs +12 -0
- package/dist/src/enums/Audio/audio-loop-mode.enum.d.ts +17 -0
- package/dist/src/enums/Audio/audio-loop-mode.enum.js +6 -0
- package/dist/src/enums/Audio/audio-variant.enum.cjs +13 -0
- package/dist/src/enums/Audio/audio-variant.enum.d.ts +26 -0
- package/dist/src/enums/Audio/audio-variant.enum.js +7 -0
- package/dist/src/enums/Audio/cover-position.enum.cjs +11 -0
- package/dist/src/enums/Audio/cover-position.enum.d.ts +9 -0
- package/dist/src/enums/Audio/cover-position.enum.js +5 -0
- package/dist/src/enums/Blockquote/blockquote-lang.enum.cjs +14 -0
- package/dist/src/enums/Blockquote/blockquote-lang.enum.d.ts +7 -0
- package/dist/src/enums/Blockquote/blockquote-lang.enum.js +8 -0
- package/dist/src/enums/Blockquote/blockquote-variant.enum.cjs +14 -0
- package/dist/src/enums/Blockquote/blockquote-variant.enum.d.ts +7 -0
- package/dist/src/enums/Blockquote/blockquote-variant.enum.js +8 -0
- package/dist/src/enums/Chart/chart-bullet-orientation.enum.cjs +11 -0
- package/dist/src/enums/Chart/chart-bullet-orientation.enum.d.ts +4 -0
- package/dist/src/enums/Chart/chart-bullet-orientation.enum.js +5 -0
- package/dist/src/enums/Chart/chart-cartesian-kind.enum.cjs +16 -0
- package/dist/src/enums/Chart/chart-cartesian-kind.enum.d.ts +14 -0
- package/dist/src/enums/Chart/chart-cartesian-kind.enum.js +10 -0
- package/dist/src/enums/Chart/chart-honeycomb-color-mode.enum.cjs +11 -0
- package/dist/src/enums/Chart/chart-honeycomb-color-mode.enum.d.ts +4 -0
- package/dist/src/enums/Chart/chart-honeycomb-color-mode.enum.js +5 -0
- package/dist/src/enums/Chart/chart-honeycomb-orientation.enum.cjs +11 -0
- package/dist/src/enums/Chart/chart-honeycomb-orientation.enum.d.ts +4 -0
- package/dist/src/enums/Chart/chart-honeycomb-orientation.enum.js +5 -0
- package/dist/src/enums/Chart/chart-map-mode.enum.cjs +11 -0
- package/dist/src/enums/Chart/chart-map-mode.enum.d.ts +4 -0
- package/dist/src/enums/Chart/chart-map-mode.enum.js +5 -0
- package/dist/src/enums/Chart/chart-pictorial-direction.enum.cjs +11 -0
- package/dist/src/enums/Chart/chart-pictorial-direction.enum.d.ts +4 -0
- package/dist/src/enums/Chart/chart-pictorial-direction.enum.js +5 -0
- package/dist/src/enums/Chart/chart-pictorial-mode.enum.cjs +11 -0
- package/dist/src/enums/Chart/chart-pictorial-mode.enum.d.ts +4 -0
- package/dist/src/enums/Chart/chart-pictorial-mode.enum.js +5 -0
- package/dist/src/enums/Chart/chart-polar-kind.enum.cjs +11 -0
- package/dist/src/enums/Chart/chart-polar-kind.enum.d.ts +8 -0
- package/dist/src/enums/Chart/chart-polar-kind.enum.js +5 -0
- package/dist/src/enums/Chart/chart-pyramid-kind.enum.cjs +11 -0
- package/dist/src/enums/Chart/chart-pyramid-kind.enum.d.ts +4 -0
- package/dist/src/enums/Chart/chart-pyramid-kind.enum.js +5 -0
- package/dist/src/enums/Chart/chart-sparkline-kind.enum.cjs +13 -0
- package/dist/src/enums/Chart/chart-sparkline-kind.enum.d.ts +6 -0
- package/dist/src/enums/Chart/chart-sparkline-kind.enum.js +7 -0
- package/dist/src/enums/Chart/chart-stacking.enum.cjs +11 -0
- package/dist/src/enums/Chart/chart-stacking.enum.d.ts +14 -0
- package/dist/src/enums/Chart/chart-stacking.enum.js +5 -0
- package/dist/src/enums/Chart/chart-streamgraph-offset.enum.cjs +13 -0
- package/dist/src/enums/Chart/chart-streamgraph-offset.enum.d.ts +6 -0
- package/dist/src/enums/Chart/chart-streamgraph-offset.enum.js +7 -0
- package/dist/src/enums/Chart/chart-treemap-algorithm.enum.cjs +11 -0
- package/dist/src/enums/Chart/chart-treemap-algorithm.enum.d.ts +9 -0
- package/dist/src/enums/Chart/chart-treemap-algorithm.enum.js +5 -0
- package/dist/src/enums/Chart/chart-word-cloud-rotation.enum.cjs +12 -0
- package/dist/src/enums/Chart/chart-word-cloud-rotation.enum.d.ts +5 -0
- package/dist/src/enums/Chart/chart-word-cloud-rotation.enum.js +6 -0
- package/dist/src/enums/Chart/chart.enum.cjs +38 -0
- package/dist/src/enums/Chart/chart.enum.d.ts +31 -0
- package/dist/src/enums/Chart/chart.enum.js +32 -0
- package/dist/src/enums/EmptyState/empty-state-preset.enum.cjs +14 -0
- package/dist/src/enums/EmptyState/empty-state-preset.enum.d.ts +16 -0
- package/dist/src/enums/EmptyState/empty-state-preset.enum.js +8 -0
- package/dist/src/enums/InlineEdit/inline-edit-action.enum.cjs +12 -0
- package/dist/src/enums/InlineEdit/inline-edit-action.enum.d.ts +10 -0
- package/dist/src/enums/InlineEdit/inline-edit-action.enum.js +6 -0
- package/dist/src/enums/SliderField/slider-field-variant.enum.cjs +12 -0
- package/dist/src/enums/SliderField/slider-field-variant.enum.d.ts +21 -0
- package/dist/src/enums/SliderField/slider-field-variant.enum.js +6 -0
- package/dist/src/enums/index.cjs +240 -9
- package/dist/src/enums/index.d.ts +23 -2
- package/dist/src/enums/index.js +23 -2
- package/dist/src/interfaces/Alert/alert.interface.d.ts +5 -1
- package/dist/src/interfaces/App/app-bar.interface.d.ts +4 -1
- package/dist/src/interfaces/Audio/audio-player.interface.d.ts +406 -0
- package/dist/src/interfaces/Avatar/avatar-group.interface.d.ts +5 -1
- package/dist/src/interfaces/Avatar/avatar.interface.d.ts +4 -1
- package/dist/src/interfaces/Blockquote/blockquote.interface.d.ts +84 -0
- package/dist/src/interfaces/BottomNav/bottom-nav.interface.d.ts +5 -1
- package/dist/src/interfaces/Bracket/bracket.interface.d.ts +3 -10
- package/dist/src/interfaces/Breadcrumb/breadcrumb-item.interface.d.ts +4 -1
- package/dist/src/interfaces/Btn/btn-toggle.interface.d.ts +4 -1
- package/dist/src/interfaces/Btn/btn.interface.d.ts +5 -1
- package/dist/src/interfaces/Calendar/calendar.interface.d.ts +159 -0
- package/dist/src/interfaces/Calendar/event.interface.d.ts +54 -0
- package/dist/src/interfaces/Card/card-header.interface.d.ts +4 -1
- package/dist/src/interfaces/Card/card.interface.d.ts +5 -1
- package/dist/src/interfaces/Carousel/carousel.interface.d.ts +4 -1
- package/dist/src/interfaces/Chart/chart-annotation.interface.d.ts +99 -0
- package/dist/src/interfaces/Chart/chart-axis.interface.d.ts +78 -0
- package/dist/src/interfaces/Chart/chart-base.interface.d.ts +87 -0
- package/dist/src/interfaces/Chart/chart-box-plot.interface.d.ts +203 -0
- package/dist/src/interfaces/Chart/chart-bullet.interface.d.ts +140 -0
- package/dist/src/interfaces/Chart/chart-candlestick.interface.d.ts +131 -0
- package/dist/src/interfaces/Chart/chart-cartesian.interface.d.ts +124 -0
- package/dist/src/interfaces/Chart/chart-cartesian.interface.js +0 -0
- package/dist/src/interfaces/Chart/chart-drilldown.interface.cjs +1 -0
- package/dist/src/interfaces/Chart/chart-drilldown.interface.d.ts +60 -0
- package/dist/src/interfaces/Chart/chart-drilldown.interface.js +0 -0
- package/dist/src/interfaces/Chart/chart-gauge.interface.cjs +1 -0
- package/dist/src/interfaces/Chart/chart-gauge.interface.d.ts +130 -0
- package/dist/src/interfaces/Chart/chart-gauge.interface.js +0 -0
- package/dist/src/interfaces/Chart/chart-heatmap.interface.cjs +1 -0
- package/dist/src/interfaces/Chart/chart-heatmap.interface.d.ts +128 -0
- package/dist/src/interfaces/Chart/chart-heatmap.interface.js +0 -0
- package/dist/src/interfaces/Chart/chart-honeycomb.interface.cjs +1 -0
- package/dist/src/interfaces/Chart/chart-honeycomb.interface.d.ts +109 -0
- package/dist/src/interfaces/Chart/chart-honeycomb.interface.js +0 -0
- package/dist/src/interfaces/Chart/chart-legend.interface.cjs +1 -0
- package/dist/src/interfaces/Chart/chart-legend.interface.d.ts +48 -0
- package/dist/src/interfaces/Chart/chart-legend.interface.js +0 -0
- package/dist/src/interfaces/Chart/chart-map.interface.cjs +1 -0
- package/dist/src/interfaces/Chart/chart-map.interface.d.ts +137 -0
- package/dist/src/interfaces/Chart/chart-map.interface.js +0 -0
- package/dist/src/interfaces/Chart/chart-pareto.interface.cjs +1 -0
- package/dist/src/interfaces/Chart/chart-pareto.interface.d.ts +124 -0
- package/dist/src/interfaces/Chart/chart-pareto.interface.js +0 -0
- package/dist/src/interfaces/Chart/chart-pictorial.interface.cjs +1 -0
- package/dist/src/interfaces/Chart/chart-pictorial.interface.d.ts +114 -0
- package/dist/src/interfaces/Chart/chart-pictorial.interface.js +0 -0
- package/dist/src/interfaces/Chart/chart-plot-band.interface.cjs +1 -0
- package/dist/src/interfaces/Chart/chart-plot-band.interface.d.ts +34 -0
- package/dist/src/interfaces/Chart/chart-plot-band.interface.js +0 -0
- package/dist/src/interfaces/Chart/chart-plot-line.interface.cjs +1 -0
- package/dist/src/interfaces/Chart/chart-plot-line.interface.d.ts +39 -0
- package/dist/src/interfaces/Chart/chart-plot-line.interface.js +0 -0
- package/dist/src/interfaces/Chart/chart-point.interface.cjs +1 -0
- package/dist/src/interfaces/Chart/chart-point.interface.d.ts +20 -0
- package/dist/src/interfaces/Chart/chart-point.interface.js +0 -0
- package/dist/src/interfaces/Chart/chart-polar-bar.interface.cjs +1 -0
- package/dist/src/interfaces/Chart/chart-polar-bar.interface.d.ts +118 -0
- package/dist/src/interfaces/Chart/chart-polar-bar.interface.js +0 -0
- package/dist/src/interfaces/Chart/chart-polar.interface.cjs +1 -0
- package/dist/src/interfaces/Chart/chart-polar.interface.d.ts +43 -0
- package/dist/src/interfaces/Chart/chart-polar.interface.js +0 -0
- package/dist/src/interfaces/Chart/chart-pyramid.interface.cjs +1 -0
- package/dist/src/interfaces/Chart/chart-pyramid.interface.d.ts +96 -0
- package/dist/src/interfaces/Chart/chart-pyramid.interface.js +0 -0
- package/dist/src/interfaces/Chart/chart-radar.interface.cjs +1 -0
- package/dist/src/interfaces/Chart/chart-radar.interface.d.ts +10 -0
- package/dist/src/interfaces/Chart/chart-radar.interface.js +0 -0
- package/dist/src/interfaces/Chart/chart-range-selector.interface.cjs +1 -0
- package/dist/src/interfaces/Chart/chart-range-selector.interface.d.ts +38 -0
- package/dist/src/interfaces/Chart/chart-range-selector.interface.js +0 -0
- package/dist/src/interfaces/Chart/chart-sankey.interface.cjs +1 -0
- package/dist/src/interfaces/Chart/chart-sankey.interface.d.ts +124 -0
- package/dist/src/interfaces/Chart/chart-sankey.interface.js +0 -0
- package/dist/src/interfaces/Chart/chart-series.interface.cjs +1 -0
- package/dist/src/interfaces/Chart/chart-series.interface.d.ts +80 -0
- package/dist/src/interfaces/Chart/chart-series.interface.js +0 -0
- package/dist/src/interfaces/Chart/chart-sparkline.interface.cjs +1 -0
- package/dist/src/interfaces/Chart/chart-sparkline.interface.d.ts +108 -0
- package/dist/src/interfaces/Chart/chart-sparkline.interface.js +0 -0
- package/dist/src/interfaces/Chart/chart-streamgraph.interface.cjs +1 -0
- package/dist/src/interfaces/Chart/chart-streamgraph.interface.d.ts +82 -0
- package/dist/src/interfaces/Chart/chart-streamgraph.interface.js +0 -0
- package/dist/src/interfaces/Chart/chart-sunburst.interface.cjs +1 -0
- package/dist/src/interfaces/Chart/chart-sunburst.interface.d.ts +100 -0
- package/dist/src/interfaces/Chart/chart-sunburst.interface.js +0 -0
- package/dist/src/interfaces/Chart/chart-tooltip.interface.cjs +1 -0
- package/dist/src/interfaces/Chart/chart-tooltip.interface.d.ts +55 -0
- package/dist/src/interfaces/Chart/chart-tooltip.interface.js +0 -0
- package/dist/src/interfaces/Chart/chart-treemap.interface.cjs +1 -0
- package/dist/src/interfaces/Chart/chart-treemap.interface.d.ts +106 -0
- package/dist/src/interfaces/Chart/chart-treemap.interface.js +0 -0
- package/dist/src/interfaces/Chart/chart-variwide.interface.cjs +1 -0
- package/dist/src/interfaces/Chart/chart-variwide.interface.d.ts +132 -0
- package/dist/src/interfaces/Chart/chart-variwide.interface.js +0 -0
- package/dist/src/interfaces/Chart/chart-word-cloud.interface.cjs +1 -0
- package/dist/src/interfaces/Chart/chart-word-cloud.interface.d.ts +83 -0
- package/dist/src/interfaces/Chart/chart-word-cloud.interface.js +0 -0
- package/dist/src/interfaces/Chart/chart.interface.cjs +1 -0
- package/dist/src/interfaces/Chart/chart.interface.d.ts +276 -0
- package/dist/src/interfaces/Chart/chart.interface.js +0 -0
- package/dist/src/interfaces/Chip/chip-group.interface.d.ts +4 -1
- package/dist/src/interfaces/Chip/chip.interface.d.ts +5 -1
- package/dist/src/interfaces/Clipboard/clipboard.interface.cjs +1 -0
- package/dist/src/interfaces/Clipboard/clipboard.interface.d.ts +106 -0
- package/dist/src/interfaces/Clipboard/clipboard.interface.js +0 -0
- package/dist/src/interfaces/Code/code.interface.d.ts +4 -14
- package/dist/src/interfaces/ColorPicker/color-picker-canvas.interface.d.ts +5 -1
- package/dist/src/interfaces/ColorPicker/color-picker-edit.interface.d.ts +5 -1
- package/dist/src/interfaces/ColorPicker/color-picker-preview.interface.d.ts +4 -1
- package/dist/src/interfaces/ColorPicker/color-picker-swatches.interface.d.ts +5 -1
- package/dist/src/interfaces/ColorPicker/color-picker.interface.d.ts +18 -2
- package/dist/src/interfaces/Commons/audio.interface.d.ts +7 -1
- package/dist/src/interfaces/Commons/clickOutside.interface.d.ts +5 -0
- package/dist/src/interfaces/Commons/commons.interface.d.ts +18 -0
- package/dist/src/interfaces/Commons/gradient.interface.cjs +1 -0
- package/dist/src/interfaces/Commons/gradient.interface.d.ts +39 -0
- package/dist/src/interfaces/Commons/gradient.interface.js +0 -0
- package/dist/src/interfaces/Commons/group.interface.d.ts +6 -0
- package/dist/src/interfaces/Commons/hover.interface.d.ts +4 -0
- package/dist/src/interfaces/Commons/layout.interface.d.ts +2 -2
- package/dist/src/interfaces/Commons/lazy.interface.d.ts +5 -1
- package/dist/src/interfaces/DataTable/data-table.interface.d.ts +12 -1
- package/dist/src/interfaces/DataTable/headers.interface.d.ts +6 -1
- package/dist/src/interfaces/DataTable/row.interface.d.ts +11 -0
- package/dist/src/interfaces/DatePicker/date-picker-controls.interface.d.ts +9 -0
- package/dist/src/interfaces/DatePicker/date-picker-header.interface.d.ts +4 -1
- package/dist/src/interfaces/DatePicker/date-picker-months.interface.d.ts +4 -0
- package/dist/src/interfaces/DatePicker/date-picker-years.interface.d.ts +4 -0
- package/dist/src/interfaces/DatePicker/date-picker.interface.d.ts +9 -1
- package/dist/src/interfaces/DatePickerField/date-picker-field.interface.d.ts +2 -2
- package/dist/src/interfaces/Dialog/dialog-confirmation.interface.d.ts +5 -0
- package/dist/src/interfaces/Dialog/dialog.interface.d.ts +8 -1
- package/dist/src/interfaces/Drawer/drawer.interface.d.ts +4 -0
- package/dist/src/interfaces/EmptyState/empty-state.interface.cjs +1 -0
- package/dist/src/interfaces/EmptyState/empty-state.interface.d.ts +100 -0
- package/dist/src/interfaces/EmptyState/empty-state.interface.js +0 -0
- package/dist/src/interfaces/ExpensionPanel/expansion-panel-header.interface.d.ts +4 -1
- package/dist/src/interfaces/ExpensionPanel/expansion-panel.interface.d.ts +4 -1
- package/dist/src/interfaces/ExpensionPanel/expansion-panels.interface.d.ts +4 -1
- package/dist/src/interfaces/FileField/file-field-dragndrop-item.interface.d.ts +2 -3
- package/dist/src/interfaces/FileField/file-field-list-item.interface.d.ts +2 -3
- package/dist/src/interfaces/Grid/grid-item.interface.cjs +1 -0
- package/dist/src/interfaces/Grid/grid-item.interface.d.ts +55 -0
- package/dist/src/interfaces/Grid/grid-item.interface.js +0 -0
- package/dist/src/interfaces/Grid/grid.interface.cjs +1 -0
- package/dist/src/interfaces/Grid/grid.interface.d.ts +121 -0
- package/dist/src/interfaces/Grid/grid.interface.js +0 -0
- package/dist/src/interfaces/Icon/icon.interface.d.ts +2 -2
- package/dist/src/interfaces/Img/img.interface.d.ts +14 -0
- package/dist/src/interfaces/InfiniteScroll/infinite-scroll.interface.d.ts +16 -0
- package/dist/src/interfaces/InlineEdit/inline-edit.interface.cjs +1 -0
- package/dist/src/interfaces/InlineEdit/inline-edit.interface.d.ts +241 -0
- package/dist/src/interfaces/InlineEdit/inline-edit.interface.js +0 -0
- package/dist/src/interfaces/ItemGroup/item-group.interface.d.ts +4 -1
- package/dist/src/interfaces/List/list-group.interface.d.ts +5 -0
- package/dist/src/interfaces/List/list-item.interface.d.ts +4 -1
- package/dist/src/interfaces/List/list.interface.d.ts +16 -0
- package/dist/src/interfaces/Main/main.interface.d.ts +2 -2
- package/dist/src/interfaces/Masonry/masonry.interface.cjs +1 -0
- package/dist/src/interfaces/Masonry/masonry.interface.d.ts +80 -0
- package/dist/src/interfaces/Masonry/masonry.interface.js +0 -0
- package/dist/src/interfaces/Media/index.cjs +49 -0
- package/dist/src/interfaces/Media/index.d.ts +4 -0
- package/dist/src/interfaces/Media/index.js +4 -0
- package/dist/src/interfaces/Media/media-controller.interface.cjs +1 -0
- package/dist/src/interfaces/Media/media-controller.interface.d.ts +159 -0
- package/dist/src/interfaces/Media/media-controller.interface.js +0 -0
- package/dist/src/interfaces/Media/media-player.interface.cjs +1 -0
- package/dist/src/interfaces/Media/media-player.interface.d.ts +121 -0
- package/dist/src/interfaces/Media/media-player.interface.js +0 -0
- package/dist/src/interfaces/Media/media-scrubber.interface.cjs +1 -0
- package/dist/src/interfaces/Media/media-scrubber.interface.d.ts +129 -0
- package/dist/src/interfaces/Media/media-scrubber.interface.js +0 -0
- package/dist/src/interfaces/Media/media-volume-control.interface.cjs +1 -0
- package/dist/src/interfaces/Media/media-volume-control.interface.d.ts +68 -0
- package/dist/src/interfaces/Media/media-volume-control.interface.js +0 -0
- package/dist/src/interfaces/Menu/menu.interface.d.ts +7 -1
- package/dist/src/interfaces/NumberField/number-field.interface.d.ts +2 -2
- package/dist/src/interfaces/NumberFormat/number-format.interface.cjs +1 -0
- package/dist/src/interfaces/NumberFormat/number-format.interface.d.ts +161 -0
- package/dist/src/interfaces/NumberFormat/number-format.interface.js +0 -0
- package/dist/src/interfaces/OtpInputField/otp-input-field.interface.d.ts +2 -2
- package/dist/src/interfaces/Overlay/overlay-scrim.interface.d.ts +8 -1
- package/dist/src/interfaces/Overlay/overlay.interface.d.ts +8 -1
- package/dist/src/interfaces/Pagination/pagination.interface.d.ts +9 -1
- package/dist/src/interfaces/PasswordField/password-field.interface.d.ts +2 -2
- package/dist/src/interfaces/Picker/picker.interface.d.ts +2 -2
- package/dist/src/interfaces/QrCode/qr-code-logo.interface.cjs +1 -0
- package/dist/src/interfaces/QrCode/qr-code-logo.interface.d.ts +47 -0
- package/dist/src/interfaces/QrCode/qr-code-logo.interface.js +0 -0
- package/dist/src/interfaces/QrCode/qr-code.interface.cjs +1 -0
- package/dist/src/interfaces/QrCode/qr-code.interface.d.ts +152 -0
- package/dist/src/interfaces/QrCode/qr-code.interface.js +0 -0
- package/dist/src/interfaces/Radio/radio-btn.interface.d.ts +4 -1
- package/dist/src/interfaces/Radio/radio.interface.d.ts +4 -1
- package/dist/src/interfaces/RatingField/rating-field-item.interface.d.ts +7 -1
- package/dist/src/interfaces/RatingField/rating-field.interface.d.ts +5 -2
- package/dist/src/interfaces/Select/select.interface.d.ts +9 -1
- package/dist/src/interfaces/Slide/slide-group.interface.d.ts +4 -1
- package/dist/src/interfaces/SliderField/slider-field-track.interface.d.ts +17 -0
- package/dist/src/interfaces/SliderField/slider-field.interface.d.ts +77 -59
- package/dist/src/interfaces/Snackbar/snackbar-group-item.interface.cjs +1 -0
- package/dist/src/interfaces/{SnackbarStack/snackbar-stack-item.interface.d.ts → Snackbar/snackbar-group-item.interface.d.ts} +5 -5
- package/dist/src/interfaces/Snackbar/snackbar-group-item.interface.js +0 -0
- package/dist/src/interfaces/Snackbar/snackbar-group.interface.cjs +1 -0
- package/dist/src/interfaces/{SnackbarStack/snackbar-stack.interface.d.ts → Snackbar/snackbar-group.interface.d.ts} +7 -7
- package/dist/src/interfaces/Snackbar/snackbar-group.interface.js +0 -0
- package/dist/src/interfaces/Snackbar/snackbar-item.interface.cjs +1 -0
- package/dist/src/interfaces/Snackbar/snackbar-item.interface.d.ts +79 -0
- package/dist/src/interfaces/Snackbar/snackbar-item.interface.js +0 -0
- package/dist/src/interfaces/Stepper/stepper.interface.d.ts +2 -2
- package/dist/src/interfaces/Switch/switch-track.interface.d.ts +8 -0
- package/dist/src/interfaces/Switch/switch.interface.d.ts +5 -1
- package/dist/src/interfaces/Table/table.interface.d.ts +3 -0
- package/dist/src/interfaces/Tabs/tab-panels.interface.d.ts +4 -1
- package/dist/src/interfaces/Tabs/tabs.interface.d.ts +4 -1
- package/dist/src/interfaces/TextMask/text-mask.interface.cjs +1 -0
- package/dist/src/interfaces/TextMask/text-mask.interface.d.ts +112 -0
- package/dist/src/interfaces/TextMask/text-mask.interface.js +0 -0
- package/dist/src/interfaces/Tooltip/tooltip.interface.d.ts +4 -1
- package/dist/src/interfaces/Video/video-track.interface.cjs +1 -0
- package/dist/src/interfaces/Video/video-track.interface.d.ts +76 -0
- package/dist/src/interfaces/Video/video-track.interface.js +0 -0
- package/dist/src/interfaces/Video/video.interface.cjs +1 -0
- package/dist/src/interfaces/Video/video.interface.d.ts +317 -0
- package/dist/src/interfaces/Video/video.interface.js +0 -0
- package/dist/src/interfaces/VirtualScroll/virtual-scroll-item.interface.d.ts +6 -0
- package/dist/src/interfaces/Watermark/watermark.interface.cjs +1 -0
- package/dist/src/interfaces/Watermark/watermark.interface.d.ts +163 -0
- package/dist/src/interfaces/Watermark/watermark.interface.js +0 -0
- package/dist/src/interfaces/Window/window-item.interface.d.ts +4 -1
- package/dist/src/interfaces/Window/window.interface.d.ts +4 -1
- package/dist/src/interfaces/index.cjs +588 -49
- package/dist/src/interfaces/index.d.ts +55 -6
- package/dist/src/interfaces/index.js +55 -6
- package/dist/src/types/Audio/audio-controls.type.cjs +1 -0
- package/dist/src/types/Audio/audio-controls.type.d.ts +12 -0
- package/dist/src/types/Audio/audio-controls.type.js +0 -0
- package/dist/src/types/Audio/audio-loop-mode.type.cjs +1 -0
- package/dist/src/types/Audio/audio-loop-mode.type.d.ts +5 -0
- package/dist/src/types/Audio/audio-loop-mode.type.js +0 -0
- package/dist/src/types/Audio/audio-variant.type.cjs +1 -0
- package/dist/src/types/Audio/audio-variant.type.d.ts +7 -0
- package/dist/src/types/Audio/audio-variant.type.js +0 -0
- package/dist/src/types/Audio/cover-position.type.cjs +1 -0
- package/dist/src/types/Audio/cover-position.type.d.ts +6 -0
- package/dist/src/types/Audio/cover-position.type.js +0 -0
- package/dist/src/types/Blockquote/blockquote-align.type.cjs +1 -0
- package/dist/src/types/Blockquote/blockquote-align.type.d.ts +5 -0
- package/dist/src/types/Blockquote/blockquote-align.type.js +0 -0
- package/dist/src/types/Blockquote/blockquote-lang.type.cjs +1 -0
- package/dist/src/types/Blockquote/blockquote-lang.type.d.ts +18 -0
- package/dist/src/types/Blockquote/blockquote-lang.type.js +0 -0
- package/dist/src/types/Blockquote/blockquote-variant.type.cjs +1 -0
- package/dist/src/types/Blockquote/blockquote-variant.type.d.ts +17 -0
- package/dist/src/types/Blockquote/blockquote-variant.type.js +0 -0
- package/dist/src/types/Calendar/calendar-time-format.type.cjs +1 -0
- package/dist/src/types/Calendar/calendar-time-format.type.d.ts +13 -0
- package/dist/src/types/Calendar/calendar-time-format.type.js +0 -0
- package/dist/src/types/Calendar/calendar-view.type.cjs +1 -0
- package/dist/src/types/Calendar/calendar-view.type.d.ts +10 -0
- package/dist/src/types/Calendar/calendar-view.type.js +0 -0
- package/dist/src/types/Chart/chart-bullet-orientation.type.cjs +1 -0
- package/dist/src/types/Chart/chart-bullet-orientation.type.d.ts +1 -0
- package/dist/src/types/Chart/chart-bullet-orientation.type.js +0 -0
- package/dist/src/types/Chart/chart-cartesian-kind.type.cjs +1 -0
- package/dist/src/types/Chart/chart-cartesian-kind.type.d.ts +18 -0
- package/dist/src/types/Chart/chart-cartesian-kind.type.js +0 -0
- package/dist/src/types/Chart/chart-honeycomb-color-mode.type.cjs +1 -0
- package/dist/src/types/Chart/chart-honeycomb-color-mode.type.d.ts +2 -0
- package/dist/src/types/Chart/chart-honeycomb-color-mode.type.js +0 -0
- package/dist/src/types/Chart/chart-honeycomb-orientation.type.cjs +1 -0
- package/dist/src/types/Chart/chart-honeycomb-orientation.type.d.ts +2 -0
- package/dist/src/types/Chart/chart-honeycomb-orientation.type.js +0 -0
- package/dist/src/types/Chart/chart-item.type.cjs +1 -0
- package/dist/src/types/Chart/chart-item.type.d.ts +9 -0
- package/dist/src/types/Chart/chart-item.type.js +0 -0
- package/dist/src/types/Chart/chart-legend-position.type.cjs +1 -0
- package/dist/src/types/Chart/chart-legend-position.type.d.ts +6 -0
- package/dist/src/types/Chart/chart-legend-position.type.js +0 -0
- package/dist/src/types/Chart/chart-map-mode.type.cjs +1 -0
- package/dist/src/types/Chart/chart-map-mode.type.d.ts +8 -0
- package/dist/src/types/Chart/chart-map-mode.type.js +0 -0
- package/dist/src/types/Chart/chart-pictorial-direction.type.cjs +1 -0
- package/dist/src/types/Chart/chart-pictorial-direction.type.d.ts +1 -0
- package/dist/src/types/Chart/chart-pictorial-direction.type.js +0 -0
- package/dist/src/types/Chart/chart-pictorial-mode.type.cjs +1 -0
- package/dist/src/types/Chart/chart-pictorial-mode.type.d.ts +1 -0
- package/dist/src/types/Chart/chart-pictorial-mode.type.js +0 -0
- package/dist/src/types/Chart/chart-polar-kind.type.cjs +1 -0
- package/dist/src/types/Chart/chart-polar-kind.type.d.ts +14 -0
- package/dist/src/types/Chart/chart-polar-kind.type.js +0 -0
- package/dist/src/types/Chart/chart-pyramid-kind.type.cjs +1 -0
- package/dist/src/types/Chart/chart-pyramid-kind.type.d.ts +9 -0
- package/dist/src/types/Chart/chart-pyramid-kind.type.js +0 -0
- package/dist/src/types/Chart/chart-smoothing.type.cjs +1 -0
- package/dist/src/types/Chart/chart-smoothing.type.d.ts +17 -0
- package/dist/src/types/Chart/chart-smoothing.type.js +0 -0
- package/dist/src/types/Chart/chart-sparkline-kind.type.cjs +1 -0
- package/dist/src/types/Chart/chart-sparkline-kind.type.d.ts +10 -0
- package/dist/src/types/Chart/chart-sparkline-kind.type.js +0 -0
- package/dist/src/types/Chart/chart-stacking.type.cjs +1 -0
- package/dist/src/types/Chart/chart-stacking.type.d.ts +9 -0
- package/dist/src/types/Chart/chart-stacking.type.js +0 -0
- package/dist/src/types/Chart/chart-streamgraph-offset.type.cjs +1 -0
- package/dist/src/types/Chart/chart-streamgraph-offset.type.d.ts +1 -0
- package/dist/src/types/Chart/chart-streamgraph-offset.type.js +0 -0
- package/dist/src/types/Chart/chart-treemap-algorithm.type.cjs +1 -0
- package/dist/src/types/Chart/chart-treemap-algorithm.type.d.ts +12 -0
- package/dist/src/types/Chart/chart-treemap-algorithm.type.js +0 -0
- package/dist/src/types/Chart/chart-type.type.cjs +1 -0
- package/dist/src/types/Chart/chart-type.type.d.ts +7 -0
- package/dist/src/types/Chart/chart-type.type.js +0 -0
- package/dist/src/types/Chart/chart-word-cloud-rotation.type.cjs +1 -0
- package/dist/src/types/Chart/chart-word-cloud-rotation.type.d.ts +8 -0
- package/dist/src/types/Chart/chart-word-cloud-rotation.type.js +0 -0
- package/dist/src/types/Commons/color.type.d.ts +18 -1
- package/dist/src/types/EmptyState/empty-state-align.type.cjs +1 -0
- package/dist/src/types/EmptyState/empty-state-align.type.d.ts +10 -0
- package/dist/src/types/EmptyState/empty-state-align.type.js +0 -0
- package/dist/src/types/EmptyState/empty-state-preset.type.cjs +1 -0
- package/dist/src/types/EmptyState/empty-state-preset.type.d.ts +14 -0
- package/dist/src/types/EmptyState/empty-state-preset.type.js +0 -0
- package/dist/src/types/EmptyState/empty-state-size.type.cjs +1 -0
- package/dist/src/types/EmptyState/empty-state-size.type.d.ts +9 -0
- package/dist/src/types/EmptyState/empty-state-size.type.js +0 -0
- package/dist/src/types/Grid/grid-align.type.cjs +1 -0
- package/dist/src/types/Grid/grid-align.type.d.ts +28 -0
- package/dist/src/types/Grid/grid-align.type.js +0 -0
- package/dist/src/types/Grid/grid-flow.type.cjs +1 -0
- package/dist/src/types/Grid/grid-flow.type.d.ts +10 -0
- package/dist/src/types/Grid/grid-flow.type.js +0 -0
- package/dist/src/types/InlineEdit/inline-edit-input-type.type.cjs +1 -0
- package/dist/src/types/InlineEdit/inline-edit-input-type.type.d.ts +7 -0
- package/dist/src/types/InlineEdit/inline-edit-input-type.type.js +0 -0
- package/dist/src/types/Masonry/masonry-align.type.cjs +1 -0
- package/dist/src/types/Masonry/masonry-align.type.d.ts +16 -0
- package/dist/src/types/Masonry/masonry-align.type.js +0 -0
- package/dist/src/types/Media/index.cjs +27 -0
- package/dist/src/types/Media/index.d.ts +2 -0
- package/dist/src/types/Media/index.js +2 -0
- package/dist/src/types/Media/media-scrubber-orientation.type.cjs +1 -0
- package/dist/src/types/Media/media-scrubber-orientation.type.d.ts +6 -0
- package/dist/src/types/Media/media-scrubber-orientation.type.js +0 -0
- package/dist/src/types/Media/quality-option.type.cjs +1 -0
- package/dist/src/types/Media/quality-option.type.d.ts +25 -0
- package/dist/src/types/Media/quality-option.type.js +0 -0
- package/dist/src/types/NumberFormat/number-format-format.type.cjs +1 -0
- package/dist/src/types/NumberFormat/number-format-format.type.d.ts +56 -0
- package/dist/src/types/NumberFormat/number-format-format.type.js +0 -0
- package/dist/src/types/QrCode/qr-code-error-correction.type.cjs +1 -0
- package/dist/src/types/QrCode/qr-code-error-correction.type.d.ts +22 -0
- package/dist/src/types/QrCode/qr-code-error-correction.type.js +0 -0
- package/dist/src/types/SliderField/slider-field-variant.type.cjs +1 -0
- package/dist/src/types/SliderField/slider-field-variant.type.d.ts +10 -0
- package/dist/src/types/SliderField/slider-field-variant.type.js +0 -0
- package/dist/src/types/Snackbar/snackbar-group-direction.type.cjs +1 -0
- package/dist/src/types/{SnackbarStack/snackbar-stack-direction.type.d.ts → Snackbar/snackbar-group-direction.type.d.ts} +2 -2
- package/dist/src/types/Snackbar/snackbar-group-direction.type.js +0 -0
- package/dist/src/types/Snackbar/snackbar-group-location.type.cjs +1 -0
- package/dist/src/types/{SnackbarStack/snackbar-stack-location.type.d.ts → Snackbar/snackbar-group-location.type.d.ts} +2 -2
- package/dist/src/types/Snackbar/snackbar-group-location.type.js +0 -0
- package/dist/src/types/Snackbar/snackbar-group.type.cjs +1 -0
- package/dist/src/types/Snackbar/snackbar-group.type.d.ts +2 -0
- package/dist/src/types/Snackbar/snackbar-group.type.js +0 -0
- package/dist/src/types/TextMask/text-mask-animation.type.cjs +1 -0
- package/dist/src/types/TextMask/text-mask-animation.type.d.ts +16 -0
- package/dist/src/types/TextMask/text-mask-animation.type.js +0 -0
- package/dist/src/types/TextMask/text-mask.type.cjs +1 -0
- package/dist/src/types/TextMask/text-mask.type.d.ts +2 -0
- package/dist/src/types/TextMask/text-mask.type.js +0 -0
- package/dist/src/types/Video/video-controls.type.cjs +1 -0
- package/dist/src/types/Video/video-controls.type.d.ts +17 -0
- package/dist/src/types/Video/video-controls.type.js +0 -0
- package/dist/src/types/Video/video-track-kind.type.cjs +1 -0
- package/dist/src/types/Video/video-track-kind.type.d.ts +11 -0
- package/dist/src/types/Video/video-track-kind.type.js +0 -0
- package/dist/src/types/index.cjs +467 -38
- package/dist/src/types/index.d.ts +45 -6
- package/dist/src/types/index.js +45 -6
- package/dist/src/types/tokens.type.d.ts +1 -1
- package/dist/src/utils/Calendar/date.util.cjs +181 -0
- package/dist/src/utils/Calendar/date.util.d.ts +96 -0
- package/dist/src/utils/Calendar/date.util.js +114 -0
- package/dist/src/utils/Calendar/rrule.util.cjs +105 -0
- package/dist/src/utils/Calendar/rrule.util.d.ts +49 -0
- package/dist/src/utils/Calendar/rrule.util.js +92 -0
- package/dist/src/utils/Chart/box-plot.util.cjs +62 -0
- package/dist/src/utils/Chart/box-plot.util.d.ts +32 -0
- package/dist/src/utils/Chart/box-plot.util.js +47 -0
- package/dist/src/utils/Chart/mercator.util.cjs +53 -0
- package/dist/src/utils/Chart/mercator.util.d.ts +51 -0
- package/dist/src/utils/Chart/mercator.util.js +44 -0
- package/dist/src/utils/Chart/path.util.cjs +150 -0
- package/dist/src/utils/Chart/path.util.d.ts +116 -0
- package/dist/src/utils/Chart/path.util.js +143 -0
- package/dist/src/utils/Commons/gradient.util.cjs +74 -0
- package/dist/src/utils/Commons/gradient.util.d.ts +36 -0
- package/dist/src/utils/Commons/gradient.util.js +66 -0
- package/dist/src/utils/Media/format-time.util.cjs +16 -0
- package/dist/src/utils/Media/format-time.util.d.ts +16 -0
- package/dist/src/utils/Media/format-time.util.js +10 -0
- package/dist/src/utils/QrCode/qr-code-adapters.util.cjs +34 -0
- package/dist/src/utils/QrCode/qr-code-adapters.util.d.ts +49 -0
- package/dist/src/utils/QrCode/qr-code-adapters.util.js +27 -0
- package/dist/src/utils/index.cjs +55 -22
- package/dist/src/utils/index.d.ts +5 -2
- package/dist/src/utils/index.js +5 -2
- package/package.json +10 -3
- package/dist/src/components/SliderField/OrigamSliderFieldThumb.vue +0 -384
- package/dist/src/components/SnackbarStack/OrigamSnackbarStack.vue +0 -457
- package/dist/src/components/SnackbarStack/index.cjs +0 -13
- package/dist/src/components/SnackbarStack/index.d.ts +0 -1
- package/dist/src/components/SnackbarStack/index.js +0 -1
- package/dist/src/consts/SliderField/slider-field.const.cjs +0 -7
- package/dist/src/consts/SliderField/slider-field.const.d.ts +0 -3
- package/dist/src/consts/SliderField/slider-field.const.js +0 -1
- package/dist/src/consts/SnackbarStack/snackbar-stack.const.cjs +0 -12
- package/dist/src/consts/SnackbarStack/snackbar-stack.const.d.ts +0 -33
- package/dist/src/consts/SnackbarStack/snackbar-stack.const.js +0 -18
- package/dist/src/enums/Charts/chart.enum.cjs +0 -12
- package/dist/src/enums/Charts/chart.enum.d.ts +0 -5
- package/dist/src/enums/Charts/chart.enum.js +0 -6
- package/dist/src/interfaces/Charts/chart-bar.interface.d.ts +0 -4
- package/dist/src/interfaces/Charts/chart-line.interface.d.ts +0 -15
- package/dist/src/interfaces/Charts/chart.interface.d.ts +0 -21
- package/dist/src/interfaces/SliderField/slider-field-thumb.interface.d.ts +0 -12
- package/dist/src/types/Charts/chart.type.d.ts +0 -5
- package/dist/src/types/SliderField/slider-field-thumb.type.d.ts +0 -2
- package/dist/src/types/SnackbarStack/snackbar-stack.type.d.ts +0 -2
- package/dist/src/utils/Charts/chart.util.cjs +0 -50
- package/dist/src/utils/Charts/chart.util.d.ts +0 -30
- package/dist/src/utils/Charts/chart.util.js +0 -40
- package/dist/src/utils/SliderField/slider-field.util.cjs +0 -12
- package/dist/src/utils/SliderField/slider-field.util.d.ts +0 -8
- package/dist/src/utils/SliderField/slider-field.util.js +0 -6
- /package/dist/src/{interfaces/Charts/chart-bar.interface.js → components/QRCode/index.d.ts} +0 -0
- /package/dist/src/interfaces/{Charts/chart-bar.interface.cjs → Audio/audio-player.interface.cjs} +0 -0
- /package/dist/src/interfaces/{Charts/chart-line.interface.js → Audio/audio-player.interface.js} +0 -0
- /package/dist/src/interfaces/{Charts/chart-line.interface.cjs → Blockquote/blockquote.interface.cjs} +0 -0
- /package/dist/src/interfaces/{Charts/chart.interface.js → Blockquote/blockquote.interface.js} +0 -0
- /package/dist/src/interfaces/{Charts/chart.interface.cjs → Calendar/calendar.interface.cjs} +0 -0
- /package/dist/src/interfaces/{SliderField/slider-field-thumb.interface.js → Calendar/calendar.interface.js} +0 -0
- /package/dist/src/interfaces/{SliderField/slider-field-thumb.interface.cjs → Calendar/event.interface.cjs} +0 -0
- /package/dist/src/interfaces/{SnackbarStack/snackbar-stack-item.interface.js → Calendar/event.interface.js} +0 -0
- /package/dist/src/interfaces/{SnackbarStack/snackbar-stack-item.interface.cjs → Chart/chart-annotation.interface.cjs} +0 -0
- /package/dist/src/interfaces/{SnackbarStack/snackbar-stack.interface.js → Chart/chart-annotation.interface.js} +0 -0
- /package/dist/src/interfaces/{SnackbarStack/snackbar-stack.interface.cjs → Chart/chart-axis.interface.cjs} +0 -0
- /package/dist/src/{types/Charts/chart.type.js → interfaces/Chart/chart-axis.interface.js} +0 -0
- /package/dist/src/{types/Charts/chart.type.cjs → interfaces/Chart/chart-base.interface.cjs} +0 -0
- /package/dist/src/{types/SliderField/slider-field-thumb.type.js → interfaces/Chart/chart-base.interface.js} +0 -0
- /package/dist/src/{types/SliderField/slider-field-thumb.type.cjs → interfaces/Chart/chart-box-plot.interface.cjs} +0 -0
- /package/dist/src/{types/SnackbarStack/snackbar-stack-direction.type.js → interfaces/Chart/chart-box-plot.interface.js} +0 -0
- /package/dist/src/{types/SnackbarStack/snackbar-stack-direction.type.cjs → interfaces/Chart/chart-bullet.interface.cjs} +0 -0
- /package/dist/src/{types/SnackbarStack/snackbar-stack-location.type.js → interfaces/Chart/chart-bullet.interface.js} +0 -0
- /package/dist/src/{types/SnackbarStack/snackbar-stack-location.type.cjs → interfaces/Chart/chart-candlestick.interface.cjs} +0 -0
- /package/dist/src/{types/SnackbarStack/snackbar-stack.type.js → interfaces/Chart/chart-candlestick.interface.js} +0 -0
- /package/dist/src/{types/SnackbarStack/snackbar-stack.type.cjs → interfaces/Chart/chart-cartesian.interface.cjs} +0 -0
|
@@ -0,0 +1,1087 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<origam-responsive
|
|
3
|
+
class="origam-video"
|
|
4
|
+
:class="rootClasses"
|
|
5
|
+
:style="rootStyles"
|
|
6
|
+
:aspect-ratio="effectiveAspectRatio"
|
|
7
|
+
content-class="origam-video__inner"
|
|
8
|
+
data-cy="origam-video"
|
|
9
|
+
@mouseenter="onPlayerMouseEnter"
|
|
10
|
+
@mouseleave="onPlayerMouseLeave"
|
|
11
|
+
>
|
|
12
|
+
<template #additional>
|
|
13
|
+
<video
|
|
14
|
+
ref="videoRef"
|
|
15
|
+
class="origam-video__el"
|
|
16
|
+
:src="singleSrc"
|
|
17
|
+
:poster="poster"
|
|
18
|
+
:autoplay="resolvedAutoplay"
|
|
19
|
+
:muted="resolvedMuted"
|
|
20
|
+
:loop="loop"
|
|
21
|
+
:controls="controls === 'native'"
|
|
22
|
+
:playsinline="playsInline"
|
|
23
|
+
:preload="preload"
|
|
24
|
+
:crossorigin="crossorigin"
|
|
25
|
+
:disablepictureinpicture="disablePictureInPicture || undefined"
|
|
26
|
+
data-cy="origam-video-el"
|
|
27
|
+
@play="emit('play')"
|
|
28
|
+
@pause="emit('pause')"
|
|
29
|
+
@ended="emit('ended')"
|
|
30
|
+
@timeupdate="onTimeUpdate"
|
|
31
|
+
@volumechange="onVolumeChange"
|
|
32
|
+
@loadedmetadata="onLoadedMetadata"
|
|
33
|
+
@error="onErrorEvent"
|
|
34
|
+
@enterpictureinpicture="emit('enterpip')"
|
|
35
|
+
@leavepictureinpicture="emit('exitpip')"
|
|
36
|
+
@pointerup="onVideoTap"
|
|
37
|
+
>
|
|
38
|
+
<source
|
|
39
|
+
v-for="source in resolvedSources"
|
|
40
|
+
:key="source.src"
|
|
41
|
+
:src="source.src"
|
|
42
|
+
:type="source.type"
|
|
43
|
+
/>
|
|
44
|
+
<track
|
|
45
|
+
v-for="track in tracks"
|
|
46
|
+
:key="`${track.kind}-${track.srclang}`"
|
|
47
|
+
:kind="track.kind"
|
|
48
|
+
:src="track.src"
|
|
49
|
+
:srclang="track.srclang"
|
|
50
|
+
:label="track.label || track.srclang.toUpperCase()"
|
|
51
|
+
:default="track.default || undefined"
|
|
52
|
+
/>
|
|
53
|
+
</video>
|
|
54
|
+
|
|
55
|
+
<transition name="origam-video-state-pulse">
|
|
56
|
+
<div
|
|
57
|
+
v-if="statePulse"
|
|
58
|
+
:key="statePulse.id"
|
|
59
|
+
class="origam-video__state-pulse"
|
|
60
|
+
aria-hidden="true"
|
|
61
|
+
data-cy="origam-video-state-pulse"
|
|
62
|
+
>
|
|
63
|
+
<origam-icon
|
|
64
|
+
:icon="statePulse.kind === 'play' ? ICONS.PLAY : ICONS.PAUSE"
|
|
65
|
+
class="origam-video__state-pulse-icon"
|
|
66
|
+
aria-hidden="true"
|
|
67
|
+
/>
|
|
68
|
+
</div>
|
|
69
|
+
</transition>
|
|
70
|
+
|
|
71
|
+
<transition name="origam-video-skip-ripple">
|
|
72
|
+
<div
|
|
73
|
+
v-if="skipFeedback"
|
|
74
|
+
:key="skipFeedback.id"
|
|
75
|
+
class="origam-video__skip-ripple"
|
|
76
|
+
:class="`origam-video__skip-ripple--${skipFeedback.side}`"
|
|
77
|
+
aria-hidden="true"
|
|
78
|
+
data-cy="origam-video-skip-ripple"
|
|
79
|
+
>
|
|
80
|
+
<div class="origam-video__skip-ripple-content">
|
|
81
|
+
<div class="origam-video__skip-chevrons">
|
|
82
|
+
<origam-icon
|
|
83
|
+
:icon="skipFeedback.side === 'left' ? ICONS.CHEVRON_LEFT : ICONS.CHEVRON_RIGHT"
|
|
84
|
+
class="origam-video__skip-chevron origam-video__skip-chevron--1"
|
|
85
|
+
aria-hidden="true"
|
|
86
|
+
/>
|
|
87
|
+
<origam-icon
|
|
88
|
+
:icon="skipFeedback.side === 'left' ? ICONS.CHEVRON_LEFT : ICONS.CHEVRON_RIGHT"
|
|
89
|
+
class="origam-video__skip-chevron origam-video__skip-chevron--2"
|
|
90
|
+
aria-hidden="true"
|
|
91
|
+
/>
|
|
92
|
+
<origam-icon
|
|
93
|
+
:icon="skipFeedback.side === 'left' ? ICONS.CHEVRON_LEFT : ICONS.CHEVRON_RIGHT"
|
|
94
|
+
class="origam-video__skip-chevron origam-video__skip-chevron--3"
|
|
95
|
+
aria-hidden="true"
|
|
96
|
+
/>
|
|
97
|
+
</div>
|
|
98
|
+
<span class="origam-video__skip-ripple-label">{{ t('origam.media.seconds', skipFeedback.seconds) }}</span>
|
|
99
|
+
</div>
|
|
100
|
+
</div>
|
|
101
|
+
</transition>
|
|
102
|
+
|
|
103
|
+
<div
|
|
104
|
+
v-if="showPosterOverlay"
|
|
105
|
+
class="origam-video__poster"
|
|
106
|
+
data-cy="origam-video-poster"
|
|
107
|
+
@click="methods.play()"
|
|
108
|
+
>
|
|
109
|
+
<slot name="poster">
|
|
110
|
+
<img
|
|
111
|
+
v-if="poster"
|
|
112
|
+
class="origam-video__poster-img"
|
|
113
|
+
:src="poster"
|
|
114
|
+
alt=""
|
|
115
|
+
/>
|
|
116
|
+
<origam-btn
|
|
117
|
+
:icon="ICONS.PLAY"
|
|
118
|
+
class="origam-video__poster-btn"
|
|
119
|
+
:aria-label="t('origam.media.play')"
|
|
120
|
+
data-cy="origam-video-poster-btn"
|
|
121
|
+
size="large"
|
|
122
|
+
variant="elevated"
|
|
123
|
+
@click.stop="methods.play()"
|
|
124
|
+
/>
|
|
125
|
+
</slot>
|
|
126
|
+
</div>
|
|
127
|
+
|
|
128
|
+
<div
|
|
129
|
+
v-if="state.loading.value && !state.error.value"
|
|
130
|
+
class="origam-video__loading"
|
|
131
|
+
role="status"
|
|
132
|
+
:aria-label="t('origam.loading')"
|
|
133
|
+
data-cy="origam-video-loading"
|
|
134
|
+
>
|
|
135
|
+
<slot name="loading">
|
|
136
|
+
<origam-icon
|
|
137
|
+
:icon="ICONS.LOADING"
|
|
138
|
+
class="origam-video__loading-icon"
|
|
139
|
+
aria-hidden="true"
|
|
140
|
+
/>
|
|
141
|
+
</slot>
|
|
142
|
+
</div>
|
|
143
|
+
|
|
144
|
+
<div
|
|
145
|
+
v-if="state.error.value"
|
|
146
|
+
class="origam-video__error"
|
|
147
|
+
role="alert"
|
|
148
|
+
data-cy="origam-video-error"
|
|
149
|
+
>
|
|
150
|
+
<slot
|
|
151
|
+
name="error"
|
|
152
|
+
:error="state.error.value"
|
|
153
|
+
>
|
|
154
|
+
<origam-icon
|
|
155
|
+
:icon="ICONS.ALERT"
|
|
156
|
+
class="origam-video__error-icon"
|
|
157
|
+
aria-hidden="true"
|
|
158
|
+
/>
|
|
159
|
+
<span class="origam-video__error-msg">{{ errorMessage }}</span>
|
|
160
|
+
</slot>
|
|
161
|
+
</div>
|
|
162
|
+
|
|
163
|
+
<slot
|
|
164
|
+
v-if="controls === 'custom'"
|
|
165
|
+
name="controls"
|
|
166
|
+
v-bind="slotBindings"
|
|
167
|
+
>
|
|
168
|
+
<origam-media-controller
|
|
169
|
+
:state="state"
|
|
170
|
+
:methods="methods"
|
|
171
|
+
:inset="inset"
|
|
172
|
+
:visible="controlsVisible"
|
|
173
|
+
:playback-rates="playbackRates"
|
|
174
|
+
:allow-remote-playback="allowRemotePlayback"
|
|
175
|
+
:downloadable="downloadable"
|
|
176
|
+
:download-url="downloadUrl"
|
|
177
|
+
:download-filename="downloadFilename"
|
|
178
|
+
:quality-options="qualityOptions"
|
|
179
|
+
:current-quality="currentQuality"
|
|
180
|
+
data-cy="origam-video-controls"
|
|
181
|
+
@quality-change="onQualityClick"
|
|
182
|
+
@download="onDownloadClick"
|
|
183
|
+
>
|
|
184
|
+
<template #extraControlsRight>
|
|
185
|
+
<button
|
|
186
|
+
v-if="hasCaptions"
|
|
187
|
+
type="button"
|
|
188
|
+
class="origam-video__btn"
|
|
189
|
+
:class="{ 'origam-video__btn--active': captionsEnabled }"
|
|
190
|
+
:aria-label="t(captionsLabelKey)"
|
|
191
|
+
data-cy="origam-video-captions"
|
|
192
|
+
@click="toggleCaptions"
|
|
193
|
+
>
|
|
194
|
+
<origam-icon
|
|
195
|
+
:icon="ICONS.CAPTIONS"
|
|
196
|
+
aria-hidden="true"
|
|
197
|
+
/>
|
|
198
|
+
</button>
|
|
199
|
+
<button
|
|
200
|
+
v-if="pipSupported"
|
|
201
|
+
type="button"
|
|
202
|
+
class="origam-video__btn"
|
|
203
|
+
:aria-label="t(pipLabelKey)"
|
|
204
|
+
data-cy="origam-video-pip"
|
|
205
|
+
@click="togglePipBtn"
|
|
206
|
+
>
|
|
207
|
+
<origam-icon
|
|
208
|
+
:icon="ICONS.PIP"
|
|
209
|
+
aria-hidden="true"
|
|
210
|
+
/>
|
|
211
|
+
</button>
|
|
212
|
+
<button
|
|
213
|
+
type="button"
|
|
214
|
+
class="origam-video__btn"
|
|
215
|
+
:aria-label="t(fullscreenLabelKey)"
|
|
216
|
+
data-cy="origam-video-fullscreen"
|
|
217
|
+
@click="toggleFullscreenBtn"
|
|
218
|
+
>
|
|
219
|
+
<origam-icon
|
|
220
|
+
:icon="fullscreenIcon"
|
|
221
|
+
aria-hidden="true"
|
|
222
|
+
/>
|
|
223
|
+
</button>
|
|
224
|
+
</template>
|
|
225
|
+
</origam-media-controller>
|
|
226
|
+
</slot>
|
|
227
|
+
</template>
|
|
228
|
+
</origam-responsive>
|
|
229
|
+
</template>
|
|
230
|
+
|
|
231
|
+
<script setup>
|
|
232
|
+
import {
|
|
233
|
+
computed,
|
|
234
|
+
onBeforeUnmount,
|
|
235
|
+
ref,
|
|
236
|
+
watch
|
|
237
|
+
} from "vue";
|
|
238
|
+
import { OrigamBtn } from "../Btn";
|
|
239
|
+
import { OrigamIcon } from "../Icon";
|
|
240
|
+
import { OrigamMediaController } from "../Media";
|
|
241
|
+
import { OrigamResponsive } from "../Responsive";
|
|
242
|
+
import { shouldSuppressAutoplay, useBorder, useColorEffect, useDimension, useElevation, useLocale, useMargin, usePadding, useRounded, useVideoPlayer } from "../../composables";
|
|
243
|
+
import { MDI_ICONS } from "../../enums";
|
|
244
|
+
const { t } = useLocale();
|
|
245
|
+
const props = defineProps({
|
|
246
|
+
src: { type: [String, Array], required: true },
|
|
247
|
+
poster: { type: String, required: false, default: void 0 },
|
|
248
|
+
tracks: { type: Array, required: false, default: () => [] },
|
|
249
|
+
autoplay: { type: Boolean, required: false, default: false },
|
|
250
|
+
muted: { type: Boolean, required: false, default: false },
|
|
251
|
+
loop: { type: Boolean, required: false, default: false },
|
|
252
|
+
controls: { type: String, required: false, default: "custom" },
|
|
253
|
+
playsInline: { type: Boolean, required: false, default: true },
|
|
254
|
+
preload: { type: String, required: false, default: "metadata" },
|
|
255
|
+
aspectRatio: { type: String, required: false, default: "16/9" },
|
|
256
|
+
crossorigin: { type: String, required: false, default: void 0 },
|
|
257
|
+
disablePictureInPicture: { type: Boolean, required: false, default: false },
|
|
258
|
+
skipSeconds: { type: Number, required: false, default: 30 },
|
|
259
|
+
showCenterControls: { type: Boolean, required: false, default: true },
|
|
260
|
+
playbackRates: { type: Array, required: false, default: () => [0.25, 0.5, 0.75, 1, 1.25, 1.5, 1.75, 2] },
|
|
261
|
+
playbackRate: { type: Number, required: false, default: 1 },
|
|
262
|
+
inset: { type: Boolean, required: false, default: true },
|
|
263
|
+
allowRemotePlayback: { type: Boolean, required: false, default: true },
|
|
264
|
+
doubleTapToSkip: { type: Boolean, required: false, default: true },
|
|
265
|
+
downloadable: { type: Boolean, required: false, default: false },
|
|
266
|
+
downloadFilename: { type: String, required: false, default: void 0 },
|
|
267
|
+
id: { type: String, required: false },
|
|
268
|
+
class: { type: [String, Array, Object], required: false },
|
|
269
|
+
style: { type: [String, Array, Object, Boolean, null], required: false, skipCheck: true },
|
|
270
|
+
color: { type: [String, Object, Boolean, null], required: false, skipCheck: true, default: void 0 },
|
|
271
|
+
bgColor: { type: [String, Object, Boolean, null], required: false, skipCheck: true, default: void 0 },
|
|
272
|
+
height: { type: [Number, String], required: false },
|
|
273
|
+
maxHeight: { type: [Number, String], required: false },
|
|
274
|
+
maxWidth: { type: [Number, String], required: false },
|
|
275
|
+
minHeight: { type: [Number, String], required: false },
|
|
276
|
+
minWidth: { type: [Number, String], required: false },
|
|
277
|
+
width: { type: [Number, String], required: false },
|
|
278
|
+
rounded: { type: [Boolean, Number, String, null], required: false, skipCheck: true },
|
|
279
|
+
roundedTopRight: { type: [Boolean, Number, String], required: false },
|
|
280
|
+
roundedTopLeft: { type: [Boolean, Number, String], required: false },
|
|
281
|
+
roundedBottomLeft: { type: [Boolean, Number, String], required: false },
|
|
282
|
+
roundedBottomRight: { type: [Boolean, Number, String], required: false },
|
|
283
|
+
border: { type: [Boolean, Number, String, Array], required: false, skipCheck: true },
|
|
284
|
+
borderTop: { type: [Boolean, Number, String], required: false },
|
|
285
|
+
borderLeft: { type: [Boolean, Number, String], required: false },
|
|
286
|
+
borderBottom: { type: [Boolean, Number, String], required: false },
|
|
287
|
+
borderRight: { type: [Boolean, Number, String], required: false },
|
|
288
|
+
borderBlock: { type: [Boolean, Number, String], required: false },
|
|
289
|
+
borderInline: { type: [Boolean, Number, String], required: false },
|
|
290
|
+
borderColor: { type: String, required: false },
|
|
291
|
+
borderStyle: { type: String, required: false },
|
|
292
|
+
margin: { type: [Boolean, Number, String], required: false },
|
|
293
|
+
marginTop: { type: [Boolean, Number, String], required: false },
|
|
294
|
+
marginLeft: { type: [Boolean, Number, String], required: false },
|
|
295
|
+
marginBottom: { type: [Boolean, Number, String], required: false },
|
|
296
|
+
marginRight: { type: [Boolean, Number, String], required: false },
|
|
297
|
+
marginBlock: { type: [Boolean, Number, String], required: false },
|
|
298
|
+
marginInline: { type: [Boolean, Number, String], required: false },
|
|
299
|
+
padding: { type: [Boolean, Number, String], required: false },
|
|
300
|
+
paddingTop: { type: [Boolean, Number, String], required: false },
|
|
301
|
+
paddingLeft: { type: [Boolean, Number, String], required: false },
|
|
302
|
+
paddingBottom: { type: [Boolean, Number, String], required: false },
|
|
303
|
+
paddingRight: { type: [Boolean, Number, String], required: false },
|
|
304
|
+
paddingBlock: { type: [Boolean, Number, String], required: false },
|
|
305
|
+
paddingInline: { type: [Boolean, Number, String], required: false },
|
|
306
|
+
elevation: { type: [Number, String], required: false }
|
|
307
|
+
});
|
|
308
|
+
const emit = defineEmits(["enterfullscreen", "exitfullscreen", "enterpip", "exitpip", "skip", "quality-change", "download", "play", "pause", "ended", "timeupdate", "volumechange", "loadedmetadata", "error", "update:playbackRate"]);
|
|
309
|
+
const ICONS = {
|
|
310
|
+
PLAY: MDI_ICONS.PLAY,
|
|
311
|
+
PAUSE: MDI_ICONS.PAUSE,
|
|
312
|
+
LOADING: MDI_ICONS.LOADING,
|
|
313
|
+
ALERT: MDI_ICONS.ALERT_CIRCLE,
|
|
314
|
+
CAPTIONS: MDI_ICONS.CLOSED_CAPTION,
|
|
315
|
+
PIP: MDI_ICONS.PICTURE_IN_PICTURE_BOTTOM_RIGHT,
|
|
316
|
+
FULLSCREEN: MDI_ICONS.FULLSCREEN,
|
|
317
|
+
FULLSCREEN_EXIT: MDI_ICONS.FULLSCREEN_EXIT,
|
|
318
|
+
CHEVRON_LEFT: MDI_ICONS.CHEVRON_LEFT,
|
|
319
|
+
CHEVRON_RIGHT: MDI_ICONS.CHEVRON_RIGHT
|
|
320
|
+
};
|
|
321
|
+
const resolvedAutoplay = computed(() => {
|
|
322
|
+
if (!props.autoplay) return false;
|
|
323
|
+
if (shouldSuppressAutoplay()) return false;
|
|
324
|
+
return true;
|
|
325
|
+
});
|
|
326
|
+
const resolvedMuted = computed(() => {
|
|
327
|
+
if (props.muted) return true;
|
|
328
|
+
if (resolvedAutoplay.value) return true;
|
|
329
|
+
return false;
|
|
330
|
+
});
|
|
331
|
+
const singleSrc = computed(() => {
|
|
332
|
+
return typeof props.src === "string" ? props.src : void 0;
|
|
333
|
+
});
|
|
334
|
+
const resolvedSources = computed(() => {
|
|
335
|
+
const sources = Array.isArray(props.src) ? props.src : [];
|
|
336
|
+
if (currentQuality.value && hasQualityOptions.value) {
|
|
337
|
+
return sources.filter((s) => !s.quality || s.quality === currentQuality.value);
|
|
338
|
+
}
|
|
339
|
+
return sources;
|
|
340
|
+
});
|
|
341
|
+
const { videoRef, state, methods } = useVideoPlayer({
|
|
342
|
+
autoplay: props.autoplay,
|
|
343
|
+
muted: resolvedMuted.value,
|
|
344
|
+
loop: props.loop,
|
|
345
|
+
preload: props.preload
|
|
346
|
+
});
|
|
347
|
+
function onTimeUpdate() {
|
|
348
|
+
emit("timeupdate", state.currentTime.value);
|
|
349
|
+
}
|
|
350
|
+
function onVolumeChange() {
|
|
351
|
+
emit("volumechange", state.volume.value);
|
|
352
|
+
}
|
|
353
|
+
const naturalWidth = ref(null);
|
|
354
|
+
const naturalHeight = ref(null);
|
|
355
|
+
function onLoadedMetadata(event) {
|
|
356
|
+
const v = event.target;
|
|
357
|
+
if (v.videoWidth && v.videoHeight) {
|
|
358
|
+
naturalWidth.value = v.videoWidth;
|
|
359
|
+
naturalHeight.value = v.videoHeight;
|
|
360
|
+
}
|
|
361
|
+
emit("loadedmetadata", { duration: state.duration.value });
|
|
362
|
+
}
|
|
363
|
+
const effectiveAspectRatio = computed(() => {
|
|
364
|
+
if (props.aspectRatio) return props.aspectRatio;
|
|
365
|
+
if (naturalWidth.value && naturalHeight.value) {
|
|
366
|
+
return naturalWidth.value / naturalHeight.value;
|
|
367
|
+
}
|
|
368
|
+
return "16/9";
|
|
369
|
+
});
|
|
370
|
+
function onErrorEvent() {
|
|
371
|
+
if (state.error.value) emit("error", state.error.value);
|
|
372
|
+
}
|
|
373
|
+
const hovered = ref(false);
|
|
374
|
+
const onPlayerMouseEnter = () => {
|
|
375
|
+
hovered.value = true;
|
|
376
|
+
};
|
|
377
|
+
const onPlayerMouseLeave = () => {
|
|
378
|
+
hovered.value = false;
|
|
379
|
+
};
|
|
380
|
+
const controlsVisible = computed(() => {
|
|
381
|
+
if (!props.inset) return true;
|
|
382
|
+
if (state.paused.value) return true;
|
|
383
|
+
return hovered.value;
|
|
384
|
+
});
|
|
385
|
+
const skipBy = (seconds) => {
|
|
386
|
+
if (seconds > 0) methods.skipForward(seconds);
|
|
387
|
+
else if (seconds < 0) methods.skipBackward(Math.abs(seconds));
|
|
388
|
+
emit("skip", seconds);
|
|
389
|
+
};
|
|
390
|
+
const onSkipBack = () => skipBy(-Math.abs(props.skipSeconds || 0));
|
|
391
|
+
const onSkipForward = () => skipBy(Math.abs(props.skipSeconds || 0));
|
|
392
|
+
const _lastTap = ref(null);
|
|
393
|
+
const skipFeedback = ref(null);
|
|
394
|
+
let _skipFeedbackTimeout = -1;
|
|
395
|
+
const statePulse = ref(null);
|
|
396
|
+
let _statePulseTimeout = -1;
|
|
397
|
+
function triggerStatePulse(kind) {
|
|
398
|
+
statePulse.value = { kind, id: Date.now() };
|
|
399
|
+
if (_statePulseTimeout !== -1) window.clearTimeout(_statePulseTimeout);
|
|
400
|
+
_statePulseTimeout = window.setTimeout(() => {
|
|
401
|
+
statePulse.value = null;
|
|
402
|
+
_statePulseTimeout = -1;
|
|
403
|
+
}, 600);
|
|
404
|
+
}
|
|
405
|
+
const triggerSkipFeedback = (side) => {
|
|
406
|
+
skipFeedback.value = { side, seconds: props.skipSeconds, id: Date.now() };
|
|
407
|
+
if (_skipFeedbackTimeout !== -1) window.clearTimeout(_skipFeedbackTimeout);
|
|
408
|
+
_skipFeedbackTimeout = window.setTimeout(() => {
|
|
409
|
+
skipFeedback.value = null;
|
|
410
|
+
_skipFeedbackTimeout = -1;
|
|
411
|
+
}, 700);
|
|
412
|
+
};
|
|
413
|
+
let _pendingTogglePlayTimeout = -1;
|
|
414
|
+
function schedulePendingTogglePlay() {
|
|
415
|
+
clearPendingTogglePlay();
|
|
416
|
+
_pendingTogglePlayTimeout = window.setTimeout(() => {
|
|
417
|
+
togglePlay();
|
|
418
|
+
_pendingTogglePlayTimeout = -1;
|
|
419
|
+
}, 280);
|
|
420
|
+
}
|
|
421
|
+
function clearPendingTogglePlay() {
|
|
422
|
+
if (_pendingTogglePlayTimeout !== -1) {
|
|
423
|
+
window.clearTimeout(_pendingTogglePlayTimeout);
|
|
424
|
+
_pendingTogglePlayTimeout = -1;
|
|
425
|
+
}
|
|
426
|
+
}
|
|
427
|
+
onBeforeUnmount(() => {
|
|
428
|
+
if (_skipFeedbackTimeout !== -1) window.clearTimeout(_skipFeedbackTimeout);
|
|
429
|
+
if (_statePulseTimeout !== -1) window.clearTimeout(_statePulseTimeout);
|
|
430
|
+
clearPendingTogglePlay();
|
|
431
|
+
});
|
|
432
|
+
const onVideoTap = (event) => {
|
|
433
|
+
if (event.clientX == null) return;
|
|
434
|
+
const eventTarget = event.target;
|
|
435
|
+
if (eventTarget?.closest(".origam-video__center-btn")) return;
|
|
436
|
+
const videoEl = videoRef.value;
|
|
437
|
+
if (!videoEl) return;
|
|
438
|
+
const rect = videoEl.getBoundingClientRect();
|
|
439
|
+
const side = event.clientX - rect.left < rect.width / 2 ? "left" : "right";
|
|
440
|
+
const now = Date.now();
|
|
441
|
+
const last = _lastTap.value;
|
|
442
|
+
if (props.doubleTapToSkip && last && now - last.time < 300 && last.side === side) {
|
|
443
|
+
clearPendingTogglePlay();
|
|
444
|
+
if (side === "left") onSkipBack();
|
|
445
|
+
else onSkipForward();
|
|
446
|
+
triggerSkipFeedback(side);
|
|
447
|
+
_lastTap.value = null;
|
|
448
|
+
event.preventDefault();
|
|
449
|
+
} else {
|
|
450
|
+
_lastTap.value = { time: now, side };
|
|
451
|
+
schedulePendingTogglePlay();
|
|
452
|
+
}
|
|
453
|
+
};
|
|
454
|
+
const qualityOptions = computed(() => {
|
|
455
|
+
const sources = Array.isArray(props.src) ? props.src : [];
|
|
456
|
+
const seen = /* @__PURE__ */ new Set();
|
|
457
|
+
const out = [];
|
|
458
|
+
for (const s of sources) {
|
|
459
|
+
if (!s?.quality || seen.has(s.quality)) continue;
|
|
460
|
+
seen.add(s.quality);
|
|
461
|
+
out.push({ quality: s.quality, label: s.label ?? s.quality, src: s.src, type: s.type });
|
|
462
|
+
}
|
|
463
|
+
return out;
|
|
464
|
+
});
|
|
465
|
+
const hasQualityOptions = computed(() => qualityOptions.value.length >= 2);
|
|
466
|
+
const currentQuality = ref(null);
|
|
467
|
+
const initQuality = () => {
|
|
468
|
+
if (currentQuality.value !== null) return;
|
|
469
|
+
if (!hasQualityOptions.value) return;
|
|
470
|
+
currentQuality.value = qualityOptions.value[0].quality;
|
|
471
|
+
};
|
|
472
|
+
initQuality();
|
|
473
|
+
function onQualityClick(quality) {
|
|
474
|
+
const target = qualityOptions.value.find((q) => q.quality === quality);
|
|
475
|
+
if (!target || !videoRef.value) return;
|
|
476
|
+
const video = videoRef.value;
|
|
477
|
+
const wasPaused = video.paused;
|
|
478
|
+
const at = video.currentTime;
|
|
479
|
+
currentQuality.value = quality;
|
|
480
|
+
emit("quality-change", quality);
|
|
481
|
+
const onReady = () => {
|
|
482
|
+
try {
|
|
483
|
+
video.currentTime = at;
|
|
484
|
+
} catch {
|
|
485
|
+
}
|
|
486
|
+
if (!wasPaused) video.play().catch(() => {
|
|
487
|
+
});
|
|
488
|
+
video.removeEventListener("loadedmetadata", onReady);
|
|
489
|
+
};
|
|
490
|
+
video.addEventListener("loadedmetadata", onReady);
|
|
491
|
+
video.src = target.src;
|
|
492
|
+
video.load();
|
|
493
|
+
}
|
|
494
|
+
function onDownloadClick() {
|
|
495
|
+
const url = downloadUrl.value;
|
|
496
|
+
if (!url) return;
|
|
497
|
+
emit("download", url);
|
|
498
|
+
}
|
|
499
|
+
const downloadUrl = computed(() => {
|
|
500
|
+
if (typeof props.src === "string") return props.src || null;
|
|
501
|
+
const sources = props.src;
|
|
502
|
+
if (!sources.length) return null;
|
|
503
|
+
if (currentQuality.value) {
|
|
504
|
+
const match = sources.find((s) => s.quality === currentQuality.value);
|
|
505
|
+
if (match) return match.src;
|
|
506
|
+
}
|
|
507
|
+
return sources[0]?.src ?? null;
|
|
508
|
+
});
|
|
509
|
+
watch(() => props.playbackRate, (rate) => {
|
|
510
|
+
if (typeof rate === "number" && Number.isFinite(rate) && rate > 0) {
|
|
511
|
+
methods.setPlaybackRate(rate);
|
|
512
|
+
}
|
|
513
|
+
}, { immediate: true });
|
|
514
|
+
watch(() => state.playbackRate.value, (rate) => {
|
|
515
|
+
emit("update:playbackRate", rate);
|
|
516
|
+
});
|
|
517
|
+
function togglePlay() {
|
|
518
|
+
if (state.playing.value) {
|
|
519
|
+
methods.pause();
|
|
520
|
+
triggerStatePulse("pause");
|
|
521
|
+
} else {
|
|
522
|
+
methods.play();
|
|
523
|
+
triggerStatePulse("play");
|
|
524
|
+
}
|
|
525
|
+
}
|
|
526
|
+
async function toggleFullscreenBtn() {
|
|
527
|
+
const wasFs = state.fullscreen.value;
|
|
528
|
+
await methods.toggleFullscreen();
|
|
529
|
+
if (state.fullscreen.value && !wasFs) emit("enterfullscreen");
|
|
530
|
+
else if (!state.fullscreen.value && wasFs) emit("exitfullscreen");
|
|
531
|
+
}
|
|
532
|
+
async function togglePipBtn() {
|
|
533
|
+
await methods.togglePip();
|
|
534
|
+
}
|
|
535
|
+
const captionsEnabled = ref(false);
|
|
536
|
+
const hasCaptions = computed(() => props.tracks.some((track) => {
|
|
537
|
+
return track.kind === "captions" || track.kind === "subtitles";
|
|
538
|
+
}));
|
|
539
|
+
function toggleCaptions() {
|
|
540
|
+
const el = videoRef.value;
|
|
541
|
+
if (!el) return;
|
|
542
|
+
const trackList = el.textTracks;
|
|
543
|
+
captionsEnabled.value = !captionsEnabled.value;
|
|
544
|
+
for (let i = 0; i < trackList.length; i++) {
|
|
545
|
+
const track = trackList[i];
|
|
546
|
+
if (!captionsEnabled.value) {
|
|
547
|
+
track.mode = "disabled";
|
|
548
|
+
} else {
|
|
549
|
+
const declared = props.tracks[i];
|
|
550
|
+
if (declared?.default) track.mode = "showing";
|
|
551
|
+
else if (i === 0) track.mode = "showing";
|
|
552
|
+
else track.mode = "disabled";
|
|
553
|
+
}
|
|
554
|
+
}
|
|
555
|
+
}
|
|
556
|
+
watch(() => state.ready.value, (ready) => {
|
|
557
|
+
if (!ready) return;
|
|
558
|
+
const el = videoRef.value;
|
|
559
|
+
if (!el) return;
|
|
560
|
+
const someShowing = Array.from(el.textTracks).some((track) => track.mode === "showing");
|
|
561
|
+
captionsEnabled.value = someShowing;
|
|
562
|
+
});
|
|
563
|
+
const pipSupported = computed(() => {
|
|
564
|
+
if (props.disablePictureInPicture) return false;
|
|
565
|
+
if (typeof document === "undefined") return false;
|
|
566
|
+
const doc = document;
|
|
567
|
+
return Boolean(doc.pictureInPictureEnabled);
|
|
568
|
+
});
|
|
569
|
+
const showPosterOverlay = computed(() => {
|
|
570
|
+
return Boolean(props.poster) && state.paused.value && state.currentTime.value === 0 && !state.error.value;
|
|
571
|
+
});
|
|
572
|
+
const errorMessage = computed(() => {
|
|
573
|
+
const err = state.error.value;
|
|
574
|
+
if (!err) return "Playback error";
|
|
575
|
+
if ("message" in err && err.message) return err.message;
|
|
576
|
+
return "Playback error";
|
|
577
|
+
});
|
|
578
|
+
const captionsLabelKey = computed(() => {
|
|
579
|
+
return captionsEnabled.value ? "origam.video.disableCaptions" : "origam.video.enableCaptions";
|
|
580
|
+
});
|
|
581
|
+
const pipLabelKey = computed(() => {
|
|
582
|
+
return state.pip.value ? "origam.video.exitPip" : "origam.video.enterPip";
|
|
583
|
+
});
|
|
584
|
+
const fullscreenLabelKey = computed(() => {
|
|
585
|
+
return state.fullscreen.value ? "origam.video.exitFullscreen" : "origam.video.enterFullscreen";
|
|
586
|
+
});
|
|
587
|
+
const fullscreenIcon = computed(() => {
|
|
588
|
+
return state.fullscreen.value ? ICONS.FULLSCREEN_EXIT : ICONS.FULLSCREEN;
|
|
589
|
+
});
|
|
590
|
+
const slotBindings = computed(() => ({
|
|
591
|
+
playing: state.playing.value,
|
|
592
|
+
paused: state.paused.value,
|
|
593
|
+
currentTime: state.currentTime.value,
|
|
594
|
+
duration: state.duration.value,
|
|
595
|
+
buffered: state.buffered.value,
|
|
596
|
+
volume: state.volume.value,
|
|
597
|
+
muted: state.muted.value,
|
|
598
|
+
fullscreen: state.fullscreen.value,
|
|
599
|
+
pip: state.pip.value,
|
|
600
|
+
loading: state.loading.value,
|
|
601
|
+
error: state.error.value,
|
|
602
|
+
playbackRate: state.playbackRate.value,
|
|
603
|
+
remoteAvailable: state.remoteAvailable.value,
|
|
604
|
+
remoteState: state.remoteState.value,
|
|
605
|
+
methods
|
|
606
|
+
}));
|
|
607
|
+
const { colorClasses, colorStyles } = useColorEffect(props);
|
|
608
|
+
const hasColorProp = computed(() => !!props.color);
|
|
609
|
+
const hasBgColorProp = computed(() => !!props.bgColor);
|
|
610
|
+
const { borderClasses, borderStyles } = useBorder(props);
|
|
611
|
+
const { marginClasses, marginStyles } = useMargin(props);
|
|
612
|
+
const { paddingClasses, paddingStyles } = usePadding(props);
|
|
613
|
+
const { roundedClasses, roundedStyles } = useRounded(props);
|
|
614
|
+
const { elevationClasses } = useElevation(props);
|
|
615
|
+
const { dimensionStyles } = useDimension(props);
|
|
616
|
+
const scrubberColorStyle = computed(() => {
|
|
617
|
+
if (hasColorProp.value || hasBgColorProp.value) {
|
|
618
|
+
return { "--origam-media-controller__scrubber---color": "currentColor" };
|
|
619
|
+
}
|
|
620
|
+
return { "--origam-media-controller__scrubber---color": "#ffffff" };
|
|
621
|
+
});
|
|
622
|
+
const rootClasses = computed(() => [
|
|
623
|
+
{
|
|
624
|
+
"origam-video--playing": state.playing.value,
|
|
625
|
+
"origam-video--paused": state.paused.value,
|
|
626
|
+
"origam-video--loading": state.loading.value,
|
|
627
|
+
"origam-video--error": state.error.value !== null,
|
|
628
|
+
"origam-video--fullscreen": state.fullscreen.value,
|
|
629
|
+
"origam-video--pip": state.pip.value,
|
|
630
|
+
"origam-video--controls-native": props.controls === "native",
|
|
631
|
+
"origam-video--controls-custom": props.controls === "custom",
|
|
632
|
+
"origam-video--controls-none": props.controls === "none",
|
|
633
|
+
"origam-video--has-color": hasColorProp.value,
|
|
634
|
+
"origam-video--has-bg-color": hasBgColorProp.value
|
|
635
|
+
},
|
|
636
|
+
...colorClasses.value,
|
|
637
|
+
borderClasses.value,
|
|
638
|
+
roundedClasses.value,
|
|
639
|
+
elevationClasses.value,
|
|
640
|
+
marginClasses.value,
|
|
641
|
+
paddingClasses.value,
|
|
642
|
+
props.class
|
|
643
|
+
]);
|
|
644
|
+
const rootStyles = computed(() => [
|
|
645
|
+
colorStyles.value,
|
|
646
|
+
scrubberColorStyle.value,
|
|
647
|
+
borderStyles.value,
|
|
648
|
+
roundedStyles.value,
|
|
649
|
+
marginStyles.value,
|
|
650
|
+
paddingStyles.value,
|
|
651
|
+
dimensionStyles.value,
|
|
652
|
+
props.style
|
|
653
|
+
]);
|
|
654
|
+
defineExpose({
|
|
655
|
+
videoRef,
|
|
656
|
+
state,
|
|
657
|
+
methods
|
|
658
|
+
});
|
|
659
|
+
</script>
|
|
660
|
+
|
|
661
|
+
<style lang="scss" scoped>
|
|
662
|
+
.origam-video {
|
|
663
|
+
position: relative;
|
|
664
|
+
display: block;
|
|
665
|
+
width: 100%;
|
|
666
|
+
background-color: var(--origam-video---background-color, #000000);
|
|
667
|
+
overflow: hidden;
|
|
668
|
+
border-radius: var(--origam-video---border-radius, 0);
|
|
669
|
+
|
|
670
|
+
/*
|
|
671
|
+
* Force the chrome (MediaController play / volume / cog,
|
|
672
|
+
* native `<button>`-based MediaVolumeControl) to white by
|
|
673
|
+
* default — the controller's own SCSS reads `color:
|
|
674
|
+
* var(--origam-media-controller---color, inherit)` which
|
|
675
|
+
* defaults to the `#171717` text-primary token. On the dark
|
|
676
|
+
* video overlay that produces near-invisible icons (the
|
|
677
|
+
* user-reported "icons all black" symptom).
|
|
678
|
+
*
|
|
679
|
+
* The variable is overridden to `inherit` further down when
|
|
680
|
+
* the consumer passes `color` / `bgColor`, so `useColorEffect`
|
|
681
|
+
* gets to drive the tint through.
|
|
682
|
+
*/
|
|
683
|
+
--origam-media-controller---color: #ffffff;
|
|
684
|
+
}
|
|
685
|
+
|
|
686
|
+
/*
|
|
687
|
+
* Tint propagation when the consumer passes `color` or `bgColor`:
|
|
688
|
+
* the MediaController + the white-by-default `.origam-video__btn`
|
|
689
|
+
* icons need to inherit the host colour so the scrubber's
|
|
690
|
+
* `currentColor` (set by `scrubberColorStyle`) AND the icons
|
|
691
|
+
* track the user's intent. Without these overrides the
|
|
692
|
+
* MediaController's own scoped `color: var(--origam-media-controller---color, inherit)`
|
|
693
|
+
* pins the chrome back to the dark text-primary token.
|
|
694
|
+
*/
|
|
695
|
+
.origam-video--has-color,
|
|
696
|
+
.origam-video--has-bg-color {
|
|
697
|
+
--origam-media-controller---color: inherit;
|
|
698
|
+
|
|
699
|
+
:deep(.origam-media-controller) {
|
|
700
|
+
color: inherit;
|
|
701
|
+
}
|
|
702
|
+
|
|
703
|
+
.origam-video__btn {
|
|
704
|
+
color: inherit;
|
|
705
|
+
}
|
|
706
|
+
}
|
|
707
|
+
|
|
708
|
+
/*
|
|
709
|
+
* Native `<button class="origam-media-volume-control__btn">` lives
|
|
710
|
+
* inside OrigamMediaVolumeControl with its own scoped CSS that
|
|
711
|
+
* doesn't honour `--origam-media-controller---color`. Force it
|
|
712
|
+
* to inherit from the controller (which is now white by default)
|
|
713
|
+
* so the volume icon matches the rest of the chrome.
|
|
714
|
+
*/
|
|
715
|
+
:deep(.origam-media-volume-control__btn) {
|
|
716
|
+
color: inherit;
|
|
717
|
+
}
|
|
718
|
+
|
|
719
|
+
/*
|
|
720
|
+
* Scrubber track / buffer background — overrides the MediaController
|
|
721
|
+
* defaults so the dark, semi-translucent track doesn't let the
|
|
722
|
+
* video frame underneath bleed through with whatever hue the
|
|
723
|
+
* picture has at the playhead position (the user-reported "pink
|
|
724
|
+
* scrubber" symptom on a pastel-toned video frame). White-tinted
|
|
725
|
+
* translucent backgrounds give a uniform light-grey track on
|
|
726
|
+
* every video regardless of content.
|
|
727
|
+
*
|
|
728
|
+
* The :deep(.) reaches into the OrigamMediaScrubber scope to set
|
|
729
|
+
* its internal slots; the consumer can still override per-instance
|
|
730
|
+
* via `--origam-media-scrubber---track-background-color`.
|
|
731
|
+
*/
|
|
732
|
+
:deep(.origam-media-controller__scrubber) {
|
|
733
|
+
--origam-media-scrubber---track-background-color: rgba(255, 255, 255, 0.28);
|
|
734
|
+
--origam-media-scrubber---buffer-background-color: rgba(255, 255, 255, 0.42);
|
|
735
|
+
}
|
|
736
|
+
|
|
737
|
+
.origam-video__el {
|
|
738
|
+
position: absolute;
|
|
739
|
+
inset: 0;
|
|
740
|
+
display: block;
|
|
741
|
+
width: 100%;
|
|
742
|
+
height: 100%;
|
|
743
|
+
object-fit: contain;
|
|
744
|
+
}
|
|
745
|
+
|
|
746
|
+
.origam-video__poster {
|
|
747
|
+
position: absolute;
|
|
748
|
+
inset: 0;
|
|
749
|
+
display: flex;
|
|
750
|
+
align-items: center;
|
|
751
|
+
justify-content: center;
|
|
752
|
+
cursor: pointer;
|
|
753
|
+
background-color: var(--origam-video__poster---background-color, #000000);
|
|
754
|
+
}
|
|
755
|
+
|
|
756
|
+
.origam-video__poster-img {
|
|
757
|
+
position: absolute;
|
|
758
|
+
inset: 0;
|
|
759
|
+
width: 100%;
|
|
760
|
+
height: 100%;
|
|
761
|
+
object-fit: cover;
|
|
762
|
+
}
|
|
763
|
+
|
|
764
|
+
.origam-video__poster-btn {
|
|
765
|
+
all: unset;
|
|
766
|
+
position: relative;
|
|
767
|
+
display: inline-flex;
|
|
768
|
+
align-items: center;
|
|
769
|
+
justify-content: center;
|
|
770
|
+
width: var(--origam-video---poster-btn-size, 64px);
|
|
771
|
+
height: var(--origam-video---poster-btn-size, 64px);
|
|
772
|
+
border-radius: 50%;
|
|
773
|
+
background-color: var(--origam-video---poster-btn-background-color, rgba(0, 0, 0, 0.6));
|
|
774
|
+
color: var(--origam-video---poster-btn-color, #ffffff);
|
|
775
|
+
font-size: var(--origam-video---poster-btn-font-size, 28px);
|
|
776
|
+
cursor: pointer;
|
|
777
|
+
transition: background-color 160ms ease;
|
|
778
|
+
}
|
|
779
|
+
|
|
780
|
+
.origam-video__poster-btn:hover {
|
|
781
|
+
background-color: var(--origam-video---poster-btn-background-color-hover, rgba(0, 0, 0, 0.8));
|
|
782
|
+
}
|
|
783
|
+
|
|
784
|
+
.origam-video__loading {
|
|
785
|
+
position: absolute;
|
|
786
|
+
inset: 0;
|
|
787
|
+
display: flex;
|
|
788
|
+
align-items: center;
|
|
789
|
+
justify-content: center;
|
|
790
|
+
color: var(--origam-video__loading---color, #ffffff);
|
|
791
|
+
font-size: var(--origam-video__loading---font-size, 32px);
|
|
792
|
+
pointer-events: none;
|
|
793
|
+
}
|
|
794
|
+
|
|
795
|
+
.origam-video__loading-icon {
|
|
796
|
+
animation: origam-video-spin 1s linear infinite;
|
|
797
|
+
}
|
|
798
|
+
|
|
799
|
+
@keyframes origam-video-spin {
|
|
800
|
+
from {
|
|
801
|
+
transform: rotate(0deg);
|
|
802
|
+
}
|
|
803
|
+
to {
|
|
804
|
+
transform: rotate(360deg);
|
|
805
|
+
}
|
|
806
|
+
}
|
|
807
|
+
|
|
808
|
+
.origam-video__error {
|
|
809
|
+
position: absolute;
|
|
810
|
+
inset: 0;
|
|
811
|
+
display: flex;
|
|
812
|
+
align-items: center;
|
|
813
|
+
justify-content: center;
|
|
814
|
+
flex-direction: column;
|
|
815
|
+
gap: var(--origam-video--error---gap, 8px);
|
|
816
|
+
padding: var(--origam-video--error---padding, 16px);
|
|
817
|
+
background-color: var(--origam-video--error---background-color, rgba(0, 0, 0, 0.85));
|
|
818
|
+
color: var(--origam-video--error---color, #f87171);
|
|
819
|
+
font-size: var(--origam-video--error---font-size, 14px);
|
|
820
|
+
text-align: center;
|
|
821
|
+
}
|
|
822
|
+
|
|
823
|
+
.origam-video__error-icon {
|
|
824
|
+
font-size: var(--origam-video--error---icon-font-size, 32px);
|
|
825
|
+
}
|
|
826
|
+
|
|
827
|
+
/* State pulse — YouTube-style brief icon flash at the centre of
|
|
828
|
+
* the video when play/pause toggles. PURELY cosmetic, never
|
|
829
|
+
* absorbs clicks (pointer-events: none) so the underlying video
|
|
830
|
+
* surface stays interactive. Fades in + scales up over ~600 ms
|
|
831
|
+
* then disappears. */
|
|
832
|
+
.origam-video__state-pulse {
|
|
833
|
+
position: absolute;
|
|
834
|
+
top: 50%;
|
|
835
|
+
left: 50%;
|
|
836
|
+
transform: translate(-50%, -50%);
|
|
837
|
+
display: flex;
|
|
838
|
+
align-items: center;
|
|
839
|
+
justify-content: center;
|
|
840
|
+
width: 80px;
|
|
841
|
+
height: 80px;
|
|
842
|
+
border-radius: 50%;
|
|
843
|
+
background: rgba(0, 0, 0, 0.55);
|
|
844
|
+
color: #ffffff;
|
|
845
|
+
pointer-events: none;
|
|
846
|
+
z-index: 2;
|
|
847
|
+
}
|
|
848
|
+
|
|
849
|
+
.origam-video__state-pulse-icon {
|
|
850
|
+
font-size: 40px;
|
|
851
|
+
line-height: 1;
|
|
852
|
+
}
|
|
853
|
+
|
|
854
|
+
.origam-video-state-pulse-enter-active {
|
|
855
|
+
transition: opacity 180ms ease, transform 480ms cubic-bezier(0.2, 0.6, 0.2, 1);
|
|
856
|
+
}
|
|
857
|
+
.origam-video-state-pulse-leave-active {
|
|
858
|
+
transition: opacity 280ms ease, transform 480ms cubic-bezier(0.2, 0.6, 0.2, 1);
|
|
859
|
+
}
|
|
860
|
+
.origam-video-state-pulse-enter-from {
|
|
861
|
+
opacity: 0;
|
|
862
|
+
transform: translate(-50%, -50%) scale(0.6);
|
|
863
|
+
}
|
|
864
|
+
.origam-video-state-pulse-leave-to {
|
|
865
|
+
opacity: 0;
|
|
866
|
+
transform: translate(-50%, -50%) scale(1.5);
|
|
867
|
+
}
|
|
868
|
+
.origam-video-state-pulse-enter-to,
|
|
869
|
+
.origam-video-state-pulse-leave-from {
|
|
870
|
+
opacity: 1;
|
|
871
|
+
transform: translate(-50%, -50%) scale(1);
|
|
872
|
+
}
|
|
873
|
+
|
|
874
|
+
@media (prefers-reduced-motion: reduce) {
|
|
875
|
+
.origam-video-state-pulse-enter-active,
|
|
876
|
+
.origam-video-state-pulse-leave-active {
|
|
877
|
+
transition: opacity 100ms ease;
|
|
878
|
+
transform: translate(-50%, -50%);
|
|
879
|
+
}
|
|
880
|
+
|
|
881
|
+
.origam-video__loading-icon {
|
|
882
|
+
animation: none;
|
|
883
|
+
}
|
|
884
|
+
}
|
|
885
|
+
|
|
886
|
+
// YouTube-parity double-tap skip overlay :
|
|
887
|
+
//
|
|
888
|
+
// • Whole element is a PERFECT CIRCLE (`width: 40 %` of the
|
|
889
|
+
// video width, `aspect-ratio: 1`, `border-radius: 50 %`).
|
|
890
|
+
// Most of the disc lives OUTSIDE the video frame — we anchor
|
|
891
|
+
// with `right: -28 %` (or `left: -28 %`), so only the
|
|
892
|
+
// 12 %-wide bulge intrudes into the visible area. The parent
|
|
893
|
+
// `.origam-video` clips the offscreen portion via its existing
|
|
894
|
+
// `overflow: hidden` — what the user sees is genuinely a slice
|
|
895
|
+
// of a circle, not an elongated oval.
|
|
896
|
+
// • Frosted background : light dark wash + `backdrop-filter:
|
|
897
|
+
// blur(6px)` for the frosted look. Fallback (browsers without
|
|
898
|
+
// backdrop-filter support) keeps a denser solid alpha so the
|
|
899
|
+
// chevrons stay readable.
|
|
900
|
+
// • Three chevrons stay visible at baseline opacity 0.5 ; a
|
|
901
|
+
// brightness wave (opacity 1 + scale 1.1) cascades through
|
|
902
|
+
// them on a 800 ms loop. The wave direction follows the skip
|
|
903
|
+
// direction (right skip → wave runs left→right ; left skip →
|
|
904
|
+
// wave runs right→left) via per-side animation-delay swap, so
|
|
905
|
+
// the eye chases the chevrons toward the skip target.
|
|
906
|
+
// • Disc itself fades + scales in/out (200 ms ease) — no
|
|
907
|
+
// translate, just a subtle "puff in" matching YouTube.
|
|
908
|
+
.origam-video__skip-ripple {
|
|
909
|
+
position: absolute;
|
|
910
|
+
top: 50%;
|
|
911
|
+
width: 40%;
|
|
912
|
+
aspect-ratio: 1;
|
|
913
|
+
z-index: 3;
|
|
914
|
+
pointer-events: none;
|
|
915
|
+
background: rgba(0, 0, 0, 0.45);
|
|
916
|
+
border-radius: 50%;
|
|
917
|
+
display: flex;
|
|
918
|
+
flex-direction: column;
|
|
919
|
+
justify-content: center;
|
|
920
|
+
}
|
|
921
|
+
|
|
922
|
+
@supports ((backdrop-filter: blur(6px)) or (-webkit-backdrop-filter: blur(6px))) {
|
|
923
|
+
.origam-video__skip-ripple {
|
|
924
|
+
background: rgba(0, 0, 0, 0.30);
|
|
925
|
+
backdrop-filter: blur(6px);
|
|
926
|
+
-webkit-backdrop-filter: blur(6px);
|
|
927
|
+
}
|
|
928
|
+
}
|
|
929
|
+
|
|
930
|
+
.origam-video__skip-ripple--left {
|
|
931
|
+
left: -25%;
|
|
932
|
+
align-items: flex-end;
|
|
933
|
+
padding-right: 5%;
|
|
934
|
+
}
|
|
935
|
+
|
|
936
|
+
.origam-video__skip-ripple--right {
|
|
937
|
+
right: -25%;
|
|
938
|
+
align-items: flex-start;
|
|
939
|
+
padding-left: 5%;
|
|
940
|
+
}
|
|
941
|
+
|
|
942
|
+
.origam-video__skip-ripple-content {
|
|
943
|
+
display: flex;
|
|
944
|
+
flex-direction: column;
|
|
945
|
+
align-items: center;
|
|
946
|
+
gap: 4px;
|
|
947
|
+
color: #ffffff;
|
|
948
|
+
text-align: center;
|
|
949
|
+
filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.4));
|
|
950
|
+
}
|
|
951
|
+
|
|
952
|
+
.origam-video__skip-chevrons {
|
|
953
|
+
display: inline-flex;
|
|
954
|
+
align-items: center;
|
|
955
|
+
gap: 0;
|
|
956
|
+
line-height: 0;
|
|
957
|
+
}
|
|
958
|
+
|
|
959
|
+
.origam-video__skip-chevron {
|
|
960
|
+
display: inline-block;
|
|
961
|
+
line-height: 0;
|
|
962
|
+
opacity: 0.5;
|
|
963
|
+
margin: 0 -4px;
|
|
964
|
+
animation: origam-video-chevron-wave 800ms ease-in-out infinite;
|
|
965
|
+
}
|
|
966
|
+
|
|
967
|
+
.origam-video__skip-chevron :deep(.origam-icon) {
|
|
968
|
+
font-size: 28px;
|
|
969
|
+
line-height: 1;
|
|
970
|
+
}
|
|
971
|
+
|
|
972
|
+
@keyframes origam-video-chevron-wave {
|
|
973
|
+
0%, 80%, 100% { opacity: 0.5; transform: scale(1); }
|
|
974
|
+
40% { opacity: 1; transform: scale(1.1); }
|
|
975
|
+
}
|
|
976
|
+
|
|
977
|
+
// Cascade order follows the skip direction :
|
|
978
|
+
// right skip → chevrons peak 1 → 2 → 3 (left to right)
|
|
979
|
+
// left skip → chevrons peak 3 → 2 → 1 (right to left)
|
|
980
|
+
.origam-video__skip-ripple--right .origam-video__skip-chevron--1 { animation-delay: 0ms; }
|
|
981
|
+
.origam-video__skip-ripple--right .origam-video__skip-chevron--2 { animation-delay: 120ms; }
|
|
982
|
+
.origam-video__skip-ripple--right .origam-video__skip-chevron--3 { animation-delay: 240ms; }
|
|
983
|
+
.origam-video__skip-ripple--left .origam-video__skip-chevron--1 { animation-delay: 240ms; }
|
|
984
|
+
.origam-video__skip-ripple--left .origam-video__skip-chevron--2 { animation-delay: 120ms; }
|
|
985
|
+
.origam-video__skip-ripple--left .origam-video__skip-chevron--3 { animation-delay: 0ms; }
|
|
986
|
+
|
|
987
|
+
.origam-video__skip-ripple-label {
|
|
988
|
+
font-size: 13px;
|
|
989
|
+
font-weight: 600;
|
|
990
|
+
font-family: var(--origam-font---family, system-ui, sans-serif);
|
|
991
|
+
letter-spacing: 0.02em;
|
|
992
|
+
white-space: nowrap;
|
|
993
|
+
user-select: none;
|
|
994
|
+
line-height: 1.2;
|
|
995
|
+
}
|
|
996
|
+
|
|
997
|
+
// Note: disc anchored at `top: 50%` with no transform — the y-axis
|
|
998
|
+
// `translateY(-50%)` we'd normally add is moved INTO the enter/leave
|
|
999
|
+
// keyframes so we can compose it with the scale puff-in without
|
|
1000
|
+
// fighting the static positioning transform.
|
|
1001
|
+
.origam-video__skip-ripple {
|
|
1002
|
+
transform: translateY(-50%) scale(1);
|
|
1003
|
+
}
|
|
1004
|
+
|
|
1005
|
+
.origam-video-skip-ripple-enter-active,
|
|
1006
|
+
.origam-video-skip-ripple-leave-active {
|
|
1007
|
+
transition: opacity 200ms ease, transform 200ms ease;
|
|
1008
|
+
}
|
|
1009
|
+
|
|
1010
|
+
.origam-video-skip-ripple-enter-from,
|
|
1011
|
+
.origam-video-skip-ripple-leave-to {
|
|
1012
|
+
opacity: 0;
|
|
1013
|
+
transform: translateY(-50%) scale(0.96);
|
|
1014
|
+
}
|
|
1015
|
+
|
|
1016
|
+
.origam-video-skip-ripple-enter-to,
|
|
1017
|
+
.origam-video-skip-ripple-leave-from {
|
|
1018
|
+
opacity: 1;
|
|
1019
|
+
transform: translateY(-50%) scale(1);
|
|
1020
|
+
}
|
|
1021
|
+
|
|
1022
|
+
@media (prefers-reduced-motion: reduce) {
|
|
1023
|
+
.origam-video__skip-icon,
|
|
1024
|
+
.origam-video__skip-ripple,
|
|
1025
|
+
.origam-video-skip-ripple-enter-active,
|
|
1026
|
+
.origam-video-skip-ripple-leave-active {
|
|
1027
|
+
transition: none;
|
|
1028
|
+
}
|
|
1029
|
+
.origam-video__skip-chevron {
|
|
1030
|
+
animation: none;
|
|
1031
|
+
opacity: 0.85;
|
|
1032
|
+
}
|
|
1033
|
+
}
|
|
1034
|
+
|
|
1035
|
+
.origam-video__btn {
|
|
1036
|
+
all: unset;
|
|
1037
|
+
box-sizing: border-box;
|
|
1038
|
+
display: inline-flex;
|
|
1039
|
+
align-items: center;
|
|
1040
|
+
justify-content: center;
|
|
1041
|
+
width: 36px;
|
|
1042
|
+
height: 36px;
|
|
1043
|
+
border-radius: 50%;
|
|
1044
|
+
cursor: pointer;
|
|
1045
|
+
color: #ffffff;
|
|
1046
|
+
transition: background-color 120ms ease, transform 120ms ease, opacity 120ms ease;
|
|
1047
|
+
opacity: 0.95;
|
|
1048
|
+
}
|
|
1049
|
+
|
|
1050
|
+
.origam-video__btn:hover,
|
|
1051
|
+
.origam-video__btn:focus-visible {
|
|
1052
|
+
opacity: 1;
|
|
1053
|
+
background-color: rgba(255, 255, 255, 0.12);
|
|
1054
|
+
}
|
|
1055
|
+
|
|
1056
|
+
.origam-video__btn:active {
|
|
1057
|
+
transform: scale(0.92);
|
|
1058
|
+
}
|
|
1059
|
+
|
|
1060
|
+
.origam-video__btn--active {
|
|
1061
|
+
opacity: 1;
|
|
1062
|
+
position: relative;
|
|
1063
|
+
}
|
|
1064
|
+
|
|
1065
|
+
.origam-video__btn--active::after {
|
|
1066
|
+
content: '';
|
|
1067
|
+
position: absolute;
|
|
1068
|
+
bottom: 2px;
|
|
1069
|
+
width: 4px;
|
|
1070
|
+
height: 4px;
|
|
1071
|
+
border-radius: 50%;
|
|
1072
|
+
background: #ef4444;
|
|
1073
|
+
}
|
|
1074
|
+
|
|
1075
|
+
.origam-video__btn .origam-icon {
|
|
1076
|
+
font-size: 20px;
|
|
1077
|
+
line-height: 1;
|
|
1078
|
+
}
|
|
1079
|
+
|
|
1080
|
+
.origam-video--fullscreen {
|
|
1081
|
+
border-radius: 0;
|
|
1082
|
+
}
|
|
1083
|
+
|
|
1084
|
+
.origam-video--error .origam-video__poster {
|
|
1085
|
+
display: none;
|
|
1086
|
+
}
|
|
1087
|
+
</style>
|