@sigmaott/base-next 1.0.6
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/README.md +1 -0
- package/hyrd-ui.preset.ts +463 -0
- package/i18n.config.ts +3 -0
- package/locales/en.yaml +719 -0
- package/locales/vi.yaml +726 -0
- package/nuxt-config.ts +23 -0
- package/nuxt.config.ts +267 -0
- package/package.json +119 -0
- package/public/routes.json +34 -0
- package/src/MediaInfoModule.wasm +0 -0
- package/src/api/api.ts +15 -0
- package/src/api/axios.ts +125 -0
- package/src/api/service-loading.ts +50 -0
- package/src/api-client-auth/.openapi-generator/FILES +83 -0
- package/src/api-client-auth/.openapi-generator/VERSION +1 -0
- package/src/api-client-auth/.openapi-generator-ignore +23 -0
- package/src/api-client-auth/api/admin-groups-api.ts +612 -0
- package/src/api-client-auth/api/admin-members-api.ts +708 -0
- package/src/api-client-auth/api/administration-api-groups-api.ts +547 -0
- package/src/api-client-auth/api/administration-apps-api.ts +709 -0
- package/src/api-client-auth/api/administration-packages-api.ts +547 -0
- package/src/api-client-auth/api/api-groups-api.ts +296 -0
- package/src/api-client-auth/api/apps-api.ts +1613 -0
- package/src/api-client-auth/api/basic-credential-api.ts +950 -0
- package/src/api-client-auth/api/groups-api.ts +702 -0
- package/src/api-client-auth/api/members-api.ts +708 -0
- package/src/api-client-auth/api/members-on-premise-api.ts +351 -0
- package/src/api-client-auth/api/packages-api.ts +296 -0
- package/src/api-client-auth/api/users-api.ts +1387 -0
- package/src/api-client-auth/api.ts +30 -0
- package/src/api-client-auth/base.ts +72 -0
- package/src/api-client-auth/common.ts +150 -0
- package/src/api-client-auth/configuration.ts +101 -0
- package/src/api-client-auth/git_push.sh +57 -0
- package/src/api-client-auth/index.ts +18 -0
- package/src/api-client-auth/models/add-member-dto.ts +42 -0
- package/src/api-client-auth/models/admin-permission.ts +44 -0
- package/src/api-client-auth/models/api-group-collection.ts +57 -0
- package/src/api-client-auth/models/api-group.ts +80 -0
- package/src/api-client-auth/models/api.ts +44 -0
- package/src/api-client-auth/models/app-collection.ts +57 -0
- package/src/api-client-auth/models/app.ts +147 -0
- package/src/api-client-auth/models/backdoor-cred.ts +39 -0
- package/src/api-client-auth/models/basic-cred-collection.ts +57 -0
- package/src/api-client-auth/models/basic-cred.ts +83 -0
- package/src/api-client-auth/models/change-password-dto.ts +42 -0
- package/src/api-client-auth/models/create-admin-group-dto.ts +39 -0
- package/src/api-client-auth/models/create-api-group-dto.ts +42 -0
- package/src/api-client-auth/models/create-app-by-user-dto.ts +36 -0
- package/src/api-client-auth/models/create-app-dto.ts +65 -0
- package/src/api-client-auth/models/create-basic-cred-dto.ts +39 -0
- package/src/api-client-auth/models/create-group-dto.ts +39 -0
- package/src/api-client-auth/models/create-package-dto.ts +48 -0
- package/src/api-client-auth/models/create-user-dto.ts +60 -0
- package/src/api-client-auth/models/free-trial.ts +54 -0
- package/src/api-client-auth/models/general-app.ts +48 -0
- package/src/api-client-auth/models/generate-app-id.ts +30 -0
- package/src/api-client-auth/models/group-collection.ts +57 -0
- package/src/api-client-auth/models/group.ts +75 -0
- package/src/api-client-auth/models/index.ts +60 -0
- package/src/api-client-auth/models/invite-email-dto.ts +30 -0
- package/src/api-client-auth/models/invite-member-dto.ts +36 -0
- package/src/api-client-auth/models/live-stream-quota.ts +42 -0
- package/src/api-client-auth/models/login-dto.ts +36 -0
- package/src/api-client-auth/models/login-result.ts +39 -0
- package/src/api-client-auth/models/member-collection.ts +57 -0
- package/src/api-client-auth/models/member.ts +92 -0
- package/src/api-client-auth/models/package-collection.ts +57 -0
- package/src/api-client-auth/models/package-permission.ts +44 -0
- package/src/api-client-auth/models/package.ts +66 -0
- package/src/api-client-auth/models/permission.ts +44 -0
- package/src/api-client-auth/models/quota.ts +45 -0
- package/src/api-client-auth/models/re-get-password-dto.ts +30 -0
- package/src/api-client-auth/models/register-dto.ts +54 -0
- package/src/api-client-auth/models/register-through-email-dto.ts +36 -0
- package/src/api-client-auth/models/rename-app-dto.ts +30 -0
- package/src/api-client-auth/models/resend-confirmation-dto.ts +30 -0
- package/src/api-client-auth/models/resend-invitation-dto.ts +30 -0
- package/src/api-client-auth/models/resend-result.ts +36 -0
- package/src/api-client-auth/models/reset-password-dto.ts +36 -0
- package/src/api-client-auth/models/revoke-basic-dto.ts +38 -0
- package/src/api-client-auth/models/signup-result.ts +45 -0
- package/src/api-client-auth/models/token-check-result.ts +36 -0
- package/src/api-client-auth/models/trial-remaining-days.ts +42 -0
- package/src/api-client-auth/models/update-admin-group-dto.ts +39 -0
- package/src/api-client-auth/models/update-api-group-dto.ts +30 -0
- package/src/api-client-auth/models/update-app-by-admin-dto.ts +48 -0
- package/src/api-client-auth/models/update-app-by-user-dto.ts +36 -0
- package/src/api-client-auth/models/update-basic-cred-dto.ts +30 -0
- package/src/api-client-auth/models/update-group-dto.ts +39 -0
- package/src/api-client-auth/models/update-member-dto.ts +30 -0
- package/src/api-client-auth/models/update-package-dto.ts +42 -0
- package/src/api-client-auth/models/update-password-member-dto.ts +30 -0
- package/src/api-client-auth/models/update-user-by-user-dto.ts +48 -0
- package/src/api-client-auth/models/user.ts +120 -0
- package/src/api-client-auth/models/validate-app-id.ts +36 -0
- package/src/api-client-billing/.openapi-generator/FILES +38 -0
- package/src/api-client-billing/.openapi-generator/VERSION +1 -0
- package/src/api-client-billing/.openapi-generator-ignore +23 -0
- package/src/api-client-billing/api/invoice-api.ts +363 -0
- package/src/api-client-billing/api/payment-methods-api.ts +414 -0
- package/src/api-client-billing/api/payment-plan-api.ts +121 -0
- package/src/api-client-billing/api/subscriptions-api.ts +121 -0
- package/src/api-client-billing/api/usages-api.ts +121 -0
- package/src/api-client-billing/api/vnpay-provider-api.ts +327 -0
- package/src/api-client-billing/api.ts +23 -0
- package/src/api-client-billing/base.ts +72 -0
- package/src/api-client-billing/common.ts +150 -0
- package/src/api-client-billing/configuration.ts +101 -0
- package/src/api-client-billing/git_push.sh +57 -0
- package/src/api-client-billing/index.ts +18 -0
- package/src/api-client-billing/models/common-paginate-response.ts +48 -0
- package/src/api-client-billing/models/dto-billing-item-info.ts +60 -0
- package/src/api-client-billing/models/dto-billing-item.ts +36 -0
- package/src/api-client-billing/models/dto-create-draft-invoice-request.ts +33 -0
- package/src/api-client-billing/models/dto-create-draft-invoice-response.ts +57 -0
- package/src/api-client-billing/models/dto-create-vnpay-card-form.ts +48 -0
- package/src/api-client-billing/models/dto-return-uri-response.ts +30 -0
- package/src/api-client-billing/models/index.ts +22 -0
- package/src/api-client-billing/models/invoices-get200-response.ts +42 -0
- package/src/api-client-billing/models/model-charge.ts +47 -0
- package/src/api-client-billing/models/model-charges-usage.ts +57 -0
- package/src/api-client-billing/models/model-graduated-range.ts +48 -0
- package/src/api-client-billing/models/model-info.ts +42 -0
- package/src/api-client-billing/models/model-invoice.ts +105 -0
- package/src/api-client-billing/models/model-item-usage.ts +54 -0
- package/src/api-client-billing/models/model-payment-method.ts +135 -0
- package/src/api-client-billing/models/model-product.ts +51 -0
- package/src/api-client-billing/models/model-properties.ts +39 -0
- package/src/api-client-billing/models/model-quota.ts +48 -0
- package/src/api-client-billing/models/model-subscription.ts +51 -0
- package/src/api-client-billing/models/model-usage-payment.ts +87 -0
- package/src/api-client-billing/models/payment-methods-get200-response.ts +42 -0
- package/src/api-client-billing/models/subscriptions-get200-response.ts +42 -0
- package/src/api-client-machine/.openapi-generator/FILES +90 -0
- package/src/api-client-machine/.openapi-generator/VERSION +1 -0
- package/src/api-client-machine/.openapi-generator-ignore +23 -0
- package/src/api-client-machine/api/apps-config-api.ts +523 -0
- package/src/api-client-machine/api/component-clusters-api.ts +741 -0
- package/src/api-client-machine/api/expose-api.ts +141 -0
- package/src/api-client-machine/api/machine-actions-api.ts +850 -0
- package/src/api-client-machine/api/machines-api.ts +524 -0
- package/src/api-client-machine/api/networks-api.ts +375 -0
- package/src/api-client-machine/api/sigma-clusters-api.ts +741 -0
- package/src/api-client-machine/api/sigma-machine-actions-api.ts +292 -0
- package/src/api-client-machine/api/sigma-machine-apps-configuration-api.ts +523 -0
- package/src/api-client-machine/api/sigma-machines-api.ts +557 -0
- package/src/api-client-machine/api/sigma-vod-server-api.ts +478 -0
- package/src/api-client-machine/api/sigma-vod-server-app-config-api.ts +980 -0
- package/src/api-client-machine/api/transcoder-configuration-api.ts +359 -0
- package/src/api-client-machine/api.ts +30 -0
- package/src/api-client-machine/base.ts +72 -0
- package/src/api-client-machine/common.ts +150 -0
- package/src/api-client-machine/configuration.ts +101 -0
- package/src/api-client-machine/git_push.sh +57 -0
- package/src/api-client-machine/index.ts +18 -0
- package/src/api-client-machine/models/actions-to-app-dto.ts +38 -0
- package/src/api-client-machine/models/add-license-machine-dto.ts +30 -0
- package/src/api-client-machine/models/app-status.ts +47 -0
- package/src/api-client-machine/models/check-quota-limit-result.ts +36 -0
- package/src/api-client-machine/models/cluster-log.ts +54 -0
- package/src/api-client-machine/models/component-cluster-collection.ts +57 -0
- package/src/api-client-machine/models/component-cluster.ts +116 -0
- package/src/api-client-machine/models/create-component-machine-cluster-dto.ts +86 -0
- package/src/api-client-machine/models/create-sigma-machine-cluster-dto.ts +77 -0
- package/src/api-client-machine/models/create-vodroute-dto.ts +42 -0
- package/src/api-client-machine/models/decklink-collection.ts +57 -0
- package/src/api-client-machine/models/decklink.ts +42 -0
- package/src/api-client-machine/models/http-app.ts +45 -0
- package/src/api-client-machine/models/https-config.ts +42 -0
- package/src/api-client-machine/models/index.ts +67 -0
- package/src/api-client-machine/models/info-channel.ts +42 -0
- package/src/api-client-machine/models/ingest-app.ts +60 -0
- package/src/api-client-machine/models/ingest-config.ts +74 -0
- package/src/api-client-machine/models/ingest-update-config-dto.ts +68 -0
- package/src/api-client-machine/models/machine-cluster-collection.ts +57 -0
- package/src/api-client-machine/models/machine-cluster.ts +120 -0
- package/src/api-client-machine/models/machine-details-license.ts +42 -0
- package/src/api-client-machine/models/machine-details.ts +127 -0
- package/src/api-client-machine/models/machine-dto.ts +42 -0
- package/src/api-client-machine/models/machine-dump.ts +108 -0
- package/src/api-client-machine/models/machine.ts +42 -0
- package/src/api-client-machine/models/network-collection.ts +57 -0
- package/src/api-client-machine/models/network-interface.ts +36 -0
- package/src/api-client-machine/models/network.ts +66 -0
- package/src/api-client-machine/models/origin-config.ts +50 -0
- package/src/api-client-machine/models/origin-update-config-dto.ts +59 -0
- package/src/api-client-machine/models/packager-component-cluster.ts +42 -0
- package/src/api-client-machine/models/packager-live-cluster.ts +42 -0
- package/src/api-client-machine/models/packager-to-component-cluster.ts +51 -0
- package/src/api-client-machine/models/quotas-result.ts +30 -0
- package/src/api-client-machine/models/registration-config.ts +48 -0
- package/src/api-client-machine/models/sigma-cluster-ingest-config.ts +42 -0
- package/src/api-client-machine/models/sigma-cluster-origin-config.ts +30 -0
- package/src/api-client-machine/models/sigma-ingest-config-entity.ts +42 -0
- package/src/api-client-machine/models/sigma-ingest-config.ts +42 -0
- package/src/api-client-machine/models/sigma-origin-config-entity.ts +30 -0
- package/src/api-client-machine/models/sigma-origin-config.ts +30 -0
- package/src/api-client-machine/models/stats.ts +57 -0
- package/src/api-client-machine/models/status.ts +36 -0
- package/src/api-client-machine/models/stop-channel.ts +48 -0
- package/src/api-client-machine/models/transcoder-apps.ts +42 -0
- package/src/api-client-machine/models/transcoder-collection.ts +57 -0
- package/src/api-client-machine/models/transcoder-component-cluster.ts +42 -0
- package/src/api-client-machine/models/transcoder-license.ts +42 -0
- package/src/api-client-machine/models/transcoder-live-cluster.ts +42 -0
- package/src/api-client-machine/models/transcoder-live-to-component-cluster.ts +45 -0
- package/src/api-client-machine/models/transcoder-network.ts +42 -0
- package/src/api-client-machine/models/transcoder.ts +276 -0
- package/src/api-client-machine/models/update-app-config-dto-config-data.ts +33 -0
- package/src/api-client-machine/models/update-app-config-dto.ts +33 -0
- package/src/api-client-machine/models/update-app-config-of-sigma-vod-server-dto-config-data.ts +30 -0
- package/src/api-client-machine/models/update-app-config-of-sigma-vod-server-dto.ts +33 -0
- package/src/api-client-machine/models/update-component-cluster-dto.ts +72 -0
- package/src/api-client-machine/models/update-machine-cluster-dto.ts +63 -0
- package/src/api-client-machine/models/update-machine-dto.ts +42 -0
- package/src/api-client-machine/models/update-packager-live-cluster.ts +42 -0
- package/src/api-client-machine/models/update-packager-to-component-cluster.ts +51 -0
- package/src/api-client-machine/models/update-route-config-of-sigma-vod-server.ts +33 -0
- package/src/api-client-machine/models/update-route-config-sigma-machine.ts +42 -0
- package/src/api-client-machine/models/update-transcoder-live-cluster.ts +42 -0
- package/src/api-client-machine/models/update-transcoder-to-component-cluster.ts +45 -0
- package/src/api-client-machine/models/video-encoder.ts +56 -0
- package/src/api-client-machine/models/vodroute.ts +60 -0
- package/src/api-client-noti/.openapi-generator/FILES +13 -0
- package/src/api-client-noti/.openapi-generator/VERSION +1 -0
- package/src/api-client-noti/.openapi-generator-ignore +23 -0
- package/src/api-client-noti/api/notification-api.ts +386 -0
- package/src/api-client-noti/api.ts +18 -0
- package/src/api-client-noti/base.ts +72 -0
- package/src/api-client-noti/common.ts +150 -0
- package/src/api-client-noti/configuration.ts +101 -0
- package/src/api-client-noti/git_push.sh +57 -0
- package/src/api-client-noti/index.ts +18 -0
- package/src/api-client-noti/models/index.ts +2 -0
- package/src/api-client-noti/models/notification-collection.ts +57 -0
- package/src/api-client-noti/models/notification.ts +101 -0
- package/src/api-client-transcode/.openapi-generator/FILES +129 -0
- package/src/api-client-transcode/.openapi-generator/VERSION +1 -0
- package/src/api-client-transcode/.openapi-generator-ignore +23 -0
- package/src/api-client-transcode/api/alert-logs-apiapi.ts +281 -0
- package/src/api-client-transcode/api/channel-package-inputs-apiapi.ts +650 -0
- package/src/api-client-transcode/api/channel-transcode-inputs-apiapi.ts +650 -0
- package/src/api-client-transcode/api/channels-crudapiapi.ts +869 -0
- package/src/api-client-transcode/api/channels-job-action-apiapi.ts +434 -0
- package/src/api-client-transcode/api/drm-credentials-api.ts +525 -0
- package/src/api-client-transcode/api/event-channel-action-apiapi.ts +363 -0
- package/src/api-client-transcode/api/event-channel-crudapiapi.ts +545 -0
- package/src/api-client-transcode/api/fast-channel-action-apiapi.ts +301 -0
- package/src/api-client-transcode/api/fast-channel-apiapi.ts +525 -0
- package/src/api-client-transcode/api/fast-channel-programs-api-api.ts +525 -0
- package/src/api-client-transcode/api/multi-channel-action-apiapi.ts +387 -0
- package/src/api-client-transcode/api/sigma-transcode-live-interactive-action-api.ts +152 -0
- package/src/api-client-transcode/api/single-channel-action-apiapi.ts +1155 -0
- package/src/api-client-transcode/api/transcode-templates-apiapi.ts +541 -0
- package/src/api-client-transcode/api.ts +32 -0
- package/src/api-client-transcode/base.ts +71 -0
- package/src/api-client-transcode/common.ts +138 -0
- package/src/api-client-transcode/configuration.ts +101 -0
- package/src/api-client-transcode/git_push.sh +57 -0
- package/src/api-client-transcode/index.ts +18 -0
- package/src/api-client-transcode/models/ads-dto.ts +137 -0
- package/src/api-client-transcode/models/alert-log-collection.ts +55 -0
- package/src/api-client-transcode/models/audio-watermark-dto.ts +59 -0
- package/src/api-client-transcode/models/blackout-slate-dto.ts +36 -0
- package/src/api-client-transcode/models/catchup-dto.ts +43 -0
- package/src/api-client-transcode/models/channel-collection.ts +55 -0
- package/src/api-client-transcode/models/channel-config-advance-dto-info.ts +25 -0
- package/src/api-client-transcode/models/channel-config-advance-dto.ts +121 -0
- package/src/api-client-transcode/models/channel-config-advance-info-dto.ts +78 -0
- package/src/api-client-transcode/models/channel-config-base.ts +69 -0
- package/src/api-client-transcode/models/channel-config-blackout-entity.ts +36 -0
- package/src/api-client-transcode/models/channel-config-dto.ts +72 -0
- package/src/api-client-transcode/models/channel-config-interactive-entity.ts +30 -0
- package/src/api-client-transcode/models/channel-config-template-dto.ts +66 -0
- package/src/api-client-transcode/models/channel-detail-catchup-dto.ts +37 -0
- package/src/api-client-transcode/models/channel-detail-dto.ts +69 -0
- package/src/api-client-transcode/models/channel-detail-input.ts +43 -0
- package/src/api-client-transcode/models/channel-detail-package.ts +50 -0
- package/src/api-client-transcode/models/channel-detail-transcode.ts +37 -0
- package/src/api-client-transcode/models/channel-job-detail.ts +84 -0
- package/src/api-client-transcode/models/channel-stats.ts +36 -0
- package/src/api-client-transcode/models/channel-template-data-dto.ts +59 -0
- package/src/api-client-transcode/models/channel-template-dto-data.ts +28 -0
- package/src/api-client-transcode/models/channel-template-dto.ts +63 -0
- package/src/api-client-transcode/models/channel.ts +168 -0
- package/src/api-client-transcode/models/create-alert-log-dto.ts +138 -0
- package/src/api-client-transcode/models/create-channel-dto.ts +84 -0
- package/src/api-client-transcode/models/create-drm-credential-dto.ts +63 -0
- package/src/api-client-transcode/models/create-event-channel-dto-targets.ts +26 -0
- package/src/api-client-transcode/models/create-event-channel-dto.ts +76 -0
- package/src/api-client-transcode/models/create-fast-channel-dto.ts +42 -0
- package/src/api-client-transcode/models/create-fast-program-dto.ts +72 -0
- package/src/api-client-transcode/models/drm-credential-collection.ts +55 -0
- package/src/api-client-transcode/models/drm-credential-entity.ts +87 -0
- package/src/api-client-transcode/models/drm-data-dto.ts +54 -0
- package/src/api-client-transcode/models/drm-data-entity.ts +54 -0
- package/src/api-client-transcode/models/drm-dto.ts +103 -0
- package/src/api-client-transcode/models/event-channel-collection.ts +55 -0
- package/src/api-client-transcode/models/event-channel-config-dto.ts +78 -0
- package/src/api-client-transcode/models/event-channel-config-entity.ts +75 -0
- package/src/api-client-transcode/models/event-channel-input-dto.ts +45 -0
- package/src/api-client-transcode/models/event-channel-input-entity.ts +45 -0
- package/src/api-client-transcode/models/event-channel-transcoder-dto.ts +56 -0
- package/src/api-client-transcode/models/event-channel.ts +147 -0
- package/src/api-client-transcode/models/event-profile-dto.ts +62 -0
- package/src/api-client-transcode/models/event-target-data-dto.ts +95 -0
- package/src/api-client-transcode/models/event-target-dto.ts +49 -0
- package/src/api-client-transcode/models/fast-channel-collection.ts +55 -0
- package/src/api-client-transcode/models/fast-channel.ts +75 -0
- package/src/api-client-transcode/models/fast-program-collection.ts +55 -0
- package/src/api-client-transcode/models/fast-program.ts +84 -0
- package/src/api-client-transcode/models/fingerprint-dto.ts +42 -0
- package/src/api-client-transcode/models/index.ts +104 -0
- package/src/api-client-transcode/models/input-collection.ts +55 -0
- package/src/api-client-transcode/models/input-data-dto.ts +104 -0
- package/src/api-client-transcode/models/input-data-item-dto.ts +42 -0
- package/src/api-client-transcode/models/input-dto.ts +30 -0
- package/src/api-client-transcode/models/input-entity.ts +30 -0
- package/src/api-client-transcode/models/input-info-response.ts +31 -0
- package/src/api-client-transcode/models/input-info.ts +123 -0
- package/src/api-client-transcode/models/input-machine-config.ts +45 -0
- package/src/api-client-transcode/models/input-program.ts +66 -0
- package/src/api-client-transcode/models/interactive-dto.ts +30 -0
- package/src/api-client-transcode/models/interactive-publish-dto.ts +30 -0
- package/src/api-client-transcode/models/job-entity.ts +102 -0
- package/src/api-client-transcode/models/low-latency-dto.ts +68 -0
- package/src/api-client-transcode/models/machine-config-dto.ts +75 -0
- package/src/api-client-transcode/models/main-input-dto.ts +62 -0
- package/src/api-client-transcode/models/main-input-entity.ts +54 -0
- package/src/api-client-transcode/models/maintenance-dto.ts +30 -0
- package/src/api-client-transcode/models/manifest-dto.ts +62 -0
- package/src/api-client-transcode/models/package-input-collection.ts +55 -0
- package/src/api-client-transcode/models/package-input-data-dto.ts +99 -0
- package/src/api-client-transcode/models/package-input-list.ts +36 -0
- package/src/api-client-transcode/models/package-input.ts +115 -0
- package/src/api-client-transcode/models/post-input-dto.ts +48 -0
- package/src/api-client-transcode/models/post-input-entity.ts +48 -0
- package/src/api-client-transcode/models/pre-input-dto.ts +54 -0
- package/src/api-client-transcode/models/pre-input-entity.ts +54 -0
- package/src/api-client-transcode/models/preset-dto.ts +247 -0
- package/src/api-client-transcode/models/profile-default-response-dto.ts +30 -0
- package/src/api-client-transcode/models/profile-dto.ts +62 -0
- package/src/api-client-transcode/models/profile-entity.ts +60 -0
- package/src/api-client-transcode/models/scte35-dto.ts +36 -0
- package/src/api-client-transcode/models/start-over-dto.ts +30 -0
- package/src/api-client-transcode/models/switch-input-dto.ts +56 -0
- package/src/api-client-transcode/models/switch-input-entity.ts +44 -0
- package/src/api-client-transcode/models/target-data-dto.ts +101 -0
- package/src/api-client-transcode/models/target-dto.ts +44 -0
- package/src/api-client-transcode/models/target-entity.ts +55 -0
- package/src/api-client-transcode/models/target-profile-dto.ts +71 -0
- package/src/api-client-transcode/models/target-profile.ts +71 -0
- package/src/api-client-transcode/models/target-template-dto.ts +44 -0
- package/src/api-client-transcode/models/target-update-dto.ts +50 -0
- package/src/api-client-transcode/models/transcode-input.ts +144 -0
- package/src/api-client-transcode/models/transcoder.ts +36 -0
- package/src/api-client-transcode/models/trick-play-dto.ts +54 -0
- package/src/api-client-transcode/models/update-channel-dto-targets.ts +27 -0
- package/src/api-client-transcode/models/update-channel-dto.ts +84 -0
- package/src/api-client-transcode/models/update-drm-management-dto.ts +63 -0
- package/src/api-client-transcode/models/update-event-channel-dto.ts +76 -0
- package/src/api-client-transcode/models/update-fast-channel-dto.ts +42 -0
- package/src/api-client-transcode/models/update-fast-program-dto.ts +30 -0
- package/src/api-client-transcode/models/watermark-dto.ts +66 -0
- package/src/api-client-transcode/models/watermark-entity.ts +102 -0
- package/src/app/spa-loading-template.html +127 -0
- package/src/app.config.ts +2 -0
- package/src/assets/global.css.ts +3 -0
- package/src/assets/scss/element/dark.scss +13 -0
- package/src/assets/scss/element/index.scss +26 -0
- package/src/assets/scss/index.scss +181 -0
- package/src/components/AdvancedFilter/SSAdvancedFilterItem.vue +180 -0
- package/src/components/AdvancedFilter/SSAdvancedFilterItemCustom.vue +165 -0
- package/src/components/AdvancedFilter/SSAdvancedFilterItemDefined.vue +298 -0
- package/src/components/AdvancedFilter/SSAdvancedFilterItemSchedule.vue +293 -0
- package/src/components/AdvancedFilter/SSAdvancedFilterMain.vue +196 -0
- package/src/components/AdvancedFilter/types.ts +37 -0
- package/src/components/AdvancedFilterReport/SSAdvancedFilterReportItem.vue +110 -0
- package/src/components/AdvancedFilterReport/SSAdvancedFilterReportItemDefined.vue +159 -0
- package/src/components/AdvancedFilterReport/SSAdvancedFilterReportMain.vue +197 -0
- package/src/components/AdvancedFilterReport/types.ts +19 -0
- package/src/components/AdvancedFilterSsai/SSAdvancedFilterSsaiItem.vue +102 -0
- package/src/components/AdvancedFilterSsai/SSAdvancedFilterSsaiItemDefined.vue +119 -0
- package/src/components/AdvancedFilterSsai/SSAdvancedFilterSsaiMain.vue +194 -0
- package/src/components/AdvancedFilterSsai/types.ts +19 -0
- package/src/components/Asset/AssetAddPlaylist.vue +169 -0
- package/src/components/Asset/AssetExtra.vue +46 -0
- package/src/components/Asset/AssetImportLinks.vue +281 -0
- package/src/components/Asset/AssetInfiniteSelect.vue +62 -0
- package/src/components/Asset/AssetItem.vue +194 -0
- package/src/components/Asset/AssetItemPreview.vue +117 -0
- package/src/components/Asset/AssetList.vue +869 -0
- package/src/components/Asset/AssetMeta.vue +97 -0
- package/src/components/Asset/AssetPicker.vue +204 -0
- package/src/components/Asset/AssetPlaylist.vue +414 -0
- package/src/components/Asset/AssetPlaylistInfiniteSelect.vue +136 -0
- package/src/components/Asset/AssetPlaylistModalAdd.vue +138 -0
- package/src/components/Asset/AssetPreview.vue +89 -0
- package/src/components/Asset/AssetShareModal.vue +131 -0
- package/src/components/Asset/AssetTable.vue +365 -0
- package/src/components/Asset/FormUploadAsset.vue +647 -0
- package/src/components/Asset/FormUploadAssetItem.vue +115 -0
- package/src/components/Asset/FormUploadAssetProgress.vue +161 -0
- package/src/components/Asset/Scrubber.vue +57 -0
- package/src/components/Asset/VideoPlayer.vue +226 -0
- package/src/components/Asset/VideoPreview.vue +102 -0
- package/src/components/Asset/VideoPreviewConfig.vue +329 -0
- package/src/components/Asset/VideoPreviewConfigMessage.vue +120 -0
- package/src/components/Asset/VideoPreviewConfigVod.vue +287 -0
- package/src/components/Asset/VideoPreviewNew.vue +66 -0
- package/src/components/Asset/VideoPreviewNewLoader.vue +144 -0
- package/src/components/Asset/VideoPreviewWrapper.vue +208 -0
- package/src/components/Asset/asset-context.ts +24 -0
- package/src/components/Asset/usePickerStore.ts +55 -0
- package/src/components/AuthLayout/AuthLayoutSimple.vue +150 -0
- package/src/components/AuthLayout/index.vue +151 -0
- package/src/components/AutoRefresh/AutoRefresh.vue +91 -0
- package/src/components/AutoRefresh/AutoRefreshOld.vue +87 -0
- package/src/components/AutoRefresh/useRefresh.ts +93 -0
- package/src/components/BackButton.vue +13 -0
- package/src/components/Card/CardInfo.vue +21 -0
- package/src/components/Channel/AIConfig.vue +101 -0
- package/src/components/Channel/AdvancedForm.vue +542 -0
- package/src/components/Channel/ChannelListGrid.vue +154 -0
- package/src/components/Channel/ConfigBlackout.vue +98 -0
- package/src/components/Channel/ConfigCensorship.vue +387 -0
- package/src/components/Channel/ConfigForensicWatermark.vue +152 -0
- package/src/components/Channel/ConfigForm.vue +102 -0
- package/src/components/Channel/ConfigInformation.vue +191 -0
- package/src/components/Channel/ConfigInteraction.vue +11 -0
- package/src/components/Channel/ConfigNameModifier.vue +15 -0
- package/src/components/Channel/ConfigOptionItem.vue +114 -0
- package/src/components/Channel/ConfigOptions.vue +181 -0
- package/src/components/Channel/ConfigPte.vue +368 -0
- package/src/components/Channel/ConfigScte.vue +442 -0
- package/src/components/Channel/ConfigTranscoder.vue +353 -0
- package/src/components/Channel/ConfigWaterMarkAudio.vue +52 -0
- package/src/components/Channel/ConfigWatermark.vue +76 -0
- package/src/components/Channel/ConfigWatermarkEventChannel.vue +86 -0
- package/src/components/Channel/ConfigWatermarkItem.vue +239 -0
- package/src/components/Channel/HeaderItem.vue +75 -0
- package/src/components/Channel/InputDetail.vue +68 -0
- package/src/components/Channel/InputForm.vue +175 -0
- package/src/components/Channel/InputList.vue +38 -0
- package/src/components/Channel/InputPackageDetail.vue +125 -0
- package/src/components/Channel/MediaProfileFormModal.vue +79 -0
- package/src/components/Channel/MediaProfileModify.vue +229 -0
- package/src/components/Channel/MessageButtonGetHelp.vue +30 -0
- package/src/components/Channel/MessageTooltipAi.vue +29 -0
- package/src/components/Channel/MultipleSelectProfile.vue +312 -0
- package/src/components/Channel/PackageInputItem.vue +13 -0
- package/src/components/Channel/PresetConfigItem.vue +1957 -0
- package/src/components/Channel/PresetConfigItemExtra.vue +59 -0
- package/src/components/Channel/PresetConfigItemPId.vue +145 -0
- package/src/components/Channel/ProfileConfigItem.vue +829 -0
- package/src/components/Channel/ProfileDetailsList.vue +160 -0
- package/src/components/Channel/ProfileForm.vue +134 -0
- package/src/components/Channel/ProfileList.vue +228 -0
- package/src/components/Channel/SelectServer.vue +134 -0
- package/src/components/Channel/SignalLoss.vue +92 -0
- package/src/components/Channel/SwitchInputButton.vue +38 -0
- package/src/components/Channel/TargetCatchup.vue +75 -0
- package/src/components/Channel/TargetDataInfo.vue +100 -0
- package/src/components/Channel/TargetDestination.vue +375 -0
- package/src/components/Channel/TargetDrm.vue +518 -0
- package/src/components/Channel/TargetForm.vue +136 -0
- package/src/components/Channel/TargetList.vue +159 -0
- package/src/components/Channel/TargetLowLatency.vue +107 -0
- package/src/components/Channel/TargetMabrOutput.vue +58 -0
- package/src/components/Channel/TargetMabrOutputItem.vue +91 -0
- package/src/components/Channel/TargetManifest.vue +94 -0
- package/src/components/Channel/TargetNetworkInterface.vue +95 -0
- package/src/components/Channel/TargetOutputMultiplex.vue +237 -0
- package/src/components/Channel/TargetOutputType.vue +201 -0
- package/src/components/Channel/TargetOutputUdp.vue +200 -0
- package/src/components/Channel/TargetPreset.vue +541 -0
- package/src/components/Channel/TargetProfileAudioGroup.vue +27 -0
- package/src/components/Channel/TargetProfileProgram.vue +43 -0
- package/src/components/Channel/TargetProfileURI.vue +68 -0
- package/src/components/Channel/TargetSrtOutput.vue +35 -0
- package/src/components/Channel/TargetSrtOutputItem.vue +83 -0
- package/src/components/Channel/TargetStartover.vue +40 -0
- package/src/components/Channel/WarningName.vue +39 -0
- package/src/components/Channel/WarningOutput.vue +40 -0
- package/src/components/CollapseTagsTooltip/CollapseTagsTooltip.vue +87 -0
- package/src/components/CollapseTagsTooltip/index.ts +1 -0
- package/src/components/CopyButton.vue +46 -0
- package/src/components/CopyText.vue +40 -0
- package/src/components/CopyTextButton.vue +40 -0
- package/src/components/DefaultLayout/DefaultLayout.vue +134 -0
- package/src/components/DefaultLayout/GlobalASide.vue +75 -0
- package/src/components/DefaultLayout/GlobalFooter.vue +15 -0
- package/src/components/DefaultLayout/GlobalHeader.vue +43 -0
- package/src/components/DefaultLayout/Logo.vue +35 -0
- package/src/components/DefaultLayout/Menu.vue +464 -0
- package/src/components/DefaultLayout/RightMenu.vue +93 -0
- package/src/components/DialogWarningAddLicense.vue +37 -0
- package/src/components/Epg/Epg.vue +24 -0
- package/src/components/Epg/components/Channel.vue +28 -0
- package/src/components/Epg/components/Channels.vue +33 -0
- package/src/components/Epg/components/Layout.vue +121 -0
- package/src/components/Epg/components/Line.vue +41 -0
- package/src/components/Epg/components/Loader.vue +23 -0
- package/src/components/Epg/components/Program.vue +101 -0
- package/src/components/Epg/components/SideBar.vue +18 -0
- package/src/components/Epg/components/Timeline.vue +72 -0
- package/src/components/Epg/helpers/common.ts +68 -0
- package/src/components/Epg/helpers/epg.ts +192 -0
- package/src/components/Epg/helpers/index.ts +5 -0
- package/src/components/Epg/helpers/interfaces.ts +54 -0
- package/src/components/Epg/helpers/time.ts +51 -0
- package/src/components/Epg/helpers/types.ts +26 -0
- package/src/components/Epg/helpers/variables.ts +33 -0
- package/src/components/Epg/hooks/index.ts +2 -0
- package/src/components/Epg/hooks/useEpg.ts +160 -0
- package/src/components/Epg/hooks/useLayout.ts +187 -0
- package/src/components/Epg/hooks/useProgram.ts +63 -0
- package/src/components/Epg/hooks/useTimeline.ts +35 -0
- package/src/components/Epg/index.ts +4 -0
- package/src/components/Epg/store.ts +85 -0
- package/src/components/Epg/theme.ts +44 -0
- package/src/components/Exception/403.png +0 -0
- package/src/components/Exception/403.vue +58 -0
- package/src/components/Exception/404.png +0 -0
- package/src/components/Exception/404.vue +59 -0
- package/src/components/Exception/500.png +0 -0
- package/src/components/Exception/500.vue +39 -0
- package/src/components/Exception/index.scss +30 -0
- package/src/components/Field.vue +193 -0
- package/src/components/FilterQuerySchema/FilterQuerySchemaForm.vue +200 -0
- package/src/components/FilterQuerySchema/QueryTag.vue +109 -0
- package/src/components/FilterQuerySchema/Tag.vue +68 -0
- package/src/components/FilterTimeDimensions.vue +265 -0
- package/src/components/FilterTimeDimensionsSingle.vue +214 -0
- package/src/components/HelpPanel.vue +87 -0
- package/src/components/HexagonPro.vue +7 -0
- package/src/components/IconCopyButton.vue +43 -0
- package/src/components/InformationLabel.vue +67 -0
- package/src/components/Input/InputTags.vue +136 -0
- package/src/components/Input/index.ts +1 -0
- package/src/components/MainDefaultLayout/index.vue +120 -0
- package/src/components/NoticeAddLicense.vue +20 -0
- package/src/components/NoticeRunningOutResources.vue +20 -0
- package/src/components/Pagination.vue +61 -0
- package/src/components/QueryBuilder/QueryBuilder.vue +141 -0
- package/src/components/QueryBuilder/components/inputs/DateInputField.vue +105 -0
- package/src/components/QueryBuilder/components/inputs/FieldSelect.vue +44 -0
- package/src/components/QueryBuilder/components/inputs/InputMultiSelect.vue +60 -0
- package/src/components/QueryBuilder/components/inputs/InputSelect.vue +39 -0
- package/src/components/QueryBuilder/components/inputs/NumberInputField.vue +91 -0
- package/src/components/QueryBuilder/components/inputs/OperatorSelect.vue +59 -0
- package/src/components/QueryBuilder/components/inputs/TextInput.vue +40 -0
- package/src/components/QueryBuilder/components/inputs/TimeInputField.vue +114 -0
- package/src/components/QueryBuilder/components/inputs/logics.ts +27 -0
- package/src/components/QueryBuilder/components/item/InputMultiOptions.vue +56 -0
- package/src/components/QueryBuilder/components/item/QueryGroup.vue +71 -0
- package/src/components/QueryBuilder/components/item/QueryGroupActions.vue +76 -0
- package/src/components/QueryBuilder/components/item/QueryRule.vue +233 -0
- package/src/components/QueryBuilder/useConfigStore.ts +27 -0
- package/src/components/QueryBuilder/utils/config.ts +194 -0
- package/src/components/QueryBuilder/utils/index.ts +3 -0
- package/src/components/QueryBuilder/utils/mongodb.ts +175 -0
- package/src/components/QueryBuilder/utils/rules.ts +213 -0
- package/src/components/RecommendedConfigurationPTE.vue +238 -0
- package/src/components/Server/MachineConfig.vue +333 -0
- package/src/components/Server/ServerConfig.vue +599 -0
- package/src/components/Server/useQueryMachine.ts +380 -0
- package/src/components/Server/validator.ts +13 -0
- package/src/components/SwitchDark.vue +19 -0
- package/src/components/SwitchLang.vue +31 -0
- package/src/components/TableEmpty.vue +50 -0
- package/src/components/Toast/ToastNoti.vue +52 -0
- package/src/components/Tool/ForensicWatermarkingDialog.vue +39 -0
- package/src/components/Tool/FormRecord.vue +162 -0
- package/src/components/Tool/FormUpload.vue +118 -0
- package/src/components/Tool/ResultChecking.vue +103 -0
- package/src/components/Tool/Watermarking.vue +159 -0
- package/src/components/Tool/record.js +92 -0
- package/src/components/Tooltip/Ellipsis.vue +52 -0
- package/src/components/Tooltip/index.vue +47 -0
- package/src/components/app/AppList.vue +50 -0
- package/src/components/button/Button.vue +27 -0
- package/src/components/button/index.ts +37 -0
- package/src/components/context-menu/ContextMenu.vue +15 -0
- package/src/components/context-menu/ContextMenuCheckboxItem.vue +39 -0
- package/src/components/context-menu/ContextMenuContent.vue +35 -0
- package/src/components/context-menu/ContextMenuGroup.vue +11 -0
- package/src/components/context-menu/ContextMenuItem.vue +33 -0
- package/src/components/context-menu/ContextMenuLabel.vue +24 -0
- package/src/components/context-menu/ContextMenuPortal.vue +11 -0
- package/src/components/context-menu/ContextMenuRadioGroup.vue +19 -0
- package/src/components/context-menu/ContextMenuRadioItem.vue +39 -0
- package/src/components/context-menu/ContextMenuSeparator.vue +19 -0
- package/src/components/context-menu/ContextMenuShortcut.vue +13 -0
- package/src/components/context-menu/ContextMenuSub.vue +19 -0
- package/src/components/context-menu/ContextMenuSubContent.vue +34 -0
- package/src/components/context-menu/ContextMenuSubTrigger.vue +33 -0
- package/src/components/context-menu/ContextMenuTrigger.vue +13 -0
- package/src/components/context-menu/index.ts +14 -0
- package/src/components/dashboard/SSDashboardChartRoot.vue +18 -0
- package/src/components/dashboard/SSDashboardDocument.vue +45 -0
- package/src/components/dashboard/SSDashboardEmpty.vue +16 -0
- package/src/components/dashboard/SSDashboardGuideline.vue +45 -0
- package/src/components/dashboard/SSDashboardInfo.vue +36 -0
- package/src/components/dashboard/SSDashboardInfoRoot.vue +9 -0
- package/src/components/dashboard/SSDashboardInfoTime.vue +38 -0
- package/src/components/markdown/Markdown.vue +295 -0
- package/src/components/tabs/Tabs.vue +15 -0
- package/src/components/tabs/TabsContent.vue +22 -0
- package/src/components/tabs/TabsList.vue +22 -0
- package/src/components/tabs/TabsTrigger.vue +26 -0
- package/src/composables/asset.ts +13 -0
- package/src/composables/channel.ts +333 -0
- package/src/composables/country.ts +788 -0
- package/src/composables/error.ts +24 -0
- package/src/composables/form.ts +351 -0
- package/src/composables/getBuildTime.ts +7 -0
- package/src/composables/micro.ts +113 -0
- package/src/composables/microState.ts +22 -0
- package/src/composables/notiGlobal.ts +19 -0
- package/src/composables/plan.ts +162 -0
- package/src/composables/refReset.ts +12 -0
- package/src/composables/resetInfiniteQueryPagination.ts +18 -0
- package/src/composables/route.ts +19 -0
- package/src/composables/toast.ts +21 -0
- package/src/composables/useApp.ts +6 -0
- package/src/composables/useAsyncSchema.ts +58 -0
- package/src/composables/useChannelActions.ts +151 -0
- package/src/composables/useComplexSearchParam.ts +293 -0
- package/src/composables/useFilterSchema.ts +106 -0
- package/src/composables/useGetInputDetail.ts +36 -0
- package/src/composables/useGetServerAddLicense.ts +21 -0
- package/src/composables/useJobPreview.ts +438 -0
- package/src/composables/useLayoutStore.ts +106 -0
- package/src/composables/usePermission.ts +5 -0
- package/src/composables/usePickerStore.ts +53 -0
- package/src/composables/useQueryAssets.ts +56 -0
- package/src/composables/useQueryParams.ts +20 -0
- package/src/composables/useRouteParams.ts +36 -0
- package/src/composables/useRouteQueries.ts +54 -0
- package/src/composables/useRouterHistory.ts +76 -0
- package/src/composables/useSearchQuery.ts +27 -0
- package/src/composables/useTooltipEllipsis.ts +12 -0
- package/src/constants/env.ts +11 -0
- package/src/constants/filterable.ts +32 -0
- package/src/constants/languageCode.ts +185 -0
- package/src/constants/micro.ts +1 -0
- package/src/constants/queryKeys.ts +11 -0
- package/src/constants/regex.ts +8 -0
- package/src/constants/storage.ts +41 -0
- package/src/enums/index.ts +24 -0
- package/src/layouts/empty.vue +7 -0
- package/src/modules/api-party/kit.ts +30 -0
- package/src/modules/api-party/module.ts +259 -0
- package/src/modules/api-party/openapi.ts +74 -0
- package/src/modules/api-party/runtime/composables/$api.ts +157 -0
- package/src/modules/api-party/runtime/composables/useApiData.ts +229 -0
- package/src/modules/api-party/runtime/constants.ts +1 -0
- package/src/modules/api-party/runtime/formData.ts +85 -0
- package/src/modules/api-party/runtime/server/$api.ts +29 -0
- package/src/modules/api-party/runtime/server/handler.ts +92 -0
- package/src/modules/api-party/runtime/types.ts +97 -0
- package/src/modules/api-party/runtime/utils.ts +43 -0
- package/src/pages/403.vue +11 -0
- package/src/pages/500.vue +11 -0
- package/src/pages/[...all].vue +11 -0
- package/src/pages/login.vue +67 -0
- package/src/plugins/auth.ts +10 -0
- package/src/plugins/build-time.ts +5 -0
- package/src/plugins/dayjs.ts +14 -0
- package/src/plugins/i18n.ts +6 -0
- package/src/plugins/router.ts +6 -0
- package/src/plugins/vue-json-pretty.ts +5 -0
- package/src/plugins/vue-query.ts +41 -0
- package/src/plugins/wujie.ts +19 -0
- package/src/public/apple-touch-icon.png +0 -0
- package/src/public/audio-recorder.js +31 -0
- package/src/public/build-time.json +1 -0
- package/src/public/favicon.ico +0 -0
- package/src/public/icon-block-free-app.png +0 -0
- package/src/public/maskable-icon.png +0 -0
- package/src/public/nuxt.svg +3 -0
- package/src/public/preview/step-1.png +0 -0
- package/src/public/preview/step-2.png +0 -0
- package/src/public/preview/step-3.png +0 -0
- package/src/public/pwa-192x192.png +0 -0
- package/src/public/pwa-512x512.png +0 -0
- package/src/public/robots.txt +2 -0
- package/src/public/vite.png +0 -0
- package/src/pwa/config.ts +61 -0
- package/src/pwa/index.ts +194 -0
- package/src/pwa/runtime/VitePwaManifest.ts +33 -0
- package/src/pwa/types.ts +56 -0
- package/src/pwa/utils.ts +16 -0
- package/src/schemas/authServiceApi.json +6709 -0
- package/src/schemas/billingApi.json +1083 -0
- package/src/schemas/chatApi.json +497 -0
- package/src/schemas/libraryApi.json +2009 -0
- package/src/schemas/licenseApi.json +772 -0
- package/src/schemas/livestreamApi.json +3354 -0
- package/src/schemas/lrmApi.json +2848 -0
- package/src/schemas/machineApi.json +4604 -0
- package/src/schemas/metricApi.json +141 -0
- package/src/schemas/notificationApi.json +1 -0
- package/src/schemas/playoutApi.json +8315 -0
- package/src/schemas/ssaiApi.json +1108 -0
- package/src/schemas/transcodeApi.json +9670 -0
- package/src/schemas/vastControlApi.json +961 -0
- package/src/schemas/vodApi.json +3974 -0
- package/src/server/plugins/loading.css +111 -0
- package/src/server/plugins/loading.html +12 -0
- package/src/server/plugins/loading.ts +134 -0
- package/src/templates/pwa.client.ts +136 -0
- package/src/utils/$apiOptions.ts +79 -0
- package/src/utils/app.ts +23 -0
- package/src/utils/cn.ts +3 -0
- package/src/utils/format.ts +88 -0
- package/src/utils/gen-routes.ts +100 -0
- package/src/utils/helper.ts +56 -0
- package/src/utils/micro.ts +207 -0
- package/src/utils/popoverSelectAttrs.ts +24 -0
- package/src/utils/popup.ts +96 -0
- package/src/utils/pwa.ts +86 -0
- package/src/utils/query-filter.ts +111 -0
- package/src/utils/table.ts +35 -0
- package/src/utils/tryCatch.ts +25 -0
- package/src/utils/utils.ts +58 -0
- package/src/utils/validator.ts +185 -0
- package/src/utils/videojs.ts +490 -0
- package/src/utils/wujie.ts +1 -0
- package/tsconfig.json +3 -0
- package/uno.config.ts +375 -0
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
<script lang="ts" setup>
|
|
2
|
+
import type { ChannelWithPosition } from '../helpers/types'
|
|
3
|
+
import { useEpgStore } from '../store'
|
|
4
|
+
|
|
5
|
+
defineProps<{
|
|
6
|
+
channel: ChannelWithPosition
|
|
7
|
+
}>()
|
|
8
|
+
const emit = defineEmits<{
|
|
9
|
+
(event: 'click', channel: ChannelWithPosition): void
|
|
10
|
+
}>()
|
|
11
|
+
|
|
12
|
+
const { theme } = useEpgStore()
|
|
13
|
+
</script>
|
|
14
|
+
|
|
15
|
+
<template>
|
|
16
|
+
<div
|
|
17
|
+
data-testid="sidebar-item" class="absolute flex items-center justify-center" :style="{
|
|
18
|
+
top: `${channel.position.top}px`,
|
|
19
|
+
height: `${channel.position.height}px`,
|
|
20
|
+
width: `100%`,
|
|
21
|
+
backgroundColor: `${theme.primary[900]}`,
|
|
22
|
+
}" @click="emit('click', channel)"
|
|
23
|
+
>
|
|
24
|
+
<slot name="channel" v-bind="{ channel, theme }">
|
|
25
|
+
<img :src="channel.logo" class="relative max-h-60px max-w-60px">
|
|
26
|
+
</slot>
|
|
27
|
+
</div>
|
|
28
|
+
</template>
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
<script lang="ts" setup>
|
|
2
|
+
import type { ChannelWithPosition } from '../helpers/types'
|
|
3
|
+
import { useEpgStore } from '../store'
|
|
4
|
+
import Channel from './Channel.vue'
|
|
5
|
+
|
|
6
|
+
const emit = defineEmits<{
|
|
7
|
+
(event: 'click', channel: ChannelWithPosition): void
|
|
8
|
+
}>()
|
|
9
|
+
|
|
10
|
+
const { theme, channels, scrollY, sidebarWidth, isChannelVisible } = useEpgStore()
|
|
11
|
+
|
|
12
|
+
const visibleChannels = computed(() => {
|
|
13
|
+
return channels.value.filter(item => isChannelVisible(item))
|
|
14
|
+
})
|
|
15
|
+
</script>
|
|
16
|
+
|
|
17
|
+
<template>
|
|
18
|
+
<div
|
|
19
|
+
data-testid="sidebar" class="sticky float-left" :style="{
|
|
20
|
+
width: `${sidebarWidth}px`,
|
|
21
|
+
bottom: `${scrollY}px`,
|
|
22
|
+
left: 0,
|
|
23
|
+
zIndex: 100,
|
|
24
|
+
backgroundColor: `${theme.primary[900]}`,
|
|
25
|
+
}"
|
|
26
|
+
>
|
|
27
|
+
<Channel v-for="channel in visibleChannels" :key="channel.uuid" :channel="channel" @click="(c) => emit('click', c)">
|
|
28
|
+
<template #channel="slotData">
|
|
29
|
+
<slot name="channel" v-bind="slotData" />
|
|
30
|
+
</template>
|
|
31
|
+
</Channel>
|
|
32
|
+
</div>
|
|
33
|
+
</template>
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
<script lang="ts" setup>
|
|
2
|
+
import type { Program as ProgramType } from '../helpers'
|
|
3
|
+
import { getProgramOptions, isFutureTime } from '../helpers'
|
|
4
|
+
import type { ChannelWithPosition } from '../helpers/types'
|
|
5
|
+
import { useEpgStore } from '../store'
|
|
6
|
+
import Line from './Line.vue'
|
|
7
|
+
import Timeline from './Timeline.vue'
|
|
8
|
+
import Channels from './Channels.vue'
|
|
9
|
+
import Program from './Program.vue'
|
|
10
|
+
|
|
11
|
+
const emit = defineEmits<{
|
|
12
|
+
(event: 'channel-click', channel: ChannelWithPosition): void
|
|
13
|
+
(event: 'program-click', program: ProgramType): void
|
|
14
|
+
(event: 'program-container-click'): void
|
|
15
|
+
}>()
|
|
16
|
+
|
|
17
|
+
const {
|
|
18
|
+
theme,
|
|
19
|
+
programs,
|
|
20
|
+
channels,
|
|
21
|
+
endDate,
|
|
22
|
+
dayWidth,
|
|
23
|
+
sidebarWidth,
|
|
24
|
+
itemHeight,
|
|
25
|
+
onScroll,
|
|
26
|
+
isSidebar,
|
|
27
|
+
isTimeline,
|
|
28
|
+
isLine,
|
|
29
|
+
isProgramVisible,
|
|
30
|
+
scrollBoxRef,
|
|
31
|
+
} = useEpgStore()
|
|
32
|
+
|
|
33
|
+
const channelsLength = computed(() => channels.value.length)
|
|
34
|
+
const contentHeight = computed(() => channelsLength.value * itemHeight.value)
|
|
35
|
+
|
|
36
|
+
const isFuture = computed(() => isFutureTime(endDate.value))
|
|
37
|
+
|
|
38
|
+
const visiblePrograms = computed(() => programs.value.filter((item) => {
|
|
39
|
+
return isProgramVisible(item.position)
|
|
40
|
+
}))
|
|
41
|
+
|
|
42
|
+
const programRef = ref<HTMLElement>()
|
|
43
|
+
|
|
44
|
+
onMounted(() => {
|
|
45
|
+
const scrollableDiv = scrollBoxRef.value!
|
|
46
|
+
scrollableDiv.addEventListener('wheel', (event) => {
|
|
47
|
+
event.preventDefault()
|
|
48
|
+
if (event.shiftKey) {
|
|
49
|
+
scrollableDiv.scrollLeft += event.deltaX
|
|
50
|
+
}
|
|
51
|
+
else {
|
|
52
|
+
scrollableDiv.scrollLeft += event.deltaX === 0
|
|
53
|
+
? event.deltaY
|
|
54
|
+
: Math.abs(event.deltaX) > Math.abs(event.deltaY) ? event.deltaX : event.deltaY
|
|
55
|
+
}
|
|
56
|
+
})
|
|
57
|
+
})
|
|
58
|
+
</script>
|
|
59
|
+
|
|
60
|
+
<template>
|
|
61
|
+
<div
|
|
62
|
+
ref="scrollBoxRef" class="scrollbox relative h-full w-full overflow-x-auto" :style="{
|
|
63
|
+
background: `${theme.primary['900']}`,
|
|
64
|
+
}" @scroll="onScroll"
|
|
65
|
+
>
|
|
66
|
+
<Line v-if="isLine && isFuture" :height="contentHeight" />
|
|
67
|
+
<Timeline v-if="isTimeline">
|
|
68
|
+
<template #timeline="slotData">
|
|
69
|
+
<slot name="timeline" v-bind="slotData" />
|
|
70
|
+
</template>
|
|
71
|
+
|
|
72
|
+
<template #timeline-last="slotData">
|
|
73
|
+
<slot name="timeline-last" v-bind="slotData" />
|
|
74
|
+
</template>
|
|
75
|
+
</Timeline>
|
|
76
|
+
|
|
77
|
+
<Channels v-if="isSidebar" @click="(channel) => emit('channel-click', channel)">
|
|
78
|
+
<template #channel="slotData">
|
|
79
|
+
<slot name="channel" v-bind="slotData" />
|
|
80
|
+
</template>
|
|
81
|
+
</Channels>
|
|
82
|
+
|
|
83
|
+
<div
|
|
84
|
+
ref="programRef" class="relative" :style="{
|
|
85
|
+
background: `${theme.primary['900']}`,
|
|
86
|
+
height: `${contentHeight}px`,
|
|
87
|
+
width: `${dayWidth}px`,
|
|
88
|
+
left: `${isSidebar ? sidebarWidth : 0}px`,
|
|
89
|
+
}" @click="() => emit('program-container-click')"
|
|
90
|
+
>
|
|
91
|
+
<Program
|
|
92
|
+
v-for="program in visiblePrograms" :key="program.data.id" :program="getProgramOptions(program)"
|
|
93
|
+
@click="(program) => emit('program-click', program)"
|
|
94
|
+
>
|
|
95
|
+
<template #program="slotData">
|
|
96
|
+
<slot name="program" v-bind="slotData" />
|
|
97
|
+
</template>
|
|
98
|
+
</Program>
|
|
99
|
+
</div>
|
|
100
|
+
</div>
|
|
101
|
+
</template>
|
|
102
|
+
|
|
103
|
+
<style>
|
|
104
|
+
.scrollbox::-webkit-scrollbar {
|
|
105
|
+
width: 7px;
|
|
106
|
+
height: 7px;
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
.scrollbox::-webkit-scrollbar-thumb {
|
|
110
|
+
@apply bg-gray-500/50 dark:bg-gray-500 rounded-16px;
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
.scrollbox::-webkit-scrollbar-thumb:hover {
|
|
114
|
+
@apply bg-gray-600/50 dark:bg-gray-400;
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
.scrollbox::-webkit-scrollbar-track {
|
|
118
|
+
border: 22px none v-bind('theme.white');
|
|
119
|
+
border-radius: 0px;
|
|
120
|
+
}
|
|
121
|
+
</style>
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
<script lang="ts" setup>
|
|
2
|
+
import { isToday, startOfDay } from 'date-fns'
|
|
3
|
+
import { dayjs } from 'element-plus'
|
|
4
|
+
|
|
5
|
+
import { getPositionX } from '../helpers'
|
|
6
|
+
import { useEpgStore } from '../store'
|
|
7
|
+
|
|
8
|
+
defineProps<{
|
|
9
|
+
height: number
|
|
10
|
+
}>()
|
|
11
|
+
|
|
12
|
+
const { theme, startDate, endDate, hourWidth, sidebarWidth, isSidebar, timezoneOffset } = useEpgStore()
|
|
13
|
+
|
|
14
|
+
function getX() {
|
|
15
|
+
return getPositionX(
|
|
16
|
+
startOfDay(new Date(startDate.value)),
|
|
17
|
+
dayjs(new Date()).toDate(),
|
|
18
|
+
startDate.value,
|
|
19
|
+
endDate.value,
|
|
20
|
+
hourWidth.value,
|
|
21
|
+
) + (isSidebar.value
|
|
22
|
+
? sidebarWidth.value
|
|
23
|
+
: 0)
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
const positionX = ref(getX())
|
|
27
|
+
|
|
28
|
+
useIntervalFn(() => {
|
|
29
|
+
positionX.value = getX()
|
|
30
|
+
}, 2000)
|
|
31
|
+
</script>
|
|
32
|
+
|
|
33
|
+
<template>
|
|
34
|
+
<div
|
|
35
|
+
v-if="isToday(new Date(startDate))" class="absolute z-1000 w-2px" :style="{
|
|
36
|
+
height: `${height + 40}px`,
|
|
37
|
+
left: `${positionX}px`,
|
|
38
|
+
background: `${theme.green['300']}`,
|
|
39
|
+
}"
|
|
40
|
+
/>
|
|
41
|
+
</template>
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
<script lang="ts" setup>
|
|
2
|
+
import { useEpgStore } from '../store'
|
|
3
|
+
|
|
4
|
+
const { theme } = useEpgStore()
|
|
5
|
+
</script>
|
|
6
|
+
|
|
7
|
+
<template>
|
|
8
|
+
<div
|
|
9
|
+
class="absolute inset-0 z-1000 flex items-center justify-center" :style="{
|
|
10
|
+
background: `${theme.loader.bg}`,
|
|
11
|
+
color: `${theme.white}`,
|
|
12
|
+
}"
|
|
13
|
+
>
|
|
14
|
+
<svg class="mr-3 h-5 w-5 animate-spin" xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24">
|
|
15
|
+
<circle class="opacity-25" cx="12" cy="12" r="10" stroke="currentColor" stroke-width="4" />
|
|
16
|
+
<path
|
|
17
|
+
class="opacity-75" fill="currentColor"
|
|
18
|
+
d="M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z"
|
|
19
|
+
/>
|
|
20
|
+
</svg>
|
|
21
|
+
Loading...
|
|
22
|
+
</div>
|
|
23
|
+
</template>
|
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
<script lang="ts" setup>
|
|
2
|
+
import type { ProgramItem } from '../helpers/types'
|
|
3
|
+
import { useProgram } from '../hooks'
|
|
4
|
+
import type { Program as ProgramType } from '../helpers/interfaces'
|
|
5
|
+
import { useEpgStore } from '../store'
|
|
6
|
+
|
|
7
|
+
const props = defineProps<{
|
|
8
|
+
program: ProgramItem
|
|
9
|
+
}>()
|
|
10
|
+
|
|
11
|
+
const emit = defineEmits<
|
|
12
|
+
(event: 'click', v: ProgramType) => void
|
|
13
|
+
>()
|
|
14
|
+
const { theme, isBaseTimeFormat } = useEpgStore()
|
|
15
|
+
|
|
16
|
+
const data = computed(() => props.program.data)
|
|
17
|
+
const program = useProgram({
|
|
18
|
+
program: toRef(props, 'program'),
|
|
19
|
+
isBaseTimeFormat,
|
|
20
|
+
})
|
|
21
|
+
|
|
22
|
+
const { styles, format12HoursTime, isLive, isMinWidth } = program
|
|
23
|
+
</script>
|
|
24
|
+
|
|
25
|
+
<template>
|
|
26
|
+
<div
|
|
27
|
+
data-testid="program-item" class="absolute overflow-hidden" :style="{
|
|
28
|
+
...styles.position,
|
|
29
|
+
paddingRight: `${styles.width === 0 ? 0 : 2}px`,
|
|
30
|
+
}" @click="emit('click', data)"
|
|
31
|
+
>
|
|
32
|
+
<slot name="program" v-bind="{ ...program, theme }" :data="data">
|
|
33
|
+
<div
|
|
34
|
+
data-testid="program-content"
|
|
35
|
+
class="program-item relative z-1 h-full flex cursor-pointer overflow-hidden rounded-8px text-11px transition-all duration-400 ease-in-out"
|
|
36
|
+
:style="{
|
|
37
|
+
padding: `10px ${styles.width < 30 ? 4 : 20}px`,
|
|
38
|
+
}" :class="{
|
|
39
|
+
'is-live': isLive,
|
|
40
|
+
}"
|
|
41
|
+
>
|
|
42
|
+
<div class="w-full flex justify-start">
|
|
43
|
+
<img v-if="isLive && isMinWidth" class="mr-15px w-100px rounded-6px" :src="data.image" alt="Preview">
|
|
44
|
+
<div class="overflow-hidden">
|
|
45
|
+
<div
|
|
46
|
+
class="mb-5px mt-0 truncate text-left text-14px font-medium" :style="{
|
|
47
|
+
color: `${theme.grey['300']}`,
|
|
48
|
+
}"
|
|
49
|
+
>
|
|
50
|
+
{{ data.title }}
|
|
51
|
+
</div>
|
|
52
|
+
<div
|
|
53
|
+
class="block truncate text-left text-12.5px font-normal" :style="{
|
|
54
|
+
color: `${theme.text.grey['500']}`,
|
|
55
|
+
}" aria-label="program time"
|
|
56
|
+
>
|
|
57
|
+
{{ format12HoursTime(data.since) }} -{{ " " }}
|
|
58
|
+
{{ format12HoursTime(data.till) }}
|
|
59
|
+
</div>
|
|
60
|
+
</div>
|
|
61
|
+
</div>
|
|
62
|
+
</div>
|
|
63
|
+
</slot>
|
|
64
|
+
</div>
|
|
65
|
+
</template>
|
|
66
|
+
|
|
67
|
+
<style>
|
|
68
|
+
.program-item {
|
|
69
|
+
background-image: linear-gradient(
|
|
70
|
+
to right,
|
|
71
|
+
v-bind('theme.primary[600]'),
|
|
72
|
+
v-bind('theme.primary[600]')
|
|
73
|
+
);
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
.program-item:hover {
|
|
77
|
+
background-image: linear-gradient(
|
|
78
|
+
to right,
|
|
79
|
+
v-bind('theme.gradient.blue[900]'),
|
|
80
|
+
v-bind('theme.gradient.blue[600]')
|
|
81
|
+
);
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
.program-item.is-live {
|
|
85
|
+
background-image: linear-gradient(
|
|
86
|
+
to right,
|
|
87
|
+
v-bind('theme.gradient.blue[900]'),
|
|
88
|
+
v-bind('theme.gradient.blue[600]'),
|
|
89
|
+
v-bind('theme.gradient.blue[300]')
|
|
90
|
+
);
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
.program-item.is-hide {
|
|
94
|
+
background-image: linear-gradient(
|
|
95
|
+
to right,
|
|
96
|
+
v-bind('theme.timeline.divider.bg'),
|
|
97
|
+
v-bind('theme.timeline.divider.bg')
|
|
98
|
+
);
|
|
99
|
+
opacity: 0.4;
|
|
100
|
+
}
|
|
101
|
+
</style>
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
<script lang="ts" setup>
|
|
2
|
+
import { TIMELINE_HEIGHT } from '../helpers'
|
|
3
|
+
import { useEpgStore } from '../store'
|
|
4
|
+
|
|
5
|
+
const { theme, sidebarWidth } = useEpgStore()
|
|
6
|
+
</script>
|
|
7
|
+
|
|
8
|
+
<template>
|
|
9
|
+
<div
|
|
10
|
+
class="absolute left-0 top-0 z-900" :style="{
|
|
11
|
+
width: `${sidebarWidth}px`,
|
|
12
|
+
height: `${TIMELINE_HEIGHT}px`,
|
|
13
|
+
background: `${theme.primary[900]}`,
|
|
14
|
+
}"
|
|
15
|
+
>
|
|
16
|
+
<div />
|
|
17
|
+
</div>
|
|
18
|
+
</template>
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
<script lang="ts" setup>
|
|
2
|
+
import { ITEM_HEIGHT } from '../helpers'
|
|
3
|
+
import { useTimeline } from '../hooks'
|
|
4
|
+
import { useEpgStore } from '../store'
|
|
5
|
+
|
|
6
|
+
const {
|
|
7
|
+
theme, divideBy, numberOfHoursInDay, isBaseTimeFormat, offsetStartHoursRange,
|
|
8
|
+
sidebarWidth, hourWidth, dayWidth, isSidebar,
|
|
9
|
+
} = useEpgStore()
|
|
10
|
+
|
|
11
|
+
const timeline = useTimeline(numberOfHoursInDay, isBaseTimeFormat, divideBy)
|
|
12
|
+
|
|
13
|
+
const { times, dividers, formatTimelineTime } = timeline
|
|
14
|
+
</script>
|
|
15
|
+
|
|
16
|
+
<template>
|
|
17
|
+
<div
|
|
18
|
+
class="sticky top-0 z-100 flex" :style="{
|
|
19
|
+
left: `${isSidebar ? sidebarWidth : 0}px`,
|
|
20
|
+
height: `${TIMELINE_HEIGHT}px`,
|
|
21
|
+
width: `${dayWidth}px`,
|
|
22
|
+
background: `${theme.primary['900']}`,
|
|
23
|
+
}"
|
|
24
|
+
>
|
|
25
|
+
<template v-for="(_, index) in times" :key="index">
|
|
26
|
+
<slot name="timeline" v-bind="{ index, dividers, formatTimelineTime, offsetStartHoursRange, hourWidth, theme }">
|
|
27
|
+
<div class="relative text-14px" :style="{ width: `${hourWidth}px` }">
|
|
28
|
+
<div
|
|
29
|
+
class="absolute top-0 font-bold" :style="{
|
|
30
|
+
color: `${theme.text.grey[300]}`,
|
|
31
|
+
left: `${index === 0 ? 0 : -18}px`,
|
|
32
|
+
}"
|
|
33
|
+
>
|
|
34
|
+
{{ formatTimelineTime(index + offsetStartHoursRange) }}
|
|
35
|
+
</div>
|
|
36
|
+
|
|
37
|
+
<div class="grid grid-cols-4 h-full w-full items-end pb-6px">
|
|
38
|
+
<div
|
|
39
|
+
v-for="(__, i) in dividers" :key="i" :style="{
|
|
40
|
+
background: `${theme.timeline.divider.bg}`,
|
|
41
|
+
height: `10px`,
|
|
42
|
+
width: '2px',
|
|
43
|
+
marginRight: `${hourWidth}px`,
|
|
44
|
+
}"
|
|
45
|
+
/>
|
|
46
|
+
</div>
|
|
47
|
+
</div>
|
|
48
|
+
</slot>
|
|
49
|
+
</template>
|
|
50
|
+
<slot name="timeline-last" v-bind="{ theme, formatTimelineTime, times, offsetStartHoursRange }">
|
|
51
|
+
<div class="relative text-14px">
|
|
52
|
+
<div
|
|
53
|
+
class="absolute top-0 -translate-x-100%" :style="{
|
|
54
|
+
color: `${theme.text.grey[300]}`,
|
|
55
|
+
left: `${0}px`,
|
|
56
|
+
}"
|
|
57
|
+
>
|
|
58
|
+
{{ formatTimelineTime(times.length + offsetStartHoursRange) }}
|
|
59
|
+
</div>
|
|
60
|
+
<div class="grid grid-cols-4 h-full w-full items-end pb-0px">
|
|
61
|
+
<div
|
|
62
|
+
:style="{
|
|
63
|
+
background: `${theme.timeline.divider.bg}`,
|
|
64
|
+
height: `10px`,
|
|
65
|
+
width: `1px`,
|
|
66
|
+
}"
|
|
67
|
+
/>
|
|
68
|
+
</div>
|
|
69
|
+
</div>
|
|
70
|
+
</slot>
|
|
71
|
+
</div>
|
|
72
|
+
</template>
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import { differenceInHours, startOfDay } from 'date-fns'
|
|
2
|
+
import { HOURS_IN_DAY } from './variables'
|
|
3
|
+
|
|
4
|
+
type DateTime = string | number | Date
|
|
5
|
+
|
|
6
|
+
interface OmitObjectType { [key: string]: any }
|
|
7
|
+
export function omit(obj: OmitObjectType, ...props: string[]) {
|
|
8
|
+
const result = { ...obj }
|
|
9
|
+
|
|
10
|
+
for (const property of props)
|
|
11
|
+
delete result[property]
|
|
12
|
+
|
|
13
|
+
return result
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
export const generateArray = (num: number) => new Array(num).fill('')
|
|
17
|
+
|
|
18
|
+
interface ProgramOptions {
|
|
19
|
+
position: { width: number; height: number; top: number; left: number }
|
|
20
|
+
}
|
|
21
|
+
export function getProgramOptions<T extends ProgramOptions>(program: T) {
|
|
22
|
+
const { width, height, top, left } = program.position
|
|
23
|
+
return {
|
|
24
|
+
...program,
|
|
25
|
+
position: { width, height, top, left },
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
export const getHourWidth = (dayWidth: number) => dayWidth / HOURS_IN_DAY
|
|
30
|
+
|
|
31
|
+
export const getDate = (date: DateTime) => new Date(date)
|
|
32
|
+
|
|
33
|
+
const abs = (num: number) => Math.abs(num)
|
|
34
|
+
interface DayWidth {
|
|
35
|
+
dayWidth: number
|
|
36
|
+
startDate: DateTime
|
|
37
|
+
endDate: DateTime
|
|
38
|
+
}
|
|
39
|
+
export function getDayWidthResources({
|
|
40
|
+
dayWidth,
|
|
41
|
+
startDate,
|
|
42
|
+
endDate,
|
|
43
|
+
}: DayWidth) {
|
|
44
|
+
const startDateTime = getDate(startDate)
|
|
45
|
+
const endDateTime = getDate(endDate)
|
|
46
|
+
|
|
47
|
+
if (endDateTime < startDateTime) {
|
|
48
|
+
console.error(
|
|
49
|
+
`Invalid endDate property. Value of endDate must be greater than startDate. Props: startDateTime: ${startDateTime}, endDateTime: ${endDateTime}`,
|
|
50
|
+
)
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
const offsetStartHoursRange = differenceInHours(
|
|
54
|
+
startDateTime,
|
|
55
|
+
startOfDay(startDateTime),
|
|
56
|
+
)
|
|
57
|
+
|
|
58
|
+
const numberOfHoursInDay = differenceInHours(endDateTime, startDateTime)
|
|
59
|
+
const hourWidth = Math.floor(dayWidth / numberOfHoursInDay)
|
|
60
|
+
const newDayWidth = hourWidth * numberOfHoursInDay
|
|
61
|
+
|
|
62
|
+
return {
|
|
63
|
+
hourWidth: abs(hourWidth),
|
|
64
|
+
dayWidth: abs(newDayWidth),
|
|
65
|
+
numberOfHoursInDay: abs(numberOfHoursInDay),
|
|
66
|
+
offsetStartHoursRange: abs(offsetStartHoursRange),
|
|
67
|
+
}
|
|
68
|
+
}
|
|
@@ -0,0 +1,192 @@
|
|
|
1
|
+
import { differenceInSeconds, getTime } from 'date-fns'
|
|
2
|
+
import type { Channel, Program } from './interfaces'
|
|
3
|
+
import type { DateTime, Position, ProgramWithPosition } from './types'
|
|
4
|
+
import { HOUR_IN_MINUTES } from './variables'
|
|
5
|
+
import {
|
|
6
|
+
formatTime,
|
|
7
|
+
isYesterday as isYesterdayTime,
|
|
8
|
+
} from './time'
|
|
9
|
+
import { getDate } from './common'
|
|
10
|
+
|
|
11
|
+
function getItemDiffWidth(diff: number, hourWidth: number) {
|
|
12
|
+
return (diff * hourWidth) / (HOUR_IN_MINUTES * 60)
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
export function getPositionX(since: DateTime,
|
|
16
|
+
till: DateTime,
|
|
17
|
+
startDate: DateTime,
|
|
18
|
+
endDate: DateTime,
|
|
19
|
+
hourWidth: number) {
|
|
20
|
+
const isTomorrow = getTime(getDate(till)) > getTime(getDate(endDate))
|
|
21
|
+
const isYesterday = getTime(getDate(since)) < getTime(getDate(startDate))
|
|
22
|
+
|
|
23
|
+
// When time range is set to 1 hour and program time is greater than 1 hour
|
|
24
|
+
if (isYesterday && isTomorrow) {
|
|
25
|
+
const diffTime = differenceInSeconds(
|
|
26
|
+
getDate(endDate),
|
|
27
|
+
getDate(startDate),
|
|
28
|
+
)
|
|
29
|
+
return getItemDiffWidth(diffTime, hourWidth)
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
if (isYesterday) {
|
|
33
|
+
const diffTime = differenceInSeconds(
|
|
34
|
+
getDate(till),
|
|
35
|
+
getDate(startDate),
|
|
36
|
+
)
|
|
37
|
+
return getItemDiffWidth(diffTime, hourWidth)
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
if (isTomorrow) {
|
|
41
|
+
const diffTime = differenceInSeconds(
|
|
42
|
+
getDate(endDate),
|
|
43
|
+
getDate(since),
|
|
44
|
+
)
|
|
45
|
+
|
|
46
|
+
if (diffTime < 0)
|
|
47
|
+
return 0
|
|
48
|
+
return getItemDiffWidth(diffTime, hourWidth)
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
const diffTime = differenceInSeconds(
|
|
52
|
+
getDate(till),
|
|
53
|
+
getDate(since),
|
|
54
|
+
)
|
|
55
|
+
|
|
56
|
+
return getItemDiffWidth(diffTime, hourWidth)
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
// -------- Channel position in the Epg --------
|
|
60
|
+
export function getChannelPosition(channelIndex: number,
|
|
61
|
+
itemHeight: number) {
|
|
62
|
+
const top = itemHeight * channelIndex
|
|
63
|
+
const position = {
|
|
64
|
+
top,
|
|
65
|
+
height: itemHeight,
|
|
66
|
+
}
|
|
67
|
+
return position
|
|
68
|
+
}
|
|
69
|
+
// -------- Program position in the Epg --------
|
|
70
|
+
export function getProgramPosition(program: Program,
|
|
71
|
+
channelIndex: number,
|
|
72
|
+
itemHeight: number,
|
|
73
|
+
hourWidth: number,
|
|
74
|
+
startDate: DateTime,
|
|
75
|
+
endDate: DateTime) {
|
|
76
|
+
const item = {
|
|
77
|
+
...program,
|
|
78
|
+
since: formatTime(program.since),
|
|
79
|
+
till: formatTime(program.till),
|
|
80
|
+
}
|
|
81
|
+
const isYesterday = isYesterdayTime(item.since, startDate)
|
|
82
|
+
|
|
83
|
+
let width = getPositionX(
|
|
84
|
+
item.since,
|
|
85
|
+
item.till,
|
|
86
|
+
startDate,
|
|
87
|
+
endDate,
|
|
88
|
+
hourWidth,
|
|
89
|
+
)
|
|
90
|
+
const top = itemHeight * channelIndex
|
|
91
|
+
let left = getPositionX(startDate, item.since, startDate, endDate, hourWidth)
|
|
92
|
+
const edgeEnd = getPositionX(
|
|
93
|
+
startDate,
|
|
94
|
+
item.till,
|
|
95
|
+
startDate,
|
|
96
|
+
endDate,
|
|
97
|
+
hourWidth,
|
|
98
|
+
)
|
|
99
|
+
|
|
100
|
+
if (isYesterday)
|
|
101
|
+
left = 0
|
|
102
|
+
// If item has negative top position, it means that it is not visible in this day
|
|
103
|
+
if (top < 0)
|
|
104
|
+
width = 0
|
|
105
|
+
|
|
106
|
+
const position = {
|
|
107
|
+
width,
|
|
108
|
+
height: itemHeight,
|
|
109
|
+
top,
|
|
110
|
+
left,
|
|
111
|
+
edgeEnd,
|
|
112
|
+
}
|
|
113
|
+
return { position, data: item }
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
// -------- Converted programs with position data --------
|
|
117
|
+
interface ConvertedPrograms {
|
|
118
|
+
data: Program[]
|
|
119
|
+
channels: Channel[]
|
|
120
|
+
startDate: DateTime
|
|
121
|
+
endDate: DateTime
|
|
122
|
+
itemHeight: number
|
|
123
|
+
hourWidth: number
|
|
124
|
+
}
|
|
125
|
+
export function getConvertedPrograms({
|
|
126
|
+
data,
|
|
127
|
+
channels,
|
|
128
|
+
startDate,
|
|
129
|
+
endDate,
|
|
130
|
+
itemHeight,
|
|
131
|
+
hourWidth,
|
|
132
|
+
}: ConvertedPrograms) {
|
|
133
|
+
return data.map((next) => {
|
|
134
|
+
const channelIndex = channels.findIndex(
|
|
135
|
+
({ uuid }) => uuid === next.channelUuid,
|
|
136
|
+
)
|
|
137
|
+
return getProgramPosition(
|
|
138
|
+
next,
|
|
139
|
+
channelIndex,
|
|
140
|
+
itemHeight,
|
|
141
|
+
hourWidth,
|
|
142
|
+
startDate,
|
|
143
|
+
endDate,
|
|
144
|
+
)
|
|
145
|
+
}, [] as ProgramWithPosition[])
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
// -------- Converted channels with position data --------
|
|
149
|
+
export function getConvertedChannels(channels: Channel[], itemHeight: number) {
|
|
150
|
+
return channels.map((channel, index) => ({
|
|
151
|
+
...channel,
|
|
152
|
+
position: getChannelPosition(index, itemHeight),
|
|
153
|
+
}))
|
|
154
|
+
}
|
|
155
|
+
|
|
156
|
+
// -------- Dynamic virtual program visibility in the EPG --------
|
|
157
|
+
export function getItemVisibility(position: Position,
|
|
158
|
+
scrollY: number,
|
|
159
|
+
scrollX: number,
|
|
160
|
+
containerHeight: number,
|
|
161
|
+
containerWidth: number,
|
|
162
|
+
itemOverscan: number) {
|
|
163
|
+
if (position.width <= 0)
|
|
164
|
+
return false
|
|
165
|
+
|
|
166
|
+
if (scrollY > position.top + itemOverscan * 3)
|
|
167
|
+
return false
|
|
168
|
+
|
|
169
|
+
if (scrollY + containerHeight <= position.top)
|
|
170
|
+
return false
|
|
171
|
+
|
|
172
|
+
if (
|
|
173
|
+
scrollX + containerWidth >= position.left
|
|
174
|
+
// && scrollX <= position.edgeEnd
|
|
175
|
+
)
|
|
176
|
+
return true
|
|
177
|
+
|
|
178
|
+
return false
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
export function getSidebarItemVisibility(position: Pick<Position, 'top'>,
|
|
182
|
+
scrollY: number,
|
|
183
|
+
containerHeight: number,
|
|
184
|
+
itemOverscan: number) {
|
|
185
|
+
if (scrollY > position.top + itemOverscan * 3)
|
|
186
|
+
return false
|
|
187
|
+
|
|
188
|
+
if (scrollY + containerHeight <= position.top)
|
|
189
|
+
return false
|
|
190
|
+
|
|
191
|
+
return true
|
|
192
|
+
}
|