Du kan inte välja fler än 25 ämnen Ämnen måste starta med en bokstav eller siffra, kan innehålla bindestreck ('-') och vara max 35 tecken långa.

use-config.ts 3.6KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. import { useCallback, useState } from 'react'
  2. import produce from 'immer'
  3. import { useBoolean } from 'ahooks'
  4. import type { StartNodeType } from './types'
  5. import { ChangeType } from '@/app/components/workflow/types'
  6. import type { InputVar, MoreInfo, ValueSelector } from '@/app/components/workflow/types'
  7. import useNodeCrud from '@/app/components/workflow/nodes/_base/hooks/use-node-crud'
  8. import {
  9. useIsChatMode,
  10. useNodesReadOnly,
  11. useWorkflow,
  12. } from '@/app/components/workflow/hooks'
  13. import useInspectVarsCrud from '../../hooks/use-inspect-vars-crud'
  14. const useConfig = (id: string, payload: StartNodeType) => {
  15. const { nodesReadOnly: readOnly } = useNodesReadOnly()
  16. const { handleOutVarRenameChange, isVarUsedInNodes, removeUsedVarInNodes } = useWorkflow()
  17. const isChatMode = useIsChatMode()
  18. const { inputs, setInputs } = useNodeCrud<StartNodeType>(id, payload)
  19. const {
  20. deleteNodeInspectorVars,
  21. renameInspectVarName,
  22. nodesWithInspectVars,
  23. deleteInspectVar,
  24. } = useInspectVarsCrud()
  25. const [isShowAddVarModal, {
  26. setTrue: showAddVarModal,
  27. setFalse: hideAddVarModal,
  28. }] = useBoolean(false)
  29. const [isShowRemoveVarConfirm, {
  30. setTrue: showRemoveVarConfirm,
  31. setFalse: hideRemoveVarConfirm,
  32. }] = useBoolean(false)
  33. const [removedVar, setRemovedVar] = useState<ValueSelector>([])
  34. const [removedIndex, setRemoveIndex] = useState(0)
  35. const handleVarListChange = useCallback((newList: InputVar[], moreInfo?: { index: number; payload: MoreInfo }) => {
  36. if (moreInfo?.payload?.type === ChangeType.remove) {
  37. const varId = nodesWithInspectVars.find(node => node.nodeId === id)?.vars.find((varItem) => {
  38. return varItem.name === moreInfo?.payload?.payload?.beforeKey
  39. })?.id
  40. if(varId)
  41. deleteInspectVar(id, varId)
  42. if (isVarUsedInNodes([id, moreInfo?.payload?.payload?.beforeKey || ''])) {
  43. showRemoveVarConfirm()
  44. setRemovedVar([id, moreInfo?.payload?.payload?.beforeKey || ''])
  45. setRemoveIndex(moreInfo?.index as number)
  46. return
  47. }
  48. }
  49. const newInputs = produce(inputs, (draft: any) => {
  50. draft.variables = newList
  51. })
  52. setInputs(newInputs)
  53. if (moreInfo?.payload?.type === ChangeType.changeVarName) {
  54. const changedVar = newList[moreInfo.index]
  55. handleOutVarRenameChange(id, [id, inputs.variables[moreInfo.index].variable], [id, changedVar.variable])
  56. renameInspectVarName(id, inputs.variables[moreInfo.index].variable, changedVar.variable)
  57. }
  58. else if(moreInfo?.payload?.type !== ChangeType.remove) { // edit var type
  59. deleteNodeInspectorVars(id)
  60. }
  61. }, [deleteInspectVar, deleteNodeInspectorVars, handleOutVarRenameChange, id, inputs, isVarUsedInNodes, nodesWithInspectVars, renameInspectVarName, setInputs, showRemoveVarConfirm])
  62. const removeVarInNode = useCallback(() => {
  63. const newInputs = produce(inputs, (draft) => {
  64. draft.variables.splice(removedIndex, 1)
  65. })
  66. setInputs(newInputs)
  67. removeUsedVarInNodes(removedVar)
  68. hideRemoveVarConfirm()
  69. }, [hideRemoveVarConfirm, inputs, removeUsedVarInNodes, removedIndex, removedVar, setInputs])
  70. const handleAddVariable = useCallback((payload: InputVar) => {
  71. const newInputs = produce(inputs, (draft: StartNodeType) => {
  72. draft.variables.push(payload)
  73. })
  74. setInputs(newInputs)
  75. }, [inputs, setInputs])
  76. return {
  77. readOnly,
  78. isChatMode,
  79. inputs,
  80. isShowAddVarModal,
  81. showAddVarModal,
  82. hideAddVarModal,
  83. handleVarListChange,
  84. handleAddVariable,
  85. isShowRemoveVarConfirm,
  86. hideRemoveVarConfirm,
  87. onRemoveVarConfirm: removeVarInNode,
  88. }
  89. }
  90. export default useConfig