@kyro-cms/admin 0.1.2 → 0.1.3

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 (58) hide show
  1. package/package.json +17 -6
  2. package/src/components/Admin.tsx +50 -1
  3. package/src/components/LoginPage.tsx +223 -0
  4. package/src/components/layout/Sidebar.tsx +35 -0
  5. package/src/index.ts +35 -0
  6. package/src/middleware.ts +2 -0
  7. package/src/pages/api/auth/register.ts +133 -0
  8. package/src/styles/main.css +148 -0
  9. package/.astro/content.d.ts +0 -154
  10. package/.astro/settings.json +0 -5
  11. package/.astro/types.d.ts +0 -2
  12. package/astro.config.mjs +0 -28
  13. package/bun.lock +0 -1374
  14. package/dist/client/_astro/AdminLayout.DkDpng53.css +0 -1
  15. package/dist/client/_astro/AutoForm.3eJCmCJp.js +0 -1
  16. package/dist/client/_astro/client.DyczpTbx.js +0 -9
  17. package/dist/client/_astro/index.B02hbnpo.js +0 -1
  18. package/dist/client/fonts/Serotiva-Black.woff2 +0 -0
  19. package/dist/client/fonts/Serotiva-Bold.woff2 +0 -0
  20. package/dist/client/fonts/Serotiva-Medium.woff2 +0 -0
  21. package/dist/client/fonts/Serotiva-Regular.woff2 +0 -0
  22. package/dist/client/fonts/Serotiva-SemiBold.woff2 +0 -0
  23. package/dist/server/chunks/AdminLayout_D-_JeUqC.mjs +0 -26
  24. package/dist/server/chunks/_id__BzI_o0qT.mjs +0 -50
  25. package/dist/server/chunks/_id__Cd-jOuY3.mjs +0 -238
  26. package/dist/server/chunks/_id__DvbD--iR.mjs +0 -992
  27. package/dist/server/chunks/_id__vpVaEo16.mjs +0 -128
  28. package/dist/server/chunks/_virtual_astro_server-island-manifest_CQQ1F5PF.mjs +0 -7
  29. package/dist/server/chunks/_virtual_astro_session-driver_Bk3Q189E.mjs +0 -4
  30. package/dist/server/chunks/astro-component_Dbx3T2Nh.mjs +0 -37
  31. package/dist/server/chunks/audit-logs_DrnUMRvY.mjs +0 -74
  32. package/dist/server/chunks/config_CPXslElD.mjs +0 -4221
  33. package/dist/server/chunks/dataStore_Dl7cA2Qp.mjs +0 -89
  34. package/dist/server/chunks/index_CVqOkerS.mjs +0 -2960
  35. package/dist/server/chunks/index_CX8SQ4BF.mjs +0 -55
  36. package/dist/server/chunks/index_CYofDU51.mjs +0 -58
  37. package/dist/server/chunks/index_DdNRhuaM.mjs +0 -55
  38. package/dist/server/chunks/index_DupPvtIF.mjs +0 -42
  39. package/dist/server/chunks/index_YTS_M-B9.mjs +0 -263
  40. package/dist/server/chunks/index_YeCzuVps.mjs +0 -53
  41. package/dist/server/chunks/login_DLyqMRO8.mjs +0 -93
  42. package/dist/server/chunks/logout_CSbt5wea.mjs +0 -50
  43. package/dist/server/chunks/me_C04jlYhH.mjs +0 -41
  44. package/dist/server/chunks/new_BbQ9b55M.mjs +0 -92
  45. package/dist/server/chunks/node_9bvTewss.mjs +0 -1014
  46. package/dist/server/chunks/noop-entrypoint_BOlrdqWF.mjs +0 -3
  47. package/dist/server/chunks/sequence_9cl7AJy-.mjs +0 -2503
  48. package/dist/server/chunks/server_peBx9VXG.mjs +0 -8117
  49. package/dist/server/chunks/sharp_pmJ7nHES.mjs +0 -142
  50. package/dist/server/chunks/users_Dzddy_YR.mjs +0 -137
  51. package/dist/server/entry.mjs +0 -5
  52. package/dist/server/virtual_astro_middleware.mjs +0 -48
  53. package/public/fonts/Serotiva-Black.woff2 +0 -0
  54. package/public/fonts/Serotiva-Bold.woff2 +0 -0
  55. package/public/fonts/Serotiva-Medium.woff2 +0 -0
  56. package/public/fonts/Serotiva-Regular.woff2 +0 -0
  57. package/public/fonts/Serotiva-SemiBold.woff2 +0 -0
  58. package/tsconfig.json +0 -12
