@veluai/velu 0.1.0
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/dist/cli.js +11 -0
- package/package.json +52 -0
- package/runtime/velu-ui/base.css +311 -0
- package/runtime/velu-ui/components/Accordion.jsx +64 -0
- package/runtime/velu-ui/components/ApiClient.jsx +121 -0
- package/runtime/velu-ui/components/ApiField.jsx +87 -0
- package/runtime/velu-ui/components/ApiPath.jsx +63 -0
- package/runtime/velu-ui/components/ApiSidebar.jsx +122 -0
- package/runtime/velu-ui/components/AskBar.jsx +71 -0
- package/runtime/velu-ui/components/Callout.jsx +114 -0
- package/runtime/velu-ui/components/Card.jsx +131 -0
- package/runtime/velu-ui/components/Chatbot.jsx +596 -0
- package/runtime/velu-ui/components/CodeBlock.jsx +375 -0
- package/runtime/velu-ui/components/Columns.jsx +56 -0
- package/runtime/velu-ui/components/Field.jsx +81 -0
- package/runtime/velu-ui/components/Image.jsx +163 -0
- package/runtime/velu-ui/components/MethodBadge.jsx +31 -0
- package/runtime/velu-ui/components/NavSelect.jsx +108 -0
- package/runtime/velu-ui/components/PageFeedback.jsx +219 -0
- package/runtime/velu-ui/components/PageFooter.jsx +213 -0
- package/runtime/velu-ui/components/PageHeader.jsx +414 -0
- package/runtime/velu-ui/components/PageNav.jsx +77 -0
- package/runtime/velu-ui/components/PoweredBy.jsx +51 -0
- package/runtime/velu-ui/components/Prompt.jsx +115 -0
- package/runtime/velu-ui/components/Search.jsx +366 -0
- package/runtime/velu-ui/components/Sidebar.jsx +191 -0
- package/runtime/velu-ui/components/Steps.jsx +65 -0
- package/runtime/velu-ui/components/ThemeToggle.jsx +48 -0
- package/runtime/velu-ui/components/Toc.jsx +537 -0
- package/runtime/velu-ui/components/TocBar.jsx +195 -0
- package/runtime/velu-ui/components/Tree.jsx +87 -0
- package/runtime/velu-ui/components/TryItBar.jsx +90 -0
- package/runtime/velu-ui/components/accordion.css +92 -0
- package/runtime/velu-ui/components/api.css +479 -0
- package/runtime/velu-ui/components/ask-bar.css +94 -0
- package/runtime/velu-ui/components/card.css +105 -0
- package/runtime/velu-ui/components/chatbot.css +617 -0
- package/runtime/velu-ui/components/code-block.css +263 -0
- package/runtime/velu-ui/components/docs-layout.css +775 -0
- package/runtime/velu-ui/components/field.css +82 -0
- package/runtime/velu-ui/components/image.css +237 -0
- package/runtime/velu-ui/components/nav-select.css +157 -0
- package/runtime/velu-ui/components/page-feedback.css +241 -0
- package/runtime/velu-ui/components/page-footer.css +130 -0
- package/runtime/velu-ui/components/page-header.css +520 -0
- package/runtime/velu-ui/components/page-nav.css +50 -0
- package/runtime/velu-ui/components/powered-by.css +66 -0
- package/runtime/velu-ui/components/prompt.css +99 -0
- package/runtime/velu-ui/components/search.css +307 -0
- package/runtime/velu-ui/components/sidebar.css +144 -0
- package/runtime/velu-ui/components/steps.css +77 -0
- package/runtime/velu-ui/components/theme-toggle.css +70 -0
- package/runtime/velu-ui/components/toc-bar.css +234 -0
- package/runtime/velu-ui/components/tree.css +49 -0
- package/runtime/velu-ui/index.js +45 -0
- package/runtime/velu-ui/lib/copyText.js +64 -0
- package/runtime/velu-ui/lib/lang-icons.jsx +156 -0
- package/runtime/velu-ui/lib/prism-langs.js +957 -0
- package/runtime/velu-ui/lib/prism-loader.js +74 -0
- package/runtime/velu-ui/lib/resolveIcon.jsx +29 -0
- package/runtime/velu-ui/lib/scrollIntoNearestView.js +66 -0
- package/runtime/velu-ui/mdx-components.jsx +85 -0
- package/runtime/velu-ui/primitives/Cluster.jsx +49 -0
- package/runtime/velu-ui/primitives/Stack.jsx +63 -0
- package/runtime/velu-ui/primitives/Switcher.jsx +57 -0
- package/runtime/velu-ui/primitives/stack.css +3 -0
- package/runtime/velu-ui/primitives/switcher.css +25 -0
- package/runtime/velu-ui/styles.css +43 -0
- package/runtime/velu-ui/tokens.css +4 -0
- package/schema/velu.schema.json +167 -0
- package/src/navigation.js +434 -0
- package/src/runtime/App.jsx +1473 -0
- package/src/runtime/client-entry.jsx +22 -0
- package/src/runtime/server-entry.jsx +16 -0
- package/src/template.html +48 -0
- package/templates/starter/ai-tools/claude-code.mdx +26 -0
- package/templates/starter/ai-tools/cursor.mdx +17 -0
- package/templates/starter/api-reference/endpoint/create.mdx +24 -0
- package/templates/starter/api-reference/endpoint/get.mdx +27 -0
- package/templates/starter/api-reference/introduction.mdx +28 -0
- package/templates/starter/development.mdx +19 -0
- package/templates/starter/essentials/code.mdx +28 -0
- package/templates/starter/essentials/images.mdx +29 -0
- package/templates/starter/essentials/markdown.mdx +25 -0
- package/templates/starter/essentials/navigation.mdx +39 -0
- package/templates/starter/essentials/settings.mdx +30 -0
- package/templates/starter/favicon.svg +6 -0
- package/templates/starter/index.mdx +31 -0
- package/templates/starter/quickstart.mdx +31 -0
- package/templates/starter/velu.json +33 -0
|
@@ -0,0 +1,263 @@
|
|
|
1
|
+
/* CodeBlock — single block (with optional filename) or tabbed CodeGroup.
|
|
2
|
+
All values are tokens; light/dark via [data-theme]. Syntax token
|
|
3
|
+
colors live in --syntax-* vars below so prism's emitted .token.<type>
|
|
4
|
+
class names style cleanly without inline-style themes. */
|
|
5
|
+
|
|
6
|
+
.velu-code-block {
|
|
7
|
+
background: var(--surface-color);
|
|
8
|
+
border: var(--border-width) solid var(--border-color);
|
|
9
|
+
border-radius: var(--radius-sm);
|
|
10
|
+
overflow: hidden;
|
|
11
|
+
color: var(--text-color);
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
/* Header row: outer flex that holds optional left/right scroll nav
|
|
15
|
+
buttons (group mode, when tabs overflow) and the tabs themselves. In
|
|
16
|
+
filename mode there's only one tab and nothing scrolls. */
|
|
17
|
+
.velu-code-block__header {
|
|
18
|
+
display: flex;
|
|
19
|
+
align-items: flex-end;
|
|
20
|
+
padding: var(--s-2) var(--s-2) 0;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
/* Inner scrollable strip — only this overflows horizontally; the nav
|
|
24
|
+
buttons stay pinned at the edges. min-inline-size: 0 lets the strip
|
|
25
|
+
shrink below its content size (default flex behavior would prevent
|
|
26
|
+
overflow from ever triggering). The scrollbar is hidden — users
|
|
27
|
+
either drag the tabs or click the nav arrows. */
|
|
28
|
+
.velu-code-block__tabs {
|
|
29
|
+
display: flex;
|
|
30
|
+
align-items: flex-end;
|
|
31
|
+
gap: var(--s-3);
|
|
32
|
+
flex: 1;
|
|
33
|
+
min-inline-size: 0;
|
|
34
|
+
overflow-x: auto;
|
|
35
|
+
scrollbar-width: none;
|
|
36
|
+
-ms-overflow-style: none;
|
|
37
|
+
scroll-behavior: smooth;
|
|
38
|
+
}
|
|
39
|
+
.velu-code-block__tabs::-webkit-scrollbar {
|
|
40
|
+
display: none;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
/* Nav arrow — only rendered when the strip can scroll further in that
|
|
44
|
+
direction (see useScrollEdges in CodeBlock.jsx). */
|
|
45
|
+
.velu-code-block__nav {
|
|
46
|
+
flex: none;
|
|
47
|
+
display: inline-flex;
|
|
48
|
+
align-items: center;
|
|
49
|
+
justify-content: center;
|
|
50
|
+
inline-size: 1.5em;
|
|
51
|
+
block-size: 1.75em;
|
|
52
|
+
margin-block-end: var(--s-3);
|
|
53
|
+
padding: 0;
|
|
54
|
+
background: transparent;
|
|
55
|
+
border: 0;
|
|
56
|
+
color: var(--muted-color);
|
|
57
|
+
cursor: pointer;
|
|
58
|
+
}
|
|
59
|
+
.velu-code-block__nav:hover {
|
|
60
|
+
color: var(--text-color);
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
.velu-code-block__tab {
|
|
64
|
+
display: inline-flex;
|
|
65
|
+
align-items: center;
|
|
66
|
+
gap: var(--s-2);
|
|
67
|
+
padding: var(--s-2) var(--s0);
|
|
68
|
+
background: transparent;
|
|
69
|
+
border: 0;
|
|
70
|
+
border-radius: var(--radius-sm) var(--radius-sm) 0 0;
|
|
71
|
+
color: var(--muted-color);
|
|
72
|
+
font: inherit;
|
|
73
|
+
font-size: var(--f-h6);
|
|
74
|
+
line-height: var(--lh-h6);
|
|
75
|
+
cursor: pointer;
|
|
76
|
+
white-space: nowrap;
|
|
77
|
+
}
|
|
78
|
+
.velu-code-block__tab:hover:not(.velu-code-block__tab--active) {
|
|
79
|
+
color: var(--text-color);
|
|
80
|
+
}
|
|
81
|
+
.velu-code-block__tab--active {
|
|
82
|
+
background: var(--page-bg);
|
|
83
|
+
color: var(--text-color);
|
|
84
|
+
cursor: default;
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
.velu-code-block__tab-icon {
|
|
88
|
+
display: inline-flex;
|
|
89
|
+
align-items: center;
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
/* Subtle vertical divider between adjacent inactive tabs in a group. */
|
|
93
|
+
.velu-code-block--group
|
|
94
|
+
.velu-code-block__tab:not(.velu-code-block__tab--active)
|
|
95
|
+
+ .velu-code-block__tab:not(.velu-code-block__tab--active) {
|
|
96
|
+
position: relative;
|
|
97
|
+
}
|
|
98
|
+
.velu-code-block--group
|
|
99
|
+
.velu-code-block__tab:not(.velu-code-block__tab--active)
|
|
100
|
+
+ .velu-code-block__tab:not(.velu-code-block__tab--active)::before {
|
|
101
|
+
content: '';
|
|
102
|
+
position: absolute;
|
|
103
|
+
inset-inline-start: calc(var(--s-3) * -1);
|
|
104
|
+
inset-block: 25%;
|
|
105
|
+
inline-size: var(--border-width);
|
|
106
|
+
background: var(--border-color);
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
/* Body: the code area, monospace, horizontally scrollable for long lines.
|
|
110
|
+
Positioned so the copy button can absolutely anchor to its top-left. */
|
|
111
|
+
.velu-code-block__body {
|
|
112
|
+
position: relative;
|
|
113
|
+
background: var(--page-bg);
|
|
114
|
+
padding: var(--s0);
|
|
115
|
+
overflow-x: auto;
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
/* Copy button — always visible. Frosted background so it remains
|
|
119
|
+
legible over whatever code sits beneath it. */
|
|
120
|
+
.velu-code-block__copy {
|
|
121
|
+
position: absolute;
|
|
122
|
+
inset-block-start: var(--s-2);
|
|
123
|
+
inset-inline-end: var(--s-2);
|
|
124
|
+
z-index: 1;
|
|
125
|
+
display: inline-flex;
|
|
126
|
+
align-items: center;
|
|
127
|
+
justify-content: center;
|
|
128
|
+
inline-size: 1.75em;
|
|
129
|
+
block-size: 1.75em;
|
|
130
|
+
padding: 0;
|
|
131
|
+
background: color-mix(in srgb, var(--surface-color) 75%, transparent);
|
|
132
|
+
-webkit-backdrop-filter: blur(6px);
|
|
133
|
+
backdrop-filter: blur(6px);
|
|
134
|
+
border: var(--border-width) solid var(--border-color);
|
|
135
|
+
border-radius: var(--radius-sm);
|
|
136
|
+
color: var(--muted-color);
|
|
137
|
+
cursor: pointer;
|
|
138
|
+
}
|
|
139
|
+
.velu-code-block__copy:hover {
|
|
140
|
+
color: var(--text-color);
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
.velu-code-block__pre {
|
|
144
|
+
margin: 0;
|
|
145
|
+
font-family: var(--font-mono, ui-monospace, SFMono-Regular, Menlo, Consolas, monospace);
|
|
146
|
+
font-size: var(--f-h6);
|
|
147
|
+
line-height: var(--lh-h6);
|
|
148
|
+
color: var(--text-color);
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
.velu-code-block__line {
|
|
152
|
+
display: flex;
|
|
153
|
+
align-items: baseline;
|
|
154
|
+
gap: var(--s0);
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
/* Highlighted-line stripe. Negative inline margin + matching padding
|
|
158
|
+
makes the highlight bleed to the body's edges (past the body padding)
|
|
159
|
+
so the stripe spans the full width like in VS Code, without shifting
|
|
160
|
+
the code text. The bg is a subtle accent tint — works in both
|
|
161
|
+
light + dark via [data-theme] color-mix. */
|
|
162
|
+
.velu-code-block__line--highlight {
|
|
163
|
+
background: color-mix(in srgb, var(--accent-color) 12%, transparent);
|
|
164
|
+
box-shadow: inset 2px 0 0 0 var(--accent-color);
|
|
165
|
+
margin-inline: calc(var(--s0) * -1);
|
|
166
|
+
padding-inline: var(--s0);
|
|
167
|
+
}
|
|
168
|
+
|
|
169
|
+
.velu-code-block__line-number {
|
|
170
|
+
user-select: none;
|
|
171
|
+
text-align: end;
|
|
172
|
+
inline-size: 2ch;
|
|
173
|
+
color: var(--muted-color);
|
|
174
|
+
flex: none;
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
.velu-code-block__line-code {
|
|
178
|
+
white-space: pre;
|
|
179
|
+
min-inline-size: 0;
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
/* ── Syntax token colors ────────────────────────────────────────────────── */
|
|
183
|
+
/* Github-light-ish in light mode, github-dark-ish in dark mode.
|
|
184
|
+
Token classes come from prism-react-renderer's getTokenProps. */
|
|
185
|
+
:root {
|
|
186
|
+
--syntax-comment: #6a737d;
|
|
187
|
+
--syntax-string: #032f62;
|
|
188
|
+
--syntax-keyword: #d73a49;
|
|
189
|
+
--syntax-function: #6f42c1;
|
|
190
|
+
--syntax-number: #005cc5;
|
|
191
|
+
--syntax-punctuation: var(--text-color);
|
|
192
|
+
--syntax-tag: #22863a;
|
|
193
|
+
}
|
|
194
|
+
:root[data-theme='dark'] {
|
|
195
|
+
--syntax-comment: #8b949e;
|
|
196
|
+
--syntax-string: #a5d6ff;
|
|
197
|
+
--syntax-keyword: #ff7b72;
|
|
198
|
+
--syntax-function: #d2a8ff;
|
|
199
|
+
--syntax-number: #79c0ff;
|
|
200
|
+
--syntax-punctuation: var(--text-color);
|
|
201
|
+
--syntax-tag: #7ee787;
|
|
202
|
+
}
|
|
203
|
+
|
|
204
|
+
.velu-code-block__pre .token.comment,
|
|
205
|
+
.velu-code-block__pre .token.prolog,
|
|
206
|
+
.velu-code-block__pre .token.cdata,
|
|
207
|
+
.velu-code-block__pre .token.doctype {
|
|
208
|
+
color: var(--syntax-comment);
|
|
209
|
+
font-style: italic;
|
|
210
|
+
}
|
|
211
|
+
|
|
212
|
+
.velu-code-block__pre .token.string,
|
|
213
|
+
.velu-code-block__pre .token.attr-value,
|
|
214
|
+
.velu-code-block__pre .token.template-string,
|
|
215
|
+
.velu-code-block__pre .token.template-punctuation,
|
|
216
|
+
.velu-code-block__pre .token.char {
|
|
217
|
+
color: var(--syntax-string);
|
|
218
|
+
}
|
|
219
|
+
|
|
220
|
+
.velu-code-block__pre .token.keyword,
|
|
221
|
+
.velu-code-block__pre .token.atrule,
|
|
222
|
+
.velu-code-block__pre .token.attr-name,
|
|
223
|
+
.velu-code-block__pre .token.selector,
|
|
224
|
+
.velu-code-block__pre .token.important {
|
|
225
|
+
color: var(--syntax-keyword);
|
|
226
|
+
}
|
|
227
|
+
|
|
228
|
+
.velu-code-block__pre .token.function,
|
|
229
|
+
.velu-code-block__pre .token.function-variable,
|
|
230
|
+
.velu-code-block__pre .token.class-name,
|
|
231
|
+
.velu-code-block__pre .token.maybe-class-name {
|
|
232
|
+
color: var(--syntax-function);
|
|
233
|
+
}
|
|
234
|
+
|
|
235
|
+
.velu-code-block__pre .token.number,
|
|
236
|
+
.velu-code-block__pre .token.boolean,
|
|
237
|
+
.velu-code-block__pre .token.constant,
|
|
238
|
+
.velu-code-block__pre .token.builtin,
|
|
239
|
+
.velu-code-block__pre .token.symbol,
|
|
240
|
+
.velu-code-block__pre .token.variable,
|
|
241
|
+
.velu-code-block__pre .token.property,
|
|
242
|
+
.velu-code-block__pre .token.regex,
|
|
243
|
+
.velu-code-block__pre .token.url,
|
|
244
|
+
.velu-code-block__pre .token.entity {
|
|
245
|
+
color: var(--syntax-number);
|
|
246
|
+
}
|
|
247
|
+
|
|
248
|
+
.velu-code-block__pre .token.punctuation,
|
|
249
|
+
.velu-code-block__pre .token.operator {
|
|
250
|
+
color: var(--syntax-punctuation);
|
|
251
|
+
}
|
|
252
|
+
|
|
253
|
+
.velu-code-block__pre .token.tag,
|
|
254
|
+
.velu-code-block__pre .token.namespace {
|
|
255
|
+
color: var(--syntax-tag);
|
|
256
|
+
}
|
|
257
|
+
|
|
258
|
+
.velu-code-block__pre .token.inserted {
|
|
259
|
+
color: var(--syntax-tag);
|
|
260
|
+
}
|
|
261
|
+
.velu-code-block__pre .token.deleted {
|
|
262
|
+
color: var(--syntax-keyword);
|
|
263
|
+
}
|