@selfcommunity/react-ui 0.9.1 → 0.10.0-alpha.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/cjs/components/CategoryFollowersButton/CategoryFollowersButton.d.ts +2 -2
- package/lib/cjs/components/CategoryFollowersButton/CategoryFollowersButton.js +14 -12
- package/lib/cjs/components/CreateEventButton/CreateEventButton.d.ts +1 -1
- package/lib/cjs/components/CreateEventButton/CreateEventButton.js +1 -1
- package/lib/cjs/components/EventParticipantsButton/EventParticipantsButton.js +5 -3
- package/lib/cjs/components/Events/Events.js +9 -29
- package/lib/cjs/components/Events/PastEventsFilter.js +2 -12
- package/lib/cjs/components/GroupMembersButton/GroupMembersButton.d.ts +2 -2
- package/lib/cjs/components/GroupMembersButton/GroupMembersButton.js +16 -14
- package/lib/cjs/components/SuggestedEventsWidget/Arrow.js +2 -1
- package/lib/cjs/utils/buttonCounters.d.ts +1 -0
- package/lib/cjs/utils/buttonCounters.js +15 -0
- package/lib/esm/components/CategoryFollowersButton/CategoryFollowersButton.d.ts +2 -2
- package/lib/esm/components/CategoryFollowersButton/CategoryFollowersButton.js +14 -12
- package/lib/esm/components/CreateEventButton/CreateEventButton.d.ts +1 -1
- package/lib/esm/components/CreateEventButton/CreateEventButton.js +1 -1
- package/lib/esm/components/EventParticipantsButton/EventParticipantsButton.js +5 -3
- package/lib/esm/components/Events/Events.js +8 -28
- package/lib/esm/components/Events/PastEventsFilter.js +2 -12
- package/lib/esm/components/GroupMembersButton/GroupMembersButton.d.ts +2 -2
- package/lib/esm/components/GroupMembersButton/GroupMembersButton.js +16 -14
- package/lib/esm/components/SuggestedEventsWidget/Arrow.js +2 -1
- package/lib/esm/utils/buttonCounters.d.ts +1 -0
- package/lib/esm/utils/buttonCounters.js +11 -0
- package/lib/umd/react-ui.js +1 -1
- package/package.json +7 -7
|
@@ -1,8 +1,7 @@
|
|
|
1
1
|
import { __rest } from "tslib";
|
|
2
2
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
-
import { Icon } from '@mui/material';
|
|
3
|
+
import { Icon, useThemeProps } from '@mui/material';
|
|
4
4
|
import { FormattedMessage } from 'react-intl';
|
|
5
|
-
import { useThemeProps } from '@mui/system';
|
|
6
5
|
import { PREFIX } from './constants';
|
|
7
6
|
import { EventsChipRoot } from './Events';
|
|
8
7
|
export default function PastEventsFilter(inProps) {
|
|
@@ -15,16 +14,7 @@ export default function PastEventsFilter(inProps) {
|
|
|
15
14
|
if (autoHide) {
|
|
16
15
|
return null;
|
|
17
16
|
}
|
|
18
|
-
return (_jsx(EventsChipRoot
|
|
19
|
-
// eslint-disable-next-line @typescript-eslint/ban-ts-ignore
|
|
20
|
-
// @ts-ignore
|
|
21
|
-
, Object.assign({
|
|
22
|
-
// eslint-disable-next-line @typescript-eslint/ban-ts-ignore
|
|
23
|
-
// @ts-ignore
|
|
24
|
-
color: showPastEvents ? 'secondary' : 'default',
|
|
25
|
-
// eslint-disable-next-line @typescript-eslint/ban-ts-ignore
|
|
26
|
-
// @ts-ignore
|
|
27
|
-
variant: showPastEvents ? 'filled' : 'outlined', label: _jsx(FormattedMessage, { id: "ui.events.filterByPastEvents", defaultMessage: "ui.events.filterByPastEvents" }), onClick: handleClick,
|
|
17
|
+
return (_jsx(EventsChipRoot, Object.assign({ color: showPastEvents ? 'secondary' : 'default', variant: showPastEvents ? 'filled' : 'outlined', label: _jsx(FormattedMessage, { id: "ui.events.filterByPastEvents", defaultMessage: "ui.events.filterByPastEvents" }), onClick: handleClick,
|
|
28
18
|
// eslint-disable-next-line @typescript-eslint/ban-ts-ignore
|
|
29
19
|
// @ts-ignore
|
|
30
20
|
showPastEvents: showPastEvents, deleteIcon: showPastEvents ? _jsx(Icon, { children: "close" }) : null, onDelete: showPastEvents ? handleDeleteClick : undefined }, rest)));
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { BaseDialogProps } from '../../shared/BaseDialog';
|
|
2
|
-
import { SCGroupType } from '@selfcommunity/types';
|
|
3
1
|
import { ButtonProps } from '@mui/material/Button/Button';
|
|
2
|
+
import { SCGroupType } from '@selfcommunity/types';
|
|
3
|
+
import { BaseDialogProps } from '../../shared/BaseDialog';
|
|
4
4
|
export interface GroupMembersButtonProps extends Pick<ButtonProps, Exclude<keyof ButtonProps, 'onClick' | 'disabled'>> {
|
|
5
5
|
/**
|
|
6
6
|
* Group Object
|
|
@@ -1,22 +1,23 @@
|
|
|
1
1
|
import { __rest } from "tslib";
|
|
2
2
|
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
-
import { useEffect, useMemo, useState } from 'react';
|
|
4
|
-
import { styled } from '@mui/material/styles';
|
|
5
3
|
import { Avatar, AvatarGroup, Button, List, ListItem, Typography, useTheme } from '@mui/material';
|
|
6
|
-
import
|
|
7
|
-
import
|
|
8
|
-
import
|
|
9
|
-
import User, { UserSkeleton } from '../User';
|
|
4
|
+
import { styled } from '@mui/material/styles';
|
|
5
|
+
import useMediaQuery from '@mui/material/useMediaQuery';
|
|
6
|
+
import { useThemeProps } from '@mui/system';
|
|
10
7
|
import { Endpoints, GroupService, http } from '@selfcommunity/api-services';
|
|
11
8
|
import { useSCFetchGroup } from '@selfcommunity/react-core';
|
|
12
9
|
import { SCGroupPrivacyType, SCGroupSubscriptionStatusType } from '@selfcommunity/types';
|
|
13
|
-
import AvatarGroupSkeleton from '../Skeleton/AvatarGroupSkeleton';
|
|
14
|
-
import classNames from 'classnames';
|
|
15
|
-
import { useThemeProps } from '@mui/system';
|
|
16
|
-
import useMediaQuery from '@mui/material/useMediaQuery';
|
|
17
10
|
import { Logger } from '@selfcommunity/utils';
|
|
18
|
-
import
|
|
11
|
+
import classNames from 'classnames';
|
|
12
|
+
import { useCallback, useEffect, useMemo, useState } from 'react';
|
|
13
|
+
import { FormattedMessage } from 'react-intl';
|
|
19
14
|
import { useDeepCompareEffectNoCheck } from 'use-deep-compare-effect';
|
|
15
|
+
import { SCOPE_SC_UI } from '../../constants/Errors';
|
|
16
|
+
import BaseDialog from '../../shared/BaseDialog';
|
|
17
|
+
import InfiniteScroll from '../../shared/InfiniteScroll';
|
|
18
|
+
import { numberFormatter } from '../../utils/buttonCounters';
|
|
19
|
+
import AvatarGroupSkeleton from '../Skeleton/AvatarGroupSkeleton';
|
|
20
|
+
import User, { UserSkeleton } from '../User';
|
|
20
21
|
const PREFIX = 'SCGroupMembersButton';
|
|
21
22
|
const classes = {
|
|
22
23
|
root: `${PREFIX}-root`,
|
|
@@ -26,12 +27,12 @@ const classes = {
|
|
|
26
27
|
const Root = styled(Button, {
|
|
27
28
|
name: PREFIX,
|
|
28
29
|
slot: 'Root',
|
|
29
|
-
overridesResolver: (
|
|
30
|
+
overridesResolver: (_props, styles) => styles.root
|
|
30
31
|
})(() => ({}));
|
|
31
32
|
const DialogRoot = styled(BaseDialog, {
|
|
32
33
|
name: PREFIX,
|
|
33
34
|
slot: 'Root',
|
|
34
|
-
overridesResolver: (
|
|
35
|
+
overridesResolver: (_props, styles) => styles.dialogRoot
|
|
35
36
|
})(() => ({}));
|
|
36
37
|
/**
|
|
37
38
|
*> API documentation for the Community-JS Group Members Button component. Learn about the available props and the CSS API.
|
|
@@ -125,8 +126,9 @@ export default function GroupMembersButton(inProps) {
|
|
|
125
126
|
const handleToggleDialogOpen = useMemo(() => () => {
|
|
126
127
|
setOpen((prev) => !prev);
|
|
127
128
|
}, [setOpen]);
|
|
129
|
+
const renderSurplus = useCallback(() => numberFormatter(scGroup.subscribers_counter), [scGroup]);
|
|
128
130
|
// RENDER
|
|
129
131
|
const theme = useTheme();
|
|
130
132
|
const isMobile = useMediaQuery(theme.breakpoints.down('md'));
|
|
131
|
-
return (_jsxs(_Fragment, { children: [_jsx(Root, Object.assign({ className: classNames(classes.root, className), onClick: handleToggleDialogOpen, disabled: loading || !scGroup || scGroup.subscribers_counter === 0 }, rest, { children: loading || !scGroup ? (_jsx(AvatarGroupSkeleton, Object.assign({}, rest))) : (_jsx(AvatarGroup, Object.assign({ total: scGroup.subscribers_counter }, { children: members.map((c) => (_jsx(Avatar, { alt: c.username, src: c.avatar }, c.id))) }))) })), open && (_jsx(DialogRoot, Object.assign({ className: classes.dialogRoot, title: _jsx(FormattedMessage, { defaultMessage: "ui.groupMembersButton.dialogTitle", id: "ui.groupMembersButton.dialogTitle", values: { total: scGroup.subscribers_counter } }), onClose: handleToggleDialogOpen, open: open }, DialogProps, { children: _jsx(InfiniteScroll, Object.assign({ dataLength: members.length, next: fetchMembers, hasMoreNext: next !== null || loading, loaderNext: _jsx(UserSkeleton, { elevation: 0 }), height: isMobile ? '100%' : 400, endMessage: _jsx(Typography, Object.assign({ className: classes.endMessage }, { children: _jsx(FormattedMessage, { id: "ui.groupMembersButton.noOtherMembers", defaultMessage: "ui.groupMembersButton.noOtherMembers" }) })) }, { children: _jsx(List, { children: members.map((member) => (_jsx(ListItem, { children: _jsx(User, { elevation: 0, user: member, onClick: handleToggleDialogOpen }) }, member.id))) }) })) })))] }));
|
|
133
|
+
return (_jsxs(_Fragment, { children: [_jsx(Root, Object.assign({ className: classNames(classes.root, className), onClick: handleToggleDialogOpen, disabled: loading || !scGroup || scGroup.subscribers_counter === 0 }, rest, { children: loading || !scGroup ? (_jsx(AvatarGroupSkeleton, Object.assign({}, rest))) : (_jsx(AvatarGroup, Object.assign({ total: scGroup.subscribers_counter, renderSurplus: renderSurplus }, { children: members.map((c) => (_jsx(Avatar, { alt: c.username, src: c.avatar }, c.id))) }))) })), open && (_jsx(DialogRoot, Object.assign({ className: classes.dialogRoot, title: _jsx(FormattedMessage, { defaultMessage: "ui.groupMembersButton.dialogTitle", id: "ui.groupMembersButton.dialogTitle", values: { total: scGroup.subscribers_counter } }), onClose: handleToggleDialogOpen, open: open }, DialogProps, { children: _jsx(InfiniteScroll, Object.assign({ dataLength: members.length, next: fetchMembers, hasMoreNext: next !== null || loading, loaderNext: _jsx(UserSkeleton, { elevation: 0 }), height: isMobile ? '100%' : 400, endMessage: _jsx(Typography, Object.assign({ className: classes.endMessage }, { children: _jsx(FormattedMessage, { id: "ui.groupMembersButton.noOtherMembers", defaultMessage: "ui.groupMembersButton.noOtherMembers" }) })) }, { children: _jsx(List, { children: members.map((member) => (_jsx(ListItem, { children: _jsx(User, { elevation: 0, user: member, onClick: handleToggleDialogOpen }) }, member.id))) }) })) })))] }));
|
|
132
134
|
}
|
|
@@ -23,5 +23,6 @@ export default function Arrow(props) {
|
|
|
23
23
|
if (type === 'prev') {
|
|
24
24
|
return (currentItem > 0 && (_jsx(Button, Object.assign({ variant: "contained", className: className, size: "medium", onClick: () => handleChange('prev') }, { children: _jsx(Icon, { children: "chevron_left" }) }))));
|
|
25
25
|
}
|
|
26
|
-
return (
|
|
26
|
+
return (itemsLength > 2 &&
|
|
27
|
+
currentItem < itemsLength - 1 && (_jsx(Button, Object.assign({ variant: "contained", className: className, size: "medium", onClick: () => handleChange('next') }, { children: _jsx(Icon, { children: "chevron_right" }) }))));
|
|
27
28
|
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function numberFormatter(num: number): JSX.Element;
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
export function numberFormatter(num) {
|
|
3
|
+
const surplus = num - 3;
|
|
4
|
+
if (surplus > 999999) {
|
|
5
|
+
return _jsxs(_Fragment, { children: ["+", (Math.abs(surplus) / 1000000).toFixed(1), "M"] });
|
|
6
|
+
}
|
|
7
|
+
else if (num > 999) {
|
|
8
|
+
return _jsxs(_Fragment, { children: ["+", (Math.abs(surplus) / 1000).toFixed(1), "K"] });
|
|
9
|
+
}
|
|
10
|
+
return _jsxs(_Fragment, { children: ["+", surplus] });
|
|
11
|
+
}
|