@prabhask5/stellar-engine 1.1.12 → 1.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/README.md +42 -1
- package/dist/auth/deviceVerification.d.ts.map +1 -1
- package/dist/auth/deviceVerification.js +17 -0
- package/dist/auth/deviceVerification.js.map +1 -1
- package/dist/auth/resolveAuthState.d.ts +2 -1
- package/dist/auth/resolveAuthState.d.ts.map +1 -1
- package/dist/auth/resolveAuthState.js +5 -0
- package/dist/auth/resolveAuthState.js.map +1 -1
- package/dist/auth/singleUser.d.ts.map +1 -1
- package/dist/auth/singleUser.js +27 -0
- package/dist/auth/singleUser.js.map +1 -1
- package/dist/bin/install-pwa.js +275 -5
- package/dist/bin/install-pwa.js.map +1 -1
- package/dist/config.d.ts +9 -0
- package/dist/config.d.ts.map +1 -1
- package/dist/config.js +10 -0
- package/dist/config.js.map +1 -1
- package/dist/data.d.ts.map +1 -1
- package/dist/data.js +13 -5
- package/dist/data.js.map +1 -1
- package/dist/demo.d.ts +131 -0
- package/dist/demo.d.ts.map +1 -0
- package/dist/demo.js +168 -0
- package/dist/demo.js.map +1 -0
- package/dist/engine.d.ts.map +1 -1
- package/dist/engine.js +13 -1
- package/dist/engine.js.map +1 -1
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +10 -0
- package/dist/index.js.map +1 -1
- package/dist/kit/auth.d.ts.map +1 -1
- package/dist/kit/auth.js +4 -1
- package/dist/kit/auth.js.map +1 -1
- package/dist/kit/loads.d.ts.map +1 -1
- package/dist/kit/loads.js +15 -4
- package/dist/kit/loads.js.map +1 -1
- package/dist/queue.d.ts.map +1 -1
- package/dist/queue.js +13 -0
- package/dist/queue.js.map +1 -1
- package/dist/realtime.d.ts.map +1 -1
- package/dist/realtime.js +4 -0
- package/dist/realtime.js.map +1 -1
- package/dist/stores/authState.d.ts +8 -0
- package/dist/stores/authState.d.ts.map +1 -1
- package/dist/stores/authState.js +31 -1
- package/dist/stores/authState.js.map +1 -1
- package/dist/supabase/auth.d.ts.map +1 -1
- package/dist/supabase/auth.js +14 -0
- package/dist/supabase/auth.js.map +1 -1
- package/dist/supabase/client.d.ts.map +1 -1
- package/dist/supabase/client.js +11 -0
- package/dist/supabase/client.js.map +1 -1
- package/dist/supabase/validate.d.ts.map +1 -1
- package/dist/supabase/validate.js +3 -0
- package/dist/supabase/validate.js.map +1 -1
- package/dist/types.d.ts +2 -1
- package/dist/types.d.ts.map +1 -1
- package/package.json +5 -1
- package/src/components/DemoBanner.svelte +94 -0
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
<!--
|
|
2
|
+
@fileoverview DemoBanner — fixed-position notification bar for demo mode.
|
|
3
|
+
|
|
4
|
+
Renders a subtle, dismissible banner at the bottom center of the viewport
|
|
5
|
+
when the app is running in demo mode. Informs the user that changes will
|
|
6
|
+
reset on refresh.
|
|
7
|
+
|
|
8
|
+
- Only renders when `isDemoMode()` returns `true`.
|
|
9
|
+
- Dismissible via the close button (component-local state).
|
|
10
|
+
- Glass morphism styling with backdrop-filter blur.
|
|
11
|
+
- z-index 9000 — above page content, below modals.
|
|
12
|
+
-->
|
|
13
|
+
<script lang="ts">
|
|
14
|
+
import { isDemoMode } from '../demo';
|
|
15
|
+
|
|
16
|
+
let dismissed = $state(false);
|
|
17
|
+
const visible = $derived(isDemoMode() && !dismissed);
|
|
18
|
+
</script>
|
|
19
|
+
|
|
20
|
+
{#if visible}
|
|
21
|
+
<div class="demo-banner" role="status" aria-live="polite">
|
|
22
|
+
<span class="demo-banner-text">Demo Mode — Changes reset on refresh</span>
|
|
23
|
+
<button
|
|
24
|
+
class="demo-banner-close"
|
|
25
|
+
onclick={() => (dismissed = true)}
|
|
26
|
+
aria-label="Dismiss demo mode banner"
|
|
27
|
+
>
|
|
28
|
+
✕
|
|
29
|
+
</button>
|
|
30
|
+
</div>
|
|
31
|
+
{/if}
|
|
32
|
+
|
|
33
|
+
<style>
|
|
34
|
+
.demo-banner {
|
|
35
|
+
position: fixed;
|
|
36
|
+
bottom: 1rem;
|
|
37
|
+
left: 50%;
|
|
38
|
+
transform: translateX(-50%);
|
|
39
|
+
z-index: 9000;
|
|
40
|
+
display: flex;
|
|
41
|
+
align-items: center;
|
|
42
|
+
gap: 0.75rem;
|
|
43
|
+
padding: 0.5rem 1rem;
|
|
44
|
+
border-radius: 9999px;
|
|
45
|
+
background: rgba(0, 0, 0, 0.6);
|
|
46
|
+
backdrop-filter: blur(12px);
|
|
47
|
+
-webkit-backdrop-filter: blur(12px);
|
|
48
|
+
border: 1px solid rgba(255, 255, 255, 0.15);
|
|
49
|
+
color: #fff;
|
|
50
|
+
font-size: 0.8125rem;
|
|
51
|
+
font-weight: 500;
|
|
52
|
+
letter-spacing: 0.01em;
|
|
53
|
+
white-space: nowrap;
|
|
54
|
+
box-shadow: 0 4px 16px rgba(0, 0, 0, 0.2);
|
|
55
|
+
pointer-events: auto;
|
|
56
|
+
animation: demo-banner-slide-up 0.3s ease-out;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
.demo-banner-text {
|
|
60
|
+
opacity: 0.95;
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
.demo-banner-close {
|
|
64
|
+
display: flex;
|
|
65
|
+
align-items: center;
|
|
66
|
+
justify-content: center;
|
|
67
|
+
width: 1.25rem;
|
|
68
|
+
height: 1.25rem;
|
|
69
|
+
padding: 0;
|
|
70
|
+
border: none;
|
|
71
|
+
border-radius: 50%;
|
|
72
|
+
background: rgba(255, 255, 255, 0.15);
|
|
73
|
+
color: rgba(255, 255, 255, 0.8);
|
|
74
|
+
font-size: 0.625rem;
|
|
75
|
+
cursor: pointer;
|
|
76
|
+
transition: background 0.15s ease;
|
|
77
|
+
flex-shrink: 0;
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
.demo-banner-close:hover {
|
|
81
|
+
background: rgba(255, 255, 255, 0.25);
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
@keyframes demo-banner-slide-up {
|
|
85
|
+
from {
|
|
86
|
+
opacity: 0;
|
|
87
|
+
transform: translateX(-50%) translateY(1rem);
|
|
88
|
+
}
|
|
89
|
+
to {
|
|
90
|
+
opacity: 1;
|
|
91
|
+
transform: translateX(-50%) translateY(0);
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
</style>
|