InvokeAI/invokeai/frontend/web/src/features/nodes/hooks
Mary Hipp Rogers 9d6e4ff1fb
workflow tab (#5680)
* new workflow tab UI - still using shared state with workflow editor tab

* polish workflow details

* remove workflow tab, add edit/view mode to workflow slice and get that working to switch between within editor tab

* UI updates for view/edit mode

* cleanup

* add warning to view mode

* lint

* start with isTouched false

* working on styling mode toggle

* more UX iteration

* lint

* cleanup

* save original field values to state, add indicator if they have been changed and give user choice to reset

* lint

* fix import and commit translation

* dont switch to view mode when loading a workflow

* warns before clearing editor

* use folder icon

* fix(ui): track do not erase value when resetting field value

- When adding an exposed field, we need to add it to originalExposedFieldValues
- When removing an exposed field, we need to remove it from originalExposedFieldValues
- add `useFieldValue` and `useOriginalFieldValue` hooks to encapsulate related logic

* feat(ui): use IconButton for workflow view/edit button

* feat(ui): change icon for new workflow

It was the same as the workflow tab icon, confusing bc you think it's going to somehow take you to the tab.

* feat(ui): use render props for NewWorkflowConfirmationAlertDialog

There was a lot of potentially sensitive logic shared between the new workflow button and menu items. Also, two instances of ConfirmationAlertDialog.

Using a render prop deduplicates the logic & components

* fix(ui): do not mark workflow touched when loading workflow

This was occurring because the `nodesChanged` action is called by reactflow when loading a workflow. Specifically, it calculates and sets the node dimensions as it loads.

The existing logic set `isTouched` whenever this action was called.

The changes reactflow emits have types, and we can use the change types and data to determine if a change should result in the workflow being marked as touched.

* chore(ui): lint

* chore(ui): lint

* delete empty file

---------

Co-authored-by: Mary Hipp <maryhipp@Marys-MacBook-Air.local>
Co-authored-by: psychedelicious <4822129+psychedelicious@users.noreply.github.com>
2024-02-14 09:02:07 -05:00
..
useAnyOrDirectInputFieldNames.ts chore(ui): format 2024-01-28 19:57:53 +11:00
useBuildNode.ts chore(ui): format 2024-01-28 19:57:53 +11:00
useConnectionInputFieldNames.ts chore(ui): format 2024-01-28 19:57:53 +11:00
useConnectionState.ts chore(ui): format 2024-01-28 19:57:53 +11:00
useDoesInputHaveValue.ts fix(ui): do not use state => state as an input selector 2024-01-06 00:03:07 +11:00
useDoNodeVersionsMatch.ts chore(ui): format 2024-01-28 19:57:53 +11:00
useFieldData.ts fix(ui): do not use state => state as an input selector 2024-01-06 00:03:07 +11:00
useFieldInputInstance.ts fix(ui): do not use state => state as an input selector 2024-01-06 00:03:07 +11:00
useFieldInputKind.ts chore(ui): format 2024-01-28 19:57:53 +11:00
useFieldInputTemplate.ts chore(ui): format 2024-01-28 19:57:53 +11:00
useFieldLabel.ts fix(ui): update most other selectors 2024-01-06 00:03:07 +11:00
useFieldOriginalValue.ts workflow tab (#5680) 2024-02-14 09:02:07 -05:00
useFieldOutputInstance.ts fix(ui): do not use state => state as an input selector 2024-01-06 00:03:07 +11:00
useFieldOutputTemplate.ts chore(ui): format 2024-01-28 19:57:53 +11:00
useFieldTemplate.ts chore(ui): format 2024-01-28 19:57:53 +11:00
useFieldTemplateTitle.ts chore(ui): format 2024-01-28 19:57:53 +11:00
useFieldType.ts.ts chore(ui): format 2024-01-28 19:57:53 +11:00
useFieldValue.ts workflow tab (#5680) 2024-02-14 09:02:07 -05:00
useGetNodesNeedUpdate.ts chore(ui): format 2024-01-28 19:57:53 +11:00
useHasImageOutput.ts fix(ui): do not use state => state as an input selector 2024-01-06 00:03:07 +11:00
useIsIntermediate.ts fix(ui): update most other selectors 2024-01-06 00:03:07 +11:00
useIsValidConnection.ts chore(ui): format 2024-01-28 19:57:53 +11:00
useMouseOverNode.ts feat(ui): optimized useMouseOverNode 2024-01-01 08:13:23 -05:00
useNodeClassification.ts chore(ui): format 2024-01-28 19:57:53 +11:00
useNodeData.ts fix(ui): do not use state => state as an input selector 2024-01-06 00:03:07 +11:00
useNodeLabel.ts fix(ui): update most other selectors 2024-01-06 00:03:07 +11:00
useNodeNeedsUpdate.ts chore(ui): format 2024-01-28 19:57:53 +11:00
useNodePack.ts fix(ui): update most other selectors 2024-01-06 00:03:07 +11:00
useNodeTemplate.ts chore(ui): format 2024-01-28 19:57:53 +11:00
useNodeTemplateByType.ts chore(ui): format 2024-01-28 19:57:53 +11:00
useNodeTemplateTitle.ts chore(ui): format 2024-01-28 19:57:53 +11:00
useOutputFieldNames.ts chore(ui): format 2024-01-28 19:57:53 +11:00
usePrettyFieldType.ts feat(ui): ux improvements & redesign 2023-12-29 08:26:14 -05:00
useUseCache.ts fix(ui): update most other selectors 2024-01-06 00:03:07 +11:00
useWithFooter.ts chore(ui): format 2024-01-28 19:57:53 +11:00
useWorkflowWatcher.ts chore(ui): format 2024-01-28 19:57:53 +11:00