From 95aed121500ac0cf51f7a6afe303634a8c3b72f2 Mon Sep 17 00:00:00 2001 From: ALC Consulting Date: Mon, 13 Mar 2023 16:17:13 +0100 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 + .../components/Create/LiveCreate.spec.tsx | 29 +++ .../Live/components/Create/LiveCreate.tsx | 80 ++++++ .../components/Create/LiveCreateForm.spec.tsx | 229 ++++++++++++++++++ .../Live/components/Create/LiveCreateForm.tsx | 161 ++++++++++++ .../Live/components/LiveRouter.spec.tsx | 21 ++ .../features/Live/components/LiveRouter.tsx | 11 + .../standalone_site/src/routes/routes.tsx | 10 + .../lib_video/src/api/initiateLive/index.ts | 9 +- 9 files changed, 546 insertions(+), 5 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 336e51c64c..52fadb3b9f 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -13,6 +13,7 @@ Versioning](https://semver.org/spec/v2.0.0.html). - standalone website: - Integrate VOD dashboard (#2086) - List the lives in the contents section (#2104) + - Create a live from the website (#2134) - Add a License Manager widget for LTI VOD view - Add a title to the classroom file dropzone 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..69d3d2e2d0 --- /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 LiveCreate Form
, +})); + +describe('', () => { + test('renders LiveCreate', () => { + render(); + + const button = screen.getByRole('button', { name: /Create Live/i }); + expect(button).toBeInTheDocument(); + expect( + screen.queryByRole('heading', { name: /Create Live/i }), + ).not.toBeInTheDocument(); + + userEvent.click(button); + + expect( + screen.getByRole('heading', { name: /Create Live/i }), + ).toBeInTheDocument(); + expect(screen.getByText('My LiveCreate 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..a34b19dd0d --- /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 { 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 { useResponsive } from 'hooks/useResponsive'; +import { routes } from 'routes'; + +import LiveCreateForm from './LiveCreateForm'; + +const messages = defineMessages({ + LiveTitle: { + defaultMessage: 'Lives', + description: 'Lives title', + id: 'features.Contents.features.Live.Create.LiveTitle', + }, + CreateLiveLabel: { + defaultMessage: 'Create Live', + description: 'Text heading create live.', + id: 'features.Contents.features.Live.Create.CreateLiveLabel', + }, +}); + +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.LiveTitle)} + + +