@alpic-ai/ui 0.0.0-dev.fffc79a → 0.0.0-dev.g00dcac1

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 (75) hide show
  1. package/dist/components/accordion-card.d.mts +5 -6
  2. package/dist/components/accordion.d.mts +5 -6
  3. package/dist/components/alert.d.mts +9 -11
  4. package/dist/components/attachment-tile.d.mts +1 -3
  5. package/dist/components/avatar.d.mts +8 -10
  6. package/dist/components/badge.d.mts +2 -4
  7. package/dist/components/breadcrumb.d.mts +10 -11
  8. package/dist/components/button.d.mts +6 -8
  9. package/dist/components/card.d.mts +9 -10
  10. package/dist/components/checkbox.d.mts +2 -3
  11. package/dist/components/collapsible.d.mts +4 -5
  12. package/dist/components/combobox.d.mts +12 -11
  13. package/dist/components/combobox.mjs +7 -4
  14. package/dist/components/command.d.mts +9 -10
  15. package/dist/components/copyable.d.mts +2 -3
  16. package/dist/components/description-list.d.mts +5 -6
  17. package/dist/components/dialog.d.mts +15 -17
  18. package/dist/components/dropdown-menu.d.mts +18 -20
  19. package/dist/components/form.d.mts +71 -19
  20. package/dist/components/form.mjs +120 -10
  21. package/dist/components/github-button.d.mts +1 -2
  22. package/dist/components/input-group.d.mts +5 -7
  23. package/dist/components/input.d.mts +4 -5
  24. package/dist/components/input.mjs +2 -2
  25. package/dist/components/label.d.mts +2 -3
  26. package/dist/components/page-loader.d.mts +1 -3
  27. package/dist/components/pagination.d.mts +3 -4
  28. package/dist/components/popover.d.mts +5 -6
  29. package/dist/components/radio-group.d.mts +3 -4
  30. package/dist/components/scroll-area.d.mts +3 -4
  31. package/dist/components/select-trigger-variants.d.mts +1 -3
  32. package/dist/components/select.d.mts +9 -10
  33. package/dist/components/separator.d.mts +2 -3
  34. package/dist/components/sheet.d.mts +11 -12
  35. package/dist/components/shimmer-text.d.mts +12 -0
  36. package/dist/components/shimmer-text.mjs +22 -0
  37. package/dist/components/sidebar.d.mts +34 -36
  38. package/dist/components/sidebar.mjs +10 -10
  39. package/dist/components/skeleton.d.mts +2 -4
  40. package/dist/components/sonner.d.mts +5 -6
  41. package/dist/components/spinner.d.mts +3 -5
  42. package/dist/components/status-dot.d.mts +2 -4
  43. package/dist/components/switch.d.mts +2 -3
  44. package/dist/components/table.d.mts +10 -11
  45. package/dist/components/table.mjs +3 -3
  46. package/dist/components/tabs.d.mts +12 -14
  47. package/dist/components/tabs.mjs +4 -4
  48. package/dist/components/tag.d.mts +3 -5
  49. package/dist/components/task-progress.d.mts +25 -0
  50. package/dist/components/task-progress.mjs +66 -0
  51. package/dist/components/textarea.d.mts +3 -4
  52. package/dist/components/textarea.mjs +2 -2
  53. package/dist/components/toggle-group.d.mts +4 -6
  54. package/dist/components/toggle-group.mjs +3 -3
  55. package/dist/components/tooltip-icon-button.d.mts +1 -2
  56. package/dist/components/tooltip.d.mts +5 -6
  57. package/dist/components/tooltip.mjs +1 -1
  58. package/dist/components/typography.d.mts +4 -5
  59. package/dist/components/wizard.d.mts +33 -0
  60. package/dist/components/wizard.mjs +46 -0
  61. package/dist/hooks/use-mobile.mjs +3 -3
  62. package/package.json +30 -30
  63. package/src/components/combobox.tsx +9 -2
  64. package/src/components/form.tsx +164 -3
  65. package/src/components/shimmer-text.tsx +23 -0
  66. package/src/components/table.tsx +2 -3
  67. package/src/components/tabs.tsx +4 -4
  68. package/src/components/task-progress.tsx +107 -0
  69. package/src/components/tooltip.tsx +1 -1
  70. package/src/components/wizard.tsx +69 -0
  71. package/src/stories/form.stories.tsx +64 -2
  72. package/src/stories/tabs.stories.tsx +4 -2
  73. package/src/stories/task-progress.stories.tsx +81 -0
  74. package/src/stories/wizard.stories.tsx +64 -0
  75. package/src/styles/tokens.css +11 -4
@@ -1,6 +1,17 @@
1
1
  import type { Story } from "@ladle/react";
2
2
  import { useForm } from "react-hook-form";
3
- import { Form, FormFields, FormHeader, InputField, SelectField, TextareaField } from "../components/form";
3
+
4
+ import {
5
+ CheckboxField,
6
+ ChecklistField,
7
+ Form,
8
+ FormFields,
9
+ FormHeader,
10
+ InputField,
11
+ RadioField,
12
+ SelectField,
13
+ TextareaField,
14
+ } from "../components/form";
4
15
 
5
16
  /* ── Types ───────────────────────────────────────────────────────────────── */
6
17
 
@@ -8,6 +19,9 @@ interface CreateProjectForm {
8
19
  email: string;
9
20
  role: string;
10
21
  description: string;
22
+ visibility: string;
23
+ capabilities: string[];
24
+ acceptTerms: boolean;
11
25
  }
12
26
 
13
27
  const roles = [
@@ -16,11 +30,31 @@ const roles = [
16
30
  { value: "viewer", label: "Viewer" },
17
31
  ];
18
32
 
33
+ const visibilities = [
34
+ { value: "public", label: "Public" },
35
+ { value: "private", label: "Private" },
36
+ { value: "internal", label: "Internal" },
37
+ ];
38
+
39
+ const capabilities = [
40
+ { value: "read", label: "Read" },
41
+ { value: "write", label: "Write" },
42
+ { value: "deploy", label: "Deploy" },
43
+ { value: "admin", label: "Admin" },
44
+ ];
45
+
19
46
  /* ── Composed Form ───────────────────────────────────────────────────────── */
20
47
 
21
48
  function ComposedForm() {
22
49
  const form = useForm<CreateProjectForm>({
23
- defaultValues: { email: "", role: "", description: "" },
50
+ defaultValues: {
51
+ email: "",
52
+ role: "",
53
+ description: "",
54
+ visibility: "",
55
+ capabilities: [],
56
+ acceptTerms: false,
57
+ },
24
58
  });
25
59
 
26
60
  const onSubmit = (data: CreateProjectForm) => {
@@ -64,6 +98,34 @@ function ComposedForm() {
64
98
  placeholder="A short description of your project..."
65
99
  required
66
100
  />
101
+
102
+ <RadioField
103
+ control={form.control}
104
+ name="visibility"
105
+ rules={{ required: "Pick a visibility." }}
106
+ label="Visibility"
107
+ description="Who can see and access this project."
108
+ options={visibilities}
109
+ required
110
+ />
111
+
112
+ <ChecklistField
113
+ control={form.control}
114
+ name="capabilities"
115
+ rules={{ validate: (value) => (value?.length ? true : "Pick at least one capability.") }}
116
+ label="Capabilities"
117
+ description="Select all that apply."
118
+ options={capabilities}
119
+ required
120
+ />
121
+
122
+ <CheckboxField
123
+ control={form.control}
124
+ name="acceptTerms"
125
+ rules={{ validate: (value) => (value ? true : "You must accept the terms.") }}
126
+ label="I accept the terms and conditions"
127
+ description="Required to create the project."
128
+ />
67
129
  </FormFields>
68
130
 
69
131
  <button
@@ -18,9 +18,11 @@ const navTabs = [
18
18
 
19
19
  const sideNavTabs = [
20
20
  { id: "general", label: "General" },
21
+ { id: "build-settings", label: "Build settings" },
22
+ { id: "environment-variables", label: "Environment variables" },
23
+ { id: "domains", label: "Domains" },
21
24
  { id: "authentication", label: "Authentication" },
22
- { id: "notifications", label: "Notifications" },
23
- { id: "billing", label: "Billing" },
25
+ { id: "marketplace", label: "Marketplace" },
24
26
  ];
25
27
 
26
28
  function useHashRoute(fallback: string) {
@@ -0,0 +1,81 @@
1
+ import type { Story } from "@ladle/react";
2
+ import { useEffect, useState } from "react";
3
+
4
+ import { TaskProgress, type TaskProgressStep } from "../components/task-progress";
5
+
6
+ const SECTION_HEADER = "type-text-xs font-medium text-subtle-foreground uppercase tracking-wide pt-4";
7
+
8
+ const beaconSteps: TaskProgressStep[] = [
9
+ { id: "init", label: "Initialize MCP connection", status: "done" },
10
+ { id: "fetch", label: "Fetch tools and resources", status: "done" },
11
+ { id: "compat", label: "Check ChatGPT & Claude.ai compatibility", status: "done" },
12
+ ];
13
+
14
+ const partialSteps: TaskProgressStep[] = [
15
+ { id: "a", label: "Reading project metadata", status: "done" },
16
+ { id: "b", label: "Fetching MCP server manifest", status: "running" },
17
+ { id: "c", label: "Preparing your submission", status: "pending" },
18
+ ];
19
+
20
+ const allDoneSteps: TaskProgressStep[] = [
21
+ { id: "a", label: "Reading project metadata", status: "done" },
22
+ { id: "b", label: "Fetching MCP server manifest", status: "done" },
23
+ { id: "c", label: "Preparing your submission", status: "done" },
24
+ ];
25
+
26
+ const STEP_INTERVAL_MS = 1200;
27
+
28
+ function AnimatedExample() {
29
+ const [activeIdx, setActiveIdx] = useState(0);
30
+
31
+ const labels = ["Reading project metadata", "Fetching MCP server manifest", "Preparing your submission"];
32
+
33
+ useEffect(() => {
34
+ if (activeIdx >= labels.length) {
35
+ return;
36
+ }
37
+ const timeoutId = setTimeout(() => setActiveIdx((prev) => prev + 1), STEP_INTERVAL_MS);
38
+ return () => clearTimeout(timeoutId);
39
+ }, [activeIdx, labels.length]);
40
+
41
+ const steps: TaskProgressStep[] = labels.map((label, idx) => ({
42
+ id: String(idx),
43
+ label,
44
+ status: idx < activeIdx ? "done" : idx === activeIdx ? "running" : "pending",
45
+ }));
46
+ const allDone = activeIdx >= labels.length;
47
+
48
+ return <TaskProgress steps={steps} trailingLabel={allDone ? "Almost there…" : undefined} />;
49
+ }
50
+
51
+ export const AllVariants: Story = () => (
52
+ <div className="flex flex-col gap-8 p-8 max-w-[640px]">
53
+ <div>
54
+ <p className={SECTION_HEADER}>In-progress (running step in the middle)</p>
55
+ <div className="mt-4">
56
+ <TaskProgress steps={partialSteps} />
57
+ </div>
58
+ </div>
59
+
60
+ <div>
61
+ <p className={SECTION_HEADER}>All done</p>
62
+ <div className="mt-4">
63
+ <TaskProgress steps={allDoneSteps} />
64
+ </div>
65
+ </div>
66
+
67
+ <div>
68
+ <p className={SECTION_HEADER}>All done + trailing "Running checks…" row</p>
69
+ <div className="mt-4">
70
+ <TaskProgress steps={beaconSteps} trailingLabel="Running checks…" />
71
+ </div>
72
+ </div>
73
+
74
+ <div>
75
+ <p className={SECTION_HEADER}>Animated (timer-driven, mirrors the submission-prefill flow)</p>
76
+ <div className="mt-4">
77
+ <AnimatedExample />
78
+ </div>
79
+ </div>
80
+ </div>
81
+ );
@@ -0,0 +1,64 @@
1
+ import type { Story } from "@ladle/react";
2
+ import { useState } from "react";
3
+
4
+ import { WizardProgress, type WizardStep, WizardSteps } from "../components/wizard";
5
+
6
+ const SECTION_HEADER = "type-text-xs font-medium text-muted-foreground uppercase tracking-wide pt-4";
7
+
8
+ const steps: WizardStep[] = [
9
+ { id: "overview", label: "Overview" },
10
+ { id: "branding", label: "Branding & metadata" },
11
+ { id: "auth", label: "Authentication" },
12
+ { id: "tools", label: "Tools & test cases" },
13
+ { id: "review", label: "Review & submit" },
14
+ ];
15
+
16
+ export const AllVariants: Story = () => {
17
+ const [activeIdx, setActiveIdx] = useState(1);
18
+
19
+ return (
20
+ <div className="flex flex-col gap-10 p-8">
21
+ {/* Full rail (steps + progress) */}
22
+ <div>
23
+ <p className={SECTION_HEADER}>Full rail — steps + progress</p>
24
+ <div className="mt-4 flex gap-6">
25
+ <aside className="basis-56 shrink-0 flex flex-col gap-4 self-start">
26
+ <WizardSteps steps={steps} activeIdx={activeIdx} onSelect={setActiveIdx} ariaLabel="Submission steps" />
27
+ <WizardProgress current={activeIdx + 1} total={steps.length} />
28
+ </aside>
29
+ <div className="flex-1 rounded-md border p-4">
30
+ <p className="type-text-sm text-muted-foreground">Content for step "{steps[activeIdx]?.label}"</p>
31
+ </div>
32
+ </div>
33
+ </div>
34
+
35
+ {/* Steps only */}
36
+ <div>
37
+ <p className={SECTION_HEADER}>Steps only</p>
38
+ <div className="mt-4 max-w-56">
39
+ <WizardSteps steps={steps} activeIdx={activeIdx} onSelect={setActiveIdx} />
40
+ </div>
41
+ </div>
42
+
43
+ {/* Progress only — various positions */}
44
+ <div>
45
+ <p className={SECTION_HEADER}>Progress — first step</p>
46
+ <div className="mt-4 max-w-56">
47
+ <WizardProgress current={1} total={5} />
48
+ </div>
49
+ </div>
50
+ <div>
51
+ <p className={SECTION_HEADER}>Progress — mid-flow</p>
52
+ <div className="mt-4 max-w-56">
53
+ <WizardProgress current={3} total={5} />
54
+ </div>
55
+ </div>
56
+ <div>
57
+ <p className={SECTION_HEADER}>Progress — complete</p>
58
+ <div className="mt-4 max-w-56">
59
+ <WizardProgress current={5} total={5} />
60
+ </div>
61
+ </div>
62
+ </div>
63
+ );
64
+ };
@@ -113,6 +113,15 @@
113
113
  --animate-beacon-ring-pulse: beacon-ring-pulse 2.2s ease-in-out infinite;
114
114
  }
115
115
 
116
+ @keyframes shimmer-text {
117
+ from {
118
+ background-position: 100% center;
119
+ }
120
+ to {
121
+ background-position: 0% center;
122
+ }
123
+ }
124
+
116
125
  @keyframes alpic-ride {
117
126
  0% {
118
127
  transform: translate(0px, 0px);
@@ -155,14 +164,12 @@
155
164
  @keyframes beacon-ring-pulse {
156
165
  0%,
157
166
  100% {
158
- opacity: 0.88;
167
+ opacity: 0.55;
159
168
  transform: scale(1);
160
- filter: drop-shadow(0 0 0 rgba(59, 130, 246, 0));
161
169
  }
162
170
  50% {
163
- opacity: 1;
171
+ opacity: 0.9;
164
172
  transform: scale(1.02);
165
- filter: drop-shadow(0 0 8px rgba(59, 130, 246, 0.24));
166
173
  }
167
174
  }
168
175