@selfcommunity/react-ui 0.11.0-alpha.76 → 0.11.0-alpha.78
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/OnBoardingWidget/Steps/Appearance/Appearance.js +13 -1
- package/lib/cjs/constants/Media.d.ts +4 -0
- package/lib/cjs/constants/Media.js +5 -1
- package/lib/cjs/shared/AutoPlayer/index.js +5 -1
- package/lib/cjs/shared/Media/File/DisplayComponent.js +7 -4
- package/lib/cjs/shared/Media/File/DocComponent.d.ts +1 -0
- package/lib/cjs/shared/Media/File/DocComponent.js +5 -3
- package/lib/cjs/shared/Media/File/badgePdf.d.ts +1 -0
- package/lib/cjs/shared/Media/File/badgePdf.js +4 -0
- package/lib/cjs/shared/Media/Share/DisplayComponent.js +4 -2
- package/lib/esm/components/OnBoardingWidget/Steps/Appearance/Appearance.js +13 -1
- package/lib/esm/constants/Media.d.ts +4 -0
- package/lib/esm/constants/Media.js +4 -0
- package/lib/esm/shared/AutoPlayer/index.js +5 -1
- package/lib/esm/shared/Media/File/DisplayComponent.js +7 -4
- package/lib/esm/shared/Media/File/DocComponent.d.ts +1 -0
- package/lib/esm/shared/Media/File/DocComponent.js +5 -3
- package/lib/esm/shared/Media/File/badgePdf.d.ts +1 -0
- package/lib/esm/shared/Media/File/badgePdf.js +1 -0
- package/lib/esm/shared/Media/Share/DisplayComponent.js +4 -2
- package/lib/umd/react-ui.js +1 -1
- package/package.json +5 -5
|
@@ -150,7 +150,19 @@ function Appearance(inProps) {
|
|
|
150
150
|
setLoadingLogo('');
|
|
151
151
|
setData({});
|
|
152
152
|
setPreferences((prev) => {
|
|
153
|
-
|
|
153
|
+
// Handle both single preference and array of preferences
|
|
154
|
+
if (Array.isArray(preference)) {
|
|
155
|
+
// If it's an array, find the preference with the matching name
|
|
156
|
+
const matchingPref = preference.find((p) => p.name === name);
|
|
157
|
+
if (matchingPref) {
|
|
158
|
+
return prev.map((p) => Object.assign({}, p, { value: p.name === name ? matchingPref.value : p.value }));
|
|
159
|
+
}
|
|
160
|
+
return prev;
|
|
161
|
+
}
|
|
162
|
+
else {
|
|
163
|
+
// Original behavior for single preference
|
|
164
|
+
return prev.map((p) => Object.assign({}, p, { value: p.name === name ? preference[name].value : p.value }));
|
|
165
|
+
}
|
|
154
166
|
});
|
|
155
167
|
onCompleteAction();
|
|
156
168
|
})
|
|
@@ -17,3 +17,7 @@ export declare const MEDIA_EMBED_SC_SHARED_EVENT = "sc_shared_event";
|
|
|
17
17
|
* MAX_GRID_IMAGES: max number of box rendered in feed preview
|
|
18
18
|
*/
|
|
19
19
|
export declare const MAX_GRID_IMAGES = 5;
|
|
20
|
+
/**
|
|
21
|
+
* Default delay tracking seconds (fallback if not in the preference)
|
|
22
|
+
*/
|
|
23
|
+
export declare const DEFAULT_VIDEO_PLAY_TRACKING_DELAY_SECONDS = 3;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.MAX_GRID_IMAGES = exports.MEDIA_EMBED_SC_SHARED_EVENT = exports.MEDIA_EMBED_SC_SHARED_OBJECT = exports.MEDIA_EMBED_SC_LINK_TYPE = exports.MEDIA_TYPE_EVENT = exports.MEDIA_TYPE_EMBED = exports.MEDIA_TYPE_SHARE = exports.MEDIA_TYPE_URL = exports.MEDIA_TYPE_LINK = exports.MEDIA_TYPE_DOCUMENT = exports.MEDIA_TYPE_VIDEO = exports.MEDIA_TYPE_IMAGE = void 0;
|
|
3
|
+
exports.DEFAULT_VIDEO_PLAY_TRACKING_DELAY_SECONDS = exports.MAX_GRID_IMAGES = exports.MEDIA_EMBED_SC_SHARED_EVENT = exports.MEDIA_EMBED_SC_SHARED_OBJECT = exports.MEDIA_EMBED_SC_LINK_TYPE = exports.MEDIA_TYPE_EVENT = exports.MEDIA_TYPE_EMBED = exports.MEDIA_TYPE_SHARE = exports.MEDIA_TYPE_URL = exports.MEDIA_TYPE_LINK = exports.MEDIA_TYPE_DOCUMENT = exports.MEDIA_TYPE_VIDEO = exports.MEDIA_TYPE_IMAGE = void 0;
|
|
4
4
|
exports.MEDIA_TYPE_IMAGE = 'image';
|
|
5
5
|
exports.MEDIA_TYPE_VIDEO = 'video';
|
|
6
6
|
exports.MEDIA_TYPE_DOCUMENT = 'doc';
|
|
@@ -20,3 +20,7 @@ exports.MEDIA_EMBED_SC_SHARED_EVENT = 'sc_shared_event';
|
|
|
20
20
|
* MAX_GRID_IMAGES: max number of box rendered in feed preview
|
|
21
21
|
*/
|
|
22
22
|
exports.MAX_GRID_IMAGES = 5;
|
|
23
|
+
/**
|
|
24
|
+
* Default delay tracking seconds (fallback if not in the preference)
|
|
25
|
+
*/
|
|
26
|
+
exports.DEFAULT_VIDEO_PLAY_TRACKING_DELAY_SECONDS = 3;
|
|
@@ -7,6 +7,7 @@ const react_waypoint_1 = require("react-waypoint");
|
|
|
7
7
|
const react_player_1 = tslib_1.__importDefault(require("react-player"));
|
|
8
8
|
const material_1 = require("@mui/material");
|
|
9
9
|
const react_core_1 = require("@selfcommunity/react-core");
|
|
10
|
+
const Media_1 = require("../../constants/Media");
|
|
10
11
|
const PREFIX = 'SCAutoPlayer';
|
|
11
12
|
const Root = (0, material_1.styled)(react_waypoint_1.Waypoint, {
|
|
12
13
|
name: PREFIX,
|
|
@@ -21,8 +22,11 @@ function AutoPlayer(props) {
|
|
|
21
22
|
const [played, setPlayed] = (0, react_1.useState)(0);
|
|
22
23
|
const { preferences } = (0, react_core_1.useSCPreferences)();
|
|
23
24
|
const enableAutoplay = react_core_1.SCPreferences.CONFIGURATIONS_VIDEO_AUTOPLAY_ENABLED in preferences && preferences[react_core_1.SCPreferences.CONFIGURATIONS_VIDEO_AUTOPLAY_ENABLED].value;
|
|
25
|
+
const videoPlayTrackingDelaySeconds = react_core_1.SCPreferences.CONFIGURATIONS_VIDEO_PLAY_TRACKING_DELAY_SECONDS in preferences
|
|
26
|
+
? preferences[react_core_1.SCPreferences.CONFIGURATIONS_VIDEO_PLAY_TRACKING_DELAY_SECONDS].value
|
|
27
|
+
: Media_1.DEFAULT_VIDEO_PLAY_TRACKING_DELAY_SECONDS;
|
|
24
28
|
(0, react_1.useEffect)(() => {
|
|
25
|
-
if (played >=
|
|
29
|
+
if (played >= videoPlayTrackingDelaySeconds && played <= videoPlayTrackingDelaySeconds + 1) {
|
|
26
30
|
onVideoWatch === null || onVideoWatch === void 0 ? void 0 : onVideoWatch();
|
|
27
31
|
}
|
|
28
32
|
}, [played]);
|
|
@@ -66,8 +66,10 @@ exports.default = (props) => {
|
|
|
66
66
|
}
|
|
67
67
|
setPreview(index);
|
|
68
68
|
setMediaType(type);
|
|
69
|
-
|
|
70
|
-
|
|
69
|
+
if (type === Media_1.MEDIA_TYPE_IMAGE) {
|
|
70
|
+
onMediaClick(images[index]);
|
|
71
|
+
}
|
|
72
|
+
}, [gallery, setPreview, setMediaType, images, onMediaClick]);
|
|
71
73
|
// RENDERING
|
|
72
74
|
const renderTitle = (o) => {
|
|
73
75
|
if (!o) {
|
|
@@ -133,11 +135,12 @@ exports.default = (props) => {
|
|
|
133
135
|
link.click();
|
|
134
136
|
// Cleanup
|
|
135
137
|
window.URL.revokeObjectURL(url);
|
|
138
|
+
onMediaClick === null || onMediaClick === void 0 ? void 0 : onMediaClick(docs[index]);
|
|
136
139
|
}
|
|
137
140
|
catch (error) {
|
|
138
141
|
utils_1.Logger.error(Errors_1.SCOPE_SC_UI, error);
|
|
139
142
|
}
|
|
140
|
-
}), []);
|
|
143
|
+
}), [onMediaClick]);
|
|
141
144
|
const handleIndexChange = (0, react_1.useCallback)((index) => {
|
|
142
145
|
if (mediaType === Media_1.MEDIA_TYPE_DOCUMENT) {
|
|
143
146
|
setToolbarButtons((0, jsx_runtime_1.jsx)(material_1.IconButton, Object.assign({ onClick: () => handleDownload(index) }, { children: (0, jsx_runtime_1.jsx)(material_1.Icon, { children: "download" }) })));
|
|
@@ -161,5 +164,5 @@ exports.default = (props) => {
|
|
|
161
164
|
if (medias.length === 0) {
|
|
162
165
|
return null;
|
|
163
166
|
}
|
|
164
|
-
return ((0, jsx_runtime_1.jsxs)(Root, Object.assign({ className: (0, classnames_1.default)(classes.displayRoot, className) }, { children: [[1, 3, 4].includes(imagesToShow.length) && renderOne(), imagesToShow.length >= 2 && imagesToShow.length < 4 && renderTwo(), imagesToShow.length >= 4 && renderThree(), preview !== -1 && ((0, jsx_runtime_1.jsx)(Lightbox_1.Lightbox, { onClose: handleClose, index: preview, medias: mediaType === Media_1.MEDIA_TYPE_IMAGE ? images : docs, toolbarButtons: toolbarButtons })), (0, jsx_runtime_1.jsx)(material_1.Stack, Object.assign({ className: classes.docsWrapper }, { children: docs.map((doc, i) => ((0, jsx_runtime_1.jsx)(DocComponent_1.default, { doc: doc, index: i, openPreviewImage: openPreviewImage, handleDownload: handleDownload }, doc.id))) }))] })));
|
|
167
|
+
return ((0, jsx_runtime_1.jsxs)(Root, Object.assign({ className: (0, classnames_1.default)(classes.displayRoot, className) }, { children: [[1, 3, 4].includes(imagesToShow.length) && renderOne(), imagesToShow.length >= 2 && imagesToShow.length < 4 && renderTwo(), imagesToShow.length >= 4 && renderThree(), preview !== -1 && ((0, jsx_runtime_1.jsx)(Lightbox_1.Lightbox, { onClose: handleClose, index: preview, medias: mediaType === Media_1.MEDIA_TYPE_IMAGE ? images : docs, toolbarButtons: toolbarButtons })), (0, jsx_runtime_1.jsx)(material_1.Stack, Object.assign({ className: classes.docsWrapper }, { children: docs.map((doc, i) => ((0, jsx_runtime_1.jsx)(DocComponent_1.default, { doc: doc, index: i, openPreviewImage: openPreviewImage, handleDownload: handleDownload, onMediaClick: onMediaClick }, doc.id))) }))] })));
|
|
165
168
|
};
|
|
@@ -5,6 +5,7 @@ interface DocComponentProps {
|
|
|
5
5
|
onDelete?: (id: number) => void;
|
|
6
6
|
openPreviewImage?: (index: number, type: string) => void;
|
|
7
7
|
handleDownload?: (id: number) => void;
|
|
8
|
+
onMediaClick?: (media: SCMediaType) => void;
|
|
8
9
|
}
|
|
9
10
|
export default function DocComponent(props: DocComponentProps): JSX.Element;
|
|
10
11
|
export {};
|
|
@@ -5,9 +5,11 @@ const material_1 = require("@mui/material");
|
|
|
5
5
|
const constants_1 = require("./constants");
|
|
6
6
|
const react_core_1 = require("@selfcommunity/react-core");
|
|
7
7
|
const Media_1 = require("../../../constants/Media");
|
|
8
|
+
const badgePdf_1 = require("./badgePdf");
|
|
8
9
|
const classes = {
|
|
9
10
|
docRoot: `${constants_1.PREFIX}-doc-root`,
|
|
10
|
-
|
|
11
|
+
imageWrapper: `${constants_1.PREFIX}-image-wrapper`,
|
|
12
|
+
badgePdf: `${constants_1.PREFIX}-badge-pdf`,
|
|
11
13
|
textWrapper: `${constants_1.PREFIX}-text-wrapper`,
|
|
12
14
|
title: `${constants_1.PREFIX}-title`,
|
|
13
15
|
subtitle: `${constants_1.PREFIX}-subtitle`,
|
|
@@ -28,7 +30,7 @@ function formatBytes(bytes, decimals = 2) {
|
|
|
28
30
|
return `${parseFloat((bytes / Math.pow(k, i)).toFixed(dm))} ${sizes[i]}`;
|
|
29
31
|
}
|
|
30
32
|
function DocComponent(props) {
|
|
31
|
-
const { doc, index, onDelete, openPreviewImage, handleDownload } = props;
|
|
32
|
-
return ((0, jsx_runtime_1.jsxs)(Root, Object.assign({ className: classes.docRoot }, { children: [(0, jsx_runtime_1.
|
|
33
|
+
const { doc, index, onDelete, openPreviewImage, handleDownload, onMediaClick } = props;
|
|
34
|
+
return ((0, jsx_runtime_1.jsxs)(Root, Object.assign({ className: classes.docRoot }, { children: [(0, jsx_runtime_1.jsxs)(material_1.Box, Object.assign({ onClick: () => openPreviewImage === null || openPreviewImage === void 0 ? void 0 : openPreviewImage(index, Media_1.MEDIA_TYPE_DOCUMENT), sx: { cursor: openPreviewImage ? 'pointer' : undefined }, className: classes.imageWrapper }, { children: [(0, jsx_runtime_1.jsx)("img", { alt: "pdf preview", src: doc.image_thumbnail ? doc.image_thumbnail.url : doc.image, width: "100%", height: "100%" }), (0, jsx_runtime_1.jsx)("img", { alt: "pdf badge", src: badgePdf_1.BADGE_PDF, className: classes.badgePdf })] })), (0, jsx_runtime_1.jsxs)(material_1.Stack, Object.assign({ className: classes.textWrapper }, { children: [(0, jsx_runtime_1.jsx)(material_1.Typography, Object.assign({ className: classes.title }, { children: doc.title })), doc.size && (0, jsx_runtime_1.jsx)(material_1.Typography, Object.assign({ className: classes.subtitle }, { children: formatBytes(doc.size) }))] })), (handleDownload || onDelete) && ((0, jsx_runtime_1.jsxs)(material_1.Stack, Object.assign({ className: classes.actionWrapper }, { children: [onDelete && ((0, jsx_runtime_1.jsx)(material_1.IconButton, Object.assign({ className: classes.action, onClick: () => onDelete(doc.id) }, { children: (0, jsx_runtime_1.jsx)(material_1.Icon, { children: "delete" }) }))), handleDownload && ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(material_1.IconButton, Object.assign({ className: classes.action, component: react_core_1.Link, to: doc.url, target: "_blank", onClick: () => onMediaClick === null || onMediaClick === void 0 ? void 0 : onMediaClick(doc) }, { children: (0, jsx_runtime_1.jsx)(material_1.Icon, { children: "visibility" }) })), (0, jsx_runtime_1.jsx)(material_1.IconButton, Object.assign({ className: classes.action, onClick: () => handleDownload(index) }, { children: (0, jsx_runtime_1.jsx)(material_1.Icon, { children: "download" }) }))] }))] })))] })));
|
|
33
35
|
}
|
|
34
36
|
exports.default = DocComponent;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const BADGE_PDF = "";
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.BADGE_PDF = void 0;
|
|
4
|
+
exports.BADGE_PDF = '';
|
|
@@ -21,7 +21,7 @@ const classes = {
|
|
|
21
21
|
const Root = (0, material_1.styled)(material_1.Box, {
|
|
22
22
|
name: constants_1.PREFIX,
|
|
23
23
|
slot: 'DisplayRoot'
|
|
24
|
-
})((
|
|
24
|
+
})(() => ({}));
|
|
25
25
|
exports.default = (_a) => {
|
|
26
26
|
var { className, medias = [], onMediaClick = null } = _a, rest = tslib_1.__rest(_a, ["className", "medias", "onMediaClick"]);
|
|
27
27
|
// MEMO
|
|
@@ -29,5 +29,7 @@ exports.default = (_a) => {
|
|
|
29
29
|
if (_medias.length === 0) {
|
|
30
30
|
return null;
|
|
31
31
|
}
|
|
32
|
-
return ((0, jsx_runtime_1.jsx)(Root, Object.assign({ className: (0, classnames_1.default)(className, classes.displayRoot) }, rest, { children: _medias.map((media, i) => ((0, jsx_runtime_1.jsx)(material_1.Box, Object.assign({ className: classes.sharePreview, onClick:
|
|
32
|
+
return ((0, jsx_runtime_1.jsx)(Root, Object.assign({ className: (0, classnames_1.default)(className, classes.displayRoot) }, rest, { children: _medias.map((media, i) => ((0, jsx_runtime_1.jsx)(material_1.Box, Object.assign({ className: classes.sharePreview, onClick: () => {
|
|
33
|
+
onMediaClick === null || onMediaClick === void 0 ? void 0 : onMediaClick(media);
|
|
34
|
+
} }, { children: media.type === Media_1.MEDIA_TYPE_EVENT || (media.embed && media.embed.embed_type === Media_1.MEDIA_EMBED_SC_SHARED_EVENT) ? ((0, jsx_runtime_1.jsx)(Event_1.default, { event: media.embed.metadata, template: event_1.SCEventTemplateType.DETAIL, variant: "outlined", square: true, hideEventParticipants: true, hideEventPlanner: true, actions: (0, jsx_runtime_1.jsx)(jsx_runtime_1.Fragment, {}) })) : ((0, jsx_runtime_1.jsx)(FeedObject_1.default, { feedObjectId: media.embed.metadata.id, feedObjectType: media.embed.metadata.type, variant: "outlined", template: feedObject_1.SCFeedObjectTemplateType.SHARE, cacheStrategy: utils_1.CacheStrategies.CACHE_FIRST })) }), i))) })));
|
|
33
35
|
};
|
|
@@ -148,7 +148,19 @@ export default function Appearance(inProps) {
|
|
|
148
148
|
setLoadingLogo('');
|
|
149
149
|
setData({});
|
|
150
150
|
setPreferences((prev) => {
|
|
151
|
-
|
|
151
|
+
// Handle both single preference and array of preferences
|
|
152
|
+
if (Array.isArray(preference)) {
|
|
153
|
+
// If it's an array, find the preference with the matching name
|
|
154
|
+
const matchingPref = preference.find((p) => p.name === name);
|
|
155
|
+
if (matchingPref) {
|
|
156
|
+
return prev.map((p) => Object.assign({}, p, { value: p.name === name ? matchingPref.value : p.value }));
|
|
157
|
+
}
|
|
158
|
+
return prev;
|
|
159
|
+
}
|
|
160
|
+
else {
|
|
161
|
+
// Original behavior for single preference
|
|
162
|
+
return prev.map((p) => Object.assign({}, p, { value: p.name === name ? preference[name].value : p.value }));
|
|
163
|
+
}
|
|
152
164
|
});
|
|
153
165
|
onCompleteAction();
|
|
154
166
|
})
|
|
@@ -17,3 +17,7 @@ export declare const MEDIA_EMBED_SC_SHARED_EVENT = "sc_shared_event";
|
|
|
17
17
|
* MAX_GRID_IMAGES: max number of box rendered in feed preview
|
|
18
18
|
*/
|
|
19
19
|
export declare const MAX_GRID_IMAGES = 5;
|
|
20
|
+
/**
|
|
21
|
+
* Default delay tracking seconds (fallback if not in the preference)
|
|
22
|
+
*/
|
|
23
|
+
export declare const DEFAULT_VIDEO_PLAY_TRACKING_DELAY_SECONDS = 3;
|
|
@@ -17,3 +17,7 @@ export const MEDIA_EMBED_SC_SHARED_EVENT = 'sc_shared_event';
|
|
|
17
17
|
* MAX_GRID_IMAGES: max number of box rendered in feed preview
|
|
18
18
|
*/
|
|
19
19
|
export const MAX_GRID_IMAGES = 5;
|
|
20
|
+
/**
|
|
21
|
+
* Default delay tracking seconds (fallback if not in the preference)
|
|
22
|
+
*/
|
|
23
|
+
export const DEFAULT_VIDEO_PLAY_TRACKING_DELAY_SECONDS = 3;
|
|
@@ -5,6 +5,7 @@ import { Waypoint } from 'react-waypoint';
|
|
|
5
5
|
import ReactPlayer from 'react-player';
|
|
6
6
|
import { styled } from '@mui/material';
|
|
7
7
|
import { SCPreferences, useSCPreferences } from '@selfcommunity/react-core';
|
|
8
|
+
import { DEFAULT_VIDEO_PLAY_TRACKING_DELAY_SECONDS } from '../../constants/Media';
|
|
8
9
|
const PREFIX = 'SCAutoPlayer';
|
|
9
10
|
const Root = styled(Waypoint, {
|
|
10
11
|
name: PREFIX,
|
|
@@ -19,8 +20,11 @@ export default function AutoPlayer(props) {
|
|
|
19
20
|
const [played, setPlayed] = useState(0);
|
|
20
21
|
const { preferences } = useSCPreferences();
|
|
21
22
|
const enableAutoplay = SCPreferences.CONFIGURATIONS_VIDEO_AUTOPLAY_ENABLED in preferences && preferences[SCPreferences.CONFIGURATIONS_VIDEO_AUTOPLAY_ENABLED].value;
|
|
23
|
+
const videoPlayTrackingDelaySeconds = SCPreferences.CONFIGURATIONS_VIDEO_PLAY_TRACKING_DELAY_SECONDS in preferences
|
|
24
|
+
? preferences[SCPreferences.CONFIGURATIONS_VIDEO_PLAY_TRACKING_DELAY_SECONDS].value
|
|
25
|
+
: DEFAULT_VIDEO_PLAY_TRACKING_DELAY_SECONDS;
|
|
22
26
|
useEffect(() => {
|
|
23
|
-
if (played >=
|
|
27
|
+
if (played >= videoPlayTrackingDelaySeconds && played <= videoPlayTrackingDelaySeconds + 1) {
|
|
24
28
|
onVideoWatch === null || onVideoWatch === void 0 ? void 0 : onVideoWatch();
|
|
25
29
|
}
|
|
26
30
|
}, [played]);
|
|
@@ -64,8 +64,10 @@ export default (props) => {
|
|
|
64
64
|
}
|
|
65
65
|
setPreview(index);
|
|
66
66
|
setMediaType(type);
|
|
67
|
-
|
|
68
|
-
|
|
67
|
+
if (type === MEDIA_TYPE_IMAGE) {
|
|
68
|
+
onMediaClick(images[index]);
|
|
69
|
+
}
|
|
70
|
+
}, [gallery, setPreview, setMediaType, images, onMediaClick]);
|
|
69
71
|
// RENDERING
|
|
70
72
|
const renderTitle = (o) => {
|
|
71
73
|
if (!o) {
|
|
@@ -131,11 +133,12 @@ export default (props) => {
|
|
|
131
133
|
link.click();
|
|
132
134
|
// Cleanup
|
|
133
135
|
window.URL.revokeObjectURL(url);
|
|
136
|
+
onMediaClick === null || onMediaClick === void 0 ? void 0 : onMediaClick(docs[index]);
|
|
134
137
|
}
|
|
135
138
|
catch (error) {
|
|
136
139
|
Logger.error(SCOPE_SC_UI, error);
|
|
137
140
|
}
|
|
138
|
-
}), []);
|
|
141
|
+
}), [onMediaClick]);
|
|
139
142
|
const handleIndexChange = useCallback((index) => {
|
|
140
143
|
if (mediaType === MEDIA_TYPE_DOCUMENT) {
|
|
141
144
|
setToolbarButtons(_jsx(IconButton, Object.assign({ onClick: () => handleDownload(index) }, { children: _jsx(Icon, { children: "download" }) })));
|
|
@@ -159,5 +162,5 @@ export default (props) => {
|
|
|
159
162
|
if (medias.length === 0) {
|
|
160
163
|
return null;
|
|
161
164
|
}
|
|
162
|
-
return (_jsxs(Root, Object.assign({ className: classNames(classes.displayRoot, className) }, { children: [[1, 3, 4].includes(imagesToShow.length) && renderOne(), imagesToShow.length >= 2 && imagesToShow.length < 4 && renderTwo(), imagesToShow.length >= 4 && renderThree(), preview !== -1 && (_jsx(Lightbox, { onClose: handleClose, index: preview, medias: mediaType === MEDIA_TYPE_IMAGE ? images : docs, toolbarButtons: toolbarButtons })), _jsx(Stack, Object.assign({ className: classes.docsWrapper }, { children: docs.map((doc, i) => (_jsx(DocComponent, { doc: doc, index: i, openPreviewImage: openPreviewImage, handleDownload: handleDownload }, doc.id))) }))] })));
|
|
165
|
+
return (_jsxs(Root, Object.assign({ className: classNames(classes.displayRoot, className) }, { children: [[1, 3, 4].includes(imagesToShow.length) && renderOne(), imagesToShow.length >= 2 && imagesToShow.length < 4 && renderTwo(), imagesToShow.length >= 4 && renderThree(), preview !== -1 && (_jsx(Lightbox, { onClose: handleClose, index: preview, medias: mediaType === MEDIA_TYPE_IMAGE ? images : docs, toolbarButtons: toolbarButtons })), _jsx(Stack, Object.assign({ className: classes.docsWrapper }, { children: docs.map((doc, i) => (_jsx(DocComponent, { doc: doc, index: i, openPreviewImage: openPreviewImage, handleDownload: handleDownload, onMediaClick: onMediaClick }, doc.id))) }))] })));
|
|
163
166
|
};
|
|
@@ -5,6 +5,7 @@ interface DocComponentProps {
|
|
|
5
5
|
onDelete?: (id: number) => void;
|
|
6
6
|
openPreviewImage?: (index: number, type: string) => void;
|
|
7
7
|
handleDownload?: (id: number) => void;
|
|
8
|
+
onMediaClick?: (media: SCMediaType) => void;
|
|
8
9
|
}
|
|
9
10
|
export default function DocComponent(props: DocComponentProps): JSX.Element;
|
|
10
11
|
export {};
|
|
@@ -3,9 +3,11 @@ import { Box, Icon, IconButton, Stack, styled, Typography } from '@mui/material'
|
|
|
3
3
|
import { PREFIX } from './constants';
|
|
4
4
|
import { Link } from '@selfcommunity/react-core';
|
|
5
5
|
import { MEDIA_TYPE_DOCUMENT } from '../../../constants/Media';
|
|
6
|
+
import { BADGE_PDF } from './badgePdf';
|
|
6
7
|
const classes = {
|
|
7
8
|
docRoot: `${PREFIX}-doc-root`,
|
|
8
|
-
|
|
9
|
+
imageWrapper: `${PREFIX}-image-wrapper`,
|
|
10
|
+
badgePdf: `${PREFIX}-badge-pdf`,
|
|
9
11
|
textWrapper: `${PREFIX}-text-wrapper`,
|
|
10
12
|
title: `${PREFIX}-title`,
|
|
11
13
|
subtitle: `${PREFIX}-subtitle`,
|
|
@@ -26,6 +28,6 @@ function formatBytes(bytes, decimals = 2) {
|
|
|
26
28
|
return `${parseFloat((bytes / Math.pow(k, i)).toFixed(dm))} ${sizes[i]}`;
|
|
27
29
|
}
|
|
28
30
|
export default function DocComponent(props) {
|
|
29
|
-
const { doc, index, onDelete, openPreviewImage, handleDownload } = props;
|
|
30
|
-
return (_jsxs(Root, Object.assign({ className: classes.docRoot }, { children: [
|
|
31
|
+
const { doc, index, onDelete, openPreviewImage, handleDownload, onMediaClick } = props;
|
|
32
|
+
return (_jsxs(Root, Object.assign({ className: classes.docRoot }, { children: [_jsxs(Box, Object.assign({ onClick: () => openPreviewImage === null || openPreviewImage === void 0 ? void 0 : openPreviewImage(index, MEDIA_TYPE_DOCUMENT), sx: { cursor: openPreviewImage ? 'pointer' : undefined }, className: classes.imageWrapper }, { children: [_jsx("img", { alt: "pdf preview", src: doc.image_thumbnail ? doc.image_thumbnail.url : doc.image, width: "100%", height: "100%" }), _jsx("img", { alt: "pdf badge", src: BADGE_PDF, className: classes.badgePdf })] })), _jsxs(Stack, Object.assign({ className: classes.textWrapper }, { children: [_jsx(Typography, Object.assign({ className: classes.title }, { children: doc.title })), doc.size && _jsx(Typography, Object.assign({ className: classes.subtitle }, { children: formatBytes(doc.size) }))] })), (handleDownload || onDelete) && (_jsxs(Stack, Object.assign({ className: classes.actionWrapper }, { children: [onDelete && (_jsx(IconButton, Object.assign({ className: classes.action, onClick: () => onDelete(doc.id) }, { children: _jsx(Icon, { children: "delete" }) }))), handleDownload && (_jsxs(_Fragment, { children: [_jsx(IconButton, Object.assign({ className: classes.action, component: Link, to: doc.url, target: "_blank", onClick: () => onMediaClick === null || onMediaClick === void 0 ? void 0 : onMediaClick(doc) }, { children: _jsx(Icon, { children: "visibility" }) })), _jsx(IconButton, Object.assign({ className: classes.action, onClick: () => handleDownload(index) }, { children: _jsx(Icon, { children: "download" }) }))] }))] })))] })));
|
|
31
33
|
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const BADGE_PDF = "";
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export const BADGE_PDF = '';
|
|
@@ -19,7 +19,7 @@ const classes = {
|
|
|
19
19
|
const Root = styled(Box, {
|
|
20
20
|
name: PREFIX,
|
|
21
21
|
slot: 'DisplayRoot'
|
|
22
|
-
})((
|
|
22
|
+
})(() => ({}));
|
|
23
23
|
export default (_a) => {
|
|
24
24
|
var { className, medias = [], onMediaClick = null } = _a, rest = __rest(_a, ["className", "medias", "onMediaClick"]);
|
|
25
25
|
// MEMO
|
|
@@ -27,5 +27,7 @@ export default (_a) => {
|
|
|
27
27
|
if (_medias.length === 0) {
|
|
28
28
|
return null;
|
|
29
29
|
}
|
|
30
|
-
return (_jsx(Root, Object.assign({ className: classNames(className, classes.displayRoot) }, rest, { children: _medias.map((media, i) => (_jsx(Box, Object.assign({ className: classes.sharePreview, onClick:
|
|
30
|
+
return (_jsx(Root, Object.assign({ className: classNames(className, classes.displayRoot) }, rest, { children: _medias.map((media, i) => (_jsx(Box, Object.assign({ className: classes.sharePreview, onClick: () => {
|
|
31
|
+
onMediaClick === null || onMediaClick === void 0 ? void 0 : onMediaClick(media);
|
|
32
|
+
} }, { children: media.type === MEDIA_TYPE_EVENT || (media.embed && media.embed.embed_type === MEDIA_EMBED_SC_SHARED_EVENT) ? (_jsx(Event, { event: media.embed.metadata, template: SCEventTemplateType.DETAIL, variant: "outlined", square: true, hideEventParticipants: true, hideEventPlanner: true, actions: _jsx(_Fragment, {}) })) : (_jsx(FeedObject, { feedObjectId: media.embed.metadata.id, feedObjectType: media.embed.metadata.type, variant: "outlined", template: SCFeedObjectTemplateType.SHARE, cacheStrategy: CacheStrategies.CACHE_FIRST })) }), i))) })));
|
|
31
33
|
};
|