@selfcommunity/react-ui 0.7.9-alpha.8 → 0.7.9-alpha.81
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/cjs/components/AccountRecover/AccountRecover.js +6 -1
- package/lib/cjs/components/BottomNavigation/BottomNavigation.js +4 -3
- package/lib/cjs/components/CategoryHeader/Skeleton.js +3 -2
- package/lib/cjs/components/ChangeGroupCover/ChangeGroupCover.js +6 -6
- package/lib/cjs/components/ChangeGroupPicture/ChangeGroupPicture.js +19 -16
- package/lib/cjs/components/Composer/Attributes/Attributes.js +3 -3
- package/lib/cjs/components/Composer/Composer.js +3 -3
- package/lib/cjs/components/Composer/Layer/AudienceLayer/AudienceLayer.d.ts +1 -1
- package/lib/cjs/components/Composer/Layer/AudienceLayer/AudienceLayer.js +9 -19
- package/lib/cjs/components/Editor/Editor.js +2 -0
- package/lib/cjs/components/Editor/nodes/ImageNode.js +6 -0
- package/lib/cjs/components/Editor/plugins/ImagePlugin.js +4 -0
- package/lib/cjs/components/Editor/plugins/ToolbarPlugin.js +17 -3
- package/lib/cjs/components/FeedObject/Actions/Share/Share.js +18 -16
- package/lib/cjs/components/FeedObject/Contributors/Contributors.js +1 -1
- package/lib/cjs/components/FeedObject/FeedObject.d.ts +1 -0
- package/lib/cjs/components/FeedObject/FeedObject.js +27 -8
- package/lib/cjs/components/FeedObject/Poll/Poll.js +20 -20
- package/lib/cjs/components/FeedUpdatesWidget/FeedUpdatesWidget.js +1 -1
- package/lib/cjs/components/Footer/Footer.js +1 -1
- package/lib/cjs/components/Group/Group.d.ts +9 -1
- package/lib/cjs/components/Group/Group.js +18 -6
- package/lib/cjs/components/GroupAutocomplete/GroupAutocomplete.d.ts +0 -1
- package/lib/cjs/components/GroupAutocomplete/GroupAutocomplete.js +1 -2
- package/lib/cjs/components/GroupForm/GroupForm.js +64 -13
- package/lib/cjs/components/GroupHeader/GroupHeader.d.ts +6 -6
- package/lib/cjs/components/GroupHeader/GroupHeader.js +53 -12
- package/lib/cjs/components/GroupInfoWidget/GroupInfoWidget.js +63 -9
- package/lib/cjs/components/GroupInviteButton/GroupInviteButton.js +31 -9
- package/lib/cjs/components/GroupInvitedWidget/GroupInvitedWidget.d.ts +73 -0
- package/lib/cjs/components/GroupInvitedWidget/GroupInvitedWidget.js +220 -0
- package/lib/cjs/components/GroupInvitedWidget/Skeleton.d.ts +22 -0
- package/lib/cjs/components/GroupInvitedWidget/Skeleton.js +38 -0
- package/lib/cjs/components/GroupInvitedWidget/constants.d.ts +1 -0
- package/lib/cjs/components/GroupInvitedWidget/constants.js +4 -0
- package/lib/cjs/components/GroupInvitedWidget/index.d.ts +4 -0
- package/lib/cjs/components/GroupInvitedWidget/index.js +8 -0
- package/lib/cjs/components/GroupMembersButton/GroupMembersButton.d.ts +5 -0
- package/lib/cjs/components/GroupMembersButton/GroupMembersButton.js +8 -3
- package/lib/cjs/components/GroupMembersWidget/GroupMembersWidget.js +25 -4
- package/lib/cjs/components/GroupRequestsWidget/GroupRequestsWidget.d.ts +12 -7
- package/lib/cjs/components/GroupRequestsWidget/GroupRequestsWidget.js +19 -9
- package/lib/cjs/components/GroupSettingsIconButton/GroupSettingsIconButton.d.ts +48 -0
- package/lib/cjs/components/GroupSettingsIconButton/GroupSettingsIconButton.js +151 -0
- package/lib/cjs/components/GroupSettingsIconButton/index.d.ts +3 -0
- package/lib/cjs/components/GroupSettingsIconButton/index.js +5 -0
- package/lib/cjs/components/GroupSubscribeButton/GroupSubscribeButton.d.ts +8 -3
- package/lib/cjs/components/GroupSubscribeButton/GroupSubscribeButton.js +30 -11
- package/lib/cjs/components/Groups/Groups.d.ts +15 -8
- package/lib/cjs/components/Groups/Groups.js +86 -32
- package/lib/cjs/components/Groups/Skeleton.d.ts +4 -0
- package/lib/cjs/components/Groups/Skeleton.js +2 -2
- package/lib/cjs/components/InlineComposerWidget/InlineComposerWidget.js +7 -0
- package/lib/cjs/components/NavigationSettingsIconButton/NavigationSettingsIconButton.js +4 -4
- package/lib/cjs/components/NavigationToolbar/NavigationToolbar.js +9 -2
- package/lib/cjs/components/NavigationToolbarMobile/NavigationToolbarMobile.d.ts +1 -0
- package/lib/cjs/components/NavigationToolbarMobile/NavigationToolbarMobile.js +9 -1
- package/lib/cjs/components/Notification/Group/Group.d.ts +15 -0
- package/lib/cjs/components/Notification/Group/Group.js +78 -0
- package/lib/cjs/components/Notification/Group/index.d.ts +3 -0
- package/lib/cjs/components/Notification/Group/index.js +5 -0
- package/lib/cjs/components/Notification/Notification.js +31 -1
- package/lib/cjs/components/Notification/PrivateMessage/PrivateMessage.js +16 -5
- package/lib/cjs/components/PrivateMessageComponent/PrivateMessageComponent.d.ts +7 -1
- package/lib/cjs/components/PrivateMessageComponent/PrivateMessageComponent.js +16 -8
- package/lib/cjs/components/PrivateMessageSettingsIconButton/PrivateMessageSettingsIconButton.js +1 -1
- package/lib/cjs/components/PrivateMessageSnippetItem/PrivateMessageSnippetItem.js +11 -6
- package/lib/cjs/components/PrivateMessageSnippets/PrivateMessageSnippets.d.ts +9 -4
- package/lib/cjs/components/PrivateMessageSnippets/PrivateMessageSnippets.js +24 -6
- package/lib/cjs/components/PrivateMessageThread/PrivateMessageThread.d.ts +6 -1
- package/lib/cjs/components/PrivateMessageThread/PrivateMessageThread.js +46 -20
- package/lib/cjs/components/PrivateMessageThreadItem/PrivateMessageThreadItem.js +6 -0
- package/lib/cjs/components/SearchAutocomplete/SearchAutocomplete.js +22 -5
- package/lib/cjs/components/SnippetNotifications/SnippetNotifications.js +7 -0
- package/lib/cjs/components/ToastNotifications/ToastNotifications.js +7 -0
- package/lib/cjs/components/User/User.d.ts +6 -1
- package/lib/cjs/components/User/User.js +5 -4
- package/lib/cjs/components/UserSubscribedGroupsWidget/Skeleton.d.ts +21 -0
- package/lib/cjs/components/UserSubscribedGroupsWidget/Skeleton.js +46 -0
- package/lib/cjs/components/UserSubscribedGroupsWidget/UserSubscribedGroupsWidget.d.ts +68 -0
- package/lib/cjs/components/UserSubscribedGroupsWidget/UserSubscribedGroupsWidget.js +183 -0
- package/lib/cjs/components/UserSubscribedGroupsWidget/constants.d.ts +1 -0
- package/lib/cjs/components/UserSubscribedGroupsWidget/constants.js +4 -0
- package/lib/cjs/components/UserSubscribedGroupsWidget/index.d.ts +4 -0
- package/lib/cjs/components/UserSubscribedGroupsWidget/index.js +8 -0
- package/lib/cjs/components/VoteAudienceButton/VoteAudienceButton.js +1 -1
- package/lib/cjs/constants/PubSub.d.ts +28 -0
- package/lib/cjs/constants/PubSub.js +22 -0
- package/lib/cjs/index.d.ts +6 -3
- package/lib/cjs/index.js +13 -4
- package/lib/cjs/types/index.d.ts +2 -1
- package/lib/esm/components/AccountRecover/AccountRecover.js +6 -1
- package/lib/esm/components/BottomNavigation/BottomNavigation.js +5 -4
- package/lib/esm/components/CategoryHeader/Skeleton.js +3 -2
- package/lib/esm/components/ChangeGroupCover/ChangeGroupCover.js +6 -6
- package/lib/esm/components/ChangeGroupPicture/ChangeGroupPicture.js +19 -16
- package/lib/esm/components/Composer/Attributes/Attributes.js +3 -3
- package/lib/esm/components/Composer/Composer.js +3 -3
- package/lib/esm/components/Composer/Layer/AudienceLayer/AudienceLayer.d.ts +1 -1
- package/lib/esm/components/Composer/Layer/AudienceLayer/AudienceLayer.js +9 -19
- package/lib/esm/components/Editor/Editor.js +2 -0
- package/lib/esm/components/Editor/nodes/ImageNode.js +6 -0
- package/lib/esm/components/Editor/plugins/ImagePlugin.js +4 -0
- package/lib/esm/components/Editor/plugins/ToolbarPlugin.js +19 -5
- package/lib/esm/components/FeedObject/Actions/Share/Share.js +19 -17
- package/lib/esm/components/FeedObject/Contributors/Contributors.js +1 -1
- package/lib/esm/components/FeedObject/FeedObject.d.ts +1 -0
- package/lib/esm/components/FeedObject/FeedObject.js +28 -9
- package/lib/esm/components/FeedObject/Poll/Poll.js +20 -20
- package/lib/esm/components/FeedUpdatesWidget/FeedUpdatesWidget.js +1 -1
- package/lib/esm/components/Footer/Footer.js +2 -2
- package/lib/esm/components/Group/Group.d.ts +9 -1
- package/lib/esm/components/Group/Group.js +22 -10
- package/lib/esm/components/GroupAutocomplete/GroupAutocomplete.d.ts +0 -1
- package/lib/esm/components/GroupAutocomplete/GroupAutocomplete.js +1 -2
- package/lib/esm/components/GroupForm/GroupForm.js +64 -13
- package/lib/esm/components/GroupHeader/GroupHeader.d.ts +6 -6
- package/lib/esm/components/GroupHeader/GroupHeader.js +55 -14
- package/lib/esm/components/GroupInfoWidget/GroupInfoWidget.js +63 -9
- package/lib/esm/components/GroupInviteButton/GroupInviteButton.js +31 -9
- package/lib/esm/components/GroupInvitedWidget/GroupInvitedWidget.d.ts +73 -0
- package/lib/esm/components/GroupInvitedWidget/GroupInvitedWidget.js +217 -0
- package/lib/esm/components/GroupInvitedWidget/Skeleton.d.ts +22 -0
- package/lib/esm/components/GroupInvitedWidget/Skeleton.js +34 -0
- package/lib/esm/components/GroupInvitedWidget/constants.d.ts +1 -0
- package/lib/esm/components/GroupInvitedWidget/constants.js +1 -0
- package/lib/esm/components/GroupInvitedWidget/index.d.ts +4 -0
- package/lib/esm/components/GroupInvitedWidget/index.js +4 -0
- package/lib/esm/components/GroupMembersButton/GroupMembersButton.d.ts +5 -0
- package/lib/esm/components/GroupMembersButton/GroupMembersButton.js +9 -4
- package/lib/esm/components/GroupMembersWidget/GroupMembersWidget.js +26 -5
- package/lib/esm/components/GroupRequestsWidget/GroupRequestsWidget.d.ts +12 -7
- package/lib/esm/components/GroupRequestsWidget/GroupRequestsWidget.js +19 -9
- package/lib/esm/components/GroupSettingsIconButton/GroupSettingsIconButton.d.ts +48 -0
- package/lib/esm/components/GroupSettingsIconButton/GroupSettingsIconButton.js +148 -0
- package/lib/esm/components/GroupSettingsIconButton/index.d.ts +3 -0
- package/lib/esm/components/GroupSettingsIconButton/index.js +2 -0
- package/lib/esm/components/GroupSubscribeButton/GroupSubscribeButton.d.ts +8 -3
- package/lib/esm/components/GroupSubscribeButton/GroupSubscribeButton.js +30 -11
- package/lib/esm/components/Groups/Groups.d.ts +15 -8
- package/lib/esm/components/Groups/Groups.js +91 -37
- package/lib/esm/components/Groups/Skeleton.d.ts +4 -0
- package/lib/esm/components/Groups/Skeleton.js +2 -2
- package/lib/esm/components/InlineComposerWidget/InlineComposerWidget.js +9 -2
- package/lib/esm/components/NavigationSettingsIconButton/NavigationSettingsIconButton.js +4 -4
- package/lib/esm/components/NavigationToolbar/NavigationToolbar.js +10 -3
- package/lib/esm/components/NavigationToolbarMobile/NavigationToolbarMobile.d.ts +1 -0
- package/lib/esm/components/NavigationToolbarMobile/NavigationToolbarMobile.js +11 -3
- package/lib/esm/components/Notification/Group/Group.d.ts +15 -0
- package/lib/esm/components/Notification/Group/Group.js +75 -0
- package/lib/esm/components/Notification/Group/index.d.ts +3 -0
- package/lib/esm/components/Notification/Group/index.js +2 -0
- package/lib/esm/components/Notification/Notification.js +31 -1
- package/lib/esm/components/Notification/PrivateMessage/PrivateMessage.js +16 -5
- package/lib/esm/components/PrivateMessageComponent/PrivateMessageComponent.d.ts +7 -1
- package/lib/esm/components/PrivateMessageComponent/PrivateMessageComponent.js +17 -9
- package/lib/esm/components/PrivateMessageSettingsIconButton/PrivateMessageSettingsIconButton.js +1 -1
- package/lib/esm/components/PrivateMessageSnippetItem/PrivateMessageSnippetItem.js +11 -6
- package/lib/esm/components/PrivateMessageSnippets/PrivateMessageSnippets.d.ts +9 -4
- package/lib/esm/components/PrivateMessageSnippets/PrivateMessageSnippets.js +26 -8
- package/lib/esm/components/PrivateMessageThread/PrivateMessageThread.d.ts +6 -1
- package/lib/esm/components/PrivateMessageThread/PrivateMessageThread.js +48 -22
- package/lib/esm/components/PrivateMessageThreadItem/PrivateMessageThreadItem.js +7 -1
- package/lib/esm/components/SearchAutocomplete/SearchAutocomplete.js +22 -5
- package/lib/esm/components/SnippetNotifications/SnippetNotifications.js +7 -0
- package/lib/esm/components/ToastNotifications/ToastNotifications.js +7 -0
- package/lib/esm/components/User/User.d.ts +6 -1
- package/lib/esm/components/User/User.js +5 -4
- package/lib/esm/components/UserSubscribedGroupsWidget/Skeleton.d.ts +21 -0
- package/lib/esm/components/UserSubscribedGroupsWidget/Skeleton.js +42 -0
- package/lib/esm/components/UserSubscribedGroupsWidget/UserSubscribedGroupsWidget.d.ts +68 -0
- package/lib/esm/components/UserSubscribedGroupsWidget/UserSubscribedGroupsWidget.js +180 -0
- package/lib/esm/components/UserSubscribedGroupsWidget/constants.d.ts +1 -0
- package/lib/esm/components/UserSubscribedGroupsWidget/constants.js +1 -0
- package/lib/esm/components/UserSubscribedGroupsWidget/index.d.ts +4 -0
- package/lib/esm/components/UserSubscribedGroupsWidget/index.js +4 -0
- package/lib/esm/components/VoteAudienceButton/VoteAudienceButton.js +1 -1
- package/lib/esm/constants/PubSub.d.ts +28 -0
- package/lib/esm/constants/PubSub.js +19 -0
- package/lib/esm/index.d.ts +6 -3
- package/lib/esm/index.js +6 -3
- package/lib/esm/types/index.d.ts +2 -1
- package/lib/umd/311.js +2 -0
- package/lib/umd/react-ui.js +1 -1
- package/package.json +9 -9
- package/lib/umd/871.js +0 -2
- /package/lib/umd/{871.js.LICENSE.txt → 311.js.LICENSE.txt} +0 -0
|
@@ -103,7 +103,12 @@ function AccountRecover(inProps) {
|
|
|
103
103
|
}
|
|
104
104
|
// RENDER
|
|
105
105
|
return (react_1.default.createElement(Root, Object.assign({ className: (0, classnames_1.default)(classes.root, className) }, rest), isSucceed ? (react_1.default.createElement(material_1.Alert, { severity: "success", className: classes.success },
|
|
106
|
-
intl.formatMessage({ id: 'ui.accountRecover.success', defaultMessage: 'ui.accountRecover.success' }, {
|
|
106
|
+
intl.formatMessage({ id: 'ui.accountRecover.success', defaultMessage: 'ui.accountRecover.success' }, {
|
|
107
|
+
email,
|
|
108
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-ignore
|
|
109
|
+
// @ts-ignore
|
|
110
|
+
b: (chunks) => react_1.default.createElement("b", null, chunks)
|
|
111
|
+
}),
|
|
107
112
|
successAction)) : (react_1.default.createElement("form", { className: classes.form, onSubmit: handleSubmit },
|
|
108
113
|
react_1.default.createElement(EmailTextField_1.default, Object.assign({ className: classes.email, disabled: isSubmitting, label: react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.accountRecover.email.label", defaultMessage: "ui.accountRecover.email.label" }) }, TextFieldProps, { value: email, onChange: handleChange, error: Boolean(emailError), helperText: emailError && (react_1.default.createElement(react_intl_1.FormattedMessage, { id: `ui.accountRecover.email.error.${emailError}`, defaultMessage: `ui.accountRecover.email.error.${emailError}` })) })),
|
|
109
114
|
react_1.default.createElement(material_1.Button, Object.assign({ type: "submit" }, ButtonProps, { disabled: !email || Boolean(emailError) || isSubmitting }),
|
|
@@ -71,9 +71,10 @@ function BottomNavigation(inProps) {
|
|
|
71
71
|
react_1.default.createElement(material_1.BottomNavigationAction, { key: "home", className: classes.action, component: react_core_1.Link, to: scUserContext.user ? scRoutingContext.url(react_core_1.SCRoutes.HOME_ROUTE_NAME, {}) : '/', value: scUserContext.user ? scRoutingContext.url(react_core_1.SCRoutes.HOME_ROUTE_NAME, {}) : '/', icon: react_1.default.createElement(material_1.Icon, null, "home") }),
|
|
72
72
|
(scUserContext.user || preferences[react_core_1.SCPreferences.CONFIGURATIONS_CONTENT_AVAILABILITY].value) &&
|
|
73
73
|
preferences[react_core_1.SCPreferences.CONFIGURATIONS_EXPLORE_STREAM_ENABLED].value ? (react_1.default.createElement(material_1.BottomNavigationAction, { key: "explore", className: classes.action, component: react_core_1.Link, to: scRoutingContext.url(react_core_1.SCRoutes.EXPLORE_ROUTE_NAME, {}), value: scRoutingContext.url(react_core_1.SCRoutes.EXPLORE_ROUTE_NAME, {}), icon: react_1.default.createElement(material_1.Icon, null, "explore") })) : null,
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
scUserContext.user ? (react_1.default.createElement(material_1.BottomNavigationAction, { key: "
|
|
74
|
+
!preferences[react_core_1.SCPreferences.CONFIGURATIONS_POST_ONLY_STAFF_ENABLED].value ||
|
|
75
|
+
(react_core_1.UserUtils.isStaff(scUserContext.user) && preferences[react_core_1.SCPreferences.CONFIGURATIONS_POST_ONLY_STAFF_ENABLED].value) ? (react_1.default.createElement(material_1.BottomNavigationAction, { key: "composer", className: (0, classnames_1.default)(classes.composer, classes.action), component: ComposerIconButton_1.default, disableRipple: true })) : null,
|
|
76
|
+
groupsEnabled && scUserContext.user ? (react_1.default.createElement(material_1.BottomNavigationAction, { key: "groups", className: classes.action, component: react_core_1.Link, to: scRoutingContext.url(react_core_1.SCRoutes.GROUPS_SUBSCRIBED_ROUTE_NAME, {}), value: scRoutingContext.url(react_core_1.SCRoutes.GROUPS_SUBSCRIBED_ROUTE_NAME, {}), icon: react_1.default.createElement(material_1.Icon, null, "groups") })) : null,
|
|
77
|
+
scUserContext.user && !groupsEnabled ? (react_1.default.createElement(material_1.BottomNavigationAction, { key: "notifications", className: classes.action, component: react_core_1.Link, to: scRoutingContext.url(react_core_1.SCRoutes.USER_NOTIFICATIONS_ROUTE_NAME, {}), value: scRoutingContext.url(react_core_1.SCRoutes.USER_NOTIFICATIONS_ROUTE_NAME, {}), icon: react_1.default.createElement(material_1.Badge, { badgeContent: scUserContext.user.unseen_notification_banners_counter + scUserContext.user.unseen_interactions_counter, color: "secondary" },
|
|
77
78
|
react_1.default.createElement(material_1.Icon, null, "notifications_active")) })) : null,
|
|
78
79
|
privateMessagingEnabled && scUserContext.user ? (react_1.default.createElement(material_1.BottomNavigationAction, { key: "messages", className: classes.action, component: react_core_1.Link, to: scRoutingContext.url(react_core_1.SCRoutes.USER_PRIVATE_MESSAGES_ROUTE_NAME, {}), value: scRoutingContext.url(react_core_1.SCRoutes.USER_PRIVATE_MESSAGES_ROUTE_NAME, {}), icon: react_1.default.createElement(material_1.Badge, { badgeContent: 0, color: "secondary" },
|
|
79
80
|
react_1.default.createElement(material_1.Icon, null, "email")) })) : null
|
|
@@ -7,7 +7,8 @@ const styles_1 = require("@mui/material/styles");
|
|
|
7
7
|
const Skeleton_1 = tslib_1.__importDefault(require("@mui/material/Skeleton"));
|
|
8
8
|
const constants_1 = require("./constants");
|
|
9
9
|
const classes = {
|
|
10
|
-
root: `${constants_1.PREFIX}-skeleton-root
|
|
10
|
+
root: `${constants_1.PREFIX}-skeleton-root`,
|
|
11
|
+
cover: `${constants_1.PREFIX}-skeleton-cover`,
|
|
11
12
|
};
|
|
12
13
|
const Root = (0, styles_1.styled)(material_1.Box, {
|
|
13
14
|
name: constants_1.PREFIX,
|
|
@@ -35,7 +36,7 @@ const Root = (0, styles_1.styled)(material_1.Box, {
|
|
|
35
36
|
*/
|
|
36
37
|
function CategoryHeaderSkeleton() {
|
|
37
38
|
return (react_1.default.createElement(Root, { className: classes.root },
|
|
38
|
-
react_1.default.createElement(Skeleton_1.default, { sx: { height:
|
|
39
|
+
react_1.default.createElement(Skeleton_1.default, { sx: { height: 230 }, animation: "wave", variant: "rectangular", className: classes.cover }),
|
|
39
40
|
react_1.default.createElement(material_1.Box, null,
|
|
40
41
|
react_1.default.createElement(Skeleton_1.default, { animation: "wave", sx: { height: 20, maxWidth: 300, width: '100%', margin: '0 auto' } })),
|
|
41
42
|
react_1.default.createElement(material_1.Box, null,
|
|
@@ -84,12 +84,12 @@ function ChangeGroupCover(inProps) {
|
|
|
84
84
|
reader.onload = (e) => {
|
|
85
85
|
const img = new Image();
|
|
86
86
|
img.onload = () => {
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
else {
|
|
91
|
-
|
|
92
|
-
}
|
|
87
|
+
isCreationMode ? onChange && onChange(fileInput) : handleSave();
|
|
88
|
+
// if (img.width < 1920) {
|
|
89
|
+
// setAlert(intl.formatMessage(messages.errorImageSize));
|
|
90
|
+
// } else {
|
|
91
|
+
// isCreationMode ? onChange && onChange(fileInput) : handleSave();
|
|
92
|
+
// }
|
|
93
93
|
};
|
|
94
94
|
// eslint-disable-next-line @typescript-eslint/ban-ts-ignore
|
|
95
95
|
// @ts-ignore
|
|
@@ -59,12 +59,12 @@ function ChangeGroupPicture(inProps) {
|
|
|
59
59
|
name: constants_1.PREFIX
|
|
60
60
|
});
|
|
61
61
|
const { groupId, onChange, autoHide, className, isCreationMode = false } = props, rest = tslib_1.__rest(props, ["groupId", "onChange", "autoHide", "className", "isCreationMode"]);
|
|
62
|
+
//CONTEXT
|
|
63
|
+
const scUserContext = (0, react_1.useContext)(react_core_1.SCUserContext);
|
|
62
64
|
//STATE
|
|
65
|
+
let fileInput = (0, react_1.useRef)(null);
|
|
63
66
|
const [loading, setLoading] = (0, react_1.useState)(false);
|
|
64
67
|
const [alert, setAlert] = (0, react_1.useState)(null);
|
|
65
|
-
let fileInput = (0, react_1.useRef)(null);
|
|
66
|
-
//CONTEXT
|
|
67
|
-
const scUserContext = (0, react_1.useContext)(react_core_1.SCUserContext);
|
|
68
68
|
// INTL
|
|
69
69
|
const intl = (0, react_intl_1.useIntl)();
|
|
70
70
|
// Anonymous
|
|
@@ -75,44 +75,47 @@ function ChangeGroupPicture(inProps) {
|
|
|
75
75
|
* Handles avatar upload
|
|
76
76
|
* @param event
|
|
77
77
|
*/
|
|
78
|
-
|
|
79
|
-
|
|
78
|
+
const handleUpload = (event) => {
|
|
79
|
+
fileInput = event.target.files[0];
|
|
80
80
|
if (fileInput) {
|
|
81
81
|
const reader = new FileReader();
|
|
82
82
|
reader.onload = (e) => {
|
|
83
83
|
const img = new Image();
|
|
84
84
|
img.onload = () => {
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
else {
|
|
89
|
-
|
|
90
|
-
}
|
|
85
|
+
isCreationMode ? onChange && onChange(fileInput) : handleSave();
|
|
86
|
+
// if (img.width < 600 && img.height < 600) {
|
|
87
|
+
// setAlert(intl.formatMessage(messages.errorLoadImage));
|
|
88
|
+
// } else {
|
|
89
|
+
// isCreationMode ? onChange && onChange(fileInput) : handleSave();
|
|
90
|
+
// }
|
|
91
91
|
};
|
|
92
92
|
// eslint-disable-next-line @typescript-eslint/ban-ts-ignore
|
|
93
93
|
// @ts-ignore
|
|
94
94
|
img.src = e.target.result;
|
|
95
95
|
};
|
|
96
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-ignore
|
|
97
|
+
// @ts-ignore
|
|
96
98
|
reader.readAsDataURL(fileInput);
|
|
97
99
|
}
|
|
98
|
-
}
|
|
99
|
-
// ui.changeGroupPicture.alert
|
|
100
|
+
};
|
|
100
101
|
/**
|
|
101
102
|
* Performs save avatar after upload
|
|
102
103
|
*/
|
|
103
104
|
function handleSave() {
|
|
104
105
|
setLoading(true);
|
|
105
106
|
const formData = new FormData();
|
|
107
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-ignore
|
|
108
|
+
// @ts-ignore
|
|
106
109
|
formData.append('image_original', fileInput);
|
|
107
110
|
api_services_1.GroupService.changeGroupAvatarOrCover(groupId, formData, { headers: { 'Content-Type': 'multipart/form-data' } })
|
|
108
111
|
.then((data) => {
|
|
112
|
+
onChange && onChange(data.image_big);
|
|
109
113
|
setLoading(false);
|
|
110
|
-
onChange && onChange(data.image_bigger);
|
|
111
114
|
})
|
|
112
115
|
.catch((error) => {
|
|
113
|
-
setAlert(intl.formatMessage(messages.errorLoadImage));
|
|
114
|
-
setLoading(false);
|
|
115
116
|
utils_1.Logger.error(Errors_1.SCOPE_SC_UI, error);
|
|
117
|
+
setLoading(false);
|
|
118
|
+
setAlert(intl.formatMessage(messages.errorLoadImage));
|
|
116
119
|
});
|
|
117
120
|
}
|
|
118
121
|
/**
|
|
@@ -16,7 +16,7 @@ const Root = (0, styles_1.styled)(material_1.Box, {
|
|
|
16
16
|
slot: 'AttributesRoot'
|
|
17
17
|
})(() => ({}));
|
|
18
18
|
exports.default = (props) => {
|
|
19
|
-
var _a, _b;
|
|
19
|
+
var _a, _b, _c;
|
|
20
20
|
// PROPS
|
|
21
21
|
const { className = null, value = null, onChange = null, onClick = null } = props;
|
|
22
22
|
// HANDLERS
|
|
@@ -47,8 +47,8 @@ exports.default = (props) => {
|
|
|
47
47
|
return (react_1.default.createElement(Root, { className: (0, classnames_1.default)(classes.root, className) },
|
|
48
48
|
((_a = value === null || value === void 0 ? void 0 : value.categories) === null || _a === void 0 ? void 0 : _a.length) > 0 &&
|
|
49
49
|
(value === null || value === void 0 ? void 0 : value.categories.map((c) => (react_1.default.createElement(material_1.Chip, { key: c.id, label: c.name, onDelete: handleDeleteCategory(c.id), icon: react_1.default.createElement(Icon_1.default, null, "category"), onClick: handleClickCategory })))),
|
|
50
|
-
(value === null || value === void 0 ? void 0 : value.group) && (react_1.default.createElement(material_1.Chip, { key: value === null || value === void 0 ? void 0 : value.group.id, label: value === null || value === void 0 ? void 0 : value.group.name, onDelete: handleDeleteGroup, icon: react_1.default.createElement(Icon_1.default, null, "groups"), onClick: handleClickGroup })),
|
|
51
|
-
((
|
|
50
|
+
(value === null || value === void 0 ? void 0 : value.group) && (react_1.default.createElement(material_1.Chip, { key: value === null || value === void 0 ? void 0 : value.group.id, label: value === null || value === void 0 ? void 0 : value.group.name, onDelete: handleDeleteGroup, icon: react_1.default.createElement(Icon_1.default, null, "groups"), onClick: handleClickGroup, disabled: !((_b = value === null || value === void 0 ? void 0 : value.group) === null || _b === void 0 ? void 0 : _b.subscription_status) })),
|
|
51
|
+
((_c = value === null || value === void 0 ? void 0 : value.addressing) === null || _c === void 0 ? void 0 : _c.length) > 0 &&
|
|
52
52
|
(value === null || value === void 0 ? void 0 : value.addressing.map((t) => (react_1.default.createElement(TagChip_1.default, { key: t.id, tag: t, onDelete: handleDeleteTag(t.id), icon: react_1.default.createElement(Icon_1.default, null, "label"), onClick: handleClickTag })))),
|
|
53
53
|
(value === null || value === void 0 ? void 0 : value.location) && (react_1.default.createElement(material_1.Chip, { icon: react_1.default.createElement(Icon_1.default, null, "add_location_alt"), label: value === null || value === void 0 ? void 0 : value.location.location, onDelete: handleDeleteLocation, onClick: handleClickLocation }))));
|
|
54
54
|
};
|
|
@@ -307,7 +307,7 @@ function Composer(inProps) {
|
|
|
307
307
|
}
|
|
308
308
|
}), [handleAddLayer, handleRemoveLayer, handleChangeCategories, categories]);
|
|
309
309
|
const handleChangeAudience = (0, react_1.useCallback)((value) => {
|
|
310
|
-
if (group ||
|
|
310
|
+
if (group || (value && Object.prototype.hasOwnProperty.call(value, 'managed_by'))) {
|
|
311
311
|
dispatch({ type: 'group', value });
|
|
312
312
|
}
|
|
313
313
|
else {
|
|
@@ -321,7 +321,7 @@ function Composer(inProps) {
|
|
|
321
321
|
ComponentProps: {
|
|
322
322
|
onClose: handleRemoveLayer,
|
|
323
323
|
onSave: handleChangeAudience,
|
|
324
|
-
defaultValue: group ||
|
|
324
|
+
defaultValue: group || (addressing && Object.prototype.hasOwnProperty.call(addressing, 'managed_by')) ? group : addressing
|
|
325
325
|
}
|
|
326
326
|
}), [handleAddLayer, handleRemoveLayer, handleChangeAudience, addressing, group]);
|
|
327
327
|
const handleChangeLocation = (0, react_1.useCallback)((value) => {
|
|
@@ -553,7 +553,7 @@ function Composer(inProps) {
|
|
|
553
553
|
}),
|
|
554
554
|
react_1.default.createElement(material_1.IconButton, { disabled: isSubmitting, onClick: handleAddCategoryLayer },
|
|
555
555
|
react_1.default.createElement(Icon_1.default, null, "category")),
|
|
556
|
-
react_1.default.createElement(material_1.IconButton, { disabled: isSubmitting || !features.includes(types_1.SCFeatureName.TAGGING), onClick: handleAddAudienceLayer }, addressing === null || addressing.length === 0 ?
|
|
556
|
+
react_1.default.createElement(material_1.IconButton, { disabled: isSubmitting || !features.includes(types_1.SCFeatureName.TAGGING) || Boolean(feedObject === null || feedObject === void 0 ? void 0 : feedObject.group), onClick: handleAddAudienceLayer }, (!group && addressing === null) || (addressing === null || addressing === void 0 ? void 0 : addressing.length) === 0 ? react_1.default.createElement(Icon_1.default, null, "public") : group ? react_1.default.createElement(Icon_1.default, null, "groups") : react_1.default.createElement(Icon_1.default, null, "label")),
|
|
557
557
|
preferences[react_core_1.SCPreferences.ADDONS_POST_GEOLOCATION_ENABLED].value && (react_1.default.createElement(material_1.IconButton, { disabled: isSubmitting, onClick: handleAddLocationLayer, color: location !== null ? 'primary' : 'default' },
|
|
558
558
|
react_1.default.createElement(Icon_1.default, null, "add_location_alt"))))),
|
|
559
559
|
layer && (react_1.default.createElement(LayerTransitionRoot, { className: classes.layerTransitionRoot, in: true, container: dialogRef.current, direction: "left" },
|
|
@@ -10,7 +10,7 @@ export declare enum AudienceTypes {
|
|
|
10
10
|
AUDIENCE_GROUP = "group"
|
|
11
11
|
}
|
|
12
12
|
export interface AudienceLayerProps extends Omit<BoxProps, 'defaultValue'>, ComposerLayerProps {
|
|
13
|
-
defaultValue: SCTagType[] | SCGroupType;
|
|
13
|
+
defaultValue: SCTagType[] | SCGroupType | any;
|
|
14
14
|
TextFieldProps?: TextFieldProps;
|
|
15
15
|
}
|
|
16
16
|
declare const AudienceLayer: React.ForwardRefExoticComponent<Pick<AudienceLayerProps, "p" | "slot" | "style" | "title" | "key" | "defaultChecked" | "defaultValue" | "suppressContentEditableWarning" | "suppressHydrationWarning" | "accessKey" | "className" | "contentEditable" | "contextMenu" | "dir" | "draggable" | "hidden" | "id" | "lang" | "placeholder" | "spellCheck" | "tabIndex" | "translate" | "radioGroup" | "role" | "about" | "datatype" | "inlist" | "prefix" | "property" | "resource" | "typeof" | "vocab" | "autoCapitalize" | "autoCorrect" | "autoSave" | "color" | "itemProp" | "itemScope" | "itemType" | "itemID" | "itemRef" | "results" | "security" | "unselectable" | "inputMode" | "is" | "aria-activedescendant" | "aria-atomic" | "aria-autocomplete" | "aria-busy" | "aria-checked" | "aria-colcount" | "aria-colindex" | "aria-colspan" | "aria-controls" | "aria-current" | "aria-describedby" | "aria-details" | "aria-disabled" | "aria-dropeffect" | "aria-errormessage" | "aria-expanded" | "aria-flowto" | "aria-grabbed" | "aria-haspopup" | "aria-hidden" | "aria-invalid" | "aria-keyshortcuts" | "aria-label" | "aria-labelledby" | "aria-level" | "aria-live" | "aria-modal" | "aria-multiline" | "aria-multiselectable" | "aria-orientation" | "aria-owns" | "aria-placeholder" | "aria-posinset" | "aria-pressed" | "aria-readonly" | "aria-relevant" | "aria-required" | "aria-roledescription" | "aria-rowcount" | "aria-rowindex" | "aria-rowspan" | "aria-selected" | "aria-setsize" | "aria-sort" | "aria-valuemax" | "aria-valuemin" | "aria-valuenow" | "aria-valuetext" | "children" | "dangerouslySetInnerHTML" | "onCopy" | "onCopyCapture" | "onCut" | "onCutCapture" | "onPaste" | "onPasteCapture" | "onCompositionEnd" | "onCompositionEndCapture" | "onCompositionStart" | "onCompositionStartCapture" | "onCompositionUpdate" | "onCompositionUpdateCapture" | "onFocus" | "onFocusCapture" | "onBlur" | "onBlurCapture" | "onChange" | "onChangeCapture" | "onBeforeInput" | "onBeforeInputCapture" | "onInput" | "onInputCapture" | "onReset" | "onResetCapture" | "onSubmit" | "onSubmitCapture" | "onInvalid" | "onInvalidCapture" | "onLoad" | "onLoadCapture" | "onError" | "onErrorCapture" | "onKeyDown" | "onKeyDownCapture" | "onKeyPress" | "onKeyPressCapture" | "onKeyUp" | "onKeyUpCapture" | "onAbort" | "onAbortCapture" | "onCanPlay" | "onCanPlayCapture" | "onCanPlayThrough" | "onCanPlayThroughCapture" | "onDurationChange" | "onDurationChangeCapture" | "onEmptied" | "onEmptiedCapture" | "onEncrypted" | "onEncryptedCapture" | "onEnded" | "onEndedCapture" | "onLoadedData" | "onLoadedDataCapture" | "onLoadedMetadata" | "onLoadedMetadataCapture" | "onLoadStart" | "onLoadStartCapture" | "onPause" | "onPauseCapture" | "onPlay" | "onPlayCapture" | "onPlaying" | "onPlayingCapture" | "onProgress" | "onProgressCapture" | "onRateChange" | "onRateChangeCapture" | "onSeeked" | "onSeekedCapture" | "onSeeking" | "onSeekingCapture" | "onStalled" | "onStalledCapture" | "onSuspend" | "onSuspendCapture" | "onTimeUpdate" | "onTimeUpdateCapture" | "onVolumeChange" | "onVolumeChangeCapture" | "onWaiting" | "onWaitingCapture" | "onAuxClick" | "onAuxClickCapture" | "onClick" | "onClickCapture" | "onContextMenu" | "onContextMenuCapture" | "onDoubleClick" | "onDoubleClickCapture" | "onDrag" | "onDragCapture" | "onDragEnd" | "onDragEndCapture" | "onDragEnter" | "onDragEnterCapture" | "onDragExit" | "onDragExitCapture" | "onDragLeave" | "onDragLeaveCapture" | "onDragOver" | "onDragOverCapture" | "onDragStart" | "onDragStartCapture" | "onDrop" | "onDropCapture" | "onMouseDown" | "onMouseDownCapture" | "onMouseEnter" | "onMouseLeave" | "onMouseMove" | "onMouseMoveCapture" | "onMouseOut" | "onMouseOutCapture" | "onMouseOver" | "onMouseOverCapture" | "onMouseUp" | "onMouseUpCapture" | "onSelect" | "onSelectCapture" | "onTouchCancel" | "onTouchCancelCapture" | "onTouchEnd" | "onTouchEndCapture" | "onTouchMove" | "onTouchMoveCapture" | "onTouchStart" | "onTouchStartCapture" | "onPointerDown" | "onPointerDownCapture" | "onPointerMove" | "onPointerMoveCapture" | "onPointerUp" | "onPointerUpCapture" | "onPointerCancel" | "onPointerCancelCapture" | "onPointerEnter" | "onPointerEnterCapture" | "onPointerLeave" | "onPointerLeaveCapture" | "onPointerOver" | "onPointerOverCapture" | "onPointerOut" | "onPointerOutCapture" | "onGotPointerCapture" | "onGotPointerCaptureCapture" | "onLostPointerCapture" | "onLostPointerCaptureCapture" | "onScroll" | "onScrollCapture" | "onWheel" | "onWheelCapture" | "onAnimationStart" | "onAnimationStartCapture" | "onAnimationEnd" | "onAnimationEndCapture" | "onAnimationIteration" | "onAnimationIterationCapture" | "onTransitionEnd" | "onTransitionEndCapture" | "border" | "borderTop" | "borderRight" | "borderBottom" | "borderLeft" | "borderColor" | "borderRadius" | "display" | "displayPrint" | "overflow" | "textOverflow" | "visibility" | "whiteSpace" | "flexBasis" | "flexDirection" | "flexWrap" | "justifyContent" | "alignItems" | "alignContent" | "order" | "flex" | "flexGrow" | "flexShrink" | "alignSelf" | "justifyItems" | "justifySelf" | "gap" | "columnGap" | "rowGap" | "gridColumn" | "gridRow" | "gridAutoFlow" | "gridAutoColumns" | "gridAutoRows" | "gridTemplateColumns" | "gridTemplateRows" | "gridTemplateAreas" | "gridArea" | "bgcolor" | "zIndex" | "position" | "top" | "right" | "bottom" | "left" | "boxShadow" | "width" | "maxWidth" | "minWidth" | "height" | "maxHeight" | "minHeight" | "boxSizing" | "m" | "mt" | "mr" | "mb" | "ml" | "mx" | "my" | "pt" | "pr" | "pb" | "pl" | "px" | "py" | "margin" | "marginTop" | "marginRight" | "marginBottom" | "marginLeft" | "marginX" | "marginY" | "marginInline" | "marginInlineStart" | "marginInlineEnd" | "marginBlock" | "marginBlockStart" | "marginBlockEnd" | "padding" | "paddingTop" | "paddingRight" | "paddingBottom" | "paddingLeft" | "paddingX" | "paddingY" | "paddingInline" | "paddingInlineStart" | "paddingInlineEnd" | "paddingBlock" | "paddingBlockStart" | "paddingBlockEnd" | "typography" | "fontFamily" | "fontSize" | "fontStyle" | "fontWeight" | "letterSpacing" | "lineHeight" | "textAlign" | "textTransform" | "component" | "sx" | "classes" | "onClose" | "TextFieldProps" | "onSave"> & React.RefAttributes<unknown>>;
|
|
@@ -46,7 +46,7 @@ const AudienceLayer = react_1.default.forwardRef((props, ref) => {
|
|
|
46
46
|
// @ts-ignore
|
|
47
47
|
defaultValue === null || defaultValue.length === 0
|
|
48
48
|
? AudienceTypes.AUDIENCE_ALL
|
|
49
|
-
:
|
|
49
|
+
: defaultValue && Object.prototype.hasOwnProperty.call(defaultValue, 'managed_by')
|
|
50
50
|
? AudienceTypes.AUDIENCE_GROUP
|
|
51
51
|
: AudienceTypes.AUDIENCE_TAG);
|
|
52
52
|
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
@@ -55,15 +55,15 @@ const AudienceLayer = react_1.default.forwardRef((props, ref) => {
|
|
|
55
55
|
// HOOKS
|
|
56
56
|
const { scAddressingTags } = (0, react_core_1.useSCFetchAddressingTagList)({ fetch: autocompleteOpen });
|
|
57
57
|
// HANDLERS
|
|
58
|
-
const handleSave = (0, react_1.useCallback)(
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
() => (typeof defaultValue === 'object' ? onSave(value) : onSave((value === null || value === void 0 ? void 0 : value.length) && (value === null || value === void 0 ? void 0 : value.length) > 0 ? value : null)), [value, onSave]);
|
|
58
|
+
const handleSave = (0, react_1.useCallback)(() => {
|
|
59
|
+
audience === AudienceTypes.AUDIENCE_GROUP ? onSave(value) : onSave((value === null || value === void 0 ? void 0 : value.length) && (value === null || value === void 0 ? void 0 : value.length) > 0 ? value : null);
|
|
60
|
+
}, [value, onSave, audience]);
|
|
62
61
|
const handleChange = (0, react_1.useCallback)((event, tags) => setValue(tags), []);
|
|
63
62
|
const handleGroupChange = (0, react_1.useCallback)((group) => setValue(group), []);
|
|
64
63
|
const handleChangeAudience = (0, react_1.useCallback)((event, data) => setAudience(data), []);
|
|
65
64
|
const handleAutocompleteOpen = (0, react_1.useCallback)(() => setAutocompleteOpen(true), []);
|
|
66
65
|
const handleAutocompleteClose = (0, react_1.useCallback)(() => setAutocompleteOpen(false), []);
|
|
66
|
+
console.log(defaultValue);
|
|
67
67
|
return (react_1.default.createElement(Root, Object.assign({ ref: ref, className: (0, classnames_1.default)(className, classes.root) }, rest),
|
|
68
68
|
react_1.default.createElement(material_1.DialogTitle, { className: classes.title },
|
|
69
69
|
react_1.default.createElement(material_1.IconButton, { onClick: onClose },
|
|
@@ -75,20 +75,10 @@ const AudienceLayer = react_1.default.forwardRef((props, ref) => {
|
|
|
75
75
|
react_1.default.createElement(DialogContent_1.default, { className: classes.content },
|
|
76
76
|
react_1.default.createElement(material_1.Tabs, { value: audience, onChange: handleChangeAudience, "aria-label": "audience type" },
|
|
77
77
|
react_1.default.createElement(material_1.Tab, { value: AudienceTypes.AUDIENCE_ALL, icon: react_1.default.createElement(Icon_1.default, null, "public"), label: react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.composer.layer.audience.all", defaultMessage: "ui.composer.layer.audience.all" }) }),
|
|
78
|
-
react_1.default.createElement(material_1.Tab
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
, {
|
|
82
|
-
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
83
|
-
// @ts-ignore
|
|
84
|
-
disabled: defaultValue && defaultValue.length !== 0, value: AudienceTypes.AUDIENCE_GROUP, icon: react_1.default.createElement(Icon_1.default, null, "groups"), label: react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.composer.layer.audience.group", defaultMessage: "ui.composer.layer.audience.group" }) }),
|
|
85
|
-
react_1.default.createElement(material_1.Tab
|
|
86
|
-
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
87
|
-
// @ts-ignore
|
|
88
|
-
, {
|
|
89
|
-
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
90
|
-
// @ts-ignore
|
|
91
|
-
disabled: typeof defaultValue === 'object', value: AudienceTypes.AUDIENCE_TAG, icon: react_1.default.createElement(Icon_1.default, null, "label"), label: react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.composer.layer.audience.tag", defaultMessage: "ui.composer.layer.audience.tag" }) })),
|
|
78
|
+
react_1.default.createElement(material_1.Tab, { disabled: (Boolean(value === null || value === void 0 ? void 0 : value.length) && !Object.prototype.hasOwnProperty.call(value, 'managed_by')) ||
|
|
79
|
+
(value !== undefined && Boolean(!(value === null || value === void 0 ? void 0 : value.length)) && audience !== AudienceTypes.AUDIENCE_ALL) ||
|
|
80
|
+
(Boolean((value === null || value === void 0 ? void 0 : value.length) === 0) && audience === AudienceTypes.AUDIENCE_ALL && Boolean((defaultValue === null || defaultValue === void 0 ? void 0 : defaultValue.length) !== 0)), value: AudienceTypes.AUDIENCE_GROUP, icon: react_1.default.createElement(Icon_1.default, null, "groups"), label: react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.composer.layer.audience.group", defaultMessage: "ui.composer.layer.audience.group" }) }),
|
|
81
|
+
react_1.default.createElement(material_1.Tab, { disabled: value && Object.prototype.hasOwnProperty.call(value, 'managed_by'), value: AudienceTypes.AUDIENCE_TAG, icon: react_1.default.createElement(Icon_1.default, null, "label"), label: react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.composer.layer.audience.tag", defaultMessage: "ui.composer.layer.audience.tag" }) })),
|
|
92
82
|
react_1.default.createElement(material_1.Typography, { className: classes.message },
|
|
93
83
|
audience === AudienceTypes.AUDIENCE_ALL && (react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.composer.layer.audience.all.message", defaultMessage: "ui.composer.audience.layer.all.message" })),
|
|
94
84
|
audience === AudienceTypes.AUDIENCE_GROUP && (react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.composer.layer.audience.group.message", defaultMessage: "ui.composer.audience.layer.group.message" })),
|
|
@@ -135,6 +135,8 @@ const Editor = (inProps, ref) => {
|
|
|
135
135
|
}
|
|
136
136
|
}));
|
|
137
137
|
// RENDER
|
|
138
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-ignore
|
|
139
|
+
// @ts-ignore
|
|
138
140
|
const initialConfig = (0, react_1.useMemo)(() => ({
|
|
139
141
|
namespace: 'LexicalEditor',
|
|
140
142
|
editable: editable,
|
|
@@ -105,6 +105,8 @@ function convertImageElement(domNode) {
|
|
|
105
105
|
}
|
|
106
106
|
return null;
|
|
107
107
|
}
|
|
108
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-ignore
|
|
109
|
+
// @ts-ignore
|
|
108
110
|
class ImageNode extends lexical_1.DecoratorNode {
|
|
109
111
|
constructor(src, altText, maxWidth, key) {
|
|
110
112
|
super(key);
|
|
@@ -170,8 +172,12 @@ class ImageNode extends lexical_1.DecoratorNode {
|
|
|
170
172
|
}
|
|
171
173
|
exportJSON() {
|
|
172
174
|
return {
|
|
175
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-ignore
|
|
176
|
+
// @ts-ignore
|
|
173
177
|
altText: this.getAltText(),
|
|
174
178
|
maxWidth: this.__maxWidth,
|
|
179
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-ignore
|
|
180
|
+
// @ts-ignore
|
|
175
181
|
src: this.getSrc(),
|
|
176
182
|
type: 'image',
|
|
177
183
|
version: 1
|
|
@@ -79,6 +79,8 @@ const Root = (0, styles_1.styled)(Image, {
|
|
|
79
79
|
function ImagePlugin() {
|
|
80
80
|
const [editor] = (0, LexicalComposerContext_1.useLexicalComposerContext)();
|
|
81
81
|
(0, react_1.useEffect)(() => {
|
|
82
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-ignore
|
|
83
|
+
// @ts-ignore
|
|
82
84
|
if (!editor.hasNodes([ImageNode_1.ImageNode])) {
|
|
83
85
|
return;
|
|
84
86
|
}
|
|
@@ -95,6 +97,8 @@ function ImagePlugin() {
|
|
|
95
97
|
return true;
|
|
96
98
|
}, lexical_1.COMMAND_PRIORITY_EDITOR);
|
|
97
99
|
}, [editor]);
|
|
100
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-ignore
|
|
101
|
+
// @ts-ignore
|
|
98
102
|
if (!editor.hasNodes([ImageNode_1.ImageNode])) {
|
|
99
103
|
return null;
|
|
100
104
|
}
|
|
@@ -50,7 +50,7 @@ function BlockFormatIconButton({ className = '', editor, blockType, disabled = f
|
|
|
50
50
|
const formatParagraph = () => {
|
|
51
51
|
editor.update(() => {
|
|
52
52
|
const selection = (0, lexical_1.$getSelection)();
|
|
53
|
-
if ((0, lexical_1.$isRangeSelection)(selection) || (0,
|
|
53
|
+
if ((0, lexical_1.$isRangeSelection)(selection) || (0, table_1.$isTableSelection)(selection)) {
|
|
54
54
|
(0, selection_1.$setBlocksType)(selection, () => (0, lexical_1.$createParagraphNode)());
|
|
55
55
|
}
|
|
56
56
|
});
|
|
@@ -59,7 +59,7 @@ function BlockFormatIconButton({ className = '', editor, blockType, disabled = f
|
|
|
59
59
|
if (blockType !== headingSize) {
|
|
60
60
|
editor.update(() => {
|
|
61
61
|
const selection = (0, lexical_1.$getSelection)();
|
|
62
|
-
if ((0, lexical_1.$isRangeSelection)(selection) || (0,
|
|
62
|
+
if ((0, lexical_1.$isRangeSelection)(selection) || (0, table_1.$isTableSelection)(selection)) {
|
|
63
63
|
(0, selection_1.$setBlocksType)(selection, () => (0, rich_text_1.$createHeadingNode)(headingSize));
|
|
64
64
|
}
|
|
65
65
|
});
|
|
@@ -85,7 +85,7 @@ function BlockFormatIconButton({ className = '', editor, blockType, disabled = f
|
|
|
85
85
|
if (blockType !== 'quote') {
|
|
86
86
|
editor.update(() => {
|
|
87
87
|
const selection = (0, lexical_1.$getSelection)();
|
|
88
|
-
if ((0, lexical_1.$isRangeSelection)(selection) || (0,
|
|
88
|
+
if ((0, lexical_1.$isRangeSelection)(selection) || (0, table_1.$isTableSelection)(selection)) {
|
|
89
89
|
(0, selection_1.$setBlocksType)(selection, () => (0, rich_text_1.$createQuoteNode)());
|
|
90
90
|
}
|
|
91
91
|
});
|
|
@@ -169,6 +169,8 @@ function ToolbarPlugin(inProps) {
|
|
|
169
169
|
const elementDOM = activeEditor.getElementByKey(elementKey);
|
|
170
170
|
// Update text format
|
|
171
171
|
setFormats(FORMATS.filter((f) => selection.hasFormat(f)));
|
|
172
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-ignore
|
|
173
|
+
// @ts-ignore
|
|
172
174
|
setAlignment(ALIGNMENTS.find((a) => element.getFormatType() === a) || ALIGNMENTS[0]);
|
|
173
175
|
// Update links
|
|
174
176
|
const node = (0, editor_1.getSelectedNode)(selection);
|
|
@@ -194,6 +196,8 @@ function ToolbarPlugin(inProps) {
|
|
|
194
196
|
setBlockType(type);
|
|
195
197
|
}
|
|
196
198
|
else {
|
|
199
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-ignore
|
|
200
|
+
// @ts-ignore
|
|
197
201
|
const type = (0, rich_text_1.$isHeadingNode)(element) ? element.getTag() : element.getType();
|
|
198
202
|
if (type in blockTypeToBlockIcon) {
|
|
199
203
|
setBlockType(type);
|
|
@@ -236,12 +240,22 @@ function ToolbarPlugin(inProps) {
|
|
|
236
240
|
node = node.splitText(anchor.offset)[1] || node;
|
|
237
241
|
}
|
|
238
242
|
if (idx === nodes.length - 1) {
|
|
243
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-ignore
|
|
244
|
+
// @ts-ignore
|
|
239
245
|
node = node.splitText(focus.offset)[0] || node;
|
|
240
246
|
}
|
|
247
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-ignore
|
|
248
|
+
// @ts-ignore
|
|
241
249
|
if (node.__style !== '') {
|
|
250
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-ignore
|
|
251
|
+
// @ts-ignore
|
|
242
252
|
node.setStyle('');
|
|
243
253
|
}
|
|
254
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-ignore
|
|
255
|
+
// @ts-ignore
|
|
244
256
|
if (node.__format !== 0) {
|
|
257
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-ignore
|
|
258
|
+
// @ts-ignore
|
|
245
259
|
node.setFormat(0);
|
|
246
260
|
(0, utils_1.$getNearestBlockElementAncestorOrThrow)(node).setFormat('');
|
|
247
261
|
}
|
|
@@ -70,6 +70,7 @@ function Share(props) {
|
|
|
70
70
|
const { enqueueSnackbar } = (0, notistack_1.useSnackbar)();
|
|
71
71
|
const domain = typeof location !== 'undefined' && location.origin ? location.origin : '';
|
|
72
72
|
const url = domain + scRoutingContext.url((0, contribution_1.getContributionRouteName)(obj), (0, contribution_1.getRouteData)(obj));
|
|
73
|
+
const isGroupPublic = (0, react_1.useMemo)(() => feedObject.group && feedObject.group.privacy === types_1.SCGroupPrivacyType.PUBLIC, [feedObject.group]);
|
|
73
74
|
// INTL
|
|
74
75
|
const intl = (0, react_intl_1.useIntl)();
|
|
75
76
|
// HANDLERS
|
|
@@ -188,22 +189,23 @@ function Share(props) {
|
|
|
188
189
|
}
|
|
189
190
|
function renderShareMenuItems() {
|
|
190
191
|
return (react_1.default.createElement(material_1.Box, null,
|
|
191
|
-
react_1.default.createElement(
|
|
192
|
-
react_1.default.createElement(
|
|
193
|
-
react_1.default.createElement(
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
react_1.default.createElement(
|
|
197
|
-
react_1.default.createElement(
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
react_1.default.createElement(
|
|
201
|
-
react_1.default.createElement(
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
react_1.default.createElement(
|
|
205
|
-
react_1.default.createElement(
|
|
206
|
-
|
|
192
|
+
(!feedObject.group || isGroupPublic) && (react_1.default.createElement(react_1.default.Fragment, null,
|
|
193
|
+
react_1.default.createElement(MenuItem_1.default, { onClick: () => share(false) },
|
|
194
|
+
react_1.default.createElement(ListItemIcon_1.default, null,
|
|
195
|
+
react_1.default.createElement(Icon_1.default, { fontSize: "small" }, "redo")),
|
|
196
|
+
react_1.default.createElement(material_1.ListItemText, { primary: react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.feedObject.share.shareNow", defaultMessage: "ui.feedObject.share.shareNow" }) })),
|
|
197
|
+
facebookShareEnabled && (react_1.default.createElement(MenuItem_1.default, { onClick: () => window.open(SocialShare_1.FACEBOOK_SHARE + url, 'facebook-share-dialog', 'width=626,height=436') },
|
|
198
|
+
react_1.default.createElement(ListItemIcon_1.default, null,
|
|
199
|
+
react_1.default.createElement(Icon_1.default, { fontSize: "small" }, "facebook")),
|
|
200
|
+
react_1.default.createElement(material_1.ListItemText, { primary: react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.feedObject.share.facebook", defaultMessage: "ui.feedObject.share.facebook" }) }))),
|
|
201
|
+
twitterShareEnabled && (react_1.default.createElement(MenuItem_1.default, { onClick: () => window.open(SocialShare_1.TWITTER_SHARE + url, 'twitter-share-dialog', 'width=626,height=436') },
|
|
202
|
+
react_1.default.createElement(ListItemIcon_1.default, null,
|
|
203
|
+
react_1.default.createElement(Icon_1.default, { fontSize: "small" }, "twitter")),
|
|
204
|
+
react_1.default.createElement(material_1.ListItemText, { primary: react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.feedObject.share.twitter", defaultMessage: "ui.feedObject.share.twitter" }) }))),
|
|
205
|
+
linkedinShareEnabled && (react_1.default.createElement(MenuItem_1.default, { onClick: () => window.open(SocialShare_1.LINKEDIN_SHARE + url, 'linkedin-share-dialog', 'width=626,height=436') },
|
|
206
|
+
react_1.default.createElement(ListItemIcon_1.default, null,
|
|
207
|
+
react_1.default.createElement(Icon_1.default, { fontSize: "small" }, "linkedin")),
|
|
208
|
+
react_1.default.createElement(material_1.ListItemText, { primary: react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.feedObject.share.linkedin", defaultMessage: "ui.feedObject.share.linkedin" }) }))))),
|
|
207
209
|
react_1.default.createElement(MenuItem_1.default, null,
|
|
208
210
|
react_1.default.createElement(ListItemIcon_1.default, null,
|
|
209
211
|
react_1.default.createElement(Icon_1.default, { fontSize: "small" }, "link")),
|
|
@@ -60,6 +60,6 @@ function ContributorsFeedObject(props) {
|
|
|
60
60
|
openContributorsDialog && (react_1.default.createElement(BaseDialog_1.default, { title: react_1.default.createElement(react_intl_1.FormattedMessage, { defaultMessage: "ui.feedObject.contributors.title", id: "ui.feedObject.contributors.title", values: { total: contributorsObject.total } }), onClose: () => setOpenContributorsDialog(false), open: openContributorsDialog }, contributorsObject.isLoadingNext ? (react_1.default.createElement(CentralProgress_1.default, { size: 50 })) : (react_1.default.createElement(InfiniteScroll_1.default, { dataLength: contributorsObject.contributors.length, next: contributorsObject.getNextPage(), hasMoreNext: Boolean(contributorsObject.next), loaderNext: react_1.default.createElement(CentralProgress_1.default, { size: 30 }), height: 400, endMessage: react_1.default.createElement(material_1.Typography, { variant: "body2", align: "center", fontWeight: "bold" },
|
|
61
61
|
react_1.default.createElement(react_intl_1.FormattedMessage, { id: "ui.feedObject.contributors.noOtherContributors", defaultMessage: "ui.feedObject.contributors.noOtherContributors" })) },
|
|
62
62
|
react_1.default.createElement(material_1.List, null, contributorsObject.contributors.map((c, i) => (react_1.default.createElement(material_1.ListItem, { key: i },
|
|
63
|
-
react_1.default.createElement(User_1.default, { elevation: 0, user: c, key: c.id, sx: { m: 0 } }))))))))))) : null)))));
|
|
63
|
+
react_1.default.createElement(User_1.default, { elevation: 0, user: c, key: c.id, sx: { m: 0 }, onClick: () => setOpenContributorsDialog(false) }))))))))))) : null)))));
|
|
64
64
|
}
|
|
65
65
|
exports.default = ContributorsFeedObject;
|
|
@@ -188,6 +188,7 @@ export interface FeedObjectProps extends CardProps, VirtualScrollerItemProps {
|
|
|
188
188
|
|deleted|.SCFeedObject-deleted|Styles applied to the feed obj when is deleted (visible only for admin and moderator).|
|
|
189
189
|
|header|.SCFeedObject-header|Styles applied to the header of the card.|
|
|
190
190
|
|category|.SCFeedObject-category|Styles applied to the category element.|
|
|
191
|
+
|group|.SCFeedObject-group|Styles applied to the group element.|
|
|
191
192
|
|avatar|.SCFeedObject-avatar|Styles applied to the avatar element.|
|
|
192
193
|
|username|.SCFeedObject-username|Styles applied to the username element.|
|
|
193
194
|
|activityAt|.SCFeedObject-activity-at|Styles applied to the activity at section.|
|
|
@@ -42,6 +42,10 @@ const messages = (0, react_intl_1.defineMessages)({
|
|
|
42
42
|
visibleToAll: {
|
|
43
43
|
id: 'ui.feedObject.visibleToAll',
|
|
44
44
|
defaultMessage: 'ui.feedObject.visibleToAll'
|
|
45
|
+
},
|
|
46
|
+
visibleToGroup: {
|
|
47
|
+
id: 'ui.feedObject.visibleToGroup',
|
|
48
|
+
defaultMessage: 'ui.feedObject.visibleToGroup'
|
|
45
49
|
}
|
|
46
50
|
});
|
|
47
51
|
const classes = {
|
|
@@ -49,6 +53,7 @@ const classes = {
|
|
|
49
53
|
deleted: `${constants_1.PREFIX}-deleted`,
|
|
50
54
|
header: `${constants_1.PREFIX}-header`,
|
|
51
55
|
category: `${constants_1.PREFIX}-category`,
|
|
56
|
+
group: `${constants_1.PREFIX}-group`,
|
|
52
57
|
avatar: `${constants_1.PREFIX}-avatar`,
|
|
53
58
|
username: `${constants_1.PREFIX}-username`,
|
|
54
59
|
activityAt: `${constants_1.PREFIX}-activity-at`,
|
|
@@ -102,6 +107,7 @@ const Root = (0, styles_1.styled)(Widget_1.default, {
|
|
|
102
107
|
|deleted|.SCFeedObject-deleted|Styles applied to the feed obj when is deleted (visible only for admin and moderator).|
|
|
103
108
|
|header|.SCFeedObject-header|Styles applied to the header of the card.|
|
|
104
109
|
|category|.SCFeedObject-category|Styles applied to the category element.|
|
|
110
|
+
|group|.SCFeedObject-group|Styles applied to the group element.|
|
|
105
111
|
|avatar|.SCFeedObject-avatar|Styles applied to the avatar element.|
|
|
106
112
|
|username|.SCFeedObject-username|Styles applied to the username element.|
|
|
107
113
|
|activityAt|.SCFeedObject-activity-at|Styles applied to the activity at section.|
|
|
@@ -169,7 +175,7 @@ function FeedObject(inProps) {
|
|
|
169
175
|
}, [onStateChange, onHeightChange]);
|
|
170
176
|
/**
|
|
171
177
|
* Update state object
|
|
172
|
-
* @param
|
|
178
|
+
* @param newObj
|
|
173
179
|
*/
|
|
174
180
|
const updateObject = (newObj) => {
|
|
175
181
|
setObj(newObj);
|
|
@@ -198,8 +204,10 @@ function FeedObject(inProps) {
|
|
|
198
204
|
/**
|
|
199
205
|
* Handle change/update poll: votes
|
|
200
206
|
*/
|
|
201
|
-
const handleChangePoll = (0, react_1.useCallback)((
|
|
202
|
-
|
|
207
|
+
const handleChangePoll = (0, react_1.useCallback)((pollChoices) => {
|
|
208
|
+
if ('poll' in obj) {
|
|
209
|
+
updateObject(Object.assign({}, obj, { poll: Object.assign(Object.assign({}, obj.poll), { choices: pollChoices }) }));
|
|
210
|
+
}
|
|
203
211
|
}, [obj]);
|
|
204
212
|
/**
|
|
205
213
|
* Handle change poll visibility
|
|
@@ -426,8 +434,13 @@ function FeedObject(inProps) {
|
|
|
426
434
|
template === feedObject_1.SCFeedObjectTemplateType.DETAIL ||
|
|
427
435
|
template === feedObject_1.SCFeedObjectTemplateType.SEARCH) {
|
|
428
436
|
objElement = (react_1.default.createElement(react_1.default.Fragment, null, obj ? (react_1.default.createElement(material_1.Box, { className: (0, classnames_1.default)({ [classes.deleted]: obj && obj.deleted }) },
|
|
429
|
-
obj.categories.length > 0 && (react_1.default.createElement("div", { className: classes.category },
|
|
430
|
-
react_1.default.createElement(
|
|
437
|
+
obj.categories.length > 0 && (react_1.default.createElement("div", { className: classes.category },
|
|
438
|
+
react_1.default.createElement(react_1.default.Fragment, null, obj.group && (react_1.default.createElement("div", { className: classes.group },
|
|
439
|
+
react_1.default.createElement(material_1.Chip, { color: "secondary", size: "small", key: obj.group.id, icon: react_1.default.createElement(Icon_1.default, null, "groups"), component: react_core_1.Link, to: scRoutingContext.url(react_core_1.SCRoutes.GROUP_ROUTE_NAME, obj.group), clickable: true })))),
|
|
440
|
+
obj.categories.map((c) => (react_1.default.createElement(react_core_1.Link, { to: scRoutingContext.url(react_core_1.SCRoutes.CATEGORY_ROUTE_NAME, c), key: c.id },
|
|
441
|
+
react_1.default.createElement(material_1.Typography, { variant: "overline" }, c.name)))))),
|
|
442
|
+
obj.group && !obj.categories.length && (react_1.default.createElement("div", { className: classes.group },
|
|
443
|
+
react_1.default.createElement(material_1.Chip, { color: "secondary", size: "small", key: obj.group.id, icon: react_1.default.createElement(Icon_1.default, null, "groups"), label: obj.group.name, component: react_core_1.Link, to: scRoutingContext.url(react_core_1.SCRoutes.GROUP_ROUTE_NAME, obj.group), clickable: true }))),
|
|
431
444
|
react_1.default.createElement(material_1.CardHeader, { className: classes.header, avatar: react_1.default.createElement(react_core_1.Link, Object.assign({}, (!obj.author.deleted && { to: scRoutingContext.url(react_core_1.SCRoutes.USER_PROFILE_ROUTE_NAME, obj.author) }), { onClick: obj.author.deleted ? () => setOpenAlert(true) : null }),
|
|
432
445
|
react_1.default.createElement(UserAvatar_1.default, { hide: !obj.author.community_badge },
|
|
433
446
|
react_1.default.createElement(material_1.Avatar, { "aria-label": "recipe", src: obj.author.avatar, className: classes.avatar }, obj.author.username))), title: react_1.default.createElement(react_core_1.Link, Object.assign({}, (!obj.author.deleted && { to: scRoutingContext.url(react_core_1.SCRoutes.USER_PROFILE_ROUTE_NAME, obj.author) }), { onClick: obj.author.deleted ? () => setOpenAlert(true) : null, className: classes.username }), obj.author.username), subheader: react_1.default.createElement(react_1.default.Fragment, null,
|
|
@@ -439,7 +452,8 @@ function FeedObject(inProps) {
|
|
|
439
452
|
react_1.default.createElement(Icon_1.default, null, "add_location_alt"), (_a = obj.location) === null || _a === void 0 ? void 0 :
|
|
440
453
|
_a.location))),
|
|
441
454
|
react_1.default.createElement(Bullet_1.default, null),
|
|
442
|
-
react_1.default.createElement(material_1.Box, { className: classes.tag }, obj.addressing.length > 0 ? (react_1.default.createElement(Tags_1.default, { tags: obj.addressing, TagChipProps: { disposable: false, clickable: false } })) : (react_1.default.createElement(material_1.Tooltip, { title: `${intl.formatMessage(messages.
|
|
455
|
+
react_1.default.createElement(material_1.Box, { className: classes.tag }, obj.addressing.length > 0 ? (react_1.default.createElement(Tags_1.default, { tags: obj.addressing, TagChipProps: { disposable: false, clickable: false } })) : obj.group ? (react_1.default.createElement(material_1.Tooltip, { title: `${intl.formatMessage(messages.visibleToGroup, { group: obj.group.name })}` },
|
|
456
|
+
react_1.default.createElement(Icon_1.default, { color: "disabled", fontSize: "small" }, "groups"))) : (react_1.default.createElement(material_1.Tooltip, { title: `${intl.formatMessage(messages.visibleToAll)}` },
|
|
443
457
|
react_1.default.createElement(Icon_1.default, { color: "disabled", fontSize: "small" }, "public"))))), action: renderHeaderAction() }),
|
|
444
458
|
react_1.default.createElement(CardContent_1.default, { classes: { root: classes.content } },
|
|
445
459
|
react_1.default.createElement(material_1.Box, { className: classes.titleSection }, 'title' in obj && (react_1.default.createElement(react_1.default.Fragment, null, template === feedObject_1.SCFeedObjectTemplateType.DETAIL ? (react_1.default.createElement(material_1.Typography, { variant: "body1", gutterBottom: true, className: classes.title }, obj.title)) : (react_1.default.createElement(react_core_1.Link, { to: scRoutingContext.url((0, contribution_1.getContributionRouteName)(obj), (0, contribution_1.getRouteData)(obj)) },
|
|
@@ -468,8 +482,13 @@ function FeedObject(inProps) {
|
|
|
468
482
|
}
|
|
469
483
|
else if (template === feedObject_1.SCFeedObjectTemplateType.SHARE) {
|
|
470
484
|
objElement = (react_1.default.createElement(react_1.default.Fragment, null, obj ? (react_1.default.createElement(react_1.default.Fragment, null,
|
|
471
|
-
obj.categories.length > 0 && (react_1.default.createElement("div", { className: classes.category },
|
|
472
|
-
react_1.default.createElement(
|
|
485
|
+
obj.categories.length > 0 && (react_1.default.createElement("div", { className: classes.category },
|
|
486
|
+
react_1.default.createElement(react_1.default.Fragment, null, obj.group && (react_1.default.createElement("div", { className: classes.group },
|
|
487
|
+
react_1.default.createElement(material_1.Chip, { color: "secondary", size: "small", key: obj.group.id, icon: react_1.default.createElement(Icon_1.default, null, "groups"), component: react_core_1.Link, to: scRoutingContext.url(react_core_1.SCRoutes.GROUP_ROUTE_NAME, obj.group), clickable: true })))),
|
|
488
|
+
obj.categories.map((c) => (react_1.default.createElement(react_core_1.Link, { to: scRoutingContext.url(react_core_1.SCRoutes.CATEGORY_ROUTE_NAME, c), key: c.id },
|
|
489
|
+
react_1.default.createElement(material_1.Typography, { variant: "overline" }, c.name)))))),
|
|
490
|
+
obj.group && !obj.categories.length && (react_1.default.createElement("div", { className: classes.group },
|
|
491
|
+
react_1.default.createElement(material_1.Chip, { color: "secondary", size: "small", key: obj.group.id, icon: react_1.default.createElement(Icon_1.default, null, "groups"), label: obj.group.name, component: react_core_1.Link, to: scRoutingContext.url(react_core_1.SCRoutes.GROUP_ROUTE_NAME, obj.group), clickable: true }))),
|
|
473
492
|
react_1.default.createElement(material_1.CardHeader, { classes: { root: classes.header }, avatar: react_1.default.createElement(react_core_1.Link, Object.assign({}, (!obj.author.deleted && { to: scRoutingContext.url(react_core_1.SCRoutes.USER_PROFILE_ROUTE_NAME, obj.author) }), { onClick: obj.author.deleted ? () => setOpenAlert(true) : null, className: classes.username }),
|
|
474
493
|
react_1.default.createElement(UserAvatar_1.default, { hide: !obj.author.community_badge },
|
|
475
494
|
react_1.default.createElement(material_1.Avatar, { "aria-label": "recipe", src: obj.author.avatar, className: classes.avatar }, obj.author.username))), title: react_1.default.createElement(react_core_1.Link, Object.assign({}, (!obj.author.deleted && { to: scRoutingContext.url(react_core_1.SCRoutes.USER_PROFILE_ROUTE_NAME, obj.author) }), { onClick: obj.author.deleted ? () => setOpenAlert(true) : null, className: classes.username }), obj.author.username), subheader: react_1.default.createElement(react_core_1.Link, { to: scRoutingContext.url((0, contribution_1.getContributionRouteName)(obj), (0, contribution_1.getRouteData)(obj)), className: classes.activityAt },
|