@edifice.io/react 2.3.2-develop-b2school.20251001121346 → 2.3.2-develop-integration.20251006100158

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.
@@ -16,6 +16,8 @@ export * from './useHover';
16
16
  export * from './useHttpErrorToast';
17
17
  export * from './useImage';
18
18
  export * from './useIsAdml';
19
+ export * from './useIsAdmc';
20
+ export * from './useIsAdmlcOrAdmc';
19
21
  export * from './useKeyPress';
20
22
  export * from './useLibraryUrl';
21
23
  export * from './useMediaLibrary';
@@ -0,0 +1 @@
1
+ export { default as useIsAdmc } from './useIsAdmc';
@@ -0,0 +1,3 @@
1
+ export default function useIsAdmc(): {
2
+ isAdmc: boolean;
3
+ };
@@ -0,0 +1,22 @@
1
+ import { useState, useEffect, useCallback } from "react";
2
+ import { odeServices } from "@edifice.io/client";
3
+ function useIsAdmc() {
4
+ const [isAdmc, setIsAdmc] = useState(!1);
5
+ useEffect(() => {
6
+ initIsAdmc();
7
+ }, []);
8
+ const initIsAdmc = useCallback(async () => {
9
+ try {
10
+ const user = await odeServices.session().getUser(), hasSuperAdmin = !!(user != null && user.functions && user.functions.SUPER_ADMIN);
11
+ setIsAdmc(!!hasSuperAdmin);
12
+ } catch {
13
+ setIsAdmc(!1);
14
+ }
15
+ }, []);
16
+ return {
17
+ isAdmc
18
+ };
19
+ }
20
+ export {
21
+ useIsAdmc as default
22
+ };
@@ -0,0 +1 @@
1
+ export { default as useIsAdmlcOrAdmc } from './useIsAdmlcOrAdmc';
@@ -0,0 +1,3 @@
1
+ export default function useIsAdmlcOrAdmc(): {
2
+ isAdmlcOrAdmc: boolean;
3
+ };
@@ -0,0 +1,16 @@
1
+ import { useMemo } from "react";
2
+ import useIsAdml from "../useIsAdml/useIsAdml.js";
3
+ import useIsAdmc from "../useIsAdmc/useIsAdmc.js";
4
+ function useIsAdmlcOrAdmc() {
5
+ const {
6
+ isAdml
7
+ } = useIsAdml(), {
8
+ isAdmc
9
+ } = useIsAdmc();
10
+ return {
11
+ isAdmlcOrAdmc: useMemo(() => !!(isAdml || isAdmc), [isAdml, isAdmc])
12
+ };
13
+ }
14
+ export {
15
+ useIsAdmlcOrAdmc as default
16
+ };
package/dist/index.js CHANGED
@@ -63,42 +63,44 @@ import { default as default62 } from "./hooks/useHover/useHover.js";
63
63
  import { default as default63 } from "./hooks/useHttpErrorToast/useHttpErrorToast.js";
64
64
  import { default as default64 } from "./hooks/useImage/useImage.js";
65
65
  import { default as default65 } from "./hooks/useIsAdml/useIsAdml.js";
