groove-dev 0.26.2 → 0.26.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -5,7 +5,7 @@
5
5
  <meta name="viewport" content="width=device-width, initial-scale=1.0" />
6
6
  <link rel="icon" type="image/png" href="/favicon.png" />
7
7
  <title>Groove GUI</title>
8
- <script type="module" crossorigin src="/assets/index-BC2Bhfv0.js"></script>
8
+ <script type="module" crossorigin src="/assets/index-BgKM8VOT.js"></script>
9
9
  <link rel="modulepreload" crossorigin href="/assets/vendor-C0HXlhrU.js">
10
10
  <link rel="modulepreload" crossorigin href="/assets/reactflow-BQPfi37R.js">
11
11
  <link rel="modulepreload" crossorigin href="/assets/codemirror-BBL3i_JW.js">
@@ -102,18 +102,22 @@ function ProviderCard({ provider, onKeyChange }) {
102
102
  }
103
103
  }
104
104
 
105
- // Ollama card
105
+ // Local models card
106
106
  if (isLocal) {
107
+ const installedCount = provider.models?.filter(m => !m.disabled)?.length || 0;
108
+ const goToModels = () => useGrooveStore.getState().setActiveView('models');
107
109
  return (
108
110
  <div className="flex flex-col rounded-lg border border-border-subtle bg-surface-1 overflow-hidden min-w-[220px]">
109
111
  <div className="flex items-center gap-2.5 px-4 py-3 border-b border-border-subtle">
110
112
  <StatusDot status={isReady ? 'running' : 'crashed'} size="sm" />
111
113
  <span className="text-[13px] font-semibold text-text-0 font-sans">{provider.name}</span>
112
114
  <div className="flex-1" />
113
- {isReady ? (
114
- <Badge variant="success" className="text-2xs gap-1"><Check size={8} /> Ready</Badge>
115
+ {isReady && installedCount > 0 ? (
116
+ <Badge variant="success" className="text-2xs gap-1"><Check size={8} /> {installedCount} models</Badge>
117
+ ) : isReady ? (
118
+ <Badge variant="warning" className="text-2xs">No models pulled</Badge>
115
119
  ) : (
116
- <Badge variant="default" className="text-2xs">Not installed</Badge>
120
+ <Badge variant="default" className="text-2xs">Ollama not installed</Badge>
117
121
  )}
118
122
  </div>
119
123
  <div className="flex-1">
@@ -122,17 +126,40 @@ function ProviderCard({ provider, onKeyChange }) {
122
126
  ) : (
123
127
  <div className="px-4 py-3 flex flex-col h-full">
124
128
  <div className="text-xs text-text-3 font-sans flex-1">
125
- {isReady ? `${provider.models?.length || 0} models available` : 'Local AI models — free, private, no API key'}
129
+ {isReady && installedCount > 0
130
+ ? 'Full agentic runtime — tool calling, context rotation, zero cloud cost'
131
+ : isReady
132
+ ? 'Ollama is running but no models pulled yet. Pull a model or browse the Models tab.'
133
+ : 'Run any open-source model on your machine — free, private, fully offline'}
126
134
  </div>
127
- <Button
128
- variant={isReady ? 'secondary' : 'primary'}
129
- size="sm"
130
- onClick={() => setOllamaOpen(true)}
131
- className="w-full h-7 text-2xs gap-1.5 mt-3"
132
- >
133
- <Cpu size={11} />
134
- {isReady ? 'Manage Models' : 'Set Up Ollama'}
135
- </Button>
135
+ {!isReady ? (
136
+ <Button
137
+ variant="primary"
138
+ size="sm"
139
+ onClick={() => setOllamaOpen(true)}
140
+ className="w-full h-7 text-2xs gap-1.5 mt-3"
141
+ >
142
+ <Cpu size={11} /> Set Up Ollama
143
+ </Button>
144
+ ) : installedCount === 0 ? (
145
+ <div className="flex gap-2 mt-3">
146
+ <Button variant="primary" size="sm" onClick={() => setOllamaOpen(true)} className="flex-1 h-7 text-2xs gap-1.5">
147
+ <Cpu size={11} /> Pull Models
148
+ </Button>
149
+ <Button variant="secondary" size="sm" onClick={goToModels} className="flex-1 h-7 text-2xs gap-1.5">
150
+ Browse HuggingFace
151
+ </Button>
152
+ </div>
153
+ ) : (
154
+ <div className="flex gap-2 mt-3">
155
+ <Button variant="secondary" size="sm" onClick={() => setOllamaOpen(true)} className="flex-1 h-7 text-2xs gap-1.5">
156
+ <Cpu size={11} /> Manage
157
+ </Button>
158
+ <Button variant="secondary" size="sm" onClick={goToModels} className="flex-1 h-7 text-2xs gap-1.5">
159
+ Browse Models
160
+ </Button>
161
+ </div>
162
+ )}
136
163
  </div>
137
164
  )}
138
165
  </div>