@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.
Files changed (90) hide show
  1. package/dist/cli.js +11 -0
  2. package/package.json +52 -0
  3. package/runtime/velu-ui/base.css +311 -0
  4. package/runtime/velu-ui/components/Accordion.jsx +64 -0
  5. package/runtime/velu-ui/components/ApiClient.jsx +121 -0
  6. package/runtime/velu-ui/components/ApiField.jsx +87 -0
  7. package/runtime/velu-ui/components/ApiPath.jsx +63 -0
  8. package/runtime/velu-ui/components/ApiSidebar.jsx +122 -0
  9. package/runtime/velu-ui/components/AskBar.jsx +71 -0
  10. package/runtime/velu-ui/components/Callout.jsx +114 -0
  11. package/runtime/velu-ui/components/Card.jsx +131 -0
  12. package/runtime/velu-ui/components/Chatbot.jsx +596 -0
  13. package/runtime/velu-ui/components/CodeBlock.jsx +375 -0
  14. package/runtime/velu-ui/components/Columns.jsx +56 -0
  15. package/runtime/velu-ui/components/Field.jsx +81 -0
  16. package/runtime/velu-ui/components/Image.jsx +163 -0
  17. package/runtime/velu-ui/components/MethodBadge.jsx +31 -0
  18. package/runtime/velu-ui/components/NavSelect.jsx +108 -0
  19. package/runtime/velu-ui/components/PageFeedback.jsx +219 -0
  20. package/runtime/velu-ui/components/PageFooter.jsx +213 -0
  21. package/runtime/velu-ui/components/PageHeader.jsx +414 -0
  22. package/runtime/velu-ui/components/PageNav.jsx +77 -0
  23. package/runtime/velu-ui/components/PoweredBy.jsx +51 -0
  24. package/runtime/velu-ui/components/Prompt.jsx +115 -0
  25. package/runtime/velu-ui/components/Search.jsx +366 -0
  26. package/runtime/velu-ui/components/Sidebar.jsx +191 -0
  27. package/runtime/velu-ui/components/Steps.jsx +65 -0
  28. package/runtime/velu-ui/components/ThemeToggle.jsx +48 -0
  29. package/runtime/velu-ui/components/Toc.jsx +537 -0
  30. package/runtime/velu-ui/components/TocBar.jsx +195 -0
  31. package/runtime/velu-ui/components/Tree.jsx +87 -0
  32. package/runtime/velu-ui/components/TryItBar.jsx +90 -0
  33. package/runtime/velu-ui/components/accordion.css +92 -0
  34. package/runtime/velu-ui/components/api.css +479 -0
  35. package/runtime/velu-ui/components/ask-bar.css +94 -0
  36. package/runtime/velu-ui/components/card.css +105 -0
  37. package/runtime/velu-ui/components/chatbot.css +617 -0
  38. package/runtime/velu-ui/components/code-block.css +263 -0
  39. package/runtime/velu-ui/components/docs-layout.css +775 -0
  40. package/runtime/velu-ui/components/field.css +82 -0
  41. package/runtime/velu-ui/components/image.css +237 -0
  42. package/runtime/velu-ui/components/nav-select.css +157 -0
  43. package/runtime/velu-ui/components/page-feedback.css +241 -0
  44. package/runtime/velu-ui/components/page-footer.css +130 -0
  45. package/runtime/velu-ui/components/page-header.css +520 -0
  46. package/runtime/velu-ui/components/page-nav.css +50 -0
  47. package/runtime/velu-ui/components/powered-by.css +66 -0
  48. package/runtime/velu-ui/components/prompt.css +99 -0
  49. package/runtime/velu-ui/components/search.css +307 -0
  50. package/runtime/velu-ui/components/sidebar.css +144 -0
  51. package/runtime/velu-ui/components/steps.css +77 -0
  52. package/runtime/velu-ui/components/theme-toggle.css +70 -0
  53. package/runtime/velu-ui/components/toc-bar.css +234 -0
  54. package/runtime/velu-ui/components/tree.css +49 -0
  55. package/runtime/velu-ui/index.js +45 -0
  56. package/runtime/velu-ui/lib/copyText.js +64 -0
  57. package/runtime/velu-ui/lib/lang-icons.jsx +156 -0
  58. package/runtime/velu-ui/lib/prism-langs.js +957 -0
  59. package/runtime/velu-ui/lib/prism-loader.js +74 -0
  60. package/runtime/velu-ui/lib/resolveIcon.jsx +29 -0
  61. package/runtime/velu-ui/lib/scrollIntoNearestView.js +66 -0
  62. package/runtime/velu-ui/mdx-components.jsx +85 -0
  63. package/runtime/velu-ui/primitives/Cluster.jsx +49 -0
  64. package/runtime/velu-ui/primitives/Stack.jsx +63 -0
  65. package/runtime/velu-ui/primitives/Switcher.jsx +57 -0
  66. package/runtime/velu-ui/primitives/stack.css +3 -0
  67. package/runtime/velu-ui/primitives/switcher.css +25 -0
  68. package/runtime/velu-ui/styles.css +43 -0
  69. package/runtime/velu-ui/tokens.css +4 -0
  70. package/schema/velu.schema.json +167 -0
  71. package/src/navigation.js +434 -0
  72. package/src/runtime/App.jsx +1473 -0
  73. package/src/runtime/client-entry.jsx +22 -0
  74. package/src/runtime/server-entry.jsx +16 -0
  75. package/src/template.html +48 -0
  76. package/templates/starter/ai-tools/claude-code.mdx +26 -0
  77. package/templates/starter/ai-tools/cursor.mdx +17 -0
  78. package/templates/starter/api-reference/endpoint/create.mdx +24 -0
  79. package/templates/starter/api-reference/endpoint/get.mdx +27 -0
  80. package/templates/starter/api-reference/introduction.mdx +28 -0
  81. package/templates/starter/development.mdx +19 -0
  82. package/templates/starter/essentials/code.mdx +28 -0
  83. package/templates/starter/essentials/images.mdx +29 -0
  84. package/templates/starter/essentials/markdown.mdx +25 -0
  85. package/templates/starter/essentials/navigation.mdx +39 -0
  86. package/templates/starter/essentials/settings.mdx +30 -0
  87. package/templates/starter/favicon.svg +6 -0
  88. package/templates/starter/index.mdx +31 -0
  89. package/templates/starter/quickstart.mdx +31 -0
  90. 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
+ }