|  | @@ -0,0 +1,137 @@
 | 
	
		
			
				|  |  | +import Button from '@/app/components/base/button'
 | 
	
		
			
				|  |  | +import Input from '@/app/components/base/input'
 | 
	
		
			
				|  |  | +import Textarea from '@/app/components/base/textarea'
 | 
	
		
			
				|  |  | +import { useChatContext } from '@/app/components/base/chat/chat/context'
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +enum DATA_FORMAT {
 | 
	
		
			
				|  |  | +  TEXT = 'text',
 | 
	
		
			
				|  |  | +  JSON = 'json',
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +enum SUPPORTED_TAGS {
 | 
	
		
			
				|  |  | +  LABEL = 'label',
 | 
	
		
			
				|  |  | +  INPUT = 'input',
 | 
	
		
			
				|  |  | +  TEXTAREA = 'textarea',
 | 
	
		
			
				|  |  | +  BUTTON = 'button',
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +enum SUPPORTED_TYPES {
 | 
	
		
			
				|  |  | +  TEXT = 'text',
 | 
	
		
			
				|  |  | +  PASSWORD = 'password',
 | 
	
		
			
				|  |  | +  EMAIL = 'email',
 | 
	
		
			
				|  |  | +  NUMBER = 'number',
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +const MarkdownForm = ({ node }: any) => {
 | 
	
		
			
				|  |  | +  // const supportedTypes = ['text', 'password', 'email', 'number']
 | 
	
		
			
				|  |  | +  //   <form data-format="text">
 | 
	
		
			
				|  |  | +  //      <label for="username">Username:</label>
 | 
	
		
			
				|  |  | +  //      <input type="text" name="username" />
 | 
	
		
			
				|  |  | +  //      <label for="password">Password:</label>
 | 
	
		
			
				|  |  | +  //      <input type="password" name="password" />
 | 
	
		
			
				|  |  | +  //      <label for="content">Content:</label>
 | 
	
		
			
				|  |  | +  //      <textarea name="content"></textarea>
 | 
	
		
			
				|  |  | +  //      <button data-size="small" data-variant="primary">Login</button>
 | 
	
		
			
				|  |  | +  //   </form>
 | 
	
		
			
				|  |  | +  const { onSend } = useChatContext()
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +  const getFormValues = (children: any) => {
 | 
	
		
			
				|  |  | +    const formValues: { [key: string]: any } = {}
 | 
	
		
			
				|  |  | +    children.forEach((child: any) => {
 | 
	
		
			
				|  |  | +      if (child.tagName === SUPPORTED_TAGS.INPUT)
 | 
	
		
			
				|  |  | +        formValues[child.properties.name] = child.properties.value
 | 
	
		
			
				|  |  | +      if (child.tagName === SUPPORTED_TAGS.TEXTAREA)
 | 
	
		
			
				|  |  | +        formValues[child.properties.name] = child.properties.value
 | 
	
		
			
				|  |  | +    })
 | 
	
		
			
				|  |  | +    return formValues
 | 
	
		
			
				|  |  | +  }
 | 
	
		
			
				|  |  | +  const onSubmit = (e: any) => {
 | 
	
		
			
				|  |  | +    e.preventDefault()
 | 
	
		
			
				|  |  | +    const format = node.properties.dataFormat || DATA_FORMAT.TEXT
 | 
	
		
			
				|  |  | +    const result = getFormValues(node.children)
 | 
	
		
			
				|  |  | +    if (format === DATA_FORMAT.JSON) {
 | 
	
		
			
				|  |  | +      onSend?.(JSON.stringify(result))
 | 
	
		
			
				|  |  | +    }
 | 
	
		
			
				|  |  | +    else {
 | 
	
		
			
				|  |  | +      const textResult = Object.entries(result)
 | 
	
		
			
				|  |  | +        .map(([key, value]) => `${key}: ${value}`)
 | 
	
		
			
				|  |  | +        .join('\n')
 | 
	
		
			
				|  |  | +      onSend?.(textResult)
 | 
	
		
			
				|  |  | +    }
 | 
	
		
			
				|  |  | +  }
 | 
	
		
			
				|  |  | +  return (
 | 
	
		
			
				|  |  | +    <form
 | 
	
		
			
				|  |  | +      autoComplete="off"
 | 
	
		
			
				|  |  | +      className='flex flex-col self-stretch'
 | 
	
		
			
				|  |  | +      onSubmit={(e: any) => {
 | 
	
		
			
				|  |  | +        e.preventDefault()
 | 
	
		
			
				|  |  | +        e.stopPropagation()
 | 
	
		
			
				|  |  | +      }}
 | 
	
		
			
				|  |  | +    >
 | 
	
		
			
				|  |  | +      {node.children.filter((i: any) => i.type === 'element').map((child: any, index: number) => {
 | 
	
		
			
				|  |  | +        if (child.tagName === SUPPORTED_TAGS.LABEL) {
 | 
	
		
			
				|  |  | +          return (
 | 
	
		
			
				|  |  | +            <label
 | 
	
		
			
				|  |  | +              key={index}
 | 
	
		
			
				|  |  | +              htmlFor={child.properties.for}
 | 
	
		
			
				|  |  | +              className="my-2 system-md-semibold text-text-secondary"
 | 
	
		
			
				|  |  | +            >
 | 
	
		
			
				|  |  | +              {child.children[0]?.value || ''}
 | 
	
		
			
				|  |  | +            </label>
 | 
	
		
			
				|  |  | +          )
 | 
	
		
			
				|  |  | +        }
 | 
	
		
			
				|  |  | +        if (child.tagName === SUPPORTED_TAGS.INPUT) {
 | 
	
		
			
				|  |  | +          if (Object.values(SUPPORTED_TYPES).includes(child.properties.type)) {
 | 
	
		
			
				|  |  | +            return (
 | 
	
		
			
				|  |  | +              <Input
 | 
	
		
			
				|  |  | +                key={index}
 | 
	
		
			
				|  |  | +                type={child.properties.type}
 | 
	
		
			
				|  |  | +                name={child.properties.name}
 | 
	
		
			
				|  |  | +                placeholder={child.properties.placeholder}
 | 
	
		
			
				|  |  | +                value={child.properties.value}
 | 
	
		
			
				|  |  | +                onChange={(e) => {
 | 
	
		
			
				|  |  | +                  e.preventDefault()
 | 
	
		
			
				|  |  | +                  child.properties.value = e.target.value
 | 
	
		
			
				|  |  | +                }}
 | 
	
		
			
				|  |  | +              />
 | 
	
		
			
				|  |  | +            )
 | 
	
		
			
				|  |  | +          }
 | 
	
		
			
				|  |  | +          else {
 | 
	
		
			
				|  |  | +            return <p key={index}>Unsupported input type: {child.properties.type}</p>
 | 
	
		
			
				|  |  | +          }
 | 
	
		
			
				|  |  | +        }
 | 
	
		
			
				|  |  | +        if (child.tagName === SUPPORTED_TAGS.TEXTAREA) {
 | 
	
		
			
				|  |  | +          return (
 | 
	
		
			
				|  |  | +            <Textarea
 | 
	
		
			
				|  |  | +              key={index}
 | 
	
		
			
				|  |  | +              name={child.properties.name}
 | 
	
		
			
				|  |  | +              placeholder={child.properties.placeholder}
 | 
	
		
			
				|  |  | +              value={child.properties.value}
 | 
	
		
			
				|  |  | +              onChange={(e) => {
 | 
	
		
			
				|  |  | +                e.preventDefault()
 | 
	
		
			
				|  |  | +                child.properties.value = e.target.value
 | 
	
		
			
				|  |  | +              }}
 | 
	
		
			
				|  |  | +            />
 | 
	
		
			
				|  |  | +          )
 | 
	
		
			
				|  |  | +        }
 | 
	
		
			
				|  |  | +        if (child.tagName === SUPPORTED_TAGS.BUTTON) {
 | 
	
		
			
				|  |  | +          const variant = child.properties.dataVariant
 | 
	
		
			
				|  |  | +          const size = child.properties.dataSize
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +          return (
 | 
	
		
			
				|  |  | +            <Button
 | 
	
		
			
				|  |  | +              variant={variant}
 | 
	
		
			
				|  |  | +              size={size}
 | 
	
		
			
				|  |  | +              className='mt-4'
 | 
	
		
			
				|  |  | +              key={index}
 | 
	
		
			
				|  |  | +              onClick={onSubmit}
 | 
	
		
			
				|  |  | +            >
 | 
	
		
			
				|  |  | +              <span className='text-[13px]'>{child.children[0]?.value || ''}</span>
 | 
	
		
			
				|  |  | +            </Button>
 | 
	
		
			
				|  |  | +          )
 | 
	
		
			
				|  |  | +        }
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        return <p key={index}>Unsupported tag: {child.tagName}</p>
 | 
	
		
			
				|  |  | +      })}
 | 
	
		
			
				|  |  | +    </form>
 | 
	
		
			
				|  |  | +  )
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +MarkdownForm.displayName = 'MarkdownForm'
 | 
	
		
			
				|  |  | +export default MarkdownForm
 |