@selfcommunity/react-ui
Version:
React UI Components to integrate a Community created with SelfCommunity Platform.
51 lines (50 loc) • 4.03 kB
JavaScript
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'
})
} }) }))] })))] })));
}