create-mikstack 0.1.12 → 0.1.14

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/index.js CHANGED
@@ -170,6 +170,10 @@ function scaffold(config, onStatus) {
170
170
  }
171
171
  const svBin = new URL("../bin.mjs", import.meta.resolve("sv")).pathname;
172
172
  execSync(`node ${svBin} create ${target} --template minimal --types ts --add devtools-json --no-install`, { stdio: "pipe" });
173
+ fs.rmSync(path.join(target, "src", "routes"), {
174
+ recursive: true,
175
+ force: true
176
+ });
173
177
  onStatus?.("Applying templates...");
174
178
  const overlay = (dir) => {
175
179
  copyDir(dir, target);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "create-mikstack",
3
- "version": "0.1.12",
3
+ "version": "0.1.14",
4
4
  "license": "MIT",
5
5
  "repository": {
6
6
  "type": "git",
@@ -1,4 +1,4 @@
1
- import type { Handle } from "@sveltejs/kit";
1
+ import { redirect, type Handle } from "@sveltejs/kit";
2
2
  import { auth } from "$lib/server/auth";
3
3
  import { svelteKitHandler } from "better-auth/svelte-kit";
4
4
  import { building } from "$app/environment";
@@ -11,5 +11,9 @@ export const handle: Handle = async ({ event, resolve }) => {
11
11
  event.locals.user = session?.user ?? null;
12
12
  event.locals.session = session?.session ?? null;
13
13
 
14
+ if (event.route.id?.startsWith("/(app)") && !event.locals.user) {
15
+ redirect(302, "/sign-in");
16
+ }
17
+
14
18
  return svelteKitHandler({ event, resolve, auth, building });
15
19
  };
@@ -1,5 +1,5 @@
1
1
  import type { LayoutServerLoad } from "./$types";
2
2
 
3
3
  export const load: LayoutServerLoad = ({ locals }) => {
4
- return { user: locals.user };
4
+ return { user: locals.user! };
5
5
  };
@@ -0,0 +1,30 @@
1
+ <script lang="ts">
2
+ import type { Snippet } from "svelte";
3
+ import type { LayoutData } from "./$types";
4
+ import { Z } from "zero-svelte";
5
+ import { PUBLIC_SERVER } from "$env/static/public";
6
+ import { schema } from "$lib/zero/schema";
7
+ import { mutators } from "$lib/zero/mutators";
8
+ import { set_z } from "$lib/z.svelte";
9
+
10
+ let { data, children }: { data: LayoutData; children: Snippet } = $props();
11
+
12
+ set_z(
13
+ new Z({
14
+ get userID() {
15
+ return data.user.id;
16
+ },
17
+ server: PUBLIC_SERVER,
18
+ schema,
19
+ mutators,
20
+ kvStore: "idb",
21
+ context: {
22
+ get userID() {
23
+ return data.user.id;
24
+ },
25
+ },
26
+ }),
27
+ );
28
+ </script>
29
+
30
+ {@render children()}
@@ -1,7 +0,0 @@
1
- import { redirect } from "@sveltejs/kit";
2
- import type { PageServerLoad } from "./$types";
3
-
4
- export const load: PageServerLoad = ({ locals }) => {
5
- if (!locals.user) redirect(302, "/sign-in");
6
- return { user: locals.user };
7
- };