@@ -1446,4 +1446,152 @@
1446
1446
  border: none;
1447
1447
  border-radius: 5px;
1448
1448
  }
1449
+
1450
+ /* Login Page */
1451
+ .kyro-login-page {
1452
+ min-height: 100vh;
1453
+ display: flex;
1454
+ align-items: center;
1455
+ justify-content: center;
1456
+ background: var(--kyro-bg);
1457
+ padding: 20px;
1458
+ }
1459
+
1460
+ .kyro-login-container {
1461
+ width: 100%;
1462
+ max-width: 400px;
1463
+ background: var(--kyro-surface);
1464
+ border-radius: var(--kyro-radius-lg);
1465
+ box-shadow: var(--kyro-shadow-tile);
1466
+ padding: 40px 32px;
1467
+ }
1468
+
1469
+ .kyro-login-header {
1470
+ text-align: center;
1471
+ margin-bottom: 32px;
1472
+ }
1473
+
1474
+ .kyro-login-title {
1475
+ font-size: 24px;
1476
+ font-weight: 700;
1477
+ color: var(--kyro-black);
1478
+ margin: 0 0 8px;
1479
+ letter-spacing: -0.02em;
1480
+ }
1481
+
1482
+ .kyro-login-subtitle {
1483
+ font-size: 14px;
1484
+ color: var(--kyro-gray-500);
1485
+ margin: 0;
1486
+ }
1487
+
1488
+ .kyro-login-form {
1489
+ display: flex;
1490
+ flex-direction: column;
1491
+ gap: 20px;
1492
+ }
1493
+
1494
+ .kyro-login-form .kyro-form-group {
1495
+ display: flex;
1496
+ flex-direction: column;
1497
+ gap: 6px;
1498
+ }
1499
+
1500
+ .kyro-login-form .kyro-form-group label {
1501
+ font-size: 13px;
1502
+ font-weight: 500;
1503
+ color: var(--kyro-gray-900);
1504
+ }
1505
+
1506
+ .kyro-login-form .kyro-form-group input {
1507
+ width: 100%;
1508
+ padding: 10px 12px;
1509
+ font-size: 14px;
1510
+ color: var(--kyro-gray-900);
1511
+ background: white;
1512
+ border: 1px solid var(--kyro-gray-200);
1513
+ border-radius: 6px;
1514
+ transition: all 150ms ease;
1515
+ font-family: inherit;
1516
+ }
1517
+
1518
+ .kyro-login-form .kyro-form-group input:hover {
1519
+ border-color: var(--kyro-gray-300);
1520
+ }
1521
+
1522
+ .kyro-login-form .kyro-form-group input:focus {
1523
+ outline: none;
1524
+ border-color: var(--kyro-black);
1525
+ box-shadow: 0 0 0 3px rgba(11, 18, 34, 0.08);
1526
+ }
1527
+
1528
+ .kyro-login-form .kyro-form-group input::placeholder {
1529
+ color: var(--kyro-gray-400);
1530
+ }
1531
+
1532
+ .kyro-login-form button[type="submit"] {
1533
+ width: 100%;
1534
+ margin-top: 8px;
1535
+ }
1536
+
1537
+ .kyro-login-footer {
1538
+ margin-top: 24px;
1539
+ text-align: center;
1540
+ }
1541
+
1542
+ .kyro-login-footer p {
1543
+ font-size: 14px;
1544
+ color: var(--kyro-gray-500);
1545
+ margin: 0;
1546
+ }
1547
+
1548
+ .kyro-login-link {
1549
+ background: none;
1550
+ border: none;
1551
+ color: var(--kyro-black);
1552
+ font-weight: 600;
1553
+ cursor: pointer;
1554
+ font-size: 14px;
1555
+ padding: 0;
1556
+ text-decoration: underline;
1557
+ font-family: inherit;
1558
+ }
1559
+
1560
+ .kyro-login-link:hover {
1561
+ color: var(--kyro-black-hover);
1562
+ }
1563
+
1564
+ /* Sidebar User Info */
1565
+ .kyro-sidebar-user-info {
1566
+ padding: 8px;
1567
+ border-top: 1px solid var(--kyro-sidebar-border);
1568
+ margin-bottom: 4px;
1569
+ }
1570
+
1571
+ .kyro-sidebar-user-email {
1572
+ font-size: 12px;
1573
+ font-weight: 500;
1574
+ color: var(--kyro-gray-700);
1575
+ white-space: nowrap;
1576
+ overflow: hidden;
1577
+ text-overflow: ellipsis;
1578
+ }
1579
+
1580
+ .kyro-sidebar-user-role {
1581
+ font-size: 10px;
1582
+ font-weight: 600;
1583
+ text-transform: uppercase;
1584
+ letter-spacing: 0.05em;
1585
+ color: var(--kyro-gray-500);
1586
+ margin-bottom: 4px;
1587
+ }
1588
+
1589
+ .kyro-sidebar-logout {
1590
+ color: var(--kyro-gray-400) !important;
1591
+ }
1592
+
1593
+ .kyro-sidebar-logout:hover {
1594
+ color: var(--kyro-black) !important;
1595
+ background: var(--kyro-gray-100);
1596
+ }
1449
1597
  }