66
- import { default as default66 } from "./hooks/useKeyPress/useKeyPress.js";
67
- import { default as default67 } from "./hooks/useLibraryUrl/useLibraryUrl.js";
68
- import { default as default68 } from "./hooks/useMediaLibrary/useMediaLibrary.js";
69
- import { default as default69 } from "./hooks/useScrollToTop/useScrollToTop.js";
70
- import { default as default70 } from "./hooks/useTitle/useTitle.js";
71
- import { default as default71 } from "./hooks/useToast/useToast.js";
72
- import { default as default72 } from "./hooks/useToggle/useToggle.js";
73
- import { default as default73 } from "./hooks/useTrapFocus/useTrapFocus.js";
74
- import { default as default74 } from "./hooks/useTrashedResource/useTrashedResource.js";
75
- import { default as default75 } from "./hooks/useUpload/useUpload.js";
76
- import { default as default76 } from "./hooks/useUploadFiles/useUploadFiles.js";
77
- import { default as default77 } from "./hooks/useUser/useUser.js";
78
- import { default as default78 } from "./hooks/useWorkspaceFile/useWorkspaceFile.js";
79
- import { default as default79 } from "./hooks/useWorkspaceFolders/useWorkspaceFolders.js";
80
- import { WORKSPACE_SHARED_FOLDER_ID, WORKSPACE_USER_FOLDER_ID, default as default80 } from "./hooks/useWorkspaceFolders/useWorkspaceFoldersTree.js";
81
- import { default as default81 } from "./hooks/useWorkspaceSearch/useWorkspaceSearch.js";
82
- import { default as default82 } from "./hooks/useXitiTrackPageLoad/useXitiTrackPageLoad.js";
83
- import { default as default83 } from "./hooks/useZendeskGuide/useZendeskGuide.js";
84
- import { default as default84 } from "./modules/modals/ConfirmModal/ConfirmModal.js";
85
- import { default as default85 } from "./modules/modals/OnboardingModal/OnboardingModal.js";
86
- import { default as default86 } from "./modules/modals/PublishModal/PublishModal.js";
87
- import { default as default87 } from "./modules/modals/ResourceModal/apps/BlogPublic.js";
88
- import { default as default88 } from "./modules/modals/ResourceModal/hooks/useUpdateMutation.js";
89
- import { default as default89 } from "./modules/modals/ShareModal/ShareModal.js";
90
- import { default as default90 } from "./modules/modals/ShareModal/apps/ShareBlog.js";
91
- import { default as default91 } from "./modules/modals/ShareModal/hooks/useShareMutation.js";
92
- import { default as default92 } from "./modules/multimedia/AudioRecorder/AudioRecorder.js";
93
- import { default as default93 } from "./modules/multimedia/Embed/Embed.js";
94
- import { default as default94 } from "./modules/multimedia/ImageEditor/components/ImageEditor.js";
95
- import { default as default95 } from "./modules/multimedia/ImagePicker/ImagePicker.js";
96
- import { default as default96 } from "./modules/multimedia/FileCard/FileCard.js";
97
- import { default as default97 } from "./modules/multimedia/MediaLibrary/MediaLibrary.js";
98
- import { default as default98 } from "./modules/multimedia/VideoEmbed/VideoEmbed.js";
99
- import { default as default99 } from "./modules/multimedia/VideoRecorder/VideoRecorder.js";
100
- import { default as default100 } from "./modules/multimedia/Workspace/Workspace.js";
101
- import { default as default101 } from "./modules/multimedia/WorkspaceFolders/WorkspaceFolders.js";
66
+ import { default as default66 } from "./hooks/useIsAdmc/useIsAdmc.js";
67
+ import { default as default67 } from "./hooks/useIsAdmlcOrAdmc/useIsAdmlcOrAdmc.js";
68
+ import { default as default68 } from "./hooks/useKeyPress/useKeyPress.js";
69
+ import { default as default69 } from "./hooks/useLibraryUrl/useLibraryUrl.js";
70
+ import { default as default70 } from "./hooks/useMediaLibrary/useMediaLibrary.js";
71
+ import { default as default71 } from "./hooks/useScrollToTop/useScrollToTop.js";
72
+ import { default as default72 } from "./hooks/useTitle/useTitle.js";
73
+ import { default as default73 } from "./hooks/useToast/useToast.js";
74
+ import { default as default74 } from "./hooks/useToggle/useToggle.js";
75
+ import { default as default75 } from "./hooks/useTrapFocus/useTrapFocus.js";
76
+ import { default as default76 } from "./hooks/useTrashedResource/useTrashedResource.js";
77
+ import { default as default77 } from "./hooks/useUpload/useUpload.js";
78
+ import { default as default78 } from "./hooks/useUploadFiles/useUploadFiles.js";
79
+ import { default as default79 } from "./hooks/useUser/useUser.js";
80
+ import { default as default80 } from "./hooks/useWorkspaceFile/useWorkspaceFile.js";
81
+ import { default as default81 } from "./hooks/useWorkspaceFolders/useWorkspaceFolders.js";
82
+ import { WORKSPACE_SHARED_FOLDER_ID, WORKSPACE_USER_FOLDER_ID, default as default82 } from "./hooks/useWorkspaceFolders/useWorkspaceFoldersTree.js";
83
+ import { default as default83 } from "./hooks/useWorkspaceSearch/useWorkspaceSearch.js";
84
+ import { default as default84 } from "./hooks/useXitiTrackPageLoad/useXitiTrackPageLoad.js";
85
+ import { default as default85 } from "./hooks/useZendeskGuide/useZendeskGuide.js";
86
+ import { default as default86 } from "./modules/modals/ConfirmModal/ConfirmModal.js";
87
+ import { default as default87 } from "./modules/modals/OnboardingModal/OnboardingModal.js";
88
+ import { default as default88 } from "./modules/modals/PublishModal/PublishModal.js";
89
+ import { default as default89 } from "./modules/modals/ResourceModal/apps/BlogPublic.js";
90
+ import { default as default90 } from "./modules/modals/ResourceModal/hooks/useUpdateMutation.js";
91
+ import { default as default91 } from "./modules/modals/ShareModal/ShareModal.js";
92
+ import { default as default92 } from "./modules/modals/ShareModal/apps/ShareBlog.js";
93
+ import { default as default93 } from "./modules/modals/ShareModal/hooks/useShareMutation.js";
94
+ import { default as default94 } from "./modules/multimedia/AudioRecorder/AudioRecorder.js";
95
+ import { default as default95 } from "./modules/multimedia/Embed/Embed.js";
96
+ import { default as default96 } from "./modules/multimedia/ImageEditor/components/ImageEditor.js";
97
+ import { default as default97 } from "./modules/multimedia/ImagePicker/ImagePicker.js";
98
+ import { default as default98 } from "./modules/multimedia/FileCard/FileCard.js";
99
+ import { default as default99 } from "./modules/multimedia/MediaLibrary/MediaLibrary.js";
100
+ import { default as default100 } from "./modules/multimedia/VideoEmbed/VideoEmbed.js";
101
+ import { default as default101 } from "./modules/multimedia/VideoRecorder/VideoRecorder.js";
102
+ import { default as default102 } from "./modules/multimedia/Workspace/Workspace.js";
103
+ import { default as default103 } from "./modules/multimedia/WorkspaceFolders/WorkspaceFolders.js";
102
104
  import { AccessiblePalette, DefaultPalette } from "./components/ColorPicker/ColorPalette.js";
