* feat: desktop revamp * feat: refactor system monitor * fix linter CI * remove unused import component * added responsive and resizeable component * responsive and resizeable local server page * finalize responsive and resizeable component * fix scroll custom ui * remove react scroll to bottom from modal troubleshoot * fix modal troubleshoot ui * fix setting gpu list * text area custom scroll bar * fix padding message input * cleanup classname * update inference engine model dropdown * update loader style * update quick ask ui * prepare theme provider * update dark theme * remove update hotkey list model and navigation * fix: cleanup hardcode classname * fix: update feedback * Set native theme electron * update destop ui revamp from feedback * update button icon component insider icon chat input message * update model dropdown ui * update tranaparent baclground * update logo model provider * fix: set background material acrylic support to blur background windows * fix: update tranparent left and right panel * fix: linter CI * update app using frameless window * styling custom style minimize, maximize and close app * temporary hidden maximize window * fix: responsive left and right panel * fix: enable click outside when leftpanel responsive * fix: remove unused import * update transparent variable css windows * fix: ui import model * feat: Support Theme system (#2946) * feat: update support theme system * update select component * feat: add theme folder in root project * fix: padding left and right center panel * fix: update padding left and right * chore: migrate themes * fix: rmdirsync error * chore: update gitignore * fix: cp recursive * fix: files electron package json * fix: migration * fix: update fgit ignore --------- Co-authored-by: Louis <louis@jan.ai> * fix: update feedback missing state when refrash app * fix: error test CI * chore: refactor useLoadThemes * chore: cleanup unused vars * fix: revert back menubar windows * fix minor ui * fix: minor ui --------- Co-authored-by: Louis <louis@jan.ai>
74 lines
1.8 KiB
TypeScript
74 lines
1.8 KiB
TypeScript
import React from 'react'
|
|
|
|
import { ModelMetadata } from '@janhq/core'
|
|
import { Badge } from '@janhq/joi'
|
|
import { useAtomValue } from 'jotai'
|
|
|
|
import { useActiveModel } from '@/hooks/useActiveModel'
|
|
|
|
import { useSettings } from '@/hooks/useSettings'
|
|
|
|
import NotEnoughMemoryLabel from './NotEnoughMemoryLabel'
|
|
|
|
import RecommendedLabel from './RecommendedLabel'
|
|
|
|
import SlowOnYourDeviceLabel from './SlowOnYourDeviceLabel'
|
|
|
|
import {
|
|
availableVramAtom,
|
|
totalRamAtom,
|
|
usedRamAtom,
|
|
} from '@/helpers/atoms/SystemBar.atom'
|
|
|
|
type Props = {
|
|
metadata: ModelMetadata
|
|
compact?: boolean
|
|
}
|
|
const UnsupportedModel = () => {
|
|
return (
|
|
<Badge className="space-x-1 rounded-md" theme="warning">
|
|
<span>Coming Soon</span>
|
|
</Badge>
|
|
)
|
|
}
|
|
|
|
const ModelLabel = ({ metadata, compact }: Props) => {
|
|
const { activeModel } = useActiveModel()
|
|
const totalRam = useAtomValue(totalRamAtom)
|
|
const usedRam = useAtomValue(usedRamAtom)
|
|
const availableVram = useAtomValue(availableVramAtom)
|
|
const { settings } = useSettings()
|
|
|
|
const getLabel = (size: number) => {
|
|
const minimumRamModel = size * 1.25
|
|
const availableRam =
|
|
settings?.run_mode === 'gpu'
|
|
? availableVram * 1000000 // MB to bytes
|
|
: totalRam - usedRam + (activeModel?.metadata.size ?? 0)
|
|
if (minimumRamModel > totalRam) {
|
|
return (
|
|
<NotEnoughMemoryLabel
|
|
unit={settings?.run_mode === 'gpu' ? 'VRAM' : 'RAM'}
|
|
compact={compact}
|
|
/>
|
|
)
|
|
}
|
|
if (minimumRamModel < availableRam && !compact) {
|
|
return <RecommendedLabel />
|
|
}
|
|
if (minimumRamModel < totalRam && minimumRamModel > availableRam) {
|
|
return <SlowOnYourDeviceLabel compact={compact} />
|
|
}
|
|
|
|
return null
|
|
}
|
|
|
|
return metadata.tags.includes('Coming Soon') ? (
|
|
<UnsupportedModel />
|
|
) : (
|
|
getLabel(metadata.size ?? 0)
|
|
)
|
|
}
|
|
|
|
export default React.memo(ModelLabel)
|