mirror of
https://github.com/harivansh-afk/clanker-agent.git
synced 2026-04-15 09:01:13 +00:00
move pi-mono into companion-cloud as apps/companion-os
- Copy all pi-mono source into apps/companion-os/ - Update Dockerfile to COPY pre-built binary instead of downloading from GitHub Releases - Update deploy-staging.yml to build pi from source (bun compile) before Docker build - Add apps/companion-os/** to path triggers - No more cross-repo dispatch needed Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
commit
0250f72976
579 changed files with 206942 additions and 0 deletions
124
packages/web-ui/src/tools/renderers/GetCurrentTimeRenderer.ts
Normal file
124
packages/web-ui/src/tools/renderers/GetCurrentTimeRenderer.ts
Normal file
|
|
@ -0,0 +1,124 @@
|
|||
import type { ToolResultMessage } from "@mariozechner/pi-ai";
|
||||
import { html } from "lit";
|
||||
import { Clock } from "lucide";
|
||||
import { i18n } from "../../utils/i18n.js";
|
||||
import { renderHeader } from "../renderer-registry.js";
|
||||
import type { ToolRenderer, ToolRenderResult } from "../types.js";
|
||||
|
||||
interface GetCurrentTimeParams {
|
||||
timezone?: string;
|
||||
}
|
||||
|
||||
// GetCurrentTime tool has undefined details (only uses output)
|
||||
export class GetCurrentTimeRenderer implements ToolRenderer<
|
||||
GetCurrentTimeParams,
|
||||
undefined
|
||||
> {
|
||||
render(
|
||||
params: GetCurrentTimeParams | undefined,
|
||||
result: ToolResultMessage<undefined> | undefined,
|
||||
): ToolRenderResult {
|
||||
const state = result
|
||||
? result.isError
|
||||
? "error"
|
||||
: "complete"
|
||||
: "inprogress";
|
||||
|
||||
// Full params + full result
|
||||
if (result && params) {
|
||||
const output =
|
||||
result.content
|
||||
?.filter((c) => c.type === "text")
|
||||
.map((c: any) => c.text)
|
||||
.join("\n") || "";
|
||||
const headerText = params.timezone
|
||||
? `${i18n("Getting current time in")} ${params.timezone}`
|
||||
: i18n("Getting current date and time");
|
||||
|
||||
// Error: show header, error below
|
||||
if (result.isError) {
|
||||
return {
|
||||
content: html`
|
||||
<div class="space-y-3">
|
||||
${renderHeader(state, Clock, headerText)}
|
||||
<div class="text-sm text-destructive">${output}</div>
|
||||
</div>
|
||||
`,
|
||||
isCustom: false,
|
||||
};
|
||||
}
|
||||
|
||||
// Success: show time in header
|
||||
return {
|
||||
content: renderHeader(state, Clock, `${headerText}: ${output}`),
|
||||
isCustom: false,
|
||||
};
|
||||
}
|
||||
|
||||
// Full result, no params
|
||||
if (result) {
|
||||
const output =
|
||||
result.content
|
||||
?.filter((c) => c.type === "text")
|
||||
.map((c: any) => c.text)
|
||||
.join("\n") || "";
|
||||
|
||||
// Error: show header, error below
|
||||
if (result.isError) {
|
||||
return {
|
||||
content: html`
|
||||
<div class="space-y-3">
|
||||
${renderHeader(
|
||||
state,
|
||||
Clock,
|
||||
i18n("Getting current date and time"),
|
||||
)}
|
||||
<div class="text-sm text-destructive">${output}</div>
|
||||
</div>
|
||||
`,
|
||||
isCustom: false,
|
||||
};
|
||||
}
|
||||
|
||||
// Success: show time in header
|
||||
return {
|
||||
content: renderHeader(
|
||||
state,
|
||||
Clock,
|
||||
`${i18n("Getting current date and time")}: ${output}`,
|
||||
),
|
||||
isCustom: false,
|
||||
};
|
||||
}
|
||||
|
||||
// Full params, no result: show timezone info in header
|
||||
if (params?.timezone) {
|
||||
return {
|
||||
content: renderHeader(
|
||||
state,
|
||||
Clock,
|
||||
`${i18n("Getting current time in")} ${params.timezone}`,
|
||||
),
|
||||
isCustom: false,
|
||||
};
|
||||
}
|
||||
|
||||
// Partial params (no timezone) or empty params, no result
|
||||
if (params) {
|
||||
return {
|
||||
content: renderHeader(
|
||||
state,
|
||||
Clock,
|
||||
i18n("Getting current date and time"),
|
||||
),
|
||||
isCustom: false,
|
||||
};
|
||||
}
|
||||
|
||||
// No params, no result
|
||||
return {
|
||||
content: renderHeader(state, Clock, i18n("Getting time...")),
|
||||
isCustom: false,
|
||||
};
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue