feat(invite-dialog) Add limit message for invite dialog

This commit is contained in:
Alexandru Petrus 2022-09-29 17:35:47 +03:00 committed by Horatiu Muresan
parent 3c180d3932
commit 7aefc3b94a
4 changed files with 75 additions and 1 deletions

View File

@ -477,9 +477,11 @@
"noRoom": "No room was specified to dial-in into.", "noRoom": "No room was specified to dial-in into.",
"numbers": "Dial-in Numbers", "numbers": "Dial-in Numbers",
"password": "$t(lockRoomPasswordUppercase): ", "password": "$t(lockRoomPasswordUppercase): ",
"reachedLimit": "you have reached the limit for you plan.",
"sip": "SIP address", "sip": "SIP address",
"title": "Share", "title": "Share",
"tooltip": "Share link and dial-in info for this meeting" "tooltip": "Share link and dial-in info for this meeting",
"upgradeOptions": "Please check the upgrade options on"
}, },
"inlineDialogFailure": { "inlineDialogFailure": {
"msg": "We stumbled a bit.", "msg": "We stumbled a bit.",

View File

@ -24,6 +24,7 @@ import {
} from '../../../functions'; } from '../../../functions';
import CopyMeetingLinkSection from './CopyMeetingLinkSection'; import CopyMeetingLinkSection from './CopyMeetingLinkSection';
import DialInLimit from './DialInLimit';
import DialInSection from './DialInSection'; import DialInSection from './DialInSection';
import InviteByEmailSection from './InviteByEmailSection'; import InviteByEmailSection from './InviteByEmailSection';
import InviteContactsSection from './InviteContactsSection'; import InviteContactsSection from './InviteContactsSection';
@ -84,6 +85,11 @@ type Props = {
*/ */
_inviteUrl: string, _inviteUrl: string,
/**
* Whether or not the current meeting belongs to a JaaS user.
*/
_isVpaasMeeting: boolean,
/** /**
* The current known URL for a live stream in progress. * The current known URL for a live stream in progress.
*/ */
@ -121,6 +127,7 @@ function AddPeopleDialog({
_inviteAppName, _inviteAppName,
_inviteContactsVisible, _inviteContactsVisible,
_inviteUrl, _inviteUrl,
_isVpaasMeeting,
_liveStreamViewURL, _liveStreamViewURL,
_phoneNumber, _phoneNumber,
t, t,
@ -183,6 +190,9 @@ function AddPeopleDialog({
&& _dialInVisible && _dialInVisible
&& <DialInSection phoneNumber = { _phoneNumber } /> && <DialInSection phoneNumber = { _phoneNumber } />
} }
{
!_dialInVisible && _isVpaasMeeting && <DialInLimit />
}
</div> </div>
</Dialog> </Dialog>
); );
@ -222,6 +232,7 @@ function mapStateToProps(state, ownProps) {
_inviteAppName: inviteAppName, _inviteAppName: inviteAppName,
_inviteContactsVisible: interfaceConfig.ENABLE_DIAL_OUT && !hideInviteContacts, _inviteContactsVisible: interfaceConfig.ENABLE_DIAL_OUT && !hideInviteContacts,
_inviteUrl: getInviteURL(state), _inviteUrl: getInviteURL(state),
_isVpaasMeeting: isVpaasMeeting(state),
_liveStreamViewURL: _liveStreamViewURL:
currentLiveStreamingSession currentLiveStreamingSession
&& currentLiveStreamingSession.liveStreamViewURL, && currentLiveStreamingSession.liveStreamViewURL,

View File

@ -0,0 +1,58 @@
/* eslint-disable lines-around-comment */
import { Theme } from '@mui/material';
import React from 'react';
import { WithTranslation } from 'react-i18next';
import { makeStyles } from 'tss-react/mui';
import { translate } from '../../../../base/i18n/functions';
import { withPixelLineHeight } from '../../../../base/styles/functions.web';
import { UPGRADE_OPTIONS_LINK, UPGRADE_OPTIONS_TEXT } from '../../../constants';
const useStyles = makeStyles()((theme: Theme) => {
return {
limitContainer: {
backgroundColor: theme.palette.warning01,
borderRadius: '6px',
padding: '8px 16px'
},
limitInfo: {
color: theme.palette.field01,
...withPixelLineHeight(theme.typography.bodyShortRegular)
},
link: {
color: theme.palette.field01,
fontWeight: 'bold',
textDecoration: 'underline'
}
};
});
/**
* Component that displays a message when the dial in limit is reached.
* * @param {Function} t - Function which translate strings.
*
* @returns {ReactElement}
*/
const DialInLimit: React.FC<WithTranslation> = ({ t }) => {
const { classes } = useStyles();
return (
<div className = { classes.limitContainer }>
<span className = { classes.limitInfo }>
<b>{ `${t('info.dialInNumber')} ` }</b>
{ `${t('info.reachedLimit')} `}
{ `${t('info.upgradeOptions')} ` }
<a
className = { classes.link }
href = { UPGRADE_OPTIONS_LINK }
rel = 'noopener noreferrer'
target = '_blank'>
{ `${UPGRADE_OPTIONS_TEXT}` }
</a>
.
</span>
</div>
);
};
export default translate(DialInLimit);

View File

@ -54,3 +54,6 @@ export const INVITE_TYPES = {
USER: 'user', USER: 'user',
VIDEO_ROOM: 'videosipgw' VIDEO_ROOM: 'videosipgw'
}; };
export const UPGRADE_OPTIONS_TEXT = 'jaas.8x8.vc';
export const UPGRADE_OPTIONS_LINK = 'https://jaas.8x8.vc/#/plan/upgrade';