File size: 3,583 Bytes
b152fd5
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
# File Browser Example Plugin

Example Paperclip plugin that demonstrates:

- **projectSidebarItem** β€” An optional "Files" link under each project in the sidebar that opens the project detail with this plugin’s tab selected. This is controlled by plugin settings and defaults to off.
- **detailTab** (entityType project) β€” A project detail tab with a workspace-path selector, a desktop two-column layout (file tree left, editor right), and a mobile one-panel flow with a back button from editor to file tree, including save support.

This is a repo-local example plugin for development. It should not be assumed to ship in a generic production build unless it is explicitly included.

## Slots

| Slot                | Type                | Description                                      |
|---------------------|---------------------|--------------------------------------------------|
| Files (sidebar)     | `projectSidebarItem`| Optional link under each project β†’ project detail + tab. |
| Files (tab)         | `detailTab`         | Responsive tree/editor layout with save support.|

## Settings

- `Show Files in Sidebar` β€” toggles the project sidebar link on or off. Defaults to off.
- `Comment File Links` β€” controls whether comment annotations and the comment context-menu action are shown.

## Capabilities

- `ui.sidebar.register` β€” project sidebar item
- `ui.detailTab.register` β€” project detail tab
- `projects.read` β€” resolve project
- `project.workspaces.read` β€” list workspaces and read paths for file access

## Worker

- **getData `workspaces`** β€” `ctx.projects.listWorkspaces(projectId, companyId)` (ordered, primary first).
- **getData `fileList`** β€” `{ projectId, workspaceId, directoryPath? }` β†’ list directory entries for the workspace root or a subdirectory (Node `fs`).
- **getData `fileContent`** β€” `{ projectId, workspaceId, filePath }` β†’ read file content using workspace-relative paths (Node `fs`).
- **performAction `writeFile`** β€” `{ projectId, workspaceId, filePath, content }` β†’ write the current editor buffer back to disk.

## Local Install (Dev)

From the repo root, build the plugin and install it by local path:

```bash
pnpm --filter @paperclipai/plugin-file-browser-example build
pnpm paperclipai plugin install ./packages/plugins/examples/plugin-file-browser-example
```

To uninstall:

```bash
pnpm paperclipai plugin uninstall paperclip-file-browser-example --force
```

**Local development notes:**

- **Build first.** The host resolves the worker from the manifest `entrypoints.worker` (e.g. `./dist/worker.js`). Run `pnpm build` in the plugin directory before installing so the worker file exists.
- **Dev-only install path.** This local-path install flow assumes this monorepo checkout is present on disk. For deployed installs, publish an npm package instead of depending on `packages/plugins/examples/...` existing on the host.
- **Reinstall after pulling.** If you installed a plugin by local path before the server stored `package_path`, the plugin may show status **error** (worker not found). Uninstall and install again so the server persists the path and can activate the plugin.
- Optional: use `paperclip-plugin-dev-server` for UI hot-reload with `devUiUrl` in plugin config.

## Structure

- `src/manifest.ts` β€” manifest with `projectSidebarItem` and `detailTab` (entityTypes `["project"]`).
- `src/worker.ts` β€” data handlers for workspaces, file list, file content.
- `src/ui/index.tsx` β€” `FilesLink` (sidebar) and `FilesTab` (workspace path selector + two-panel file tree/editor).