workflow.ts 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470
  1. const translation = {
  2. common: {
  3. undo: '실행 취소',
  4. redo: '다시 실행',
  5. editing: '편집 중',
  6. autoSaved: '자동 저장됨',
  7. unpublished: '미발행',
  8. published: '발행됨',
  9. publish: '발행',
  10. update: '업데이트',
  11. run: '실행',
  12. running: '실행 중',
  13. inRunMode: '실행 모드',
  14. inPreview: '미리보기 중',
  15. inPreviewMode: '미리보기 모드',
  16. preview: '미리보기',
  17. viewRunHistory: '실행 기록 보기',
  18. runHistory: '실행 기록',
  19. goBackToEdit: '편집기로 돌아가기',
  20. conversationLog: '대화 로그',
  21. features: '기능',
  22. debugAndPreview: '미리보기',
  23. restart: '재시작',
  24. currentDraft: '현재 초안',
  25. currentDraftUnpublished: '현재 초안 미발행',
  26. latestPublished: '최신 발행본',
  27. publishedAt: '발행일',
  28. restore: '복원',
  29. runApp: '앱 실행',
  30. batchRunApp: '앱 일괄 실행',
  31. accessAPIReference: 'API 참조 접근',
  32. embedIntoSite: '사이트에 삽입',
  33. addTitle: '제목 추가...',
  34. addDescription: '설명 추가...',
  35. noVar: '변수 없음',
  36. searchVar: '변수 검색',
  37. variableNamePlaceholder: '변수 이름',
  38. setVarValuePlaceholder: '변수 값 설정',
  39. needConnecttip: '이 단계는 아무것도 연결되어 있지 않습니다',
  40. maxTreeDepth: '분기당 최대 {{depth}} 노드 제한',
  41. needEndNode: '종료 블록을 추가해야 합니다',
  42. needAnswerNode: '답변 블록을 추가해야 합니다',
  43. workflowProcess: '워크플로우 과정',
  44. notRunning: '아직 실행되지 않음',
  45. previewPlaceholder: '디버깅을 시작하려면 아래 상자에 내용을 입력하세요',
  46. effectVarConfirm: {
  47. title: '변수 제거',
  48. content: '변수가 다른 노드에서 사용되고 있습니다. 그래도 제거하시겠습니까?',
  49. },
  50. insertVarTip: '빠르게 삽입하려면 \'/\' 키를 누르세요',
  51. processData: '데이터 처리',
  52. input: '입력',
  53. output: '출력',
  54. jinjaEditorPlaceholder: '변수를 삽입하려면 \'/\' 또는 \'{\'를 입력하세요',
  55. viewOnly: '보기 전용',
  56. showRunHistory: '실행 기록 보기',
  57. enableJinja: 'Jinja 템플릿 지원 활성화',
  58. learnMore: '더 알아보기',
  59. copy: '복사',
  60. duplicate: '복제',
  61. addBlock: '블록 추가',
  62. pasteHere: '여기에 붙여넣기',
  63. pointerMode: '포인터 모드',
  64. handMode: '핸드 모드',
  65. model: '모델',
  66. workflowAsTool: '도구로서의 워크플로우',
  67. configureRequired: '구성 필요',
  68. configure: '구성',
  69. manageInTools: '도구에서 관리',
  70. workflowAsToolTip: '워크플로우 업데이트 후 도구 재구성이 필요합니다.',
  71. viewDetailInTracingPanel: '세부 정보 보기',
  72. },
  73. env: {
  74. envPanelTitle: '환경 변수',
  75. envDescription: '환경 변수는 개인 정보와 자격 증명을 저장하는 데 사용될 수 있습니다. 이들은 읽기 전용이며 내보내기 중에 DSL 파일과 분리할 수 있습니다.',
  76. envPanelButton: '변수 추가',
  77. modal: {
  78. title: '환경 변수 추가',
  79. editTitle: '환경 변수 편집',
  80. type: '유형',
  81. name: '이름',
  82. namePlaceholder: '환경 이름',
  83. value: '값',
  84. valuePlaceholder: '환경 값',
  85. secretTip: '민감한 정보나 데이터를 정의하는 데 사용되며, DSL 설정은 유출 방지를 위해 구성됩니다.',
  86. },
  87. export: {
  88. title: '비밀 환경 변수를 내보내시겠습니까?',
  89. checkbox: '비밀 값 내보내기',
  90. ignore: 'DSL 내보내기',
  91. export: '비밀 값이 포함된 DSL 내보내기',
  92. },
  93. },
  94. changeHistory: {
  95. title: '변경 기록',
  96. placeholder: '아직 아무 것도 변경하지 않았습니다',
  97. clearHistory: '기록 지우기',
  98. hint: '힌트',
  99. hintText: '편집 작업이 변경 기록에 추적되며, 이 세션 동안 기기에 저장됩니다. 편집기를 떠나면 이 기록이 지워집니다.',
  100. stepBackward_one: '{{count}} 단계 뒤로',
  101. stepBackward_other: '{{count}} 단계 뒤로',
  102. stepForward_one: '{{count}} 단계 앞으로',
  103. stepForward_other: '{{count}} 단계 앞으로',
  104. sessionStart: '세션 시작',
  105. currentState: '현재 상태',
  106. nodeTitleChange: '블록 제목 변경됨',
  107. nodeDescriptionChange: '블록 설명 변경됨',
  108. nodeDragStop: '블록 이동됨',
  109. nodeChange: '블록 변경됨',
  110. nodeConnect: '블록 연결됨',
  111. nodePaste: '블록 붙여넣기됨',
  112. nodeDelete: '블록 삭제됨',
  113. nodeAdd: '블록 추가됨',
  114. nodeResize: '블록 크기 조정됨',
  115. noteAdd: '노트 추가됨',
  116. noteChange: '노트 변경됨',
  117. noteDelete: '노트 삭제됨',
  118. edgeDelete: '블록 연결 해제됨',
  119. },
  120. errorMsg: {
  121. fieldRequired: '{{field}}가 필요합니다',
  122. authRequired: '인증이 필요합니다',
  123. invalidJson: '{{field}}는 잘못된 JSON입니다',
  124. fields: {
  125. variable: '변수 이름',
  126. variableValue: '변수 값',
  127. code: '코드',
  128. model: '모델',
  129. rerankModel: '재정렬 모델',
  130. },
  131. invalidVariable: '잘못된 변수',
  132. },
  133. singleRun: {
  134. testRun: '테스트 실행',
  135. startRun: '실행 시작',
  136. running: '실행 중',
  137. testRunIteration: '테스트 실행 반복',
  138. back: '뒤로',
  139. iteration: '반복',
  140. },
  141. tabs: {
  142. 'searchBlock': '블록 검색',
  143. 'blocks': '블록',
  144. 'tools': '도구',
  145. 'allTool': '전체',
  146. 'builtInTool': '내장',
  147. 'customTool': '사용자 정의',
  148. 'workflowTool': '워크플로우',
  149. 'question-understand': '질문 이해',
  150. 'logic': '논리',
  151. 'transform': '변환',
  152. 'utilities': '유틸리티',
  153. 'noResult': '일치하는 결과 없음',
  154. },
  155. blocks: {
  156. 'start': '시작',
  157. 'end': '끝',
  158. 'answer': '답변',
  159. 'llm': 'LLM',
  160. 'knowledge-retrieval': '지식 검색',
  161. 'question-classifier': '질문 분류기',
  162. 'if-else': 'IF/ELSE',
  163. 'code': '코드',
  164. 'template-transform': '템플릿',
  165. 'http-request': 'HTTP 요청',
  166. 'variable-assigner': '변수 할당자',
  167. 'variable-aggregator': '변수 집계자',
  168. 'iteration-start': '반복 시작',
  169. 'iteration': '반복',
  170. 'parameter-extractor': '매개변수 추출기',
  171. },
  172. blocksAbout: {
  173. 'start': '워크플로우를 시작하기 위한 초기 매개변수를 정의합니다',
  174. 'end': '워크플로우의 종료 및 결과 유형을 정의합니다',
  175. 'answer': '대화의 답변 내용을 정의합니다',
  176. 'llm': '질문에 답하거나 자연어를 처리하기 위해 대형 언어 모델을 호출합니다',
  177. 'knowledge-retrieval': '사용자 질문과 관련된 텍스트 콘텐츠를 지식 베이스에서 쿼리할 수 있습니다',
  178. 'question-classifier': '사용자 질문의 분류 조건을 정의합니다. LLM은 분류 설명을 기반으로 대화의 진행 방식을 정의할 수 있습니다',
  179. 'if-else': 'if/else 조건을 기반으로 워크플로우를 두 가지 분기로 나눌 수 있습니다',
  180. 'code': '사용자 정의 논리를 구현하기 위해 Python 또는 NodeJS 코드를 실행합니다',
  181. 'template-transform': 'Jinja 템플릿 구문을 사용하여 데이터를 문자열로 변환합니다',
  182. 'http-request': 'HTTP 프로토콜을 통해 서버 요청을 보낼 수 있습니다',
  183. 'variable-assigner': '다중 분기 변수들을 하나의 변수로 집계하여 다운스트림 노드의 통합 구성을 가능하게 합니다.',
  184. 'variable-aggregator': '다중 분기 변수들을 하나의 변수로 집계하여 다운스트림 노드의 통합 구성을 가능하게 합니다.',
  185. 'iteration': '목록 객체에서 여러 단계를 수행하여 모든 결과가 출력될 때까지 반복합니다.',
  186. 'parameter-extractor': '도구 호출 또는 HTTP 요청을 위해 자연어에서 구조화된 매개변수를 추출하기 위해 LLM을 사용합니다.',
  187. },
  188. operator: {
  189. zoomIn: '확대',
  190. zoomOut: '축소',
  191. zoomTo50: '50%로 확대',
  192. zoomTo100: '100%로 확대',
  193. zoomToFit: '화면에 맞게 확대',
  194. },
  195. panel: {
  196. userInputField: '사용자 입력 필드',
  197. changeBlock: '블록 변경',
  198. helpLink: '도움말 링크',
  199. about: '정보',
  200. createdBy: '작성자 ',
  201. nextStep: '다음 단계',
  202. addNextStep: '이 워크플로우의 다음 블록 추가',
  203. selectNextStep: '다음 블록 선택',
  204. runThisStep: '이 단계 실행',
  205. checklist: '체크리스트',
  206. checklistTip: '게시하기 전에 모든 문제가 해결되었는지 확인하세요',
  207. checklistResolved: '모든 문제가 해결되었습니다',
  208. organizeBlocks: '블록 정리',
  209. change: '변경',
  210. },
  211. nodes: {
  212. common: {
  213. outputVars: '출력 변수',
  214. insertVarTip: '변수 삽입',
  215. memory: {
  216. memory: '메모리',
  217. memoryTip: '대화 메모리 설정',
  218. windowSize: '창 크기',
  219. conversationRoleName: '대화 역할 이름',
  220. user: '사용자 접두사',
  221. assistant: '어시스턴트 접두사',
  222. },
  223. memories: {
  224. title: '메모리',
  225. tip: '대화 메모리',
  226. builtIn: '내장',
  227. },
  228. },
  229. start: {
  230. required: '필수',
  231. inputField: '입력 필드',
  232. builtInVar: '내장 변수',
  233. outputVars: {
  234. query: '사용자 입력',
  235. memories: {
  236. des: '대화 기록',
  237. type: '메시지 유형',
  238. content: '메시지 내용',
  239. },
  240. files: '파일 목록',
  241. },
  242. noVarTip: '워크플로우에서 사용할 입력을 설정하세요',
  243. },
  244. end: {
  245. outputs: '출력',
  246. output: {
  247. type: '출력 유형',
  248. variable: '출력 변수',
  249. },
  250. type: {
  251. 'none': '없음',
  252. 'plain-text': '일반 텍스트',
  253. 'structured': '구조화된',
  254. },
  255. },
  256. answer: {
  257. answer: '답변',
  258. outputVars: '출력 변수',
  259. },
  260. llm: {
  261. model: '모델',
  262. variables: '변수',
  263. context: '컨텍스트',
  264. contextTooltip: '컨텍스트로 지식을 가져올 수 있습니다',
  265. notSetContextInPromptTip: '컨텍스트 기능을 활성화하려면 PROMPT에 컨텍스트 변수를 입력하세요.',
  266. prompt: '프롬프트',
  267. roleDescription: {
  268. system: '대화를 위한 고급 지침 제공',
  269. user: '모델에 지침, 질문 또는 텍스트 기반 입력 제공',
  270. assistant: '사용자 메시지에 기반한 모델의 응답',
  271. },
  272. addMessage: '메시지 추가',
  273. vision: '비전',
  274. files: '파일',
  275. resolution: {
  276. name: '해상도',
  277. high: '높음',
  278. low: '낮음',
  279. },
  280. outputVars: {
  281. output: '생성된 내용',
  282. usage: '모델 사용 정보',
  283. },
  284. singleRun: {
  285. variable: '변수',
  286. },
  287. sysQueryInUser: '사용자 메시지에 sys.query가 필요합니다',
  288. },
  289. knowledgeRetrieval: {
  290. queryVariable: '쿼리 변수',
  291. knowledge: '지식',
  292. outputVars: {
  293. output: '복구된 세그먼트 데이터',
  294. content: '세그먼트 내용',
  295. title: '세그먼트 제목',
  296. icon: '세그먼트 아이콘',
  297. url: '세그먼트 URL',
  298. metadata: '기타 메타데이터',
  299. },
  300. },
  301. http: {
  302. inputVars: '입력 변수',
  303. api: 'API',
  304. apiPlaceholder: 'URL을 입력하세요, 변수를 삽입하려면 ‘/’를 입력하세요',
  305. notStartWithHttp: 'API는 http:// 또는 https://로 시작해야 합니다',
  306. key: '키',
  307. value: '값',
  308. bulkEdit: '일괄 편집',
  309. keyValueEdit: '키-값 편집',
  310. headers: '헤더',
  311. params: '매개변수',
  312. body: '본문',
  313. outputVars: {
  314. body: '응답 내용',
  315. statusCode: '응답 상태 코드',
  316. headers: '응답 헤더 목록 JSON',
  317. files: '파일 목록',
  318. },
  319. authorization: {
  320. 'authorization': '권한 부여',
  321. 'authorizationType': '권한 부여 유형',
  322. 'no-auth': '없음',
  323. 'api-key': 'API 키',
  324. 'auth-type': '인증 유형',
  325. 'basic': '기본',
  326. 'bearer': 'Bearer',
  327. 'custom': '사용자 정의',
  328. 'api-key-title': 'API 키',
  329. 'header': '헤더',
  330. },
  331. insertVarPlaceholder: '변수를 삽입하려면 \'/\'를 입력하세요',
  332. timeout: {
  333. title: '시간 초과',
  334. connectLabel: '연결 시간 초과',
  335. connectPlaceholder: '초 단위로 연결 시간 초과 입력',
  336. readLabel: '읽기 시간 초과',
  337. readPlaceholder: '초 단위로 읽기 시간 초과 입력',
  338. writeLabel: '쓰기 시간 초과',
  339. writePlaceholder: '초 단위로 쓰기 시간 초과 입력',
  340. },
  341. },
  342. code: {
  343. inputVars: '입력 변수',
  344. outputVars: '출력 변수',
  345. advancedDependencies: '고급 종속성',
  346. advancedDependenciesTip: '더 많은 시간이 소요되거나 기본으로 내장되지 않은 일부 미리 로드된 종속성을 여기에 추가하세요',
  347. searchDependencies: '종속성 검색',
  348. },
  349. templateTransform: {
  350. inputVars: '입력 변수',
  351. code: '코드',
  352. codeSupportTip: 'Jinja2만 지원합니다',
  353. outputVars: {
  354. output: '변환된 내용',
  355. },
  356. },
  357. ifElse: {
  358. if: 'If',
  359. else: 'Else',
  360. elseDescription: 'If 조건이 충족되지 않을 때 실행할 논리를 정의하는 데 사용됩니다.',
  361. and: '그리고',
  362. or: '또는',
  363. operator: '연산자',
  364. notSetVariable: '먼저 변수를 설정하세요',
  365. comparisonOperator: {
  366. 'contains': '포함',
  367. 'not contains': '포함하지 않음',
  368. 'start with': '시작',
  369. 'end with': '끝',
  370. 'is': '이다',
  371. 'is not': '아니다',
  372. 'empty': '비어 있음',
  373. 'not empty': '비어 있지 않음',
  374. 'null': 'null임',
  375. 'not null': 'null이 아님',
  376. },
  377. enterValue: '값 입력',
  378. addCondition: '조건 추가',
  379. conditionNotSetup: '조건이 설정되지 않음',
  380. },
  381. variableAssigner: {
  382. title: '변수 할당',
  383. outputType: '출력 유형',
  384. varNotSet: '변수가 설정되지 않음',
  385. noVarTip: '할당할 변수를 추가하세요',
  386. type: {
  387. string: '문자열',
  388. number: '숫자',
  389. object: '객체',
  390. array: '배열',
  391. },
  392. aggregationGroup: '집계 그룹',
  393. aggregationGroupTip: '이 기능을 활성화하면 변수 집계자가 여러 변수 집합을 집계할 수 있습니다.',
  394. addGroup: '그룹 추가',
  395. outputVars: {
  396. varDescribe: '{{groupName}} 출력',
  397. },
  398. setAssignVariable: '할당 변수 설정',
  399. },
  400. tool: {
  401. toAuthorize: '승인하기',
  402. inputVars: '입력 변수',
  403. outputVars: {
  404. text: '도구가 생성한 내용',
  405. files: {
  406. title: '도구가 생성한 파일',
  407. type: '지원 유형. 현재는 이미지만 지원합니다',
  408. transfer_method: '전송 방법. 값은 remote_url 또는 local_file',
  409. url: '이미지 URL',
  410. upload_file_id: '업로드된 파일 ID',
  411. },
  412. json: '도구로 생성된 JSON',
  413. },
  414. },
  415. questionClassifiers: {
  416. model: '모델',
  417. inputVars: '입력 변수',
  418. outputVars: {
  419. className: '클래스 이름',
  420. },
  421. class: '클래스',
  422. classNamePlaceholder: '클래스 이름을 작성하세요',
  423. advancedSetting: '고급 설정',
  424. topicName: '주제 이름',
  425. topicPlaceholder: '주제 이름을 작성하세요',
  426. addClass: '클래스 추가',
  427. instruction: '지시',
  428. instructionTip: '질문 분류기가 질문을 더 잘 분류할 수 있도록 추가 지시를 입력하세요.',
  429. instructionPlaceholder: '지시를 작성하세요',
  430. },
  431. parameterExtractor: {
  432. inputVar: '입력 변수',
  433. extractParameters: '매개변수 추출',
  434. importFromTool: '도구에서 가져오기',
  435. addExtractParameter: '추출 매개변수 추가',
  436. addExtractParameterContent: {
  437. name: '이름',
  438. namePlaceholder: '추출 매개변수 이름',
  439. type: '유형',
  440. typePlaceholder: '추출 매개변수 유형',
  441. description: '설명',
  442. descriptionPlaceholder: '추출 매개변수 설명',
  443. required: '필수',
  444. requiredContent: '필수는 모델 추론을 위한 참고 용도로만 사용되며, 매개변수 출력의 필수 유효성 검사는 아닙니다.',
  445. },
  446. extractParametersNotSet: '추출 매개변수가 설정되지 않음',
  447. instruction: '지시',
  448. instructionTip: '매개변수 추출기가 매개변수를 추출하는 방법을 이해하는 데 도움이 되는 추가 지시를 입력하세요.',
  449. advancedSetting: '고급 설정',
  450. reasoningMode: '추론 모드',
  451. reasoningModeTip: '모델의 함수 호출 또는 프롬프트에 대한 지시 응답 능력을 기반으로 적절한 추론 모드를 선택할 수 있습니다.',
  452. isSuccess: '성공 여부. 성공 시 값은 1이고, 실패 시 값은 0입니다.',
  453. errorReason: '오류 원인',
  454. },
  455. iteration: {
  456. deleteTitle: '반복 노드를 삭제하시겠습니까?',
  457. deleteDesc: '반복 노드를 삭제하면 모든 하위 노드가 삭제됩니다',
  458. input: '입력',
  459. output: '출력 변수',
  460. iteration_one: '{{count}} 반복',
  461. iteration_other: '{{count}} 반복',
  462. currentIteration: '현재 반복',
  463. },
  464. },
  465. tracing: {
  466. stopBy: '{{user}}에 의해 중지됨',
  467. },
  468. }
  469. export default translation