Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
D
dify
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
ai-tech
dify
Commits
6bf39c02
Commit
6bf39c02
authored
Aug 02, 2023
by
StyleZhang
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
fix: some style
parent
76e0c93b
Changes
55
Hide whitespace changes
Inline
Side-by-side
Showing
55 changed files
with
768 additions
and
559 deletions
+768
-559
minimax-text.png
...p/components/base/icons/assets/image/llm/minimax-text.png
+0
-0
minimax.png
web/app/components/base/icons/assets/image/llm/minimax.png
+0
-0
tongyi-text-cn.png
...components/base/icons/assets/image/llm/tongyi-text-cn.png
+0
-0
tongyi-text.png
...pp/components/base/icons/assets/image/llm/tongyi-text.png
+0
-0
tongyi.png
web/app/components/base/icons/assets/image/llm/tongyi.png
+0
-0
minimax-text.svg
.../components/base/icons/assets/public/llm/minimax-text.svg
+0
-9
minimax.svg
web/app/components/base/icons/assets/public/llm/minimax.svg
+0
-9
tongyi-text-cn.svg
...omponents/base/icons/assets/public/llm/tongyi-text-cn.svg
+0
-9
tongyi-text.svg
...p/components/base/icons/assets/public/llm/tongyi-text.svg
+0
-15
tongyi.svg
web/app/components/base/icons/assets/public/llm/tongyi.svg
+0
-9
dots-horizontal.svg
...base/icons/assets/vender/line/general/dots-horizontal.svg
+9
-0
help-circle.svg
...nts/base/icons/assets/vender/line/general/help-circle.svg
+3
-0
info-circle.svg
...nts/base/icons/assets/vender/line/general/info-circle.svg
+10
-0
script.js
web/app/components/base/icons/script.js
+52
-0
Minimax.module.css
...pp/components/base/icons/src/image/llm/Minimax.module.css
+5
-0
Minimax.tsx
web/app/components/base/icons/src/image/llm/Minimax.tsx
+13
-0
MinimaxText.module.css
...omponents/base/icons/src/image/llm/MinimaxText.module.css
+5
-0
MinimaxText.tsx
web/app/components/base/icons/src/image/llm/MinimaxText.tsx
+13
-0
Tongyi.module.css
...app/components/base/icons/src/image/llm/Tongyi.module.css
+5
-0
Tongyi.tsx
web/app/components/base/icons/src/image/llm/Tongyi.tsx
+13
-0
TongyiText.module.css
...components/base/icons/src/image/llm/TongyiText.module.css
+5
-0
TongyiText.tsx
web/app/components/base/icons/src/image/llm/TongyiText.tsx
+13
-0
TongyiTextCn.module.css
...mponents/base/icons/src/image/llm/TongyiTextCn.module.css
+5
-0
TongyiTextCn.tsx
web/app/components/base/icons/src/image/llm/TongyiTextCn.tsx
+13
-0
index.ts
web/app/components/base/icons/src/image/llm/index.ts
+5
-0
Minimax.json
web/app/components/base/icons/src/public/llm/Minimax.json
+0
-68
MinimaxText.json
...app/components/base/icons/src/public/llm/MinimaxText.json
+0
-68
Tongyi.json
web/app/components/base/icons/src/public/llm/Tongyi.json
+0
-69
TongyiText.json
web/app/components/base/icons/src/public/llm/TongyiText.json
+0
-123
TongyiText.tsx
web/app/components/base/icons/src/public/llm/TongyiText.tsx
+0
-14
TongyiTextCn.json
...pp/components/base/icons/src/public/llm/TongyiTextCn.json
+0
-69
TongyiTextCn.tsx
...app/components/base/icons/src/public/llm/TongyiTextCn.tsx
+0
-14
index.ts
web/app/components/base/icons/src/public/llm/index.ts
+0
-5
DotsHorizontal.json
...ts/base/icons/src/vender/line/general/DotsHorizontal.json
+71
-0
DotsHorizontal.tsx
...nts/base/icons/src/vender/line/general/DotsHorizontal.tsx
+1
-1
HelpCircle.json
...onents/base/icons/src/vender/line/general/HelpCircle.json
+30
-0
HelpCircle.tsx
...ponents/base/icons/src/vender/line/general/HelpCircle.tsx
+1
-1
InfoCircle.json
...onents/base/icons/src/vender/line/general/InfoCircle.json
+66
-0
InfoCircle.tsx
...ponents/base/icons/src/vender/line/general/InfoCircle.tsx
+1
-1
index.ts
...pp/components/base/icons/src/vender/line/general/index.ts
+3
-0
utils.ts
web/app/components/base/icons/utils.ts
+12
-0
anthropic.config.ts
...er/account-setting/model-page/configs/anthropic.config.ts
+49
-0
index.ts
...onents/header/account-setting/model-page/configs/index.ts
+7
-0
openai.config.ts
...eader/account-setting/model-page/configs/openai.config.ts
+63
-0
index.tsx
...pp/components/header/account-setting/model-page/index.tsx
+49
-7
PrioritySelector.tsx
...ccount-setting/model-page/model-card/PrioritySelector.tsx
+63
-0
index.module.css
...er/account-setting/model-page/model-card/index.module.css
+0
-3
index.tsx
...ts/header/account-setting/model-page/model-card/index.tsx
+53
-23
Operation.tsx
...eader/account-setting/model-page/model-item/Operation.tsx
+48
-0
index.tsx
...ts/header/account-setting/model-page/model-item/index.tsx
+15
-22
index.module.css
...ccount-setting/model-page/model-selector/index.module.css
+0
-3
index.tsx
...eader/account-setting/model-page/model-selector/index.tsx
+44
-17
common.en.ts
web/i18n/lang/common.en.ts
+9
-0
common.zh.ts
web/i18n/lang/common.zh.ts
+5
-0
tailwind.config.js
web/tailwind.config.js
+9
-0
No files found.
web/app/components/base/icons/assets/image/llm/minimax-text.png
0 → 100644
View file @
6bf39c02
5.63 KB
web/app/components/base/icons/assets/image/llm/minimax.png
0 → 100644
View file @
6bf39c02
1.96 KB
web/app/components/base/icons/assets/image/llm/tongyi-text-cn.png
0 → 100644
View file @
6bf39c02
6.89 KB
web/app/components/base/icons/assets/image/llm/tongyi-text.png
0 → 100644
View file @
6bf39c02
4.63 KB
web/app/components/base/icons/assets/image/llm/tongyi.png
0 → 100644
View file @
6bf39c02
2.77 KB
web/app/components/base/icons/assets/public/llm/minimax-text.svg
deleted
100644 → 0
View file @
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>
web/app/components/base/icons/assets/public/llm/minimax.svg
deleted
100644 → 0
View file @
76e0c93b
<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>
web/app/components/base/icons/assets/public/llm/tongyi-text-cn.svg
deleted
100644 → 0
View file @
76e0c93b
<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>
web/app/components/base/icons/assets/public/llm/tongyi-text.svg
deleted
100644 → 0
View file @
76e0c93b
<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>
web/app/components/base/icons/assets/public/llm/tongyi.svg
deleted
100644 → 0
View file @
76e0c93b
<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>
web/app/components/base/icons/assets/vender/line/general/dots-horizontal.svg
0 → 100644
View file @
6bf39c02
<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>
web/app/components/base/icons/assets/vender/line/general/help-circle.svg
0 → 100644
View file @
6bf39c02
<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>
web/app/components/base/icons/assets/vender/line/general/info-circle.svg
0 → 100644
View file @
6bf39c02
<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>
web/app/components/base/icons/script.js
View file @
6bf39c02
...
...
@@ -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'
])
})()
web/app/components/base/icons/src/image/llm/Minimax.module.css
0 → 100644
View file @
6bf39c02
.wrapper
{
display
:
inline-flex
;
background
:
url(~@/app/components/base/icons/assets/image/llm/minimax.png)
center
center
no-repeat
;
background-size
:
contain
;
}
web/app/components/base/icons/src/image/llm/Minimax.tsx
0 → 100644
View file @
6bf39c02
// 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
web/app/components/base/icons/src/image/llm/MinimaxText.module.css
0 → 100644
View file @
6bf39c02
.wrapper
{
display
:
inline-flex
;
background
:
url(~@/app/components/base/icons/assets/image/llm/minimax-text.png)
center
center
no-repeat
;
background-size
:
contain
;
}
web/app/components/base/icons/src/image/llm/MinimaxText.tsx
0 → 100644
View file @
6bf39c02
// 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
web/app/components/base/icons/src/image/llm/Tongyi.module.css
0 → 100644
View file @
6bf39c02
.wrapper
{
display
:
inline-flex
;
background
:
url(~@/app/components/base/icons/assets/image/llm/tongyi.png)
center
center
no-repeat
;
background-size
:
contain
;
}
web/app/components/base/icons/src/image/llm/Tongyi.tsx
0 → 100644
View file @
6bf39c02
// 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
web/app/components/base/icons/src/image/llm/TongyiText.module.css
0 → 100644
View file @
6bf39c02
.wrapper
{
display
:
inline-flex
;
background
:
url(~@/app/components/base/icons/assets/image/llm/tongyi-text.png)
center
center
no-repeat
;
background-size
:
contain
;
}
web/app/components/base/icons/src/image/llm/TongyiText.tsx
0 → 100644
View file @
6bf39c02
// 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
web/app/components/base/icons/src/image/llm/TongyiTextCn.module.css
0 → 100644
View file @
6bf39c02
.wrapper
{
display
:
inline-flex
;
background
:
url(~@/app/components/base/icons/assets/image/llm/tongyi-text-cn.png)
center
center
no-repeat
;
background-size
:
contain
;
}
web/app/components/base/icons/src/image/llm/TongyiTextCn.tsx
0 → 100644
View file @
6bf39c02
// 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
web/app/components/base/icons/src/image/llm/index.ts
0 → 100644
View file @
6bf39c02
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'
web/app/components/base/icons/src/public/llm/Minimax.json
deleted
100644 → 0
View file @
76e0c93b
{
"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
web/app/components/base/icons/src/public/llm/MinimaxText.json
deleted
100644 → 0
View file @
76e0c93b
{
"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
web/app/components/base/icons/src/public/llm/Tongyi.json
deleted
100644 → 0
View file @
76e0c93b
{
"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
web/app/components/base/icons/src/public/llm/TongyiText.json
deleted
100644 → 0
View file @
76e0c93b
{
"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
web/app/components/base/icons/src/public/llm/TongyiText.tsx
deleted
100644 → 0
View file @
76e0c93b
// 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
web/app/components/base/icons/src/public/llm/TongyiTextCn.json
deleted
100644 → 0
View file @
76e0c93b
{
"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
web/app/components/base/icons/src/public/llm/TongyiTextCn.tsx
deleted
100644 → 0
View file @
76e0c93b
// 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
web/app/components/base/icons/src/public/llm/index.ts
View file @
6bf39c02
...
...
@@ -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'
web/app/components/base/icons/src/vender/line/general/DotsHorizontal.json
0 → 100644
View file @
6bf39c02
{
"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
web/app/components/base/icons/src/
public/llm/MinimaxText
.tsx
→
web/app/components/base/icons/src/
vender/line/general/DotsHorizontal
.tsx
View file @
6bf39c02
...
...
@@ -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'
...
...
web/app/components/base/icons/src/vender/line/general/HelpCircle.json
0 → 100644
View file @
6bf39c02
{
"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
web/app/components/base/icons/src/
public/llm/Minimax
.tsx
→
web/app/components/base/icons/src/
vender/line/general/HelpCircle
.tsx
View file @
6bf39c02
...
...
@@ -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'
...
...
web/app/components/base/icons/src/vender/line/general/InfoCircle.json
0 → 100644
View file @
6bf39c02
{
"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
web/app/components/base/icons/src/
public/llm/Tongyi
.tsx
→
web/app/components/base/icons/src/
vender/line/general/InfoCircle
.tsx
View file @
6bf39c02
...
...
@@ -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'
...
...
web/app/components/base/icons/src/vender/line/general/index.ts
View file @
6bf39c02
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'
...
...
web/app/components/base/icons/utils.ts
View file @
6bf39c02
...
...
@@ -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
}
...
...
web/app/components/header/account-setting/model-page/configs/anthropic.config.ts
0 → 100644
View file @
6bf39c02
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 服务器地址。'
,
},
},
],
}
web/app/components/header/account-setting/model-page/configs/index.ts
0 → 100644
View file @
6bf39c02
import
anthropicConfig
from
'./anthropic.config'
import
openaiConfig
from
'./openai.config'
export
default
{
anthropic
:
anthropicConfig
,
openai
:
openaiConfig
,
}
web/app/components/header/account-setting/model-page/configs/openai.config.ts
0 → 100644
View file @
6bf39c02
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'
,
},
},
],
}
web/app/components/header/account-setting/model-page/index.tsx
View file @
6bf39c02
...
...
@@ -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
)
}
/>
))
...
...
web/app/components/header/account-setting/model-page/model-card/PrioritySelector.tsx
0 → 100644
View file @
6bf39c02
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
web/app/components/header/account-setting/model-page/model-card/index.module.css
deleted
100644 → 0
View file @
76e0c93b
.card
{
box-shadow
:
0px
1px
2px
0px
rgba
(
16
,
24
,
40
,
0.05
);
}
\ No newline at end of file
web/app/components/header/account-setting/model-page/model-card/index.tsx
View file @
6bf39c02
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
>
<
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
>
{
!
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 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=
'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
>
</
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
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
>
)
...
...
web/app/components/header/account-setting/model-page/model-item/Operation.tsx
0 → 100644
View file @
6bf39c02
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
web/app/components/header/account-setting/model-page/model-item/index.tsx
View file @
6bf39c02
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
>
)
}
...
...
web/app/components/header/account-setting/model-page/model-selector/index.module.css
deleted
100644 → 0
View file @
76e0c93b
.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
web/app/components/header/account-setting/model-page/model-selector/index.tsx
View file @
6bf39c02
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
>
...
...
web/i18n/lang/common.en.ts
View file @
6bf39c02
...
...
@@ -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'
,
...
...
web/i18n/lang/common.zh.ts
View file @
6bf39c02
...
...
@@ -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'
,
...
...
web/tailwind.config.js
View file @
6bf39c02
...
...
@@ -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
:
[
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment