@selfcommunity/react-ui 0.7.9-alpha.47 → 0.7.9-alpha.49
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/Composer/Composer.js +2 -2
- package/lib/cjs/components/Composer/Layer/AudienceLayer/AudienceLayer.d.ts +1 -1
- package/lib/cjs/components/Composer/Layer/AudienceLayer/AudienceLayer.js +5 -18
- package/lib/cjs/components/Groups/Groups.d.ts +5 -11
- package/lib/cjs/components/Groups/Groups.js +54 -29
- package/lib/esm/components/Composer/Composer.js +2 -2
- package/lib/esm/components/Composer/Layer/AudienceLayer/AudienceLayer.d.ts +1 -1
- package/lib/esm/components/Composer/Layer/AudienceLayer/AudienceLayer.js +5 -18
- package/lib/esm/components/Groups/Groups.d.ts +5 -11
- package/lib/esm/components/Groups/Groups.js +58 -33
- package/lib/umd/react-ui.js +1 -1
- package/package.json +4 -4
|
@@ -307,7 +307,7 @@ function Composer(inProps) {
|
|
|
307
307
|
}
|
|
308
308
|
}), [handleAddLayer, handleRemoveLayer, handleChangeCategories, categories]);
|
|
309
309
|
const handleChangeAudience = (0, react_1.useCallback)((value) => {
|
|
310
|
-
if (group || Object.prototype.hasOwnProperty.call(value, 'managed_by')) {
|
|
310
|
+
if (group || (value && Object.prototype.hasOwnProperty.call(value, 'managed_by'))) {
|
|
311
311
|
dispatch({ type: 'group', value });
|
|
312
312
|
}
|
|
313
313
|
else {
|
|
@@ -321,7 +321,7 @@ function Composer(inProps) {
|
|
|
321
321
|
ComponentProps: {
|
|
322
322
|
onClose: handleRemoveLayer,
|
|
323
323
|
onSave: handleChangeAudience,
|
|
324
|
-
defaultValue: group ||
|
|
324
|
+
defaultValue: group || (addressing && Object.prototype.hasOwnProperty.call(addressing, 'managed_by')) ? group : addressing
|
|
325
325
|
}
|
|
326
326
|
}), [handleAddLayer, handleRemoveLayer, handleChangeAudience, addressing, group]);
|
|
327
327
|
const handleChangeLocation = (0, react_1.useCallback)((value) => {
|
|
@@ -10,7 +10,7 @@ export declare enum AudienceTypes {
|
|
|
10
10
|
AUDIENCE_GROUP = "group"
|
|
11
11
|
}
|
|
12
12
|
export interface AudienceLayerProps extends Omit<BoxProps, 'defaultValue'>, ComposerLayerProps {
|
|
13
|
-
defaultValue: SCTagType[] | SCGroupType;
|
|
13
|
+
defaultValue: SCTagType[] | SCGroupType | any;
|
|
14
14
|
TextFieldProps?: TextFieldProps;
|
|
15
15
|
}
|
|
16
16
|
declare const AudienceLayer: React.ForwardRefExoticComponent<Pick<AudienceLayerProps, "p" | "slot" | "style" | "title" | "key" | "defaultChecked" | "defaultValue" | "suppressContentEditableWarning" | "suppressHydrationWarning" | "accessKey" | "className" | "contentEditable" | "contextMenu" | "dir" | "draggable" | "hidden" | "id" | "lang" | "placeholder" | "spellCheck" | "tabIndex" | "translate" | "radioGroup" | "role" | "about" | "datatype" | "inlist" | "prefix" | "property" | "resource" | "typeof" | "vocab" | "autoCapitalize" | "autoCorrect" | "autoSave" | "color" | "itemProp" | "itemScope" | "itemType" | "itemID" | "itemRef" | "results" | "security" | "unselectable" | "inputMode" | "is" | "aria-activedescendant" | "aria-atomic" | "aria-autocomplete" | "aria-busy" | "aria-checked" | "aria-colcount" | "aria-colindex" | "aria-colspan" | "aria-controls" | "aria-current" | "aria-describedby" | "aria-details" | "aria-disabled" | "aria-dropeffect" | "aria-errormessage" | "aria-expanded" | "aria-flowto" | "aria-grabbed" | "aria-haspopup" | "aria-hidden" | "aria-invalid" | "aria-keyshortcuts" | "aria-label" | "aria-labelledby" | "aria-level" | "aria-live" | "aria-modal" | "aria-multiline" | "aria-multiselectable" | "aria-orientation" | "aria-owns" | "aria-placeholder" | "aria-posinset" | "aria-pressed" | "aria-readonly" | "aria-relevant" | "aria-required" | "aria-roledescription" | "aria-rowcount" | "aria-rowindex" | "aria-rowspan" | "aria-selected" | "aria-setsize" | "aria-sort" | "aria-valuemax" | "aria-valuemin" | "aria-valuenow" | "aria-valuetext" | "children" | "dangerouslySetInnerHTML" | "onCopy" | "onCopyCapture" | "onCut" | "onCutCapture" | "onPaste" | "onPasteCapture" | "onCompositionEnd" | "onCompositionEndCapture" | "onCompositionStart" | "onCompositionStartCapture" | "onCompositionUpdate" | "onCompositionUpdateCapture" | "onFocus" | "onFocusCapture" | "onBlur" | "onBlurCapture" | "onChange" | "onChangeCapture" | "onBeforeInput" | "onBeforeInputCapture" | "onInput" | "onInputCapture" | "onReset" | "onResetCapture" | "onSubmit" | "onSubmitCapture" | "onInvalid" | "onInvalidCapture" | "onLoad" | "onLoadCapture" | "onError" | "onErrorCapture" | "onKeyDown" | "onKeyDownCapture" | "onKeyPress" | "onKeyPressCapture" | "onKeyUp" | "onKeyUpCapture" | "onAbort" | "onAbortCapture" | "onCanPlay" | "onCanPlayCapture" | "onCanPlayThrough" | "onCanPlayThroughCapture" | "onDurationChange" | "onDurationChangeCapture" | "onEmptied" | "onEmptiedCapture" | "onEncrypted" | "onEncryptedCapture" | "onEnded" | "onEndedCapture" | "onLoadedData" | "onLoadedDataCapture" | "onLoadedMetadata" | "onLoadedMetadataCapture" | "onLoadStart" | "onLoadStartCapture" | "onPause" | "onPauseCapture" | "onPlay" | "onPlayCapture" | "onPlaying" | "onPlayingCapture" | "onProgress" | "onProgressCapture" | "onRateChange" | "onRateChangeCapture" | "onSeeked" | "onSeekedCapture" | "onSeeking" | "onSeekingCapture" | "onStalled" | "onStalledCapture" | "onSuspend" | "onSuspendCapture" | "onTimeUpdate" | "onTimeUpdateCapture" | "onVolumeChange" | "onVolumeChangeCapture" | "onWaiting" | "onWaitingCapture" | "onAuxClick" | "onAuxClickCapture" | "onClick" | "onClickCapture" | "onContextMenu" | "onContextMenuCapture" | "onDoubleClick" | "onDoubleClickCapture" | "onDrag" | "onDragCapture" | "onDragEnd" | "onDragEndCapture" | "onDragEnter" | "onDragEnterCapture" | "onDragExit" | "onDragExitCapture" | "onDragLeave" | "onDragLeaveCapture" | "onDragOver" | "onDragOverCapture" | "onDragStart" | "onDragStartCapture" | "onDrop" | "onDropCapture" | "onMouseDown" | "onMouseDownCapture" | "onMouseEnter" | "onMouseLeave" | "onMouseMove" | "onMouseMoveCapture" | "onMouseOut" | "onMouseOutCapture" | "onMouseOver" | "onMouseOverCapture" | "onMouseUp" | "onMouseUpCapture" | "onSelect" | "onSelectCapture" | "onTouchCancel" | "onTouchCancelCapture" | "onTouchEnd" | "onTouchEndCapture" | "onTouchMove" | "onTouchMoveCapture" | "onTouchStart" | "onTouchStartCapture" | "onPointerDown" | "onPointerDownCapture" | "onPointerMove" | "onPointerMoveCapture" | "onPointerUp" | "onPointerUpCapture" | "onPointerCancel" | "onPointerCancelCapture" | "onPointerEnter" | "onPointerEnterCapture" | "onPointerLeave" | "onPointerLeaveCapture" | "onPointerOver" | "onPointerOverCapture" | "onPointerOut" | "onPointerOutCapture" | "onGotPointerCapture" | "onGotPointerCaptureCapture" | "onLostPointerCapture" | "onLostPointerCaptureCapture" | "onScroll" | "onScrollCapture" | "onWheel" | "onWheelCapture" | "onAnimationStart" | "onAnimationStartCapture" | "onAnimationEnd" | "onAnimationEndCapture" | "onAnimationIteration" | "onAnimationIterationCapture" | "onTransitionEnd" | "onTransitionEndCapture" | "border" | "borderTop" | "borderRight" | "borderBottom" | "borderLeft" | "borderColor" | "borderRadius" | "display" | "displayPrint" | "overflow" | "textOverflow" | "visibility" | "whiteSpace" | "flexBasis" | "flexDirection" | "flexWrap" | "justifyContent" | "alignItems" | "alignContent" | "order" | "flex" | "flexGrow" | "flexShrink" | "alignSelf" | "justifyItems" | "justifySelf" | "gap" | "columnGap" | "rowGap" | "gridColumn" | "gridRow" | "gridAutoFlow" | "gridAutoColumns" | "gridAutoRows" | "gridTemplateColumns" | "gridTemplateRows" | "gridTemplateAreas" | "gridArea" | "bgcolor" | "zIndex" | "position" | "top" | "right" | "bottom" | "left" | "boxShadow" | "width" | "maxWidth" | "minWidth" | "height" | "maxHeight" | "minHeight" | "boxSizing" | "m" | "mt" | "mr" | "mb" | "ml" | "mx" | "my" | "pt" | "pr" | "pb" | "pl" | "px" | "py" | "margin" | "marginTop" | "marginRight" | "marginBottom" | "marginLeft" | "marginX" | "marginY" | "marginInline" | "marginInlineStart" | "marginInlineEnd" | "marginBlock" | "marginBlockStart" | "marginBlockEnd" | "padding" | "paddingTop" | "paddingRight" | "paddingBottom" | "paddingLeft" | "paddingX" | "paddingY" | "paddingInline" | "paddingInlineStart" | "paddingInlineEnd" | "paddingBlock" | "paddingBlockStart" | "paddingBlockEnd" | "typography" | "fontFamily" | "fontSize" | "fontStyle" | "fontWeight" | "letterSpacing" | "lineHeight" | "textAlign" | "textTransform" | "component" | "sx" | "classes" | "onClose" | "TextFieldProps" | "onSave"> & React.RefAttributes<unknown>>;
|
|
@@ -55,10 +55,9 @@ const AudienceLayer = react_1.default.forwardRef((props, ref) => {
|
|
|
55
55
|
// HOOKS
|
|
56
56
|
const { scAddressingTags } = (0, react_core_1.useSCFetchAddressingTagList)({ fetch: autocompleteOpen });
|
|
57
57
|
// HANDLERS
|
|
58
|
-
const handleSave = (0, react_1.useCallback)(
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
() => (audience === AudienceTypes.AUDIENCE_GROUP ? onSave(value) : onSave((value === null || value === void 0 ? void 0 : value.length) && (value === null || value === void 0 ? void 0 : value.length) > 0 ? value : null)), [value, onSave, audience]);
|
|
58
|
+
const handleSave = (0, react_1.useCallback)(() => {
|
|
59
|
+
audience === AudienceTypes.AUDIENCE_GROUP ? onSave(value) : onSave((value === null || value === void 0 ? void 0 : value.length) && (value === null || value === void 0 ? void 0 : value.length) > 0 ? value : null);
|
|
60
|
+
}, [value, onSave, audience]);
|
|
62
61
|
const handleChange = (0, react_1.useCallback)((event, tags) => setValue(tags), []);
|
|
63
62
|
const handleGroupChange = (0, react_1.useCallback)((group) => setValue(group), []);
|
|
64
63
|
const handleChangeAudience = (0, react_1.useCallback)((event, data) => setAudience(data), []);
|
|
@@ -75,20 +74,8 @@ const AudienceLayer = react_1.default.forwardRef((props, ref) => {
|
|
|
75
74
|
react_1.default.createElement(DialogContent_1.default, { className: classes.content },
|
|
76
75
|
react_1.default.createElement(material_1.Tabs, { value: audience, onChange: handleChangeAudience, "aria-label": "audience type" },
|
|
77
76
|
react_1.default.createElement(material_1.Tab, { value: AudienceTypes.AUDIENCE_ALL, icon: react_1.default.createElement(Icon_1.default, null, "public"), label: react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.composer.layer.audience.all", defaultMessage: "ui.composer.layer.audience.all" }) }),
|
|
78
|
-
react_1.default.createElement(material_1.Tab
|
|
79
|
-
|
|
80
|
-
// @ts-ignore
|
|
81
|
-
, {
|
|
82
|
-
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
83
|
-
// @ts-ignore
|
|
84
|
-
disabled: defaultValue && !Object.prototype.hasOwnProperty.call(value, 'managed_by'), value: AudienceTypes.AUDIENCE_GROUP, icon: react_1.default.createElement(Icon_1.default, null, "groups"), label: react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.composer.layer.audience.group", defaultMessage: "ui.composer.layer.audience.group" }) }),
|
|
85
|
-
react_1.default.createElement(material_1.Tab
|
|
86
|
-
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
87
|
-
// @ts-ignore
|
|
88
|
-
, {
|
|
89
|
-
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
90
|
-
// @ts-ignore
|
|
91
|
-
disabled: value && Object.prototype.hasOwnProperty.call(value, 'managed_by'), value: AudienceTypes.AUDIENCE_TAG, icon: react_1.default.createElement(Icon_1.default, null, "label"), label: react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.composer.layer.audience.tag", defaultMessage: "ui.composer.layer.audience.tag" }) })),
|
|
77
|
+
react_1.default.createElement(material_1.Tab, { disabled: value && Boolean(value === null || value === void 0 ? void 0 : value.length), value: AudienceTypes.AUDIENCE_GROUP, icon: react_1.default.createElement(Icon_1.default, null, "groups"), label: react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.composer.layer.audience.group", defaultMessage: "ui.composer.layer.audience.group" }) }),
|
|
78
|
+
react_1.default.createElement(material_1.Tab, { disabled: value && Object.prototype.hasOwnProperty.call(value, 'managed_by'), value: AudienceTypes.AUDIENCE_TAG, icon: react_1.default.createElement(Icon_1.default, null, "label"), label: react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.composer.layer.audience.tag", defaultMessage: "ui.composer.layer.audience.tag" }) })),
|
|
92
79
|
react_1.default.createElement(material_1.Typography, { className: classes.message },
|
|
93
80
|
audience === AudienceTypes.AUDIENCE_ALL && (react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.composer.layer.audience.all.message", defaultMessage: "ui.composer.audience.layer.all.message" })),
|
|
94
81
|
audience === AudienceTypes.AUDIENCE_GROUP && (react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.composer.layer.audience.group.message", defaultMessage: "ui.composer.audience.layer.group.message" })),
|
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
import { SCGroupType } from '@selfcommunity/types';
|
|
2
|
-
import { EndpointType } from '@selfcommunity/api-services';
|
|
3
2
|
import { GroupProps } from '../Group';
|
|
4
3
|
export interface GroupsProps {
|
|
5
4
|
/**
|
|
@@ -8,24 +7,19 @@ export interface GroupsProps {
|
|
|
8
7
|
*/
|
|
9
8
|
className?: string;
|
|
10
9
|
/**
|
|
11
|
-
*
|
|
10
|
+
* Feed API Query Params
|
|
11
|
+
* @default [{'limit': 10, 'offset': 0}]
|
|
12
12
|
*/
|
|
13
|
-
|
|
13
|
+
endpointQueryParams?: Record<string, string | number>;
|
|
14
14
|
/**
|
|
15
15
|
* Props to spread to single group object
|
|
16
16
|
* @default {variant: 'outlined', ButtonBaseProps: {disableRipple: 'true'}}
|
|
17
17
|
*/
|
|
18
18
|
GroupComponentProps?: GroupProps;
|
|
19
|
-
/**
|
|
20
|
-
* Prefetch groups. Useful for SSR.
|
|
21
|
-
* Use this to init the component with groups
|
|
22
|
-
* @default null
|
|
23
|
-
*/
|
|
24
|
-
prefetchedGroups?: SCGroupType[];
|
|
25
19
|
/** If true, it means that the endpoint fetches all groups available
|
|
26
|
-
* @default
|
|
20
|
+
* @default true
|
|
27
21
|
*/
|
|
28
|
-
general
|
|
22
|
+
general: boolean;
|
|
29
23
|
/**
|
|
30
24
|
* Show/Hide filters
|
|
31
25
|
* @default false
|
|
@@ -14,7 +14,9 @@ const Errors_1 = require("../../constants/Errors");
|
|
|
14
14
|
const system_1 = require("@mui/system");
|
|
15
15
|
const HiddenPlaceholder_1 = tslib_1.__importDefault(require("../../shared/HiddenPlaceholder"));
|
|
16
16
|
const constants_1 = require("./constants");
|
|
17
|
-
const Group_1 = tslib_1.
|
|
17
|
+
const Group_1 = tslib_1.__importStar(require("../Group"));
|
|
18
|
+
const Pagination_1 = require("../../constants/Pagination");
|
|
19
|
+
const InfiniteScroll_1 = tslib_1.__importDefault(require("../../shared/InfiniteScroll"));
|
|
18
20
|
const classes = {
|
|
19
21
|
root: `${constants_1.PREFIX}-root`,
|
|
20
22
|
filters: `${constants_1.PREFIX}-filter`,
|
|
@@ -65,10 +67,11 @@ function Groups(inProps) {
|
|
|
65
67
|
props: inProps,
|
|
66
68
|
name: constants_1.PREFIX
|
|
67
69
|
});
|
|
68
|
-
const {
|
|
70
|
+
const { endpointQueryParams = { limit: Pagination_1.DEFAULT_PAGINATION_LIMIT, offset: Pagination_1.DEFAULT_PAGINATION_OFFSET }, className, GroupComponentProps = { variant: 'outlined', ButtonBaseProps: { disableRipple: true, component: material_1.Box } }, showFilters = false, filters, handleFilterGroups, general = true } = props, rest = tslib_1.__rest(props, ["endpointQueryParams", "className", "GroupComponentProps", "showFilters", "filters", "handleFilterGroups", "general"]);
|
|
69
71
|
// STATE
|
|
70
72
|
const [groups, setGroups] = (0, react_1.useState)([]);
|
|
71
73
|
const [loading, setLoading] = (0, react_1.useState)(true);
|
|
74
|
+
const [next, setNext] = (0, react_1.useState)(null);
|
|
72
75
|
const [filterName, setFilterName] = (0, react_1.useState)('');
|
|
73
76
|
// CONTEXT
|
|
74
77
|
const scUserContext = (0, react_core_1.useSCUser)();
|
|
@@ -78,19 +81,31 @@ function Groups(inProps) {
|
|
|
78
81
|
scPreferencesContext.preferences[react_core_1.SCPreferences.CONFIGURATIONS_CONTENT_AVAILABILITY].value, [scPreferencesContext.preferences]);
|
|
79
82
|
// CONST
|
|
80
83
|
const authUserId = scUserContext.user ? scUserContext.user.id : null;
|
|
81
|
-
//
|
|
82
|
-
const
|
|
84
|
+
// HANDLERS
|
|
85
|
+
const handleScrollUp = () => {
|
|
86
|
+
window.scrollTo({ left: 0, top: 0, behavior: 'smooth' });
|
|
87
|
+
};
|
|
83
88
|
/**
|
|
84
89
|
* Fetches groups list
|
|
85
90
|
*/
|
|
86
|
-
const fetchGroups = (
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
91
|
+
const fetchGroups = () => {
|
|
92
|
+
let groupService;
|
|
93
|
+
if (general) {
|
|
94
|
+
groupService = api_services_1.GroupService.searchGroups(endpointQueryParams);
|
|
95
|
+
}
|
|
96
|
+
else {
|
|
97
|
+
groupService = api_services_1.GroupService.getUserGroups(endpointQueryParams);
|
|
98
|
+
}
|
|
99
|
+
groupService
|
|
100
|
+
.then((res) => {
|
|
101
|
+
setGroups(res.results);
|
|
102
|
+
setNext(res.next);
|
|
103
|
+
setLoading(false);
|
|
104
|
+
})
|
|
105
|
+
.catch((error) => {
|
|
106
|
+
utils_1.Logger.error(Errors_1.SCOPE_SC_UI, error);
|
|
90
107
|
});
|
|
91
|
-
|
|
92
|
-
return data.next ? data.results.concat(yield fetchGroups(data.next)) : data.results;
|
|
93
|
-
});
|
|
108
|
+
};
|
|
94
109
|
/**
|
|
95
110
|
* On mount, fetches groups list
|
|
96
111
|
*/
|
|
@@ -98,23 +113,10 @@ function Groups(inProps) {
|
|
|
98
113
|
if (!contentAvailability && !authUserId) {
|
|
99
114
|
return;
|
|
100
115
|
}
|
|
101
|
-
else if (prefetchedGroups.length) {
|
|
102
|
-
setGroups(prefetchedGroups);
|
|
103
|
-
setLoading(false);
|
|
104
|
-
}
|
|
105
116
|
else {
|
|
106
|
-
fetchGroups()
|
|
107
|
-
.then((data) => {
|
|
108
|
-
if (isMountedRef.current) {
|
|
109
|
-
setGroups(data);
|
|
110
|
-
setLoading(false);
|
|
111
|
-
}
|
|
112
|
-
})
|
|
113
|
-
.catch((error) => {
|
|
114
|
-
utils_1.Logger.error(Errors_1.SCOPE_SC_UI, error);
|
|
115
|
-
});
|
|
117
|
+
fetchGroups();
|
|
116
118
|
}
|
|
117
|
-
}, [contentAvailability, authUserId
|
|
119
|
+
}, [contentAvailability, authUserId]);
|
|
118
120
|
const handleSubscribe = (group) => {
|
|
119
121
|
if (!general) {
|
|
120
122
|
const newGroups = [...groups];
|
|
@@ -122,6 +124,22 @@ function Groups(inProps) {
|
|
|
122
124
|
setGroups(_updated);
|
|
123
125
|
}
|
|
124
126
|
};
|
|
127
|
+
const handleNext = (0, react_1.useMemo)(() => () => {
|
|
128
|
+
if (!next) {
|
|
129
|
+
return;
|
|
130
|
+
}
|
|
131
|
+
return api_services_1.http
|
|
132
|
+
.request({
|
|
133
|
+
url: next,
|
|
134
|
+
method: general ? api_services_1.Endpoints.SearchGroups.method : api_services_1.Endpoints.GetUserGroups.method
|
|
135
|
+
})
|
|
136
|
+
.then((res) => {
|
|
137
|
+
setGroups([...groups, ...res.data.results]);
|
|
138
|
+
setNext(res.data.next);
|
|
139
|
+
})
|
|
140
|
+
.catch((error) => console.log(error))
|
|
141
|
+
.then(() => setLoading(false));
|
|
142
|
+
}, [next]);
|
|
125
143
|
/**
|
|
126
144
|
* Get groups filtered
|
|
127
145
|
*/
|
|
@@ -148,16 +166,23 @@ function Groups(inProps) {
|
|
|
148
166
|
const content = (react_1.default.createElement(react_1.default.Fragment, null,
|
|
149
167
|
showFilters && (react_1.default.createElement(material_1.Grid, { container: true, direction: "row", justifyContent: "center", alignItems: "center", className: classes.filters }, filters ? (filters) : (react_1.default.createElement(material_1.Grid, { item: true, xs: 12, md: 6 },
|
|
150
168
|
react_1.default.createElement(material_1.TextField, { fullWidth: true, value: filterName, label: react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groups.filterByName", defaultMessage: "ui.groups.filterByName" }), variant: "outlined", onChange: handleOnChangeFilterName, disabled: loading }))))),
|
|
151
|
-
|
|
169
|
+
react_1.default.createElement(react_1.default.Fragment, null, !groups.length ? (react_1.default.createElement(material_1.Box, { className: classes.noResults },
|
|
152
170
|
react_1.default.createElement(material_1.Typography, { variant: "h4" },
|
|
153
171
|
react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groups.noGroups.title", defaultMessage: "ui.groups.noGroups.title" })),
|
|
154
172
|
react_1.default.createElement(material_1.Typography, { variant: "body1" },
|
|
155
|
-
react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groups.noGroups.subtitle", defaultMessage: "ui.groups.noGroups.subtitle" })))) : (react_1.default.createElement(
|
|
156
|
-
|
|
173
|
+
react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groups.noGroups.subtitle", defaultMessage: "ui.groups.noGroups.subtitle" })))) : (react_1.default.createElement(InfiniteScroll_1.default, { dataLength: groups.length, next: handleNext, hasMoreNext: Boolean(next), loaderNext: react_1.default.createElement(Group_1.GroupSkeleton, null), endMessage: react_1.default.createElement(material_1.Typography, { component: "div", className: classes.endMessage },
|
|
174
|
+
react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groups.endMessage", defaultMessage: "ui.groups.endMessage", values: {
|
|
175
|
+
button: (chunk) => (react_1.default.createElement(material_1.Button, { color: "secondary", variant: "text", onClick: handleScrollUp }, chunk))
|
|
176
|
+
} })) },
|
|
177
|
+
react_1.default.createElement(material_1.Grid, { container: true, spacing: { xs: 2 }, className: classes.groups }, filteredGroups.map((group) => (react_1.default.createElement(material_1.Grid, { item: true, xs: 12, sm: 8, md: 6, key: group.id, className: classes.item },
|
|
178
|
+
react_1.default.createElement(Group_1.default, Object.assign({ group: group, groupId: group.id, groupSubscribeButtonProps: { onSubscribe: handleSubscribe } }, GroupComponentProps)))))))))));
|
|
157
179
|
// RENDER
|
|
158
180
|
if (!contentAvailability && !scUserContext.user) {
|
|
159
181
|
return react_1.default.createElement(HiddenPlaceholder_1.default, null);
|
|
160
182
|
}
|
|
183
|
+
if (loading) {
|
|
184
|
+
return react_1.default.createElement(Skeleton_1.default, null);
|
|
185
|
+
}
|
|
161
186
|
return (react_1.default.createElement(Root, Object.assign({ className: (0, classnames_1.default)(classes.root, className) }, rest), content));
|
|
162
187
|
}
|
|
163
188
|
exports.default = Groups;
|
|
@@ -305,7 +305,7 @@ export default function Composer(inProps) {
|
|
|
305
305
|
}
|
|
306
306
|
}), [handleAddLayer, handleRemoveLayer, handleChangeCategories, categories]);
|
|
307
307
|
const handleChangeAudience = useCallback((value) => {
|
|
308
|
-
if (group || Object.prototype.hasOwnProperty.call(value, 'managed_by')) {
|
|
308
|
+
if (group || (value && Object.prototype.hasOwnProperty.call(value, 'managed_by'))) {
|
|
309
309
|
dispatch({ type: 'group', value });
|
|
310
310
|
}
|
|
311
311
|
else {
|
|
@@ -319,7 +319,7 @@ export default function Composer(inProps) {
|
|
|
319
319
|
ComponentProps: {
|
|
320
320
|
onClose: handleRemoveLayer,
|
|
321
321
|
onSave: handleChangeAudience,
|
|
322
|
-
defaultValue: group ||
|
|
322
|
+
defaultValue: group || (addressing && Object.prototype.hasOwnProperty.call(addressing, 'managed_by')) ? group : addressing
|
|
323
323
|
}
|
|
324
324
|
}), [handleAddLayer, handleRemoveLayer, handleChangeAudience, addressing, group]);
|
|
325
325
|
const handleChangeLocation = useCallback((value) => {
|
|
@@ -10,7 +10,7 @@ export declare enum AudienceTypes {
|
|
|
10
10
|
AUDIENCE_GROUP = "group"
|
|
11
11
|
}
|
|
12
12
|
export interface AudienceLayerProps extends Omit<BoxProps, 'defaultValue'>, ComposerLayerProps {
|
|
13
|
-
defaultValue: SCTagType[] | SCGroupType;
|
|
13
|
+
defaultValue: SCTagType[] | SCGroupType | any;
|
|
14
14
|
TextFieldProps?: TextFieldProps;
|
|
15
15
|
}
|
|
16
16
|
declare const AudienceLayer: React.ForwardRefExoticComponent<Pick<AudienceLayerProps, "p" | "slot" | "style" | "title" | "key" | "defaultChecked" | "defaultValue" | "suppressContentEditableWarning" | "suppressHydrationWarning" | "accessKey" | "className" | "contentEditable" | "contextMenu" | "dir" | "draggable" | "hidden" | "id" | "lang" | "placeholder" | "spellCheck" | "tabIndex" | "translate" | "radioGroup" | "role" | "about" | "datatype" | "inlist" | "prefix" | "property" | "resource" | "typeof" | "vocab" | "autoCapitalize" | "autoCorrect" | "autoSave" | "color" | "itemProp" | "itemScope" | "itemType" | "itemID" | "itemRef" | "results" | "security" | "unselectable" | "inputMode" | "is" | "aria-activedescendant" | "aria-atomic" | "aria-autocomplete" | "aria-busy" | "aria-checked" | "aria-colcount" | "aria-colindex" | "aria-colspan" | "aria-controls" | "aria-current" | "aria-describedby" | "aria-details" | "aria-disabled" | "aria-dropeffect" | "aria-errormessage" | "aria-expanded" | "aria-flowto" | "aria-grabbed" | "aria-haspopup" | "aria-hidden" | "aria-invalid" | "aria-keyshortcuts" | "aria-label" | "aria-labelledby" | "aria-level" | "aria-live" | "aria-modal" | "aria-multiline" | "aria-multiselectable" | "aria-orientation" | "aria-owns" | "aria-placeholder" | "aria-posinset" | "aria-pressed" | "aria-readonly" | "aria-relevant" | "aria-required" | "aria-roledescription" | "aria-rowcount" | "aria-rowindex" | "aria-rowspan" | "aria-selected" | "aria-setsize" | "aria-sort" | "aria-valuemax" | "aria-valuemin" | "aria-valuenow" | "aria-valuetext" | "children" | "dangerouslySetInnerHTML" | "onCopy" | "onCopyCapture" | "onCut" | "onCutCapture" | "onPaste" | "onPasteCapture" | "onCompositionEnd" | "onCompositionEndCapture" | "onCompositionStart" | "onCompositionStartCapture" | "onCompositionUpdate" | "onCompositionUpdateCapture" | "onFocus" | "onFocusCapture" | "onBlur" | "onBlurCapture" | "onChange" | "onChangeCapture" | "onBeforeInput" | "onBeforeInputCapture" | "onInput" | "onInputCapture" | "onReset" | "onResetCapture" | "onSubmit" | "onSubmitCapture" | "onInvalid" | "onInvalidCapture" | "onLoad" | "onLoadCapture" | "onError" | "onErrorCapture" | "onKeyDown" | "onKeyDownCapture" | "onKeyPress" | "onKeyPressCapture" | "onKeyUp" | "onKeyUpCapture" | "onAbort" | "onAbortCapture" | "onCanPlay" | "onCanPlayCapture" | "onCanPlayThrough" | "onCanPlayThroughCapture" | "onDurationChange" | "onDurationChangeCapture" | "onEmptied" | "onEmptiedCapture" | "onEncrypted" | "onEncryptedCapture" | "onEnded" | "onEndedCapture" | "onLoadedData" | "onLoadedDataCapture" | "onLoadedMetadata" | "onLoadedMetadataCapture" | "onLoadStart" | "onLoadStartCapture" | "onPause" | "onPauseCapture" | "onPlay" | "onPlayCapture" | "onPlaying" | "onPlayingCapture" | "onProgress" | "onProgressCapture" | "onRateChange" | "onRateChangeCapture" | "onSeeked" | "onSeekedCapture" | "onSeeking" | "onSeekingCapture" | "onStalled" | "onStalledCapture" | "onSuspend" | "onSuspendCapture" | "onTimeUpdate" | "onTimeUpdateCapture" | "onVolumeChange" | "onVolumeChangeCapture" | "onWaiting" | "onWaitingCapture" | "onAuxClick" | "onAuxClickCapture" | "onClick" | "onClickCapture" | "onContextMenu" | "onContextMenuCapture" | "onDoubleClick" | "onDoubleClickCapture" | "onDrag" | "onDragCapture" | "onDragEnd" | "onDragEndCapture" | "onDragEnter" | "onDragEnterCapture" | "onDragExit" | "onDragExitCapture" | "onDragLeave" | "onDragLeaveCapture" | "onDragOver" | "onDragOverCapture" | "onDragStart" | "onDragStartCapture" | "onDrop" | "onDropCapture" | "onMouseDown" | "onMouseDownCapture" | "onMouseEnter" | "onMouseLeave" | "onMouseMove" | "onMouseMoveCapture" | "onMouseOut" | "onMouseOutCapture" | "onMouseOver" | "onMouseOverCapture" | "onMouseUp" | "onMouseUpCapture" | "onSelect" | "onSelectCapture" | "onTouchCancel" | "onTouchCancelCapture" | "onTouchEnd" | "onTouchEndCapture" | "onTouchMove" | "onTouchMoveCapture" | "onTouchStart" | "onTouchStartCapture" | "onPointerDown" | "onPointerDownCapture" | "onPointerMove" | "onPointerMoveCapture" | "onPointerUp" | "onPointerUpCapture" | "onPointerCancel" | "onPointerCancelCapture" | "onPointerEnter" | "onPointerEnterCapture" | "onPointerLeave" | "onPointerLeaveCapture" | "onPointerOver" | "onPointerOverCapture" | "onPointerOut" | "onPointerOutCapture" | "onGotPointerCapture" | "onGotPointerCaptureCapture" | "onLostPointerCapture" | "onLostPointerCaptureCapture" | "onScroll" | "onScrollCapture" | "onWheel" | "onWheelCapture" | "onAnimationStart" | "onAnimationStartCapture" | "onAnimationEnd" | "onAnimationEndCapture" | "onAnimationIteration" | "onAnimationIterationCapture" | "onTransitionEnd" | "onTransitionEndCapture" | "border" | "borderTop" | "borderRight" | "borderBottom" | "borderLeft" | "borderColor" | "borderRadius" | "display" | "displayPrint" | "overflow" | "textOverflow" | "visibility" | "whiteSpace" | "flexBasis" | "flexDirection" | "flexWrap" | "justifyContent" | "alignItems" | "alignContent" | "order" | "flex" | "flexGrow" | "flexShrink" | "alignSelf" | "justifyItems" | "justifySelf" | "gap" | "columnGap" | "rowGap" | "gridColumn" | "gridRow" | "gridAutoFlow" | "gridAutoColumns" | "gridAutoRows" | "gridTemplateColumns" | "gridTemplateRows" | "gridTemplateAreas" | "gridArea" | "bgcolor" | "zIndex" | "position" | "top" | "right" | "bottom" | "left" | "boxShadow" | "width" | "maxWidth" | "minWidth" | "height" | "maxHeight" | "minHeight" | "boxSizing" | "m" | "mt" | "mr" | "mb" | "ml" | "mx" | "my" | "pt" | "pr" | "pb" | "pl" | "px" | "py" | "margin" | "marginTop" | "marginRight" | "marginBottom" | "marginLeft" | "marginX" | "marginY" | "marginInline" | "marginInlineStart" | "marginInlineEnd" | "marginBlock" | "marginBlockStart" | "marginBlockEnd" | "padding" | "paddingTop" | "paddingRight" | "paddingBottom" | "paddingLeft" | "paddingX" | "paddingY" | "paddingInline" | "paddingInlineStart" | "paddingInlineEnd" | "paddingBlock" | "paddingBlockStart" | "paddingBlockEnd" | "typography" | "fontFamily" | "fontSize" | "fontStyle" | "fontWeight" | "letterSpacing" | "lineHeight" | "textAlign" | "textTransform" | "component" | "sx" | "classes" | "onClose" | "TextFieldProps" | "onSave"> & React.RefAttributes<unknown>>;
|
|
@@ -52,10 +52,9 @@ const AudienceLayer = React.forwardRef((props, ref) => {
|
|
|
52
52
|
// HOOKS
|
|
53
53
|
const { scAddressingTags } = useSCFetchAddressingTagList({ fetch: autocompleteOpen });
|
|
54
54
|
// HANDLERS
|
|
55
|
-
const handleSave = useCallback(
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
() => (audience === AudienceTypes.AUDIENCE_GROUP ? onSave(value) : onSave((value === null || value === void 0 ? void 0 : value.length) && (value === null || value === void 0 ? void 0 : value.length) > 0 ? value : null)), [value, onSave, audience]);
|
|
55
|
+
const handleSave = useCallback(() => {
|
|
56
|
+
audience === AudienceTypes.AUDIENCE_GROUP ? onSave(value) : onSave((value === null || value === void 0 ? void 0 : value.length) && (value === null || value === void 0 ? void 0 : value.length) > 0 ? value : null);
|
|
57
|
+
}, [value, onSave, audience]);
|
|
59
58
|
const handleChange = useCallback((event, tags) => setValue(tags), []);
|
|
60
59
|
const handleGroupChange = useCallback((group) => setValue(group), []);
|
|
61
60
|
const handleChangeAudience = useCallback((event, data) => setAudience(data), []);
|
|
@@ -72,20 +71,8 @@ const AudienceLayer = React.forwardRef((props, ref) => {
|
|
|
72
71
|
React.createElement(DialogContent, { className: classes.content },
|
|
73
72
|
React.createElement(Tabs, { value: audience, onChange: handleChangeAudience, "aria-label": "audience type" },
|
|
74
73
|
React.createElement(Tab, { value: AudienceTypes.AUDIENCE_ALL, icon: React.createElement(Icon, null, "public"), label: React.createElement(FormattedMessage, { id: "ui.composer.layer.audience.all", defaultMessage: "ui.composer.layer.audience.all" }) }),
|
|
75
|
-
React.createElement(Tab
|
|
76
|
-
|
|
77
|
-
// @ts-ignore
|
|
78
|
-
, {
|
|
79
|
-
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
80
|
-
// @ts-ignore
|
|
81
|
-
disabled: defaultValue && !Object.prototype.hasOwnProperty.call(value, 'managed_by'), value: AudienceTypes.AUDIENCE_GROUP, icon: React.createElement(Icon, null, "groups"), label: React.createElement(FormattedMessage, { id: "ui.composer.layer.audience.group", defaultMessage: "ui.composer.layer.audience.group" }) }),
|
|
82
|
-
React.createElement(Tab
|
|
83
|
-
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
84
|
-
// @ts-ignore
|
|
85
|
-
, {
|
|
86
|
-
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
87
|
-
// @ts-ignore
|
|
88
|
-
disabled: value && Object.prototype.hasOwnProperty.call(value, 'managed_by'), value: AudienceTypes.AUDIENCE_TAG, icon: React.createElement(Icon, null, "label"), label: React.createElement(FormattedMessage, { id: "ui.composer.layer.audience.tag", defaultMessage: "ui.composer.layer.audience.tag" }) })),
|
|
74
|
+
React.createElement(Tab, { disabled: value && Boolean(value === null || value === void 0 ? void 0 : value.length), value: AudienceTypes.AUDIENCE_GROUP, icon: React.createElement(Icon, null, "groups"), label: React.createElement(FormattedMessage, { id: "ui.composer.layer.audience.group", defaultMessage: "ui.composer.layer.audience.group" }) }),
|
|
75
|
+
React.createElement(Tab, { disabled: value && Object.prototype.hasOwnProperty.call(value, 'managed_by'), value: AudienceTypes.AUDIENCE_TAG, icon: React.createElement(Icon, null, "label"), label: React.createElement(FormattedMessage, { id: "ui.composer.layer.audience.tag", defaultMessage: "ui.composer.layer.audience.tag" }) })),
|
|
89
76
|
React.createElement(Typography, { className: classes.message },
|
|
90
77
|
audience === AudienceTypes.AUDIENCE_ALL && (React.createElement(FormattedMessage, { id: "ui.composer.layer.audience.all.message", defaultMessage: "ui.composer.audience.layer.all.message" })),
|
|
91
78
|
audience === AudienceTypes.AUDIENCE_GROUP && (React.createElement(FormattedMessage, { id: "ui.composer.layer.audience.group.message", defaultMessage: "ui.composer.audience.layer.group.message" })),
|
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
import { SCGroupType } from '@selfcommunity/types';
|
|
2
|
-
import { EndpointType } from '@selfcommunity/api-services';
|
|
3
2
|
import { GroupProps } from '../Group';
|
|
4
3
|
export interface GroupsProps {
|
|
5
4
|
/**
|
|
@@ -8,24 +7,19 @@ export interface GroupsProps {
|
|
|
8
7
|
*/
|
|
9
8
|
className?: string;
|
|
10
9
|
/**
|
|
11
|
-
*
|
|
10
|
+
* Feed API Query Params
|
|
11
|
+
* @default [{'limit': 10, 'offset': 0}]
|
|
12
12
|
*/
|
|
13
|
-
|
|
13
|
+
endpointQueryParams?: Record<string, string | number>;
|
|
14
14
|
/**
|
|
15
15
|
* Props to spread to single group object
|
|
16
16
|
* @default {variant: 'outlined', ButtonBaseProps: {disableRipple: 'true'}}
|
|
17
17
|
*/
|
|
18
18
|
GroupComponentProps?: GroupProps;
|
|
19
|
-
/**
|
|
20
|
-
* Prefetch groups. Useful for SSR.
|
|
21
|
-
* Use this to init the component with groups
|
|
22
|
-
* @default null
|
|
23
|
-
*/
|
|
24
|
-
prefetchedGroups?: SCGroupType[];
|
|
25
19
|
/** If true, it means that the endpoint fetches all groups available
|
|
26
|
-
* @default
|
|
20
|
+
* @default true
|
|
27
21
|
*/
|
|
28
|
-
general
|
|
22
|
+
general: boolean;
|
|
29
23
|
/**
|
|
30
24
|
* Show/Hide filters
|
|
31
25
|
* @default false
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { __rest } from "tslib";
|
|
2
2
|
import React, { useEffect, useMemo, useState } from 'react';
|
|
3
3
|
import { styled } from '@mui/material/styles';
|
|
4
|
-
import { Box, Grid, TextField, Typography } from '@mui/material';
|
|
5
|
-
import { http } from '@selfcommunity/api-services';
|
|
4
|
+
import { Box, Button, Grid, TextField, Typography } from '@mui/material';
|
|
5
|
+
import { Endpoints, GroupService, http } from '@selfcommunity/api-services';
|
|
6
6
|
import { Logger, sortByAttr } from '@selfcommunity/utils';
|
|
7
|
-
import { SCPreferences,
|
|
7
|
+
import { SCPreferences, useSCPreferences, useSCUser } from '@selfcommunity/react-core';
|
|
8
8
|
import Skeleton from './Skeleton';
|
|
9
9
|
import { FormattedMessage } from 'react-intl';
|
|
10
10
|
import classNames from 'classnames';
|
|
@@ -12,7 +12,9 @@ import { SCOPE_SC_UI } from '../../constants/Errors';
|
|
|
12
12
|
import { useThemeProps } from '@mui/system';
|
|
13
13
|
import HiddenPlaceholder from '../../shared/HiddenPlaceholder';
|
|
14
14
|
import { PREFIX } from './constants';
|
|
15
|
-
import Group from '../Group';
|
|
15
|
+
import Group, { GroupSkeleton } from '../Group';
|
|
16
|
+
import { DEFAULT_PAGINATION_LIMIT, DEFAULT_PAGINATION_OFFSET } from '../../constants/Pagination';
|
|
17
|
+
import InfiniteScroll from '../../shared/InfiniteScroll';
|
|
16
18
|
const classes = {
|
|
17
19
|
root: `${PREFIX}-root`,
|
|
18
20
|
filters: `${PREFIX}-filter`,
|
|
@@ -63,10 +65,11 @@ export default function Groups(inProps) {
|
|
|
63
65
|
props: inProps,
|
|
64
66
|
name: PREFIX
|
|
65
67
|
});
|
|
66
|
-
const {
|
|
68
|
+
const { endpointQueryParams = { limit: DEFAULT_PAGINATION_LIMIT, offset: DEFAULT_PAGINATION_OFFSET }, className, GroupComponentProps = { variant: 'outlined', ButtonBaseProps: { disableRipple: true, component: Box } }, showFilters = false, filters, handleFilterGroups, general = true } = props, rest = __rest(props, ["endpointQueryParams", "className", "GroupComponentProps", "showFilters", "filters", "handleFilterGroups", "general"]);
|
|
67
69
|
// STATE
|
|
68
70
|
const [groups, setGroups] = useState([]);
|
|
69
71
|
const [loading, setLoading] = useState(true);
|
|
72
|
+
const [next, setNext] = useState(null);
|
|
70
73
|
const [filterName, setFilterName] = useState('');
|
|
71
74
|
// CONTEXT
|
|
72
75
|
const scUserContext = useSCUser();
|
|
@@ -76,19 +79,31 @@ export default function Groups(inProps) {
|
|
|
76
79
|
scPreferencesContext.preferences[SCPreferences.CONFIGURATIONS_CONTENT_AVAILABILITY].value, [scPreferencesContext.preferences]);
|
|
77
80
|
// CONST
|
|
78
81
|
const authUserId = scUserContext.user ? scUserContext.user.id : null;
|
|
79
|
-
//
|
|
80
|
-
const
|
|
82
|
+
// HANDLERS
|
|
83
|
+
const handleScrollUp = () => {
|
|
84
|
+
window.scrollTo({ left: 0, top: 0, behavior: 'smooth' });
|
|
85
|
+
};
|
|
81
86
|
/**
|
|
82
87
|
* Fetches groups list
|
|
83
88
|
*/
|
|
84
|
-
const fetchGroups = (
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
89
|
+
const fetchGroups = () => {
|
|
90
|
+
let groupService;
|
|
91
|
+
if (general) {
|
|
92
|
+
groupService = GroupService.searchGroups(endpointQueryParams);
|
|
93
|
+
}
|
|
94
|
+
else {
|
|
95
|
+
groupService = GroupService.getUserGroups(endpointQueryParams);
|
|
96
|
+
}
|
|
97
|
+
groupService
|
|
98
|
+
.then((res) => {
|
|
99
|
+
setGroups(res.results);
|
|
100
|
+
setNext(res.next);
|
|
101
|
+
setLoading(false);
|
|
102
|
+
})
|
|
103
|
+
.catch((error) => {
|
|
104
|
+
Logger.error(SCOPE_SC_UI, error);
|
|
88
105
|
});
|
|
89
|
-
|
|
90
|
-
return data.next ? data.results.concat(yield fetchGroups(data.next)) : data.results;
|
|
91
|
-
});
|
|
106
|
+
};
|
|
92
107
|
/**
|
|
93
108
|
* On mount, fetches groups list
|
|
94
109
|
*/
|
|
@@ -96,23 +111,10 @@ export default function Groups(inProps) {
|
|
|
96
111
|
if (!contentAvailability && !authUserId) {
|
|
97
112
|
return;
|
|
98
113
|
}
|
|
99
|
-
else if (prefetchedGroups.length) {
|
|
100
|
-
setGroups(prefetchedGroups);
|
|
101
|
-
setLoading(false);
|
|
102
|
-
}
|
|
103
114
|
else {
|
|
104
|
-
fetchGroups()
|
|
105
|
-
.then((data) => {
|
|
106
|
-
if (isMountedRef.current) {
|
|
107
|
-
setGroups(data);
|
|
108
|
-
setLoading(false);
|
|
109
|
-
}
|
|
110
|
-
})
|
|
111
|
-
.catch((error) => {
|
|
112
|
-
Logger.error(SCOPE_SC_UI, error);
|
|
113
|
-
});
|
|
115
|
+
fetchGroups();
|
|
114
116
|
}
|
|
115
|
-
}, [contentAvailability, authUserId
|
|
117
|
+
}, [contentAvailability, authUserId]);
|
|
116
118
|
const handleSubscribe = (group) => {
|
|
117
119
|
if (!general) {
|
|
118
120
|
const newGroups = [...groups];
|
|
@@ -120,6 +122,22 @@ export default function Groups(inProps) {
|
|
|
120
122
|
setGroups(_updated);
|
|
121
123
|
}
|
|
122
124
|
};
|
|
125
|
+
const handleNext = useMemo(() => () => {
|
|
126
|
+
if (!next) {
|
|
127
|
+
return;
|
|
128
|
+
}
|
|
129
|
+
return http
|
|
130
|
+
.request({
|
|
131
|
+
url: next,
|
|
132
|
+
method: general ? Endpoints.SearchGroups.method : Endpoints.GetUserGroups.method
|
|
133
|
+
})
|
|
134
|
+
.then((res) => {
|
|
135
|
+
setGroups([...groups, ...res.data.results]);
|
|
136
|
+
setNext(res.data.next);
|
|
137
|
+
})
|
|
138
|
+
.catch((error) => console.log(error))
|
|
139
|
+
.then(() => setLoading(false));
|
|
140
|
+
}, [next]);
|
|
123
141
|
/**
|
|
124
142
|
* Get groups filtered
|
|
125
143
|
*/
|
|
@@ -146,15 +164,22 @@ export default function Groups(inProps) {
|
|
|
146
164
|
const content = (React.createElement(React.Fragment, null,
|
|
147
165
|
showFilters && (React.createElement(Grid, { container: true, direction: "row", justifyContent: "center", alignItems: "center", className: classes.filters }, filters ? (filters) : (React.createElement(Grid, { item: true, xs: 12, md: 6 },
|
|
148
166
|
React.createElement(TextField, { fullWidth: true, value: filterName, label: React.createElement(FormattedMessage, { id: "ui.groups.filterByName", defaultMessage: "ui.groups.filterByName" }), variant: "outlined", onChange: handleOnChangeFilterName, disabled: loading }))))),
|
|
149
|
-
|
|
167
|
+
React.createElement(React.Fragment, null, !groups.length ? (React.createElement(Box, { className: classes.noResults },
|
|
150
168
|
React.createElement(Typography, { variant: "h4" },
|
|
151
169
|
React.createElement(FormattedMessage, { id: "ui.groups.noGroups.title", defaultMessage: "ui.groups.noGroups.title" })),
|
|
152
170
|
React.createElement(Typography, { variant: "body1" },
|
|
153
|
-
React.createElement(FormattedMessage, { id: "ui.groups.noGroups.subtitle", defaultMessage: "ui.groups.noGroups.subtitle" })))) : (React.createElement(
|
|
154
|
-
|
|
171
|
+
React.createElement(FormattedMessage, { id: "ui.groups.noGroups.subtitle", defaultMessage: "ui.groups.noGroups.subtitle" })))) : (React.createElement(InfiniteScroll, { dataLength: groups.length, next: handleNext, hasMoreNext: Boolean(next), loaderNext: React.createElement(GroupSkeleton, null), endMessage: React.createElement(Typography, { component: "div", className: classes.endMessage },
|
|
172
|
+
React.createElement(FormattedMessage, { id: "ui.groups.endMessage", defaultMessage: "ui.groups.endMessage", values: {
|
|
173
|
+
button: (chunk) => (React.createElement(Button, { color: "secondary", variant: "text", onClick: handleScrollUp }, chunk))
|
|
174
|
+
} })) },
|
|
175
|
+
React.createElement(Grid, { container: true, spacing: { xs: 2 }, className: classes.groups }, filteredGroups.map((group) => (React.createElement(Grid, { item: true, xs: 12, sm: 8, md: 6, key: group.id, className: classes.item },
|
|
176
|
+
React.createElement(Group, Object.assign({ group: group, groupId: group.id, groupSubscribeButtonProps: { onSubscribe: handleSubscribe } }, GroupComponentProps)))))))))));
|
|
155
177
|
// RENDER
|
|
156
178
|
if (!contentAvailability && !scUserContext.user) {
|
|
157
179
|
return React.createElement(HiddenPlaceholder, null);
|
|
158
180
|
}
|
|
181
|
+
if (loading) {
|
|
182
|
+
return React.createElement(Skeleton, null);
|
|
183
|
+
}
|
|
159
184
|
return (React.createElement(Root, Object.assign({ className: classNames(classes.root, className) }, rest), content));
|
|
160
185
|
}
|