@selfcommunity/react-ui 0.7.9-alpha.4 → 0.7.9-alpha.41

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 (132) hide show
  1. package/lib/cjs/components/ChangeGroupCover/ChangeGroupCover.js +24 -1
  2. package/lib/cjs/components/ChangeGroupPicture/ChangeGroupPicture.js +32 -11
  3. package/lib/cjs/components/Composer/Attributes/Attributes.js +3 -3
  4. package/lib/cjs/components/Composer/Composer.js +3 -5
  5. package/lib/cjs/components/Composer/Content/ContentPost/ContentPost.js +4 -3
  6. package/lib/cjs/components/Composer/Layer/AudienceLayer/AudienceLayer.d.ts +1 -2
  7. package/lib/cjs/components/Composer/Layer/AudienceLayer/AudienceLayer.js +18 -6
  8. package/lib/cjs/components/EditGroupButton/EditGroupButton.js +4 -0
  9. package/lib/cjs/components/FeedObject/FeedObject.d.ts +1 -0
  10. package/lib/cjs/components/FeedObject/FeedObject.js +23 -6
  11. package/lib/cjs/components/FeedUpdatesWidget/FeedUpdatesWidget.js +1 -1
  12. package/lib/cjs/components/Group/Group.js +9 -3
  13. package/lib/cjs/components/GroupForm/GroupForm.js +31 -9
  14. package/lib/cjs/components/GroupHeader/GroupHeader.d.ts +6 -5
  15. package/lib/cjs/components/GroupHeader/GroupHeader.js +52 -11
  16. package/lib/cjs/components/GroupHeader/Skeleton.d.ts +2 -4
  17. package/lib/cjs/components/GroupHeader/Skeleton.js +10 -10
  18. package/lib/cjs/components/GroupInfoWidget/GroupInfoWidget.js +40 -7
  19. package/lib/cjs/components/GroupInviteButton/GroupInviteButton.js +8 -7
  20. package/lib/cjs/components/GroupInvitedWidget/GroupInvitedWidget.d.ts +74 -0
  21. package/lib/cjs/components/GroupInvitedWidget/GroupInvitedWidget.js +197 -0
  22. package/lib/cjs/components/GroupInvitedWidget/Skeleton.d.ts +22 -0
  23. package/lib/cjs/components/GroupInvitedWidget/Skeleton.js +38 -0
  24. package/lib/cjs/components/GroupInvitedWidget/constants.d.ts +1 -0
  25. package/lib/cjs/components/GroupInvitedWidget/constants.js +4 -0
  26. package/lib/cjs/components/GroupInvitedWidget/index.d.ts +4 -0
  27. package/lib/cjs/components/GroupInvitedWidget/index.js +8 -0
  28. package/lib/cjs/components/GroupMembersButton/GroupMembersButton.d.ts +5 -0
  29. package/lib/cjs/components/GroupMembersButton/GroupMembersButton.js +7 -2
  30. package/lib/cjs/components/GroupMembersWidget/GroupMembersWidget.js +25 -4
  31. package/lib/cjs/components/GroupRequestsWidget/GroupRequestsWidget.d.ts +11 -5
  32. package/lib/cjs/components/GroupRequestsWidget/GroupRequestsWidget.js +18 -7
  33. package/lib/cjs/components/GroupSettingsIconButton/GroupSettingsIconButton.d.ts +48 -0
  34. package/lib/cjs/components/GroupSettingsIconButton/GroupSettingsIconButton.js +145 -0
  35. package/lib/cjs/components/GroupSettingsIconButton/index.d.ts +3 -0
  36. package/lib/cjs/components/GroupSettingsIconButton/index.js +5 -0
  37. package/lib/cjs/components/GroupSubscribeButton/GroupSubscribeButton.d.ts +8 -3
  38. package/lib/cjs/components/GroupSubscribeButton/GroupSubscribeButton.js +31 -10
  39. package/lib/cjs/components/Groups/Groups.d.ts +28 -13
  40. package/lib/cjs/components/Groups/Groups.js +71 -89
  41. package/lib/cjs/components/NavigationMenuIconButton/NavigationMenuIconButton.js +1 -1
  42. package/lib/cjs/components/NavigationToolbarMobile/NavigationToolbarMobile.d.ts +4 -0
  43. package/lib/cjs/components/NavigationToolbarMobile/NavigationToolbarMobile.js +2 -3
  44. package/lib/cjs/components/Notification/Group/Group.d.ts +15 -0
  45. package/lib/cjs/components/Notification/Group/Group.js +78 -0
  46. package/lib/cjs/components/Notification/Group/index.d.ts +3 -0
  47. package/lib/cjs/components/Notification/Group/index.js +5 -0
  48. package/lib/cjs/components/Notification/Notification.js +31 -1
  49. package/lib/cjs/components/Notification/PrivateMessage/PrivateMessage.js +16 -5
  50. package/lib/cjs/components/PrivateMessageComponent/PrivateMessageComponent.d.ts +1 -1
  51. package/lib/cjs/components/PrivateMessageComponent/PrivateMessageComponent.js +10 -7
  52. package/lib/cjs/components/PrivateMessageSnippetItem/PrivateMessageSnippetItem.js +11 -6
  53. package/lib/cjs/components/PrivateMessageSnippets/PrivateMessageSnippets.d.ts +3 -3
  54. package/lib/cjs/components/PrivateMessageSnippets/PrivateMessageSnippets.js +24 -6
  55. package/lib/cjs/components/PrivateMessageThread/PrivateMessageThread.d.ts +6 -1
  56. package/lib/cjs/components/PrivateMessageThread/PrivateMessageThread.js +45 -20
  57. package/lib/cjs/components/SearchAutocomplete/SearchAutocomplete.js +22 -5
  58. package/lib/cjs/components/SnippetNotifications/SnippetNotifications.js +7 -0
  59. package/lib/cjs/components/ToastNotifications/ToastNotifications.js +7 -0
  60. package/lib/cjs/components/User/User.d.ts +5 -0
  61. package/lib/cjs/components/User/User.js +5 -4
  62. package/lib/cjs/constants/PubSub.d.ts +27 -0
  63. package/lib/cjs/constants/PubSub.js +21 -0
  64. package/lib/cjs/index.d.ts +5 -2
  65. package/lib/cjs/index.js +12 -4
  66. package/lib/esm/components/ChangeGroupCover/ChangeGroupCover.js +24 -1
  67. package/lib/esm/components/ChangeGroupPicture/ChangeGroupPicture.js +32 -11
  68. package/lib/esm/components/Composer/Attributes/Attributes.js +3 -3
  69. package/lib/esm/components/Composer/Composer.js +3 -5
  70. package/lib/esm/components/Composer/Content/ContentPost/ContentPost.js +4 -3
  71. package/lib/esm/components/Composer/Layer/AudienceLayer/AudienceLayer.d.ts +1 -2
  72. package/lib/esm/components/Composer/Layer/AudienceLayer/AudienceLayer.js +18 -6
  73. package/lib/esm/components/EditGroupButton/EditGroupButton.js +5 -1
  74. package/lib/esm/components/FeedObject/FeedObject.d.ts +1 -0
  75. package/lib/esm/components/FeedObject/FeedObject.js +24 -7
  76. package/lib/esm/components/FeedUpdatesWidget/FeedUpdatesWidget.js +1 -1
  77. package/lib/esm/components/Group/Group.js +11 -5
  78. package/lib/esm/components/GroupForm/GroupForm.js +31 -9
  79. package/lib/esm/components/GroupHeader/GroupHeader.d.ts +6 -5
  80. package/lib/esm/components/GroupHeader/GroupHeader.js +54 -13
  81. package/lib/esm/components/GroupHeader/Skeleton.d.ts +2 -4
  82. package/lib/esm/components/GroupHeader/Skeleton.js +10 -10
  83. package/lib/esm/components/GroupInfoWidget/GroupInfoWidget.js +40 -7
  84. package/lib/esm/components/GroupInviteButton/GroupInviteButton.js +8 -7
  85. package/lib/esm/components/GroupInvitedWidget/GroupInvitedWidget.d.ts +74 -0
  86. package/lib/esm/components/GroupInvitedWidget/GroupInvitedWidget.js +194 -0
  87. package/lib/esm/components/GroupInvitedWidget/Skeleton.d.ts +22 -0
  88. package/lib/esm/components/GroupInvitedWidget/Skeleton.js +34 -0
  89. package/lib/esm/components/GroupInvitedWidget/constants.d.ts +1 -0
  90. package/lib/esm/components/GroupInvitedWidget/constants.js +1 -0
  91. package/lib/esm/components/GroupInvitedWidget/index.d.ts +4 -0
  92. package/lib/esm/components/GroupInvitedWidget/index.js +4 -0
  93. package/lib/esm/components/GroupMembersButton/GroupMembersButton.d.ts +5 -0
  94. package/lib/esm/components/GroupMembersButton/GroupMembersButton.js +8 -3
  95. package/lib/esm/components/GroupMembersWidget/GroupMembersWidget.js +26 -5
  96. package/lib/esm/components/GroupRequestsWidget/GroupRequestsWidget.d.ts +11 -5
  97. package/lib/esm/components/GroupRequestsWidget/GroupRequestsWidget.js +18 -7
  98. package/lib/esm/components/GroupSettingsIconButton/GroupSettingsIconButton.d.ts +48 -0
  99. package/lib/esm/components/GroupSettingsIconButton/GroupSettingsIconButton.js +142 -0
  100. package/lib/esm/components/GroupSettingsIconButton/index.d.ts +3 -0
  101. package/lib/esm/components/GroupSettingsIconButton/index.js +2 -0
  102. package/lib/esm/components/GroupSubscribeButton/GroupSubscribeButton.d.ts +8 -3
  103. package/lib/esm/components/GroupSubscribeButton/GroupSubscribeButton.js +32 -11
  104. package/lib/esm/components/Groups/Groups.d.ts +28 -13
  105. package/lib/esm/components/Groups/Groups.js +76 -94
  106. package/lib/esm/components/NavigationMenuIconButton/NavigationMenuIconButton.js +1 -1
  107. package/lib/esm/components/NavigationToolbarMobile/NavigationToolbarMobile.d.ts +4 -0
  108. package/lib/esm/components/NavigationToolbarMobile/NavigationToolbarMobile.js +2 -3
  109. package/lib/esm/components/Notification/Group/Group.d.ts +15 -0
  110. package/lib/esm/components/Notification/Group/Group.js +75 -0
  111. package/lib/esm/components/Notification/Group/index.d.ts +3 -0
  112. package/lib/esm/components/Notification/Group/index.js +2 -0
  113. package/lib/esm/components/Notification/Notification.js +31 -1
  114. package/lib/esm/components/Notification/PrivateMessage/PrivateMessage.js +16 -5
  115. package/lib/esm/components/PrivateMessageComponent/PrivateMessageComponent.d.ts +1 -1
  116. package/lib/esm/components/PrivateMessageComponent/PrivateMessageComponent.js +11 -8
  117. package/lib/esm/components/PrivateMessageSnippetItem/PrivateMessageSnippetItem.js +11 -6
  118. package/lib/esm/components/PrivateMessageSnippets/PrivateMessageSnippets.d.ts +3 -3
  119. package/lib/esm/components/PrivateMessageSnippets/PrivateMessageSnippets.js +26 -8
  120. package/lib/esm/components/PrivateMessageThread/PrivateMessageThread.d.ts +6 -1
  121. package/lib/esm/components/PrivateMessageThread/PrivateMessageThread.js +47 -22
  122. package/lib/esm/components/SearchAutocomplete/SearchAutocomplete.js +22 -5
  123. package/lib/esm/components/SnippetNotifications/SnippetNotifications.js +7 -0
  124. package/lib/esm/components/ToastNotifications/ToastNotifications.js +7 -0
  125. package/lib/esm/components/User/User.d.ts +5 -0
  126. package/lib/esm/components/User/User.js +5 -4
  127. package/lib/esm/constants/PubSub.d.ts +27 -0
  128. package/lib/esm/constants/PubSub.js +18 -0
  129. package/lib/esm/index.d.ts +5 -2
  130. package/lib/esm/index.js +7 -4
  131. package/lib/umd/react-ui.js +1 -1
  132. package/package.json +6 -6
