Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

refactor: update keyboard shortcuts display #3316

Merged
merged 44 commits into from
Aug 14, 2024
Merged
Show file tree
Hide file tree
Changes from 34 commits
Commits
Show all changes
44 commits
Select commit Hold shift + click to select a range
56a5b13
remove repeated code
anovazzi1 Aug 7, 2024
bce2e6a
refactor: remove useless code
anovazzi1 Aug 7, 2024
19abddb
feat: sort input parameters in GenericNode renderInputParameter
anovazzi1 Aug 7, 2024
a7bd5f9
refactor: remove unused code in GenericNode component
anovazzi1 Aug 8, 2024
ae9c37f
refactor: add NodeName component for displaying and editing node names
anovazzi1 Aug 8, 2024
4b27c6b
refactor: add NodeDescription component for displaying and editing no…
anovazzi1 Aug 8, 2024
f6c1041
fix import and add autofocus on nodeName
anovazzi1 Aug 8, 2024
55247d0
feat: add NodeStatus component for displaying and managing node status
anovazzi1 Aug 8, 2024
9bbeaa4
[autofix.ci] apply automated fixes
autofix-ci[bot] Aug 8, 2024
693fe70
refactor: remove unused code in GenericNode component
anovazzi1 Aug 8, 2024
8a067a9
fix bugs on minimize
anovazzi1 Aug 8, 2024
52689fa
[autofix.ci] apply automated fixes
autofix-ci[bot] Aug 8, 2024
a33f8fc
Merge remote-tracking branch 'origin/main' into refactorNode
anovazzi1 Aug 13, 2024
bc3448b
refactor: remove unused code and handle count in GenericNodeToolbar c…
anovazzi1 Aug 8, 2024
4aaef1f
refactor: Add useShortcuts hook for handling keyboard shortcuts in no…
anovazzi1 Aug 8, 2024
e288013
refactor: Add keyboard shortcuts handling to nodeToolbarComponent nee…
anovazzi1 Aug 8, 2024
c887f09
refactor: Update FreezeAllVertices function in NodeToolbarComponent
anovazzi1 Aug 13, 2024
4eb6137
feat: Add getNodeLength function to calculate the length of a node's …
anovazzi1 Aug 13, 2024
946d391
refactor: Update RenderIcons component to use navigator.platform for …
anovazzi1 Aug 13, 2024
f3bfe0d
refactor: Add ShortcutDisplay component to nodeToolbarComponent
anovazzi1 Aug 13, 2024
bed43ae
refactor: Update nodeToolbarComponent to remove RenderIcons and add S…
anovazzi1 Aug 13, 2024
a4d7756
refactor: Improve keyboard shortcuts handling in nodeToolbarComponent
anovazzi1 Aug 13, 2024
1d4aa71
Merge remote-tracking branch 'origin/main' into refactorNodeToolbar
anovazzi1 Aug 13, 2024
84563b0
[autofix.ci] apply automated fixes
autofix-ci[bot] Aug 13, 2024
4949dd6
Merge branch 'main' into refactorNodeToolbar
anovazzi1 Aug 13, 2024
d15b08f
refactor: Add OptionIcon to nodeIconsLucide
anovazzi1 Aug 13, 2024
5776fd5
feat: Add SHORTCUT_KEYS constant
anovazzi1 Aug 13, 2024
43d480b
feat: Add SHORTCUT_KEYS constant
anovazzi1 Aug 13, 2024
dab8a74
refactor: Add RenderKey component for rendering keyboard shortcuts
anovazzi1 Aug 13, 2024
56efc15
refactor: Update RenderIcons component to use RenderKey for rendering…
anovazzi1 Aug 13, 2024
eb5ba1c
update shortcut page to use shortcut icons
anovazzi1 Aug 13, 2024
00b90f9
[autofix.ci] apply automated fixes
autofix-ci[bot] Aug 13, 2024
fef6bb9
Update Astra link in README.md (#3314)
alexleventer Aug 13, 2024
292cd82
Merge branch 'main' into fixShortcutRender
anovazzi1 Aug 14, 2024
4af2631
refactor: Simplify NodeToolbarComponent's save flow logic
anovazzi1 Aug 14, 2024
24612ec
[autofix.ci] apply automated fixes
autofix-ci[bot] Aug 14, 2024
e40ac91
feat: Google Drive Search Component (#3319)
edwinjosechittilappilly Aug 14, 2024
0815ad7
feat: Add support for metadata filtering and namespaces for the Upsta…
ytkimirti Aug 14, 2024
a977890
ci: Update pytest configuration and add pytest-flakefinder. (#3330)
ogabrielluiz Aug 14, 2024
221296a
chore: Refactor NodeToolbarComponent to simplify code structure
anovazzi1 Aug 14, 2024
d253342
[autofix.ci] apply automated fixes
autofix-ci[bot] Aug 14, 2024
ba17168
refactor: Simplify NodeToolbarComponent's save flow logic
anovazzi1 Aug 14, 2024
a4fae9a
[autofix.ci] apply automated fixes
autofix-ci[bot] Aug 14, 2024
7abf5e3
chore: Fix formatting issue in get-curl-code.tsx
anovazzi1 Aug 14, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
12 changes: 0 additions & 12 deletions src/frontend/src/CustomNodes/GenericNode/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,6 @@ export default function GenericNode({
const takeSnapshot = useFlowsManagerStore((state) => state.takeSnapshot);
const [isOutdated, setIsOutdated] = useState(false);
const [isUserEdited, setIsUserEdited] = useState(false);
const [handles, setHandles] = useState<number>(0);
const [borderColor, setBorderColor] = useState<string>("");
const [showNode, setShowNode] = useState(data.showNode ?? true);

Expand Down Expand Up @@ -108,15 +107,6 @@ export default function GenericNode({
checkNodeIconFragment,
);

function countHandles(): void {
const count = countHandlesFn(data);
setHandles(count);
}

useEffect(() => {
countHandles();
}, [data, data.node]);

useEffect(() => {
setShowNode(data.showNode ?? true);
}, [data.showNode]);
Expand Down Expand Up @@ -228,7 +218,6 @@ export default function GenericNode({
}));
}}
setShowState={setShowNode}
numberOfHandles={handles}
numberOfOutputHandles={shownOutputs.length ?? 0}
showNode={showNode}
openAdvancedModal={false}
Expand All @@ -244,7 +233,6 @@ export default function GenericNode({
takeSnapshot,
setNode,
setShowNode,
handles,
showNode,
updateNodeCode,
isOutdated,
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
import ForwardedIconComponent from "@/components/genericIconComponent";
import { IS_MAC } from "@/constants/constants";
import { cn } from "@/utils/utils";

export default function RenderKey({
value,
tableRender,
}: {
value: string;
tableRender?: boolean;
}): JSX.Element {
const check = value.toLowerCase().trim();
return (
<div>
{check === "shift" ? (
<ForwardedIconComponent
name="ArrowBigUp"
className={cn(tableRender ? "h-5 w-5" : "h-4 w-4")}
/>
) : check === "ctrl" && IS_MAC ? (
<span>⌃</span>
) : check === "alt" && IS_MAC ? (
<ForwardedIconComponent
name="OptionIcon"
className={cn(tableRender ? "h-4 w-4" : "h-3 w-3")}
/>
) : check === "cmd" ? (
<ForwardedIconComponent
name="Command"
className={cn(tableRender ? "h-4 w-4" : "h-3 w-3")}
/>
) : (
<span>{value}</span>
)}
</div>
);
}
59 changes: 17 additions & 42 deletions src/frontend/src/components/renderIconComponent/index.tsx
Original file line number Diff line number Diff line change
@@ -1,52 +1,27 @@
import ForwardedIconComponent from "../genericIconComponent";
import { IS_MAC } from "@/constants/constants";
import { addPlusSignes, cn, sortShortcuts } from "@/utils/utils";
import RenderKey from "./components/renderKey";

export default function RenderIcons({
isMac,
hasShift,
filteredShortcut,
shortcutWPlus,
tableRender = false,
}: {
isMac: boolean;
hasShift: boolean;
filteredShortcut: string[];
shortcutWPlus: string[];
tableRender?: boolean;
}): JSX.Element {
return hasShift ? (
<span className="flex items-center justify-center gap-0.5 text-xs">
{isMac ? (
<ForwardedIconComponent name="Command" className="h-3 w-3" />
) : (
filteredShortcut[0]
const shortcutList = addPlusSignes([...filteredShortcut].sort(sortShortcuts));
return (
<span
className={cn(
"flex items-center gap-0.5",
tableRender ? "justify-start" : "justify-center text-xs",
)}
<ForwardedIconComponent name="ArrowBigUp" className="h-4 w-4" />
{filteredShortcut.map((key, idx) => {
if (idx > 0) {
return key.toUpperCase();
}
return null;
})}
</span>
) : (
<span className="flex items-center justify-center gap-0.5 text-xs">
{shortcutWPlus[0].toLowerCase() === "space" ? (
"Space"
) : shortcutWPlus[0].length <= 1 ? (
shortcutWPlus[0]
) : isMac ? (
<ForwardedIconComponent name="Command" className="h-3 w-3" />
) : (
<span className="flex items-center">{shortcutWPlus[0]}</span>
)}
{shortcutWPlus.map((key, idx) => {
if (idx > 0) {
return (
<span key={idx} className="flex items-center">
{key.toUpperCase()}
</span>
);
}
return null;
})}
>
{shortcutList.map((key, index) => (
<span key={index}>
<RenderKey value={key} tableRender={tableRender} />
</span>
))}
</span>
);
}
2 changes: 2 additions & 0 deletions src/frontend/src/constants/constants.ts
Original file line number Diff line number Diff line change
Expand Up @@ -886,3 +886,5 @@ export const LANGFLOW_ACCESS_TOKEN_EXPIRE_SECONDS_ENV =
export const TEXT_FIELD_TYPES: string[] = ["str", "SecretStr"];
export const NODE_WIDTH = 400;
export const NODE_HEIGHT = NODE_WIDTH * 3;

export const SHORTCUT_KEYS = ["cmd", "ctrl", "alt", "shift"];
Original file line number Diff line number Diff line change
@@ -0,0 +1,115 @@
import { useShortcutsStore } from "@/stores/shortcuts";
import { useHotkeys } from "react-hotkeys-hook";
import isWrappedWithClass from "../../PageComponent/utils/is-wrapped-with-class";

export default function useShortcuts({
showOverrideModal,
showModalAdvanced,
openModal,
showconfirmShare,
FreezeAllVertices,
Freeze,
downloadFunction,
displayDocs,
saveComponent,
showAdvance,
handleCodeModal,
shareComponent,
ungroup,
minimizeFunction,
}: {
showOverrideModal: boolean;
showModalAdvanced: boolean;
openModal: boolean;
showconfirmShare: boolean;
FreezeAllVertices: () => void;
Freeze: () => void;
downloadFunction: () => void;
displayDocs: () => void;
saveComponent: () => void;
showAdvance: () => void;
handleCodeModal: () => void;
shareComponent: () => void;
ungroup: () => void;
minimizeFunction: () => void;
}) {
const advanced = useShortcutsStore((state) => state.advanced);
const minimize = useShortcutsStore((state) => state.minimize);
const component = useShortcutsStore((state) => state.component);
const save = useShortcutsStore((state) => state.save);
const docs = useShortcutsStore((state) => state.docs);
const code = useShortcutsStore((state) => state.code);
const group = useShortcutsStore((state) => state.group);
const download = useShortcutsStore((state) => state.download);
const freeze = useShortcutsStore((state) => state.freeze);
const freezeAll = useShortcutsStore((state) => state.FreezePath);

function handleFreezeAll(e: KeyboardEvent) {
if (isWrappedWithClass(e, "noflow")) return;
e.preventDefault();
FreezeAllVertices();
}

function handleFreeze(e: KeyboardEvent) {
if (isWrappedWithClass(e, "noflow")) return;
e.preventDefault();
Freeze();
}

function handleDownloadWShortcut(e: KeyboardEvent) {
e.preventDefault();
downloadFunction();
}

function handleDocsWShortcut(e: KeyboardEvent) {
e.preventDefault();
displayDocs();
}

function handleSaveWShortcut(e: KeyboardEvent) {
if (isWrappedWithClass(e, "noflow") && !showOverrideModal) return;
e.preventDefault();
saveComponent();
}

function handleAdvancedWShortcut(e: KeyboardEvent) {
//check if there is another modal open
if (isWrappedWithClass(e, "noflow") && !showModalAdvanced) return;
e.preventDefault();
showAdvance();
}

function handleCodeWShortcut(e: KeyboardEvent) {
if (isWrappedWithClass(e, "noflow") && !openModal) return;
e.preventDefault();
handleCodeModal();
}

function handleShareWShortcut(e: KeyboardEvent) {
if (isWrappedWithClass(e, "noflow") && !showconfirmShare) return;
e.preventDefault();
shareComponent();
}
function handleGroupWShortcut(e: KeyboardEvent) {
if (isWrappedWithClass(e, "noflow")) return;
e.preventDefault();
ungroup();
}

function handleMinimizeWShortcut(e: KeyboardEvent) {
if (isWrappedWithClass(e, "noflow")) return;
e.preventDefault();
minimizeFunction();
}

useHotkeys(minimize, handleMinimizeWShortcut, { preventDefault: true });
useHotkeys(group, handleGroupWShortcut, { preventDefault: true });
useHotkeys(component, handleShareWShortcut, { preventDefault: true });
useHotkeys(code, handleCodeWShortcut, { preventDefault: true });
useHotkeys(advanced, handleAdvancedWShortcut, { preventDefault: true });
useHotkeys(save, handleSaveWShortcut, { preventDefault: true });
useHotkeys(docs, handleDocsWShortcut, { preventDefault: true });
useHotkeys(download, handleDownloadWShortcut, { preventDefault: true });
useHotkeys(freeze, handleFreeze);
useHotkeys(freezeAll, handleFreezeAll);
}
Loading
Loading