@selfcommunity/react-ui 0.8.1-alpha.4 → 0.9.0-alpha.1

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 (80) hide show
  1. package/lib/cjs/components/CreateEventButton/CreateEventButton.d.ts +2 -2
  2. package/lib/cjs/components/CreateEventButton/CreateEventButton.js +4 -4
  3. package/lib/cjs/components/EditEventButton/EditEventButton.js +1 -1
  4. package/lib/cjs/components/EventForm/EventForm.d.ts +7 -12
  5. package/lib/cjs/components/EventForm/EventForm.js +55 -55
  6. package/lib/cjs/components/EventFormDialog/EventFormDialog.d.ts +48 -0
  7. package/lib/cjs/components/EventFormDialog/EventFormDialog.js +56 -0
  8. package/lib/cjs/components/EventFormDialog/constants.d.ts +1 -0
  9. package/lib/cjs/components/EventFormDialog/constants.js +4 -0
  10. package/lib/cjs/components/EventFormDialog/index.d.ts +3 -0
  11. package/lib/cjs/components/EventFormDialog/index.js +5 -0
  12. package/lib/cjs/components/EventMediaWidget/EventMediaWidget.d.ts +37 -0
  13. package/lib/cjs/components/EventMediaWidget/EventMediaWidget.js +242 -0
  14. package/lib/cjs/components/EventMediaWidget/Skeleton.d.ts +2 -0
  15. package/lib/cjs/components/EventMediaWidget/Skeleton.js +28 -0
  16. package/lib/cjs/components/EventMediaWidget/TriggerButton.d.ts +17 -0
  17. package/lib/cjs/components/EventMediaWidget/TriggerButton.js +66 -0
  18. package/lib/cjs/components/EventMediaWidget/asUploadButton.d.ts +7 -0
  19. package/lib/cjs/components/EventMediaWidget/asUploadButton.js +25 -0
  20. package/lib/cjs/components/EventMediaWidget/constants.d.ts +1 -0
  21. package/lib/cjs/components/EventMediaWidget/constants.js +4 -0
  22. package/lib/cjs/components/EventMediaWidget/index.d.ts +4 -0
  23. package/lib/cjs/components/EventMediaWidget/index.js +8 -0
  24. package/lib/cjs/components/PrivateMessageThreadItem/PrivateMessageThreadItem.js +1 -3
  25. package/lib/cjs/index.d.ts +8 -5
  26. package/lib/cjs/index.js +18 -13
  27. package/lib/cjs/shared/Lightbox/BaseLightbox.d.ts +19 -0
  28. package/lib/cjs/shared/Lightbox/BaseLightbox.js +35 -0
  29. package/lib/cjs/shared/Lightbox/Lightbox.d.ts +31 -17
  30. package/lib/cjs/shared/Lightbox/Lightbox.js +16 -19
  31. package/lib/cjs/shared/Lightbox/constants.d.ts +1 -0
  32. package/lib/cjs/shared/Lightbox/constants.js +4 -0
  33. package/lib/cjs/shared/Lightbox/index.d.ts +4 -2
  34. package/lib/cjs/shared/Lightbox/index.js +4 -1
  35. package/lib/cjs/shared/Media/File/DisplayComponent.js +23 -6
  36. package/lib/cjs/shared/MediaChunkUploader/index.js +13 -11
  37. package/lib/cjs/utils/hash.d.ts +2 -1
  38. package/lib/esm/components/CreateEventButton/CreateEventButton.d.ts +2 -2
  39. package/lib/esm/components/CreateEventButton/CreateEventButton.js +4 -4
  40. package/lib/esm/components/EditEventButton/EditEventButton.js +1 -1
  41. package/lib/esm/components/EventForm/EventForm.d.ts +7 -12
  42. package/lib/esm/components/EventForm/EventForm.js +56 -56
  43. package/lib/esm/components/EventFormDialog/EventFormDialog.d.ts +48 -0
  44. package/lib/esm/components/EventFormDialog/EventFormDialog.js +53 -0
  45. package/lib/esm/components/EventFormDialog/constants.d.ts +1 -0
  46. package/lib/esm/components/EventFormDialog/constants.js +1 -0
  47. package/lib/esm/components/EventFormDialog/index.d.ts +3 -0
  48. package/lib/esm/components/EventFormDialog/index.js +2 -0
  49. package/lib/esm/components/EventMediaWidget/EventMediaWidget.d.ts +37 -0
  50. package/lib/esm/components/EventMediaWidget/EventMediaWidget.js +239 -0
  51. package/lib/esm/components/EventMediaWidget/Skeleton.d.ts +2 -0
  52. package/lib/esm/components/EventMediaWidget/Skeleton.js +22 -0
  53. package/lib/esm/components/EventMediaWidget/TriggerButton.d.ts +17 -0
  54. package/lib/esm/components/EventMediaWidget/TriggerButton.js +64 -0
  55. package/lib/esm/components/EventMediaWidget/asUploadButton.d.ts +7 -0
  56. package/lib/esm/components/EventMediaWidget/asUploadButton.js +23 -0
  57. package/lib/esm/components/EventMediaWidget/constants.d.ts +1 -0
  58. package/lib/esm/components/EventMediaWidget/constants.js +1 -0
  59. package/lib/esm/components/EventMediaWidget/index.d.ts +4 -0
  60. package/lib/esm/components/EventMediaWidget/index.js +4 -0
  61. package/lib/esm/components/PrivateMessageThreadItem/PrivateMessageThreadItem.js +1 -3
  62. package/lib/esm/index.d.ts +8 -5
  63. package/lib/esm/index.js +10 -8
  64. package/lib/esm/shared/Lightbox/BaseLightbox.d.ts +19 -0
  65. package/lib/esm/shared/Lightbox/BaseLightbox.js +33 -0
  66. package/lib/esm/shared/Lightbox/Lightbox.d.ts +31 -17
  67. package/lib/esm/shared/Lightbox/Lightbox.js +15 -19
  68. package/lib/esm/shared/Lightbox/constants.d.ts +1 -0
  69. package/lib/esm/shared/Lightbox/constants.js +1 -0
  70. package/lib/esm/shared/Lightbox/index.d.ts +4 -2
  71. package/lib/esm/shared/Lightbox/index.js +3 -1
  72. package/lib/esm/shared/Media/File/DisplayComponent.js +23 -6
  73. package/lib/esm/shared/MediaChunkUploader/index.js +14 -12
  74. package/lib/esm/utils/hash.d.ts +2 -1
  75. package/lib/umd/react-ui.js +1 -1
  76. package/package.json +6 -6
  77. package/lib/cjs/shared/Media/File/Lightbox/index.d.ts +0 -28
  78. package/lib/cjs/shared/Media/File/Lightbox/index.js +0 -37
  79. package/lib/esm/shared/Media/File/Lightbox/index.d.ts +0 -28
  80. package/lib/esm/shared/Media/File/Lightbox/index.js +0 -34
@@ -1,5 +1,5 @@
1
1
  import { __rest } from "tslib";
2
- import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
3
  import { LoadingButton } from '@mui/lab';
4
4
  import { Box, FormControl, FormGroup, Icon, IconButton, InputAdornment, InputLabel, MenuItem, Paper, Select, Stack, Switch, TextField, Typography } from '@mui/material';
5
5
  import { styled } from '@mui/material/styles';
@@ -19,7 +19,6 @@ import { defineMessages, FormattedMessage, useIntl } from 'react-intl';
19
19
  import { SCOPE_SC_UI } from '../../constants/Errors';
