nexus/ui/src/lib/agent-skills-state.ts
dotta cfc53bf96b Add unmanaged skill provenance to agent skills
Expose adapter-discovered user-installed skills with provenance metadata, share persistent skill snapshot classification across local adapters, and render unmanaged skills as a read-only section in the agent skills UI.

Co-Authored-By: Paperclip <noreply@paperclip.ing>
2026-03-18 14:21:50 -05:00

40 lines
1.2 KiB
TypeScript

import type { AgentSkillEntry } from "@paperclipai/shared";
export interface AgentSkillDraftState {
draft: string[];
lastSaved: string[];
hasHydratedSnapshot: boolean;
}
export interface AgentSkillSnapshotApplyResult extends AgentSkillDraftState {
shouldSkipAutosave: boolean;
}
export function arraysEqual(a: string[], b: string[]): boolean {
if (a === b) return true;
if (a.length !== b.length) return false;
return a.every((value, index) => value === b[index]);
}
export function applyAgentSkillSnapshot(
state: AgentSkillDraftState,
desiredSkills: string[],
): AgentSkillSnapshotApplyResult {
const shouldReplaceDraft = !state.hasHydratedSnapshot || arraysEqual(state.draft, state.lastSaved);
return {
draft: shouldReplaceDraft ? desiredSkills : state.draft,
lastSaved: desiredSkills,
hasHydratedSnapshot: true,
shouldSkipAutosave: shouldReplaceDraft,
};
}
export function isReadOnlyUnmanagedSkillEntry(
entry: AgentSkillEntry,
companySkillKeys: Set<string>,
): boolean {
if (companySkillKeys.has(entry.key)) return false;
if (entry.origin === "user_installed" || entry.origin === "external_unknown") return true;
return entry.managed === false && entry.state === "external";
}