Commit 6bf39c02 authored by StyleZhang's avatar StyleZhang

fix: some style

parent 76e0c93b
<svg width="84" height="24" viewBox="0 0 84 24" fill="none" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
<rect x="2" width="80.5714" height="24" fill="url(#pattern0)"/>
<defs>
<pattern id="pattern0" patternContentUnits="objectBoundingBox" width="1" height="1">
<use xlink:href="#image0_8587_60486" transform="scale(0.0070922 0.0238095)"/>
</pattern>
<image id="image0_8587_60486" width="141" height="42" xlink:href=""/>
</defs>
</svg>
<svg width="24" height="24" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
<rect y="2.06897" width="24" height="19.8621" fill="url(#pattern0)"/>
<defs>
<pattern id="pattern0" patternContentUnits="objectBoundingBox" width="1" height="1">
<use xlink:href="#image0_8587_60226" transform="scale(0.0197044 0.0238095)"/>
</pattern>
<image id="image0_8587_60226" width="141" height="42" xlink:href=""/>
</defs>
</svg>
<svg width="100" height="24" viewBox="0 0 100 24" fill="none" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
<rect x="1" y="1" width="97.57" height="22" fill="url(#pattern0)"/>
<defs>
<pattern id="pattern0" patternContentUnits="objectBoundingBox" width="1" height="1">
<use xlink:href="#image0_8587_60493" transform="scale(0.0011274 0.005)"/>
</pattern>
<image id="image0_8587_60493" width="887" height="200" xlink:href=""/>
</defs>
</svg>
<svg width="88" height="24" viewBox="0 0 88 24" fill="none" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
<rect x="1" y="1" width="22" height="22" fill="url(#pattern0)"/>
<path d="M31.4971 8.59302V6.81816H39.8593V8.59302H36.7421V17H34.6143V8.59302H31.4971Z" fill="#101828"/>
<path d="M50.1281 11.9091C50.1281 13.0194 49.9176 13.964 49.4967 14.7429C49.0791 15.5218 48.509 16.1167 47.7865 16.5277C47.0673 16.9353 46.2586 17.1392 45.3604 17.1392C44.4555 17.1392 43.6435 16.9337 42.9243 16.5227C42.205 16.1117 41.6366 15.5168 41.219 14.7379C40.8014 13.959 40.5926 13.0161 40.5926 11.9091C40.5926 10.7987 40.8014 9.85414 41.219 9.07526C41.6366 8.29638 42.205 7.7031 42.9243 7.29543C43.6435 6.88445 44.4555 6.67896 45.3604 6.67896C46.2586 6.67896 47.0673 6.88445 47.7865 7.29543C48.509 7.7031 49.0791 8.29638 49.4967 9.07526C49.9176 9.85414 50.1281 10.7987 50.1281 11.9091ZM47.9456 11.9091C47.9456 11.1898 47.8379 10.5833 47.6224 10.0895C47.4103 9.59562 47.1104 9.2211 46.7226 8.96589C46.3348 8.71068 45.8807 8.58307 45.3604 8.58307C44.84 8.58307 44.3859 8.71068 43.9981 8.96589C43.6104 9.2211 43.3087 9.59562 43.0933 10.0895C42.8812 10.5833 42.7751 11.1898 42.7751 11.9091C42.7751 12.6283 42.8812 13.2348 43.0933 13.7287C43.3087 14.2225 43.6104 14.597 43.9981 14.8523C44.3859 15.1075 44.84 15.2351 45.3604 15.2351C45.8807 15.2351 46.3348 15.1075 46.7226 14.8523C47.1104 14.597 47.4103 14.2225 47.6224 13.7287C47.8379 13.2348 47.9456 12.6283 47.9456 11.9091Z" fill="#101828"/>
<path d="M60.2391 6.81816V17H58.3797L53.95 10.5916H53.8754V17H51.7227V6.81816H53.6119L58.0068 13.2216H58.0963V6.81816H60.2391Z" fill="#101828"/>
<path d="M68.7691 10.1094C68.6995 9.8674 68.6017 9.65362 68.4758 9.46802C68.3498 9.2791 68.1957 9.12001 68.0134 8.99075C67.8344 8.85817 67.6289 8.75708 67.3969 8.68748C67.1682 8.61788 66.9147 8.58307 66.6363 8.58307C66.1159 8.58307 65.6585 8.71234 65.2641 8.97086C64.873 9.22938 64.5681 9.60557 64.3493 10.0994C64.1306 10.5899 64.0212 11.1898 64.0212 11.8991C64.0212 12.6084 64.1289 13.2116 64.3444 13.7088C64.5598 14.2059 64.8647 14.5854 65.2591 14.8473C65.6536 15.1058 66.1192 15.2351 66.6562 15.2351C67.1434 15.2351 67.5593 15.1489 67.904 14.9765C68.252 14.8009 68.5172 14.554 68.6995 14.2358C68.8851 13.9176 68.9779 13.5414 68.9779 13.1072L69.4154 13.1719H66.7904V11.5511H71.051V12.8338C71.051 13.7287 70.8621 14.4976 70.4843 15.1406C70.1064 15.7803 69.5861 16.2741 68.9232 16.6221C68.2603 16.9668 67.5013 17.1392 66.6462 17.1392C65.6917 17.1392 64.8531 16.9287 64.1306 16.5078C63.4081 16.0835 62.8446 15.482 62.4403 14.7031C62.0392 13.9209 61.8387 12.9929 61.8387 11.919C61.8387 11.0937 61.958 10.3579 62.1966 9.71163C62.4386 9.062 62.7767 8.51181 63.2108 8.06106C63.645 7.6103 64.1505 7.26726 64.7272 7.03194C65.3039 6.79662 65.9287 6.67896 66.6015 6.67896C67.1782 6.67896 67.7151 6.76347 68.2123 6.93251C68.7094 7.09823 69.1502 7.33355 69.5347 7.63847C69.9225 7.9434 70.239 8.30632 70.4843 8.72725C70.7296 9.14486 70.887 9.60556 70.9566 10.1094H68.7691Z" fill="#101828"/>
<path d="M71.6613 6.81816H74.0725L76.3943 11.2031H76.4937L78.8154 6.81816H81.2267L77.5129 13.4005V17H75.3751V13.4005L71.6613 6.81816Z" fill="#101828"/>
<path d="M84.5551 6.81816V17H82.4024V6.81816H84.5551Z" fill="#101828"/>
<defs>
<pattern id="pattern0" patternContentUnits="objectBoundingBox" width="1" height="1">
<use xlink:href="#image0_8587_60489" transform="scale(0.005)"/>
</pattern>
<image id="image0_8587_60489" width="887" height="200" xlink:href=""/>
</defs>
</svg>
<svg width="24" height="24" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
<rect x="1" y="1" width="22" height="22" fill="url(#pattern0)"/>
<defs>
<pattern id="pattern0" patternContentUnits="objectBoundingBox" width="1" height="1">
<use xlink:href="#image0_8587_60228" transform="scale(0.005)"/>
</pattern>
<image id="image0_8587_60228" width="887" height="200" xlink:href=""/>
</defs>
</svg>
<svg width="12" height="12" viewBox="0 0 12 12" fill="none" xmlns="http://www.w3.org/2000/svg">
<g id="Icon">
<g id="Icon_2">
<path d="M6 6.5C6.27614 6.5 6.5 6.27614 6.5 6C6.5 5.72386 6.27614 5.5 6 5.5C5.72386 5.5 5.5 5.72386 5.5 6C5.5 6.27614 5.72386 6.5 6 6.5Z" stroke="#344054" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/>
<path d="M9.5 6.5C9.77614 6.5 10 6.27614 10 6C10 5.72386 9.77614 5.5 9.5 5.5C9.22386 5.5 9 5.72386 9 6C9 6.27614 9.22386 6.5 9.5 6.5Z" stroke="#344054" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/>
<path d="M2.5 6.5C2.77614 6.5 3 6.27614 3 6C3 5.72386 2.77614 5.5 2.5 5.5C2.22386 5.5 2 5.72386 2 6C2 6.27614 2.22386 6.5 2.5 6.5Z" stroke="#344054" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/>
</g>
</g>
</svg>
<svg width="14" height="13" viewBox="0 0 14 13" fill="none" xmlns="http://www.w3.org/2000/svg">
<path id="Icon" d="M5.30246 4.74996C5.4396 4.3601 5.7103 4.03135 6.0666 3.82195C6.4229 3.61255 6.84181 3.53601 7.24915 3.60587C7.65648 3.67574 8.02594 3.88752 8.29209 4.20368C8.55824 4.51985 8.70391 4.92001 8.70329 5.33329C8.70329 6.49996 6.95329 7.08329 6.95329 7.08329M6.99996 9.41663H7.00579M12.8333 6.49996C12.8333 9.72162 10.2216 12.3333 6.99996 12.3333C3.7783 12.3333 1.16663 9.72162 1.16663 6.49996C1.16663 3.2783 3.7783 0.666626 6.99996 0.666626C10.2216 0.666626 12.8333 3.2783 12.8333 6.49996Z" stroke="#98A2B3" stroke-width="1.25" stroke-linecap="round" stroke-linejoin="round"/>
</svg>
<svg width="12" height="12" viewBox="0 0 12 12" fill="none" xmlns="http://www.w3.org/2000/svg">
<g id="info-circle" clip-path="url(#clip0_7880_62014)">
<path id="Icon" d="M6 8V6M6 4H6.005M11 6C11 8.76142 8.76142 11 6 11C3.23858 11 1 8.76142 1 6C1 3.23858 3.23858 1 6 1C8.76142 1 11 3.23858 11 6Z" stroke="#98A2B3" stroke-width="1.25" stroke-linecap="round" stroke-linejoin="round"/>
</g>
<defs>
<clipPath id="clip0_7880_62014">
<rect width="12" height="12" fill="white"/>
</clipPath>
</defs>
</svg>
......@@ -77,6 +77,54 @@ export { default as <%= svgName %> } from './<%= svgName %>'
await appendFile(path.resolve(currentPath, 'index.ts'), `${indexingRender({ svgName: fileName })}\n`)
}
const generateImageComponent = async (entry, pathList) => {
const currentPath = path.resolve(__dirname, 'src', ...pathList.slice(2))
try {
await access(currentPath)
}
catch {
await generateDir(currentPath)
}
const prefixFileName = camelCase(entry.split('.')[0])
const fileName = prefixFileName.charAt(0).toUpperCase() + prefixFileName.slice(1)
const componentCSSRender = template(`
.wrapper {
display: inline-flex;
background: url(<%= assetPath %>) center center no-repeat;
background-size: contain;
}
`.trim())
await writeFile(path.resolve(currentPath, `${fileName}.module.css`), `${componentCSSRender({ assetPath: path.join('~@/app/components/base/icons/assets', ...pathList.slice(2), entry) })}\n`)
const componentRender = template(`
// GENERATE BY script
// DON NOT EDIT IT MANUALLY
import * as React from 'react'
import cn from 'classnames'
import s from './<%= fileName %>.module.css'
const Icon = React.forwardRef<HTMLSpanElement, React.DetailedHTMLProps<React.HTMLAttributes<HTMLSpanElement>, HTMLSpanElement>>((
{ className, ...restProps },
ref,
) => <span className={cn(s.wrapper, className)} {...restProps} ref={ref} />)
export default Icon
`.trim())
await writeFile(path.resolve(currentPath, `${fileName}.tsx`), `${componentRender({ fileName })}\n`)
const indexingRender = template(`
export { default as <%= fileName %> } from './<%= fileName %>'
`.trim())
await appendFile(path.resolve(currentPath, 'index.ts'), `${indexingRender({ fileName })}\n`)
}
const walk = async (entry, pathList, replaceFillOrStrokeColor) => {
const currentPath = path.resolve(...pathList, entry)
let fileHandle
......@@ -94,6 +142,9 @@ const walk = async (entry, pathList, replaceFillOrStrokeColor) => {
if (stat.isFile() && /.+\.svg$/g.test(entry))
await generateSvgComponent(fileHandle, entry, pathList, replaceFillOrStrokeColor)
if (stat.isFile() && /.+\.png$/g.test(entry))
await generateImageComponent(entry, pathList)
}
finally {
fileHandle?.close()
......@@ -104,4 +155,5 @@ const walk = async (entry, pathList, replaceFillOrStrokeColor) => {
await rm(path.resolve(__dirname, 'src'), { recursive: true, force: true })
await walk('public', [__dirname, 'assets'])
await walk('vender', [__dirname, 'assets'], true)
await walk('image', [__dirname, 'assets'])
})()
.wrapper {
display: inline-flex;
background: url(~@/app/components/base/icons/assets/image/llm/minimax.png) center center no-repeat;
background-size: contain;
}
// GENERATE BY script
// DON NOT EDIT IT MANUALLY
import * as React from 'react'
import cn from 'classnames'
import s from './Minimax.module.css'
const Icon = React.forwardRef<HTMLSpanElement, React.DetailedHTMLProps<React.HTMLAttributes<HTMLSpanElement>, HTMLSpanElement>>((
{ className, ...restProps },
ref,
) => <span className={cn(s.wrapper, className)} {...restProps} ref={ref} />)
export default Icon
.wrapper {
display: inline-flex;
background: url(~@/app/components/base/icons/assets/image/llm/minimax-text.png) center center no-repeat;
background-size: contain;
}
// GENERATE BY script
// DON NOT EDIT IT MANUALLY
import * as React from 'react'
import cn from 'classnames'
import s from './MinimaxText.module.css'
const Icon = React.forwardRef<HTMLSpanElement, React.DetailedHTMLProps<React.HTMLAttributes<HTMLSpanElement>, HTMLSpanElement>>((
{ className, ...restProps },
ref,
) => <span className={cn(s.wrapper, className)} {...restProps} ref={ref} />)
export default Icon
.wrapper {
display: inline-flex;
background: url(~@/app/components/base/icons/assets/image/llm/tongyi.png) center center no-repeat;
background-size: contain;
}
// GENERATE BY script
// DON NOT EDIT IT MANUALLY
import * as React from 'react'
import cn from 'classnames'
import s from './Tongyi.module.css'
const Icon = React.forwardRef<HTMLSpanElement, React.DetailedHTMLProps<React.HTMLAttributes<HTMLSpanElement>, HTMLSpanElement>>((
{ className, ...restProps },
ref,
) => <span className={cn(s.wrapper, className)} {...restProps} ref={ref} />)
export default Icon
.wrapper {
display: inline-flex;
background: url(~@/app/components/base/icons/assets/image/llm/tongyi-text.png) center center no-repeat;
background-size: contain;
}
// GENERATE BY script
// DON NOT EDIT IT MANUALLY
import * as React from 'react'
import cn from 'classnames'
import s from './TongyiText.module.css'
const Icon = React.forwardRef<HTMLSpanElement, React.DetailedHTMLProps<React.HTMLAttributes<HTMLSpanElement>, HTMLSpanElement>>((
{ className, ...restProps },
ref,
) => <span className={cn(s.wrapper, className)} {...restProps} ref={ref} />)
export default Icon
.wrapper {
display: inline-flex;
background: url(~@/app/components/base/icons/assets/image/llm/tongyi-text-cn.png) center center no-repeat;
background-size: contain;
}
// GENERATE BY script
// DON NOT EDIT IT MANUALLY
import * as React from 'react'
import cn from 'classnames'
import s from './TongyiTextCn.module.css'
const Icon = React.forwardRef<HTMLSpanElement, React.DetailedHTMLProps<React.HTMLAttributes<HTMLSpanElement>, HTMLSpanElement>>((
{ className, ...restProps },
ref,
) => <span className={cn(s.wrapper, className)} {...restProps} ref={ref} />)
export default Icon
export { default as MinimaxText } from './MinimaxText'
export { default as Minimax } from './Minimax'
export { default as TongyiTextCn } from './TongyiTextCn'
export { default as TongyiText } from './TongyiText'
export { default as Tongyi } from './Tongyi'
{
"icon": {
"type": "element",
"isRootNode": true,
"name": "svg",
"attributes": {
"width": "24",
"height": "24",
"viewBox": "0 0 24 24",
"fill": "none",
"xmlns": "http://www.w3.org/2000/svg",
"xmlns:xlink": "http://www.w3.org/1999/xlink"
},
"children": [
{
"type": "element",
"name": "rect",
"attributes": {
"y": "2.06897",
"width": "24",
"height": "19.8621",
"fill": "url(#pattern0)"
},
"children": []
},
{
"type": "element",
"name": "defs",
"attributes": {},
"children": [
{
"type": "element",
"name": "pattern",
"attributes": {
"id": "pattern0",
"patternContentUnits": "objectBoundingBox",
"width": "1",
"height": "1"
},
"children": [
{
"type": "element",
"name": "use",
"attributes": {
"xlink:href": "#image0_8587_60226",
"transform": "scale(0.0197044 0.0238095)"
},
"children": []
}
]
},
{
"type": "element",
"name": "image",
"attributes": {
"id": "image0_8587_60226",
"width": "141",
"height": "42",
"xlink:href": ""
},
"children": []
}
]
}
]
},
"name": "Minimax"
}
\ No newline at end of file
{
"icon": {
"type": "element",
"isRootNode": true,
"name": "svg",
"attributes": {
"width": "84",
"height": "24",
"viewBox": "0 0 84 24",
"fill": "none",
"xmlns": "http://www.w3.org/2000/svg",
"xmlns:xlink": "http://www.w3.org/1999/xlink"
},
"children": [
{
"type": "element",
"name": "rect",
"attributes": {
"x": "2",
"width": "80.5714",
"height": "24",
"fill": "url(#pattern0)"
},
"children": []
},
{
"type": "element",
"name": "defs",
"attributes": {},
"children": [
{
"type": "element",
"name": "pattern",
"attributes": {
"id": "pattern0",
"patternContentUnits": "objectBoundingBox",
"width": "1",
"height": "1"
},
"children": [
{
"type": "element",
"name": "use",
"attributes": {
"xlink:href": "#image0_8587_60486",
"transform": "scale(0.0070922 0.0238095)"
},
"children": []
}
]
},
{
"type": "element",
"name": "image",
"attributes": {
"id": "image0_8587_60486",
"width": "141",
"height": "42",
"xlink:href": ""
},
"children": []
}
]
}
]
},
"name": "MinimaxText"
}
\ No newline at end of file
{
"icon": {
"type": "element",
"isRootNode": true,
"name": "svg",
"attributes": {
"width": "24",
"height": "24",
"viewBox": "0 0 24 24",
"fill": "none",
"xmlns": "http://www.w3.org/2000/svg",
"xmlns:xlink": "http://www.w3.org/1999/xlink"
},
"children": [
{
"type": "element",
"name": "rect",
"attributes": {
"x": "1",
"y": "1",
"width": "22",
"height": "22",
"fill": "url(#pattern0)"
},
"children": []
},
{
"type": "element",
"name": "defs",
"attributes": {},
"children": [
{
"type": "element",
"name": "pattern",
"attributes": {
"id": "pattern0",
"patternContentUnits": "objectBoundingBox",
"width": "1",
"height": "1"
},
"children": [
{
"type": "element",
"name": "use",
"attributes": {
"xlink:href": "#image0_8587_60228",
"transform": "scale(0.005)"
},
"children": []
}
]
},
{
"type": "element",
"name": "image",
"attributes": {
"id": "image0_8587_60228",
"width": "887",
"height": "200",
"xlink:href": ""
},
"children": []
}
]
}
]
},
"name": "Tongyi"
}
\ No newline at end of file
{
"icon": {
"type": "element",
"isRootNode": true,
"name": "svg",
"attributes": {
"width": "88",
"height": "24",
"viewBox": "0 0 88 24",
"fill": "none",
"xmlns": "http://www.w3.org/2000/svg",
"xmlns:xlink": "http://www.w3.org/1999/xlink"
},
"children": [
{
"type": "element",
"name": "rect",
"attributes": {
"x": "1",
"y": "1",
"width": "22",
"height": "22",
"fill": "url(#pattern0)"
},
"children": []
},
{
"type": "element",
"name": "path",
"attributes": {
"d": "M31.4971 8.59302V6.81816H39.8593V8.59302H36.7421V17H34.6143V8.59302H31.4971Z",
"fill": "#101828"
},
"children": []
},
{
"type": "element",
"name": "path",
"attributes": {
"d": "M50.1281 11.9091C50.1281 13.0194 49.9176 13.964 49.4967 14.7429C49.0791 15.5218 48.509 16.1167 47.7865 16.5277C47.0673 16.9353 46.2586 17.1392 45.3604 17.1392C44.4555 17.1392 43.6435 16.9337 42.9243 16.5227C42.205 16.1117 41.6366 15.5168 41.219 14.7379C40.8014 13.959 40.5926 13.0161 40.5926 11.9091C40.5926 10.7987 40.8014 9.85414 41.219 9.07526C41.6366 8.29638 42.205 7.7031 42.9243 7.29543C43.6435 6.88445 44.4555 6.67896 45.3604 6.67896C46.2586 6.67896 47.0673 6.88445 47.7865 7.29543C48.509 7.7031 49.0791 8.29638 49.4967 9.07526C49.9176 9.85414 50.1281 10.7987 50.1281 11.9091ZM47.9456 11.9091C47.9456 11.1898 47.8379 10.5833 47.6224 10.0895C47.4103 9.59562 47.1104 9.2211 46.7226 8.96589C46.3348 8.71068 45.8807 8.58307 45.3604 8.58307C44.84 8.58307 44.3859 8.71068 43.9981 8.96589C43.6104 9.2211 43.3087 9.59562 43.0933 10.0895C42.8812 10.5833 42.7751 11.1898 42.7751 11.9091C42.7751 12.6283 42.8812 13.2348 43.0933 13.7287C43.3087 14.2225 43.6104 14.597 43.9981 14.8523C44.3859 15.1075 44.84 15.2351 45.3604 15.2351C45.8807 15.2351 46.3348 15.1075 46.7226 14.8523C47.1104 14.597 47.4103 14.2225 47.6224 13.7287C47.8379 13.2348 47.9456 12.6283 47.9456 11.9091Z",
"fill": "#101828"
},
"children": []
},
{
"type": "element",
"name": "path",
"attributes": {
"d": "M60.2391 6.81816V17H58.3797L53.95 10.5916H53.8754V17H51.7227V6.81816H53.6119L58.0068 13.2216H58.0963V6.81816H60.2391Z",
"fill": "#101828"
},
"children": []
},
{
"type": "element",
"name": "path",
"attributes": {
"d": "M68.7691 10.1094C68.6995 9.8674 68.6017 9.65362 68.4758 9.46802C68.3498 9.2791 68.1957 9.12001 68.0134 8.99075C67.8344 8.85817 67.6289 8.75708 67.3969 8.68748C67.1682 8.61788 66.9147 8.58307 66.6363 8.58307C66.1159 8.58307 65.6585 8.71234 65.2641 8.97086C64.873 9.22938 64.5681 9.60557 64.3493 10.0994C64.1306 10.5899 64.0212 11.1898 64.0212 11.8991C64.0212 12.6084 64.1289 13.2116 64.3444 13.7088C64.5598 14.2059 64.8647 14.5854 65.2591 14.8473C65.6536 15.1058 66.1192 15.2351 66.6562 15.2351C67.1434 15.2351 67.5593 15.1489 67.904 14.9765C68.252 14.8009 68.5172 14.554 68.6995 14.2358C68.8851 13.9176 68.9779 13.5414 68.9779 13.1072L69.4154 13.1719H66.7904V11.5511H71.051V12.8338C71.051 13.7287 70.8621 14.4976 70.4843 15.1406C70.1064 15.7803 69.5861 16.2741 68.9232 16.6221C68.2603 16.9668 67.5013 17.1392 66.6462 17.1392C65.6917 17.1392 64.8531 16.9287 64.1306 16.5078C63.4081 16.0835 62.8446 15.482 62.4403 14.7031C62.0392 13.9209 61.8387 12.9929 61.8387 11.919C61.8387 11.0937 61.958 10.3579 62.1966 9.71163C62.4386 9.062 62.7767 8.51181 63.2108 8.06106C63.645 7.6103 64.1505 7.26726 64.7272 7.03194C65.3039 6.79662 65.9287 6.67896 66.6015 6.67896C67.1782 6.67896 67.7151 6.76347 68.2123 6.93251C68.7094 7.09823 69.1502 7.33355 69.5347 7.63847C69.9225 7.9434 70.239 8.30632 70.4843 8.72725C70.7296 9.14486 70.887 9.60556 70.9566 10.1094H68.7691Z",
"fill": "#101828"
},
"children": []
},
{
"type": "element",
"name": "path",
"attributes": {
"d": "M71.6613 6.81816H74.0725L76.3943 11.2031H76.4937L78.8154 6.81816H81.2267L77.5129 13.4005V17H75.3751V13.4005L71.6613 6.81816Z",
"fill": "#101828"
},
"children": []
},
{
"type": "element",
"name": "path",
"attributes": {
"d": "M84.5551 6.81816V17H82.4024V6.81816H84.5551Z",
"fill": "#101828"
},
"children": []
},
{
"type": "element",
"name": "defs",
"attributes": {},
"children": [
{
"type": "element",
"name": "pattern",
"attributes": {
"id": "pattern0",
"patternContentUnits": "objectBoundingBox",
"width": "1",
"height": "1"
},
"children": [
{
"type": "element",
"name": "use",
"attributes": {
"xlink:href": "#image0_8587_60489",
"transform": "scale(0.005)"
},
"children": []
}
]
},
{
"type": "element",
"name": "image",
"attributes": {
"id": "image0_8587_60489",
"width": "887",
"height": "200",
"xlink:href": ""
},
"children": []
}
]
}
]
},
"name": "TongyiText"
}
\ No newline at end of file
// GENERATE BY script
// DON NOT EDIT IT MANUALLY
import * as React from 'react'
import data from './TongyiText.json'
import IconBase from '@/app/components/base/icons/IconBase'
import type { IconBaseProps, IconData } from '@/app/components/base/icons/IconBase'
const Icon = React.forwardRef<React.MutableRefObject<SVGElement>, Omit<IconBaseProps, 'data'>>((
props,
ref,
) => <IconBase {...props} ref={ref} data={data as IconData} />)
export default Icon
{
"icon": {
"type": "element",
"isRootNode": true,
"name": "svg",
"attributes": {
"width": "100",
"height": "24",
"viewBox": "0 0 100 24",
"fill": "none",
"xmlns": "http://www.w3.org/2000/svg",
"xmlns:xlink": "http://www.w3.org/1999/xlink"
},
"children": [
{
"type": "element",
"name": "rect",
"attributes": {
"x": "1",
"y": "1",
"width": "97.57",
"height": "22",
"fill": "url(#pattern0)"
},
"children": []
},
{
"type": "element",
"name": "defs",
"attributes": {},
"children": [
{
"type": "element",
"name": "pattern",
"attributes": {
"id": "pattern0",
"patternContentUnits": "objectBoundingBox",
"width": "1",
"height": "1"
},
"children": [
{
"type": "element",
"name": "use",
"attributes": {
"xlink:href": "#image0_8587_60493",
"transform": "scale(0.0011274 0.005)"
},
"children": []
}
]
},
{
"type": "element",
"name": "image",
"attributes": {
"id": "image0_8587_60493",
"width": "887",
"height": "200",
"xlink:href": ""
},
"children": []
}
]
}
]
},
"name": "TongyiTextCn"
}
\ No newline at end of file
// GENERATE BY script
// DON NOT EDIT IT MANUALLY
import * as React from 'react'
import data from './TongyiTextCn.json'
import IconBase from '@/app/components/base/icons/IconBase'
import type { IconBaseProps, IconData } from '@/app/components/base/icons/IconBase'
const Icon = React.forwardRef<React.MutableRefObject<SVGElement>, Omit<IconBaseProps, 'data'>>((
props,
ref,
) => <IconBase {...props} ref={ref} data={data as IconData} />)
export default Icon
......@@ -15,8 +15,6 @@ export { default as IflytekSparkTextCn } from './IflytekSparkTextCn'
export { default as IflytekSparkText } from './IflytekSparkText'
export { default as IflytekSpark } from './IflytekSpark'
export { default as Microsoft } from './Microsoft'
export { default as MinimaxText } from './MinimaxText'
export { default as Minimax } from './Minimax'
export { default as OpenaiBlack } from './OpenaiBlack'
export { default as OpenaiBlue } from './OpenaiBlue'
export { default as OpenaiGreen } from './OpenaiGreen'
......@@ -25,9 +23,6 @@ export { default as OpenaiTransparent } from './OpenaiTransparent'
export { default as OpenaiViolet } from './OpenaiViolet'
export { default as ReplicateText } from './ReplicateText'
export { default as Replicate } from './Replicate'
export { default as TongyiTextCn } from './TongyiTextCn'
export { default as TongyiText } from './TongyiText'
export { default as Tongyi } from './Tongyi'
export { default as WxyyTextCn } from './WxyyTextCn'
export { default as WxyyText } from './WxyyText'
export { default as Wxyy } from './Wxyy'
{
"icon": {
"type": "element",
"isRootNode": true,
"name": "svg",
"attributes": {
"width": "12",
"height": "12",
"viewBox": "0 0 12 12",
"fill": "none",
"xmlns": "http://www.w3.org/2000/svg"
},
"children": [
{
"type": "element",
"name": "g",
"attributes": {
"id": "Icon"
},
"children": [
{
"type": "element",
"name": "g",
"attributes": {
"id": "Icon_2"
},
"children": [
{
"type": "element",
"name": "path",
"attributes": {
"d": "M6 6.5C6.27614 6.5 6.5 6.27614 6.5 6C6.5 5.72386 6.27614 5.5 6 5.5C5.72386 5.5 5.5 5.72386 5.5 6C5.5 6.27614 5.72386 6.5 6 6.5Z",
"stroke": "currentColor",
"stroke-width": "1.5",
"stroke-linecap": "round",
"stroke-linejoin": "round"
},
"children": []
},
{
"type": "element",
"name": "path",
"attributes": {
"d": "M9.5 6.5C9.77614 6.5 10 6.27614 10 6C10 5.72386 9.77614 5.5 9.5 5.5C9.22386 5.5 9 5.72386 9 6C9 6.27614 9.22386 6.5 9.5 6.5Z",
"stroke": "currentColor",
"stroke-width": "1.5",
"stroke-linecap": "round",
"stroke-linejoin": "round"
},
"children": []
},
{
"type": "element",
"name": "path",
"attributes": {
"d": "M2.5 6.5C2.77614 6.5 3 6.27614 3 6C3 5.72386 2.77614 5.5 2.5 5.5C2.22386 5.5 2 5.72386 2 6C2 6.27614 2.22386 6.5 2.5 6.5Z",
"stroke": "currentColor",
"stroke-width": "1.5",
"stroke-linecap": "round",
"stroke-linejoin": "round"
},
"children": []
}
]
}
]
}
]
},
"name": "DotsHorizontal"
}
\ No newline at end of file
......@@ -2,7 +2,7 @@
// DON NOT EDIT IT MANUALLY
import * as React from 'react'
import data from './MinimaxText.json'
import data from './DotsHorizontal.json'
import IconBase from '@/app/components/base/icons/IconBase'
import type { IconBaseProps, IconData } from '@/app/components/base/icons/IconBase'
......
{
"icon": {
"type": "element",
"isRootNode": true,
"name": "svg",
"attributes": {
"width": "14",
"height": "13",
"viewBox": "0 0 14 13",
"fill": "none",
"xmlns": "http://www.w3.org/2000/svg"
},
"children": [
{
"type": "element",
"name": "path",
"attributes": {
"id": "Icon",
"d": "M5.30246 4.74996C5.4396 4.3601 5.7103 4.03135 6.0666 3.82195C6.4229 3.61255 6.84181 3.53601 7.24915 3.60587C7.65648 3.67574 8.02594 3.88752 8.29209 4.20368C8.55824 4.51985 8.70391 4.92001 8.70329 5.33329C8.70329 6.49996 6.95329 7.08329 6.95329 7.08329M6.99996 9.41663H7.00579M12.8333 6.49996C12.8333 9.72162 10.2216 12.3333 6.99996 12.3333C3.7783 12.3333 1.16663 9.72162 1.16663 6.49996C1.16663 3.2783 3.7783 0.666626 6.99996 0.666626C10.2216 0.666626 12.8333 3.2783 12.8333 6.49996Z",
"stroke": "currentColor",
"stroke-width": "1.25",
"stroke-linecap": "round",
"stroke-linejoin": "round"
},
"children": []
}
]
},
"name": "HelpCircle"
}
\ No newline at end of file
......@@ -2,7 +2,7 @@
// DON NOT EDIT IT MANUALLY
import * as React from 'react'
import data from './Minimax.json'
import data from './HelpCircle.json'
import IconBase from '@/app/components/base/icons/IconBase'
import type { IconBaseProps, IconData } from '@/app/components/base/icons/IconBase'
......
{
"icon": {
"type": "element",
"isRootNode": true,
"name": "svg",
"attributes": {
"width": "12",
"height": "12",
"viewBox": "0 0 12 12",
"fill": "none",
"xmlns": "http://www.w3.org/2000/svg"
},
"children": [
{
"type": "element",
"name": "g",
"attributes": {
"id": "info-circle",
"clip-path": "url(#clip0_7880_62014)"
},
"children": [
{
"type": "element",
"name": "path",
"attributes": {
"id": "Icon",
"d": "M6 8V6M6 4H6.005M11 6C11 8.76142 8.76142 11 6 11C3.23858 11 1 8.76142 1 6C1 3.23858 3.23858 1 6 1C8.76142 1 11 3.23858 11 6Z",
"stroke": "currentColor",
"stroke-width": "1.25",
"stroke-linecap": "round",
"stroke-linejoin": "round"
},
"children": []
}
]
},
{
"type": "element",
"name": "defs",
"attributes": {},
"children": [
{
"type": "element",
"name": "clipPath",
"attributes": {
"id": "clip0_7880_62014"
},
"children": [
{
"type": "element",
"name": "rect",
"attributes": {
"width": "12",
"height": "12",
"fill": "white"
},
"children": []
}
]
}
]
}
]
},
"name": "InfoCircle"
}
\ No newline at end of file
......@@ -2,7 +2,7 @@
// DON NOT EDIT IT MANUALLY
import * as React from 'react'
import data from './Tongyi.json'
import data from './InfoCircle.json'
import IconBase from '@/app/components/base/icons/IconBase'
import type { IconBaseProps, IconData } from '@/app/components/base/icons/IconBase'
......
export { default as Check } from './Check'
export { default as DotsHorizontal } from './DotsHorizontal'
export { default as Edit03 } from './Edit03'
export { default as Hash02 } from './Hash02'
export { default as HelpCircle } from './HelpCircle'
export { default as InfoCircle } from './InfoCircle'
export { default as LinkExternal02 } from './LinkExternal02'
export { default as Loading02 } from './Loading02'
export { default as LogOut01 } from './LogOut01'
......
......@@ -22,6 +22,18 @@ export function normalizeAttrs(attrs: Attrs = {}): Attrs {
acc.className = val
delete acc.class
break
case 'style':
(acc.style as any) = val.split(';').reduce((prev, next) => {
const pairs = next?.split(':')
if (pairs[0] && pairs[1]) {
const k = pairs[0].replace(/([-]\w)/g, (g: string) => g[1].toUpperCase())
prev[k] = pairs[1]
}
return prev
}, {} as Attrs)
break
default:
acc[key] = val
}
......
export default {
type: 'provider',
title: {
'en-US': 'Anthropic',
'zh-Hans': 'Anthropic',
},
link: {
href: 'https://docs.dify.ai',
label: {
'en-US': 'Get your API key from Anthropic',
'zh-Hans': '从 Anthropic 获取 API Key',
},
},
fields: [
{
type: 'text',
key: 'anthropic_api_key',
is_required: true,
toggle_enabled: false,
is_obfuscated: true,
label: {
'en-US': 'API Key',
'zh-Hans': 'API Key',
},
place_holder: {
'en-US': 'Enter your API key here',
'zh-Hans': '在此输入您的 API Key',
},
},
{
type: 'text',
key: 'anthropic_api_url',
is_required: false,
toggle_enabled: true,
label: {
'en-US': 'Custom API Domain',
'zh-Hans': '自定义 API 域名',
},
place_holder: {
'en-US': 'Enter your API domain, eg: https://example.com/xxx',
'zh-Hans': '在此输入您的 API 域名,如:https://example.com/xxx',
},
help: {
'en-US': 'Configurable custom Anthropic API server url.',
'zh-Hans': '可配置自定义 Anthropic API 服务器地址。',
},
},
],
}
import anthropicConfig from './anthropic.config'
import openaiConfig from './openai.config'
export default {
anthropic: anthropicConfig,
openai: openaiConfig,
}
export default {
type: 'provider',
title: {
'en-US': 'OpenAI',
'zh-Hans': 'OpenAI',
},
link: {
href: 'https://docs.dify.ai',
label: {
'en-US': 'Get your API key from OpenAI',
'zh-Hans': '从 OpenAI 获取 API Key',
},
},
fields: [
{
type: 'text',
key: 'openai_api_key',
is_required: true,
toggle_enabled: false,
is_obfuscated: true,
label: {
'en-US': 'API Key',
'zh-Hans': 'API Key',
},
place_holder: {
'en-US': 'Enter your API key here',
'zh-Hans': '在此输入您的 API Key',
},
},
{
type: 'text',
key: 'openai_api_base',
is_required: false,
toggle_enabled: true,
label: {
'en-US': 'Custom API Domain',
'zh-Hans': '自定义 API 域名',
},
place_holder: {
'en-US': 'Enter your API domain, eg: https://example.com/xxx',
'zh-Hans': '在此输入您的 API 域名,如:https://example.com/xxx',
},
help: {
'en-US': 'You can configure your server compatible with the OpenAI API specification, or proxy mirror address',
'zh-Hans': '可配置您的兼容 OpenAI API 规范的服务器,或者代理镜像地址',
},
},
{
type: 'text',
key: 'openai_organization',
is_required: false,
toggle_enabled: true,
label: {
'en-US': 'Organization ID',
'zh-Hans': '组织 ID',
},
place_holder: {
'en-US': 'Enter your Organization ID, eg: org-xxxxxxxxxxxxxxxx',
'zh-Hans': '在此输入您的组织 ID,如:org-xxxxxxxxxxxxxxxx',
},
},
],
}
......@@ -5,34 +5,58 @@ import ModelCard from './model-card'
import ModelItem from './model-item'
import ModelModal from './model-modal'
import { ChevronDownDouble } from '@/app/components/base/icons/src/vender/line/arrows'
import { HelpCircle } from '@/app/components/base/icons/src/vender/line/general'
import {
AzureOpenaiServiceText,
ChatglmText,
HuggingfaceText,
ReplicateText,
} from '@/app/components/base/icons/src/public/llm'
import {
MinimaxText,
TongyiText,
} from '@/app/components/base/icons/src/image/llm'
const MODEL_LIST = [
{
key: 'azure_openai',
type: 'add',
icon: <AzureOpenaiServiceText className='h-6' />,
},
{
key: 'replicate',
type: 'add',
icon: <ReplicateText className='h-6' />,
},
{
key: 'huggingface_hub',
type: 'add',
icon: <HuggingfaceText className='h-6' />,
},
{
key: 'tongyi',
type: 'setup',
icon: <TongyiText className='w-[88px] h-6' />,
},
{
key: 'minimax',
type: 'setup',
icon: <MinimaxText className='w-[84px] h-6' />,
},
{
key: 'chatglm',
type: 'setup',
icon: <ChatglmText className='h-6' />,
},
]
const titleClassName = `
flex items-center h-9 text-sm font-medium text-gray-900
`
const tipClassName = `
ml-0.5 w-[14px] h-[14px] text-gray-400
`
const ModelPage = () => {
const { t } = useTranslation()
const [showMoreModel, setShowMoreModel] = useState(false)
......@@ -40,28 +64,46 @@ const ModelPage = () => {
return (
<div className='pt-1'>
<div className='grid grid-cols-2 gap-4 mb-4'>
<div className='grid grid-cols-3 gap-4 mb-5'>
<div className='w-full'>
<div className='py-2 text-sm font-medium text-gray-900'>
<div className={titleClassName}>
{t('common.modelProvider.systemReasoningModel.key')}
<HelpCircle className={tipClassName} />
</div>
<div>
<ModelSelector />
</div>
</div>
<div className='w-full'>
<div className={titleClassName}>
{t('common.modelProvider.embeddingModel.key')}
<HelpCircle className={tipClassName} />
</div>
<div>
<ModelSelector />
</div>
</div>
<div className='w-full'>
<div className={titleClassName}>
{t('common.modelProvider.speechToTextModel.key')}
<HelpCircle className={tipClassName} />
</div>
<div>
<ModelSelector />
</div>
</div>
</div>
<div className='mb-4 h-[0.5px] bg-gray-100' />
<div className='mb-5 h-[0.5px] bg-gray-100' />
<div className='mb-3 text-sm font-medium text-gray-800'>{t('common.modelProvider.models')}</div>
<div className='grid grid-cols-2 gap-4 mb-6'>
<ModelCard />
<ModelCard type='anthropic' />
<ModelCard onOpenModal={() => {}} />
<ModelCard onOpenModal={() => {}} type='anthropic' />
</div>
{
MODEL_LIST.slice(0, showMoreModel ? MODEL_LIST.length : 3).map(model => (
<ModelItem
key={model.key}
provider={model.key}
type={model.type}
provider={model}
onOperate={() => setModelModalShow(true)}
/>
))
......
import { Fragment } from 'react'
import { Popover, Transition } from '@headlessui/react'
import { useTranslation } from 'react-i18next'
import { Check, DotsHorizontal, Trash03 } from '@/app/components/base/icons/src/vender/line/general'
const itemClassName = `
flex items-center px-3 h-9 text-sm text-gray-700 rounded-lg cursor-pointer
`
const PrioritySelector = () => {
const { t } = useTranslation()
return (
<Popover className='relative'>
<Popover.Button>
{
({ open }) => (
<div className={`
flex justify-center items-center w-6 h-6 rounded-md hover:bg-gray-50 cursor-pointer
${open && 'bg-gray-50'}
`}>
<DotsHorizontal className='w-3 h-3 text-gray-700' />
</div>
)
}
</Popover.Button>
<Transition
as={Fragment}
leave='transition ease-in duration-100'
leaveFrom='opacity-100'
leaveTo='opacity-0'
>
<Popover.Panel className='absolute top-7 right-0 w-[192px] bg-white border-[0.5px] border-gray-200 rounded-lg shadow-lg z-10'>
<div className='p-1'>
<div className='px-3 pt-2 pb-1 text-sm font-medium text-gray-700'>{t('common.modelProvider.card.priorityUse')}</div>
<Popover.Button as={Fragment}>
<div className={`${itemClassName} hover:bg-gray-50`}>
<div className='grow'>API</div>
</div>
</Popover.Button>
<Popover.Button as={Fragment}>
<div className={`${itemClassName} hover:bg-gray-50`}>
<div className='grow'>{t('common.modelProvider.quota')}</div>
<Check className='w-4 h-4 text-primary-600' />
</div>
</Popover.Button>
</div>
<div className='h-[1px] bg-gray-100' />
<div className='p-1'>
<Popover.Button as={Fragment}>
<div className={`group ${itemClassName} hover:bg-[#FEF3F2] hover:text-[#D92D20]`}>
<Trash03 className='mr-2 w-4 h-4 text-gray-500 group-hover:text-[#D92D20]' />
{t('common.modelProvider.card.removeKey')}
</div>
</Popover.Button>
</div>
</Popover.Panel>
</Transition>
</Popover>
)
}
export default PrioritySelector
.card {
box-shadow: 0px 1px 2px 0px rgba(16, 24, 40, 0.05);
}
\ No newline at end of file
import type { FC } from 'react'
import { useTranslation } from 'react-i18next'
import cn from 'classnames'
import s from './index.module.css'
import Indicator from '../../../indicator'
import PrioritySelector from './PrioritySelector'
import { IS_CE_EDITION } from '@/config'
import Button from '@/app/components/base/button'
import { Plus } from '@/app/components/base/icons/src/vender/line/general'
import { InfoCircle, Plus } from '@/app/components/base/icons/src/vender/line/general'
import { Anthropic, AnthropicText, OpenaiBlack, OpenaiText } from '@/app/components/base/icons/src/public/llm'
const PROVIDER_MAP = {
openai: {
bgColor: 'bg-gray-200',
title: <OpenaiText className='h-5' />,
desc: <OpenaiBlack className='w-6 h-6' />,
},
anthropic: {
bgColor: 'bg-[#F0F0EB]',
title: <AnthropicText className='h-5' />,
desc: <Anthropic className='w-6 h-6' />,
},
}
type ModelCardProps = {
type?: 'openai' | 'anthropic'
onOpenModal: () => void
}
const ModelCard: FC<ModelCardProps> = ({
type = 'openai',
onOpenModal,
}) => {
const { t } = useTranslation()
return (
<div className={cn(
s.card,
'rounded-xl border-[0.5px] border-gray-200',
)}>
<div className='flex px-4 pt-4 pb-3 bg-gray-200 rounded-t-lg'>
<div className='rounded-xl border-[0.5px] border-gray-200 shadow-xs'>
<div className={`flex px-4 pt-4 pb-3 rounded-t-lg ${PROVIDER_MAP[type].bgColor}`}>
<div className='mr-3'>
<div className='mb-1'></div>
<div className='mb-1'>
{PROVIDER_MAP[type].title}
</div>
<div className='text-xs text-black opacity-60'>{t(`common.modelProvider.card.${type}.desc`)}</div>
</div>
<div className='w-6 h-6' />
{PROVIDER_MAP[type].desc}
</div>
{
!IS_CE_EDITION && (
<div className='flex justify-between px-4 py-3 border-b-[0.5px] border-b-[rgba(0, 0, 0, 0.5)]'>
<div>
<div className='flex items-center mb-1 h-5'>
<div className='mr-1 text-xs font-medium text-gray-500'>{t('common.modelProvider.card.quota')}</div>
<div className='px-1.5 bg-primary-50 rounded-md text-xs font-semibold text-primary-600'>{t('common.modelProvider.card.onTrial')}</div>
</div>
<div className='flex items-center'>
<div className='mr-1 text-sm font-medium text-gray-700'>200</div>
<div className='mr-1 text-sm text-gray-700'>{t('common.modelProvider.card.callTimes')}</div>
<div className='flex items-center text-gray-700'>
<div className='mr-1 text-sm font-medium'>200</div>
<div className='mr-1 text-sm'>{t('common.modelProvider.card.callTimes')}</div>
<InfoCircle className='w-3 h-3 text-gray-400 hover:text-gray-700' />
</div>
</div>
<Button className='mt-1.5 !px-3 !h-8 !text-[13px] font-medium rounded-lg' type='primary'>{t('common.modelProvider.card.buyQuota')}</Button>
</div>
)
}
<div
className='inline-flex items-center px-4 h-12 text-gray-500 cursor-pointer hover:text-primary-600'
onClick={onOpenModal}
>
<Plus className='mr-1.5 w-4 h-4'/>
<div className='text-xs font-medium'>{t('common.modelProvider.addApiKey')}</div>
</div>
<div className='flex items-center px-4 h-12'>
<Plus className='mr-1.5 w-4 h-4 text-gray-500' />
<div className='text-xs font-medium text-gray-500'>{t('common.modelProvider.addApiKey')}</div>
<Indicator color='green' className='mr-2' />
<div className='grow text-[13px] font-medium text-gray-700'>API key</div>
<div className='mr-1 px-2 leading-6 rounded-md text-xs font-medium text-gray-500 hover:bg-gray-50 cursor-pointer'>{t('common.operation.edit')}</div>
<PrioritySelector />
</div>
</div>
)
......
import { Fragment } from 'react'
import { Popover, Transition } from '@headlessui/react'
import { useTranslation } from 'react-i18next'
import { DotsHorizontal, Trash03 } from '@/app/components/base/icons/src/vender/line/general'
const itemClassName = `
flex items-center px-3 h-9 text-sm text-gray-700 rounded-lg cursor-pointer
`
const Operation = () => {
const { t } = useTranslation()
return (
<Popover className='relative'>
<Popover.Button>
{
({ open }) => (
<div className={`
flex justify-center items-center w-7 h-7 bg-white rounded-md border-[0.5px] border-gray-200 shadow-xs cursor-pointer
${open && 'bg-gray-100 shadow-none'}
`}>
<DotsHorizontal className='w-4 h-4 text-gray-700' />
</div>
)
}
</Popover.Button>
<Transition
as={Fragment}
leave='transition ease-in duration-100'
leaveFrom='opacity-100'
leaveTo='opacity-0'
>
<Popover.Panel className='absolute top-8 right-0 w-[144px] bg-white border-[0.5px] border-gray-200 rounded-lg shadow-lg z-10'>
<div className='p-1'>
<Popover.Button as={Fragment}>
<div className={`group ${itemClassName} hover:bg-[#FEF3F2] hover:text-[#D92D20]`}>
<Trash03 className='mr-2 w-4 h-4 text-gray-500 group-hover:text-[#D92D20]' />
{t('common.operation.remove')}
</div>
</Popover.Button>
</div>
</Popover.Panel>
</Transition>
</Popover>
)
}
export default Operation
import type { FC } from 'react'
import { useTranslation } from 'react-i18next'
import Indicator from '../../../indicator'
import Operation from './Operation'
import Button from '@/app/components/base/button'
import {
AzureOpenaiServiceText,
ChatglmText,
HuggingfaceText,
MinimaxText,
ReplicateText,
TongyiText,
} from '@/app/components/base/icons/src/public/llm'
const ICON_MAP = {
azure_openai: <AzureOpenaiServiceText />,
replicate: <ReplicateText />,
huggingface_hub: <HuggingfaceText />,
tongyi: <TongyiText />,
minimax: <MinimaxText />,
chatglm: <ChatglmText />,
}
type ModelItemProps = {
type: string
provider: string
provider: { key: string; type: string; icon: any }
onOperate: () => void
}
const ModelItem: FC<ModelItemProps> = ({
type,
provider,
onOperate,
}) => {
......@@ -34,13 +17,23 @@ const ModelItem: FC<ModelItemProps> = ({
return (
<div className='flex justify-between items-center mb-2 px-4 h-14 bg-gray-50 rounded-xl'>
<div />
{provider.icon}
<Button
className='!px-3 !h-7 rounded-md bg-white !text-xs font-medium text-gray-700'
onClick={onOperate}
>
{t(`common.operation.${type}`)}
{t(`common.operation.${provider.type}`)}
</Button>
<div className='flex items-center'>
<Indicator className='mr-3' />
<Button
className='mr-1 !px-3 !h-7 rounded-md bg-white !text-xs font-medium text-gray-700'
onClick={onOperate}
>
{t('common.operation.edit')}
</Button>
<Operation />
</div>
</div>
)
}
......
.options {
box-shadow: 0px 4px 6px 0px rgba(0, 0, 0, 0.05), 0px 10px 15px -3px rgba(0, 0, 0, 0.10)
}
\ No newline at end of file
import { Fragment, useState } from 'react'
import { Popover, Transition } from '@headlessui/react'
import { useTranslation } from 'react-i18next'
import cn from 'classnames'
import s from './index.module.css'
import { ChevronDown } from '@/app/components/base/icons/src/vender/line/arrows'
import { Check, SearchLg } from '@/app/components/base/icons/src/vender/line/general'
import { XCircle } from '@/app/components/base/icons/src/vender/solid/general'
import { Anthropic, Gpt3, Gpt4 } from '@/app/components/base/icons/src/public/llm'
const iconClassName = 'mr-2 w-4 h-4'
import {
Anthropic,
Chatglm,
Huggingface,
OpenaiGreen,
OpenaiViolet,
Replicate,
} from '@/app/components/base/icons/src/public/llm'
import {
Minimax,
Tongyi,
} from '@/app/components/base/icons/src/image/llm'
const models = [
{ type: 'provider', name: 'OpenAI' },
{ type: 'model', name: 'GPT-3.5-Turbo-16K', value: 'GPT-3.5-Turbo-16K', icon: <Gpt3 className={iconClassName} />, i: 'Gpt3' },
{ type: 'model', name: 'GPT-4', value: 'GPT-4', icon: <Gpt4 className={iconClassName} />, i: 'Gpt4' },
{ type: 'model', name: 'GPT-3.5-Turbo-16K', value: 'GPT-3.5-Turbo-16K', icon: OpenaiGreen },
{ type: 'model', name: 'GPT-4', value: 'GPT-4', icon: OpenaiViolet },
{ type: 'provider', name: 'Anthropic' },
{ type: 'model', name: 'Claude-2', value: 'Claude-2', icon: <Anthropic className={iconClassName} />, i: 'Anthropic' },
{ type: 'model', name: 'Claude-Instant', value: 'Claude-Instant', icon: <Anthropic className={iconClassName} />, i: 'Anthropic' },
{ type: 'model', name: 'Claude-2', value: 'Claude-2', icon: Anthropic },
{ type: 'model', name: 'Claude-Instant', value: 'Claude-Instant', icon: Anthropic },
{ type: 'provider', name: 'Replicate' },
{ type: 'model', name: 'xxx/xxx-chat', value: 'xxx/xxx-chat', icon: Replicate },
{ type: 'provider', name: 'Hugging Face' },
{ type: 'model', name: 'xxx-chat', value: 'xxx-chat', icon: Huggingface },
{ type: 'provider', name: 'TONGYI QIANWEN' },
{ type: 'model', name: 'TONGYI-GPT', value: 'TONGYI-GPT', icon: Tongyi },
{ type: 'provider', name: 'ChatGLM' },
{ type: 'model', name: 'ChatGLM-3', value: 'ChatGLM-3', icon: Chatglm },
{ type: 'provider', name: 'MINIMAX' },
{ type: 'model', name: 'MINIMAX-GPT', value: 'MINIMAX-GPT', icon: Minimax },
]
const ModelSelector = () => {
const { t } = useTranslation()
const [selected, setSelected] = useState('Claude-2')
const [selected, setSelected] = useState<{ type: string; name: string; value?: string; icon?: any }>()
const [search, setSearch] = useState('')
return (
......@@ -31,8 +48,18 @@ const ModelSelector = () => {
{
({ open }) => (
<>
<div className='mr-1.5 w-5 h-5' />
<div className='mr-1.5 grow text-left text-sm text-gray-900'>{selected}</div>
{
selected
? (
<>
<selected.icon className='mr-1.5 w-5 h-5' />
<div className='mr-1.5 grow text-left text-sm text-gray-900'>{selected?.name}</div>
</>
)
: (
<div className='grow text-left text-sm text-gray-800 opacity-60'>{t('common.modelProvider.selectModel')}</div>
)
}
<ChevronDown className={`w-4 h-4 text-gray-700 ${open ? 'opacity-100' : 'opacity-60'}`} />
</>
)
......@@ -44,10 +71,7 @@ const ModelSelector = () => {
leaveFrom='opacity-100'
leaveTo='opacity-0'
>
<Popover.Panel className={cn(
s.options,
'absolute top-10 p-1 w-full max-h-[366px] bg-white border-[0.5px] border-gray-200 rounded-lg overflow-auto z-10',
)}>
<Popover.Panel className='absolute top-10 p-1 w-full max-h-[366px] bg-white border-[0.5px] border-gray-200 rounded-lg shadow-lg overflow-auto z-10'>
<div className='px-2 pt-2 pb-1'>
<div className='flex items-center px-2 h-8 bg-gray-100 rounded-lg'>
<div className='mr-1.5 p-[1px]'><SearchLg className='w-[14px] h-[14px] text-gray-400' /></div>
......@@ -85,6 +109,7 @@ const ModelSelector = () => {
}
if (model.type === 'model') {
const Icon: any = model.icon
return (
<Popover.Button
key={`${model.type}-${model.name}`}
......@@ -92,8 +117,9 @@ const ModelSelector = () => {
flex items-center px-3 w-full h-8 rounded-lg cursor-pointer hover:bg-gray-50
${selected === model.value && 'bg-gray-50'}
`}
onClick={() => setSelected(model)}
>
{model.icon}
<Icon className='mr-2 w-4 h-4' />
<div className='grow text-left text-sm text-gray-900'>{model.name}</div>
{ selected === model.value && <Check className='w-4 h-4 text-primary-600' /> }
</Popover.Button>
......@@ -103,6 +129,7 @@ const ModelSelector = () => {
return null
})
}
<div className='px-3 pt-1.5 h-[30px] text-center text-xs text-gray-500'>{t('common.modelProvider.noModelFound')}</div>
</Popover.Panel>
</Transition>
</Popover>
......
......@@ -204,6 +204,8 @@ const translation = {
},
},
modelProvider: {
selectModel: 'Select your model',
setupModelFirst: 'Please set up your model first',
systemReasoningModel: {
key: 'System Reasoning Model',
tip: 'System Reasoning Model',
......@@ -212,6 +214,11 @@ const translation = {
key: 'Embedding Model',
tip: 'Embedding Model',
},
speechToTextModel: {
key: 'Speech-to-Text Model',
tip: 'Speech-to-Text Model',
},
quota: 'Quota',
searchModel: 'Search model',
noModelFound: 'No model found for {{model}}',
models: 'Models',
......@@ -229,6 +236,8 @@ const translation = {
callTimes: 'Call times',
tokens: 'Tokens',
buyQuota: 'Buy Quota',
priorityUse: 'Priority use',
removeKey: 'Remove API Key',
},
addApiKey: 'Add your API key',
invalidApiKey: 'Invalid API key',
......
......@@ -204,6 +204,8 @@ const translation = {
},
},
modelProvider: {
selectModel: 'Select your model',
setupModelFirst: 'Please set up your model first',
systemReasoningModel: {
key: 'System Reasoning Model',
tip: 'System Reasoning Model',
......@@ -212,6 +214,7 @@ const translation = {
key: 'Embedding Model',
tip: 'Embedding Model',
},
quota: 'Quota',
searchModel: 'Search model',
noModelFound: 'No model found for {{model}}',
models: 'Models',
......@@ -229,6 +232,8 @@ const translation = {
callTimes: 'Call times',
tokens: 'Tokens',
buyQuota: 'Buy Quota',
priorityUse: 'Priority use',
removeKey: 'Remove API Key',
},
addApiKey: 'Add your API key',
invalidApiKey: 'Invalid API key',
......
......@@ -61,6 +61,15 @@ module.exports = {
pc: '769px',
// => @media (min-width: 769px) { ... }
},
boxShadow: {
'xs': '0px 1px 2px 0px rgba(16, 24, 40, 0.05)',
'sm': '0px 1px 2px 0px rgba(16, 24, 40, 0.06), 0px 1px 3px 0px rgba(16, 24, 40, 0.10)',
'md': '0px 2px 4px -2px rgba(16, 24, 40, 0.06), 0px 4px 8px -2px rgba(16, 24, 40, 0.10)',
'lg': '0px 4px 6px -2px rgba(16, 24, 40, 0.03), 0px 12px 16px -4px rgba(16, 24, 40, 0.08)',
'xl': '0px 8px 8px -4px rgba(16, 24, 40, 0.03), 0px 20px 24px -4px rgba(16, 24, 40, 0.08)',
'2xl': '0px 24px 48px -12px rgba(16, 24, 40, 0.18)',
'3xl': '0px 32px 64px -12px rgba(16, 24, 40, 0.14)',
},
},
},
plugins: [
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment