From a430284aa21e3ae1f0d5654e55b2ad2852519cc2 Mon Sep 17 00:00:00 2001
From: wwf <yearningwang@iqtogether.com>
Date: 星期三, 04 六月 2025 15:17:49 +0800
Subject: [PATCH] 初始化

---
 app/components/share/text-generation/run-once/index.tsx |  164 ++++++++++++++++++++++++------------------------------
 1 files changed, 74 insertions(+), 90 deletions(-)

diff --git a/app/components/share/text-generation/run-once/index.tsx b/app/components/share/text-generation/run-once/index.tsx
index 546b21d..f46713a 100644
--- a/app/components/share/text-generation/run-once/index.tsx
+++ b/app/components/share/text-generation/run-once/index.tsx
@@ -1,23 +1,19 @@
-import type { ChangeEvent, FC, FormEvent } from 'react'
-import { useEffect } from 'react'
+import type { FC, FormEvent } from 'react'
 import React, { useCallback } from 'react'
 import { useTranslation } from 'react-i18next'
 import {
-  RiPlayLargeLine,
-} from '@remixicon/react'
+  PlayIcon,
+} from '@heroicons/react/24/solid'
 import Select from '@/app/components/base/select'
 import type { SiteInfo } from '@/models/share'
 import type { PromptConfig } from '@/models/debug'
 import Button from '@/app/components/base/button'
 import Textarea from '@/app/components/base/textarea'
-import Input from '@/app/components/base/input'
 import { DEFAULT_VALUE_MAX_LEN } from '@/config'
 import TextGenerationImageUploader from '@/app/components/base/image-uploader/text-generation-image-uploader'
 import type { VisionFile, VisionSettings } from '@/types/app'
 import { FileUploaderInAttachmentWrapper } from '@/app/components/base/file-uploader'
 import { getProcessedFiles } from '@/app/components/base/file-uploader/utils'
-import useBreakpoints, { MediaType } from '@/hooks/use-breakpoints'
-import cn from '@/utils/classnames'
 
 export type IRunOnceProps = {
   siteInfo: SiteInfo
@@ -39,16 +35,11 @@
   onVisionFilesChange,
 }) => {
   const { t } = useTranslation()
-  const media = useBreakpoints()
-  const isPC = media === MediaType.pc
 
   const onClear = () => {
     const newInputs: Record<string, any> = {}
     promptConfig.prompt_variables.forEach((item) => {
-      if (item.type === 'string' || item.type === 'paragraph')
-        newInputs[item.key] = ''
-      else
-        newInputs[item.key] = undefined
+      newInputs[item.key] = ''
     })
     onInputsChange(newInputs)
   }
@@ -63,87 +54,78 @@
     inputsRef.current = newInputs
   }, [onInputsChange, inputsRef])
 
