Signed-off-by: Yuichiro Utsumi <utsumi.yuichiro@fujitsu.com> Signed-off-by: -LAN- <laipz8200@outlook.com> Signed-off-by: yihong0618 <zouzou0208@gmail.com> Signed-off-by: kenwoodjw <blackxin55+@gmail.com> Signed-off-by: ChengZi <chen.zhang@zilliz.com> Signed-off-by: cl <cailue@apache.org> Co-authored-by: Yu Chun Chang <changyuchun159630@gmail.com> Co-authored-by: Kyle Chang <kylechang@91app.com> Co-authored-by: Lick-liu <51771897+Lick-liu@users.noreply.github.com> Co-authored-by: crazywoola <427733928@qq.com> Co-authored-by: Yuichiro Utsumi <81412151+utsumi-fj@users.noreply.github.com> Co-authored-by: NFish <douxc512@gmail.com> Co-authored-by: Yeuoly <45712896+Yeuoly@users.noreply.github.com> Co-authored-by: Wu Tianwei <30284043+WTW0313@users.noreply.github.com> Co-authored-by: DDDDD12138 <43703884+DDDDD12138@users.noreply.github.com> Co-authored-by: Jyong <76649700+JohnJyong@users.noreply.github.com> Co-authored-by: -LAN- <laipz8200@outlook.com> Co-authored-by: Novice <857526207@qq.com> Co-authored-by: yihong <zouzou0208@gmail.com> Co-authored-by: Kalo Chin <91766386+fdb02983rhy@users.noreply.github.com> Co-authored-by: zxhlyh <jasonapring2015@outlook.com> Co-authored-by: jiangbo721 <365065261@qq.com> Co-authored-by: 刘江波 <jiangbo721@163.com> Co-authored-by: Lam <scau_ljw@126.com> Co-authored-by: crazywoola <100913391+crazywoola@users.noreply.github.com> Co-authored-by: Mars <524574386@qq.com> Co-authored-by: mars <linjx2@by-health.com> Co-authored-by: Joe <79627742+ZhouhaoJiang@users.noreply.github.com> Co-authored-by: Rafael Carvalho <r.carvalho@me.com> Co-authored-by: Joel <iamjoel007@gmail.com> Co-authored-by: 非法操作 <hjlarry@163.com> Co-authored-by: kenwoodjw <blackxin55+@gmail.com> Co-authored-by: codingjaguar <codingjaguar@gmail.com> Co-authored-by: ChengZi <chen.zhang@zilliz.com> Co-authored-by: Fei He <droxer.he@gmail.com> Co-authored-by: Arcaner <52057416+lrhan321@users.noreply.github.com> Co-authored-by: Xiyuan Chen <52963600+GareArc@users.noreply.github.com> Co-authored-by: KVOJJJin <jzongcode@gmail.com> Co-authored-by: XiaoBa <94062266+XiaoBa-Yu@users.noreply.github.com> Co-authored-by: Xiaoba Yu <xb1823725853@gmail.com> Co-authored-by: zhangyuhang <2827528315@qq.com> Co-authored-by: yuhang2.zhang <yuhang2.zhang@ly.com> Co-authored-by: 诗浓 <nyaashino@gmail.com> Co-authored-by: RookieAgent <42060616+Sakura4036@users.noreply.github.com> Co-authored-by: sho-takano-dev <shota.takano.dev@gmail.com> Co-authored-by: 過世秋風 <1040926235@qq.com> Co-authored-by: Yi Feng <66539215+bigyifeng@users.noreply.github.com> Co-authored-by: QuantumGhost <obelisk.reg+git@gmail.com> Co-authored-by: Yongtao Huang <99629139+hyongtao-db@users.noreply.github.com> Co-authored-by: ShadowJobs <794878115@qq.com> Co-authored-by: LinYing <linying@momenta.ai> Co-authored-by: Benjamin <benjaminx@gmail.com> Co-authored-by: LiuBodong <liubodong2010@126.com> Co-authored-by: huangzhuo1949 <167434202+huangzhuo1949@users.noreply.github.com> Co-authored-by: huangzhuo <huangzhuo1@xiaomi.com> Co-authored-by: csurong <csurong1@gmail.com> Co-authored-by: 傻笑zz <43721571+shaxiaozz@users.noreply.github.com> Co-authored-by: L8ng <straydragonl@foxmail.com> Co-authored-by: Bowen Liang <liangbowen@gf.com.cn> Co-authored-by: Novice Lee <novicelee@NoviPro.local> Co-authored-by: GuanMu <ballmanjq@gmail.com> Co-authored-by: LittleFish-15 <58618983+LittleFish-15@users.noreply.github.com> Co-authored-by: 诗浓 <844670992@qq.com> Co-authored-by: luckylhb90 <luckylhb90@gmail.com> Co-authored-by: hobo.l <hobo.l@binance.com> Co-authored-by: Gen Sato <52241300+halogen22@users.noreply.github.com> Co-authored-by: twwu <twwu@dify.ai> Co-authored-by: StoneFancyX <53338920+StoneFancyX@users.noreply.github.com> Co-authored-by: StoneFancyX <kindbin@qq.com> Co-authored-by: Naoki KOBAYASHI <naotama@gmail.com> Co-authored-by: kurokobo <kuro664@gmail.com> Co-authored-by: cyflhn <cyflhn@163.com> Co-authored-by: Yingchun Lai <laiyingchun@apache.org> Co-authored-by: jimmyfen <757343258@qq.com> Co-authored-by: Xuetao Song <xuetaomagicsong@gmail.com> Co-authored-by: Panpan <wurui.dev@gmail.com> Co-authored-by: wyy-holding <59436937+wyy-holding@users.noreply.github.com> Co-authored-by: リイノ Lin <sorphwer@gmail.com> Co-authored-by: Ning <accelerator314@gmail.com> Co-authored-by: Linh Nguyen <55907715+batman0911@users.noreply.github.com> Co-authored-by: Junjie.M <118170653@qq.com> Co-authored-by: Ron <svcvit@gmail.com> Co-authored-by: Novice <novice12185727@gmail.com> Co-authored-by: NanoNova <kid1412621@gmail.com> Co-authored-by: JaydenZhou <380774082@qq.com> Co-authored-by: dotdotdot <823150982@qq.com> Co-authored-by: Good Wood <slm_1990@126.com> Co-authored-by: Ryosei Karaki <38310693+karamaru-alpha@users.noreply.github.com> Co-authored-by: chenhuan0728 <54611342+chenhuan0728@users.noreply.github.com> Co-authored-by: chenhuan <huan.chen0728@foxmail> Co-authored-by: lenbo <islenbo@qq.com> Co-authored-by: Jiang <65766008+AlwaysBluer@users.noreply.github.com> Co-authored-by: jiangzhijie <jiangzhijie.jzj@alibaba-inc.com> Co-authored-by: Yongtao Huang <yongtaoh2022@gmail.com> Co-authored-by: zhangkun-21 <sephiroth0932@gmail.com> Co-authored-by: hsiong <37357447+hsiong@users.noreply.github.com> Co-authored-by: 李远军 <4842@9ji.com> Co-authored-by: yourchanges <yourchanges@gmail.com> Co-authored-by: David <guyuezhuying@126.com> Co-authored-by: liuzhenghua <1090179900@qq.com> Co-authored-by: taokuizu <taokuizu@qq.com> Co-authored-by: Hanqing Zhao <sherry9277@gmail.com> Co-authored-by: JimintheBox <gjwlals111@gmail.com> Co-authored-by: wlleiiwang <1025164922@qq.com> Co-authored-by: wlleiiwang <wlleiiwang@tencent.com> Co-authored-by: Alex <32982705+AlexYuan997@users.noreply.github.com> Co-authored-by: yuanlong <yuanlong@boco.com.cn> Co-authored-by: wanttobeamaster <45583625+wanttobeamaster@users.noreply.github.com> Co-authored-by: xiaozhiqing.xzq <xiaozhiqing.xzq@alibaba-inc.com> Co-authored-by: Chenhe Gu <guchenhe@gmail.com> Co-authored-by: tyounami <vkbo@qq.com> Co-authored-by: bo.zhao <bo.zhao@iglooinsure.com> Co-authored-by: ClSlaid <cailue@apache.org> Co-authored-by: adru <106513264+adpanru@users.noreply.github.com> Co-authored-by: horochx <32632779+horochx@users.noreply.github.com>
260 lines
8.1 KiB
TypeScript
260 lines
8.1 KiB
TypeScript
'use client'
|
|
import type { FC } from 'react'
|
|
import React, { useCallback, useState } from 'react'
|
|
import { useTranslation } from 'react-i18next'
|
|
import { useBoolean } from 'ahooks'
|
|
import TracingIcon from './tracing-icon'
|
|
import ProviderPanel from './provider-panel'
|
|
import type { LangFuseConfig, LangSmithConfig, OpikConfig, WeaveConfig } from './type'
|
|
import { TracingProvider } from './type'
|
|
import ProviderConfigModal from './provider-config-modal'
|
|
import Indicator from '@/app/components/header/indicator'
|
|
import Switch from '@/app/components/base/switch'
|
|
import Tooltip from '@/app/components/base/tooltip'
|
|
import Divider from '@/app/components/base/divider'
|
|
import cn from '@/utils/classnames'
|
|
|
|
const I18N_PREFIX = 'app.tracing'
|
|
|
|
export type PopupProps = {
|
|
appId: string
|
|
readOnly: boolean
|
|
enabled: boolean
|
|
onStatusChange: (enabled: boolean) => void
|
|
chosenProvider: TracingProvider | null
|
|
onChooseProvider: (provider: TracingProvider) => void
|
|
langSmithConfig: LangSmithConfig | null
|
|
langFuseConfig: LangFuseConfig | null
|
|
opikConfig: OpikConfig | null
|
|
weaveConfig: WeaveConfig | null
|
|
onConfigUpdated: (provider: TracingProvider, payload: LangSmithConfig | LangFuseConfig | OpikConfig | WeaveConfig) => void
|
|
onConfigRemoved: (provider: TracingProvider) => void
|
|
}
|
|
|
|
const ConfigPopup: FC<PopupProps> = ({
|
|
appId,
|
|
readOnly,
|
|
enabled,
|
|
onStatusChange,
|
|
chosenProvider,
|
|
onChooseProvider,
|
|
langSmithConfig,
|
|
langFuseConfig,
|
|
opikConfig,
|
|
weaveConfig,
|
|
onConfigUpdated,
|
|
onConfigRemoved,
|
|
}) => {
|
|
const { t } = useTranslation()
|
|
|
|
const [currentProvider, setCurrentProvider] = useState<TracingProvider | null>(TracingProvider.langfuse)
|
|
const [isShowConfigModal, {
|
|
setTrue: showConfigModal,
|
|
setFalse: hideConfigModal,
|
|
}] = useBoolean(false)
|
|
const handleOnConfig = useCallback((provider: TracingProvider) => {
|
|
return () => {
|
|
setCurrentProvider(provider)
|
|
showConfigModal()
|
|
}
|
|
}, [showConfigModal])
|
|
|
|
const handleOnChoose = useCallback((provider: TracingProvider) => {
|
|
return () => {
|
|
onChooseProvider(provider)
|
|
}
|
|
}, [onChooseProvider])
|
|
|
|
const handleConfigUpdated = useCallback((payload: LangSmithConfig | LangFuseConfig | OpikConfig | WeaveConfig) => {
|
|
onConfigUpdated(currentProvider!, payload)
|
|
hideConfigModal()
|
|
}, [currentProvider, hideConfigModal, onConfigUpdated])
|
|
|
|
const handleConfigRemoved = useCallback(() => {
|
|
onConfigRemoved(currentProvider!)
|
|
hideConfigModal()
|
|
}, [currentProvider, hideConfigModal, onConfigRemoved])
|
|
|
|
const providerAllConfigured = langSmithConfig && langFuseConfig && opikConfig && weaveConfig
|
|
const providerAllNotConfigured = !langSmithConfig && !langFuseConfig && !opikConfig && !weaveConfig
|
|
|
|
const switchContent = (
|
|
<Switch
|
|
className='ml-3'
|
|
defaultValue={enabled}
|
|
onChange={onStatusChange}
|
|
disabled={providerAllNotConfigured}
|
|
/>
|
|
)
|
|
const langSmithPanel = (
|
|
<ProviderPanel
|
|
type={TracingProvider.langSmith}
|
|
readOnly={readOnly}
|
|
config={langSmithConfig}
|
|
hasConfigured={!!langSmithConfig}
|
|
onConfig={handleOnConfig(TracingProvider.langSmith)}
|
|
isChosen={chosenProvider === TracingProvider.langSmith}
|
|
onChoose={handleOnChoose(TracingProvider.langSmith)}
|
|
key="langSmith-provider-panel"
|
|
/>
|
|
)
|
|
|
|
const langfusePanel = (
|
|
<ProviderPanel
|
|
type={TracingProvider.langfuse}
|
|
readOnly={readOnly}
|
|
config={langFuseConfig}
|
|
hasConfigured={!!langFuseConfig}
|
|
onConfig={handleOnConfig(TracingProvider.langfuse)}
|
|
isChosen={chosenProvider === TracingProvider.langfuse}
|
|
onChoose={handleOnChoose(TracingProvider.langfuse)}
|
|
key="langfuse-provider-panel"
|
|
/>
|
|
)
|
|
|
|
const opikPanel = (
|
|
<ProviderPanel
|
|
type={TracingProvider.opik}
|
|
readOnly={readOnly}
|
|
config={opikConfig}
|
|
hasConfigured={!!opikConfig}
|
|
onConfig={handleOnConfig(TracingProvider.opik)}
|
|
isChosen={chosenProvider === TracingProvider.opik}
|
|
onChoose={handleOnChoose(TracingProvider.opik)}
|
|
key="opik-provider-panel"
|
|
/>
|
|
)
|
|
|
|
const weavePanel = (
|
|
<ProviderPanel
|
|
type={TracingProvider.weave}
|
|
readOnly={readOnly}
|
|
config={weaveConfig}
|
|
hasConfigured={!!weaveConfig}
|
|
onConfig={handleOnConfig(TracingProvider.weave)}
|
|
isChosen={chosenProvider === TracingProvider.weave}
|
|
onChoose={handleOnChoose(TracingProvider.weave)}
|
|
key="weave-provider-panel"
|
|
/>
|
|
)
|
|
const configuredProviderPanel = () => {
|
|
const configuredPanels: JSX.Element[] = []
|
|
|
|
if (langFuseConfig)
|
|
configuredPanels.push(langfusePanel)
|
|
|
|
if (langSmithConfig)
|
|
configuredPanels.push(langSmithPanel)
|
|
|
|
if (opikConfig)
|
|
configuredPanels.push(opikPanel)
|
|
|
|
if (weaveConfig)
|
|
configuredPanels.push(weavePanel)
|
|
|
|
return configuredPanels
|
|
}
|
|
|
|
const moreProviderPanel = () => {
|
|
const notConfiguredPanels: JSX.Element[] = []
|
|
|
|
if (!langFuseConfig)
|
|
notConfiguredPanels.push(langfusePanel)
|
|
|
|
if (!langSmithConfig)
|
|
notConfiguredPanels.push(langSmithPanel)
|
|
|
|
if (!opikConfig)
|
|
notConfiguredPanels.push(opikPanel)
|
|
|
|
if (!weaveConfig)
|
|
notConfiguredPanels.push(weavePanel)
|
|
|
|
return notConfiguredPanels
|
|
}
|
|
|
|
const configuredProviderConfig = () => {
|
|
if (currentProvider === TracingProvider.langSmith)
|
|
return langSmithConfig
|
|
if (currentProvider === TracingProvider.langfuse)
|
|
return langFuseConfig
|
|
if (currentProvider === TracingProvider.opik)
|
|
return opikConfig
|
|
return weaveConfig
|
|
}
|
|
|
|
return (
|
|
<div className='w-[420px] rounded-2xl border-[0.5px] border-components-panel-border bg-components-panel-bg p-4 shadow-xl'>
|
|
<div className='flex items-center justify-between'>
|
|
<div className='flex items-center'>
|
|
<TracingIcon size='md' className='mr-2' />
|
|
<div className='title-2xl-semi-bold text-text-primary'>{t(`${I18N_PREFIX}.tracing`)}</div>
|
|
</div>
|
|
<div className='flex items-center'>
|
|
<Indicator color={enabled ? 'green' : 'gray'} />
|
|
<div className={cn('system-xs-semibold-uppercase ml-1 text-text-tertiary', enabled && 'text-util-colors-green-green-600')}>
|
|
{t(`${I18N_PREFIX}.${enabled ? 'enabled' : 'disabled'}`)}
|
|
</div>
|
|
{!readOnly && (
|
|
<>
|
|
{providerAllNotConfigured
|
|
? (
|
|
<Tooltip
|
|
popupContent={t(`${I18N_PREFIX}.disabledTip`)}
|
|
>
|
|
{switchContent}
|
|
</Tooltip>
|
|
)
|
|
: switchContent}
|
|
</>
|
|
)}
|
|
</div>
|
|
</div>
|
|
|
|
<div className='system-xs-regular mt-2 text-text-tertiary'>
|
|
{t(`${I18N_PREFIX}.tracingDescription`)}
|
|
</div>
|
|
<Divider className='my-3' />
|
|
<div className='relative'>
|
|
{(providerAllConfigured || providerAllNotConfigured)
|
|
? (
|
|
<>
|
|
<div className='system-xs-medium-uppercase text-text-tertiary'>{t(`${I18N_PREFIX}.configProviderTitle.${providerAllConfigured ? 'configured' : 'notConfigured'}`)}</div>
|
|
<div className='mt-2 space-y-2'>
|
|
{langfusePanel}
|
|
{langSmithPanel}
|
|
{opikPanel}
|
|
{weavePanel}
|
|
</div>
|
|
</>
|
|
)
|
|
: (
|
|
<>
|
|
<div className='system-xs-medium-uppercase text-text-tertiary'>{t(`${I18N_PREFIX}.configProviderTitle.configured`)}</div>
|
|
<div className='mt-2 space-y-2'>
|
|
{configuredProviderPanel()}
|
|
</div>
|
|
<div className='system-xs-medium-uppercase mt-3 text-text-tertiary'>{t(`${I18N_PREFIX}.configProviderTitle.moreProvider`)}</div>
|
|
<div className='mt-2 space-y-2'>
|
|
{moreProviderPanel()}
|
|
</div>
|
|
</>
|
|
)}
|
|
|
|
</div>
|
|
{isShowConfigModal && (
|
|
<ProviderConfigModal
|
|
appId={appId}
|
|
type={currentProvider!}
|
|
payload={configuredProviderConfig()}
|
|
onCancel={hideConfigModal}
|
|
onSaved={handleConfigUpdated}
|
|
onChosen={onChooseProvider}
|
|
onRemoved={handleConfigRemoved}
|
|
/>
|
|
)}
|
|
</div>
|
|
)
|
|
}
|
|
export default React.memo(ConfigPopup)
|