gitspace 0.2.0-rc.1
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/.claude/settings.local.json +21 -0
- package/.gitspace/bundle.json +50 -0
- package/.gitspace/select/01-status.sh +40 -0
- package/.gitspace/setup/01-install-deps.sh +12 -0
- package/.gitspace/setup/02-typecheck.sh +16 -0
- package/AGENTS.md +439 -0
- package/CLAUDE.md +1 -0
- package/LICENSE +25 -0
- package/README.md +607 -0
- package/bin/gssh +62 -0
- package/bun.lock +647 -0
- package/docs/CONNECTION.md +623 -0
- package/docs/GATEWAY-WORKER.md +319 -0
- package/docs/GETTING-STARTED.md +448 -0
- package/docs/GITSPACE-PLATFORM.md +1819 -0
- package/docs/INFRASTRUCTURE.md +1347 -0
- package/docs/PROTOCOL.md +619 -0
- package/docs/QUICKSTART.md +174 -0
- package/docs/RELAY.md +327 -0
- package/docs/REMOTE-DESIGN.md +549 -0
- package/docs/ROADMAP.md +564 -0
- package/docs/SITE_DOCS_FIGMA_MAKE.md +1167 -0
- package/docs/STACK-DESIGN.md +588 -0
- package/docs/UNIFIED_ARCHITECTURE.md +292 -0
- package/experiments/pty-benchmark.ts +148 -0
- package/experiments/pty-latency.ts +100 -0
- package/experiments/router/client.ts +199 -0
- package/experiments/router/protocol.ts +74 -0
- package/experiments/router/router.ts +217 -0
- package/experiments/router/session.ts +180 -0
- package/experiments/router/test.ts +133 -0
- package/experiments/socket-bandwidth.ts +77 -0
- package/homebrew/gitspace.rb +45 -0
- package/landing-page/ATTRIBUTIONS.md +3 -0
- package/landing-page/README.md +11 -0
- package/landing-page/bun.lock +801 -0
- package/landing-page/guidelines/Guidelines.md +61 -0
- package/landing-page/index.html +37 -0
- package/landing-page/package.json +90 -0
- package/landing-page/postcss.config.mjs +15 -0
- package/landing-page/public/_redirects +1 -0
- package/landing-page/public/favicon.png +0 -0
- package/landing-page/src/app/App.tsx +53 -0
- package/landing-page/src/app/components/figma/ImageWithFallback.tsx +27 -0
- package/landing-page/src/app/components/ui/accordion.tsx +66 -0
- package/landing-page/src/app/components/ui/alert-dialog.tsx +157 -0
- package/landing-page/src/app/components/ui/alert.tsx +66 -0
- package/landing-page/src/app/components/ui/aspect-ratio.tsx +11 -0
- package/landing-page/src/app/components/ui/avatar.tsx +53 -0
- package/landing-page/src/app/components/ui/badge.tsx +46 -0
- package/landing-page/src/app/components/ui/breadcrumb.tsx +109 -0
- package/landing-page/src/app/components/ui/button.tsx +57 -0
- package/landing-page/src/app/components/ui/calendar.tsx +75 -0
- package/landing-page/src/app/components/ui/card.tsx +92 -0
- package/landing-page/src/app/components/ui/carousel.tsx +241 -0
- package/landing-page/src/app/components/ui/chart.tsx +353 -0
- package/landing-page/src/app/components/ui/checkbox.tsx +32 -0
- package/landing-page/src/app/components/ui/collapsible.tsx +33 -0
- package/landing-page/src/app/components/ui/command.tsx +177 -0
- package/landing-page/src/app/components/ui/context-menu.tsx +252 -0
- package/landing-page/src/app/components/ui/dialog.tsx +135 -0
- package/landing-page/src/app/components/ui/drawer.tsx +132 -0
- package/landing-page/src/app/components/ui/dropdown-menu.tsx +257 -0
- package/landing-page/src/app/components/ui/form.tsx +168 -0
- package/landing-page/src/app/components/ui/hover-card.tsx +44 -0
- package/landing-page/src/app/components/ui/input-otp.tsx +77 -0
- package/landing-page/src/app/components/ui/input.tsx +21 -0
- package/landing-page/src/app/components/ui/label.tsx +24 -0
- package/landing-page/src/app/components/ui/menubar.tsx +276 -0
- package/landing-page/src/app/components/ui/navigation-menu.tsx +168 -0
- package/landing-page/src/app/components/ui/pagination.tsx +127 -0
- package/landing-page/src/app/components/ui/popover.tsx +48 -0
- package/landing-page/src/app/components/ui/progress.tsx +31 -0
- package/landing-page/src/app/components/ui/radio-group.tsx +45 -0
- package/landing-page/src/app/components/ui/resizable.tsx +56 -0
- package/landing-page/src/app/components/ui/scroll-area.tsx +58 -0
- package/landing-page/src/app/components/ui/select.tsx +189 -0
- package/landing-page/src/app/components/ui/separator.tsx +28 -0
- package/landing-page/src/app/components/ui/sheet.tsx +139 -0
- package/landing-page/src/app/components/ui/sidebar.tsx +726 -0
- package/landing-page/src/app/components/ui/skeleton.tsx +13 -0
- package/landing-page/src/app/components/ui/slider.tsx +63 -0
- package/landing-page/src/app/components/ui/sonner.tsx +25 -0
- package/landing-page/src/app/components/ui/switch.tsx +31 -0
- package/landing-page/src/app/components/ui/table.tsx +116 -0
- package/landing-page/src/app/components/ui/tabs.tsx +66 -0
- package/landing-page/src/app/components/ui/textarea.tsx +18 -0
- package/landing-page/src/app/components/ui/toggle-group.tsx +73 -0
- package/landing-page/src/app/components/ui/toggle.tsx +47 -0
- package/landing-page/src/app/components/ui/tooltip.tsx +61 -0
- package/landing-page/src/app/components/ui/use-mobile.ts +21 -0
- package/landing-page/src/app/components/ui/utils.ts +6 -0
- package/landing-page/src/components/docs/DocsContent.tsx +718 -0
- package/landing-page/src/components/docs/DocsSidebar.tsx +84 -0
- package/landing-page/src/components/landing/CTA.tsx +59 -0
- package/landing-page/src/components/landing/Comparison.tsx +84 -0
- package/landing-page/src/components/landing/FaultyTerminal.tsx +424 -0
- package/landing-page/src/components/landing/Features.tsx +201 -0
- package/landing-page/src/components/landing/Hero.tsx +142 -0
- package/landing-page/src/components/landing/Pricing.tsx +140 -0
- package/landing-page/src/components/landing/Roadmap.tsx +86 -0
- package/landing-page/src/components/landing/Security.tsx +81 -0
- package/landing-page/src/components/landing/TerminalWindow.tsx +27 -0
- package/landing-page/src/components/landing/UseCases.tsx +55 -0
- package/landing-page/src/components/landing/Workflow.tsx +101 -0
- package/landing-page/src/components/layout/DashboardNavbar.tsx +37 -0
- package/landing-page/src/components/layout/Footer.tsx +55 -0
- package/landing-page/src/components/layout/LandingNavbar.tsx +82 -0
- package/landing-page/src/components/ui/badge.tsx +39 -0
- package/landing-page/src/components/ui/breadcrumb.tsx +115 -0
- package/landing-page/src/components/ui/button.tsx +57 -0
- package/landing-page/src/components/ui/card.tsx +79 -0
- package/landing-page/src/components/ui/mock-terminal.tsx +68 -0
- package/landing-page/src/components/ui/separator.tsx +28 -0
- package/landing-page/src/lib/utils.ts +6 -0
- package/landing-page/src/main.tsx +10 -0
- package/landing-page/src/pages/Dashboard.tsx +133 -0
- package/landing-page/src/pages/DocsPage.tsx +79 -0
- package/landing-page/src/pages/LandingPage.tsx +31 -0
- package/landing-page/src/pages/TerminalView.tsx +106 -0
- package/landing-page/src/styles/fonts.css +0 -0
- package/landing-page/src/styles/index.css +3 -0
- package/landing-page/src/styles/tailwind.css +4 -0
- package/landing-page/src/styles/theme.css +181 -0
- package/landing-page/vite.config.ts +19 -0
- package/npm/darwin-arm64/bin/gssh +0 -0
- package/npm/darwin-arm64/package.json +20 -0
- package/package.json +74 -0
- package/scripts/build.ts +284 -0
- package/scripts/release.ts +140 -0
- package/src/__tests__/test-utils.ts +298 -0
- package/src/commands/__tests__/serve-messages.test.ts +190 -0
- package/src/commands/access.ts +298 -0
- package/src/commands/add.ts +452 -0
- package/src/commands/auth.ts +364 -0
- package/src/commands/connect.ts +287 -0
- package/src/commands/directory.ts +16 -0
- package/src/commands/host.ts +396 -0
- package/src/commands/identity.ts +184 -0
- package/src/commands/list.ts +200 -0
- package/src/commands/relay.ts +315 -0
- package/src/commands/remove.ts +241 -0
- package/src/commands/serve.ts +1493 -0
- package/src/commands/share.ts +456 -0
- package/src/commands/status.ts +125 -0
- package/src/commands/switch.ts +353 -0
- package/src/commands/tmux.ts +317 -0
- package/src/core/__tests__/access.test.ts +240 -0
- package/src/core/access.ts +277 -0
- package/src/core/bundle.ts +342 -0
- package/src/core/config.ts +510 -0
- package/src/core/git.ts +317 -0
- package/src/core/github.ts +151 -0
- package/src/core/identity.ts +631 -0
- package/src/core/linear.ts +225 -0
- package/src/core/shell.ts +161 -0
- package/src/core/trusted-relays.ts +315 -0
- package/src/index.ts +821 -0
- package/src/lib/remote-session/index.ts +7 -0
- package/src/lib/remote-session/protocol.ts +267 -0
- package/src/lib/remote-session/session-handler.ts +581 -0
- package/src/lib/remote-session/workspace-scanner.ts +167 -0
- package/src/lib/tmux-lite/README.md +81 -0
- package/src/lib/tmux-lite/cli.ts +796 -0
- package/src/lib/tmux-lite/crypto/__tests__/helpers/handshake-runner.ts +349 -0
- package/src/lib/tmux-lite/crypto/__tests__/helpers/mock-relay.ts +291 -0
- package/src/lib/tmux-lite/crypto/__tests__/helpers/test-identities.ts +142 -0
- package/src/lib/tmux-lite/crypto/__tests__/integration/authorization.integration.test.ts +339 -0
- package/src/lib/tmux-lite/crypto/__tests__/integration/e2e-communication.integration.test.ts +477 -0
- package/src/lib/tmux-lite/crypto/__tests__/integration/error-handling.integration.test.ts +499 -0
- package/src/lib/tmux-lite/crypto/__tests__/integration/handshake.integration.test.ts +371 -0
- package/src/lib/tmux-lite/crypto/__tests__/integration/security.integration.test.ts +573 -0
- package/src/lib/tmux-lite/crypto/access-control.test.ts +512 -0
- package/src/lib/tmux-lite/crypto/access-control.ts +320 -0
- package/src/lib/tmux-lite/crypto/frames.test.ts +262 -0
- package/src/lib/tmux-lite/crypto/frames.ts +141 -0
- package/src/lib/tmux-lite/crypto/handshake.ts +894 -0
- package/src/lib/tmux-lite/crypto/identity.test.ts +220 -0
- package/src/lib/tmux-lite/crypto/identity.ts +286 -0
- package/src/lib/tmux-lite/crypto/index.ts +51 -0
- package/src/lib/tmux-lite/crypto/invites.test.ts +381 -0
- package/src/lib/tmux-lite/crypto/invites.ts +215 -0
- package/src/lib/tmux-lite/crypto/keyexchange.ts +435 -0
- package/src/lib/tmux-lite/crypto/keys.test.ts +58 -0
- package/src/lib/tmux-lite/crypto/keys.ts +47 -0
- package/src/lib/tmux-lite/crypto/secretbox.test.ts +169 -0
- package/src/lib/tmux-lite/crypto/secretbox.ts +124 -0
- package/src/lib/tmux-lite/handshake-handler.ts +451 -0
- package/src/lib/tmux-lite/protocol.test.ts +307 -0
- package/src/lib/tmux-lite/protocol.ts +266 -0
- package/src/lib/tmux-lite/relay-client.ts +506 -0
- package/src/lib/tmux-lite/server.ts +1250 -0
- package/src/lib/tmux-lite/shell-integration.sh +37 -0
- package/src/lib/tmux-lite/terminal-queries.test.ts +54 -0
- package/src/lib/tmux-lite/terminal-queries.ts +49 -0
- package/src/relay/__tests__/e2e-flow.test.ts +1284 -0
- package/src/relay/__tests__/helpers/auth.ts +354 -0
- package/src/relay/__tests__/helpers/ports.ts +51 -0
- package/src/relay/__tests__/protocol-validation.test.ts +265 -0
- package/src/relay/authorization.ts +303 -0
- package/src/relay/embedded-assets.generated.d.ts +15 -0
- package/src/relay/identity.ts +352 -0
- package/src/relay/index.ts +57 -0
- package/src/relay/pipes.test.ts +427 -0
- package/src/relay/pipes.ts +195 -0
- package/src/relay/protocol.ts +804 -0
- package/src/relay/registries.test.ts +437 -0
- package/src/relay/registries.ts +593 -0
- package/src/relay/server.test.ts +1323 -0
- package/src/relay/server.ts +1092 -0
- package/src/relay/signing.ts +238 -0
- package/src/relay/types.ts +69 -0
- package/src/serve/client-session-manager.ts +622 -0
- package/src/serve/daemon.ts +497 -0
- package/src/serve/pty-session.ts +236 -0
- package/src/serve/types.ts +169 -0
- package/src/shared/components/Flow.tsx +453 -0
- package/src/shared/components/Flow.tui.tsx +343 -0
- package/src/shared/components/Flow.web.tsx +442 -0
- package/src/shared/components/Inbox.tsx +446 -0
- package/src/shared/components/Inbox.tui.tsx +262 -0
- package/src/shared/components/Inbox.web.tsx +329 -0
- package/src/shared/components/MachineList.tsx +187 -0
- package/src/shared/components/MachineList.tui.tsx +161 -0
- package/src/shared/components/MachineList.web.tsx +210 -0
- package/src/shared/components/ProjectList.tsx +176 -0
- package/src/shared/components/ProjectList.tui.tsx +109 -0
- package/src/shared/components/ProjectList.web.tsx +143 -0
- package/src/shared/components/SpacesBrowser.tsx +332 -0
- package/src/shared/components/SpacesBrowser.tui.tsx +163 -0
- package/src/shared/components/SpacesBrowser.web.tsx +221 -0
- package/src/shared/components/index.ts +103 -0
- package/src/shared/hooks/index.ts +16 -0
- package/src/shared/hooks/useNavigation.ts +226 -0
- package/src/shared/index.ts +122 -0
- package/src/shared/providers/LocalMachineProvider.ts +425 -0
- package/src/shared/providers/MachineProvider.ts +165 -0
- package/src/shared/providers/RemoteMachineProvider.ts +444 -0
- package/src/shared/providers/index.ts +26 -0
- package/src/shared/types.ts +145 -0
- package/src/tui/adapters.ts +120 -0
- package/src/tui/app.tsx +1816 -0
- package/src/tui/components/Terminal.tsx +580 -0
- package/src/tui/hooks/index.ts +35 -0
- package/src/tui/hooks/useAppState.ts +314 -0
- package/src/tui/hooks/useDaemonStatus.ts +174 -0
- package/src/tui/hooks/useInboxTUI.ts +113 -0
- package/src/tui/hooks/useRemoteMachines.ts +209 -0
- package/src/tui/index.ts +24 -0
- package/src/tui/state.ts +299 -0
- package/src/tui/terminal-bracketed-paste.test.ts +45 -0
- package/src/tui/terminal-bracketed-paste.ts +47 -0
- package/src/types/bundle.ts +112 -0
- package/src/types/config.ts +89 -0
- package/src/types/errors.ts +206 -0
- package/src/types/identity.ts +284 -0
- package/src/types/workspace-fuzzy.ts +49 -0
- package/src/types/workspace.ts +151 -0
- package/src/utils/bun-socket-writer.ts +80 -0
- package/src/utils/deps.ts +127 -0
- package/src/utils/fuzzy-match.ts +125 -0
- package/src/utils/logger.ts +127 -0
- package/src/utils/markdown.ts +254 -0
- package/src/utils/onboarding.ts +229 -0
- package/src/utils/prompts.ts +114 -0
- package/src/utils/run-commands.ts +112 -0
- package/src/utils/run-scripts.ts +142 -0
- package/src/utils/sanitize.ts +98 -0
- package/src/utils/secrets.ts +122 -0
- package/src/utils/shell-escape.ts +40 -0
- package/src/utils/utf8.ts +79 -0
- package/src/utils/workspace-state.ts +47 -0
- package/src/web/README.md +73 -0
- package/src/web/bun.lock +575 -0
- package/src/web/eslint.config.js +23 -0
- package/src/web/index.html +16 -0
- package/src/web/package.json +37 -0
- package/src/web/public/vite.svg +1 -0
- package/src/web/src/App.tsx +604 -0
- package/src/web/src/assets/react.svg +1 -0
- package/src/web/src/components/Terminal.tsx +207 -0
- package/src/web/src/hooks/useRelayConnection.ts +224 -0
- package/src/web/src/hooks/useTerminal.ts +699 -0
- package/src/web/src/index.css +55 -0
- package/src/web/src/lib/crypto/__tests__/web-terminal.test.ts +1158 -0
- package/src/web/src/lib/crypto/frames.ts +205 -0
- package/src/web/src/lib/crypto/handshake.ts +396 -0
- package/src/web/src/lib/crypto/identity.ts +128 -0
- package/src/web/src/lib/crypto/keyexchange.ts +246 -0
- package/src/web/src/lib/crypto/relay-signing.ts +53 -0
- package/src/web/src/lib/invite.ts +58 -0
- package/src/web/src/lib/storage/identity-store.ts +94 -0
- package/src/web/src/main.tsx +10 -0
- package/src/web/src/types/identity.ts +45 -0
- package/src/web/tsconfig.app.json +28 -0
- package/src/web/tsconfig.json +7 -0
- package/src/web/tsconfig.node.json +26 -0
- package/src/web/vite.config.ts +31 -0
- package/todo-security.md +92 -0
- package/tsconfig.json +23 -0
- package/worker/.wrangler/state/v3/d1/miniflare-D1DatabaseObject/12b7107e435bf1b9a8713a7f320472a63e543104d633d89a26f8d21f4e4ef182.sqlite +0 -0
- package/worker/.wrangler/state/v3/d1/miniflare-D1DatabaseObject/12b7107e435bf1b9a8713a7f320472a63e543104d633d89a26f8d21f4e4ef182.sqlite-shm +0 -0
- package/worker/.wrangler/state/v3/d1/miniflare-D1DatabaseObject/12b7107e435bf1b9a8713a7f320472a63e543104d633d89a26f8d21f4e4ef182.sqlite-wal +0 -0
- package/worker/.wrangler/state/v3/d1/miniflare-D1DatabaseObject/1a1ac3db1ab86ecf712f90322868a9aabc2c7dc9fe2dfbe94f9b075096276b0f.sqlite +0 -0
- package/worker/.wrangler/state/v3/d1/miniflare-D1DatabaseObject/1a1ac3db1ab86ecf712f90322868a9aabc2c7dc9fe2dfbe94f9b075096276b0f.sqlite-shm +0 -0
- package/worker/.wrangler/state/v3/d1/miniflare-D1DatabaseObject/1a1ac3db1ab86ecf712f90322868a9aabc2c7dc9fe2dfbe94f9b075096276b0f.sqlite-wal +0 -0
- package/worker/bun.lock +237 -0
- package/worker/package.json +22 -0
- package/worker/schema.sql +96 -0
- package/worker/src/handlers/auth.ts +451 -0
- package/worker/src/handlers/subdomains.ts +376 -0
- package/worker/src/handlers/user.ts +98 -0
- package/worker/src/index.ts +70 -0
- package/worker/src/middleware/auth.ts +152 -0
- package/worker/src/services/cloudflare.ts +609 -0
- package/worker/src/types.ts +96 -0
- package/worker/tsconfig.json +15 -0
- package/worker/wrangler.toml +26 -0
|
@@ -0,0 +1,201 @@
|
|
|
1
|
+
import { TerminalWindow } from "./TerminalWindow";
|
|
2
|
+
import { GitBranch, Globe, Layers, ArrowRight, Shield, Smartphone, Laptop } from "lucide-react";
|
|
3
|
+
import { Badge } from "../../app/components/ui/badge";
|
|
4
|
+
|
|
5
|
+
export function Features() {
|
|
6
|
+
return (
|
|
7
|
+
<section id="features" className="py-24 bg-black relative">
|
|
8
|
+
<div className="container px-4 mx-auto">
|
|
9
|
+
<div className="text-center mb-20">
|
|
10
|
+
<h2 className="text-3xl md:text-5xl font-bold mb-4">One tool. Three superpowers.</h2>
|
|
11
|
+
<div className="h-1 w-20 bg-green-500 mx-auto rounded-full" />
|
|
12
|
+
</div>
|
|
13
|
+
|
|
14
|
+
<div className="space-y-32">
|
|
15
|
+
|
|
16
|
+
{/* SPACES */}
|
|
17
|
+
<div className="grid lg:grid-cols-2 gap-12 items-center">
|
|
18
|
+
<div>
|
|
19
|
+
<div className="inline-flex items-center gap-2 text-green-400 font-mono text-sm mb-4">
|
|
20
|
+
<GitBranch className="w-5 h-5" />
|
|
21
|
+
<span>SPACES</span>
|
|
22
|
+
</div>
|
|
23
|
+
<h3 className="text-3xl md:text-4xl font-bold mb-6">Work on everything at once.</h3>
|
|
24
|
+
<p className="text-lg text-zinc-400 leading-relaxed mb-8">
|
|
25
|
+
Git worktrees let you have multiple branches checked out simultaneously. No more stashing. No more "let me finish this first." Jump between features instantly.
|
|
26
|
+
</p>
|
|
27
|
+
<ul className="space-y-3 text-zinc-300">
|
|
28
|
+
<li className="flex items-start">
|
|
29
|
+
<ArrowRight className="w-5 h-5 text-green-500 mr-3 shrink-0 mt-0.5" />
|
|
30
|
+
<span>Each workspace is a full git worktree</span>
|
|
31
|
+
</li>
|
|
32
|
+
<li className="flex items-start">
|
|
33
|
+
<ArrowRight className="w-5 h-5 text-green-500 mr-3 shrink-0 mt-0.5" />
|
|
34
|
+
<span>Run different branches simultaneously</span>
|
|
35
|
+
</li>
|
|
36
|
+
<li className="flex items-start">
|
|
37
|
+
<ArrowRight className="w-5 h-5 text-green-500 mr-3 shrink-0 mt-0.5" />
|
|
38
|
+
<span>Custom setup scripts per project</span>
|
|
39
|
+
</li>
|
|
40
|
+
<li className="flex items-start">
|
|
41
|
+
<ArrowRight className="w-5 h-5 text-green-500 mr-3 shrink-0 mt-0.5" />
|
|
42
|
+
<span>Integrates with Linear issues</span>
|
|
43
|
+
</li>
|
|
44
|
+
</ul>
|
|
45
|
+
</div>
|
|
46
|
+
<div>
|
|
47
|
+
<TerminalWindow title="bash">
|
|
48
|
+
<div className="space-y-2 font-mono text-sm">
|
|
49
|
+
<div className="text-zinc-500"># Install</div>
|
|
50
|
+
<div className="text-zinc-400">$ bun install -g https://github.com/inkibra/gitspace.sh</div>
|
|
51
|
+
<br />
|
|
52
|
+
<div className="text-zinc-500"># Launch the TUI</div>
|
|
53
|
+
<div className="text-zinc-400">$ gssh</div>
|
|
54
|
+
<br />
|
|
55
|
+
<div className="text-zinc-500"># Or use commands</div>
|
|
56
|
+
<div className="text-zinc-400">$ gssh add project</div>
|
|
57
|
+
<div className="text-green-400">✓ Added project: my-api</div>
|
|
58
|
+
<div className="text-zinc-400">$ gssh add feature-auth</div>
|
|
59
|
+
<div className="text-green-400">✓ Created workspace: feature-auth</div>
|
|
60
|
+
</div>
|
|
61
|
+
</TerminalWindow>
|
|
62
|
+
</div>
|
|
63
|
+
</div>
|
|
64
|
+
|
|
65
|
+
{/* REMOTE */}
|
|
66
|
+
<div className="grid lg:grid-cols-2 gap-12 items-center lg:flex-row-reverse">
|
|
67
|
+
<div className="lg:order-2">
|
|
68
|
+
<div className="inline-flex items-center gap-2 text-blue-400 font-mono text-sm mb-4">
|
|
69
|
+
<Globe className="w-5 h-5" />
|
|
70
|
+
<span>REMOTE</span>
|
|
71
|
+
</div>
|
|
72
|
+
<h3 className="text-3xl md:text-4xl font-bold mb-6">Your terminal, from anywhere.</h3>
|
|
73
|
+
<p className="text-lg text-zinc-400 leading-relaxed mb-8">
|
|
74
|
+
Start an AI agent on a big task. Close your laptop. Check in from your phone.
|
|
75
|
+
Get notified when it's done. End-to-end encrypted - we can't see your terminal.
|
|
76
|
+
</p>
|
|
77
|
+
<ul className="space-y-3 text-zinc-300">
|
|
78
|
+
<li className="flex items-start">
|
|
79
|
+
<ArrowRight className="w-5 h-5 text-blue-500 mr-3 shrink-0 mt-0.5" />
|
|
80
|
+
<span>Encrypted access from your phone or any device</span>
|
|
81
|
+
</li>
|
|
82
|
+
<li className="flex items-start">
|
|
83
|
+
<ArrowRight className="w-5 h-5 text-blue-500 mr-3 shrink-0 mt-0.5" />
|
|
84
|
+
<div className="flex flex-col">
|
|
85
|
+
<span className="text-zinc-300">Public subdomains & port forwarding</span>
|
|
86
|
+
<span className="text-xs font-semibold text-blue-500 mt-1 uppercase tracking-wider">Coming Soon</span>
|
|
87
|
+
</div>
|
|
88
|
+
</li>
|
|
89
|
+
<li className="flex items-start">
|
|
90
|
+
<ArrowRight className="w-5 h-5 text-blue-500 mr-3 shrink-0 mt-0.5" />
|
|
91
|
+
<span>End-to-end encrypted relay — we can't see your data</span>
|
|
92
|
+
</li>
|
|
93
|
+
<li className="flex items-start">
|
|
94
|
+
<ArrowRight className="w-5 h-5 text-blue-500 mr-3 shrink-0 mt-0.5" />
|
|
95
|
+
<span>Share sessions (view-only or full access)</span>
|
|
96
|
+
</li>
|
|
97
|
+
<li className="flex items-start">
|
|
98
|
+
<ArrowRight className="w-5 h-5 text-blue-500 mr-3 shrink-0 mt-0.5" />
|
|
99
|
+
<span>Inbox tracks what happened while you were away</span>
|
|
100
|
+
</li>
|
|
101
|
+
</ul>
|
|
102
|
+
</div>
|
|
103
|
+
<div className="lg:order-1">
|
|
104
|
+
<TerminalWindow title="Connection Architecture">
|
|
105
|
+
<div className="flex justify-between items-center text-center text-xs md:text-sm p-4">
|
|
106
|
+
<div className="flex flex-col items-center gap-2">
|
|
107
|
+
<Laptop className="w-8 h-8 text-zinc-300" />
|
|
108
|
+
<span className="font-bold">Your Mac</span>
|
|
109
|
+
<span className="text-green-500 text-[10px] border border-green-500/30 px-1 rounded bg-green-500/10">Has Keys</span>
|
|
110
|
+
</div>
|
|
111
|
+
|
|
112
|
+
<div className="flex-1 px-4 relative">
|
|
113
|
+
<div className="h-px bg-zinc-700 absolute top-1/2 left-0 right-0 -z-10" />
|
|
114
|
+
<div className="bg-black px-2 relative z-10 inline-block">
|
|
115
|
+
<Shield className="w-5 h-5 text-green-500 mx-auto mb-1" />
|
|
116
|
+
<span className="text-[10px] text-zinc-500 uppercase tracking-wider block bg-zinc-900 px-2 py-0.5 rounded border border-zinc-800">End-to-End Encrypted</span>
|
|
117
|
+
</div>
|
|
118
|
+
</div>
|
|
119
|
+
|
|
120
|
+
<div className="flex flex-col items-center gap-2">
|
|
121
|
+
<Smartphone className="w-8 h-8 text-zinc-300" />
|
|
122
|
+
<span className="font-bold">Your Phone</span>
|
|
123
|
+
<span className="text-green-500 text-[10px] border border-green-500/30 px-1 rounded bg-green-500/10">Has Keys</span>
|
|
124
|
+
</div>
|
|
125
|
+
</div>
|
|
126
|
+
<div className="text-center mt-4 pt-4 border-t border-zinc-800">
|
|
127
|
+
<div className="text-zinc-500 text-xs mb-1">gitspace.sh Relay</div>
|
|
128
|
+
<div className="text-zinc-600 text-[10px] italic">Blind relay - cannot read data</div>
|
|
129
|
+
</div>
|
|
130
|
+
</TerminalWindow>
|
|
131
|
+
</div>
|
|
132
|
+
</div>
|
|
133
|
+
|
|
134
|
+
{/* GIT STACK */}
|
|
135
|
+
<div className="grid lg:grid-cols-2 gap-12 items-center">
|
|
136
|
+
<div>
|
|
137
|
+
<div className="inline-flex items-center gap-2 text-purple-400 font-mono text-sm mb-4">
|
|
138
|
+
<Layers className="w-5 h-5" />
|
|
139
|
+
<span>GIT STACK</span>
|
|
140
|
+
<Badge variant="outline" className="ml-2 border-purple-500/30 text-purple-400 bg-purple-500/10 text-[10px] h-5">COMING SOON</Badge>
|
|
141
|
+
</div>
|
|
142
|
+
<h3 className="text-3xl md:text-4xl font-bold mb-6">AI turns your mess into clean PRs.</h3>
|
|
143
|
+
<p className="text-lg text-zinc-400 leading-relaxed mb-8">
|
|
144
|
+
You've been hacking for hours. Your branch has 47 commits touching 30 files.
|
|
145
|
+
Git Stack analyzes your changes and splits them into logical, reviewable PRs - automatically.
|
|
146
|
+
</p>
|
|
147
|
+
<ul className="space-y-3 text-zinc-300">
|
|
148
|
+
<li className="flex items-start">
|
|
149
|
+
<ArrowRight className="w-5 h-5 text-purple-500 mr-3 shrink-0 mt-0.5" />
|
|
150
|
+
<span>AI understands code dependencies</span>
|
|
151
|
+
</li>
|
|
152
|
+
<li className="flex items-start">
|
|
153
|
+
<ArrowRight className="w-5 h-5 text-purple-500 mr-3 shrink-0 mt-0.5" />
|
|
154
|
+
<span>Splits by logical units, not just files</span>
|
|
155
|
+
</li>
|
|
156
|
+
<li className="flex items-start">
|
|
157
|
+
<ArrowRight className="w-5 h-5 text-purple-500 mr-3 shrink-0 mt-0.5" />
|
|
158
|
+
<span>Creates dependent PR chains</span>
|
|
159
|
+
</li>
|
|
160
|
+
<li className="flex items-start">
|
|
161
|
+
<ArrowRight className="w-5 h-5 text-purple-500 mr-3 shrink-0 mt-0.5" />
|
|
162
|
+
<span>Explains its reasoning</span>
|
|
163
|
+
</li>
|
|
164
|
+
</ul>
|
|
165
|
+
</div>
|
|
166
|
+
<div>
|
|
167
|
+
<TerminalWindow title="bash">
|
|
168
|
+
<div className="space-y-2 font-mono text-sm">
|
|
169
|
+
<div className="text-zinc-400">$ gitspace stack</div>
|
|
170
|
+
<div className="text-blue-400 animate-pulse">Analyzing 47 commits across 30 files...</div>
|
|
171
|
+
<br />
|
|
172
|
+
<div className="text-zinc-300">Suggested stack:</div>
|
|
173
|
+
|
|
174
|
+
<div className="pl-4 border-l-2 border-purple-500/30 space-y-3 mt-2">
|
|
175
|
+
<div>
|
|
176
|
+
<div className="text-green-400 font-bold">PR #1: Add user authentication types</div>
|
|
177
|
+
<div className="text-zinc-500 text-xs">└─ src/types/auth.ts, src/types/user.ts</div>
|
|
178
|
+
</div>
|
|
179
|
+
<div>
|
|
180
|
+
<div className="text-green-400 font-bold">PR #2: Implement auth middleware</div>
|
|
181
|
+
<div className="text-zinc-500 text-xs">└─ src/middleware/auth.ts (depends on #1)</div>
|
|
182
|
+
</div>
|
|
183
|
+
<div>
|
|
184
|
+
<div className="text-green-400 font-bold">PR #3: Add login/logout endpoints</div>
|
|
185
|
+
<div className="text-zinc-500 text-xs">└─ src/routes/auth.ts (depends on #2)</div>
|
|
186
|
+
</div>
|
|
187
|
+
</div>
|
|
188
|
+
|
|
189
|
+
<div className="mt-4 pt-2 border-t border-zinc-800 text-zinc-500 text-xs">
|
|
190
|
+
[c] create stack [e] edit [?] explain reasoning
|
|
191
|
+
</div>
|
|
192
|
+
</div>
|
|
193
|
+
</TerminalWindow>
|
|
194
|
+
</div>
|
|
195
|
+
</div>
|
|
196
|
+
|
|
197
|
+
</div>
|
|
198
|
+
</div>
|
|
199
|
+
</section>
|
|
200
|
+
);
|
|
201
|
+
}
|
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
import { Button } from "../../app/components/ui/button";
|
|
2
|
+
import { Link } from "react-router-dom";
|
|
3
|
+
import { ArrowRight, Play, Check, Activity, Clock, Laptop, Smartphone, Github } from "lucide-react";
|
|
4
|
+
import { TerminalWindow } from "./TerminalWindow";
|
|
5
|
+
import FaultyTerminal from "./FaultyTerminal";
|
|
6
|
+
import { Badge } from "../../app/components/ui/badge";
|
|
7
|
+
|
|
8
|
+
export function Hero() {
|
|
9
|
+
return (
|
|
10
|
+
<section className="relative pt-32 pb-32 overflow-hidden px-4">
|
|
11
|
+
|
|
12
|
+
<div className="absolute inset-0 w-full h-full z-0 opacity-15">
|
|
13
|
+
<FaultyTerminal
|
|
14
|
+
scale={2}
|
|
15
|
+
gridMul={[2, 1]}
|
|
16
|
+
digitSize={1.2}
|
|
17
|
+
timeScale={0.5}
|
|
18
|
+
pause={false}
|
|
19
|
+
scanlineIntensity={0.35}
|
|
20
|
+
glitchAmount={1}
|
|
21
|
+
flickerAmount={1}
|
|
22
|
+
noiseAmp={1}
|
|
23
|
+
chromaticAberration={0}
|
|
24
|
+
dither={1}
|
|
25
|
+
curvature={0}
|
|
26
|
+
tint="#22c55e"
|
|
27
|
+
mouseReact={true}
|
|
28
|
+
mouseStrength={0.5}
|
|
29
|
+
pageLoadAnimation={false}
|
|
30
|
+
brightness={0.4}
|
|
31
|
+
/>
|
|
32
|
+
</div>
|
|
33
|
+
|
|
34
|
+
<div className="container px-4 mx-auto text-center relative z-10">
|
|
35
|
+
|
|
36
|
+
<h1 className="text-4xl md:text-6xl lg:text-7xl font-bold tracking-tight mb-6 bg-clip-text text-transparent bg-gradient-to-b from-white to-white/60">
|
|
37
|
+
The developer environment<br />for the AI age.
|
|
38
|
+
</h1>
|
|
39
|
+
|
|
40
|
+
<p className="text-xl md:text-2xl text-muted-foreground max-w-2xl mx-auto mb-10 leading-relaxed">
|
|
41
|
+
Parallel workspaces. Remote access. AI-assisted shipping.
|
|
42
|
+
</p>
|
|
43
|
+
|
|
44
|
+
<div className="flex flex-col sm:flex-row items-center justify-center gap-4 mb-20">
|
|
45
|
+
<a href="https://github.com/inkibra/gitspace.sh" target="_blank" rel="noopener noreferrer">
|
|
46
|
+
<Button size="lg" className="bg-white text-black hover:bg-gray-200 h-12 px-8 text-base">
|
|
47
|
+
<Github className="w-5 h-5 mr-2" />
|
|
48
|
+
Star on GitHub
|
|
49
|
+
</Button>
|
|
50
|
+
</a>
|
|
51
|
+
<Link to="/docs">
|
|
52
|
+
<Button variant="outline" size="lg" className="h-12 px-8 text-base border-white/10 hover:bg-white/5">
|
|
53
|
+
Read the Docs <ArrowRight className="ml-2 w-4 h-4" />
|
|
54
|
+
</Button>
|
|
55
|
+
</Link>
|
|
56
|
+
</div>
|
|
57
|
+
|
|
58
|
+
<div className="max-w-4xl mx-auto text-left relative group">
|
|
59
|
+
<div className="absolute -inset-1 bg-gradient-to-b from-green-500/20 to-transparent blur-2xl opacity-50 rounded-[2rem] group-hover:opacity-75 transition duration-500" />
|
|
60
|
+
|
|
61
|
+
<TerminalWindow title="gitspace" className="relative bg-black/90 backdrop-blur-xl">
|
|
62
|
+
<div className="flex flex-col md:flex-row gap-8 p-2 font-mono text-sm md:text-base">
|
|
63
|
+
|
|
64
|
+
{/* Left Column: Projects */}
|
|
65
|
+
<div className="w-full md:w-1/3 border-r border-zinc-800 md:pr-4">
|
|
66
|
+
<div className="text-zinc-500 mb-2 uppercase text-xs tracking-wider">Projects</div>
|
|
67
|
+
<div className="h-px bg-zinc-800 mb-4" />
|
|
68
|
+
<ul className="space-y-2">
|
|
69
|
+
<li className="flex items-center text-green-400 font-bold bg-zinc-900/50 -mx-2 px-2 py-1 rounded">
|
|
70
|
+
<span className="mr-2">></span> gitspace
|
|
71
|
+
</li>
|
|
72
|
+
<li className="text-zinc-400 px-2">website</li>
|
|
73
|
+
<li className="text-zinc-400 px-2">relay-server</li>
|
|
74
|
+
</ul>
|
|
75
|
+
</div>
|
|
76
|
+
|
|
77
|
+
{/* Right Column: Workspaces */}
|
|
78
|
+
<div className="w-full md:w-2/3">
|
|
79
|
+
<div className="text-zinc-500 mb-2 uppercase text-xs tracking-wider">Workspaces (gitspace)</div>
|
|
80
|
+
<div className="h-px bg-zinc-800 mb-4" />
|
|
81
|
+
|
|
82
|
+
<ul className="space-y-3">
|
|
83
|
+
<li className="flex items-center justify-between group/item p-1 hover:bg-zinc-900/50 rounded cursor-pointer transition-colors">
|
|
84
|
+
<div className="flex items-center text-white">
|
|
85
|
+
<span className="text-green-500 mr-2">></span> feat-remote-acl
|
|
86
|
+
</div>
|
|
87
|
+
<div className="flex items-center text-xs text-zinc-500">
|
|
88
|
+
[main] *
|
|
89
|
+
</div>
|
|
90
|
+
</li>
|
|
91
|
+
|
|
92
|
+
<li className="flex items-center justify-between group/item p-1 hover:bg-zinc-900/50 rounded cursor-pointer transition-colors">
|
|
93
|
+
<div className="flex items-center text-zinc-400">
|
|
94
|
+
<span className="w-3 mr-2"></span> fix-worktree-cleanup
|
|
95
|
+
</div>
|
|
96
|
+
<div className="flex items-center text-xs text-zinc-600">
|
|
97
|
+
[main]
|
|
98
|
+
</div>
|
|
99
|
+
</li>
|
|
100
|
+
|
|
101
|
+
<li className="flex items-center justify-between group/item p-1 hover:bg-zinc-900/50 rounded cursor-pointer transition-colors">
|
|
102
|
+
<div className="flex items-center text-zinc-400">
|
|
103
|
+
<span className="w-3 mr-2"></span> refactor-crypto
|
|
104
|
+
</div>
|
|
105
|
+
<div className="flex items-center text-xs text-zinc-600">
|
|
106
|
+
[dev-v2]
|
|
107
|
+
</div>
|
|
108
|
+
</li>
|
|
109
|
+
</ul>
|
|
110
|
+
</div>
|
|
111
|
+
|
|
112
|
+
</div>
|
|
113
|
+
|
|
114
|
+
{/* Status Bar */}
|
|
115
|
+
<div className="mt-8 pt-3 border-t border-zinc-800 text-xs text-zinc-500 flex flex-wrap gap-4">
|
|
116
|
+
<span><span className="text-zinc-300">[a]</span> add</span>
|
|
117
|
+
<span><span className="text-zinc-300">[s]</span> switch</span>
|
|
118
|
+
<span><span className="text-zinc-300">[r]</span> remove</span>
|
|
119
|
+
<span><span className="text-zinc-300">[i]</span> identity</span>
|
|
120
|
+
</div>
|
|
121
|
+
</TerminalWindow>
|
|
122
|
+
|
|
123
|
+
{/* Device Labels */}
|
|
124
|
+
<div className="flex justify-between mt-4 text-xs md:text-sm font-medium text-zinc-500 px-4">
|
|
125
|
+
<div className="flex items-center gap-2">
|
|
126
|
+
<Laptop className="w-4 h-4" />
|
|
127
|
+
<span>On your Mac</span>
|
|
128
|
+
</div>
|
|
129
|
+
<div className="flex items-center gap-2 text-green-500/80 animate-pulse">
|
|
130
|
+
<Smartphone className="w-4 h-4" />
|
|
131
|
+
<span>Watching from phone</span>
|
|
132
|
+
</div>
|
|
133
|
+
</div>
|
|
134
|
+
|
|
135
|
+
</div>
|
|
136
|
+
</div>
|
|
137
|
+
|
|
138
|
+
{/* Background Gradient */}
|
|
139
|
+
<div className="absolute top-0 left-1/2 -translate-x-1/2 w-full h-[600px] bg-[radial-gradient(ellipse_at_top,_var(--tw-gradient-stops))] from-green-950/10 via-black/0 to-black/0 pointer-events-none" />
|
|
140
|
+
</section>
|
|
141
|
+
);
|
|
142
|
+
}
|
|
@@ -0,0 +1,140 @@
|
|
|
1
|
+
import { Check, X, Github } from "lucide-react";
|
|
2
|
+
import { Button } from "../../app/components/ui/button";
|
|
3
|
+
import { Card, CardContent, CardHeader, CardTitle, CardFooter, CardDescription } from "../../app/components/ui/card";
|
|
4
|
+
import { Badge } from "../../app/components/ui/badge";
|
|
5
|
+
|
|
6
|
+
export function Pricing() {
|
|
7
|
+
const plans = [
|
|
8
|
+
{
|
|
9
|
+
name: "Local",
|
|
10
|
+
price: "Free",
|
|
11
|
+
period: "forever",
|
|
12
|
+
description: "For individual developers working locally.",
|
|
13
|
+
features: [
|
|
14
|
+
"Unlimited workspaces",
|
|
15
|
+
"TUI & CLI",
|
|
16
|
+
"Setup scripts",
|
|
17
|
+
"Linear integration",
|
|
18
|
+
"Git Stack (when released)"
|
|
19
|
+
],
|
|
20
|
+
notIncluded: [
|
|
21
|
+
"Remote access"
|
|
22
|
+
],
|
|
23
|
+
cta: "Star on GitHub",
|
|
24
|
+
variant: "outline",
|
|
25
|
+
link: "https://github.com/inkibra/gitspace.sh"
|
|
26
|
+
},
|
|
27
|
+
{
|
|
28
|
+
name: "Pro",
|
|
29
|
+
price: "$4.99",
|
|
30
|
+
period: "/month",
|
|
31
|
+
description: "Remote access and AI workflow superpowers.",
|
|
32
|
+
features: [
|
|
33
|
+
"Everything in Local",
|
|
34
|
+
"Remote access",
|
|
35
|
+
"Unlimited machines",
|
|
36
|
+
"Session sharing",
|
|
37
|
+
"90-day inbox history",
|
|
38
|
+
"Priority support"
|
|
39
|
+
],
|
|
40
|
+
cta: "Coming Soon",
|
|
41
|
+
variant: "default",
|
|
42
|
+
popular: true,
|
|
43
|
+
disabled: true
|
|
44
|
+
},
|
|
45
|
+
{
|
|
46
|
+
name: "Enterprise",
|
|
47
|
+
price: "Contact Us",
|
|
48
|
+
period: "",
|
|
49
|
+
description: "For organizations with custom security and scale needs.",
|
|
50
|
+
features: [
|
|
51
|
+
"Everything in Pro",
|
|
52
|
+
"Team sharing",
|
|
53
|
+
"Shared inbox",
|
|
54
|
+
"Audit logs",
|
|
55
|
+
"SSO & SAML",
|
|
56
|
+
"Dedicated support"
|
|
57
|
+
],
|
|
58
|
+
cta: "Coming Soon",
|
|
59
|
+
variant: "outline",
|
|
60
|
+
disabled: true
|
|
61
|
+
}
|
|
62
|
+
];
|
|
63
|
+
|
|
64
|
+
return (
|
|
65
|
+
<section id="pricing" className="py-24 bg-zinc-950">
|
|
66
|
+
<div className="container px-4 mx-auto">
|
|
67
|
+
<div className="text-center mb-16">
|
|
68
|
+
<h2 className="text-3xl md:text-5xl font-bold mb-4">Simple Pricing</h2>
|
|
69
|
+
<p className="text-zinc-400">Local-only is always free. Pay for remote access.</p>
|
|
70
|
+
</div>
|
|
71
|
+
|
|
72
|
+
<div className="grid md:grid-cols-3 gap-8 max-w-6xl mx-auto">
|
|
73
|
+
{plans.map((plan, i) => (
|
|
74
|
+
<Card key={i} className={`relative bg-zinc-900/50 border-zinc-800 hover:border-zinc-700 transition-all ${plan.popular ? 'border-green-500/50 shadow-green-900/20 shadow-2xl' : ''}`}>
|
|
75
|
+
{plan.popular && (
|
|
76
|
+
<div className="absolute -top-3 left-1/2 -translate-x-1/2">
|
|
77
|
+
<Badge className="bg-green-500 text-black hover:bg-green-600">Most Popular</Badge>
|
|
78
|
+
</div>
|
|
79
|
+
)}
|
|
80
|
+
|
|
81
|
+
<CardHeader>
|
|
82
|
+
<CardTitle className="text-xl text-zinc-300">{plan.name}</CardTitle>
|
|
83
|
+
<div className="flex items-baseline mt-4">
|
|
84
|
+
<span className="text-4xl font-bold text-white">{plan.price}</span>
|
|
85
|
+
<span className="text-zinc-500 ml-2">{plan.period}</span>
|
|
86
|
+
</div>
|
|
87
|
+
<CardDescription className="mt-2 text-zinc-400">
|
|
88
|
+
{plan.description}
|
|
89
|
+
</CardDescription>
|
|
90
|
+
</CardHeader>
|
|
91
|
+
|
|
92
|
+
<CardContent>
|
|
93
|
+
<ul className="space-y-4">
|
|
94
|
+
{plan.features.map((feature, j) => (
|
|
95
|
+
<li key={j} className="flex items-start">
|
|
96
|
+
<Check className="w-5 h-5 text-green-500 mr-3 shrink-0" />
|
|
97
|
+
<span className="text-sm text-zinc-300">{feature}</span>
|
|
98
|
+
</li>
|
|
99
|
+
))}
|
|
100
|
+
{plan.notIncluded?.map((feature, j) => (
|
|
101
|
+
<li key={j} className="flex items-start opacity-50">
|
|
102
|
+
<X className="w-5 h-5 text-zinc-600 mr-3 shrink-0" />
|
|
103
|
+
<span className="text-sm text-zinc-500">{feature}</span>
|
|
104
|
+
</li>
|
|
105
|
+
))}
|
|
106
|
+
</ul>
|
|
107
|
+
</CardContent>
|
|
108
|
+
|
|
109
|
+
<CardFooter className="flex flex-col gap-4">
|
|
110
|
+
{plan.link ? (
|
|
111
|
+
<a href={plan.link} target="_blank" rel="noopener noreferrer" className="w-full">
|
|
112
|
+
<Button
|
|
113
|
+
variant={plan.variant as "default" | "outline"}
|
|
114
|
+
className={`w-full ${plan.variant === 'default' ? 'bg-white text-black hover:bg-gray-200' : 'border-zinc-700 text-white hover:bg-zinc-800'}`}
|
|
115
|
+
>
|
|
116
|
+
{plan.name === "Local" && <Github className="w-4 h-4 mr-2" />}
|
|
117
|
+
{plan.cta}
|
|
118
|
+
</Button>
|
|
119
|
+
</a>
|
|
120
|
+
) : (
|
|
121
|
+
<Button
|
|
122
|
+
variant={plan.variant as "default" | "outline"}
|
|
123
|
+
className={`w-full ${plan.variant === 'default' ? 'bg-white text-black hover:bg-gray-200' : 'border-zinc-700 text-white hover:bg-zinc-800'}`}
|
|
124
|
+
disabled={plan.disabled}
|
|
125
|
+
>
|
|
126
|
+
{plan.cta}
|
|
127
|
+
</Button>
|
|
128
|
+
)}
|
|
129
|
+
</CardFooter>
|
|
130
|
+
</Card>
|
|
131
|
+
))}
|
|
132
|
+
</div>
|
|
133
|
+
|
|
134
|
+
<div className="text-center mt-12 text-zinc-500 text-sm">
|
|
135
|
+
Self-host the relay? It's open source. Run it on your infra.
|
|
136
|
+
</div>
|
|
137
|
+
</div>
|
|
138
|
+
</section>
|
|
139
|
+
);
|
|
140
|
+
}
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
import { Badge } from "../../app/components/ui/badge";
|
|
2
|
+
import { Terminal, Zap, Bug, PlayCircle } from "lucide-react";
|
|
3
|
+
|
|
4
|
+
export function Roadmap() {
|
|
5
|
+
const plannedFeatures = [
|
|
6
|
+
{
|
|
7
|
+
title: "CI/CD via GitSpace",
|
|
8
|
+
description: "Use a remote GitSpace as your CI/CD runner. If a build fails, you don't just get a log—you get a machine. SSH into the runner instantly to see exactly what happened and fix it in real-time.",
|
|
9
|
+
icon: <Terminal className="w-5 h-5 text-green-500" />,
|
|
10
|
+
tag: "Planned",
|
|
11
|
+
status: "In Concept"
|
|
12
|
+
},
|
|
13
|
+
{
|
|
14
|
+
title: "Dev & Preview Deploys",
|
|
15
|
+
description: "Push a branch and see it running instantly as a GitSpace in a Firecracker VM. Only pay for what you use with sub-second startup times. Remote into the preview environment via GitSpace to debug live code.",
|
|
16
|
+
icon: <Zap className="w-5 h-5 text-blue-500" />,
|
|
17
|
+
tag: "Coming Soon",
|
|
18
|
+
status: "In Development"
|
|
19
|
+
}
|
|
20
|
+
];
|
|
21
|
+
|
|
22
|
+
return (
|
|
23
|
+
<section className="py-24 bg-zinc-950 border-y border-zinc-900">
|
|
24
|
+
<div className="container px-4 mx-auto">
|
|
25
|
+
<div className="max-w-4xl">
|
|
26
|
+
<div className="inline-flex items-center gap-2 px-3 py-1 rounded-full bg-green-500/10 border border-green-500/20 text-green-400 text-xs font-mono mb-6">
|
|
27
|
+
<span className="relative flex h-2 w-2">
|
|
28
|
+
<span className="animate-ping absolute inline-flex h-full w-full rounded-full bg-green-400 opacity-75"></span>
|
|
29
|
+
<span className="relative inline-flex rounded-full h-2 w-2 bg-green-500"></span>
|
|
30
|
+
</span>
|
|
31
|
+
ROADMAP
|
|
32
|
+
</div>
|
|
33
|
+
|
|
34
|
+
<h2 className="text-3xl md:text-5xl font-bold mb-6">Building the future of dev-ops.</h2>
|
|
35
|
+
<p className="text-xl text-zinc-400 mb-16 max-w-2xl leading-relaxed">
|
|
36
|
+
GitSpace isn't just about local development. We're rethinking the entire lifecycle from commit to production.
|
|
37
|
+
</p>
|
|
38
|
+
|
|
39
|
+
<div className="grid md:grid-cols-2 gap-8">
|
|
40
|
+
{plannedFeatures.map((feature, i) => (
|
|
41
|
+
<div key={i} className="group p-8 rounded-2xl bg-black border border-zinc-800 hover:border-zinc-700 transition-all duration-300">
|
|
42
|
+
<div className="flex items-start justify-between mb-6">
|
|
43
|
+
<div className="p-3 rounded-xl bg-zinc-900 border border-zinc-800 group-hover:bg-zinc-800 transition-colors">
|
|
44
|
+
{feature.icon}
|
|
45
|
+
</div>
|
|
46
|
+
<Badge variant="outline" className="border-zinc-800 text-zinc-500 text-[10px] uppercase tracking-wider">
|
|
47
|
+
{feature.tag}
|
|
48
|
+
</Badge>
|
|
49
|
+
</div>
|
|
50
|
+
|
|
51
|
+
<h3 className="text-xl font-bold mb-3 group-hover:text-white transition-colors">
|
|
52
|
+
{feature.title}
|
|
53
|
+
</h3>
|
|
54
|
+
|
|
55
|
+
<p className="text-zinc-400 text-sm leading-relaxed mb-6">
|
|
56
|
+
{feature.description}
|
|
57
|
+
</p>
|
|
58
|
+
|
|
59
|
+
<div className="flex items-center gap-4 pt-4 border-t border-zinc-900">
|
|
60
|
+
<div className="flex items-center gap-1.5 text-[10px] font-mono text-zinc-500">
|
|
61
|
+
<div className="w-1.5 h-1.5 rounded-full bg-zinc-700" />
|
|
62
|
+
STATUS: {feature.status}
|
|
63
|
+
</div>
|
|
64
|
+
</div>
|
|
65
|
+
</div>
|
|
66
|
+
))}
|
|
67
|
+
</div>
|
|
68
|
+
|
|
69
|
+
<div className="mt-16 p-8 rounded-2xl bg-gradient-to-br from-green-500/5 to-transparent border border-green-500/10">
|
|
70
|
+
<div className="flex flex-col md:flex-row items-center justify-between gap-8">
|
|
71
|
+
<div>
|
|
72
|
+
<h4 className="text-lg font-bold mb-2">Want to shape our roadmap?</h4>
|
|
73
|
+
<p className="text-sm text-zinc-400">Join our Discord to suggest features and test new builds.</p>
|
|
74
|
+
</div>
|
|
75
|
+
<a href="https://discord.gg/kHRWYPnR" target="_blank" rel="noopener noreferrer">
|
|
76
|
+
<button className="px-6 py-2.5 rounded-full bg-white text-black font-medium hover:bg-zinc-200 transition-colors shrink-0">
|
|
77
|
+
Join Discord
|
|
78
|
+
</button>
|
|
79
|
+
</a>
|
|
80
|
+
</div>
|
|
81
|
+
</div>
|
|
82
|
+
</div>
|
|
83
|
+
</div>
|
|
84
|
+
</section>
|
|
85
|
+
);
|
|
86
|
+
}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
import { Lock, Github, Server, FileCode, ShieldCheck, Eye, ArrowRight } from "lucide-react";
|
|
2
|
+
import { Button } from "../../app/components/ui/button";
|
|
3
|
+
import { Link } from "react-router-dom";
|
|
4
|
+
|
|
5
|
+
export function Security() {
|
|
6
|
+
return (
|
|
7
|
+
<section id="security" className="py-24 bg-black relative">
|
|
8
|
+
<div className="container px-4 mx-auto">
|
|
9
|
+
<div className="text-center mb-16">
|
|
10
|
+
<h2 className="text-3xl md:text-5xl font-bold mb-6">Open source. Self-hostable. <span className="text-green-500">Actually secure.</span></h2>
|
|
11
|
+
</div>
|
|
12
|
+
|
|
13
|
+
<div className="grid md:grid-cols-2 gap-8 max-w-5xl mx-auto">
|
|
14
|
+
|
|
15
|
+
{/* Open Source Card */}
|
|
16
|
+
<div className="bg-zinc-900/30 border border-zinc-800 rounded-2xl p-8 hover:border-zinc-700 transition-colors">
|
|
17
|
+
<div className="w-12 h-12 rounded-lg bg-blue-500/10 flex items-center justify-center border border-blue-500/20 mb-6">
|
|
18
|
+
<Github className="w-6 h-6 text-blue-400" />
|
|
19
|
+
</div>
|
|
20
|
+
<h3 className="text-2xl font-bold mb-4">Fully Open Source</h3>
|
|
21
|
+
<p className="text-zinc-400 mb-8 leading-relaxed">
|
|
22
|
+
The CLI, the relay, the protocol. All MIT licensed.
|
|
23
|
+
Run it yourself or use our managed service. We have nothing to hide.
|
|
24
|
+
</p>
|
|
25
|
+
|
|
26
|
+
<div className="space-y-4">
|
|
27
|
+
<div className="flex items-start gap-3">
|
|
28
|
+
<Server className="w-5 h-5 text-zinc-500 mt-1" />
|
|
29
|
+
<div>
|
|
30
|
+
<h4 className="font-bold text-white">Self-Host Everything</h4>
|
|
31
|
+
<p className="text-sm text-zinc-500">Don't trust us? Don't have to. Run your own relay. Same security. Your infrastructure.</p>
|
|
32
|
+
</div>
|
|
33
|
+
</div>
|
|
34
|
+
</div>
|
|
35
|
+
|
|
36
|
+
<div className="mt-8 pt-8 border-t border-zinc-800">
|
|
37
|
+
<a href="https://github.com/inkibra/gitspace.sh" target="_blank" rel="noopener noreferrer">
|
|
38
|
+
<Button variant="outline" className="text-blue-400 border-blue-500/20 hover:bg-blue-500/10 hover:text-blue-300 w-full justify-between group">
|
|
39
|
+
View on GitHub
|
|
40
|
+
<ArrowRight className="w-4 h-4 ml-2 group-hover:translate-x-1 transition-transform" />
|
|
41
|
+
</Button>
|
|
42
|
+
</a>
|
|
43
|
+
</div>
|
|
44
|
+
</div>
|
|
45
|
+
|
|
46
|
+
{/* Security Card */}
|
|
47
|
+
<div className="bg-zinc-900/30 border border-zinc-800 rounded-2xl p-8 hover:border-zinc-700 transition-colors">
|
|
48
|
+
<div className="w-12 h-12 rounded-lg bg-green-500/10 flex items-center justify-center border border-green-500/20 mb-6">
|
|
49
|
+
<Lock className="w-6 h-6 text-green-400" />
|
|
50
|
+
</div>
|
|
51
|
+
<h3 className="text-2xl font-bold mb-4">End-to-End Encrypted</h3>
|
|
52
|
+
<p className="text-zinc-400 mb-8 leading-relaxed">
|
|
53
|
+
Your encryption keys never leave your devices. We route bytes but can't read them.
|
|
54
|
+
Even if our servers are compromised, your data is safe.
|
|
55
|
+
</p>
|
|
56
|
+
|
|
57
|
+
<div className="space-y-4">
|
|
58
|
+
<div className="flex items-start gap-3">
|
|
59
|
+
<Eye className="w-5 h-5 text-zinc-500 mt-1" />
|
|
60
|
+
<div>
|
|
61
|
+
<h4 className="font-bold text-white">Auditable Protocol</h4>
|
|
62
|
+
<p className="text-sm text-zinc-500">The crypto is standard. The protocol is documented. Third party audits coming.</p>
|
|
63
|
+
</div>
|
|
64
|
+
</div>
|
|
65
|
+
</div>
|
|
66
|
+
|
|
67
|
+
<div className="mt-8 pt-8 border-t border-zinc-800">
|
|
68
|
+
<Link to="/docs?section=security-notes">
|
|
69
|
+
<Button variant="outline" className="text-green-400 border-green-500/20 hover:bg-green-500/10 hover:text-green-300 w-full justify-between group">
|
|
70
|
+
Read Security Docs
|
|
71
|
+
<ArrowRight className="w-4 h-4 ml-2 group-hover:translate-x-1 transition-transform" />
|
|
72
|
+
</Button>
|
|
73
|
+
</Link>
|
|
74
|
+
</div>
|
|
75
|
+
</div>
|
|
76
|
+
|
|
77
|
+
</div>
|
|
78
|
+
</div>
|
|
79
|
+
</section>
|
|
80
|
+
);
|
|
81
|
+
}
|