Skip to content

Commit

Permalink
feat: New tooltips and color behavior for private apps bar (#33243)
Browse files Browse the repository at this point in the history
* feat: New tooltips and behavior for private apps bar

* Create brown-pants-press.md
  • Loading branch information
MartinSchoeler authored and tassoevan committed Oct 1, 2024
1 parent 65beb3f commit ab080c6
Show file tree
Hide file tree
Showing 6 changed files with 38 additions and 7 deletions.
6 changes: 6 additions & 0 deletions .changeset/brown-pants-press.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
---
"@rocket.chat/meteor": major
"@rocket.chat/i18n": major
---

feat: New tooltips to reflect changes in private apps
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ const GenericResourceUsage = ({
threshold = 80,
variant = percentage < threshold ? 'success' : 'danger',
subTitle,
tooltip,
...props
}: {
title: string;
Expand All @@ -19,9 +20,20 @@ const GenericResourceUsage = ({
percentage: number;
threshold?: number;
variant?: 'warning' | 'danger' | 'success';
tooltip?: string;
}) => {
return (
<Box w='x180' h='x40' mi={8} fontScale='c1' display='flex' flexDirection='column' justifyContent='space-around' {...props}>
<Box
title={tooltip}
w='x180'
h='x40'
mi={8}
fontScale='c1'
display='flex'
flexDirection='column'
justifyContent='space-around'
{...props}
>
<Box display='flex' justifyContent='space-between'>
<Box color='default'>{title}</Box>
{subTitle && <Box color='hint'>{subTitle}</Box>}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ const AppsUsageCard = ({ privateAppsLimit, marketplaceAppsLimit }: AppsUsageCard
const marketplaceAppsPercentage = Math.round((marketplaceAppsEnabled / marketplaceAppsLimitCount) * 100);

const privateAppsEnabled = privateAppsLimit?.value || 0;
const privateAppsLimitCount = privateAppsLimit?.max || 3;
const privateAppsLimitCount = privateAppsLimit?.max || 0;
const privateAppsPercentage = Math.round((privateAppsEnabled / privateAppsLimitCount) * 100);

const card: CardProps = {
Expand All @@ -43,6 +43,11 @@ const AppsUsageCard = ({ privateAppsLimit, marketplaceAppsLimit }: AppsUsageCard
}),
};

const privateAppsDisabled = privateAppsLimitCount === 0;
const privateAppsTitle = privateAppsDisabled ? t('Private_apps_premium_message') : undefined;
const privateAppsVariant = privateAppsDisabled || (privateAppsPercentage || 0) >= 80 ? 'danger' : 'success';
const privateAppsFontColor = privateAppsDisabled || (privateAppsPercentage || 0) >= 80 ? 'font-danger' : 'status-font-on-success';

if (!privateAppsLimit || !marketplaceAppsLimit) {
return (
<FeatureUsageCard card={card}>
Expand All @@ -63,15 +68,15 @@ const AppsUsageCard = ({ privateAppsLimit, marketplaceAppsLimit }: AppsUsageCard

<ProgressBar percentage={marketplaceAppsPercentage || 0} variant={(marketplaceAppsPercentage || 0) >= 80 ? 'danger' : 'success'} />
</Box>
<Box fontScale='c1' mb={12}>
<Box fontScale='c1' mb={12} title={privateAppsTitle}>
<Box display='flex' flexGrow='1' justifyContent='space-between' mbe={4}>
<div>{t('Private_apps')}</div>
<Box color={(privateAppsPercentage || 0) >= 80 ? 'font-danger' : 'status-font-on-success'}>
<Box color={privateAppsFontColor}>
{privateAppsEnabled} / {privateAppsLimitCount}
</Box>
</Box>

<ProgressBar percentage={privateAppsPercentage || 0} variant={(privateAppsPercentage || 0) >= 80 ? 'danger' : 'success'} />
<ProgressBar percentage={privateAppsDisabled ? 100 : privateAppsPercentage || 0} variant={privateAppsVariant} />
</Box>
</FeatureUsageCard>
);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,12 +10,14 @@ const EnabledAppsCount = ({
limit,
enabled,
context,
tooltip,
}: {
variant: 'warning' | 'danger' | 'success';
percentage: number;
limit: number;
enabled: number;
context: 'private' | 'explore' | 'installed' | 'premium' | 'requested';
tooltip?: string;
}): ReactElement | null => {
const { t } = useTranslation();

Expand All @@ -27,6 +29,7 @@ const EnabledAppsCount = ({
percentage={percentage}
threshold={80}
variant={variant}
tooltip={tooltip}
/>
);
};
Expand Down
Original file line number Diff line number Diff line change
@@ -1,14 +1,15 @@
import { useEndpoint } from '@rocket.chat/ui-contexts';
import { useQueryClient, useQuery } from '@tanstack/react-query';
import { useCallback } from 'react';
import { useTranslation } from 'react-i18next';

type Variant = 'success' | 'warning' | 'danger';

const getProgressBarValues = (numberOfEnabledApps: number, enabledAppsLimit: number): { variant: Variant; percentage: number } => ({
variant: 'success',
...(numberOfEnabledApps + 1 === enabledAppsLimit && { variant: 'warning' }),
...(numberOfEnabledApps >= enabledAppsLimit && { variant: 'danger' }),
percentage: Math.round((numberOfEnabledApps / enabledAppsLimit) * 100),
...((enabledAppsLimit === 0 || numberOfEnabledApps >= enabledAppsLimit) && { variant: 'danger' }),
percentage: Math.round(enabledAppsLimit === 0 ? 100 : (numberOfEnabledApps / enabledAppsLimit) * 100),
});

export type MarketplaceRouteContext = 'private' | 'explore' | 'installed' | 'premium' | 'requested' | 'details';
Expand All @@ -19,6 +20,7 @@ export function isMarketplaceRouteContext(context: string): context is Marketpla

export const useAppsCountQuery = (context: MarketplaceRouteContext) => {
const getAppsCount = useEndpoint('GET', '/apps/count');
const { t } = useTranslation();

return useQuery(
['apps/count', context],
Expand All @@ -28,10 +30,12 @@ export const useAppsCountQuery = (context: MarketplaceRouteContext) => {
const numberOfEnabledApps = context === 'private' ? data.totalPrivateEnabled : data.totalMarketplaceEnabled;
const enabledAppsLimit = context === 'private' ? data.maxPrivateApps : data.maxMarketplaceApps;
const hasUnlimitedApps = enabledAppsLimit === -1;
const tooltip = context === 'private' && enabledAppsLimit === 0 ? t('Private_apps_premium_message') : undefined;
return {
hasUnlimitedApps,
enabled: numberOfEnabledApps,
limit: enabledAppsLimit,
tooltip,
...getProgressBarValues(numberOfEnabledApps, enabledAppsLimit),
};
},
Expand Down
1 change: 1 addition & 0 deletions packages/i18n/src/locales/en.i18n.json
Original file line number Diff line number Diff line change
Expand Up @@ -560,6 +560,7 @@
"Apps_Count_Enabled_other": "{{count}} apps enabled",
"Private_Apps_Count_Enabled_one": "{{count}} private app enabled",
"Private_Apps_Count_Enabled_other": "{{count}} private apps enabled",
"Private_apps_premium_message": "Private apps can only be enabled in premium plans",
"Private_apps_upgrade_empty_state_title": "Upgrade to unlock private apps",
"Private_apps_upgrade_empty_state_description": "Tailor Rocket.Chat according to your needs with private apps.",
"Apps_Count_Enabled_tooltip": "Community workspaces can enable up to {{number}} {{context}} apps",
Expand Down

0 comments on commit ab080c6

Please sign in to comment.