20
20
  import { EVENT_DESCRIPTION_MAX_LENGTH, EVENT_TITLE_MAX_LENGTH } from '../../constants/Event';
21
21
  import { SCGroupEventType, SCTopicType } from '../../constants/PubSub';
22
- import BaseDialog from '../../shared/BaseDialog';
23
22
  import { DAILY_LATER_DAYS, MONTHLY_LATER_DAYS, NEVER_LATER_DAYS, PREFIX, WEEKLY_LATER_DAYS } from './constants';
24
23
  import EventAddress from './EventAddress';
25
24
  import UploadEventCover from './UploadEventCover';
@@ -72,11 +71,12 @@ const classes = {
72
71
  name: `${PREFIX}-name`,
73
72
  description: `${PREFIX}-description`,
74
73
  content: `${PREFIX}-content`,
74
+ actions: `${PREFIX}-actions`,
75
75
  privacySection: `${PREFIX}-privacy-section`,
76
76
  privacySectionInfo: `${PREFIX}-privacy-section-info`,
77
77
  error: `${PREFIX}-error`
78
78
  };
79
- const Root = styled(BaseDialog, {
79
+ const Root = styled(Box, {
80
80
  name: PREFIX,
81
81
  slot: 'Root'
82
82
  })(() => ({}));
@@ -118,7 +118,7 @@ export default function EventForm(inProps) {
118
118
  props: inProps,
119
119
  name: PREFIX
120
120
  });
121
- const { className, open = true, onClose, onSuccess, event = null } = props, rest = __rest(props, ["className", "open", "onClose", "onSuccess", "event"]);
121
+ const { className, onSuccess, onError, event = null } = props, rest = __rest(props, ["className", "onSuccess", "onError", "event"]);
122
122
  // CONTEXT
123
123
  const scContext = useSCContext();
124
124
  // INTL
@@ -219,10 +219,9 @@ export default function EventForm(inProps) {
219
219
  }
220
220
  eventService
221
221
  .then((data) => {
222
- onSuccess === null || onSuccess === void 0 ? void 0 : onSuccess(data);
223
222
  notifyChanges(data);
224
- onClose === null || onClose === void 0 ? void 0 : onClose();
225
223
  setField((prev) => (Object.assign(Object.assign({}, prev), { ['isSubmitting']: false })));
224
+ onSuccess === null || onSuccess === void 0 ? void 0 : onSuccess(data);
226
225
  })
227
226
  .catch((e) => {
228
227
  const _error = formatHttpErrorCode(e);
@@ -236,8 +235,9 @@ export default function EventForm(inProps) {
236
235
  }
237
236
  setField((prev) => (Object.assign(Object.assign({}, prev), { ['isSubmitting']: false })));
238
237
  Logger.error(SCOPE_SC_UI, e);
238
+ onError === null || onError === void 0 ? void 0 : onError(e);
239
239
  });
240
- }, [field, privateEnabled, visibilityEnabled]);
240
+ }, [field, privateEnabled, visibilityEnabled, onSuccess, onError]);
241
241
  const handleChange = useCallback((event) => {
242
242
  const { name, value } = event.target;
243
243
  setField((prev) => (Object.assign(Object.assign({}, prev), { [name]: value })));
@@ -282,55 +282,55 @@ export default function EventForm(inProps) {
282
282
  /**
283
283
  * Renders root object
284
284
  */
285
- return (_jsx(Root, Object.assign({ DialogContentProps: { dividers: false }, title: event ? (_jsx(FormattedMessage, { id: "ui.eventForm.title.edit", defaultMessage: "ui.eventForm.title.edit" })) : (_jsx(FormattedMessage, { id: "ui.eventForm.title", defaultMessage: "ui.eventForm.title" })), open: open, onClose: onClose, className: classNames(classes.root, className), actions: _jsx(LoadingButton, Object.assign({ loading: field.isSubmitting, disabled: !field.name ||
286
- !field.startDate ||
287
- !field.startTime ||
288
- !field.endDate ||
289
- !field.endTime ||
290
- (field.location === SCEventLocationType.ONLINE && !field.link) ||
291
- (field.location === SCEventLocationType.PERSON && !field.geolocation) ||
292
- (field.recurring !== SCEventRecurrenceType.NEVER && !field.endDate && !field.endTime) ||
293
- Object.keys(error).length !== 0 ||
294
- field.name.length > EVENT_TITLE_MAX_LENGTH ||
295
- field.description.length > EVENT_DESCRIPTION_MAX_LENGTH, variant: "contained", onClick: handleSubmit, color: "secondary" }, { children: event ? (_jsx(FormattedMessage, { id: "ui.eventForm.button.edit", defaultMessage: "ui.eventForm.button.edit" })) : (_jsx(FormattedMessage, { id: "ui.eventForm.button.create", defaultMessage: "ui.eventForm.button.create" })) })) }, rest, { children: _jsxs(_Fragment, { children: [_jsx(Paper, Object.assign({ style: _backgroundCover, classes: { root: classes.cover } }, { children: _jsx(UploadEventCover, { isCreationMode: true, onChange: handleChangeCover }) })), _jsxs(FormGroup, Object.assign({ className: classes.form }, { children: [_jsx(TextField, { required: true, className: classes.name, placeholder: `${intl.formatMessage(messages.name)}`, margin: "normal", value: field.name, name: "name", onChange: handleChange, InputProps: {
296
- endAdornment: _jsx(Typography, Object.assign({ variant: "body2" }, { children: EVENT_TITLE_MAX_LENGTH - field.name.length }))
297
- }, error: Boolean(field.name.length > EVENT_TITLE_MAX_LENGTH) || Boolean(error['nameError']), helperText: field.name.length > EVENT_TITLE_MAX_LENGTH ? (_jsx(FormattedMessage, { id: "ui.eventForm.name.error.maxLength", defaultMessage: "ui.eventForm.name.error.maxLength" })) : error['nameError'] ? (error['nameError']) : null }), _jsx(Box, Object.assign({ className: classes.dateTime }, { children: _jsxs(LocalizationProvider, Object.assign({ dateAdapter: AdapterDateFns, adapterLocale: scContext.settings.locale.default === 'it' ? itLocale : enLocale }, { children: [_jsx(MobileDatePicker, { className: classes.picker, disablePast: true, label: field.startDate && _jsx(FormattedMessage, { id: "ui.eventForm.date.placeholder", defaultMessage: "ui.eventForm.date.placeholder" }), value: field.startDate, slots: {
298
- textField: (params) => (_jsx(TextField, Object.assign({}, params, { InputProps: Object.assign(Object.assign({}, params.InputProps), { placeholder: `${intl.formatMessage(messages.startDate)}`, startAdornment: (_jsx(InputAdornment, Object.assign({ position: "start" }, { children: _jsx(IconButton, { children: _jsx(Icon, { children: "CalendarIcon" }) }) }))) }) })))
299
- }, slotProps: {
300
- toolbar: {
301
- // eslint-disable-next-line @typescript-eslint/ban-ts-ignore,@typescript-eslint/ban-ts-comment
302
- // @ts-ignore
303
- toolbarTitle: _jsx(FormattedMessage, { id: "ui.eventForm.date.title", defaultMessage: "ui.eventForm.date.title" })
304
- }
305
- }, onChange: (value) => handleChangeDateTime(value, 'startDate') }), _jsx(MobileTimePicker, { className: classes.picker, disablePast: disablePastStartTime, label: field.startTime && _jsx(FormattedMessage, { id: "ui.eventForm.time.placeholder", defaultMessage: "ui.eventForm.time.placeholder" }), value: field.startTime, slots: {
306
- textField: (params) => (_jsx(TextField, Object.assign({}, params, { InputProps: Object.assign(Object.assign({}, params.InputProps), { placeholder: `${intl.formatMessage(messages.startTime)}`, startAdornment: (_jsx(InputAdornment, Object.assign({ position: "start" }, { children: _jsx(IconButton, { children: _jsx(Icon, { children: "access_time" }) }) }))) }) })))
307
- }, slotProps: {
308
- toolbar: {
309
- // eslint-disable-next-line @typescript-eslint/ban-ts-ignore,@typescript-eslint/ban-ts-comment
310
- // @ts-ignore
311
- toolbarTitle: _jsx(FormattedMessage, { id: "ui.eventForm.time.title", defaultMessage: "ui.eventForm.time.title" })
312
- }
313
- }, onChange: (value) => handleChangeDateTime(value, 'startTime') })] })) })), _jsxs(FormControl, Object.assign({ className: classes.frequency }, { children: [field.recurring !== SCEventRecurrenceType.NEVER && _jsx(InputLabel, Object.assign({ id: "recurring" }, { children: `${intl.formatMessage(messages.frequency)}` })), _jsx(Select, Object.assign({ name: "recurring", label: field.recurring !== SCEventRecurrenceType.NEVER && `${intl.formatMessage(messages.frequency)}`, labelId: "recurring", value: field.recurring, onChange: handleChange, displayEmpty: true, renderValue: (selected) => {
314
- if (!selected) {
315
- return _jsx("em", { children: `${intl.formatMessage(messages.frequencyPlaceholder)}` });
316
- }
317
- return (_jsx(FormattedMessage, { id: `ui.eventForm.frequency.${selected}.placeholder`, defaultMessage: `ui.eventForm.frequency.${selected}.placeholder` }));
318
- }, startAdornment: _jsx(InputAdornment, Object.assign({ position: "start" }, { children: _jsx(IconButton, { children: _jsx(Icon, { children: "frequency" }) }) })) }, { children: Object.values(SCEventRecurrenceType).map((f) => (_jsx(MenuItem, Object.assign({ value: f }, { children: _jsx(FormattedMessage, { id: `ui.eventForm.frequency.${f}.placeholder`, defaultMessage: `ui.eventForm.frequency.${f}.placeholder` }) }), f))) }))] })), _jsx(Box, Object.assign({ className: classes.dateTime }, { children: _jsxs(LocalizationProvider, Object.assign({ dateAdapter: AdapterDateFns, adapterLocale: scContext.settings.locale.default === 'it' ? itLocale : enLocale }, { children: [_jsx(MobileDatePicker, { className: classes.picker, disablePast: true, minDate: field.startDate, label: _jsx(FormattedMessage, { id: "ui.eventForm.date.end.placeholder", defaultMessage: "ui.eventForm.date.end.placeholder" }), value: field.endDate, slots: {
319
- textField: (params) => (_jsx(TextField, Object.assign({}, params, { InputProps: Object.assign(Object.assign({}, params.InputProps), { placeholder: `${intl.formatMessage(messages.endDate)}`, startAdornment: (_jsx(InputAdornment, Object.assign({ position: "start" }, { children: _jsx(IconButton, { children: _jsx(Icon, { children: "calendar_off" }) }) }))) }) })))
320
- }, onChange: (value) => handleChangeDateTime(value, 'endDate'), shouldDisableDate: shouldDisabledDate }), _jsx(MobileTimePicker, { className: classes.picker, disablePast: disablePastEndTime, label: field.endTime && _jsx(FormattedMessage, { id: "ui.eventForm.time.end.placeholder", defaultMessage: "ui.eventForm.time.end.placeholder" }), value: field.endTime, slots: {
321
- textField: (params) => {
322
- var _a;
323
- return (_jsx(TextField, Object.assign({}, params, { InputProps: Object.assign(Object.assign({}, params.InputProps), { placeholder: `${intl.formatMessage(messages.endTime)}`, startAdornment: (_jsx(InputAdornment, Object.assign({ position: "start" }, { children: _jsx(IconButton, { children: _jsx(Icon, { children: "access_time" }) }) }))) }), error: Boolean(error['endDateError']), helperText: ((_a = error['endDateError']) === null || _a === void 0 ? void 0 : _a.error) ? (_jsx(FormattedMessage, { id: "ui.eventForm.time.end.error.invalid", defaultMessage: "ui.eventForm.time.end.error.invalid" })) : null })));
324
- }
325
- }, onChange: (value) => handleChangeDateTime(value, 'endTime'), shouldDisableTime: shouldDisabledTime })] })) })), _jsx(EventAddress, { forwardGeolocationData: handleGeoData, event: event !== null && event !== void 0 ? event : null }), privateEnabled && (_jsxs(Box, Object.assign({ className: classes.privacySection }, { children: [_jsxs(Stack, Object.assign({ direction: "row", spacing: 1, alignItems: "center", justifyContent: "center" }, { children: [_jsxs(Typography, Object.assign({ className: classNames(classes.switchLabel, { [classes.active]: !field.isPublic }) }, { children: [_jsx(Icon, { children: "private" }), _jsx(FormattedMessage, { id: "ui.eventForm.privacy.private", defaultMessage: "ui.eventForm.privacy.private" })] })), _jsx(Switch, { className: classes.switch, checked: field.isPublic, onChange: () => setField((prev) => (Object.assign(Object.assign({}, prev), { ['isPublic']: !field.isPublic }))), disabled: event && !field.isPublic }), _jsxs(Typography, Object.assign({ className: classNames(classes.switchLabel, { [classes.active]: field.isPublic }) }, { children: [_jsx(Icon, { children: "public" }), _jsx(FormattedMessage, { id: "ui.eventForm.privacy.public", defaultMessage: "ui.eventForm.privacy.public" })] }))] })), _jsx(Typography, Object.assign({ variant: "body2", textAlign: "center", className: classes.privacySectionInfo }, { children: field.isPublic ? (_jsx(FormattedMessage, { id: "ui.eventForm.privacy.public.info", defaultMessage: "ui.eventForm.privacy.public.info", values: {
326
- // eslint-disable-next-line @typescript-eslint/ban-ts-ignore
285
+ return (_jsxs(Root, Object.assign({ className: classNames(classes.root, className) }, rest, { children: [_jsx(Paper, Object.assign({ style: _backgroundCover, classes: { root: classes.cover } }, { children: _jsx(UploadEventCover, { isCreationMode: true, onChange: handleChangeCover }) })), _jsxs(FormGroup, Object.assign({ className: classes.form }, { children: [_jsx(TextField, { required: true, className: classes.name, placeholder: `${intl.formatMessage(messages.name)}`, margin: "normal", value: field.name, name: "name", onChange: handleChange, InputProps: {
286
+ endAdornment: _jsx(Typography, Object.assign({ variant: "body2" }, { children: EVENT_TITLE_MAX_LENGTH - field.name.length }))
287
+ }, error: Boolean(field.name.length > EVENT_TITLE_MAX_LENGTH) || Boolean(error['nameError']), helperText: field.name.length > EVENT_TITLE_MAX_LENGTH ? (_jsx(FormattedMessage, { id: "ui.eventForm.name.error.maxLength", defaultMessage: "ui.eventForm.name.error.maxLength" })) : error['nameError'] ? (error['nameError']) : null }), _jsx(Box, Object.assign({ className: classes.dateTime }, { children: _jsxs(LocalizationProvider, Object.assign({ dateAdapter: AdapterDateFns, adapterLocale: scContext.settings.locale.default === 'it' ? itLocale : enLocale }, { children: [_jsx(MobileDatePicker, { className: classes.picker, disablePast: true, label: field.startDate && _jsx(FormattedMessage, { id: "ui.eventForm.date.placeholder", defaultMessage: "ui.eventForm.date.placeholder" }), value: field.startDate, slots: {
288
+ textField: (params) => (_jsx(TextField, Object.assign({}, params, { InputProps: Object.assign(Object.assign({}, params.InputProps), { placeholder: `${intl.formatMessage(messages.startDate)}`, startAdornment: (_jsx(InputAdornment, Object.assign({ position: "start" }, { children: _jsx(IconButton, { children: _jsx(Icon, { children: "CalendarIcon" }) }) }))) }) })))
289
+ }, slotProps: {
290
+ toolbar: {
291
+ // eslint-disable-next-line @typescript-eslint/ban-ts-ignore,@typescript-eslint/ban-ts-comment
327
292
  // @ts-ignore
328
- b: (chunks) => _jsx("strong", { children: chunks })
329
- } })) : (_jsx(FormattedMessage, { id: "ui.eventForm.privacy.private.info", defaultMessage: "ui.eventForm.private.public.info", values: {
330
- // eslint-disable-next-line @typescript-eslint/ban-ts-ignore
293
+ toolbarTitle: _jsx(FormattedMessage, { id: "ui.eventForm.date.title", defaultMessage: "ui.eventForm.date.title" })
294
+ }
295
+ }, onChange: (value) => handleChangeDateTime(value, 'startDate') }), _jsx(MobileTimePicker, { className: classes.picker, disablePast: disablePastStartTime, label: field.startTime && _jsx(FormattedMessage, { id: "ui.eventForm.time.placeholder", defaultMessage: "ui.eventForm.time.placeholder" }), value: field.startTime, slots: {
296
+ textField: (params) => (_jsx(TextField, Object.assign({}, params, { InputProps: Object.assign(Object.assign({}, params.InputProps), { placeholder: `${intl.formatMessage(messages.startTime)}`, startAdornment: (_jsx(InputAdornment, Object.assign({ position: "start" }, { children: _jsx(IconButton, { children: _jsx(Icon, { children: "access_time" }) }) }))) }) })))
297
+ }, slotProps: {
298
+ toolbar: {
299
+ // eslint-disable-next-line @typescript-eslint/ban-ts-ignore,@typescript-eslint/ban-ts-comment
331
300
  // @ts-ignore
332
- b: (chunks) => _jsx("strong", { children: chunks })
333
- } })) }))] }))), _jsx(TextField, { multiline: true, className: classes.description, placeholder: `${intl.formatMessage(messages.description)}`, margin: "normal", value: field.description, name: "description", onChange: handleChange, InputProps: {
334
- endAdornment: (_jsx(Typography, Object.assign({ variant: "body2" }, { children: ((_b = field.description) === null || _b === void 0 ? void 0 : _b.length) ? EVENT_DESCRIPTION_MAX_LENGTH - field.description.length : EVENT_DESCRIPTION_MAX_LENGTH })))
335
- }, error: Boolean(((_c = field.description) === null || _c === void 0 ? void 0 : _c.length) > EVENT_DESCRIPTION_MAX_LENGTH), helperText: ((_d = field.description) === null || _d === void 0 ? void 0 : _d.length) > EVENT_DESCRIPTION_MAX_LENGTH ? (_jsx(FormattedMessage, { id: "ui.eventForm.description.error.maxLength", defaultMessage: "ui.eventForm.description.error.maxLength" })) : null })] }))] }) })));
301
+ toolbarTitle: _jsx(FormattedMessage, { id: "ui.eventForm.time.title", defaultMessage: "ui.eventForm.time.title" })
302
+ }
303
+ }, onChange: (value) => handleChangeDateTime(value, 'startTime') })] })) })), _jsxs(FormControl, Object.assign({ className: classes.frequency }, { children: [field.recurring !== SCEventRecurrenceType.NEVER && _jsx(InputLabel, Object.assign({ id: "recurring" }, { children: `${intl.formatMessage(messages.frequency)}` })), _jsx(Select, Object.assign({ name: "recurring", label: field.recurring !== SCEventRecurrenceType.NEVER && `${intl.formatMessage(messages.frequency)}`, labelId: "recurring", value: field.recurring, onChange: handleChange, displayEmpty: true, renderValue: (selected) => {
304
+ if (!selected) {
305
+ return _jsx("em", { children: `${intl.formatMessage(messages.frequencyPlaceholder)}` });
306
+ }
307
+ return (_jsx(FormattedMessage, { id: `ui.eventForm.frequency.${selected}.placeholder`, defaultMessage: `ui.eventForm.frequency.${selected}.placeholder` }));
308
+ }, startAdornment: _jsx(InputAdornment, Object.assign({ position: "start" }, { children: _jsx(IconButton, { children: _jsx(Icon, { children: "frequency" }) }) })) }, { children: Object.values(SCEventRecurrenceType).map((f) => (_jsx(MenuItem, Object.assign({ value: f }, { children: _jsx(FormattedMessage, { id: `ui.eventForm.frequency.${f}.placeholder`, defaultMessage: `ui.eventForm.frequency.${f}.placeholder` }) }), f))) }))] })), _jsx(Box, Object.assign({ className: classes.dateTime }, { children: _jsxs(LocalizationProvider, Object.assign({ dateAdapter: AdapterDateFns, adapterLocale: scContext.settings.locale.default === 'it' ? itLocale : enLocale }, { children: [_jsx(MobileDatePicker, { className: classes.picker, disablePast: true, minDate: field.startDate, label: _jsx(FormattedMessage, { id: "ui.eventForm.date.end.placeholder", defaultMessage: "ui.eventForm.date.end.placeholder" }), value: field.endDate, slots: {
309
+ textField: (params) => (_jsx(TextField, Object.assign({}, params, { InputProps: Object.assign(Object.assign({}, params.InputProps), { placeholder: `${intl.formatMessage(messages.endDate)}`, startAdornment: (_jsx(InputAdornment, Object.assign({ position: "start" }, { children: _jsx(IconButton, { children: _jsx(Icon, { children: "calendar_off" }) }) }))) }) })))
310
+ }, onChange: (value) => handleChangeDateTime(value, 'endDate'), shouldDisableDate: shouldDisabledDate }), _jsx(MobileTimePicker, { className: classes.picker, disablePast: disablePastEndTime, label: field.endTime && _jsx(FormattedMessage, { id: "ui.eventForm.time.end.placeholder", defaultMessage: "ui.eventForm.time.end.placeholder" }), value: field.endTime, slots: {
311
+ textField: (params) => {
312
+ var _a;
313
+ return (_jsx(TextField, Object.assign({}, params, { InputProps: Object.assign(Object.assign({}, params.InputProps), { placeholder: `${intl.formatMessage(messages.endTime)}`, startAdornment: (_jsx(InputAdornment, Object.assign({ position: "start" }, { children: _jsx(IconButton, { children: _jsx(Icon, { children: "access_time" }) }) }))) }), error: Boolean(error['endDateError']), helperText: ((_a = error['endDateError']) === null || _a === void 0 ? void 0 : _a.error) ? (_jsx(FormattedMessage, { id: "ui.eventForm.time.end.error.invalid", defaultMessage: "ui.eventForm.time.end.error.invalid" })) : null })));
314
+ }
315
+ }, onChange: (value) => handleChangeDateTime(value, 'endTime'), shouldDisableTime: shouldDisabledTime })] })) })), _jsx(EventAddress, { forwardGeolocationData: handleGeoData, event: event !== null && event !== void 0 ? event : null }), privateEnabled && (_jsxs(Box, Object.assign({ className: classes.privacySection }, { children: [_jsxs(Stack, Object.assign({ direction: "row", spacing: 1, alignItems: "center", justifyContent: "center" }, { children: [_jsxs(Typography, Object.assign({ className: classNames(classes.switchLabel, { [classes.active]: !field.isPublic }) }, { children: [_jsx(Icon, { children: "private" }), _jsx(FormattedMessage, { id: "ui.eventForm.privacy.private", defaultMessage: "ui.eventForm.privacy.private" })] })), _jsx(Switch, { className: classes.switch, checked: field.isPublic, onChange: () => setField((prev) => (Object.assign(Object.assign({}, prev), { ['isPublic']: !field.isPublic }))), disabled: event && !field.isPublic }), _jsxs(Typography, Object.assign({ className: classNames(classes.switchLabel, { [classes.active]: field.isPublic }) }, { children: [_jsx(Icon, { children: "public" }), _jsx(FormattedMessage, { id: "ui.eventForm.privacy.public", defaultMessage: "ui.eventForm.privacy.public" })] }))] })), _jsx(Typography, Object.assign({ variant: "body2", textAlign: "center", className: classes.privacySectionInfo }, { children: field.isPublic ? (_jsx(FormattedMessage, { id: "ui.eventForm.privacy.public.info", defaultMessage: "ui.eventForm.privacy.public.info", values: {
316
+ // eslint-disable-next-line @typescript-eslint/ban-ts-ignore
317
+ // @ts-ignore
318
+ b: (chunks) => _jsx("strong", { children: chunks })
319
+ } })) : (_jsx(FormattedMessage, { id: "ui.eventForm.privacy.private.info", defaultMessage: "ui.eventForm.private.public.info", values: {
320
+ // eslint-disable-next-line @typescript-eslint/ban-ts-ignore
321
+ // @ts-ignore
322
+ b: (chunks) => _jsx("strong", { children: chunks })
323
+ } })) }))] }))), _jsx(TextField, { multiline: true, className: classes.description, placeholder: `${intl.formatMessage(messages.description)}`, margin: "normal", value: field.description, name: "description", onChange: handleChange, InputProps: {
324
+ endAdornment: (_jsx(Typography, Object.assign({ variant: "body2" }, { children: ((_b = field.description) === null || _b === void 0 ? void 0 : _b.length) ? EVENT_DESCRIPTION_MAX_LENGTH - field.description.length : EVENT_DESCRIPTION_MAX_LENGTH })))
325
+ }, error: Boolean(((_c = field.description) === null || _c === void 0 ? void 0 : _c.length) > EVENT_DESCRIPTION_MAX_LENGTH), helperText: ((_d = field.description) === null || _d === void 0 ? void 0 : _d.length) > EVENT_DESCRIPTION_MAX_LENGTH ? (_jsx(FormattedMessage, { id: "ui.eventForm.description.error.maxLength", defaultMessage: "ui.eventForm.description.error.maxLength" })) : null }), _jsx(Box, Object.assign({ className: classes.actions }, { children: _jsx(LoadingButton, Object.assign({ loading: field.isSubmitting, disabled: !field.name ||
326
+ !field.startDate ||
327
+ !field.startTime ||
328
+ !field.endDate ||
329
+ !field.endTime ||
330
+ (field.location === SCEventLocationType.ONLINE && !field.link) ||
331
+ (field.location === SCEventLocationType.PERSON && !field.geolocation) ||
332
+ (field.recurring !== SCEventRecurrenceType.NEVER && !field.endDate && !field.endTime) ||
333
+ Object.keys(error).length !== 0 ||
334
+ field.name.length > EVENT_TITLE_MAX_LENGTH ||
335
+ field.description.length > EVENT_DESCRIPTION_MAX_LENGTH, variant: "contained", onClick: handleSubmit, color: "secondary" }, { children: event ? (_jsx(FormattedMessage, { id: "ui.eventForm.button.edit", defaultMessage: "ui.eventForm.button.edit" })) : (_jsx(FormattedMessage, { id: "ui.eventForm.button.create", defaultMessage: "ui.eventForm.button.create" })) })) }))] }))] })));
336
336
  }
@@ -0,0 +1,48 @@
1
+ import { BaseDialogProps } from '../../shared/BaseDialog';
2
+ import { EventFormProps } from '../EventForm';
3
+ export interface EventFormDialogProps extends BaseDialogProps {
4
+ /**
5
+ * Overrides or extends the styles applied to the component.
6
+ * @default null
7
+ */
8
+ className?: string;
9
+ /**
10
+ * Open dialog
11
+ * @default true
12
+ */
13
+ open?: boolean;
14
+ /**
15
+ * On dialog close callback function
16
+ * @default null
17
+ */
18
+ onClose?: () => void;
19
+ /**
20
+ * Props to spread to EventForm component
21
+ * @default {}
22
+ */
23
+ EventFormComponentProps?: EventFormProps;
24
+ /**
25
+ * Any other properties
26
+ */
27
+ [p: string]: any;
28
+ }
29
+ /**
30
+ *> API documentation for the Community-JS EventFormDialog component. Learn about the available props and the CSS API.
31
+ *
32
+ #### Import
33
+ ```jsx
34
+ import {EventFormDialog} from '@selfcommunity/react-ui';
35
+ ```
36
+
37
+ #### Component Name
38
+ The name `SCEventFormDialog` can be used when providing style overrides in the theme.
39
+
40
+ #### CSS
41
+
42
+ |Rule Name|Global class|Description|
43
+ |---|---|---|
44
+ |root|.SCEventFormDialog-root|Styles applied to the root element.|
45
+
46
+ * @param inProps
47
+ */
48
+ export default function EventFormDialog(inProps: EventFormDialogProps): JSX.Element;
@@ -0,0 +1,53 @@
1
+ import { __rest } from "tslib";
2
+ import { jsx as _jsx } from "react/jsx-runtime";
3
+ import { styled } from '@mui/material/styles';
4
+ import { useThemeProps } from '@mui/system';
5
+ import classNames from 'classnames';
6
+ import { FormattedMessage } from 'react-intl';
7
+ import BaseDialog from '../../shared/BaseDialog';
8
+ import { PREFIX } from './constants';
9
+ import EventForm from '../EventForm';
10
+ import { useCallback } from 'react';
11
+ const classes = {
12
+ root: `${PREFIX}-root`
13
+ };
14
+ const Root = styled(BaseDialog, {
15
+ name: PREFIX,
16
+ slot: 'Root'
17
+ })(() => ({}));
18
+ /**
19
+ *> API documentation for the Community-JS EventFormDialog component. Learn about the available props and the CSS API.
20
+ *
21
+ #### Import
22
+ ```jsx
23
+ import {EventFormDialog} from '@selfcommunity/react-ui';
24
+ ```
25
+
26
+ #### Component Name
27
+ The name `SCEventFormDialog` can be used when providing style overrides in the theme.
28
+
29
+ #### CSS
30
+
31
+ |Rule Name|Global class|Description|
32
+ |---|---|---|
33
+ |root|.SCEventFormDialog-root|Styles applied to the root element.|
34
+
35
+ * @param inProps
36
+ */
37
+ export default function EventFormDialog(inProps) {
38
+ //PROPS
39
+ const props = useThemeProps({
40
+ props: inProps,
41
+ name: PREFIX
42
+ });
43
+ const { className, open = true, onClose, EventFormComponentProps = {} } = props, rest = __rest(props, ["className", "open", "onClose", "EventFormComponentProps"]);
44
+ const handleSuccess = useCallback((event) => {
45
+ var _a;
46
+ (_a = EventFormComponentProps.onSuccess) === null || _a === void 0 ? void 0 : _a.call(EventFormComponentProps, event);
47
+ onClose === null || onClose === void 0 ? void 0 : onClose();
48
+ }, [onClose, EventFormComponentProps]);
49
+ /**
50
+ * Renders root object
51
+ */
52
+ return (_jsx(Root, Object.assign({ DialogContentProps: { dividers: false }, title: (EventFormComponentProps === null || EventFormComponentProps === void 0 ? void 0 : EventFormComponentProps.event) ? (_jsx(FormattedMessage, { id: "ui.eventForm.title.edit", defaultMessage: "ui.eventForm.title.edit" })) : (_jsx(FormattedMessage, { id: "ui.eventForm.title", defaultMessage: "ui.eventForm.title" })), open: open, onClose: onClose, className: classNames(classes.root, className) }, rest, { children: _jsx(EventForm, Object.assign({}, EventFormComponentProps, { onSuccess: handleSuccess })) })));
53
+ }
@@ -0,0 +1 @@
1
+ export declare const PREFIX = "SCEventFormDialog";
@@ -0,0 +1 @@
1
+ export const PREFIX = 'SCEventFormDialog';
@@ -0,0 +1,3 @@
1
+ import EventFormDialog, { EventFormDialogProps } from './EventFormDialog';
2
+ export default EventFormDialog;
3
+ export { EventFormDialogProps };
@@ -0,0 +1,2 @@
1
+ import EventFormDialog from './EventFormDialog';
2
+ export default EventFormDialog;
@@ -0,0 +1,37 @@
1
+ import { SCEventType } from '@selfcommunity/types';
2
+ import { CacheStrategies } from '@selfcommunity/utils';
3
+ import { BaseDialogProps } from '../../shared/BaseDialog';
4
+ import { WidgetProps } from '../Widget';
5
+ export interface EventMediaWidgetProps extends WidgetProps {
6
+ /**
7
+ * Event Object
8
+ * @default null
9
+ */
10
+ event?: SCEventType;
11
+ /**
12
+ * Id of event object
13
+ * @default null
14
+ */
15
+ eventId?: number;
16
+ /**
17
+ * Feed API Query Params
18
+ * @default [{'limit': 20, 'offset': 0}]
19
+ */
20
+ endpointQueryParams?: Record<string, string | number>;
21
+ /**
22
+ * Caching strategies
23
+ * @default CacheStrategies.CACHE_FIRST
24
+ */
25
+ cacheStrategy?: CacheStrategies;
26
+ /**
27
+ * Props to spread to users suggestion dialog
28
+ * @default {}
29
+ */
30
+ dialogProps?: BaseDialogProps;
31
+ limit?: number;
32
+ /**
33
+ * Other props
34
+ */
35
+ [p: string]: any;
36
+ }
37
+ export default function EventMediaWidget(inProps: EventMediaWidgetProps): JSX.Element;
@@ -0,0 +1,239 @@
1
+ import { __rest } from "tslib";
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import { LoadingButton } from '@mui/lab';
4
+ import { Button, CardActions, CardContent, CardHeader, Divider, Icon, Stack, Tooltip, Typography, useMediaQuery, useTheme } from '@mui/material';
5
+ import { styled } from '@mui/material/styles';
6
+ import { Box, useThemeProps } from '@mui/system';
7
+ import { Endpoints, EventService, http } from '@selfcommunity/api-services';
8
+ import { SCCache, useSCFetchEvent, useSCUser } from '@selfcommunity/react-core';
9
+ import { Logger } from '@selfcommunity/utils';
10
+ import { Fragment, useCallback, useEffect, useMemo, useReducer, useState } from 'react';
11
+ import { defineMessages, FormattedMessage, useIntl } from 'react-intl';
12
+ import { SCOPE_SC_UI } from '../../constants/Errors';
13
+ import { DEFAULT_PAGINATION_LIMIT, DEFAULT_PAGINATION_OFFSET } from '../../constants/Pagination';
14
+ import BaseDialog from '../../shared/BaseDialog';
15
+ import ConfirmDialog from '../../shared/ConfirmDialog/ConfirmDialog';
16
+ import HiddenPlaceholder from '../../shared/HiddenPlaceholder';
17
+ import InfiniteScroll from '../../shared/InfiniteScroll';
18
+ import { Lightbox } from '../../shared/Lightbox';
19
+ import { actionWidgetTypes, dataWidgetReducer, stateWidgetInitializer } from '../../utils/widget';
20
+ import Widget from '../Widget';
21
+ import { PREFIX } from './constants';
22
+ import SkeletonComponent, { EventMediaSkeleton } from './Skeleton';
23
+ import TriggerButton from './TriggerButton';
24
+ const messages = defineMessages({
25
+ title: {
26
+ id: 'ui.eventMediaWidget.title',
27
+ defaultMessage: 'ui.eventMediaWidget.title'
28
+ }
29
+ });
30
+ const MEDIAS_TO_SHOW = 9;
31
+ const classes = {
32
+ root: `${PREFIX}-root`,
33
+ header: `${PREFIX}-header`,
34
+ grid: `${PREFIX}-grid`,
35
+ media: `${PREFIX}-media`,
36
+ mediaLayer: `${PREFIX}-media-layer`,
37
+ countHiddenMediaWrapper: `${PREFIX}-count-hidden-media-wrapper`,
38
+ countHiddenMedia: `${PREFIX}-count-hidden-media`,
39
+ content: `${PREFIX}-content`,
40
+ actions: `${PREFIX}-actions`,
41
+ dialogRoot: `${PREFIX}-dialog-root`,
42
+ dialogInfiniteScroll: `${PREFIX}-dialog-infinite-scroll`,
43
+ dialogMediaWrapper: `${PREFIX}-dialog-media-wrapper`,
44
+ dialogButtonWrapper: `${PREFIX}-dialog-button-wrapper`,
45
+ dialogLoadingButton: `${PREFIX}-dialog-loading-button`,
46
+ endMessage: `${PREFIX}-end-message`
47
+ };
48
+ const Root = styled(Widget, {
49
+ name: PREFIX,
50
+ slot: 'Root',
51
+ overridesResolver: (_props, styles) => styles.root,
52
+ shouldForwardProp: (prop) => prop !== 'showPadding'
53
+ })(() => ({}));
54
+ const DialogRoot = styled(BaseDialog, {
55
+ name: PREFIX,
56
+ slot: 'DialogRoot',
57
+ overridesResolver: (_props, styles) => styles.dialogRoot,
58
+ shouldForwardProp: (prop) => prop !== 'loading'
59
+ })(() => ({}));
60
+ export default function EventMediaWidget(inProps) {
61
+ // PROPS
62
+ const props = useThemeProps({
63
+ props: inProps,
64
+ name: PREFIX
65
+ });
66
+ // CONST
67
+ const { event, eventId, limit = DEFAULT_PAGINATION_LIMIT, endpointQueryParams = {
68
+ limit,
69
+ offset: DEFAULT_PAGINATION_OFFSET
70
+ }, cacheStrategy, dialogProps } = props, rest = __rest(props, ["event", "eventId", "limit", "endpointQueryParams", "cacheStrategy", "dialogProps"]);
71
+ // STATE
72
+ const [state, dispatch] = useReducer(dataWidgetReducer, {
73
+ isLoadingNext: false,
74
+ next: null,
75
+ cacheKey: SCCache.getWidgetStateCacheKey(SCCache.EVENT_MEDIA_STATE_CACHE_PREFIX_KEY),
76
+ cacheStrategy,
77
+ visibleItems: limit
78
+ }, stateWidgetInitializer);
79
+ const [medias, setMedias] = useState([]);
80
+ const [mediasCount, setMediasCount] = useState(0);
81
+ const [openDialog, setOpenDialog] = useState(false);
82
+ const [openDialogConfirm, setOpenDialogConfirm] = useState(false);
83
+ const [mediaId, setMediaId] = useState(null);
84
+ const [preview, setPreview] = useState(-1);
85
+ const [loading, setLoading] = useState(false);
86
+ const [showSkeleton, setShowSkeleton] = useState(null);
87
+ // CONTEXT
88
+ const scUserContext = useSCUser();
89
+ // HOOKS
90
+ const { scEvent } = useSCFetchEvent({ id: eventId, event });
91
+ const intl = useIntl();
92
+ const theme = useTheme();
93
+ const isMobile = useMediaQuery(theme.breakpoints.down('md'));
94
+ // CONSTS
95
+ const hasAllow = useMemo(() => { var _a; return ((_a = scUserContext.user) === null || _a === void 0 ? void 0 : _a.id) === (scEvent === null || scEvent === void 0 ? void 0 : scEvent.managed_by.id); }, [scUserContext, scEvent]);
96
+ const countHiddenMedia = useMemo(() => mediasCount - MEDIAS_TO_SHOW, [mediasCount]);
97
+ /**
98
+ * Initialize component
99
+ * Fetch data only if the component is not initialized and it is not loading data
100
+ */
101
+ const _initComponent = useCallback(() => {
102
+ if (!state.initialized && !state.isLoadingNext) {
103
+ dispatch({ type: actionWidgetTypes.LOADING_NEXT });
104
+ EventService.getEventPhotoGallery(scEvent.id, Object.assign({}, endpointQueryParams))
105
+ .then((payload) => {
106
+ dispatch({ type: actionWidgetTypes.LOAD_NEXT_SUCCESS, payload: Object.assign(Object.assign({}, payload), { initialized: true }) });
107
+ setMedias(payload.results);
108
+ setMediasCount(payload.count);
109
+ })
110
+ .catch((error) => {
111
+ dispatch({ type: actionWidgetTypes.LOAD_NEXT_FAILURE, payload: { errorLoadNext: error } });
112
+ Logger.error(SCOPE_SC_UI, error);
113
+ });
114
+ }
115
+ }, [state.isLoadingNext, state.initialized, scEvent, dispatch, setMedias, setMediasCount]);
116
+ const _fetchNext = useCallback((index) => {
117
+ if (mediasCount > medias.length && index >= 6 && !state.isLoadingNext && state.next) {
118
+ setPreview(index);
119
+ dispatch({ type: actionWidgetTypes.LOADING_NEXT });
120
+ http
121
+ .request({
122
+ url: state.next,
123
+ method: Endpoints.GetEventPhotoGallery.method
124
+ })
125
+ .then((res) => {
126
+ dispatch({ type: actionWidgetTypes.LOAD_NEXT_SUCCESS, payload: res.data });
127
+ setMedias((prev) => [...prev, ...res.data.results]);
128
+ setMediasCount(res.data.count);
129
+ })
130
+ .catch((error) => {
131
+ dispatch({ type: actionWidgetTypes.LOAD_NEXT_FAILURE, payload: { errorLoadNext: error } });
132
+ Logger.error(SCOPE_SC_UI, error);
133
+ });
134
+ }
135
+ }, [state.next, state.isLoadingNext, medias, mediasCount, dispatch, setPreview]);
136
+ const handleOpenLightbox = useCallback((index) => {
137
+ setPreview(index);
138
+ }, [setPreview]);
139
+ const handleCloseLightbox = useCallback(() => {
140
+ setPreview(-1);
141
+ }, [setPreview]);
142
+ const handleToggleDialogOpen = useCallback(() => {
143
+ setOpenDialog((prev) => !prev);
144
+ }, [setOpenDialog]);
145
+ const handleNext = useCallback(() => {
146
+ setShowSkeleton('dialog');
147
+ dispatch({ type: actionWidgetTypes.LOADING_NEXT });
148
+ http
149
+ .request({
150
+ url: state.next,
151
+ method: Endpoints.GetEventPhotoGallery.method
152
+ })
153
+ .then((res) => {
154
+ dispatch({ type: actionWidgetTypes.LOAD_NEXT_SUCCESS, payload: res.data });
155
+ setMedias((prev) => [...prev, ...res.data.results]);
156
+ setMediasCount(res.data.count);
157
+ setShowSkeleton(null);
158
+ })
159
+ .catch((error) => {
160
+ dispatch({ type: actionWidgetTypes.LOAD_NEXT_FAILURE, payload: { errorLoadNext: error } });
161
+ Logger.error(SCOPE_SC_UI, error);
162
+ });
163
+ }, [state.next, state.isLoadingNext, state.initialized, dispatch, setMedias, setMediasCount, setShowSkeleton]);
164
+ const handleRemoveMedia = useCallback((id) => {
165
+ if (hasAllow) {
166
+ setMediaId(id);
167
+ setOpenDialogConfirm(true);
168
+ }
169
+ }, [setMediaId, setOpenDialogConfirm]);
170
+ const handleConfirmAction = useCallback(() => {
171
+ setLoading(true);
172
+ http
173
+ .request({
174
+ url: Endpoints.RemoveMediasFromEventPhotoGallery.url({ id: scEvent.id }),
175
+ method: Endpoints.RemoveMediasFromEventPhotoGallery.method,
176
+ data: { medias: [mediaId] }
177
+ })
178
+ .then(() => {
179
+ setMedias((prev) => prev.filter((media) => media.id !== mediaId));
180
+ setMediasCount((prev) => prev - 1);
181
+ setMediaId(null);
182
+ setLoading(false);
183
+ setOpenDialogConfirm(false);
184
+ })
185
+ .catch((error) => {
186
+ Logger.error(SCOPE_SC_UI, error);
187
+ });
188
+ }, [scEvent, mediaId, setMedias, setLoading, setOpenDialogConfirm, dispatch, setMediasCount]);
189
+ const handleCloseAction = useCallback(() => {
190
+ setMediaId(null);
191
+ setOpenDialogConfirm(false);
192
+ }, [setMediaId, setOpenDialogConfirm]);
193
+ const handleAddMedia = useCallback((media) => {
194
+ setShowSkeleton('widget');
195
+ http
196
+ .request({
197
+ url: Endpoints.AddMediaToEventPhotoGallery.url({ id: scEvent.id }),
198
+ method: Endpoints.AddMediaToEventPhotoGallery.method,
199
+ data: { media: media.id }
200
+ })
201
+ .then((res) => {
202
+ setMedias((prev) => [res.data, ...prev]);
203
+ setMediasCount((prev) => prev + 1);
204
+ setShowSkeleton(null);
205
+ })
206
+ .catch((error) => {
207
+ Logger.error(SCOPE_SC_UI, error);
208
+ });
209
+ }, [scEvent, setMedias, setMediasCount, setShowSkeleton]);
210
+ // EFFECTS
211
+ useEffect(() => {
212
+ let _t;
213
+ if (scUserContext.user && scEvent) {
214
+ _t = setTimeout(_initComponent);
215
+ return () => {
216
+ clearTimeout(_t);
217
+ };
218
+ }
219
+ }, [scUserContext.user, scEvent]);
220
+ useEffect(() => {
221
+ if (isMobile && openDialog && state.next) {
222
+ handleNext();
223
+ }
224
+ }, [isMobile, openDialog, state.next]);
225
+ // RENDER
226
+ if (!scEvent || (state.initialized && mediasCount === 0 && !hasAllow)) {
227
+ return _jsx(HiddenPlaceholder, {});
228
+ }
229
+ if (!state.initialized || (state.isLoadingNext && mediasCount === 0)) {
230
+ return _jsx(SkeletonComponent, {});
231
+ }
232
+ return (_jsxs(Root, Object.assign({ className: classes.root }, rest, { showPadding: hasAllow }, { children: [_jsx(CardHeader, { title: _jsxs(Stack, Object.assign({ direction: "row", justifyContent: "space-between", alignItems: "center" }, { children: [_jsx(Typography, Object.assign({ variant: "h5" }, { children: _jsx(FormattedMessage, { id: "ui.eventMediaWidget.title", defaultMessage: "ui.eventMediaWidget.title" }) })), hasAllow && mediasCount > 0 && _jsx(TriggerButton, { size: "small", onAdd: handleAddMedia })] })), className: classes.header }), _jsx(Divider, {}), _jsxs(CardContent, Object.assign({ className: classes.content }, { children: [_jsxs(Box, Object.assign({ className: classes.grid }, { children: [showSkeleton === 'widget' && _jsx(EventMediaSkeleton, {}), medias.slice(0, MEDIAS_TO_SHOW).map((media, i, array) => (_jsx(Box, Object.assign({ onClick: () => handleOpenLightbox(i), sx: {
233
+ background: `url(${media.image}) no-repeat center`
234
+ }, className: classes.media }, { children: medias.length > array.length && i === array.length - 1 && (_jsxs(Fragment, { children: [_jsx(Box, { className: classes.mediaLayer }), _jsx(Box, Object.assign({ className: classes.countHiddenMediaWrapper }, { children: _jsxs(Typography, Object.assign({ className: classes.countHiddenMedia }, { children: ["+", countHiddenMedia] })) }))] })) }), media.id))), hasAllow && mediasCount === 0 && (_jsx(Tooltip, Object.assign({ title: _jsx(FormattedMessage, { id: "ui.eventMediaWidget.add", defaultMessage: "ui.eventMediaWidget.add" }) }, { children: _jsx(TriggerButton, { size: "large", onAdd: handleAddMedia, isSquare: true }) })))] })), preview !== -1 && _jsx(Lightbox, { onClose: handleCloseLightbox, index: preview, medias: medias, onIndexChange: _fetchNext })] })), hasAllow && mediasCount > 0 && (_jsx(CardActions, Object.assign({ className: classes.actions }, { children: _jsx(Button, Object.assign({ onClick: handleToggleDialogOpen }, { children: _jsx(Typography, Object.assign({ variant: "caption" }, { children: _jsx(FormattedMessage, { id: "ui.eventMediaWidget.showAll", defaultMessage: "ui.eventMediaWidget.showAll" }) })) })) }))), openDialog && (_jsx(DialogRoot, Object.assign({ className: classes.dialogRoot, title: intl.formatMessage(messages.title, { user: scEvent.managed_by.username }), onClose: handleToggleDialogOpen, open: openDialog }, dialogProps, { children: _jsx(InfiniteScroll, Object.assign({ dataLength: medias.length, height: isMobile ? '100%' : '515px', next: handleNext, hasMoreNext: Boolean(state.next), className: classes.dialogInfiniteScroll, endMessage: _jsx(Typography, Object.assign({ className: classes.endMessage }, { children: _jsx(FormattedMessage, { id: "ui.eventMediaWidget.noMoreResults", defaultMessage: "ui.eventMediaWidget.noMoreResults" }) })) }, { children: _jsxs(Box, Object.assign({ className: classes.grid }, { children: [medias.map((media) => (_jsx(Box, Object.assign({ sx: {
235
+ background: `url(${media.image}) no-repeat center`
236
+ }, className: classes.dialogMediaWrapper }, { children: _jsx(Stack, Object.assign({ className: classes.dialogButtonWrapper }, { children: _jsx(LoadingButton, Object.assign({ className: classes.dialogLoadingButton, loading: mediaId === media.id, size: "large", onClick: () => handleRemoveMedia(media.id), sx: {
237
+ color: (theme) => (mediaId === media.id ? 'transparent' : theme.palette.common.white)
238
+ } }, { children: _jsx(Icon, Object.assign({ fontSize: "inherit" }, { children: "delete" })) })) })) }), media.id))), showSkeleton === 'dialog' && Array.from(Array(countHiddenMedia)).map((_, i) => _jsx(EventMediaSkeleton, {}, i))] })) })) }))), openDialogConfirm && (_jsx(ConfirmDialog, { open: openDialogConfirm, title: _jsx(FormattedMessage, { id: "ui.eventMediaWidget.dialog.title", defaultMessage: "ui.eventMediaWidget.dialog.title" }), content: _jsx(FormattedMessage, { id: "ui.eventMediaWidget.dialog.msg", defaultMessage: "ui.eventMediaWidget.dialog.msg" }), btnConfirm: _jsx(FormattedMessage, { id: "ui.eventMediaWidget.dialog.confirm", defaultMessage: "ui.eventMediaWidget.dialog.confirm" }), isUpdating: loading, onConfirm: handleConfirmAction, onClose: handleCloseAction }))] })));
239
+ }
@@ -0,0 +1,2 @@
1
+ export default function EventMediaWidgetSkeleton(): JSX.Element;
2
+ export declare function EventMediaSkeleton(): JSX.Element;
@@ -0,0 +1,22 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Box, CardContent, CardHeader, Divider } from '@mui/material';
3
+ import Skeleton from '@mui/material/Skeleton';
4
+ import { styled } from '@mui/material/styles';
5
+ import Widget from '../Widget';
6
+ import { PREFIX } from './constants';
7
+ const classes = {
8
+ root: `${PREFIX}-skeleton-root`,
9
+ grid: `${PREFIX}-grid`,
10
+ media: `${PREFIX}-media`
11
+ };
12
+ const Root = styled(Widget, {
13
+ name: PREFIX,
14
+ slot: 'SkeletonRoot',
15
+ overridesResolver: (_props, styles) => styles.skeletonRoot
16
+ })(() => ({}));
17
+ export default function EventMediaWidgetSkeleton() {
18
+ return (_jsxs(Root, Object.assign({ className: classes.root }, { children: [_jsx(CardHeader, { title: _jsx(Skeleton, { animation: "wave", width: "50px", height: "23px" }) }), _jsx(Divider, {}), _jsx(CardContent, { children: _jsx(Box, Object.assign({ className: classes.grid }, { children: Array.from(Array(9)).map((_, i) => (_jsx(EventMediaSkeleton, {}, i))) })) })] })));
19
+ }
20
+ export function EventMediaSkeleton() {
21
+ return _jsx(Skeleton, { variant: "rectangular", animation: "wave", width: "100%", className: classes.media });
22
+ }