@@ -1,154 +0,0 @@
1
- declare module 'astro:content' {
2
- export interface RenderResult {
3
- Content: import('astro/runtime/server/index.js').AstroComponentFactory;
4
- headings: import('astro').MarkdownHeading[];
5
- remarkPluginFrontmatter: Record<string, any>;
6
- }
7
- interface Render {
8
- '.md': Promise<RenderResult>;
9
- }
10
-
11
- export interface RenderedContent {
12
- html: string;
13
- metadata?: {
14
- imagePaths: Array<string>;
15
- [key: string]: unknown;
16
- };
17
- }
18
-
19
- type Flatten<T> = T extends { [K: string]: infer U } ? U : never;
20
-
21
- export type CollectionKey = keyof DataEntryMap;
22
- export type CollectionEntry<C extends CollectionKey> = Flatten<DataEntryMap[C]>;
23
-
24
- type AllValuesOf<T> = T extends any ? T[keyof T] : never;
25
-
26
- export type ReferenceDataEntry<
27
- C extends CollectionKey,
28
- E extends keyof DataEntryMap[C] = string,
29
- > = {
30
- collection: C;
31
- id: E;
32
- };
33
-
34
- export type ReferenceLiveEntry<C extends keyof LiveContentConfig['collections']> = {
35
- collection: C;
36
- id: string;
37
- };
38
-
39
- export function getCollection<C extends keyof DataEntryMap, E extends CollectionEntry<C>>(
40
- collection: C,
41
- filter?: (entry: CollectionEntry<C>) => entry is E,
42
- ): Promise<E[]>;
43
- export function getCollection<C extends keyof DataEntryMap>(
44
- collection: C,
45
- filter?: (entry: CollectionEntry<C>) => unknown,
46
- ): Promise<CollectionEntry<C>[]>;
47
-
48
- export function getLiveCollection<C extends keyof LiveContentConfig['collections']>(
49
- collection: C,
50
- filter?: LiveLoaderCollectionFilterType<C>,
51
- ): Promise<
52
- import('astro').LiveDataCollectionResult<LiveLoaderDataType<C>, LiveLoaderErrorType<C>>
53
- >;
54
-
55
- export function getEntry<
56
- C extends keyof DataEntryMap,
57
- E extends keyof DataEntryMap[C] | (string & {}),
58
- >(
59
- entry: ReferenceDataEntry<C, E>,
60
- ): E extends keyof DataEntryMap[C]
61
- ? Promise<DataEntryMap[C][E]>
62
- : Promise<CollectionEntry<C> | undefined>;
63
- export function getEntry<
64
- C extends keyof DataEntryMap,
65
- E extends keyof DataEntryMap[C] | (string & {}),
66
- >(
67
- collection: C,
68
- id: E,
69
- ): E extends keyof DataEntryMap[C]
70
- ? string extends keyof DataEntryMap[C]
71
- ? Promise<DataEntryMap[C][E]> | undefined
72
- : Promise<DataEntryMap[C][E]>
73
- : Promise<CollectionEntry<C> | undefined>;
74
- export function getLiveEntry<C extends keyof LiveContentConfig['collections']>(
75
- collection: C,
76
- filter: string | LiveLoaderEntryFilterType<C>,
77
- ): Promise<import('astro').LiveDataEntryResult<LiveLoaderDataType<C>, LiveLoaderErrorType<C>>>;
78
-
79
- /** Resolve an array of entry references from the same collection */
80
- export function getEntries<C extends keyof DataEntryMap>(
81
- entries: ReferenceDataEntry<C, keyof DataEntryMap[C]>[],
82
- ): Promise<CollectionEntry<C>[]>;
83
-
84
- export function render<C extends keyof DataEntryMap>(
85
- entry: DataEntryMap[C][string],
86
- ): Promise<RenderResult>;
87
-
88
- export function reference<
89
- C extends
90
- | keyof DataEntryMap
91
- // Allow generic `string` to avoid excessive type errors in the config
92
- // if `dev` is not running to update as you edit.
93
- // Invalid collection names will be caught at build time.
94
- | (string & {}),
95
- >(
96
- collection: C,
97
- ): import('astro/zod').ZodPipe<
98
- import('astro/zod').ZodString,
99
- import('astro/zod').ZodTransform<
100
- C extends keyof DataEntryMap
101
- ? {
102
- collection: C;
103
- id: string;
104
- }
105
- : never,
106
- string
107
- >
108
- >;
109
-
110
- type ReturnTypeOrOriginal<T> = T extends (...args: any[]) => infer R ? R : T;
111
- type InferEntrySchema<C extends keyof DataEntryMap> = import('astro/zod').infer<
112
- ReturnTypeOrOriginal<Required<ContentConfig['collections'][C]>['schema']>
113
- >;
114
- type ExtractLoaderConfig<T> = T extends { loader: infer L } ? L : never;
115
- type InferLoaderSchema<
116
- C extends keyof DataEntryMap,
117
- L = ExtractLoaderConfig<ContentConfig['collections'][C]>,
118
- > = L extends { schema: import('astro/zod').ZodSchema }
119
- ? import('astro/zod').infer<L['schema']>
120
- : any;
121
-
122
- type DataEntryMap = {
123
-
124
- };
125
-
126
- type ExtractLoaderTypes<T> = T extends import('astro/loaders').LiveLoader<
127
- infer TData,
128
- infer TEntryFilter,
129
- infer TCollectionFilter,
130
- infer TError
131
- >
132
- ? { data: TData; entryFilter: TEntryFilter; collectionFilter: TCollectionFilter; error: TError }
133
- : { data: never; entryFilter: never; collectionFilter: never; error: never };
134
- type ExtractEntryFilterType<T> = ExtractLoaderTypes<T>['entryFilter'];
135
- type ExtractCollectionFilterType<T> = ExtractLoaderTypes<T>['collectionFilter'];
136
- type ExtractErrorType<T> = ExtractLoaderTypes<T>['error'];
137
-
138
- type LiveLoaderDataType<C extends keyof LiveContentConfig['collections']> =
139
- LiveContentConfig['collections'][C]['schema'] extends undefined
140
- ? ExtractDataType<LiveContentConfig['collections'][C]['loader']>
141
- : import('astro/zod').infer<
142
- Exclude<LiveContentConfig['collections'][C]['schema'], undefined>
143
- >;
144
- type LiveLoaderEntryFilterType<C extends keyof LiveContentConfig['collections']> =
145
- ExtractEntryFilterType<LiveContentConfig['collections'][C]['loader']>;
146
- type LiveLoaderCollectionFilterType<C extends keyof LiveContentConfig['collections']> =
147
- ExtractCollectionFilterType<LiveContentConfig['collections'][C]['loader']>;
148
- type LiveLoaderErrorType<C extends keyof LiveContentConfig['collections']> = ExtractErrorType<
149
- LiveContentConfig['collections'][C]['loader']
150
- >;
151
-
152
- export type ContentConfig = never;
153
- export type LiveContentConfig = never;
154
- }
@@ -1,5 +0,0 @@
1
- {
2
- "_variables": {
3
- "lastUpdateCheck": 1775234492377
4
- }
5
- }
package/.astro/types.d.ts DELETED
@@ -1,2 +0,0 @@
1
- /// <reference types="astro/client" />
2
- /// <reference path="content.d.ts" />
package/astro.config.mjs DELETED
@@ -1,28 +0,0 @@
1
- import { defineConfig } from 'astro/config';
2
- import react from '@astrojs/react';
3
- import tailwindcss from '@tailwindcss/vite';
4
- import node from '@astrojs/node';
5
-
6
- export default defineConfig({
7
- integrations: [react()],
8
- vite: {
9
- plugins: [tailwindcss()],
10
- ssr: {
11
- external: ['@mapbox/node-pre-gyp', 'mock-aws-s3', 'aws-sdk', 'nock'],
12
- },
13
- optimizeDeps: {
14
- exclude: ['@mapbox/node-pre-gyp'],
15
- },
16
- },
17
- output: 'server',
18
- adapter: node({
19
- mode: 'standalone'
20
- }),
21
- server: {
22
- port: 4555,
23
- host: true,
24
- },
25
- build: {
26
- inlineStylesheets: 'auto',
27
- },
28
- });