From def31b38e6468c0069d82c35857935670b1c3078 Mon Sep 17 00:00:00 2001 From: Andrea Stagi Date: Thu, 28 Nov 2024 23:15:17 +0100 Subject: [PATCH 1/3] chore: scaffolding for video --- src/Video/Video.tsx | 48 ++++++++++++++++++++++++++++ src/index.ts | 2 ++ stories/Components/Video.stories.tsx | 30 +++++++++++++++++ stories/Documentation/Video.mdx | 22 +++++++++++++ 4 files changed, 102 insertions(+) create mode 100644 src/Video/Video.tsx create mode 100644 stories/Components/Video.stories.tsx create mode 100644 stories/Documentation/Video.mdx diff --git a/src/Video/Video.tsx b/src/Video/Video.tsx new file mode 100644 index 000000000..fc2d59ad2 --- /dev/null +++ b/src/Video/Video.tsx @@ -0,0 +1,48 @@ +import React, { ElementType, FC, ReactNode, useEffect } from 'react'; + +import { CSSModule } from 'reactstrap/types/lib/utils'; +import { InputProps } from '../Input/Input'; + +import { VideoPlayer } from 'bootstrap-italia' + +export interface VideoProps extends InputProps { + /** Label da mostrare per il componente */ + label: string | ReactNode; + /** Dimensioni ammissibili per il componente */ + bsSize?: 'lg' | 'sm'; + /** Utilizzarlo in caso di utilizzo di componenti personalizzati */ + tag?: ElementType; + /** Da utilizzare per impostare un riferimento all'elemento DOM */ + innerRef?: React.Ref; + /** Oggetto contenente la nuova mappatura per le classi CSS. */ + cssModule?: CSSModule; + testId?: string; +} + +export const Video: FC = ({ label, testId }) => { + useEffect(() => { + new VideoPlayer(document.querySelector('video')); + }); + return ( +
+ +
+
+

+ +

+
+
+ {label} +
+
+
+
+
+ ); +}; diff --git a/src/index.ts b/src/index.ts index 196137072..cc7ea5d98 100644 --- a/src/index.ts +++ b/src/index.ts @@ -143,6 +143,7 @@ export { Toggle } from './Toggle/Toggle'; export { Toolbar } from './Toolbar/Toolbar'; export { ToolbarDividerItem } from './Toolbar/ToolbarDividerItem'; export { ToolbarItem } from './Toolbar/ToolbarItem'; +export { Video } from './Video/Video' // Types export type { AccordionProps } from './Accordion/Accordion'; @@ -248,6 +249,7 @@ export type { TimelineProps } from './Timeline/TimelineWrapper'; export type { ToggleProps } from './Toggle/Toggle'; export type { ToolbarProps } from './Toolbar/Toolbar'; export type { ToolbarItemBadge, ToolbarItemProps } from './Toolbar/ToolbarItem'; +export type { VideoProps } from "./Video/Video" export type { BreadcrumbItemProps, diff --git a/stories/Components/Video.stories.tsx b/stories/Components/Video.stories.tsx new file mode 100644 index 000000000..7d3746dff --- /dev/null +++ b/stories/Components/Video.stories.tsx @@ -0,0 +1,30 @@ +import type { Meta, StoryObj } from '@storybook/react'; +import React from 'react'; +import { Video } from '../../src'; + +const meta: Meta = { + title: 'Documentazione/Componenti/Video', + component: Video, + parameters: { + docs: { + canvas: { sourceState: 'none' } + } + } +}; + +export default meta; + +type Story = StoryObj; + +const EsempiVideo = () => { + return ( +
+ +
+ ); +}; + +export const Esempi: Story = { + render: () => +}; + diff --git a/stories/Documentation/Video.mdx b/stories/Documentation/Video.mdx new file mode 100644 index 000000000..fdcc582d9 --- /dev/null +++ b/stories/Documentation/Video.mdx @@ -0,0 +1,22 @@ +import { Canvas, Controls, Meta, Story } from '@storybook/blocks'; +import { Code } from '@storybook/components'; +import { Callout, CalloutText, CalloutTitle } from '../../src'; +import * as VideoStories from '../Components/Video.stories'; + + + +# VIDEO + + + +#### Source + +```tsx + +``` + + + +## More + +Fare riferimento alla [documentazione Bootstrap per il video](https://italia.github.io/bootstrap-italia/docs/componenti/video-player/) From 12983cd9e39dbd09522df2933c42f71bfc9a10b0 Mon Sep 17 00:00:00 2001 From: Andrea Stagi Date: Thu, 28 Nov 2024 23:44:14 +0100 Subject: [PATCH 2/3] fix: check elements before video instantiation --- src/Video/Video.tsx | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/src/Video/Video.tsx b/src/Video/Video.tsx index fc2d59ad2..4f52e7808 100644 --- a/src/Video/Video.tsx +++ b/src/Video/Video.tsx @@ -21,7 +21,10 @@ export interface VideoProps extends InputProps { export const Video: FC = ({ label, testId }) => { useEffect(() => { - new VideoPlayer(document.querySelector('video')); + const el = document.querySelector('video'); + if (el) { + new VideoPlayer(el); + } }); return (
From a7455f579acce0b9514d3d100bd86160cb343d77 Mon Sep 17 00:00:00 2001 From: Andrea Stagi Date: Fri, 29 Nov 2024 00:19:58 +0100 Subject: [PATCH 3/3] fix: use correct types --- src/Video/Video.tsx | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/src/Video/Video.tsx b/src/Video/Video.tsx index 4f52e7808..c8102a77c 100644 --- a/src/Video/Video.tsx +++ b/src/Video/Video.tsx @@ -20,10 +20,14 @@ export interface VideoProps extends InputProps { } export const Video: FC = ({ label, testId }) => { + let vpInstance:VideoPlayer; useEffect(() => { const el = document.querySelector('video'); if (el) { - new VideoPlayer(el); + vpInstance = new VideoPlayer(el); + setTimeout(() => { + console.log(vpInstance.player.log) // Con .player puoi usare play(), stop() ecc .. + }, 3000); } }); return (