@selfcommunity/react-ui 0.7.9-alpha.3 → 0.7.9-alpha.31

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 (169) 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/CommentObject/CommentObject.js +18 -0
  4. package/lib/cjs/components/Composer/Attributes/Attributes.d.ts +1 -1
  5. package/lib/cjs/components/Composer/Attributes/Attributes.js +9 -2
  6. package/lib/cjs/components/Composer/Composer.d.ts +2 -1
  7. package/lib/cjs/components/Composer/Composer.js +39 -12
  8. package/lib/cjs/components/Composer/Content/ContentDiscussion/ContentDiscussion.js +7 -3
  9. package/lib/cjs/components/Composer/Content/ContentPost/ContentPost.js +4 -3
  10. package/lib/cjs/components/Composer/Layer/AudienceLayer/AudienceLayer.d.ts +7 -1
  11. package/lib/cjs/components/Composer/Layer/AudienceLayer/AudienceLayer.js +46 -12
  12. package/lib/cjs/components/CreateGroupButton/CreateGroupButton.d.ts +2 -2
  13. package/lib/cjs/components/CreateGroupButton/CreateGroupButton.js +5 -6
  14. package/lib/cjs/components/CustomAdv/CustomAdv.d.ts +4 -0
  15. package/lib/cjs/components/{CreateGroup/CreateGroup.d.ts → EditGroupButton/EditGroupButton.d.ts} +11 -16
  16. package/lib/cjs/components/EditGroupButton/EditGroupButton.js +61 -0
  17. package/lib/cjs/components/EditGroupButton/index.d.ts +3 -0
  18. package/lib/cjs/components/EditGroupButton/index.js +5 -0
  19. package/lib/cjs/components/FeedObject/Actions/Follow/Follow.js +18 -0
  20. package/lib/cjs/components/FeedObject/Actions/Share/Share.js +18 -0
  21. package/lib/cjs/components/FeedObject/FeedObject.d.ts +1 -0
  22. package/lib/cjs/components/FeedObject/FeedObject.js +43 -9
  23. package/lib/cjs/components/Group/Group.d.ts +4 -3
  24. package/lib/cjs/components/Group/Group.js +5 -4
  25. package/lib/cjs/components/Group/Skeleton.js +1 -1
  26. package/lib/cjs/components/GroupAutocomplete/GroupAutocomplete.d.ts +49 -0
  27. package/lib/cjs/components/GroupAutocomplete/GroupAutocomplete.js +101 -0
  28. package/lib/cjs/components/GroupAutocomplete/index.d.ts +3 -0
  29. package/lib/cjs/components/GroupAutocomplete/index.js +5 -0
  30. package/lib/cjs/components/GroupForm/GroupForm.d.ts +70 -0
  31. package/lib/cjs/components/GroupForm/GroupForm.js +239 -0
  32. package/lib/cjs/components/GroupForm/constants.d.ts +1 -0
  33. package/lib/cjs/components/{CreateGroup → GroupForm}/constants.js +1 -1
  34. package/lib/cjs/components/GroupForm/index.d.ts +3 -0
  35. package/lib/cjs/components/GroupForm/index.js +5 -0
  36. package/lib/cjs/components/GroupHeader/GroupHeader.d.ts +6 -5
  37. package/lib/cjs/components/GroupHeader/GroupHeader.js +21 -11
  38. package/lib/cjs/components/GroupHeader/Skeleton.d.ts +2 -4
  39. package/lib/cjs/components/GroupHeader/Skeleton.js +10 -10
  40. package/lib/cjs/components/GroupInfoWidget/GroupInfoWidget.js +12 -8
  41. package/lib/cjs/components/GroupInviteButton/GroupInviteButton.js +7 -6
  42. package/lib/cjs/components/GroupMembersButton/GroupMembersButton.d.ts +5 -0
  43. package/lib/cjs/components/GroupMembersButton/GroupMembersButton.js +3 -2
  44. package/lib/cjs/components/GroupMembersWidget/GroupMembersWidget.js +36 -16
  45. package/lib/cjs/components/GroupRequestsWidget/GroupRequestsWidget.d.ts +11 -5
  46. package/lib/cjs/components/GroupRequestsWidget/GroupRequestsWidget.js +18 -7
  47. package/lib/cjs/components/GroupSettingsIconButton/GroupSettingsIconButton.d.ts +48 -0
  48. package/lib/cjs/components/GroupSettingsIconButton/GroupSettingsIconButton.js +132 -0
  49. package/lib/cjs/components/GroupSettingsIconButton/index.d.ts +3 -0
  50. package/lib/cjs/components/GroupSettingsIconButton/index.js +5 -0
  51. package/lib/cjs/components/GroupSubscribeButton/GroupSubscribeButton.d.ts +8 -3
  52. package/lib/cjs/components/GroupSubscribeButton/GroupSubscribeButton.js +24 -9
  53. package/lib/cjs/components/Groups/Groups.d.ts +16 -16
  54. package/lib/cjs/components/Groups/Groups.js +47 -96
  55. package/lib/cjs/components/Groups/Skeleton.d.ts +14 -2
  56. package/lib/cjs/components/Groups/Skeleton.js +12 -5
  57. package/lib/cjs/components/InlineComposerWidget/InlineComposerWidget.d.ts +2 -1
  58. package/lib/cjs/components/NavigationMenuIconButton/NavigationMenuIconButton.js +1 -1
  59. package/lib/cjs/components/NavigationToolbarMobile/NavigationToolbarMobile.d.ts +4 -0
  60. package/lib/cjs/components/NavigationToolbarMobile/NavigationToolbarMobile.js +2 -3
  61. package/lib/cjs/components/Notification/Group/Group.d.ts +15 -0
  62. package/lib/cjs/components/Notification/Group/Group.js +79 -0
  63. package/lib/cjs/components/Notification/Group/index.d.ts +3 -0
  64. package/lib/cjs/components/Notification/Group/index.js +5 -0
  65. package/lib/cjs/components/Notification/Notification.js +32 -1
  66. package/lib/cjs/components/Notification/PrivateMessage/PrivateMessage.js +16 -5
  67. package/lib/cjs/components/PrivateMessageComponent/PrivateMessageComponent.d.ts +1 -1
  68. package/lib/cjs/components/PrivateMessageComponent/PrivateMessageComponent.js +10 -7
  69. package/lib/cjs/components/PrivateMessageSnippetItem/PrivateMessageSnippetItem.js +11 -6
  70. package/lib/cjs/components/PrivateMessageSnippets/PrivateMessageSnippets.d.ts +3 -3
  71. package/lib/cjs/components/PrivateMessageSnippets/PrivateMessageSnippets.js +24 -6
  72. package/lib/cjs/components/PrivateMessageThread/PrivateMessageThread.d.ts +6 -1
  73. package/lib/cjs/components/PrivateMessageThread/PrivateMessageThread.js +45 -20
  74. package/lib/cjs/components/SearchAutocomplete/SearchAutocomplete.js +22 -5
  75. package/lib/cjs/components/SnippetNotifications/SnippetNotifications.js +7 -0
  76. package/lib/cjs/components/ToastNotifications/ToastNotifications.js +7 -0
  77. package/lib/cjs/components/VoteButton/VoteButton.js +19 -0
  78. package/lib/cjs/index.d.ts +7 -4
  79. package/lib/cjs/index.js +13 -6
  80. package/lib/esm/components/ChangeGroupCover/ChangeGroupCover.js +24 -1
  81. package/lib/esm/components/ChangeGroupPicture/ChangeGroupPicture.js +32 -11
  82. package/lib/esm/components/CommentObject/CommentObject.js +20 -2
  83. package/lib/esm/components/Composer/Attributes/Attributes.d.ts +1 -1
  84. package/lib/esm/components/Composer/Attributes/Attributes.js +9 -2
  85. package/lib/esm/components/Composer/Composer.d.ts +2 -1
  86. package/lib/esm/components/Composer/Composer.js +39 -12
  87. package/lib/esm/components/Composer/Content/ContentDiscussion/ContentDiscussion.js +7 -3
  88. package/lib/esm/components/Composer/Content/ContentPost/ContentPost.js +4 -3
  89. package/lib/esm/components/Composer/Layer/AudienceLayer/AudienceLayer.d.ts +7 -1
  90. package/lib/esm/components/Composer/Layer/AudienceLayer/AudienceLayer.js +45 -12
  91. package/lib/esm/components/CreateGroupButton/CreateGroupButton.d.ts +2 -2
  92. package/lib/esm/components/CreateGroupButton/CreateGroupButton.js +5 -6
  93. package/lib/esm/components/CustomAdv/CustomAdv.d.ts +4 -0
  94. package/lib/esm/components/{CreateGroup/CreateGroup.d.ts → EditGroupButton/EditGroupButton.d.ts} +11 -16
  95. package/lib/esm/components/EditGroupButton/EditGroupButton.js +58 -0
  96. package/lib/esm/components/EditGroupButton/index.d.ts +3 -0
  97. package/lib/esm/components/EditGroupButton/index.js +2 -0
  98. package/lib/esm/components/FeedObject/Actions/Follow/Follow.js +20 -2
  99. package/lib/esm/components/FeedObject/Actions/Share/Share.js +20 -2
  100. package/lib/esm/components/FeedObject/FeedObject.d.ts +1 -0
  101. package/lib/esm/components/FeedObject/FeedObject.js +45 -11
  102. package/lib/esm/components/Group/Group.d.ts +4 -3
  103. package/lib/esm/components/Group/Group.js +5 -4
  104. package/lib/esm/components/Group/Skeleton.js +1 -1
  105. package/lib/esm/components/GroupAutocomplete/GroupAutocomplete.d.ts +49 -0
  106. package/lib/esm/components/GroupAutocomplete/GroupAutocomplete.js +99 -0
  107. package/lib/esm/components/GroupAutocomplete/index.d.ts +3 -0
  108. package/lib/esm/components/GroupAutocomplete/index.js +2 -0
  109. package/lib/esm/components/GroupForm/GroupForm.d.ts +70 -0
  110. package/lib/esm/components/GroupForm/GroupForm.js +236 -0
  111. package/lib/esm/components/GroupForm/constants.d.ts +1 -0
  112. package/lib/esm/components/GroupForm/constants.js +1 -0
  113. package/lib/esm/components/GroupForm/index.d.ts +3 -0
  114. package/lib/esm/components/GroupForm/index.js +2 -0
  115. package/lib/esm/components/GroupHeader/GroupHeader.d.ts +6 -5
  116. package/lib/esm/components/GroupHeader/GroupHeader.js +21 -11
  117. package/lib/esm/components/GroupHeader/Skeleton.d.ts +2 -4
  118. package/lib/esm/components/GroupHeader/Skeleton.js +10 -10
  119. package/lib/esm/components/GroupInfoWidget/GroupInfoWidget.js +12 -8
  120. package/lib/esm/components/GroupInviteButton/GroupInviteButton.js +7 -6
  121. package/lib/esm/components/GroupMembersButton/GroupMembersButton.d.ts +5 -0
  122. package/lib/esm/components/GroupMembersButton/GroupMembersButton.js +4 -3
  123. package/lib/esm/components/GroupMembersWidget/GroupMembersWidget.js +38 -18
  124. package/lib/esm/components/GroupRequestsWidget/GroupRequestsWidget.d.ts +11 -5
  125. package/lib/esm/components/GroupRequestsWidget/GroupRequestsWidget.js +18 -7
  126. package/lib/esm/components/GroupSettingsIconButton/GroupSettingsIconButton.d.ts +48 -0
  127. package/lib/esm/components/GroupSettingsIconButton/GroupSettingsIconButton.js +129 -0
  128. package/lib/esm/components/GroupSettingsIconButton/index.d.ts +3 -0
  129. package/lib/esm/components/GroupSettingsIconButton/index.js +2 -0
  130. package/lib/esm/components/GroupSubscribeButton/GroupSubscribeButton.d.ts +8 -3
  131. package/lib/esm/components/GroupSubscribeButton/GroupSubscribeButton.js +25 -10
  132. package/lib/esm/components/Groups/Groups.d.ts +16 -16
  133. package/lib/esm/components/Groups/Groups.js +52 -101
  134. package/lib/esm/components/Groups/Skeleton.d.ts +14 -2
  135. package/lib/esm/components/Groups/Skeleton.js +13 -5
  136. package/lib/esm/components/InlineComposerWidget/InlineComposerWidget.d.ts +2 -1
  137. package/lib/esm/components/NavigationMenuIconButton/NavigationMenuIconButton.js +1 -1
  138. package/lib/esm/components/NavigationToolbarMobile/NavigationToolbarMobile.d.ts +4 -0
  139. package/lib/esm/components/NavigationToolbarMobile/NavigationToolbarMobile.js +2 -3
  140. package/lib/esm/components/Notification/Group/Group.d.ts +15 -0
  141. package/lib/esm/components/Notification/Group/Group.js +76 -0
  142. package/lib/esm/components/Notification/Group/index.d.ts +3 -0
  143. package/lib/esm/components/Notification/Group/index.js +2 -0
  144. package/lib/esm/components/Notification/Notification.js +32 -1
  145. package/lib/esm/components/Notification/PrivateMessage/PrivateMessage.js +16 -5
  146. package/lib/esm/components/PrivateMessageComponent/PrivateMessageComponent.d.ts +1 -1
  147. package/lib/esm/components/PrivateMessageComponent/PrivateMessageComponent.js +11 -8
  148. package/lib/esm/components/PrivateMessageSnippetItem/PrivateMessageSnippetItem.js +11 -6
  149. package/lib/esm/components/PrivateMessageSnippets/PrivateMessageSnippets.d.ts +3 -3
  150. package/lib/esm/components/PrivateMessageSnippets/PrivateMessageSnippets.js +26 -8
  151. package/lib/esm/components/PrivateMessageThread/PrivateMessageThread.d.ts +6 -1
  152. package/lib/esm/components/PrivateMessageThread/PrivateMessageThread.js +47 -22
  153. package/lib/esm/components/SearchAutocomplete/SearchAutocomplete.js +22 -5
  154. package/lib/esm/components/SnippetNotifications/SnippetNotifications.js +7 -0
  155. package/lib/esm/components/ToastNotifications/ToastNotifications.js +7 -0
  156. package/lib/esm/components/VoteButton/VoteButton.js +20 -1
  157. package/lib/esm/index.d.ts +7 -4
  158. package/lib/esm/index.js +8 -5
  159. package/lib/umd/react-ui.js +1 -1
  160. package/package.json +6 -6
  161. package/lib/cjs/components/CreateGroup/CreateGroup.js +0 -187
  162. package/lib/cjs/components/CreateGroup/constants.d.ts +0 -1
  163. package/lib/cjs/components/CreateGroup/index.d.ts +0 -3
  164. package/lib/cjs/components/CreateGroup/index.js +0 -5
  165. package/lib/esm/components/CreateGroup/CreateGroup.js +0 -184
  166. package/lib/esm/components/CreateGroup/constants.d.ts +0 -1
  167. package/lib/esm/components/CreateGroup/constants.js +0 -1
  168. package/lib/esm/components/CreateGroup/index.d.ts +0 -3
  169. package/lib/esm/components/CreateGroup/index.js +0 -2
