UNPKG

@selfcommunity/react-ui

Version:

React UI Components to integrate a Community created with SelfCommunity Platform.

51 lines (50 loc) 4.03 kB
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime"; import { Box, Icon, Stack, styled, Tooltip, Typography, useThemeProps } from '@mui/material'; import { Link, SCRoutes, useSCFetchLiveStream, useSCRouting } from '@selfcommunity/react-core'; import { FormattedMessage, useIntl } from 'react-intl'; const PREFIX = 'SCLiveStreamInfoDetails'; const classes = { root: `${PREFIX}-root`, iconTextWrapper: `${PREFIX}-icon-text-wrapper`, inProgress: `${PREFIX}-in-progress`, link: `${PREFIX}-link`, url: `${PREFIX}-url`, creationWrapper: `${PREFIX}-creation-wrapper` }; const Root = styled(Stack, { name: PREFIX, slot: 'Root', overridesResolver: (_props, styles) => styles.root })(() => ({})); export default function LiveStreamInfoDetails(inProps) { // PROPS const props = useThemeProps({ props: inProps, name: PREFIX }); const { liveStream, liveStreamId, hideDateIcon = false, hideLocationIcon = false, hideCreatedIcon = false, hasDateInfo = true, hasLocationInfo = true, hasCreatedInfo = false, hasInProgress = false, beforeDateInfo, beforeLocationInfo, beforeCreatedInfo } = props; // CONTEXT const scRoutingContext = useSCRouting(); // HOOKS const intl = useIntl(); const { scLiveStream } = useSCFetchLiveStream({ id: liveStreamId, liveStream }); if (!scLiveStream) { return null; } return (_jsxs(Root, Object.assign({ className: classes.root }, { children: [beforeDateInfo, hasDateInfo && (_jsxs(Stack, Object.assign({ className: classes.iconTextWrapper }, { children: [!hideDateIcon && _jsx(Icon, Object.assign({ fontSize: "small" }, { children: scLiveStream.closed_at_by_host ? 'calendar_off' : 'CalendarIcon' })), _jsx(Typography, Object.assign({ variant: "body1" }, { children: _jsx(FormattedMessage, { id: "ui.eventInfoDetails.date.startEndTime", defaultMessage: "ui.eventInfoDetails.date.startEndTime", values: { date: intl.formatDate(scLiveStream.created_at, { weekday: 'long', day: 'numeric', year: 'numeric', month: 'long' }), start: intl.formatDate(scLiveStream.created_at, { hour: 'numeric', minute: 'numeric' }) } }) })), hasInProgress && scLiveStream.last_started_at && (_jsx(Tooltip, Object.assign({ title: _jsx(FormattedMessage, { id: "ui.eventInfoDetails.inProgress", defaultMessage: "ui.eventInfoDetails.inProgress" }) }, { children: _jsx(Box, { className: classes.inProgress }) })))] }))), beforeLocationInfo, hasLocationInfo && (_jsxs(Stack, Object.assign({ className: classes.iconTextWrapper }, { children: [!hideLocationIcon && _jsx(Icon, Object.assign({ fontSize: "small" }, { children: "play_circle_outline" })), _jsx(Link, Object.assign({ to: scRoutingContext.url(SCRoutes.LIVESTREAM_ROUTE_NAME, scLiveStream), target: "_blank", className: classes.link }, { children: _jsx(Typography, Object.assign({ variant: "body1", className: classes.url }, { children: scRoutingContext.url(SCRoutes.LIVESTREAM_ROUTE_NAME, scLiveStream) })) }))] }))), beforeCreatedInfo, hasCreatedInfo && (_jsxs(Stack, Object.assign({ className: classes.creationWrapper }, { children: [!hideCreatedIcon && _jsx(Icon, Object.assign({ fontSize: "small" }, { children: "create" })), _jsx(Typography, Object.assign({ variant: "body1" }, { children: _jsx(FormattedMessage, { id: "ui.eventInfoDetails.date.create", defaultMessage: "ui.eventInfoDetails.date.create", values: { date: intl.formatDate(scLiveStream.created_at, { weekday: 'long', day: 'numeric', year: 'numeric', month: 'long' }) } }) }))] })))] }))); }