claudecode-history-viewer 1.0.0 → 1.0.2
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.
- package/README.en-US.md +21 -6
- package/README.md +21 -6
- package/bin/cli.js +29 -0
- package/dist/assets/github-BfC0goYb.css +10 -0
- package/dist/assets/github-dark-BEHUn5zE.css +10 -0
- package/dist/assets/index-C1lUOLp_.css +1 -0
- package/dist/assets/index-DHwkGIiZ.js +37 -0
- package/dist/index.html +28 -0
- package/package.json +15 -2
- package/SECURITY.md +0 -23
- package/claude-history-viewer.png +0 -0
- package/postcss.config.js +0 -6
- package/src/App.vue +0 -338
- package/src/components/ChatView.vue +0 -353
- package/src/components/MarkdownRenderer.vue +0 -63
- package/src/components/MessageBubble.vue +0 -105
- package/src/components/RawJsonView.vue +0 -116
- package/src/components/SessionItem.vue +0 -48
- package/src/components/SessionSidebar.vue +0 -202
- package/src/components/SettingsMenu.vue +0 -63
- package/src/components/ThemeToggle.vue +0 -47
- package/src/components/ToolCallBlock.vue +0 -43
- package/src/components/ToolResultBlock.vue +0 -46
- package/src/composables/useLocale.js +0 -68
- package/src/composables/useTheme.js +0 -49
- package/src/i18n/messages.js +0 -135
- package/src/main.js +0 -7
- package/src/styles/main.css +0 -151
- package/src/utils/format.js +0 -37
- package/src/utils/highlight.js +0 -135
- package/src/utils/hljs-theme.js +0 -22
- package/src/utils/markdown.js +0 -59
- package/tailwind.config.js +0 -44
- package/vite.config.js +0 -16
package/README.en-US.md
CHANGED
|
@@ -22,6 +22,25 @@ Browse, search, and export sessions from `~/.claude` and `~/.cursor` — **100%
|
|
|
22
22
|
|
|
23
23
|
Requires **Node.js 18+**. Optional: existing `~/.claude` / `~/.cursor` history on your machine.
|
|
24
24
|
|
|
25
|
+
### Use from npm (recommended)
|
|
26
|
+
|
|
27
|
+
```bash
|
|
28
|
+
npx claudecode-history-viewer
|
|
29
|
+
```
|
|
30
|
+
|
|
31
|
+
Or install globally:
|
|
32
|
+
|
|
33
|
+
```bash
|
|
34
|
+
npm install -g claudecode-history-viewer
|
|
35
|
+
claudecode-history-viewer
|
|
36
|
+
```
|
|
37
|
+
|
|
38
|
+
Open **http://localhost:3747**
|
|
39
|
+
|
|
40
|
+
Disable auto-open: `NO_OPEN_BROWSER=1 npx claudecode-history-viewer`
|
|
41
|
+
|
|
42
|
+
### Clone from GitHub (development)
|
|
43
|
+
|
|
25
44
|
```bash
|
|
26
45
|
git clone https://github.com/wonderomg/claude-history-viewer.git
|
|
27
46
|
cd claude-history-viewer
|
|
@@ -29,11 +48,7 @@ npm install
|
|
|
29
48
|
npm run build && npm start
|
|
30
49
|
```
|
|
31
50
|
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
Auto-open on start; disable: `NO_OPEN_BROWSER=1 npm start`.
|
|
35
|
-
|
|
36
|
-
For development (hot reload): `npm run dev` → http://localhost:5173
|
|
51
|
+
For development (hot reload): `npm run dev` in the repo → http://localhost:5173
|
|
37
52
|
|
|
38
53
|
---
|
|
39
54
|
|
|
@@ -98,7 +113,7 @@ Project slugs like `-Users-you-code-project` are decoded to readable paths in th
|
|
|
98
113
|
|
|
99
114
|
| Issue | Fix |
|
|
100
115
|
|-------|-----|
|
|
101
|
-
| Cannot connect to backend | Run `
|
|
116
|
+
| Cannot connect to backend | Run `npx claudecode-history-viewer` or `npm start`; ensure port `3747` is free |
|
|
102
117
|
| Empty session list | Ensure history dirs exist and tools have written data |
|
|
103
118
|
| Search/highlight off | Press **Enter** in in-session search, or use ◀ ▶ after render |
|
|
104
119
|
|
package/README.md
CHANGED
|
@@ -22,6 +22,25 @@
|
|
|
22
22
|
|
|
23
23
|
需要 **Node.js 18+**。本机可选已有 `~/.claude` / `~/.cursor` 历史数据。
|
|
24
24
|
|
|
25
|
+
### 从 npm 使用(推荐)
|
|
26
|
+
|
|
27
|
+
```bash
|
|
28
|
+
npx claudecode-history-viewer
|
|
29
|
+
```
|
|
30
|
+
|
|
31
|
+
或全局安装后执行:
|
|
32
|
+
|
|
33
|
+
```bash
|
|
34
|
+
npm install -g claudecode-history-viewer
|
|
35
|
+
claudecode-history-viewer
|
|
36
|
+
```
|
|
37
|
+
|
|
38
|
+
浏览器访问 **http://localhost:3747**
|
|
39
|
+
|
|
40
|
+
禁用自动打开:`NO_OPEN_BROWSER=1 npx claudecode-history-viewer`
|
|
41
|
+
|
|
42
|
+
### 从 GitHub 克隆(开发 / 改代码)
|
|
43
|
+
|
|
25
44
|
```bash
|
|
26
45
|
git clone https://github.com/wonderomg/claude-history-viewer.git
|
|
27
46
|
cd claude-history-viewer
|
|
@@ -29,11 +48,7 @@ npm install
|
|
|
29
48
|
npm run build && npm start
|
|
30
49
|
```
|
|
31
50
|
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
启动后会尝试自动打开;禁用:`NO_OPEN_BROWSER=1 npm start`。
|
|
35
|
-
|
|
36
|
-
开发调试(热更新):`npm run dev` → http://localhost:5173
|
|
51
|
+
开发调试(热更新):在源码目录执行 `npm run dev` → http://localhost:5173
|
|
37
52
|
|
|
38
53
|
---
|
|
39
54
|
|
|
@@ -98,7 +113,7 @@ npm run build && npm start
|
|
|
98
113
|
|
|
99
114
|
| 问题 | 处理 |
|
|
100
115
|
|------|------|
|
|
101
|
-
| 无法连接后端 |
|
|
116
|
+
| 无法连接后端 | 确认已运行 `npx claudecode-history-viewer` 或 `npm start`,端口 `3747` 未被占用 |
|
|
102
117
|
| 列表为空 | 确认对应目录存在且已有工具产生的历史 |
|
|
103
118
|
| 搜索/高亮不准 | 会话内搜索按 **回车** 或等渲染后用 ◀ ▶ |
|
|
104
119
|
|
package/bin/cli.js
ADDED
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
/** Start production server (reads ~/.claude, ~/.cursor). */
|
|
3
|
+
import { spawn } from 'child_process'
|
|
4
|
+
import fs from 'fs'
|
|
5
|
+
import path from 'path'
|
|
6
|
+
import { fileURLToPath } from 'url'
|
|
7
|
+
|
|
8
|
+
const __dirname = path.dirname(fileURLToPath(import.meta.url))
|
|
9
|
+
const root = path.join(__dirname, '..')
|
|
10
|
+
const distIndex = path.join(root, 'dist', 'index.html')
|
|
11
|
+
const server = path.join(root, 'server', 'index.js')
|
|
12
|
+
|
|
13
|
+
if (!fs.existsSync(distIndex)) {
|
|
14
|
+
console.error(
|
|
15
|
+
'[claudecode-history-viewer] Missing dist/. Reinstall the package or run from a built clone (npm run build).'
|
|
16
|
+
)
|
|
17
|
+
process.exit(1)
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
const child = spawn(process.execPath, [server], {
|
|
21
|
+
cwd: root,
|
|
22
|
+
env: { ...process.env, NODE_ENV: 'production' },
|
|
23
|
+
stdio: 'inherit',
|
|
24
|
+
})
|
|
25
|
+
|
|
26
|
+
child.on('exit', (code, signal) => {
|
|
27
|
+
if (signal) process.kill(process.pid, signal)
|
|
28
|
+
else process.exit(code ?? 0)
|
|
29
|
+
})
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
pre code.hljs{display:block;overflow-x:auto;padding:1em}code.hljs{padding:3px 5px}/*!
|
|
2
|
+
Theme: GitHub
|
|
3
|
+
Description: Light theme as seen on github.com
|
|
4
|
+
Author: github.com
|
|
5
|
+
Maintainer: @Hirse
|
|
6
|
+
Updated: 2021-05-15
|
|
7
|
+
|
|
8
|
+
Outdated base version: https://github.com/primer/github-syntax-light
|
|
9
|
+
Current colors taken from GitHub's CSS
|
|
10
|
+
*/.hljs{color:#24292e;background:#fff}.hljs-doctag,.hljs-keyword,.hljs-meta .hljs-keyword,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_{color:#d73a49}.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_{color:#6f42c1}.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-variable,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id{color:#005cc5}.hljs-regexp,.hljs-string,.hljs-meta .hljs-string{color:#032f62}.hljs-built_in,.hljs-symbol{color:#e36209}.hljs-comment,.hljs-code,.hljs-formula{color:#6a737d}.hljs-name,.hljs-quote,.hljs-selector-tag,.hljs-selector-pseudo{color:#22863a}.hljs-subst{color:#24292e}.hljs-section{color:#005cc5;font-weight:700}.hljs-bullet{color:#735c0f}.hljs-emphasis{color:#24292e;font-style:italic}.hljs-strong{color:#24292e;font-weight:700}.hljs-addition{color:#22863a;background-color:#f0fff4}.hljs-deletion{color:#b31d28;background-color:#ffeef0}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
pre code.hljs{display:block;overflow-x:auto;padding:1em}code.hljs{padding:3px 5px}/*!
|
|
2
|
+
Theme: GitHub Dark
|
|
3
|
+
Description: Dark theme as seen on github.com
|
|
4
|
+
Author: github.com
|
|
5
|
+
Maintainer: @Hirse
|
|
6
|
+
Updated: 2021-05-15
|
|
7
|
+
|
|
8
|
+
Outdated base version: https://github.com/primer/github-syntax-dark
|
|
9
|
+
Current colors taken from GitHub's CSS
|
|
10
|
+
*/.hljs{color:#c9d1d9;background:#0d1117}.hljs-doctag,.hljs-keyword,.hljs-meta .hljs-keyword,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_{color:#ff7b72}.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_{color:#d2a8ff}.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-variable,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id{color:#79c0ff}.hljs-regexp,.hljs-string,.hljs-meta .hljs-string{color:#a5d6ff}.hljs-built_in,.hljs-symbol{color:#ffa657}.hljs-comment,.hljs-code,.hljs-formula{color:#8b949e}.hljs-name,.hljs-quote,.hljs-selector-tag,.hljs-selector-pseudo{color:#7ee787}.hljs-subst{color:#c9d1d9}.hljs-section{color:#1f6feb;font-weight:700}.hljs-bullet{color:#f2cc60}.hljs-emphasis{color:#c9d1d9;font-style:italic}.hljs-strong{color:#c9d1d9;font-weight:700}.hljs-addition{color:#aff5b4;background-color:#033a16}.hljs-deletion{color:#ffdcd7;background-color:#67060c}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Hiragino Sans GB,Microsoft YaHei,system-ui,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}:root{color-scheme:light;--t-bg: 241 245 249;--t-bg-raised: 255 255 255;--t-bg-overlay: 248 250 252;--t-text: 15 23 42;--t-text-muted: 100 116 139;--t-border: 226 232 240;--t-code-bg: 241 245 249;--t-pre-bg: 248 250 252;--t-scrollbar: 203 213 225;--t-user-bubble: 37 99 235}html.dark{color-scheme:dark;--t-bg: 15 17 23;--t-bg-raised: 22 27 38;--t-bg-overlay: 28 35 51;--t-text: 226 232 240;--t-text-muted: 100 116 139;--t-border: 30 41 59;--t-code-bg: 28 35 51;--t-pre-bg: 13 17 23;--t-scrollbar: 51 65 85;--t-user-bubble: 37 99 235}html{transition:background-color .35s ease,color .35s ease}body{--tw-bg-opacity: 1;background-color:rgb(var(--t-bg) / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(var(--t-text) / var(--tw-text-opacity, 1));-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color .35s ease,color .35s ease}*{scrollbar-width:thin;scrollbar-color:rgb(var(--t-scrollbar)) transparent}.container{width:100%}@media(min-width:640px){.container{max-width:640px}}@media(min-width:768px){.container{max-width:768px}}@media(min-width:1024px){.container{max-width:1024px}}@media(min-width:1280px){.container{max-width:1280px}}@media(min-width:1536px){.container{max-width:1536px}}.theme-transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;transition-timing-function:cubic-bezier(0,0,.2,1)}.search-highlight{border-radius:.125rem;padding-left:.125rem;padding-right:.125rem;font-weight:600;background-color:#facc15a6;color:#0f172a;box-decoration-break:clone;-webkit-box-decoration-break:clone}html.dark .search-highlight{background-color:#fde0478c;color:#0f172a}.search-highlight-active{background-color:#fb923ce6!important;color:#0f172a!important;outline:2px solid rgb(251 146 60);outline-offset:1px}.prose-chat{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;transition-timing-function:cubic-bezier(0,0,.2,1);font-size:15px;line-height:1.625;--tw-text-opacity: 1;color:rgb(var(--t-text) / var(--tw-text-opacity, 1))}.prose-chat h1,.prose-chat h2,.prose-chat h3{margin-top:1rem;margin-bottom:.5rem;font-weight:600;--tw-text-opacity: 1;color:rgb(var(--t-text) / var(--tw-text-opacity, 1))}.prose-chat h1{font-size:1.25rem;line-height:1.75rem}.prose-chat h2{font-size:1.125rem;line-height:1.75rem}.prose-chat h3{font-size:1rem;line-height:1.5rem}.prose-chat p{margin-top:.5rem;margin-bottom:.5rem}.prose-chat ul,.prose-chat ol{margin-top:.5rem;margin-bottom:.5rem;padding-left:1.25rem}.prose-chat ul{list-style-type:disc}.prose-chat ol{list-style-type:decimal}.prose-chat a{--tw-text-opacity: 1;color:rgb(217 119 87 / var(--tw-text-opacity, 1));text-underline-offset:2px}.prose-chat a:hover{text-decoration-line:underline}.prose-chat blockquote{margin-top:.5rem;margin-bottom:.5rem;border-left-width:2px;--tw-border-opacity: 1;border-color:rgb(var(--t-border) / var(--tw-border-opacity, 1));padding-left:.75rem;font-style:italic;--tw-text-opacity: 1;color:rgb(var(--t-text-muted) / var(--tw-text-opacity, 1))}.prose-chat table{margin-top:.75rem;margin-bottom:.75rem;width:100%;border-collapse:collapse;font-size:.875rem;line-height:1.25rem}.prose-chat th,.prose-chat td{border-width:1px;--tw-border-opacity: 1;border-color:rgb(var(--t-border) / var(--tw-border-opacity, 1));padding:.25rem .5rem}.prose-chat th{--tw-bg-opacity: 1;background-color:rgb(var(--t-bg-overlay) / var(--tw-bg-opacity, 1))}.prose-chat pre{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;transition-timing-function:cubic-bezier(0,0,.2,1);position:relative;margin-top:.75rem;margin-bottom:.75rem;overflow-x:auto;border-radius:.5rem;border-width:1px;--tw-border-opacity: 1;border-color:rgb(var(--t-border) / var(--tw-border-opacity, 1));background-color:rgb(var(--t-pre-bg))}.prose-chat pre code{display:block;padding:1rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:13px;line-height:1.625}.prose-chat :not(pre)>code{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;transition-timing-function:cubic-bezier(0,0,.2,1);border-radius:.25rem;padding:.125rem .375rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:13px;background-color:rgb(var(--t-code-bg));color:rgb(var(--t-text))}html.dark .prose-chat :not(pre)>code{color:#fde68ae6}.hljs{background:transparent!important;transition:color .35s ease}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.right-0{right:0}.right-2{right:.5rem}.top-0{top:0}.top-2{top:.5rem}.top-full{top:100%}.z-10{z-index:10}.z-50{z-index:50}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.ml-2{margin-left:.5rem}.ml-3{margin-left:.75rem}.ml-auto{margin-left:auto}.mr-1{margin-right:.25rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-1\.5{margin-top:.375rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.hidden{display:none}.h-4{height:1rem}.h-5{height:1.25rem}.h-full{height:100%}.h-screen{height:100vh}.max-h-24{max-height:6rem}.max-h-32{max-height:8rem}.max-h-40{max-height:10rem}.max-h-64{max-height:16rem}.max-h-96{max-height:24rem}.min-h-0{min-height:0px}.w-4{width:1rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-72{width:18rem}.w-8{width:2rem}.w-full{width:100%}.min-w-0{min-width:0px}.min-w-\[160px\]{min-width:160px}.min-w-\[168px\]{min-width:168px}.min-w-\[3\.5rem\]{min-width:3.5rem}.max-w-2xl{max-width:42rem}.max-w-4xl{max-width:56rem}.max-w-\[200px\]{max-width:200px}.max-w-\[85\%\]{max-width:85%}.max-w-full{max-width:100%}.max-w-md{max-width:28rem}.max-w-xs{max-width:20rem}.flex-1{flex:1 1 0%}.shrink-0{flex-shrink:0}.rotate-90{--tw-rotate: 90deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-pointer{cursor:pointer}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.scroll-mt-4{scroll-margin-top:1rem}.list-none{list-style-type:none}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.items-stretch{align-items:stretch}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-0\.5{gap:.125rem}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.space-y-0\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.125rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.125rem * var(--tw-space-y-reverse))}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.self-center{align-self:center}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-pre-wrap{white-space:pre-wrap}.break-words{overflow-wrap:break-word}.break-all{word-break:break-all}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-l-lg{border-top-left-radius:.5rem;border-bottom-left-radius:.5rem}.rounded-r-lg{border-top-right-radius:.5rem;border-bottom-right-radius:.5rem}.rounded-tl-sm{border-top-left-radius:.125rem}.rounded-tr-sm{border-top-right-radius:.125rem}.border{border-width:1px}.border-b{border-bottom-width:1px}.border-l{border-left-width:1px}.border-l-2{border-left-width:2px}.border-r{border-right-width:1px}.border-t{border-top-width:1px}.border-accent\/30{border-color:#d977574d}.border-accent\/40{border-color:#d9775766}.border-accent\/50{border-color:#d9775780}.border-amber-900\/30{border-color:#78350f4d}.border-amber-900\/40{border-color:#78350f66}.border-emerald-900\/40{border-color:#064e3b66}.border-purple-900\/40{border-color:#581c8766}.border-red-900\/30{border-color:#7f1d1d4d}.border-red-900\/50{border-color:#7f1d1d80}.border-t-border{--tw-border-opacity: 1;border-color:rgb(var(--t-border) / var(--tw-border-opacity, 1))}.border-t-border\/50{border-color:rgb(var(--t-border) / .5)}.border-transparent{border-color:transparent}.bg-accent\/15{background-color:#d9775726}.bg-accent\/20{background-color:#d9775733}.bg-accent\/5{background-color:#d977570d}.bg-amber-950\/20{background-color:#451a0333}.bg-blue-600\/90{background-color:#2563ebe6}.bg-emerald-950\/15{background-color:#022c2226}.bg-purple-950\/50{background-color:#3b076480}.bg-red-950\/20{background-color:#450a0a33}.bg-red-950\/30{background-color:#450a0a4d}.bg-sky-500\/20{background-color:#0ea5e933}.bg-t-bg{--tw-bg-opacity: 1;background-color:rgb(var(--t-bg) / var(--tw-bg-opacity, 1))}.bg-t-overlay{--tw-bg-opacity: 1;background-color:rgb(var(--t-bg-overlay) / var(--tw-bg-opacity, 1))}.bg-t-overlay\/50{background-color:rgb(var(--t-bg-overlay) / .5)}.bg-t-overlay\/80{background-color:rgb(var(--t-bg-overlay) / .8)}.bg-t-raised{--tw-bg-opacity: 1;background-color:rgb(var(--t-bg-raised) / var(--tw-bg-opacity, 1))}.bg-t-raised\/50{background-color:rgb(var(--t-bg-raised) / .5)}.p-0\.5{padding:.125rem}.p-1\.5{padding:.375rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.px-1{padding-left:.25rem;padding-right:.25rem}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-8{padding-top:2rem;padding-bottom:2rem}.pb-2{padding-bottom:.5rem}.pb-3{padding-bottom:.75rem}.pl-2{padding-left:.5rem}.pl-3{padding-left:.75rem}.pl-4{padding-left:1rem}.pr-0\.5{padding-right:.125rem}.pr-2{padding-right:.5rem}.pt-2{padding-top:.5rem}.pt-3{padding-top:.75rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-\[15px\]{font-size:15px}.text-\[9px\]{font-size:9px}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing: tabular-nums;font-variant-numeric:var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction)}.leading-none{line-height:1}.leading-relaxed{line-height:1.625}.tracking-tight{letter-spacing:-.025em}.tracking-wide{letter-spacing:.025em}.text-accent{--tw-text-opacity: 1;color:rgb(217 119 87 / var(--tw-text-opacity, 1))}.text-amber-400{--tw-text-opacity: 1;color:rgb(251 191 36 / var(--tw-text-opacity, 1))}.text-blue-400{--tw-text-opacity: 1;color:rgb(96 165 250 / var(--tw-text-opacity, 1))}.text-emerald-400{--tw-text-opacity: 1;color:rgb(52 211 153 / var(--tw-text-opacity, 1))}.text-purple-300{--tw-text-opacity: 1;color:rgb(216 180 254 / var(--tw-text-opacity, 1))}.text-purple-400{--tw-text-opacity: 1;color:rgb(192 132 252 / var(--tw-text-opacity, 1))}.text-purple-500\/80{color:#a855f7cc}.text-red-400{--tw-text-opacity: 1;color:rgb(248 113 113 / var(--tw-text-opacity, 1))}.text-sky-400{--tw-text-opacity: 1;color:rgb(56 189 248 / var(--tw-text-opacity, 1))}.text-t-muted{--tw-text-opacity: 1;color:rgb(var(--t-text-muted) / var(--tw-text-opacity, 1))}.text-t-text{--tw-text-opacity: 1;color:rgb(var(--t-text) / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.opacity-0{opacity:0}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.ring-1{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-accent\/60{--tw-ring-color: rgb(217 119 87 / .6)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-300{transition-duration:.3s}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}.placeholder\:text-t-muted::-moz-placeholder{--tw-text-opacity: 1;color:rgb(var(--t-text-muted) / var(--tw-text-opacity, 1))}.placeholder\:text-t-muted::placeholder{--tw-text-opacity: 1;color:rgb(var(--t-text-muted) / var(--tw-text-opacity, 1))}.hover\:-rotate-12:hover{--tw-rotate: -12deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:rotate-45:hover{--tw-rotate: 45deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:border-accent\/40:hover{border-color:#d9775766}.hover\:border-t-border:hover{--tw-border-opacity: 1;border-color:rgb(var(--t-border) / var(--tw-border-opacity, 1))}.hover\:bg-amber-950\/30:hover{background-color:#451a034d}.hover\:bg-purple-950\/30:hover{background-color:#3b07644d}.hover\:bg-t-bg:hover{--tw-bg-opacity: 1;background-color:rgb(var(--t-bg) / var(--tw-bg-opacity, 1))}.hover\:bg-t-border:hover{--tw-bg-opacity: 1;background-color:rgb(var(--t-border) / var(--tw-bg-opacity, 1))}.hover\:bg-t-overlay:hover{--tw-bg-opacity: 1;background-color:rgb(var(--t-bg-overlay) / var(--tw-bg-opacity, 1))}.hover\:text-t-muted:hover{--tw-text-opacity: 1;color:rgb(var(--t-text-muted) / var(--tw-text-opacity, 1))}.hover\:text-t-text:hover{--tw-text-opacity: 1;color:rgb(var(--t-text) / var(--tw-text-opacity, 1))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-1:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-accent\/50:focus{--tw-ring-color: rgb(217 119 87 / .5)}.disabled\:opacity-40:disabled{opacity:.4}.group[open] .group-open\:rotate-90{--tw-rotate: 90deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.group:hover .group-hover\:opacity-100{opacity:1}@media(min-width:640px){.sm\:block{display:block}.sm\:inline{display:inline}}@media(min-width:768px){.md\:px-8{padding-left:2rem;padding-right:2rem}}@media(min-width:1024px){.lg\:block{display:block}.lg\:w-80{width:20rem}}.\[\&_\.search-highlight\]\:bg-amber-200\/90 .search-highlight{background-color:#fde68ae6}.\[\&_\.search-highlight\]\:text-slate-900 .search-highlight{--tw-text-opacity: 1;color:rgb(15 23 42 / var(--tw-text-opacity, 1))}
|