From 1bc9937c846a52ae20ba127d5f716aedcd6fdb1b Mon Sep 17 00:00:00 2001 From: ALC Consulting Date: Mon, 3 Apr 2023 13:54:01 +0200 Subject: [PATCH] =?UTF-8?q?=E2=9C=A8(website)=20creates=20lives=20on=20the?= =?UTF-8?q?=20website?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Give the possibility to create a live from the website. --- CHANGELOG.md | 1 + .../ContentsRouter/ContentsRouter.spec.tsx | 8 + .../components/Create/LiveCreate.spec.tsx | 29 +++ .../Live/components/Create/LiveCreate.tsx | 80 ++++++ .../components/Create/LiveCreateForm.spec.tsx | 229 ++++++++++++++++++ .../Live/components/Create/LiveCreateForm.tsx | 159 ++++++++++++ .../Live/components/LiveRouter.spec.tsx | 21 ++ .../features/Live/components/LiveRouter.tsx | 11 + .../standalone_site/src/routes/routes.tsx | 15 +- .../lib_video/src/api/initiateLive/index.ts | 9 +- 10 files changed, 547 insertions(+), 15 deletions(-) create mode 100644 src/frontend/apps/standalone_site/src/features/Contents/features/Live/components/Create/LiveCreate.spec.tsx create mode 100644 src/frontend/apps/standalone_site/src/features/Contents/features/Live/components/Create/LiveCreate.tsx create mode 100644 src/frontend/apps/standalone_site/src/features/Contents/features/Live/components/Create/LiveCreateForm.spec.tsx create mode 100644 src/frontend/apps/standalone_site/src/features/Contents/features/Live/components/Create/LiveCreateForm.tsx diff --git a/CHANGELOG.md b/CHANGELOG.md index eda42b5ac3..1e75a54a60 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -16,6 +16,7 @@ Versioning](https://semver.org/spec/v2.0.0.html). - Live session model - Livesession backend rewrite - Add sentry + - Create a live from the website (#2134) - Add a License Manager widget for LTI VOD view - Add a title to the classroom file dropzone - Add can_edit property on a serialized video diff --git a/src/frontend/apps/standalone_site/src/features/Contents/components/ContentsRouter/ContentsRouter.spec.tsx b/src/frontend/apps/standalone_site/src/features/Contents/components/ContentsRouter/ContentsRouter.spec.tsx index 6fd0865328..0c1921a693 100644 --- a/src/frontend/apps/standalone_site/src/features/Contents/components/ContentsRouter/ContentsRouter.spec.tsx +++ b/src/frontend/apps/standalone_site/src/features/Contents/components/ContentsRouter/ContentsRouter.spec.tsx @@ -11,6 +11,7 @@ jest.mock('../Contents/Contents', () => ({ jest.mock('features/Contents', () => ({ ClassRoomRouter: () =>
My ClassRoomRouter
, VideoRouter: () =>
My VideoRouter
, + LiveRouter: () =>
My LiveRouter
, })); describe('', () => { @@ -38,4 +39,11 @@ describe('', () => { }); expect(screen.getByText('My VideoRouter')).toBeInTheDocument(); }); + + test('render route /my-contents/lives', () => { + render(, { + routerOptions: { history: ['/my-contents/lives'] }, + }); + expect(screen.getByText('My LiveRouter')).toBeInTheDocument(); + }); }); diff --git a/src/frontend/apps/standalone_site/src/features/Contents/features/Live/components/Create/LiveCreate.spec.tsx b/src/frontend/apps/standalone_site/src/features/Contents/features/Live/components/Create/LiveCreate.spec.tsx new file mode 100644 index 0000000000..a98b08d69e --- /dev/null +++ b/src/frontend/apps/standalone_site/src/features/Contents/features/Live/components/Create/LiveCreate.spec.tsx @@ -0,0 +1,29 @@ +import { screen } from '@testing-library/react'; +import userEvent from '@testing-library/user-event'; +import { render } from 'lib-tests'; + +import LiveCreate from './LiveCreate'; + +jest.mock('./LiveCreateForm', () => ({ + __esModule: true, + default: () =>
My WebinarCreate Form
, +})); + +describe('', () => { + test('renders LiveCreate', () => { + render(); + + const button = screen.getByRole('button', { name: /Create Webinar/i }); + expect(button).toBeInTheDocument(); + expect( + screen.queryByRole('heading', { name: /Create Webinar/i }), + ).not.toBeInTheDocument(); + + userEvent.click(button); + + expect( + screen.getByRole('heading', { name: /Create Webinar/i }), + ).toBeInTheDocument(); + expect(screen.getByText('My WebinarCreate Form')).toBeInTheDocument(); + }); +}); diff --git a/src/frontend/apps/standalone_site/src/features/Contents/features/Live/components/Create/LiveCreate.tsx b/src/frontend/apps/standalone_site/src/features/Contents/features/Live/components/Create/LiveCreate.tsx new file mode 100644 index 0000000000..bb484beebc --- /dev/null +++ b/src/frontend/apps/standalone_site/src/features/Contents/features/Live/components/Create/LiveCreate.tsx @@ -0,0 +1,80 @@ +import { Button, Heading, Text } from 'grommet'; +import { useResponsive } from 'lib-components'; +import { Fragment } from 'react'; +import { defineMessages, useIntl } from 'react-intl'; +import { Link, Route, Switch, useHistory } from 'react-router-dom'; + +import { WhiteCard } from 'components/Cards'; +import { Modal } from 'components/Modal'; +import { routes } from 'routes'; + +import LiveCreateForm from './LiveCreateForm'; + +const messages = defineMessages({ + WebinarTitle: { + defaultMessage: 'Webinars', + description: 'Webinars title', + id: 'features.Contents.features.Webinar.Create.WebinarTitle', + }, + CreateWebinarLabel: { + defaultMessage: 'Create Webinar', + description: 'Text heading create webinar.', + id: 'features.Contents.features.Webinar.Create.CreateWebinarLabel', + }, +}); + +const LiveCreate = () => { + const intl = useIntl(); + const { breakpoint } = useResponsive(); + const history = useHistory(); + + const liveRoute = routes.CONTENTS.subRoutes.LIVE; + const livePath = liveRoute.path; + const liveCreatePath = liveRoute.subRoutes?.CREATE?.path || ''; + + return ( + + + + {intl.formatMessage(messages.WebinarTitle)} + + +