-  useEffect(() => {
-    const newInputs: Record<string, any> = {}
-    promptConfig.prompt_variables.forEach((item) => {
-      if (item.type === 'string' || item.type === 'paragraph')
-        newInputs[item.key] = ''
-      else
-        newInputs[item.key] = undefined
-    })
-    onInputsChange(newInputs)
-  }, [promptConfig.prompt_variables, onInputsChange])
-
   return (
     <div className="">
       <section>
         {/* input form */}
         <form onSubmit={onSubmit}>
-          {(inputs === null || inputs === undefined || Object.keys(inputs).length === 0) ? null
-            : promptConfig.prompt_variables.map(item => (
-              <div className='mt-4 w-full' key={item.key}>
-                <label className='system-md-semibold flex h-6 items-center text-text-secondary'>{item.name}</label>
-                <div className='mt-1'>
-                  {item.type === 'select' && (
-                    <Select
-                      className='w-full'
-                      defaultValue={inputs[item.key]}
-                      onSelect={(i) => { handleInputsChange({ ...inputsRef.current, [item.key]: i.value }) }}
-                      items={(item.options || []).map(i => ({ name: i, value: i }))}
-                      allowSearch={false}
-                    />
-                  )}
-                  {item.type === 'string' && (
-                    <Input
-                      type="text"
-                      placeholder={`${item.name}${!item.required ? `(${t('appDebug.variableTable.optional')})` : ''}`}
-                      value={inputs[item.key]}
-                      onChange={(e: ChangeEvent<HTMLInputElement>) => { handleInputsChange({ ...inputsRef.current, [item.key]: e.target.value }) }}
-                      maxLength={item.max_length || DEFAULT_VALUE_MAX_LEN}
-                    />
-                  )}
-                  {item.type === 'paragraph' && (
-                    <Textarea
-                      className='h-[104px] sm:text-xs'
-                      placeholder={`${item.name}${!item.required ? `(${t('appDebug.variableTable.optional')})` : ''}`}
-                      value={inputs[item.key]}
-                      onChange={(e: ChangeEvent<HTMLInputElement>) => { handleInputsChange({ ...inputsRef.current, [item.key]: e.target.value }) }}
-                    />
-                  )}
-                  {item.type === 'number' && (
-                    <Input
-                      type="number"
-                      placeholder={`${item.name}${!item.required ? `(${t('appDebug.variableTable.optional')})` : ''}`}
-                      value={inputs[item.key]}
-                      onChange={(e: ChangeEvent<HTMLInputElement>) => { handleInputsChange({ ...inputsRef.current, [item.key]: e.target.value }) }}
-                    />
-                  )}
-                  {item.type === 'file' && (
-                    <FileUploaderInAttachmentWrapper
-                      onChange={(files) => { handleInputsChange({ ...inputsRef.current, [item.key]: getProcessedFiles(files)[0] }) }}
-                      fileConfig={{
-                        ...item.config,
-                        fileUploadConfig: (visionConfig as any).fileUploadConfig,
-                      }}
-                    />
-                  )}
-                  {item.type === 'file-list' && (
-                    <FileUploaderInAttachmentWrapper
-                      onChange={(files) => { handleInputsChange({ ...inputsRef.current, [item.key]: getProcessedFiles(files) }) }}
-                      fileConfig={{
-                        ...item.config,
-                        fileUploadConfig: (visionConfig as any).fileUploadConfig,
-                      }}
-                    />
-                  )}
-                </div>
+          {promptConfig.prompt_variables.map(item => (
+            <div className='w-full mt-4' key={item.key}>
+              <label className='text-gray-900 text-sm font-medium'>{item.name}</label>
+              <div className='mt-2'>
+                {item.type === 'select' && (
+                  <Select
+                    className='w-full'
+                    defaultValue={inputs[item.key]}
+                    onSelect={(i) => { handleInputsChange({ ...inputsRef.current, [item.key]: i.value }) }}
+                    items={(item.options || []).map(i => ({ name: i, value: i }))}
+                    allowSearch={false}
+                    bgClassName='bg-gray-50'
+                  />
+                )}
+                {item.type === 'string' && (
+                  <input
+                    type="text"
+                    className="block w-full p-2 text-gray-900 border border-gray-300 rounded-lg bg-gray-50 sm:text-xs focus:ring-blue-500 focus:border-blue-500 "
+                    placeholder={`${item.name}${!item.required ? `(${t('appDebug.variableTable.optional')})` : ''}`}
+                    value={inputs[item.key]}
+                    onChange={(e) => { handleInputsChange({ ...inputsRef.current, [item.key]: e.target.value }) }}
+                    maxLength={item.max_length || DEFAULT_VALUE_MAX_LEN}
+                  />
+                )}
+                {item.type === 'paragraph' && (
+                  <Textarea
+                    className='h-[104px] sm:text-xs'
+                    placeholder={`${item.name}${!item.required ? `(${t('appDebug.variableTable.optional')})` : ''}`}
+                    value={inputs[item.key]}
+                    onChange={(e) => { handleInputsChange({ ...inputsRef.current, [item.key]: e.target.value }) }}
+                  />
+                )}
+                {item.type === 'number' && (
+                  <input
+                    type="number"
+                    className="block w-full p-2 text-gray-900 border border-gray-300 rounded-lg bg-gray-50 sm:text-xs focus:ring-blue-500 focus:border-blue-500 "
+                    placeholder={`${item.name}${!item.required ? `(${t('appDebug.variableTable.optional')})` : ''}`}
+                    value={inputs[item.key]}
+                    onChange={(e) => { handleInputsChange({ ...inputsRef.current, [item.key]: e.target.value }) }}
+                  />
+                )}
+                {item.type === 'file' && (
+                  <FileUploaderInAttachmentWrapper
+                    onChange={(files) => { handleInputsChange({ ...inputsRef.current, [item.key]: getProcessedFiles(files)[0] }) }}
+                    fileConfig={{
+                      ...item.config,
+                      fileUploadConfig: (visionConfig as any).fileUploadConfig,
+                    }}
+                  />
+                )}
+                {item.type === 'file-list' && (
+                  <FileUploaderInAttachmentWrapper
+                    onChange={(files) => { handleInputsChange({ ...inputsRef.current, [item.key]: getProcessedFiles(files) }) }}
+                    fileConfig={{
+                      ...item.config,
+                      fileUploadConfig: (visionConfig as any).fileUploadConfig,
+                    }}
+                  />
+                )}
               </div>
-            ))}
+            </div>
+          ))}
           {
             visionConfig?.enabled && (
-              <div className="mt-4 w-full">
-                <div className="system-md-semibold flex h-6 items-center text-text-secondary">{t('common.imageUploader.imageUpload')}</div>
-                <div className='mt-1'>
+              <div className="w-full mt-4">
+                <div className="text-gray-900 text-sm font-medium">{t('common.imageUploader.imageUpload')}</div>
+                <div className='mt-2'>
                   <TextGenerationImageUploader
                     settings={visionConfig}
                     onFilesChange={files => onVisionFilesChange(files.filter(file => file.progress !== -1).map(fileItem => ({
@@ -157,8 +139,11 @@
               </div>
             )
           }
-          <div className='mb-3 mt-6 w-full'>
-            <div className="flex items-center justify-between gap-2">
+          {promptConfig.prompt_variables.length > 0 && (
+            <div className='mt-4 h-[1px] bg-gray-100'></div>
+          )}
+          <div className='w-full mt-4'>
+            <div className="flex items-center justify-between">
               <Button
                 onClick={onClear}
                 disabled={false}
@@ -166,12 +151,11 @@
                 <span className='text-[13px]'>{t('common.operation.clear')}</span>
               </Button>
               <Button
-                className={cn(!isPC && 'grow')}
                 type='submit'
                 variant="primary"
                 disabled={false}
               >
-                <RiPlayLargeLine className="mr-1 h-4 w-4 shrink-0" aria-hidden="true" />
+                <PlayIcon className="shrink-0 w-4 h-4 mr-1" aria-hidden="true" />
                 <span className='text-[13px]'>{t('share.generation.run')}</span>
               </Button>
             </div>

--
Gitblit v1.8.0