@@ -73,6 +73,7 @@ const DialogRoot = (0, styles_1.styled)(BaseDialog_1.default, {
73
73
  * @param inProps
74
74
  */
75
75
  function GroupInviteButton(inProps) {
76
+ var _a;
76
77
  //PROPS
77
78
  const props = (0, system_1.useThemeProps)({
78
79
  props: inProps,
@@ -107,10 +108,9 @@ function GroupInviteButton(inProps) {
107
108
  }
108
109
  return [invited];
109
110
  }, [invited]);
110
- // CONST
111
- const authUserId = scUserContext.user ? scUserContext.user.id : null;
112
111
  // HOOKS
113
112
  const { scGroup } = (0, react_core_1.useSCFetchGroup)({ id: groupId, group });
113
+ const isGroupAdmin = (0, react_1.useMemo)(() => { var _a; return scUserContext.user && ((_a = scGroup === null || scGroup === void 0 ? void 0 : scGroup.managed_by) === null || _a === void 0 ? void 0 : _a.id) === scUserContext.user.id; }, [scUserContext.user, (_a = scGroup === null || scGroup === void 0 ? void 0 : scGroup.managed_by) === null || _a === void 0 ? void 0 : _a.id]);
114
114
  // INTL
115
115
  const intl = (0, react_intl_1.useIntl)();
116
116
  function fetchResults() {
@@ -181,6 +181,7 @@ function GroupInviteButton(inProps) {
181
181
  .then(() => {
182
182
  setIsSending(false);
183
183
  setOpen(false);
184
+ setInvited([]);
184
185
  })
185
186
  .catch((error) => {
186
187
  setOpen(false);
@@ -225,23 +226,23 @@ function GroupInviteButton(inProps) {
225
226
  setList((prev) => [...prev, option]);
226
227
  };
227
228
  /**
228
- * If there's no authUserId, component is hidden.
229
+ * If in group edit mode and logged-in user is not also the group manager, the component is hidden.
229
230
  // */
230
- if (!authUserId) {
231
+ if (group && !isGroupAdmin) {
231
232
  return null;
232
233
  }
233
234
  /**
234
235
  * Renders root object
235
236
  */
236
237
  return (react_1.default.createElement(react_1.default.Fragment, null,
237
- react_1.default.createElement(Root, Object.assign({ className: (0, classnames_1.default)(classes.root, className), onClick: handleClose, size: "small", variant: scGroup ? 'contained' : 'outlined', color: scGroup ? 'secondary' : 'inherit', startIcon: react_1.default.createElement(material_1.Icon, { fontSize: "small" }, "add") }, rest),
238
+ react_1.default.createElement(Root, Object.assign({ className: (0, classnames_1.default)(classes.root, className), onClick: handleClose, variant: scGroup ? 'contained' : 'outlined', color: scGroup ? 'secondary' : 'inherit', startIcon: react_1.default.createElement(material_1.Icon, { fontSize: "small" }, "add") }, rest),
238
239
  react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groupInviteButton", defaultMessage: "ui.groupInviteButton" })),
239
240
  open && (react_1.default.createElement(DialogRoot, { DialogContentProps: { dividers: false }, open: true, className: classes.dialogRoot, title: react_1.default.createElement(react_1.default.Fragment, null,
240
241
  react_1.default.createElement(material_1.IconButton, { onClick: handleClose },
241
242
  react_1.default.createElement(material_1.Icon, { fontSize: "medium" }, "arrow_back")),
242
243
  react_1.default.createElement(material_1.Typography, { className: classes.dialogTitle },
243
244
  react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groupInviteButton.dialog.title", defaultMessage: "ui.groupInviteButton.dialog.title" })),
244
- react_1.default.createElement(lab_1.LoadingButton, { size: "small", color: "secondary", variant: "contained", onClick: handleSendInvitations, loading: isSending },
245
+ react_1.default.createElement(lab_1.LoadingButton, { size: "small", color: "secondary", variant: "contained", onClick: handleSendInvitations, loading: isSending, disabled: !invited.length },
245
246
  react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groupInviteButton.dialog.button.end", defaultMessage: "ui.groupInviteButton.dialog.button.end" }))) },
246
247
  react_1.default.createElement(material_1.Box, { className: classes.dialogContent },
247
248
  react_1.default.createElement(Autocomplete_1.default, { className: classes.autocomplete, loading: loading, size: "small", multiple: true, freeSolo: true, disableClearable: true, options: suggested, onChange: handleChange, onInputChange: handleInputChange, inputValue: value, value: invited, getOptionLabel: (option) => (option ? option.username : '...'), isOptionEqualToValue: (option, value) => (option ? value.id === option.id : false), renderTags: () => null, renderOption: (props, option) => (react_1.default.createElement(material_1.Box, Object.assign({ component: "li" }, props),
@@ -17,6 +17,11 @@ export interface GroupMembersButtonProps extends Pick<ButtonProps, Exclude<keyof
17
17
  * @default {}
18
18
  */
19
19
  DialogProps?: BaseDialogProps;
20
+ /**
21
+ * Hides this component
22
+ * @default false
23
+ */
24
+ autoHide?: boolean;
20
25
  /**
21
26
  * Any other properties
22
27
  */
@@ -10,6 +10,7 @@ const InfiniteScroll_1 = tslib_1.__importDefault(require("../../shared/InfiniteS
10
10
  const User_1 = tslib_1.__importStar(require("../User"));
11
11
  const api_services_1 = require("@selfcommunity/api-services");
12
12
  const react_core_1 = require("@selfcommunity/react-core");
13
+ const types_1 = require("@selfcommunity/types");
13
14
  const AvatarGroupSkeleton_1 = tslib_1.__importDefault(require("../Skeleton/AvatarGroupSkeleton"));
14
15
  const classnames_1 = tslib_1.__importDefault(require("classnames"));
15
16
  const system_1 = require("@mui/system");
@@ -60,7 +61,7 @@ function GroupMembersButton(inProps) {
60
61
  props: inProps,
61
62
  name: PREFIX
62
63
  });
63
- const { className, groupId, group, DialogProps = {} } = props, rest = tslib_1.__rest(props, ["className", "groupId", "group", "DialogProps"]);
64
+ const { className, groupId, group, DialogProps = {}, autoHide = false } = props, rest = tslib_1.__rest(props, ["className", "groupId", "group", "DialogProps", "autoHide"]);
64
65
  // STATE
65
66
  const [loading, setLoading] = (0, react_1.useState)(true);
66
67
  const [next, setNext] = (0, react_1.useState)(null);
@@ -71,7 +72,7 @@ function GroupMembersButton(inProps) {
71
72
  const { scGroup } = (0, react_core_1.useSCFetchGroup)({ id: groupId, group });
72
73
  // FETCH FIRST FOLLOWERS
73
74
  (0, use_deep_compare_effect_1.useDeepCompareEffectNoCheck)(() => {
74
- if (!scGroup) {
75
+ if (!scGroup || (scGroup && scGroup.privacy !== types_1.SCGroupPrivacyType.PUBLIC && autoHide)) {
75
76
  return;
76
77
  }
77
78
  if (members.length === 0) {
@@ -21,10 +21,11 @@ const HiddenPlaceholder_1 = tslib_1.__importDefault(require("../../shared/Hidden
21
21
  const constants_1 = require("./constants");
22
22
  const User_1 = tslib_1.__importStar(require("../User"));
23
23
  const GroupInviteButton_1 = tslib_1.__importDefault(require("../GroupInviteButton"));
24
+ const GroupSettingsIconButton_1 = tslib_1.__importDefault(require("../GroupSettingsIconButton"));
24
25
  const classes = {
25
26
  root: `${constants_1.PREFIX}-root`,
26
27
  title: `${constants_1.PREFIX}-title`,
27
- button: `${constants_1.PREFIX}-button`,
28
+ actions: `${constants_1.PREFIX}-actions`,
28
29
  noResults: `${constants_1.PREFIX}-no-results`,
29
30
  showMore: `${constants_1.PREFIX}-show-more`,
30
31
  dialogRoot: `${constants_1.PREFIX}-dialog-root`,
@@ -70,6 +71,7 @@ const DialogRoot = (0, styles_1.styled)(BaseDialog_1.default, {
70
71
  * @param inProps
71
72
  */
72
73
  function GroupMembersWidget(inProps) {
74
+ var _a;
73
75
  // PROPS
74
76
  const props = (0, system_1.useThemeProps)({
75
77
  props: inProps,
@@ -87,8 +89,11 @@ function GroupMembersWidget(inProps) {
87
89
  const [openDialog, setOpenDialog] = (0, react_1.useState)(false);
88
90
  // CONTEXT
89
91
  const scUserContext = (0, react_core_1.useSCUser)();
92
+ const scRoutingContext = (0, react_core_1.useSCRouting)();
90
93
  const scPreferencesContext = (0, react_core_1.useSCPreferences)();
91
94
  const { scGroup } = (0, react_core_1.useSCFetchGroup)({ id: groupId, group });
95
+ // CONST
96
+ const isGroupAdmin = (0, react_1.useMemo)(() => { var _a; return scUserContext.user && ((_a = scGroup === null || scGroup === void 0 ? void 0 : scGroup.managed_by) === null || _a === void 0 ? void 0 : _a.id) === scUserContext.user.id; }, [scUserContext.user, (_a = scGroup === null || scGroup === void 0 ? void 0 : scGroup.managed_by) === null || _a === void 0 ? void 0 : _a.id]);
92
97
  // MEMO
93
98
  const contentAvailability = (0, react_1.useMemo)(() => react_core_1.SCPreferences.CONFIGURATIONS_CONTENT_AVAILABILITY in scPreferencesContext.preferences &&
94
99
  scPreferencesContext.preferences[react_core_1.SCPreferences.CONFIGURATIONS_CONTENT_AVAILABILITY].value, [scPreferencesContext.preferences]);
@@ -170,6 +175,14 @@ function GroupMembersWidget(inProps) {
170
175
  const handleToggleDialogOpen = () => {
171
176
  setOpenDialog((prev) => !prev);
172
177
  };
178
+ const handleRefresh = (0, react_1.useMemo)(() => (userId) => {
179
+ const newMembers = [...state.results];
180
+ const _updated = newMembers.filter((u) => u.id !== userId);
181
+ dispatch({
182
+ type: widget_1.actionWidgetTypes.SET_RESULTS,
183
+ payload: { results: newMembers.length > 1 ? _updated : [] }
184
+ });
185
+ }, [dispatch, state.count, state.results]);
173
186
  // RENDER
174
187
  if ((autoHide && !state.count && state.initialized) || (!contentAvailability && !scUserContext.user) || !scGroup) {
175
188
  return react_1.default.createElement(HiddenPlaceholder_1.default, null);
@@ -177,21 +190,28 @@ function GroupMembersWidget(inProps) {
177
190
  if (!state.initialized) {
178
191
  return react_1.default.createElement(Skeleton_1.default, null);
179
192
  }
180
- const content = (react_1.default.createElement(material_1.CardContent, null,
181
- react_1.default.createElement(material_1.Typography, { className: classes.title, variant: "h5" },
182
- react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groupMembersWidget.title", defaultMessage: "ui.groupMembersWidget.title" })),
183
- !state.count ? (react_1.default.createElement(material_1.Typography, { className: classes.noResults, variant: "body2" },
184
- react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groupMembersWidget.subtitle.noResults", defaultMessage: "" }))) : (react_1.default.createElement(react_1.default.Fragment, null,
185
- react_1.default.createElement(List_1.default, null, state.results.slice(0, state.visibleItems).map((user) => (react_1.default.createElement(material_1.ListItem, { key: user.id },
186
- react_1.default.createElement(User_1.default, { elevation: 0, actions: react_1.default.createElement(react_1.default.Fragment, null), user: user, userId: user.id, buttonProps: { onClick: () => console.log(user) } }))))),
187
- state.count > state.visibleItems && (react_1.default.createElement(material_1.Button, { className: classes.showMore, onClick: handleToggleDialogOpen },
188
- react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groupMembersWidget.button.showMore", defaultMessage: "ui.groupMembersWidget.button.showMore" }))))),
189
- openDialog && (react_1.default.createElement(DialogRoot, Object.assign({ className: classes.dialogRoot, title: react_1.default.createElement(react_intl_1.FormattedMessage, { defaultMessage: "ui.groupMembersWidget.dialogTitle", id: "ui.groupMembersWidget.dialogTitle", values: { total: scGroup.subscribers_counter } }), onClose: handleToggleDialogOpen, open: openDialog }, DialogProps),
190
- react_1.default.createElement(InfiniteScroll_1.default, { dataLength: state.results.length, next: handleNext, hasMoreNext: Boolean(state.next), loaderNext: react_1.default.createElement(User_1.UserSkeleton, Object.assign({ elevation: 0 }, UserProps)), height: isMobile ? '100%' : 400, endMessage: react_1.default.createElement(material_1.Typography, { className: classes.endMessage },
191
- react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groupMembersWidget.noMoreResults", defaultMessage: "ui.groupMembersWidget.noMoreResults" })) },
192
- react_1.default.createElement(List_1.default, null, state.results.map((user) => (react_1.default.createElement(material_1.ListItem, { key: user.id },
193
- react_1.default.createElement(User_1.default, { elevation: 0, actions: react_1.default.createElement(react_1.default.Fragment, null), user: user, userId: user.id, buttonProps: { onClick: () => console.log(user) } })))))))),
194
- react_1.default.createElement(GroupInviteButton_1.default, { className: classes.button, groupId: scGroup === null || scGroup === void 0 ? void 0 : scGroup.id, group: scGroup })));
193
+ const content = (react_1.default.createElement(react_1.default.Fragment, null,
194
+ react_1.default.createElement(material_1.CardContent, null,
195
+ react_1.default.createElement(material_1.Typography, { className: classes.title, variant: "h5" },
196
+ react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groupMembersWidget.title", defaultMessage: "ui.groupMembersWidget.title" })),
197
+ !state.count ? (react_1.default.createElement(material_1.Typography, { className: classes.noResults, variant: "body2" },
198
+ react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groupMembersWidget.subtitle.noResults", defaultMessage: "" }))) : (react_1.default.createElement(react_1.default.Fragment, null,
199
+ react_1.default.createElement(List_1.default, null, state.results.slice(0, state.visibleItems).map((user) => {
200
+ var _a;
201
+ return (react_1.default.createElement(material_1.ListItem, { key: user.id },
202
+ react_1.default.createElement(User_1.default, { elevation: 0, actions: isGroupAdmin ? (react_1.default.createElement(GroupSettingsIconButton_1.default, { group: scGroup, user: user, onRemoveSuccess: () => handleRefresh(user.id) })) : ((_a = scUserContext === null || scUserContext === void 0 ? void 0 : scUserContext.user) === null || _a === void 0 ? void 0 : _a.id) !== user.id ? (react_1.default.createElement(material_1.Button, { size: "small", variant: "outlined", component: react_core_1.Link, to: scRoutingContext.url(react_core_1.SCRoutes.USER_PRIVATE_MESSAGES_ROUTE_NAME, user) },
203
+ react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groupSettingsIconButton.item.message", defaultMessage: "ui.groupSettingsIconButton.item.message" }))) : null, user: user, userId: user.id })));
204
+ })),
205
+ state.count > state.visibleItems && (react_1.default.createElement(material_1.Button, { className: classes.showMore, onClick: handleToggleDialogOpen },
206
+ react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groupMembersWidget.button.showMore", defaultMessage: "ui.groupMembersWidget.button.showMore" }))))),
207
+ openDialog && (react_1.default.createElement(DialogRoot, Object.assign({ className: classes.dialogRoot, title: react_1.default.createElement(react_intl_1.FormattedMessage, { defaultMessage: "ui.groupMembersWidget.dialogTitle", id: "ui.groupMembersWidget.dialogTitle", values: { total: scGroup.subscribers_counter } }), onClose: handleToggleDialogOpen, open: openDialog }, DialogProps),
208
+ react_1.default.createElement(InfiniteScroll_1.default, { dataLength: state.results.length, next: handleNext, hasMoreNext: Boolean(state.next), loaderNext: react_1.default.createElement(User_1.UserSkeleton, Object.assign({ elevation: 0 }, UserProps)), height: isMobile ? '100%' : 400, endMessage: react_1.default.createElement(material_1.Typography, { className: classes.endMessage },
209
+ react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groupMembersWidget.noMoreResults", defaultMessage: "ui.groupMembersWidget.noMoreResults" })) },
210
+ react_1.default.createElement(List_1.default, null, state.results.map((user) => (react_1.default.createElement(material_1.ListItem, { key: user.id },
211
+ react_1.default.createElement(User_1.default, { elevation: 0, actions: isGroupAdmin ? (react_1.default.createElement(GroupSettingsIconButton_1.default, { group: scGroup, user: user, onRemoveSuccess: () => handleRefresh(user.id) })) : (react_1.default.createElement(material_1.Button, null,
212
+ react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groupSettingsIconButton.item.message", defaultMessage: "ui.groupSettingsIconButton.item.message" }))), user: user, userId: user.id }))))))))),
213
+ react_1.default.createElement(material_1.CardActions, { className: classes.actions },
214
+ react_1.default.createElement(GroupInviteButton_1.default, { groupId: scGroup === null || scGroup === void 0 ? void 0 : scGroup.id, group: scGroup }))));
195
215
  return (react_1.default.createElement(Root, Object.assign({ className: (0, classnames_1.default)(classes.root, className) }, rest), content));
196
216
  }
197
217
  exports.default = GroupMembersWidget;
@@ -4,6 +4,7 @@ import { CacheStrategies } from '@selfcommunity/utils';
4
4
  import { BaseDialogProps } from '../../shared/BaseDialog';
5
5
  import { VirtualScrollerItemProps } from '../../types/virtualScroller';
6
6
  import { UserProps } from '../User';
7
+ import { GroupSubscribeButtonProps } from '../GroupSubscribeButton';
7
8
  export interface GroupRequestsWidgetProps extends VirtualScrollerItemProps, WidgetProps {
8
9
  /**
9
10
  * Group Object
@@ -15,11 +16,6 @@ export interface GroupRequestsWidgetProps extends VirtualScrollerItemProps, Widg
15
16
  * @default null
16
17
  */
17
18
  groupId?: number | string;
18
- /**
19
- * Hides this component
20
- * @default false
21
- */
22
- autoHide?: boolean;
23
19
  /**
24
20
  * Limit the number of users to show
25
21
  * @default false
@@ -40,6 +36,16 @@ export interface GroupRequestsWidgetProps extends VirtualScrollerItemProps, Widg
40
36
  * @default {}
41
37
  */
42
38
  DialogProps?: BaseDialogProps;
39
+ /**
40
+ * Props to spread to group subscribe button component
41
+ * @default {}
42
+ */
43
+ GroupSubscribeButtonProps?: GroupSubscribeButtonProps;
44
+ /**
45
+ * onSubscribeAction callback
46
+ * @param user
47
+ */
48
+ onSubscribeActon?: (userId: number | string) => any;
43
49
  /**
44
50
  * Other props
45
51
  */
@@ -20,6 +20,7 @@ const system_1 = require("@mui/system");
20
20
  const HiddenPlaceholder_1 = tslib_1.__importDefault(require("../../shared/HiddenPlaceholder"));
21
21
  const constants_1 = require("./constants");
22
22
  const User_1 = tslib_1.__importStar(require("../User"));
23
+ const GroupSubscribeButton_1 = tslib_1.__importDefault(require("../GroupSubscribeButton"));
23
24
  const classes = {
24
25
  root: `${constants_1.PREFIX}-root`,
25
26
  title: `${constants_1.PREFIX}-title`,
@@ -68,12 +69,13 @@ const DialogRoot = (0, styles_1.styled)(BaseDialog_1.default, {
68
69
  * @param inProps
69
70
  */
70
71
  function GroupRequestsWidget(inProps) {
72
+ var _a;
71
73
  // PROPS
72
74
  const props = (0, system_1.useThemeProps)({
73
75
  props: inProps,
74
76
  name: constants_1.PREFIX
75
77
  });
76
- const { groupId, group, autoHide = false, limit = 5, className, cacheStrategy = utils_1.CacheStrategies.NETWORK_ONLY, onHeightChange, onStateChange, UserProps = {}, DialogProps = {} } = props, rest = tslib_1.__rest(props, ["groupId", "group", "autoHide", "limit", "className", "cacheStrategy", "onHeightChange", "onStateChange", "UserProps", "DialogProps"]);
78
+ const { groupId, group, limit = 5, className, cacheStrategy = utils_1.CacheStrategies.NETWORK_ONLY, onHeightChange, onStateChange, UserProps = {}, DialogProps = {}, GroupSubscribeButtonProps = {}, onSubscribeActon } = props, rest = tslib_1.__rest(props, ["groupId", "group", "limit", "className", "cacheStrategy", "onHeightChange", "onStateChange", "UserProps", "DialogProps", "GroupSubscribeButtonProps", "onSubscribeActon"]);
77
79
  // STATE
78
80
  const [state, dispatch] = (0, react_1.useReducer)(widget_1.dataWidgetReducer, {
79
81
  isLoadingNext: false,
@@ -93,6 +95,7 @@ function GroupRequestsWidget(inProps) {
93
95
  // HOOKS
94
96
  const theme = (0, material_1.useTheme)();
95
97
  const isMobile = (0, material_1.useMediaQuery)(theme.breakpoints.down('md'));
98
+ const isGroupAdmin = (0, react_1.useMemo)(() => { var _a; return scUserContext.user && ((_a = scGroup === null || scGroup === void 0 ? void 0 : scGroup.managed_by) === null || _a === void 0 ? void 0 : _a.id) === scUserContext.user.id; }, [scUserContext.user, (_a = scGroup === null || scGroup === void 0 ? void 0 : scGroup.managed_by) === null || _a === void 0 ? void 0 : _a.id]);
96
99
  /**
97
100
  * Initialize component
98
101
  * Fetch data only if the component is not initialized and it is not loading data
@@ -168,8 +171,17 @@ function GroupRequestsWidget(inProps) {
168
171
  const handleToggleDialogOpen = () => {
169
172
  setOpenDialog((prev) => !prev);
170
173
  };
174
+ const handleSubscribeAction = (0, react_1.useMemo)(() => (user) => {
175
+ const newRequests = [...state.results];
176
+ const _updated = newRequests.filter((u) => u.id !== user.id);
177
+ dispatch({
178
+ type: widget_1.actionWidgetTypes.SET_RESULTS,
179
+ payload: { results: newRequests.length > 1 ? _updated : [] }
180
+ });
181
+ onSubscribeActon && onSubscribeActon(user);
182
+ }, [dispatch, state.count, state.results, onSubscribeActon]);
171
183
  // RENDER
172
- if ((autoHide && !state.count && state.initialized) || (!contentAvailability && !scUserContext.user) || !scGroup) {
184
+ if ((!state.count && state.initialized) || !contentAvailability || !scGroup || !state.count || !state.results.length || !isGroupAdmin) {
173
185
  return react_1.default.createElement(HiddenPlaceholder_1.default, null);
174
186
  }
175
187
  if (!state.initialized) {
@@ -178,17 +190,16 @@ function GroupRequestsWidget(inProps) {
178
190
  const content = (react_1.default.createElement(material_1.CardContent, null,
179
191
  react_1.default.createElement(material_1.Typography, { className: classes.title, variant: "h5" },
180
192
  react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groupRequestsWidget.title", defaultMessage: "ui.groupRequestsWidget.title" })),
181
- !state.count ? (react_1.default.createElement(material_1.Typography, { className: classes.noResults, variant: "body2" },
182
- react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groupRequestsWidget.subtitle.noResults", defaultMessage: "" }))) : (react_1.default.createElement(react_1.default.Fragment, null,
193
+ react_1.default.createElement(react_1.default.Fragment, null,
183
194
  react_1.default.createElement(List_1.default, null, state.results.slice(0, state.visibleItems).map((user) => (react_1.default.createElement(material_1.ListItem, { key: user.id },
184
- react_1.default.createElement(User_1.default, { elevation: 0, actions: react_1.default.createElement(react_1.default.Fragment, null), user: user, userId: user.id, buttonProps: { onClick: () => console.log(user) } }))))),
195
+ react_1.default.createElement(User_1.default, { elevation: 0, actions: react_1.default.createElement(GroupSubscribeButton_1.default, Object.assign({ group: scGroup, groupId: scGroup === null || scGroup === void 0 ? void 0 : scGroup.id, user: user, onSubscribe: () => handleSubscribeAction(user) }, GroupSubscribeButtonProps)), user: user, userId: user.id }))))),
185
196
  state.count > state.visibleItems && (react_1.default.createElement(material_1.Button, { className: classes.showMore, onClick: handleToggleDialogOpen },
186
- react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groupRequestsWidget.button.showMore", defaultMessage: "ui.groupRequestsWidget.button.showMore" }))))),
197
+ react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groupRequestsWidget.button.showMore", defaultMessage: "ui.groupRequestsWidget.button.showMore" })))),
187
198
  openDialog && (react_1.default.createElement(DialogRoot, Object.assign({ className: classes.dialogRoot, title: react_1.default.createElement(react_intl_1.FormattedMessage, { defaultMessage: "ui.groupRequestsWidget.dialogTitle", id: "ui.groupRequestsWidget.dialogTitle", values: { total: scGroup.subscribers_counter } }), onClose: handleToggleDialogOpen, open: openDialog }, DialogProps),
188
199
  react_1.default.createElement(InfiniteScroll_1.default, { dataLength: state.results.length, next: handleNext, hasMoreNext: Boolean(state.next), loaderNext: react_1.default.createElement(User_1.UserSkeleton, Object.assign({ elevation: 0 }, UserProps)), height: isMobile ? '100%' : 400, endMessage: react_1.default.createElement(material_1.Typography, { className: classes.endMessage },
189
200
  react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groupRequestsWidget.noMoreResults", defaultMessage: "ui.groupRequestsWidget.noMoreResults" })) },
190
201
  react_1.default.createElement(List_1.default, null, state.results.map((user) => (react_1.default.createElement(material_1.ListItem, { key: user.id },
191
- react_1.default.createElement(User_1.default, { elevation: 0, actions: react_1.default.createElement(react_1.default.Fragment, null), user: user, userId: user.id, buttonProps: { onClick: () => console.log(user) } }))))))))));
202
+ react_1.default.createElement(User_1.default, { elevation: 0, actions: react_1.default.createElement(GroupSubscribeButton_1.default, Object.assign({ group: scGroup, groupId: scGroup === null || scGroup === void 0 ? void 0 : scGroup.id, user: user, onSubscribe: () => handleSubscribeAction(user) }, GroupSubscribeButtonProps)), user: user, userId: user.id }))))))))));
192
203
  return (react_1.default.createElement(Root, Object.assign({ className: (0, classnames_1.default)(classes.root, className) }, rest), content));
193
204
  }
194
205
  exports.default = GroupRequestsWidget;
@@ -0,0 +1,48 @@
1
+ import { IconButtonProps } from '@mui/material';
2
+ import { SCGroupType, SCUserType } from '@selfcommunity/types';
3
+ export interface GroupSettingsIconButtonProps extends IconButtonProps {
4
+ /**
5
+ * Overrides or extends the styles applied to the component.
6
+ * @default null
7
+ */
8
+ className?: string;
9
+ /**
10
+ * Handles callback on delete success
11
+ */
12
+ onRemoveSuccess?: () => void;
13
+ /**
14
+ * The user
15
+ */
16
+ user: SCUserType;
17
+ /**
18
+ * The group obj
19
+ */
20
+ group: SCGroupType;
21
+ /**
22
+ * Any other properties
23
+ */
24
+ [p: string]: any;
25
+ }
26
+ /**
27
+ * > API documentation for the Community-JS PrivateMessageSettingsIconButton component. Learn about the available props and the CSS API.
28
+
29
+ #### Import
30
+
31
+ ```jsx
32
+ import {PrivateMessageSettingsIconButton} from '@selfcommunity/react-ui';
33
+ ```
34
+
35
+ #### Component Name
36
+
37
+ The name `SCGroupSettingsIconButton` can be used when providing style overrides in the theme.
38
+
39
+
40
+ #### CSS
41
+
42
+ |Rule Name|Global class|Description|
43
+ |---|---|---|
44
+ |root|.SCGroupSettingsIconButton-root|Styles applied to the root element.|
45
+
46
+ * @param inProps
47
+ */
48
+ export default function GroupSettingsIconButton(inProps: GroupSettingsIconButtonProps): JSX.Element;
@@ -0,0 +1,132 @@
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_intl_1 = require("react-intl");
8
+ const Icon_1 = tslib_1.__importDefault(require("@mui/material/Icon"));
9
+ const classnames_1 = tslib_1.__importDefault(require("classnames"));
10
+ const system_1 = require("@mui/system");
11
+ const react_core_1 = require("@selfcommunity/react-core");
12
+ const ConfirmDialog_1 = tslib_1.__importDefault(require("../../shared/ConfirmDialog/ConfirmDialog"));
13
+ const api_services_1 = require("@selfcommunity/api-services");
14
+ const PREFIX = 'SCGroupSettingsIconButton';
15
+ const classes = {
16
+ root: `${PREFIX}-root`,
17
+ drawerRoot: `${PREFIX}-drawer-root`,
18
+ menuRoot: `${PREFIX}-menu-root`,
19
+ paper: `${PREFIX}-paper`,
20
+ item: `${PREFIX}-item`
21
+ };
22
+ const Root = (0, styles_1.styled)(material_1.IconButton, {
23
+ name: PREFIX,
24
+ slot: 'Root'
25
+ })(() => ({}));
26
+ const SwipeableDrawerRoot = (0, styles_1.styled)(material_1.SwipeableDrawer, {
27
+ name: PREFIX,
28
+ slot: 'DrawerRoot'
29
+ })(() => ({}));
30
+ const MenuRoot = (0, styles_1.styled)(material_1.Menu, {
31
+ name: PREFIX,
32
+ slot: 'MenuRoot'
33
+ })(() => ({}));
34
+ /**
35
+ * > API documentation for the Community-JS PrivateMessageSettingsIconButton component. Learn about the available props and the CSS API.
36
+
37
+ #### Import
38
+
39
+ ```jsx
40
+ import {PrivateMessageSettingsIconButton} from '@selfcommunity/react-ui';
41
+ ```
42
+
43
+ #### Component Name
44
+
45
+ The name `SCGroupSettingsIconButton` can be used when providing style overrides in the theme.
46
+
47
+
48
+ #### CSS
49
+
50
+ |Rule Name|Global class|Description|
51
+ |---|---|---|
52
+ |root|.SCGroupSettingsIconButton-root|Styles applied to the root element.|
53
+
54
+ * @param inProps
55
+ */
56
+ function GroupSettingsIconButton(inProps) {
57
+ // PROPS
58
+ const props = (0, system_1.useThemeProps)({
59
+ props: inProps,
60
+ name: PREFIX
61
+ });
62
+ const { className = null, group, user, onRemoveSuccess } = props, rest = tslib_1.__rest(props, ["className", "group", "user", "onRemoveSuccess"]);
63
+ // STATE
64
+ const [anchorEl, setAnchorEl] = (0, react_1.useState)(null);
65
+ const [openConfirmDialog, setOpenConfirmDialog] = (0, react_1.useState)(false);
66
+ // HOOKS
67
+ const theme = (0, material_1.useTheme)();
68
+ const isMobile = (0, material_1.useMediaQuery)(theme.breakpoints.down('md'));
69
+ const scRoutingContext = (0, react_core_1.useSCRouting)();
70
+ // CONTEXT
71
+ const scUserContext = (0, react_core_1.useSCUser)();
72
+ // HANDLERS
73
+ const handleOpen = (event) => {
74
+ setAnchorEl(event.currentTarget);
75
+ };
76
+ const handleClose = () => {
77
+ setAnchorEl(null);
78
+ };
79
+ const handleOpenDialog = () => {
80
+ setOpenConfirmDialog(true);
81
+ setAnchorEl(null);
82
+ };
83
+ const handleCloseDialog = () => {
84
+ setOpenConfirmDialog(false);
85
+ setAnchorEl(null);
86
+ onRemoveSuccess && onRemoveSuccess();
87
+ };
88
+ /**
89
+ * Handles thread deletion
90
+ */
91
+ function handleRemoveUser() {
92
+ api_services_1.GroupService.removeUserFromGroup(group.id, user.id)
93
+ .then(() => {
94
+ handleCloseDialog();
95
+ })
96
+ .catch((error) => {
97
+ setOpenConfirmDialog(false);
98
+ console.log(error);
99
+ });
100
+ }
101
+ if (scUserContext.user.id === user.id) {
102
+ return null;
103
+ }
104
+ /**
105
+ *
106
+ */
107
+ const renderList = () => {
108
+ if (isMobile) {
109
+ return [
110
+ react_1.default.createElement(material_1.ListItem, { className: classes.item, key: "message", component: react_core_1.Link, to: scRoutingContext.url(react_core_1.SCRoutes.USER_PRIVATE_MESSAGES_ROUTE_NAME, user) },
111
+ react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groupSettingsIconButton.item.message", defaultMessage: "ui.groupSettingsIconButton.item.message" })),
112
+ react_1.default.createElement(material_1.ListItem, { className: classes.item, key: "delete", onClick: handleOpenDialog },
113
+ react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groupSettingsIconButton.item.remove", defaultMessage: "ui.groupSettingsIconButton.item.remove" }))
114
+ ];
115
+ }
116
+ else {
117
+ return [
118
+ react_1.default.createElement(material_1.MenuItem, { className: classes.item, component: react_core_1.Link, to: scRoutingContext.url(react_core_1.SCRoutes.USER_PRIVATE_MESSAGES_ROUTE_NAME, user), key: "message" },
119
+ react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groupSettingsIconButton.item.message", defaultMessage: "ui.groupSettingsIconButton.item.message" })),
120
+ react_1.default.createElement(material_1.MenuItem, { className: classes.item, onClick: handleOpenDialog, key: "delete" },
121
+ react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groupSettingsIconButton.item.remove", defaultMessage: "ui.groupSettingsIconButton.item.remove" }))
122
+ ];
123
+ }
124
+ };
125
+ return (react_1.default.createElement(react_1.default.Fragment, null,
126
+ react_1.default.createElement(Root, Object.assign({ className: (0, classnames_1.default)(classes.root, className) }, rest, { onClick: handleOpen }),
127
+ react_1.default.createElement(Icon_1.default, null, "more_vert")),
128
+ isMobile ? (react_1.default.createElement(SwipeableDrawerRoot, { className: classes.drawerRoot, anchor: "bottom", open: Boolean(anchorEl), onClose: handleClose, onOpen: handleOpen, PaperProps: { className: classes.paper }, disableSwipeToOpen: true },
129
+ react_1.default.createElement(material_1.List, null, renderList()))) : (react_1.default.createElement(MenuRoot, { className: classes.menuRoot, anchorEl: anchorEl, open: Boolean(anchorEl), onClose: handleClose, PaperProps: { className: classes.paper } }, renderList())),
130
+ openConfirmDialog && (react_1.default.createElement(ConfirmDialog_1.default, { open: openConfirmDialog, title: react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groupSettingsIconButton.dialog.msg", defaultMessage: "ui.groupSettingsIconButton.dialog.msg", values: { b: (...chunks) => react_1.default.createElement("strong", null, chunks), user: user.username, group: group.name } }), btnConfirm: react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.groupSettingsIconButton.dialog.confirm", defaultMessage: "ui.groupSettingsIconButton.dialog.confirm" }), onConfirm: handleRemoveUser, onClose: handleCloseDialog }))));
131
+ }
132
+ exports.default = GroupSettingsIconButton;
@@ -0,0 +1,3 @@
1
+ import GroupSettingsIconButton, { GroupSettingsIconButtonProps } from './GroupSettingsIconButton';
2
+ export default GroupSettingsIconButton;
3
+ export { GroupSettingsIconButtonProps };
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const tslib_1 = require("tslib");
4
+ const GroupSettingsIconButton_1 = tslib_1.__importDefault(require("./GroupSettingsIconButton"));
5
+ exports.default = GroupSettingsIconButton_1.default;
@@ -1,4 +1,4 @@
1
- import { SCGroupType } from '@selfcommunity/types';
1
+ import { SCGroupType, SCUserType } from '@selfcommunity/types';
2
2
  export interface GroupSubscribeButtonProps {
3
3
  /**
4
4
  * Overrides or extends the styles applied to the component.
@@ -16,11 +16,16 @@ export interface GroupSubscribeButtonProps {
16
16
  */
17
17
  groupId?: number;
18
18
  /**
19
- * onJoin callback
19
+ * The user to be accepted into the group
20
+ * @default null
21
+ */
22
+ user?: SCUserType;
23
+ /**
24
+ * onSubscribe callback
20
25
  * @param user
21
26
  * @param joined
22
27
  */
23
- onJoin?: (group: SCGroupType, member: boolean) => any;
28
+ onSubscribe?: (group: SCGroupType, status: string | null) => any;
24
29
  /**
25
30
  * Others properties
26
31
  */
@@ -43,12 +43,13 @@ const Root = (0, styles_1.styled)(lab_1.LoadingButton, {
43
43
  * @param inProps
44
44
  */
45
45
  function GroupSubscribeButton(inProps) {
46
+ var _a;
46
47
  // PROPS
47
48
  const props = (0, system_1.useThemeProps)({
48
49
  props: inProps,
49
50
  name: PREFIX
50
51
  });
51
- const { className, groupId, group, onJoin } = props, rest = tslib_1.__rest(props, ["className", "groupId", "group", "onJoin"]);
52
+ const { className, groupId, group, user, onSubscribe } = props, rest = tslib_1.__rest(props, ["className", "groupId", "group", "user", "onSubscribe"]);
52
53
  // STATE
53
54
  const [status, setStatus] = (0, react_1.useState)(null);
54
55
  // CONTEXT
@@ -62,6 +63,7 @@ function GroupSubscribeButton(inProps) {
62
63
  group,
63
64
  cacheStrategy: authUserId ? utils_1.CacheStrategies.CACHE_FIRST : utils_1.CacheStrategies.STALE_WHILE_REVALIDATE
64
65
  });
66
+ const isGroupAdmin = (0, react_1.useMemo)(() => { var _a; return scUserContext.user && ((_a = scGroup === null || scGroup === void 0 ? void 0 : scGroup.managed_by) === null || _a === void 0 ? void 0 : _a.id) === scUserContext.user.id; }, [scUserContext.user, (_a = scGroup === null || scGroup === void 0 ? void 0 : scGroup.managed_by) === null || _a === void 0 ? void 0 : _a.id]);
65
67
  (0, react_1.useEffect)(() => {
66
68
  /**
67
69
  * Call scGroupsManager.subscriptionStatus inside an effect
@@ -71,11 +73,21 @@ function GroupSubscribeButton(inProps) {
71
73
  setStatus(scGroupsManager.subscriptionStatus(scGroup));
72
74
  }
73
75
  }, [authUserId, scGroupsManager.subscriptionStatus]);
74
- const subscribe = () => {
76
+ const subscribe = (userId) => {
75
77
  scGroupsManager
76
- .subscribe(scGroup)
78
+ .subscribe(scGroup, userId)
77
79
  .then(() => {
78
- // onJoin && onJoin(scGroup, !joined);
80
+ onSubscribe && onSubscribe(scGroup, types_1.SCGroupSubscriptionStatusType.SUBSCRIBED);
81
+ })
82
+ .catch((e) => {
83
+ utils_1.Logger.error(Errors_1.SCOPE_SC_UI, e);
84
+ });
85
+ };
86
+ const unsubscribe = () => {
87
+ scGroupsManager
88
+ .unsubscribe(scGroup)
89
+ .then(() => {
90
+ onSubscribe && onSubscribe(scGroup, null);
79
91
  })
80
92
  .catch((e) => {
81
93
  utils_1.Logger.error(Errors_1.SCOPE_SC_UI, e);
@@ -86,7 +98,7 @@ function GroupSubscribeButton(inProps) {
86
98
  scContext.settings.handleAnonymousAction();
87
99
  }
88
100
  else {
89
- subscribe();
101
+ status === types_1.SCGroupSubscriptionStatusType.SUBSCRIBED && !(user === null || user === void 0 ? void 0 : user.id) ? unsubscribe() : (user === null || user === void 0 ? void 0 : user.id) ? subscribe(user === null || user === void 0 ? void 0 : user.id) : subscribe();
90
102
  }
91
103
  };
92
104
  /**
@@ -96,22 +108,25 @@ function GroupSubscribeButton(inProps) {
96
108
  let _status;
97
109
  switch (status) {
98
110
  case types_1.SCGroupSubscriptionStatusType.REQUESTED:
99
- _status = react_1.default.createElement(react_intl_1.FormattedMessage, { defaultMessage: "ui.groupJoinButton.waitingApproval", id: "ui.groupJoinButton.waitingApproval" });
111
+ _status = react_1.default.createElement(react_intl_1.FormattedMessage, { defaultMessage: "ui.groupSubscribeButton.waitingApproval", id: "ui.groupSubscribeButton.waitingApproval" });
100
112
  break;
101
113
  case types_1.SCGroupSubscriptionStatusType.SUBSCRIBED:
102
114
  _status = react_1.default.createElement(react_intl_1.FormattedMessage, { defaultMessage: "ui.groupSubscribeButton.exit", id: "ui.groupSubscribeButton.exit" });
103
115
  break;
116
+ case types_1.SCGroupSubscriptionStatusType.INVITED:
117
+ _status = react_1.default.createElement(react_intl_1.FormattedMessage, { defaultMessage: "ui.groupSubscribeButton.accept", id: "ui.groupSubscribeButton.accept" });
118
+ break;
104
119
  default:
105
120
  scGroup.privacy === types_1.SCGroupPrivacyType.PUBLIC
106
121
  ? (_status = react_1.default.createElement(react_intl_1.FormattedMessage, { defaultMessage: "ui.groupSubscribeButton.enter", id: "ui.groupSubscribeButton.enter" }))
107
- : (_status = react_1.default.createElement(react_intl_1.FormattedMessage, { defaultMessage: "ui.groupJoinButton.requestAccess", id: "ui.groupJoinButton.requestAccess" }));
122
+ : (_status = react_1.default.createElement(react_intl_1.FormattedMessage, { defaultMessage: "ui.groupSubscribeButton.requestAccess", id: "ui.groupSubscribeButton.requestAccess" }));
108
123
  break;
109
124
  }
110
125
  return _status;
111
126
  };
112
- if (!scGroup || (scGroup && !scGroup.subscription_status)) {
127
+ if (!scGroup || (isGroupAdmin && (user === null || user === void 0 ? void 0 : user.id) === scUserContext.user.id) || (isGroupAdmin && !(user === null || user === void 0 ? void 0 : user.id))) {
113
128
  return null;
114
129
  }
115
- return (react_1.default.createElement(Root, Object.assign({ size: "small", variant: "outlined", onClick: handleSubscribeAction, loading: scUserContext.user ? scGroupsManager.isLoading(scGroup) : null, className: (0, classnames_1.default)(classes.root, className) }, rest), getStatus()));
130
+ return (react_1.default.createElement(Root, Object.assign({ size: "small", variant: "outlined", onClick: handleSubscribeAction, loading: scUserContext.user ? scGroupsManager.isLoading(scGroup) : null, disabled: status === types_1.SCGroupSubscriptionStatusType.REQUESTED, className: (0, classnames_1.default)(classes.root, className) }, rest), isGroupAdmin ? react_1.default.createElement(react_intl_1.FormattedMessage, { defaultMessage: "ui.groupSubscribeButton.accept", id: "ui.groupSubscribeButton.accept" }) : getStatus()));
116
131
  }
117
132
  exports.default = GroupSubscribeButton;