@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.
Files changed (26) hide show
  1. package/lib/cjs/components/CategoryFollowersButton/CategoryFollowersButton.d.ts +2 -2
  2. package/lib/cjs/components/CategoryFollowersButton/CategoryFollowersButton.js +14 -12
  3. package/lib/cjs/components/CreateEventButton/CreateEventButton.d.ts +1 -1
  4. package/lib/cjs/components/CreateEventButton/CreateEventButton.js +1 -1
  5. package/lib/cjs/components/EventParticipantsButton/EventParticipantsButton.js +5 -3
  6. package/lib/cjs/components/Events/Events.js +9 -29
  7. package/lib/cjs/components/Events/PastEventsFilter.js +2 -12
  8. package/lib/cjs/components/GroupMembersButton/GroupMembersButton.d.ts +2 -2
  9. package/lib/cjs/components/GroupMembersButton/GroupMembersButton.js +16 -14
  10. package/lib/cjs/components/SuggestedEventsWidget/Arrow.js +2 -1
  11. package/lib/cjs/utils/buttonCounters.d.ts +1 -0
  12. package/lib/cjs/utils/buttonCounters.js +15 -0
  13. package/lib/esm/components/CategoryFollowersButton/CategoryFollowersButton.d.ts +2 -2
  14. package/lib/esm/components/CategoryFollowersButton/CategoryFollowersButton.js +14 -12
  15. package/lib/esm/components/CreateEventButton/CreateEventButton.d.ts +1 -1
  16. package/lib/esm/components/CreateEventButton/CreateEventButton.js +1 -1
  17. package/lib/esm/components/EventParticipantsButton/EventParticipantsButton.js +5 -3
  18. package/lib/esm/components/Events/Events.js +8 -28
  19. package/lib/esm/components/Events/PastEventsFilter.js +2 -12
  20. package/lib/esm/components/GroupMembersButton/GroupMembersButton.d.ts +2 -2
  21. package/lib/esm/components/GroupMembersButton/GroupMembersButton.js +16 -14
  22. package/lib/esm/components/SuggestedEventsWidget/Arrow.js +2 -1
  23. package/lib/esm/utils/buttonCounters.d.ts +1 -0
  24. package/lib/esm/utils/buttonCounters.js +11 -0
  25. package/lib/umd/react-ui.js +1 -1
  26. 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 BaseDialog from '../../shared/BaseDialog';
7
- import { FormattedMessage } from 'react-intl';
8
- import InfiniteScroll from '../../shared/InfiniteScroll';
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 { SCOPE_SC_UI } from '../../constants/Errors';
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: (props, styles) => styles.root
30
+ overridesResolver: (_props, styles) => styles.root
30
31
  })(() => ({}));
31
32
  const DialogRoot = styled(BaseDialog, {
32
33
  name: PREFIX,
33
34
  slot: 'Root',
34
- overridesResolver: (props, styles) => styles.dialogRoot
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 (currentItem < itemsLength - 1 && (_jsx(Button, Object.assign({ variant: "contained", className: className, size: "medium", onClick: () => handleChange('next') }, { children: _jsx(Icon, { children: "chevron_right" }) }))));
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
+ }