diff options
| author | Frank <[email protected]> | 2026-02-25 23:06:16 -0500 |
|---|---|---|
| committer | Frank <[email protected]> | 2026-02-25 23:06:16 -0500 |
| commit | c4ea11fef3dc3ac6bd2e3c55d1c8179457eace5d (patch) | |
| tree | dc25130b50d6d7489b2deb40e00225d17a67ef58 /packages/console/app/src | |
| parent | b8337cddc4269ba6e72f74c1e1f39aae41f56af3 (diff) | |
| download | opencode-c4ea11fef3dc3ac6bd2e3c55d1c8179457eace5d.tar.gz opencode-c4ea11fef3dc3ac6bd2e3c55d1c8179457eace5d.zip | |
wip: zen
Diffstat (limited to 'packages/console/app/src')
| -rw-r--r-- | packages/console/app/src/routes/black/index.tsx | 13 | ||||
| -rw-r--r-- | packages/console/app/src/routes/black/subscribe/[plan].tsx (renamed from packages/console/app/src/routes/black/_subscribe/[plan].tsx) | 11 |
2 files changed, 18 insertions, 6 deletions
diff --git a/packages/console/app/src/routes/black/index.tsx b/packages/console/app/src/routes/black/index.tsx index 382832e8f..8bce3cd46 100644 --- a/packages/console/app/src/routes/black/index.tsx +++ b/packages/console/app/src/routes/black/index.tsx @@ -1,16 +1,21 @@ -import { A, useSearchParams } from "@solidjs/router" +import { A, createAsync, query, useSearchParams } from "@solidjs/router" import { Title } from "@solidjs/meta" import { createMemo, createSignal, For, Match, onMount, Show, Switch } from "solid-js" import { PlanIcon, plans } from "./common" import { useI18n } from "~/context/i18n" import { useLanguage } from "~/context/language" +import { Resource } from "@opencode-ai/console-resource" -const paused = true +const getPaused = query(async () => { + "use server" + return Resource.App.stage === "production" +}, "black.paused") export default function Black() { const [params] = useSearchParams() const i18n = useI18n() const language = useLanguage() + const paused = createAsync(() => getPaused()) const [selected, setSelected] = createSignal<string | null>((params.plan as string) || null) const [mounted, setMounted] = createSignal(false) const selectedPlan = createMemo(() => plans.find((p) => p.id === selected())) @@ -44,7 +49,7 @@ export default function Black() { <> <Title>{i18n.t("black.title")}</Title> <section data-slot="cta"> - <Show when={!paused} fallback={<p data-slot="paused">{i18n.t("black.paused")}</p>}> + <Show when={!paused()} fallback={<p data-slot="paused">{i18n.t("black.paused")}</p>}> <Switch> <Match when={!selected()}> <div data-slot="pricing"> @@ -108,7 +113,7 @@ export default function Black() { </Match> </Switch> </Show> - <Show when={!paused}> + <Show when={!paused()}> <p data-slot="fine-print" style={{ "view-transition-name": "fine-print" }}> {i18n.t("black.finePrint.beforeTerms")} ยท{" "} <A href={language.route("/legal/terms-of-service")}>{i18n.t("black.finePrint.terms")}</A> diff --git a/packages/console/app/src/routes/black/_subscribe/[plan].tsx b/packages/console/app/src/routes/black/subscribe/[plan].tsx index 644d87d9b..19b56eabe 100644 --- a/packages/console/app/src/routes/black/_subscribe/[plan].tsx +++ b/packages/console/app/src/routes/black/subscribe/[plan].tsx @@ -17,6 +17,12 @@ import { Billing } from "@opencode-ai/console-core/billing.js" import { useI18n } from "~/context/i18n" import { useLanguage } from "~/context/language" import { formError } from "~/lib/form-error" +import { Resource } from "@opencode-ai/console-resource" + +const getEnabled = query(async () => { + "use server" + return Resource.App.stage !== "production" +}, "black.subscribe.enabled") const plansMap = Object.fromEntries(plans.map((p) => [p.id, p])) as Record<PlanID, (typeof plans)[number]> const stripePromise = loadStripe(import.meta.env.VITE_STRIPE_PUBLISHABLE_KEY!) @@ -269,6 +275,7 @@ export default function BlackSubscribe() { const params = useParams() const i18n = useI18n() const language = useLanguage() + const enabled = createAsync(() => getEnabled()) const planData = plansMap[(params.plan as PlanID) ?? "20"] ?? plansMap["20"] const plan = planData.id @@ -359,7 +366,7 @@ export default function BlackSubscribe() { } return ( - <> + <Show when={enabled()}> <Title>{i18n.t("black.subscribe.title")}</Title> <section data-slot="subscribe-form"> <div data-slot="form-card"> @@ -472,6 +479,6 @@ export default function BlackSubscribe() { <A href={language.route("/legal/terms-of-service")}>{i18n.t("black.finePrint.terms")}</A> </p> </section> - </> + </Show> ) } |