@@ -1,31 +1,46 @@
1
+ import { SCGroupType } from '@selfcommunity/types';
1
2
  import { EndpointType } from '@selfcommunity/api-services';
2
- import { CacheStrategies } from '@selfcommunity/utils';
3
3
  import { GroupProps } from '../Group';
4
4
  export interface GroupsProps {
5
+ /**
6
+ * Overrides or extends the styles applied to the component.
7
+ * @default null
8
+ */
9
+ className?: string;
5
10
  /**
6
11
  * Endpoint to call
7
12
  */
8
- endpoint: EndpointType;
13
+ endpoint?: EndpointType;
9
14
  /**
10
- * Hides this component
11
- * @default false
15
+ * Props to spread to single group object
16
+ * @default {variant: 'outlined', ButtonBaseProps: {disableRipple: 'true'}}
12
17
  */
13
- autoHide?: boolean;
18
+ GroupComponentProps?: GroupProps;
14
19
  /**
15
- * Limit the number of users to show
20
+ * Prefetch groups. Useful for SSR.
21
+ * Use this to init the component with groups
22
+ * @default null
23
+ */
24
+ prefetchedGroups?: SCGroupType[];
25
+ /** If true, it means that the endpoint fetches all groups available
26
+ * @default null
27
+ */
28
+ general?: boolean;
29
+ /**
30
+ * Show/Hide filters
16
31
  * @default false
17
32
  */
18
- limit?: number;
33
+ showFilters?: boolean;
19
34
  /**
20
- * Caching strategies
21
- * @default CacheStrategies.CACHE_FIRST
35
+ * Override filter func
36
+ * @default null
22
37
  */
23
- cacheStrategy?: CacheStrategies;
38
+ handleFilterGroups?: (groups: SCGroupType[]) => SCGroupType[];
24
39
  /**
25
- * Props to spread to single group object
26
- * @default empty object
40
+ * Filters component
41
+ * @param props
27
42
  */
28
- GroupProps?: GroupProps;
43
+ filters?: JSX.Element;
29
44
  /**
30
45
  * Other props
31
46
  */
@@ -7,7 +7,6 @@ const material_1 = require("@mui/material");
7
7
  const api_services_1 = require("@selfcommunity/api-services");
8
8
  const utils_1 = require("@selfcommunity/utils");
9
9
  const react_core_1 = require("@selfcommunity/react-core");
10
- const widget_1 = require("../../utils/widget");
11
10
  const Skeleton_1 = tslib_1.__importDefault(require("./Skeleton"));
12
11
  const react_intl_1 = require("react-intl");
13
12
  const classnames_1 = tslib_1.__importDefault(require("classnames"));
@@ -18,6 +17,7 @@ const constants_1 = require("./constants");
18
17
  const Group_1 = tslib_1.__importDefault(require("../Group"));
19
18
  const classes = {
20
19
  root: `${constants_1.PREFIX}-root`,
20
+ filters: `${constants_1.PREFIX}-filter`,
21
21
  groups: `${constants_1.PREFIX}-groups`,
22
22
  item: `${constants_1.PREFIX}-item`,
23
23
  noResults: `${constants_1.PREFIX}-no-results`,
@@ -65,117 +65,99 @@ function Groups(inProps) {
65
65
  props: inProps,
66
66
  name: constants_1.PREFIX
67
67
  });
68
- const { endpoint, autoHide = false, limit = 6, className, cacheStrategy = utils_1.CacheStrategies.NETWORK_ONLY, onHeightChange, onStateChange, GroupProps = { variant: 'outlined', ButtonBaseProps: { disableRipple: true, component: material_1.Box } } } = props, rest = tslib_1.__rest(props, ["endpoint", "autoHide", "limit", "className", "cacheStrategy", "onHeightChange", "onStateChange", "GroupProps"]);
68
+ const { endpoint, className, GroupComponentProps = { variant: 'outlined', ButtonBaseProps: { disableRipple: true, component: material_1.Box } }, prefetchedGroups = [], showFilters = false, filters, handleFilterGroups, general } = props, rest = tslib_1.__rest(props, ["endpoint", "className", "GroupComponentProps", "prefetchedGroups", "showFilters", "filters", "handleFilterGroups", "general"]);
69
69
  // STATE
70
- const [state, dispatch] = (0, react_1.useReducer)(widget_1.dataWidgetReducer, {
71
- isLoadingNext: false,
72
- next: null,
73
- cacheKey: react_core_1.SCCache.getWidgetStateCacheKey(react_core_1.SCCache.GROUPS_LIST_TOOLS_STATE_CACHE_PREFIX_KEY),
74
- cacheStrategy,
75
- visibleItems: limit
76
- }, widget_1.stateWidgetInitializer);
70
+ const [groups, setGroups] = (0, react_1.useState)([]);
71
+ const [loading, setLoading] = (0, react_1.useState)(true);
72
+ const [filterName, setFilterName] = (0, react_1.useState)('');
77
73
  // CONTEXT
78
74
  const scUserContext = (0, react_core_1.useSCUser)();
79
75
  const scPreferencesContext = (0, react_core_1.useSCPreferences)();
80
76
  // MEMO
81
77
  const contentAvailability = (0, react_1.useMemo)(() => react_core_1.SCPreferences.CONFIGURATIONS_CONTENT_AVAILABILITY in scPreferencesContext.preferences &&
82
78
  scPreferencesContext.preferences[react_core_1.SCPreferences.CONFIGURATIONS_CONTENT_AVAILABILITY].value, [scPreferencesContext.preferences]);
83
- // HOOKS
84
- // const theme = useTheme<SCThemeType>();
85
- // const isMobile = useMediaQuery(theme.breakpoints.down('md'));
79
+ // CONST
80
+ const authUserId = scUserContext.user ? scUserContext.user.id : null;
81
+ // REFS
82
+ const isMountedRef = (0, react_core_1.useIsComponentMountedRef)();
86
83
  /**
87
- * Initialize component
88
- * Fetch data only if the component is not initialized, and it is not loading data
84
+ * Fetches groups list
85
+ */
86
+ const fetchGroups = (next = endpoint.url({})) => tslib_1.__awaiter(this, void 0, void 0, function* () {
87
+ const response = yield api_services_1.http.request({
88
+ url: next,
89
+ method: endpoint.method
90
+ });
91
+ const data = response.data;
92
+ return data.next ? data.results.concat(yield fetchGroups(data.next)) : data.results;
93
+ });
94
+ /**
95
+ * On mount, fetches groups list
89
96
  */
90
- const _initComponent = (0, react_1.useMemo)(() => () => {
91
- if (!state.initialized && !state.isLoadingNext) {
92
- dispatch({ type: widget_1.actionWidgetTypes.LOADING_NEXT });
93
- api_services_1.http
94
- .request({
95
- url: endpoint.url({ limit }),
96
- method: endpoint.method
97
- })
98
- .then((payload) => {
99
- dispatch({ type: widget_1.actionWidgetTypes.LOAD_NEXT_SUCCESS, payload: Object.assign(Object.assign({}, payload.data), { initialized: true }) });
100
- })
101
- .catch((error) => {
102
- dispatch({ type: widget_1.actionWidgetTypes.LOAD_NEXT_FAILURE, payload: { errorLoadNext: error } });
103
- utils_1.Logger.error(Errors_1.SCOPE_SC_UI, error);
104
- });
105
- }
106
- }, [state.isLoadingNext, state.initialized, endpoint, limit, dispatch]);
107
- // EFFECTS
108
97
  (0, react_1.useEffect)(() => {
109
- var _a;
110
- let _t;
111
- if ((contentAvailability || (!contentAvailability && ((_a = scUserContext.user) === null || _a === void 0 ? void 0 : _a.id))) && scUserContext.user !== undefined) {
112
- _t = setTimeout(_initComponent);
113
- return () => {
114
- _t && clearTimeout(_t);
115
- };
98
+ if (!contentAvailability && !authUserId) {
99
+ return;
116
100
  }
117
- }, [scUserContext.user, contentAvailability]);
118
- (0, react_1.useEffect)(() => {
119
- if (state.next && state.results.length === limit && state.initialized) {
120
- dispatch({ type: widget_1.actionWidgetTypes.LOADING_NEXT });
121
- api_services_1.http
122
- .request({
123
- url: endpoint.url({ offset: limit, limit: 10 }),
124
- method: endpoint.method
125
- })
126
- .then((payload) => {
127
- dispatch({ type: widget_1.actionWidgetTypes.LOAD_NEXT_SUCCESS, payload: payload.data });
101
+ else if (prefetchedGroups.length) {
102
+ setGroups(prefetchedGroups);
103
+ setLoading(false);
104
+ }
105
+ else {
106
+ fetchGroups()
107
+ .then((data) => {
108
+ if (isMountedRef.current) {
109
+ setGroups(data);
110
+ setLoading(false);
111
+ }
128
112
  })
129
113
  .catch((error) => {
130
- dispatch({ type: widget_1.actionWidgetTypes.LOAD_NEXT_FAILURE, payload: { errorLoadNext: error } });
131
114
  utils_1.Logger.error(Errors_1.SCOPE_SC_UI, error);
132
115
  });
133
116
  }
134
- }, [state.next, state.results.length, state.initialized, limit]);
117
+ }, [contentAvailability, authUserId, prefetchedGroups.length]);
118
+ const handleSubscribe = (group) => {
119
+ if (!general) {
120
+ const newGroups = [...groups];
121
+ const _updated = newGroups.filter((g) => g.id !== group.id);
122
+ setGroups(_updated);
123
+ }
124
+ };
135
125
  /**
136
- * Virtual feed update
126
+ * Get groups filtered
137
127
  */
138
- (0, react_1.useEffect)(() => {
139
- onHeightChange && onHeightChange();
140
- }, [state.results]);
141
- (0, react_1.useEffect)(() => {
142
- if (!endpoint || (!contentAvailability && !scUserContext.user)) {
143
- return;
128
+ const getFilteredGroups = () => {
129
+ if (handleFilterGroups) {
130
+ return handleFilterGroups(groups);
144
131
  }
145
- else if (cacheStrategy === utils_1.CacheStrategies.NETWORK_ONLY) {
146
- onStateChange && onStateChange({ cacheStrategy: utils_1.CacheStrategies.CACHE_FIRST });
147
- }
148
- }, [scUserContext.user, endpoint, contentAvailability]);
149
- (0, react_1.useEffect)(() => {
150
- if (!endpoint || !scUserContext.user || !state.initialized) {
151
- return;
132
+ if (filterName) {
133
+ return groups.filter((g) => g.name.toLowerCase().includes(filterName.toLowerCase()));
152
134
  }
153
- }, []);
154
- // HANDLERS
155
- const handleNext = (0, react_1.useMemo)(() => () => {
156
- dispatch({ type: widget_1.actionWidgetTypes.LOADING_NEXT });
157
- api_services_1.http
158
- .request({
159
- url: state.next,
160
- method: endpoint.method
161
- })
162
- .then((res) => {
163
- dispatch({ type: widget_1.actionWidgetTypes.LOAD_NEXT_SUCCESS, payload: res.data });
164
- });
165
- }, [dispatch, state.next, state.isLoadingNext, state.initialized, endpoint.method]);
135
+ return groups;
136
+ };
137
+ /**
138
+ * Handle change filter name
139
+ * @param event
140
+ */
141
+ const handleOnChangeFilterName = (event) => {
142
+ setFilterName(event.target.value);
143
+ };
144
+ /**
145
+ * Renders groups list
146
+ */
147
+ const filteredGroups = (0, utils_1.sortByAttr)(getFilteredGroups(), 'order');
148
+ const content = (react_1.default.createElement(react_1.default.Fragment, null,
149
+ 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
+ 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
+ loading ? (react_1.default.createElement(Skeleton_1.default, null)) : (react_1.default.createElement(react_1.default.Fragment, null, !groups.length ? (react_1.default.createElement(material_1.Box, { className: classes.noResults },
152
+ react_1.default.createElement(material_1.Typography, { variant: "h4" },
153
+ react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groups.noGroups.title", defaultMessage: "ui.groups.noGroups.title" })),
154
+ 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(material_1.Grid, { container: true, spacing: { xs: 3 }, 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 },
156
+ react_1.default.createElement(Group_1.default, Object.assign({ group: group, groupId: group.id, groupSubscribeButtonProps: { onSubscribe: handleSubscribe } }, GroupComponentProps)))))))))));
166
157
  // RENDER
167
- if ((autoHide && !state.count && state.initialized) || (!contentAvailability && !scUserContext.user) || !endpoint) {
158
+ if (!contentAvailability && !scUserContext.user) {
168
159
  return react_1.default.createElement(HiddenPlaceholder_1.default, null);
169
160
  }
170
- if (!state.initialized) {
171
- return react_1.default.createElement(Skeleton_1.default, null);
172
- }
173
- const content = (react_1.default.createElement(react_1.default.Fragment, null, !state.count ? (react_1.default.createElement(material_1.Typography, { className: classes.noResults, variant: "body2" },
174
- react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groupRequestsWidget.subtitle.noResults", defaultMessage: "" }))) : (react_1.default.createElement(react_1.default.Fragment, null,
175
- react_1.default.createElement(material_1.Grid, { container: true, spacing: { xs: 3 }, className: classes.groups }, state.results.slice(0, state.visibleItems).map((group) => (react_1.default.createElement(material_1.Grid, { item: true, xs: 12, sm: 8, md: 6, key: group.id, className: classes.item },
176
- react_1.default.createElement(Group_1.default, Object.assign({ actions: react_1.default.createElement(react_1.default.Fragment, null), group: group, groupId: group.id, buttonProps: { onClick: () => console.log(group) } }, GroupProps)))))),
177
- state.count > state.visibleItems && (react_1.default.createElement(material_1.Button, { className: classes.showMore, onClick: handleNext },
178
- react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groupRequestsWidget.button.showMore", defaultMessage: "ui.groupRequestsWidget.button.showMore" })))))));
179
161
  return (react_1.default.createElement(Root, Object.assign({ className: (0, classnames_1.default)(classes.root, className) }, rest), content));
180
162
  }
181
163
  exports.default = Groups;
@@ -62,7 +62,7 @@ function NavigationMenuIconButton(inProps) {
62
62
  props: inProps,
63
63
  name: PREFIX
64
64
  });
65
- const { className = null, DrawerProps = { anchor: 'left' }, drawerContent = react_1.default.createElement(DefaultDrawerContent_1.default, null), drawerHeaderContent = react_1.default.createElement(DefaultHeaderContent_1.default, null), ScrollContainerProps = {} } = props, rest = tslib_1.__rest(props, ["className", "DrawerProps", "drawerContent", "drawerHeaderContent", "ScrollContainerProps"]);
65
+ const { className = null, DrawerProps = { anchor: 'left' }, drawerHeaderContent = react_1.default.createElement(DefaultHeaderContent_1.default, null), drawerContent = react_1.default.createElement(DefaultDrawerContent_1.default, null), ScrollContainerProps = {} } = props, rest = tslib_1.__rest(props, ["className", "DrawerProps", "drawerHeaderContent", "drawerContent", "ScrollContainerProps"]);
66
66
  // STATE
67
67
  const [anchorEl, setAnchorEl] = (0, react_1.useState)(null);
68
68
  // CONTEXT
@@ -8,6 +8,10 @@ export interface NavigationToolbarMobileProps extends ToolbarProps {
8
8
  * Disable search action if possible
9
9
  */
10
10
  disableSearch?: boolean;
11
+ /**
12
+ * Preserve the same as the desktop version
13
+ */
14
+ preserveDesktopLogo?: boolean;
11
15
  /**
12
16
  * Props spread to SearchAutocomplete component
13
17
  */
@@ -64,7 +64,7 @@ function NavigationToolbarMobile(inProps) {
64
64
  props: inProps,
65
65
  name: constants_1.PREFIX
66
66
  });
67
- const { className = '', disableSearch = false, SearchAutocompleteProps = {}, children = null, startActions = null, endActions = null, NavigationMenuIconButtonComponent = NavigationMenuIconButton_1.default, NavigationSettingsIconButtonComponent = NavigationSettingsIconButton_1.default } = props, rest = tslib_1.__rest(props, ["className", "disableSearch", "SearchAutocompleteProps", "children", "startActions", "endActions", "NavigationMenuIconButtonComponent", "NavigationSettingsIconButtonComponent"]);
67
+ const { className = '', disableSearch = false, preserveDesktopLogo = false, SearchAutocompleteProps = {}, children = null, startActions = null, endActions = null, NavigationMenuIconButtonComponent = NavigationMenuIconButton_1.default, NavigationSettingsIconButtonComponent = NavigationSettingsIconButton_1.default } = props, rest = tslib_1.__rest(props, ["className", "disableSearch", "preserveDesktopLogo", "SearchAutocompleteProps", "children", "startActions", "endActions", "NavigationMenuIconButtonComponent", "NavigationSettingsIconButtonComponent"]);
68
68
  // CONTEXT
69
69
  const scUserContext = (0, react_core_1.useSCUser)();
70
70
  const scRoutingContext = (0, react_core_1.useSCRouting)();
@@ -85,8 +85,7 @@ function NavigationToolbarMobile(inProps) {
85
85
  }
86
86
  const _children = children || (react_1.default.createElement(react_1.default.Fragment, null,
87
87
  react_1.default.createElement(NavigationMenuIconButtonComponent, null),
88
- react_1.default.createElement(react_core_1.Link, { to: scRoutingContext.url(react_core_1.SCRoutes.HOME_ROUTE_NAME, {}), className: classes.logo },
89
- react_1.default.createElement("img", { src: preferences[react_core_1.SCPreferences.LOGO_NAVBAR_LOGO_MOBILE].value, alt: "logo" }))));
88
+ react_1.default.createElement(react_core_1.Link, { to: scRoutingContext.url(react_core_1.SCRoutes.HOME_ROUTE_NAME, {}), className: classes.logo }, !preserveDesktopLogo ? (react_1.default.createElement("img", { src: preferences[react_core_1.SCPreferences.LOGO_NAVBAR_LOGO_MOBILE].value, alt: "logo" })) : (react_1.default.createElement("img", { src: preferences[react_core_1.SCPreferences.LOGO_NAVBAR_LOGO].value, alt: "logo" })))));
90
89
  return (react_1.default.createElement(Root, Object.assign({ className: (0, classnames_1.default)(className, classes.root) }, rest),
91
90
  _children,
92
91
  startActions,
@@ -0,0 +1,15 @@
1
+ import { SCNotificationGroupActivityType } from '@selfcommunity/types';
2
+ import { NotificationItemProps } from '../../../shared/NotificationItem';
3
+ export interface NotificationGroupProps extends Pick<NotificationItemProps, Exclude<keyof NotificationItemProps, 'image' | 'disableTypography' | 'primary' | 'primaryTypographyProps' | 'secondary' | 'secondaryTypographyProps' | 'actions' | 'footer' | 'isNew'>> {
4
+ /**
5
+ * Notification obj
6
+ * @default null
7
+ */
8
+ notificationObject: SCNotificationGroupActivityType;
9
+ }
10
+ /**
11
+ * This component render the content of the notification of type group
12
+ * @constructor
13
+ * @param props
14
+ */
15
+ export default function GroupNotification(props: NotificationGroupProps): JSX.Element;
@@ -0,0 +1,78 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const tslib_1 = require("tslib");
4
+ const react_1 = tslib_1.__importStar(require("react"));
5
+ const styles_1 = require("@mui/material/styles");
6
+ const material_1 = require("@mui/material");
7
+ const react_core_1 = require("@selfcommunity/react-core");
8
+ const types_1 = require("@selfcommunity/types");
9
+ const react_intl_1 = require("react-intl");
10
+ const DateTimeAgo_1 = tslib_1.__importDefault(require("../../../shared/DateTimeAgo"));
11
+ const classnames_1 = tslib_1.__importDefault(require("classnames"));
12
+ const types_2 = require("../../../types");
13
+ const NotificationItem_1 = tslib_1.__importDefault(require("../../../shared/NotificationItem"));
14
+ const lab_1 = require("@mui/lab");
15
+ const UserDeletedSnackBar_1 = tslib_1.__importDefault(require("../../../shared/UserDeletedSnackBar"));
16
+ const UserAvatar_1 = tslib_1.__importDefault(require("../../../shared/UserAvatar"));
17
+ const constants_1 = require("../constants");
18
+ const classes = {
19
+ root: `${constants_1.PREFIX}-group-root`,
20
+ avatar: `${constants_1.PREFIX}-avatar`,
21
+ actions: `${constants_1.PREFIX}-actions`,
22
+ acceptButton: `${constants_1.PREFIX}-reply-button`,
23
+ activeAt: `${constants_1.PREFIX}-active-at`,
24
+ username: `${constants_1.PREFIX}-username`
25
+ };
26
+ const Root = (0, styles_1.styled)(NotificationItem_1.default, {
27
+ name: constants_1.PREFIX,
28
+ slot: 'GroupRoot'
29
+ })(() => ({}));
30
+ /**
31
+ * This component render the content of the notification of type group
32
+ * @constructor
33
+ * @param props
34
+ */
35
+ function GroupNotification(props) {
36
+ // PROPS
37
+ const { notificationObject, id = `n_${props.notificationObject['sid']}`, className, template = types_2.SCNotificationObjectTemplateType.DETAIL } = props, rest = tslib_1.__rest(props, ["notificationObject", "id", "className", "template"]);
38
+ // CONTEXT
39
+ const scRoutingContext = (0, react_core_1.useSCRouting)();
40
+ const scUserContext = (0, react_1.useContext)(react_core_1.SCUserContext);
41
+ const manager = scUserContext.managers.groups;
42
+ // STATE
43
+ const [status, setStatus] = (0, react_1.useState)(null);
44
+ const [openAlert, setOpenAlert] = (0, react_1.useState)(false);
45
+ // CONST
46
+ const isSnippetTemplate = template === types_2.SCNotificationObjectTemplateType.SNIPPET;
47
+ const isToastTemplate = template === types_2.SCNotificationObjectTemplateType.TOAST;
48
+ (0, react_1.useEffect)(() => {
49
+ setStatus(manager.subscriptionStatus(notificationObject.group));
50
+ }, [manager.subscriptionStatus, notificationObject.group]);
51
+ // RENDER
52
+ if (isSnippetTemplate || isToastTemplate) {
53
+ return (react_1.default.createElement(Root, Object.assign({ id: id, className: (0, classnames_1.default)(classes.root, className, `${constants_1.PREFIX}-${template}`), template: template, isNew: notificationObject.is_new, disableTypography: true, image: react_1.default.createElement(react_core_1.Link, Object.assign({}, (!notificationObject.user.deleted && {
54
+ to: scRoutingContext.url(react_core_1.SCRoutes.USER_PROFILE_ROUTE_NAME, notificationObject.user)
55
+ }), { onClick: notificationObject.user.deleted ? () => setOpenAlert(true) : null }),
56
+ react_1.default.createElement(UserAvatar_1.default, { hide: !notificationObject.user.community_badge, smaller: true },
57
+ react_1.default.createElement(material_1.Avatar, { alt: notificationObject.user.username, variant: "circular", src: notificationObject.user.avatar, classes: { root: classes.avatar } }))), primary: react_1.default.createElement(material_1.Box, null,
58
+ react_1.default.createElement(react_core_1.Link, Object.assign({}, (!notificationObject.user.deleted && {
59
+ to: scRoutingContext.url(react_core_1.SCRoutes.USER_PROFILE_ROUTE_NAME, notificationObject.user)
60
+ }), { onClick: notificationObject.user.deleted ? () => setOpenAlert(true) : null, className: classes.username }), notificationObject.user.username),
61
+ ' ',
62
+ react_1.default.createElement(react_intl_1.FormattedMessage, { id: `ui.notification.${notificationObject.type}`, defaultMessage: `ui.notification.${notificationObject.type}`, values: {
63
+ group: notificationObject.group.name,
64
+ link: (...chunks) => react_1.default.createElement(react_core_1.Link, { to: scRoutingContext.url(react_core_1.SCRoutes.GROUP_ROUTE_NAME, notificationObject.group) }, chunks)
65
+ } })), footer: isToastTemplate && (react_1.default.createElement(material_1.Stack, { direction: "row", justifyContent: "space-between", alignItems: "center", spacing: 2 },
66
+ react_1.default.createElement(DateTimeAgo_1.default, { date: notificationObject.active_at }),
67
+ status && status !== types_1.SCGroupSubscriptionStatusType.SUBSCRIBED && (react_1.default.createElement(material_1.Typography, { color: "primary" },
68
+ react_1.default.createElement(react_core_1.Link, { to: scRoutingContext.url(react_core_1.SCRoutes.GROUP_ROUTE_NAME, notificationObject.group) },
69
+ react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groupSubscribeButton.accept", defaultMessage: "ui.groupSubscribeButton.accept" })))))) }, rest)));
70
+ }
71
+ return (react_1.default.createElement(react_1.default.Fragment, null,
72
+ react_1.default.createElement(Root, Object.assign({ id: id, className: (0, classnames_1.default)(classes.root, className, `${constants_1.PREFIX}-${template}`), template: template, isNew: notificationObject.is_new, disableTypography: true, actions: react_1.default.createElement(material_1.Stack, { direction: "row", justifyContent: "space-between", alignItems: "center", spacing: 2 },
73
+ react_1.default.createElement(DateTimeAgo_1.default, { date: notificationObject.active_at, className: classes.activeAt }),
74
+ status && status !== types_1.SCGroupSubscriptionStatusType.SUBSCRIBED && (react_1.default.createElement(lab_1.LoadingButton, { color: 'primary', variant: "outlined", size: "small", classes: { root: classes.acceptButton }, component: react_core_1.Link, loading: scUserContext.user ? status === null || manager.isLoading(notificationObject.group) : null, to: scRoutingContext.url(react_core_1.SCRoutes.GROUP_ROUTE_NAME, notificationObject.group) },
75
+ react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groupSubscribeButton.accept", defaultMessage: "ui.groupSubscribeButton.accept" })))) }, rest)),
76
+ openAlert && react_1.default.createElement(UserDeletedSnackBar_1.default, { open: openAlert, handleClose: () => setOpenAlert(false) })));
77
+ }
78
+ exports.default = GroupNotification;
@@ -0,0 +1,3 @@
1
+ import GroupNotification, { NotificationGroupProps } from './Group';
2
+ export default GroupNotification;
3
+ export { NotificationGroupProps };
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const tslib_1 = require("tslib");
4
+ const Group_1 = tslib_1.__importDefault(require("./Group"));
5
+ exports.default = Group_1.default;
@@ -35,6 +35,7 @@ const types_1 = require("@selfcommunity/types");
35
35
  const UserDeletedSnackBar_1 = tslib_1.__importDefault(require("../../shared/UserDeletedSnackBar"));
36
36
  const UserAvatar_1 = tslib_1.__importDefault(require("../../shared/UserAvatar"));
37
37
  const constants_1 = require("./constants");
38
+ const Group_1 = tslib_1.__importDefault(require("./Group"));
38
39
  const messages = (0, react_intl_1.defineMessages)({
39
40
  receivePrivateMessage: {
40
41
  id: 'ui.notification.receivePrivateMessage',
@@ -151,7 +152,7 @@ function UserNotification(inProps) {
151
152
  }
152
153
  /**
153
154
  * Handles vote
154
- * @param comment
155
+ * @param index
155
156
  */
156
157
  const handleVote = (index) => {
157
158
  return (contribution) => {
@@ -196,6 +197,29 @@ function UserNotification(inProps) {
196
197
  b: (...chunks) => react_1.default.createElement("strong", null, chunks)
197
198
  })) }));
198
199
  }
200
+ /**
201
+ * Group notifications header
202
+ */
203
+ if (notificationObject.aggregated &&
204
+ (notificationObject.aggregated[0].type === types_1.SCNotificationTypologyType.USER_INVITED_TO_JOIN_GROUP ||
205
+ notificationObject.aggregated[0].type === types_1.SCNotificationTypologyType.USER_ACCEPTED_TO_JOIN_GROUP ||
206
+ notificationObject.aggregated[0].type === types_1.SCNotificationTypologyType.USER_ADDED_TO_GROUP ||
207
+ notificationObject.aggregated[0].type === types_1.SCNotificationTypologyType.USER_REQUESTED_TO_JOIN_GROUP)) {
208
+ let groupNotification = notificationObject.aggregated[0];
209
+ return (react_1.default.createElement(material_1.CardHeader, { className: classes.header, avatar: react_1.default.createElement(react_core_1.Link, Object.assign({}, (!groupNotification.user.deleted && {
210
+ to: scRoutingContext.url(react_core_1.SCRoutes.USER_PROFILE_ROUTE_NAME, groupNotification.user)
211
+ }), { onClick: groupNotification.user.deleted ? () => setOpenAlert(true) : null }),
212
+ react_1.default.createElement(UserAvatar_1.default, { hide: !groupNotification.user.community_badge, smaller: true },
213
+ react_1.default.createElement(material_1.Avatar, { className: classes.avatar, alt: groupNotification.user.username, variant: "circular", src: groupNotification.user.avatar }))), titleTypographyProps: { className: classes.title, variant: 'subtitle1' }, title: react_1.default.createElement(react_1.default.Fragment, null,
214
+ react_1.default.createElement(react_core_1.Link, Object.assign({}, (!groupNotification.user.deleted && {
215
+ to: scRoutingContext.url(react_core_1.SCRoutes.USER_PROFILE_ROUTE_NAME, groupNotification.user)
216
+ }), { onClick: groupNotification.user.deleted ? () => setOpenAlert(true) : null, className: classes.username }), groupNotification.user.username),
217
+ ' ',
218
+ react_1.default.createElement(react_intl_1.FormattedMessage, { id: `ui.notification.${notificationObject.aggregated[0].type}`, defaultMessage: `ui.notification.${notificationObject.aggregated[0].type}`, values: {
219
+ group: groupNotification.group.name,
220
+ link: (...chunks) => react_1.default.createElement(react_core_1.Link, { to: scRoutingContext.url(react_core_1.SCRoutes.GROUP_ROUTE_NAME, groupNotification.group) }, chunks)
221
+ } })) }));
222
+ }
199
223
  /**
200
224
  * Comment, NestedComment, Follow Contribution header
201
225
  */
@@ -278,6 +302,12 @@ function UserNotification(inProps) {
278
302
  else if (n.type === types_1.SCNotificationTypologyType.CONTRIBUTION) {
279
303
  return react_1.default.createElement(Contribution_1.default, { notificationObject: n, key: i, onVote: handleVote(i) });
280
304
  }
305
+ else if (n.type === types_1.SCNotificationTypologyType.USER_ADDED_TO_GROUP ||
306
+ n.type === types_1.SCNotificationTypologyType.USER_INVITED_TO_JOIN_GROUP ||
307
+ n.type === types_1.SCNotificationTypologyType.USER_ACCEPTED_TO_JOIN_GROUP ||
308
+ n.type === types_1.SCNotificationTypologyType.USER_REQUESTED_TO_JOIN_GROUP) {
309
+ return react_1.default.createElement(Group_1.default, { notificationObject: n, key: i });
310
+ }
281
311
  return null;
282
312
  }
283
313
  /**
@@ -41,6 +41,7 @@ const Root = (0, styles_1.styled)(NotificationItem_1.default, {
41
41
  * @param props
42
42
  */
43
43
  function PrivateMessageNotification(props) {
44
+ var _a, _b, _c, _d, _e;
44
45
  // PROPS
45
46
  const { notificationObject, id = `n_${props.notificationObject['sid']}`, className, template = types_1.SCNotificationObjectTemplateType.DETAIL } = props, rest = tslib_1.__rest(props, ["notificationObject", "id", "className", "template"]);
46
47
  // CONTEXT
@@ -91,7 +92,9 @@ function PrivateMessageNotification(props) {
91
92
  react_1.default.createElement(react_intl_1.FormattedMessage, { id: 'ui.userToastNotifications.privateMessage.sentMessage', defaultMessage: 'ui.userToastNotifications.privateMessage.sentMessage' }),
92
93
  ":",
93
94
  react_1.default.createElement(material_1.Box, { className: classes.messageWrap },
94
- react_1.default.createElement(react_core_1.Link, { to: scRoutingContext.url(react_core_1.SCRoutes.USER_PRIVATE_MESSAGES_ROUTE_NAME, notificationObject.message.sender), className: classes.message },
95
+ react_1.default.createElement(react_core_1.Link, { to: ((_a = notificationObject.message) === null || _a === void 0 ? void 0 : _a.group)
96
+ ? scRoutingContext.url(react_core_1.SCRoutes.GROUP_MESSAGES_ROUTE_NAME, notificationObject.message.group)
97
+ : scRoutingContext.url(react_core_1.SCRoutes.USER_PRIVATE_MESSAGES_ROUTE_NAME, notificationObject.message.sender), className: classes.message },
95
98
  react_1.default.createElement(material_1.Typography, { variant: "body2", dangerouslySetInnerHTML: { __html: notificationObject.message.message } }))))),
96
99
  isSnippetTemplate && (react_1.default.createElement(material_1.Box, null,
97
100
  react_1.default.createElement(material_1.Typography, { component: "div", color: "inherit" },
@@ -99,13 +102,17 @@ function PrivateMessageNotification(props) {
99
102
  to: scRoutingContext.url(react_core_1.SCRoutes.USER_PROFILE_ROUTE_NAME, notificationObject.message.sender)
100
103
  }), { onClick: notificationObject.message.sender.deleted ? () => setOpenAlert(true) : null, className: classes.username }), notificationObject.message.sender.username),
101
104
  ' ',
102
- react_1.default.createElement(react_core_1.Link, { to: scRoutingContext.url(react_core_1.SCRoutes.USER_PRIVATE_MESSAGES_ROUTE_NAME, notificationObject.message.sender), className: classes.messageLabel }, intl.formatMessage(messages.receivePrivateMessage, {
105
+ react_1.default.createElement(react_core_1.Link, { to: ((_b = notificationObject.message) === null || _b === void 0 ? void 0 : _b.group)
106
+ ? scRoutingContext.url(react_core_1.SCRoutes.GROUP_MESSAGES_ROUTE_NAME, notificationObject.message.group)
107
+ : scRoutingContext.url(react_core_1.SCRoutes.USER_PRIVATE_MESSAGES_ROUTE_NAME, notificationObject.message.sender), className: classes.messageLabel }, intl.formatMessage(messages.receivePrivateMessage, {
103
108
  total: 1,
104
109
  b: (...chunks) => react_1.default.createElement("strong", null, chunks)
105
110
  })))))), footer: isToastTemplate && (react_1.default.createElement(material_1.Stack, { direction: "row", justifyContent: "space-between", alignItems: "center", spacing: 2 },
106
111
  react_1.default.createElement(DateTimeAgo_1.default, { date: notificationObject.active_at }),
107
112
  react_1.default.createElement(material_1.Typography, { color: "primary" },
108
- react_1.default.createElement(react_core_1.Link, { to: scRoutingContext.url(react_core_1.SCRoutes.USER_PRIVATE_MESSAGES_ROUTE_NAME, notificationObject.message.sender) }, scUserContext.user && follower ? (react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.userToastNotifications.replyMessage", defaultMessage: 'ui.userToastNotifications.replyMessage' })) : (react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.userToastNotifications.viewMessage", defaultMessage: 'ui.userToastNotifications.viewMessage' })))))) }, rest)));
113
+ react_1.default.createElement(react_core_1.Link, { to: ((_c = notificationObject.message) === null || _c === void 0 ? void 0 : _c.group)
114
+ ? scRoutingContext.url(react_core_1.SCRoutes.GROUP_MESSAGES_ROUTE_NAME, notificationObject.message.group)
115
+ : scRoutingContext.url(react_core_1.SCRoutes.USER_PRIVATE_MESSAGES_ROUTE_NAME, notificationObject.message.sender) }, scUserContext.user && follower ? (react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.userToastNotifications.replyMessage", defaultMessage: 'ui.userToastNotifications.replyMessage' })) : (react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.userToastNotifications.viewMessage", defaultMessage: 'ui.userToastNotifications.viewMessage' })))))) }, rest)));
109
116
  }
110
117
  return (react_1.default.createElement(react_1.default.Fragment, null,
111
118
  react_1.default.createElement(Root, Object.assign({ id: id, className: (0, classnames_1.default)(classes.root, className, `${constants_1.PREFIX}-${template}`), template: template, isNew: notificationObject.is_new, disableTypography: true, actions: react_1.default.createElement(material_1.Stack, { direction: "row", justifyContent: "space-between", alignItems: "center", spacing: 2 },
@@ -114,8 +121,12 @@ function PrivateMessageNotification(props) {
114
121
  ? null
115
122
  : scUserContext.user
116
123
  ? follower === null || manager.isLoading(notificationObject.message.sender)
117
- : null, to: scRoutingContext.url(react_core_1.SCRoutes.USER_PRIVATE_MESSAGES_ROUTE_NAME, notificationObject.message.sender) }, scUserContext.user && follower ? (react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.notification.privateMessage.btnReplyLabel", defaultMessage: "ui.notification.privateMessage.btnReplyLabel" })) : (react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.notification.privateMessage.btnViewLabel", defaultMessage: "ui.notification.privateMessage.btnViewLabel" })))), primary: react_1.default.createElement(material_1.Box, { className: classes.messageWrap },
118
- react_1.default.createElement(react_core_1.Link, { to: scRoutingContext.url(react_core_1.SCRoutes.USER_PRIVATE_MESSAGES_ROUTE_NAME, notificationObject.message.sender), className: classes.message },
124
+ : null, to: ((_d = notificationObject.message) === null || _d === void 0 ? void 0 : _d.group)
125
+ ? scRoutingContext.url(react_core_1.SCRoutes.GROUP_MESSAGES_ROUTE_NAME, notificationObject.message.group)
126
+ : scRoutingContext.url(react_core_1.SCRoutes.USER_PRIVATE_MESSAGES_ROUTE_NAME, notificationObject.message.sender) }, scUserContext.user && follower ? (react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.notification.privateMessage.btnReplyLabel", defaultMessage: "ui.notification.privateMessage.btnReplyLabel" })) : (react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.notification.privateMessage.btnViewLabel", defaultMessage: "ui.notification.privateMessage.btnViewLabel" })))), primary: react_1.default.createElement(material_1.Box, { className: classes.messageWrap },
127
+ react_1.default.createElement(react_core_1.Link, { to: ((_e = notificationObject.message) === null || _e === void 0 ? void 0 : _e.group)
128
+ ? scRoutingContext.url(react_core_1.SCRoutes.GROUP_MESSAGES_ROUTE_NAME, notificationObject.message.group)
129
+ : scRoutingContext.url(react_core_1.SCRoutes.USER_PRIVATE_MESSAGES_ROUTE_NAME, notificationObject.message.sender), className: classes.message },
119
130
  react_1.default.createElement(material_1.Typography, { variant: "body2", dangerouslySetInnerHTML: { __html: notificationObject.message.message } }))) }, rest)),
120
131
  openAlert && react_1.default.createElement(UserDeletedSnackBar_1.default, { open: openAlert, handleClose: () => setOpenAlert(false) })));
121
132
  }
