Skip to content

Commit

Permalink
perf: fix rendering & type issues
Browse files Browse the repository at this point in the history
  • Loading branch information
alex-golovanov committed Dec 24, 2024
1 parent 00007ae commit 221119c
Showing 1 changed file with 124 additions and 101 deletions.
225 changes: 124 additions & 101 deletions app/client/src/pages/Editor/JSEditor/AppJSEditorContextMenu.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import React, { useCallback, useState } from "react";
import React, { useCallback, useMemo } from "react";
import { useBoolean } from "usehooks-ts";
import { useDispatch, useSelector } from "react-redux";
import {
moveJSCollectionRequest,
Expand Down Expand Up @@ -34,6 +35,7 @@ import { useFeatureFlag } from "utils/hooks/useFeatureFlag";
import { FEATURE_FLAG } from "ee/entities/FeatureFlag";
import type { JSCollection } from "entities/JSCollection";
import { setRenameEntity } from "actions/ideActions";
import type CodeMirror from "codemirror";

interface AppJSEditorContextMenuProps {
pageId: string;
Expand All @@ -46,7 +48,11 @@ export function AppJSEditorContextMenu({
jsCollection,
pageId,
}: AppJSEditorContextMenuProps) {
const [confirmDelete, setConfirmDelete] = useState(false);
const {
setFalse: cancelConfirmDelete,
setValue: setConfirmDelete,
value: confirmDelete,
} = useBoolean(false);
const dispatch = useDispatch();
const isFeatureEnabled = useFeatureFlag(FEATURE_FLAG.license_gac_enabled);
const isDeletePermitted = getHasDeleteActionPermission(
Expand Down Expand Up @@ -95,113 +101,130 @@ export function AppJSEditorContextMenu({
dispatch(deleteJSCollection({ id: actionId, name: actionName }));
setConfirmDelete(false);
},
[dispatch],
[dispatch, setConfirmDelete],
);

const confirmDeletion = (value: boolean, event?: Event) => {
event?.preventDefault?.();
setConfirmDelete(value);
};

const menuPages = useSelector(getPageListAsOptions, equal);

const renameOption = {
icon: "input-cursor-move" as IconName,
value: "rename",
onSelect: renameJS,
label: createMessage(CONTEXT_RENAME),
disabled: !isChangePermitted,
};

const copyOption = {
icon: "duplicate" as IconName,
value: "copy",
onSelect: noop,
label: createMessage(CONTEXT_COPY),
children: menuPages.map((page) => {
return {
...page,
onSelect: () =>
copyJSCollectionToPage(jsCollection.id, jsCollection.name, page.id),
};
}),
};

const moveOption = {
icon: "swap-horizontal" as IconName,
value: "move",
onSelect: noop,
label: createMessage(CONTEXT_MOVE),
children:
menuPages.length > 1
? menuPages
.filter((page) => page.id !== pageId) // Remove current page from the list
.map((page) => {
return {
...page,
onSelect: () =>
moveJSCollectionToPage(
jsCollection.id,
jsCollection.name,
page.id,
),
};
})
: [{ value: "No Pages", onSelect: noop, label: "No Pages" }],
};

const prettifyOptions = {
value: "prettify",
icon: "code" as IconName,
subText: prettifyCodeKeyboardShortCut,
onSelect: () => {
/*
PS: Please do not remove ts-ignore from here, TS keeps suggesting that
the object is null, but that is not the case, and we need an
instance of the editor to pass to autoIndentCode function
*/
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
// @ts-ignore
const editor = document.querySelector(".CodeMirror").CodeMirror;

autoIndentCode(editor);
dispatch(updateJSCollectionBody(editor.getValue(), jsCollection.id));
AnalyticsUtil.logEvent("PRETTIFY_CODE_MANUAL_TRIGGER");
},
label: "Prettify code",
};

const deleteOption = {
confirmDelete: confirmDelete,
icon: "delete-bin-line" as IconName,
value: "delete",
onSelect: (event?: Event): void => {
confirmDelete
? deleteJSCollectionFromPage(jsCollection.id, jsCollection.name)
: confirmDeletion(true, event);
},
label: confirmDelete
? createMessage(CONFIRM_CONTEXT_DELETE)
: createMessage(CONTEXT_DELETE),
className: "t--apiFormDeleteBtn error-menuitem",
};

const options: ContextMenuOption[] = [renameOption];

if (isChangePermitted) {
options.push(copyOption);
options.push(moveOption);
options.push(prettifyOptions);
}

if (isDeletePermitted) options.push(deleteOption);
const options = useMemo(() => {
const confirmDeletion = (value: boolean, event?: Event) => {
event?.preventDefault?.();
setConfirmDelete(value);
};

const renameOption = {
icon: "input-cursor-move" as IconName,
value: "rename",
onSelect: renameJS,
label: createMessage(CONTEXT_RENAME),
disabled: !isChangePermitted,
};

const copyOption = {
icon: "duplicate" as IconName,
value: "copy",
onSelect: noop,
label: createMessage(CONTEXT_COPY),
children: menuPages.map((page) => {
return {
...page,
onSelect: () =>
copyJSCollectionToPage(jsCollection.id, jsCollection.name, page.id),
};
}),
};

const moveOption = {
icon: "swap-horizontal" as IconName,
value: "move",
onSelect: noop,
label: createMessage(CONTEXT_MOVE),
children:
menuPages.length > 1
? menuPages
.filter((page) => page.id !== pageId) // Remove current page from the list
.map((page) => {
return {
...page,
onSelect: () =>
moveJSCollectionToPage(
jsCollection.id,
jsCollection.name,
page.id,
),
};
})
: [{ value: "No Pages", onSelect: noop, label: "No Pages" }],
};

const prettifyOptions = {
value: "prettify",
icon: "code" as IconName,
subText: prettifyCodeKeyboardShortCut,
onSelect: () => {
const editorElement = document.querySelector(".CodeMirror");

if (
editorElement &&
"CodeMirror" in editorElement &&
editorElement.CodeMirror
) {
const editor = editorElement.CodeMirror as CodeMirror.Editor;

autoIndentCode(editor);
dispatch(updateJSCollectionBody(editor.getValue(), jsCollection.id));
AnalyticsUtil.logEvent("PRETTIFY_CODE_MANUAL_TRIGGER");
}
},
label: "Prettify code",
};

const deleteOption = {
confirmDelete: confirmDelete,
icon: "delete-bin-line" as IconName,
value: "delete",
onSelect: (event?: Event): void => {
confirmDelete
? deleteJSCollectionFromPage(jsCollection.id, jsCollection.name)
: confirmDeletion(true, event);
},
label: confirmDelete
? createMessage(CONFIRM_CONTEXT_DELETE)
: createMessage(CONTEXT_DELETE),
className: "t--apiFormDeleteBtn error-menuitem",
};

const options: ContextMenuOption[] = [renameOption];

if (isChangePermitted) {
options.push(copyOption);
options.push(moveOption);
options.push(prettifyOptions);
}

if (isDeletePermitted) options.push(deleteOption);

return options;
}, [
confirmDelete,
copyJSCollectionToPage,
deleteJSCollectionFromPage,
dispatch,
isChangePermitted,
isDeletePermitted,
jsCollection.id,
jsCollection.name,
menuPages,
moveJSCollectionToPage,
pageId,
renameJS,
setConfirmDelete,
]);

return (
<JSEditorContextMenu
className="t--more-action-menu"
onMenuClose={() => {
setConfirmDelete(false);
}}
onMenuClose={cancelConfirmDelete}
options={options}
/>
);
Expand Down

0 comments on commit 221119c

Please sign in to comment.