Você não pode selecionar mais de 25 tópicos Os tópicos devem começar com uma letra ou um número, podem incluir traços ('-') e podem ter até 35 caracteres.

panel.tsx 3.8KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. import type { FC } from 'react'
  2. import React from 'react'
  3. import { useTranslation } from 'react-i18next'
  4. import RemoveEffectVarConfirm from '../_base/components/remove-effect-var-confirm'
  5. import useConfig from './use-config'
  6. import type { CodeNodeType } from './types'
  7. import { CodeLanguage } from './types'
  8. import { extractFunctionParams, extractReturnType } from './code-parser'
  9. import VarList from '@/app/components/workflow/nodes/_base/components/variable/var-list'
  10. import OutputVarList from '@/app/components/workflow/nodes/_base/components/variable/output-var-list'
  11. import AddButton from '@/app/components/base/button/add-button'
  12. import Field from '@/app/components/workflow/nodes/_base/components/field'
  13. import Split from '@/app/components/workflow/nodes/_base/components/split'
  14. import CodeEditor from '@/app/components/workflow/nodes/_base/components/editor/code-editor'
  15. import TypeSelector from '@/app/components/workflow/nodes/_base/components/selector'
  16. import type { NodePanelProps } from '@/app/components/workflow/types'
  17. const i18nPrefix = 'workflow.nodes.code'
  18. const codeLanguages = [
  19. {
  20. label: 'Python3',
  21. value: CodeLanguage.python3,
  22. },
  23. {
  24. label: 'JavaScript',
  25. value: CodeLanguage.javascript,
  26. },
  27. ]
  28. const Panel: FC<NodePanelProps<CodeNodeType>> = ({
  29. id,
  30. data,
  31. }) => {
  32. const { t } = useTranslation()
  33. const {
  34. readOnly,
  35. inputs,
  36. outputKeyOrders,
  37. handleCodeAndVarsChange,
  38. handleVarListChange,
  39. handleAddVariable,
  40. handleRemoveVariable,
  41. handleCodeChange,
  42. handleCodeLanguageChange,
  43. handleVarsChange,
  44. handleAddOutputVariable,
  45. filterVar,
  46. isShowRemoveVarConfirm,
  47. hideRemoveVarConfirm,
  48. onRemoveVarConfirm,
  49. } = useConfig(id, data)
  50. const handleGeneratedCode = (value: string) => {
  51. const params = extractFunctionParams(value, inputs.code_language)
  52. const codeNewInput = params.map((p) => {
  53. return {
  54. variable: p,
  55. value_selector: [],
  56. }
  57. })
  58. const returnTypes = extractReturnType(value, inputs.code_language)
  59. handleCodeAndVarsChange(value, codeNewInput, returnTypes)
  60. }
  61. return (
  62. <div className='mt-2'>
  63. <div className='space-y-4 px-4 pb-4'>
  64. <Field
  65. title={t(`${i18nPrefix}.inputVars`)}
  66. operations={
  67. !readOnly ? <AddButton onClick={handleAddVariable} /> : undefined
  68. }
  69. >
  70. <VarList
  71. readonly={readOnly}
  72. nodeId={id}
  73. list={inputs.variables}
  74. onChange={handleVarListChange}
  75. filterVar={filterVar}
  76. isSupportFileVar={false}
  77. />
  78. </Field>
  79. <Split />
  80. <CodeEditor
  81. isInNode
  82. readOnly={readOnly}
  83. title={
  84. <TypeSelector
  85. options={codeLanguages}
  86. value={inputs.code_language}
  87. onChange={handleCodeLanguageChange}
  88. />
  89. }
  90. language={inputs.code_language}
  91. value={inputs.code}
  92. onChange={handleCodeChange}
  93. onGenerated={handleGeneratedCode}
  94. showCodeGenerator={true}
  95. />
  96. </div>
  97. <Split />
  98. <div className='px-4 pb-2 pt-4'>
  99. <Field
  100. title={t(`${i18nPrefix}.outputVars`)}
  101. operations={
  102. <AddButton onClick={handleAddOutputVariable} />
  103. }
  104. required
  105. >
  106. <OutputVarList
  107. readonly={readOnly}
  108. outputs={inputs.outputs}
  109. outputKeyOrders={outputKeyOrders}
  110. onChange={handleVarsChange}
  111. onRemove={handleRemoveVariable}
  112. />
  113. </Field>
  114. </div>
  115. <RemoveEffectVarConfirm
  116. isShow={isShowRemoveVarConfirm}
  117. onCancel={hideRemoveVarConfirm}
  118. onConfirm={onRemoveVarConfirm}
  119. />
  120. </div >
  121. )
  122. }
  123. export default React.memo(Panel)