@@ -8,7 +8,7 @@ export interface PrivateMessageComponentProps {
8
8
  * Handler on message click
9
9
  * @default null
10
10
  */
11
- onItemClick?: (id: any) => void;
11
+ onItemClick?: (id: any, type: any) => void;
12
12
  /**
13
13
  * Handler on single message open
14
14
  * @default null
@@ -67,6 +67,7 @@ function PrivateMessageComponent(inProps) {
67
67
  const isMobile = (0, material_1.useMediaQuery)(theme.breakpoints.down('md'));
68
68
  const [layout, setLayout] = (0, react_1.useState)('default');
69
69
  const [obj, setObj] = (0, react_1.useState)(id !== null && id !== void 0 ? id : null);
70
+ const [type, setType] = (0, react_1.useState)(null);
70
71
  const isNew = obj && obj === types_1.SCPrivateMessageStatusType.NEW;
71
72
  const [openNewMessage, setOpenNewMessage] = (0, react_1.useState)(isNew !== null && isNew !== void 0 ? isNew : false);
72
73
  const mobileSnippetsView = (layout === 'default' && !obj) || (layout === 'mobile' && !obj);
@@ -88,10 +89,12 @@ function PrivateMessageComponent(inProps) {
88
89
  /**
89
90
  * Handles thread opening on click
90
91
  * @param item
92
+ * @param type
91
93
  */
92
- const handleThreadOpening = (item) => {
93
- onItemClick && onItemClick(messageReceiver(item, authUserId));
94
- setObj(messageReceiver(item, authUserId));
94
+ const handleThreadOpening = (item, type) => {
95
+ onItemClick && onItemClick(item.group ? item.group.id : messageReceiver(item, authUserId), type);
96
+ setType(type);
97
+ setObj(item.group ? item : messageReceiver(item, authUserId));
95
98
  setOpenNewMessage(false);
96
99
  };
97
100
  /**
@@ -107,7 +110,7 @@ function PrivateMessageComponent(inProps) {
107
110
  const handleOpenNewMessage = () => {
108
111
  setOpenNewMessage(!openNewMessage);
109
112
  setObj(types_1.SCPrivateMessageStatusType.NEW);
110
- onItemClick && onItemClick(types_1.SCPrivateMessageStatusType.NEW);
113
+ onItemClick && onItemClick(types_1.SCPrivateMessageStatusType.NEW, types_1.SCPrivateMessageType.NEW);
111
114
  };
112
115
  /**
113
116
  * Handles new messages open from user profile page or notifications section
@@ -129,7 +132,7 @@ function PrivateMessageComponent(inProps) {
129
132
  * Handles state update when a new message is sent
130
133
  */
131
134
  const handleOnNewMessageSent = (msg, isOne) => {
132
- onItemClick && onItemClick(isOne ? messageReceiver(msg, authUserId) : '');
135
+ onItemClick && onItemClick(isOne ? messageReceiver(msg, authUserId) : '', msg.group ? types_1.SCPrivateMessageType.GROUP : types_1.SCPrivateMessageType.USER);
133
136
  setObj(isOne ? messageReceiver(msg, authUserId) : null);
134
137
  setOpenNewMessage(false);
135
138
  };
@@ -149,14 +152,14 @@ function PrivateMessageComponent(inProps) {
149
152
  onSnippetClick: handleThreadOpening,
150
153
  onNewMessageClick: handleOpenNewMessage,
151
154
  onDeleteConfirm: handleDeleteThread
152
- }, userObj: obj, clearSearch: clear, elevation: 0 })));
155
+ }, threadObj: obj, clearSearch: clear, elevation: 0 })));
153
156
  }
154
157
  /**
155
158
  * Renders thread section
156
159
  */
157
160
  function renderThread() {
158
161
  return (react_1.default.createElement(material_1.Grid, { item: true, xs: 12, md: 7, className: (0, classnames_1.default)(classes.threadBox, { [classes.hide]: isMobile && mobileSnippetsView }) },
159
- react_1.default.createElement(PrivateMessageThread_1.default, { userObj: obj, openNewMessage: openNewMessage, onNewMessageClose: handleMessageBack, onNewMessageSent: handleOnNewMessageSent, onSingleMessageOpen: handleSingleMessage, elevation: 0 })));
162
+ react_1.default.createElement(PrivateMessageThread_1.default, { threadObj: obj, type: type, openNewMessage: openNewMessage, onNewMessageClose: handleMessageBack, onNewMessageSent: handleOnNewMessageSent, onSingleMessageOpen: handleSingleMessage, elevation: 0 })));
160
163
  }
161
164
  /**
162
165
  * Renders the component (if not hidden by autoHide prop)