103
105
  import { DropzoneContext, useDropzoneContext } from "./components/Dropzone/DropzoneContext.js";
104
106
  import { Column, Grid } from "./components/Grid/Grid.js";
@@ -134,11 +136,11 @@ export {
134
136
  default4 as AppHeader,
135
137
  default5 as AppIcon,
136
138
  default6 as Attachment,
137
- default92 as AudioRecorder,
139
+ default94 as AudioRecorder,
138
140
  default7 as Avatar,
139
141
  default8 as AvatarGroup,
140
142
  default9 as Badge,
141
- default87 as BlogPublic,
143
+ default89 as BlogPublic,
142
144
  default10 as Breadcrumb,
143
145
  default11 as Button,
144
146
  default37 as ButtonSkeleton,
@@ -148,7 +150,7 @@ export {
148
150
  default17 as ColorPickerItem,
149
151
  Column,
150
152
  default18 as Combobox,
151
- default84 as ConfirmModal,
153
+ default86 as ConfirmModal,
152
154
  DefaultPalette,
153
155
  DndTree,
154
156
  default19 as Dropdown,
@@ -158,10 +160,10 @@ export {
158
160
  EdificeClientProvider,
159
161
  EdificeThemeContext,
160
162
  EdificeThemeProvider,
161
- default93 as Embed,
163
+ default95 as Embed,
162
164
  default21 as EmptyScreen,
163
165
  ExternalLinker,
164
- default96 as FileCard,
166
+ default98 as FileCard,
165
167
  default22 as Flex,
166
168
  default24 as FormControl,
167
169
  default23 as FormText,
@@ -169,8 +171,8 @@ export {
169
171
  default25 as Heading,
170
172
  default12 as IconButton,
171
173
  default26 as Image,
172
- default94 as ImageEditor,
173
- default95 as ImagePicker,
174
+ default96 as ImageEditor,
175
+ default97 as ImagePicker,
174
176
  default27 as Input,
175
177
  InternalLinker,
176
178
  default28 as Label,
@@ -179,24 +181,24 @@ export {
179
181
  default29 as Loading,
180
182
  default30 as LoadingScreen,
181
183
  default31 as Logo,
182
- default97 as MediaLibrary,
184
+ default99 as MediaLibrary,
183
185
  Menu,
184
186
  MockedProvider,
185
187
  default32 as Modal,
186
- default85 as OnboardingModal,
188
+ default87 as OnboardingModal,
187
189
  Popover,
188
190
  PopoverBody,
189
191
  PopoverFooter,
190
192
  PopoverHeader,
191
193
  default33 as PreventPropagation,
192
- default86 as PublishModal,
194
+ default88 as PublishModal,
193
195
  default34 as Radio,
194
196
  ResourceModal,
195
197
  default35 as SearchBar,
196
198
  default13 as SearchButton,
197
199
  default36 as Select,
198
- default90 as ShareBlog,
199
- default89 as ShareModal,
200
+ default92 as ShareBlog,
201
+ default91 as ShareModal,
200
202
  default45 as SortableTree,
201
203
  default39 as StackedGroup,
202
204
  default40 as Stepper,
@@ -211,13 +213,13 @@ export {
211
213
  TreeNode,
212
214
  TreeNodeFolderWrapper,
213
215
  default47 as TreeView,
214
- default98 as VideoEmbed,
215
- default99 as VideoRecorder,
216
+ default100 as VideoEmbed,
217
+ default101 as VideoRecorder,
216
218
  default48 as VisuallyHidden,
217
219
  WORKSPACE_SHARED_FOLDER_ID,
218
220
  WORKSPACE_USER_FOLDER_ID,
219
- default100 as Workspace,
220
- default101 as WorkspaceFolders,
221
+ default102 as Workspace,
222
+ default103 as WorkspaceFolders,
221
223
  addNode,
222
224
  arrayUnique,
223
225
  buildTree,
@@ -265,28 +267,30 @@ export {
265
267
  default62 as useHover,
266
268
  default63 as useHttpErrorToast,
267
269
  default64 as useImage,
270
+ default66 as useIsAdmc,
268
271
  default65 as useIsAdml,
269
- default66 as useKeyPress,
270
- default67 as useLibraryUrl,
271
- default68 as useMediaLibrary,
272
- default69 as useScrollToTop,
273
- default91 as useShareMutation,
274
- default70 as useTitle,
275
- default71 as useToast,
276
- default72 as useToggle,
277
- default73 as useTrapFocus,
278
- default74 as useTrashedResource,
272
+ default67 as useIsAdmlcOrAdmc,
273
+ default68 as useKeyPress,
274
+ default69 as useLibraryUrl,
275
+ default70 as useMediaLibrary,
276
+ default71 as useScrollToTop,
277
+ default93 as useShareMutation,
278
+ default72 as useTitle,
279
+ default73 as useToast,
280
+ default74 as useToggle,
281
+ default75 as useTrapFocus,
282
+ default76 as useTrashedResource,
279
283
  useTreeSortable,
280
284
  useTreeView,
281
- default88 as useUpdateMutation,
282
- default75 as useUpload,
283
- default76 as useUploadFiles,
284
- default77 as useUser,
285
- default78 as useWorkspaceFile,
286
- default79 as useWorkspaceFolders,
287
- default80 as useWorkspaceFoldersTree,
288
- default81 as useWorkspaceSearch,
289
- default82 as useXitiTrackPageLoad,
290
- default83 as useZendeskGuide,
285
+ default90 as useUpdateMutation,
286
+ default77 as useUpload,
287
+ default78 as useUploadFiles,
288
+ default79 as useUser,
289
+ default80 as useWorkspaceFile,
290
+ default81 as useWorkspaceFolders,
291
+ default82 as useWorkspaceFoldersTree,
292
+ default83 as useWorkspaceSearch,
293
+ default84 as useXitiTrackPageLoad,
294
+ default85 as useZendeskGuide,
291
295
  wrapTreeNode
292
296
  };
@@ -71,7 +71,7 @@ const DeleteModal = /* @__PURE__ */ lazy(() => import("./DeleteModal.js")), Comm
71
71
  ] }) : /* @__PURE__ */ jsxs(Fragment, { children: [
72
72
  /* @__PURE__ */ jsx("div", { className: "mt-8 mb-4", children: content }),
73
73
  type === "edit" && /* @__PURE__ */ jsxs("div", { className: "ms-n8", children: [
74
- !replyTo && /* @__PURE__ */ jsx(Button, { variant: "ghost", color: "tertiary", size: "sm", onClick: () => handleReplyToComment(comment.id), children: t("comment.reply") }),
74
+ !replyTo && options.allowReplies && /* @__PURE__ */ jsx(Button, { variant: "ghost", color: "tertiary", size: "sm", onClick: () => handleReplyToComment(comment.id), children: t("comment.reply") }),
75
75
  userId === authorId && /* @__PURE__ */ jsx(Button, { variant: "ghost", color: "tertiary", size: "sm", onClick: () => {
76
76
  handleModifyComment(comment.id), setValue(content);
77
77
  }, children: t("comment.edit") }),
@@ -20,6 +20,7 @@ const CommentProvider = ({
20
20
  additionalComments: DEFAULT_ADD_COMMENTS,
21
21
  maxReplies: DEFAULT_MAX_REPLIES,
22
22
  additionalReplies: DEFAULT_ADD_REPLIES,
23
+ allowReplies: !0,
23
24
  ...commentOptions
24
25
  }, {
25
26
  type
@@ -104,6 +104,10 @@ export type CommentOptions = {
104
104
  * Number of replies to load additionally in the limited list
105
105
  */
106
106
  additionalReplies: number;
107
+ /**
108
+ * Allow replying to comments
109
+ */
110
+ allowReplies: boolean;
107
111
  };
108
112
  export interface UserProfileResult {
109
113
  /**
@@ -6,6 +6,7 @@ export interface FormInputs {
6
6
  description: string;
7
7
  enablePublic: boolean;
8
8
  formSlug: string;
9
+ allowReplies: boolean;
9
10
  }
10
11
  /**
11
12
  * Custom translations interface for overriding default translations
@@ -1,8 +1,8 @@
1
1
  import { jsx, jsxs, Fragment } from "react/jsx-runtime";
2
- import { useId } from "react";
2
+ import { useId, useEffect } from "react";
3
3
  import { odeServices } from "@edifice.io/client";
4
4
  import { createPortal } from "react-dom";
5
- import { useForm } from "react-hook-form";
5
+ import { useForm, Controller } from "react-hook-form";
6
6
  import { useTranslation } from "react-i18next";
7
7
  import { TextareaCounter } from "../../../components/TextArea/TextareaCounter.js";
8
8
  import ImagePicker from "../../multimedia/ImagePicker/ImagePicker.js";
@@ -18,6 +18,7 @@ import FormControl from "../../../components/Form/FormControl.js";
18
18
  import Label from "../../../components/Label/Label.js";
19
19
  import Input from "../../../components/Input/Input.js";
20
20
  import TextArea from "../../../components/TextArea/TextArea.js";
21
+ import Checkbox from "../../../components/Checkbox/Checkbox.js";
21
22
  import Button from "../../../components/Button/Button.js";
22
23
  import MediaLibrary from "../../multimedia/MediaLibrary/MediaLibrary.js";
23
24
  const DEFAULT_INPUT_MAX_LENGTH = 60, DEFAULT_TEXTAREA_MAX_LENGTH = 400, ResourceModal = ({
@@ -44,6 +45,7 @@ const DEFAULT_INPUT_MAX_LENGTH = 60, DEFAULT_TEXTAREA_MAX_LENGTH = 400, Resource
44
45
  register,
45
46
  handleSubmit,
46
47
  setValue,
48
+ control,
47
49
  formState: {
48
50
  isSubmitting,
49
51
  isValid
@@ -54,9 +56,14 @@ const DEFAULT_INPUT_MAX_LENGTH = 60, DEFAULT_TEXTAREA_MAX_LENGTH = 400, Resource
54
56
  description: isUpdating ? resource == null ? void 0 : resource.description : "",
55
57
  enablePublic: isUpdating ? resource == null ? void 0 : resource.public : !1,
56
58
  title: isUpdating ? resource == null ? void 0 : resource.name : "",
57
- formSlug: isUpdating ? resource == null ? void 0 : resource.slug : ""
59
+ formSlug: isUpdating ? resource == null ? void 0 : resource.slug : "",
60
+ allowReplies: isUpdating ? (resource == null ? void 0 : resource.allowReplies) ?? !0 : !0
58
61
  }
59
- }), {
62
+ });
63
+ useEffect(() => {
64
+ console.log(resource);
65
+ }, [resource]);
66
+ const {
60
67
  ref: mediaLibraryRef,
61
68
  libraryMedia,
62
69
  ...mediaLibraryHandlers
@@ -75,7 +82,8 @@ const DEFAULT_INPUT_MAX_LENGTH = 60, DEFAULT_TEXTAREA_MAX_LENGTH = 400, Resource
75
82
  name: formData.title,
76
83
  public: formData.enablePublic,
77
84
  slug: formData.enablePublic && formData.formSlug || "",
78
- thumbnail
85
+ thumbnail,
86
+ allowReplies: formData.allowReplies
79
87
  };
80
88
  let result, param;
81
89
  if (isCreating) {
@@ -141,7 +149,10 @@ const DEFAULT_INPUT_MAX_LENGTH = 60, DEFAULT_TEXTAREA_MAX_LENGTH = 400, Resource
141
149
  maxLength: textareaMaxLength
142
150
  }), placeholder: ((_f = customT.placeholder) == null ? void 0 : _f.description) ?? t("explorer.resource.editModal.description.placeholder"), size: "md", maxLength: textareaMaxLength }),
143
151
  watchedDescription && /* @__PURE__ */ jsx(TextareaCounter, { content: watchedDescription, maxLength: textareaMaxLength })
144
- ] })
152
+ ] }),
153
+ application === "blog" && /* @__PURE__ */ jsx(FormControl, { id: "allowReplies", className: "mt-16", children: /* @__PURE__ */ jsx(Controller, { name: "allowReplies", control, render: ({
154
+ field
155
+ }) => /* @__PURE__ */ jsx(Checkbox, { label: "Autoriser les réponses aux commentaires", checked: field.value, onChange: field.onChange }) }) })
145
156
  ] })
146
157
  ] }),
