add-variable-popup-with-position.tsx 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. import {
  2. memo,
  3. useCallback,
  4. useMemo,
  5. useRef,
  6. } from 'react'
  7. import { useClickAway } from 'ahooks'
  8. import { useTranslation } from 'react-i18next'
  9. import { useStore } from '../../../store'
  10. import {
  11. useIsChatMode,
  12. useNodeDataUpdate,
  13. useWorkflow,
  14. } from '../../../hooks'
  15. import type {
  16. ValueSelector,
  17. Var,
  18. VarType,
  19. } from '../../../types'
  20. import { useVariableAssigner } from '../../variable-assigner/hooks'
  21. import { filterVar } from '../../variable-assigner/utils'
  22. import AddVariablePopup from './add-variable-popup'
  23. import { toNodeAvailableVars } from '@/app/components/workflow/nodes/_base/components/variable/utils'
  24. type AddVariablePopupWithPositionProps = {
  25. nodeId: string
  26. nodeData: any
  27. }
  28. const AddVariablePopupWithPosition = ({
  29. nodeId,
  30. nodeData,
  31. }: AddVariablePopupWithPositionProps) => {
  32. const { t } = useTranslation()
  33. const ref = useRef(null)
  34. const showAssignVariablePopup = useStore(s => s.showAssignVariablePopup)
  35. const setShowAssignVariablePopup = useStore(s => s.setShowAssignVariablePopup)
  36. const { handleNodeDataUpdate } = useNodeDataUpdate()
  37. const { handleAddVariableInAddVariablePopupWithPosition } = useVariableAssigner()
  38. const isChatMode = useIsChatMode()
  39. const { getBeforeNodesInSameBranch } = useWorkflow()
  40. const outputType = useMemo(() => {
  41. if (!showAssignVariablePopup)
  42. return ''
  43. if (showAssignVariablePopup.variableAssignerNodeHandleId === 'target')
  44. return showAssignVariablePopup.variableAssignerNodeData.output_type
  45. const group = showAssignVariablePopup.variableAssignerNodeData.advanced_settings?.groups.find(group => group.groupId === showAssignVariablePopup.variableAssignerNodeHandleId)
  46. return group?.output_type || ''
  47. }, [showAssignVariablePopup])
  48. const availableVars = useMemo(() => {
  49. if (!showAssignVariablePopup)
  50. return []
  51. return toNodeAvailableVars({
  52. parentNode: showAssignVariablePopup.parentNode,
  53. t,
  54. beforeNodes: [
  55. ...getBeforeNodesInSameBranch(showAssignVariablePopup.nodeId),
  56. {
  57. id: showAssignVariablePopup.nodeId,
  58. data: showAssignVariablePopup.nodeData,
  59. } as any,
  60. ],
  61. isChatMode,
  62. filterVar: filterVar(outputType as VarType),
  63. })
  64. }, [getBeforeNodesInSameBranch, isChatMode, showAssignVariablePopup, t, outputType])
  65. useClickAway(() => {
  66. if (nodeData._holdAddVariablePopup) {
  67. handleNodeDataUpdate({
  68. id: nodeId,
  69. data: {
  70. _holdAddVariablePopup: false,
  71. },
  72. })
  73. }
  74. else {
  75. handleNodeDataUpdate({
  76. id: nodeId,
  77. data: {
  78. _showAddVariablePopup: false,
  79. },
  80. })
  81. setShowAssignVariablePopup(undefined)
  82. }
  83. }, ref)
  84. const handleAddVariable = useCallback((value: ValueSelector, varDetail: Var) => {
  85. if (showAssignVariablePopup) {
  86. handleAddVariableInAddVariablePopupWithPosition(
  87. showAssignVariablePopup.nodeId,
  88. showAssignVariablePopup.variableAssignerNodeId,
  89. showAssignVariablePopup.variableAssignerNodeHandleId,
  90. value,
  91. varDetail,
  92. )
  93. }
  94. }, [showAssignVariablePopup, handleAddVariableInAddVariablePopupWithPosition])
  95. if (!showAssignVariablePopup)
  96. return null
  97. return (
  98. <div
  99. className='absolute z-10'
  100. style={{
  101. left: showAssignVariablePopup.x,
  102. top: showAssignVariablePopup.y,
  103. }}
  104. ref={ref}
  105. >
  106. <AddVariablePopup
  107. availableVars={availableVars}
  108. onSelect={handleAddVariable}
  109. />
  110. </div>
  111. )
  112. }
  113. export default memo(AddVariablePopupWithPosition)