147
158
  typeof children == "function" ? children(resource, isUpdating, watch, setValue, register) : children
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@edifice.io/react",
3
- "version": "2.3.2-develop-b2school.20251001121346",
3
+ "version": "2.3.2-develop-integration.20251006100158",
4
4
  "description": "Edifice React Library",
5
5
  "keywords": [
6
6
  "react",
@@ -131,9 +131,9 @@
131
131
  "react-slugify": "^3.0.3",
132
132
  "swiper": "^10.1.0",
133
133
  "ua-parser-js": "^1.0.36",
134
- "@edifice.io/tiptap-extensions": "2.3.2-develop-b2school.20251001121346",
135
- "@edifice.io/utilities": "2.3.2-develop-b2school.20251001121346",
136
- "@edifice.io/bootstrap": "2.3.2-develop-b2school.20251001121346"
134
+ "@edifice.io/bootstrap": "2.3.2-develop-integration.20251006100158",
135
+ "@edifice.io/tiptap-extensions": "2.3.2-develop-integration.20251006100158",
136
+ "@edifice.io/utilities": "2.3.2-develop-integration.20251006100158"
137
137
  },
138
138
  "devDependencies": {
139
139
  "@babel/plugin-transform-react-pure-annotations": "^7.23.3",
@@ -164,8 +164,8 @@
164
164
  "vite": "^5.4.11",
165
165
  "vite-plugin-dts": "^4.1.0",
166
166
  "vite-tsconfig-paths": "^5.0.1",
167
- "@edifice.io/client": "2.3.2-develop-b2school.20251001121346",
168
- "@edifice.io/config": "2.3.2-develop-b2school.20251001121346"
167
+ "@edifice.io/client": "2.3.2-develop-integration.20251006100158",
168
+ "@edifice.io/config": "2.3.2-develop-integration.20251006100158"
169
169
  },
170
170
  "peerDependencies": {
171
171
  "@react-spring/web": "^9.7.5",