├── .gitignore ├── README.md ├── app ├── Guestbook.tsx ├── Login.tsx ├── favicon.ico ├── globals.css ├── layout.tsx ├── page.tsx └── pocketbase.ts ├── next.config.mjs ├── nginx.conf ├── package-lock.json ├── package.json ├── pb_migrations ├── 1719093567_created_signatures.js ├── 1719093799_updated_signatures.js ├── 1719093987_updated_signatures.js ├── 1719094114_updated_signatures.js ├── 1719094869_updated_signatures.js ├── 1719095267_updated_signatures.js ├── 1719095351_updated_signatures.js ├── 1719095401_updated_signatures.js ├── 1719096282_updated_signatures.js ├── 1719096824_updated_users.js ├── 1719096961_updated_users.js ├── 1719096997_updated_users.js ├── 1719229813_updated_users.js └── 1719229909_updated_users.js ├── pocketbase ├── postcss.config.mjs ├── public ├── next.svg └── vercel.svg ├── tailwind.config.ts └── tsconfig.json /.gitignore: -------------------------------------------------------------------------------- 1 | # See https://help.github.com/articles/ignoring-files/ for more about ignoring files. 2 | 3 | # dependencies 4 | /node_modules 5 | /.pnp 6 | .pnp.js 7 | .yarn/install-state.gz 8 | 9 | # testing 10 | /coverage 11 | 12 | # next.js 13 | /.next/ 14 | /out/ 15 | 16 | # production 17 | /build 18 | 19 | # misc 20 | .DS_Store 21 | *.pem 22 | 23 | # debug 24 | npm-debug.log* 25 | yarn-debug.log* 26 | yarn-error.log* 27 | 28 | # local env files 29 | .env*.local 30 | 31 | # vercel 32 | .vercel 33 | 34 | # typescript 35 | *.tsbuildinfo 36 | next-env.d.ts 37 | 38 | /pb_data -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | ## The Full Linux Course 2 | 3 | This repo contains the project source code the the [The Full Linux Self-hosting Course](https://fireship.io/courses/linux/). 4 | 5 | ## How to Run it Locally 6 | 7 | ``` 8 | git clone guestbook 9 | cd guestbook 10 | 11 | npm install 12 | npm run dev 13 | 14 | ./pocketbase serve 15 | ``` 16 | 17 | ### Pocketbase Setup Instructions 18 | 19 | 20 | Navigate to [localhost:8090/_/](http://127.0.0.1:8090/_/) 21 | 22 | Create an admin account for your pocketbase backend 23 | 24 | In Pocketbase, go to settings -> auth providers -> github 25 | 26 | In order to enable GitHub login, you will need to create a [GitHub OAuth app](https://github.com/settings/applications/new) to obtain a Client ID and Secret. 27 | 28 | Set the callback URL to: http://127.0.0.1:8090/api/oauth2-redirect 29 | 30 | Set the Client ID and Secret in Pocketbase and you should now be able to login with GitHub locally. 31 | 32 | -------------------------------------------------------------------------------- /app/Guestbook.tsx: -------------------------------------------------------------------------------- 1 | 'use client' 2 | 3 | import { useState, useEffect } from 'react'; 4 | import PocketBase from 'pocketbase'; 5 | import { faker } from '@faker-js/faker'; 6 | 7 | import { pb } from './pocketbase' 8 | 9 | export default function GuestbookSigner() { 10 | const [user, setUser] = useState(null); 11 | // const [lastMessage, setLastMessage] = useState(''); 12 | const [signatures, setSignatures] = useState([]); 13 | 14 | useEffect(() => { 15 | // Check if the user is already logged in 16 | const authData = pb.authStore.model; 17 | if (authData) { 18 | setUser(authData); 19 | } 20 | 21 | // Listen for authentication changes 22 | pb.authStore.onChange((auth) => { 23 | setUser(auth ? pb.authStore.model : null); 24 | }); 25 | 26 | // Fetch last 100 signatures 27 | fetchSignatures(); 28 | }, []); 29 | 30 | const fetchSignatures = async () => { 31 | try { 32 | const resultList = await pb.collection('users').getList(1, 100, { 33 | sort: '-created', 34 | // expand: 'user', 35 | }); 36 | setSignatures(resultList.items); 37 | } catch (error) { 38 | console.error('Failed to fetch signatures:', error); 39 | } 40 | }; 41 | 42 | const signGuestbook = async () => { 43 | if (!user) { 44 | alert('Please log in to sign the guestbook.'); 45 | return; 46 | } 47 | 48 | const message = faker.hacker.phrase(); 49 | 50 | try { 51 | // const record = await pb.collection('signatures').create({ 52 | // // user: user.id, 53 | // user: user.id, 54 | // message: message, 55 | // }); 56 | const record = await pb.collection('users').update(user.id, { 57 | message: message, 58 | signed: new DateTime() 59 | }); 60 | console.log('Guestbook signed:', record); 61 | // setLastMessage(message); 62 | fetchSignatures(); 63 | } catch (error) { 64 | alert('unable to sign guestbook, did you already sign it?') 65 | console.error('Failed to sign guestbook:', error); 66 | } 67 | }; 68 | 69 | return ( 70 |
71 | {user && 72 | } 75 |

Last 100 Signatures

76 |
    77 | {signatures.map((signature) => ( 78 |
  • 79 | {signature.expand?.user?.username || 'Anonymous'}: 80 | "{signature.message}" 81 | - {new Date(signature.created).toLocaleString()} 82 |
  • 83 | ))} 84 |
85 |
86 | ); 87 | } -------------------------------------------------------------------------------- /app/Login.tsx: -------------------------------------------------------------------------------- 1 | 'use client' 2 | 3 | import { useState, useEffect } from 'react'; 4 | import { pb } from './pocketbase' 5 | 6 | export default function GitHubLogin() { 7 | const [user, setUser] = useState(null); 8 | 9 | useEffect(() => { 10 | // Check if the user is already logged in 11 | const authData = pb.authStore.model; 12 | if (authData) { 13 | setUser(authData); 14 | } 15 | 16 | // Listen for authentication changes 17 | pb.authStore.onChange((auth) => { 18 | setUser(auth ? pb.authStore.model : null); 19 | }); 20 | }, []); 21 | 22 | const login = async () => { 23 | try { 24 | const authData = await pb.collection('users').authWithOAuth2({ 25 | provider: 'github', 26 | }); 27 | 28 | // Authentication successful 29 | console.log('Logged in:', pb.authStore.isValid); 30 | console.log('User Data:', pb.authStore.model); 31 | setUser(authData.record); 32 | } catch (error) { 33 | console.error('Authentication failed:', error); 34 | } 35 | }; 36 | 37 | const logout = () => { 38 | pb.authStore.clear(); 39 | }; 40 | 41 | return ( 42 |
43 | {user ? ( 44 |
45 |

Welcome, {user.name || user.username}!

46 | 48 | 49 |
50 | ) : ( 51 | 53 | )} 54 |
55 | ); 56 | } -------------------------------------------------------------------------------- /app/favicon.ico: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/fireship-io/linux-course/78e997639faea32d69095b67d13b08291d7c727e/app/favicon.ico -------------------------------------------------------------------------------- /app/globals.css: -------------------------------------------------------------------------------- 1 | @tailwind base; 2 | @tailwind components; 3 | @tailwind utilities; 4 | 5 | :root { 6 | --foreground-rgb: 0, 0, 0; 7 | --background-start-rgb: 214, 219, 220; 8 | --background-end-rgb: 255, 255, 255; 9 | } 10 | 11 | @media (prefers-color-scheme: dark) { 12 | :root { 13 | --foreground-rgb: 255, 255, 255; 14 | --background-start-rgb: 0, 0, 0; 15 | --background-end-rgb: 0, 0, 0; 16 | } 17 | } 18 | 19 | body { 20 | color: rgb(var(--foreground-rgb)); 21 | background: linear-gradient( 22 | to bottom, 23 | transparent, 24 | rgb(var(--background-end-rgb)) 25 | ) 26 | rgb(var(--background-start-rgb)); 27 | } 28 | 29 | @layer utilities { 30 | .text-balance { 31 | text-wrap: balance; 32 | } 33 | } 34 | -------------------------------------------------------------------------------- /app/layout.tsx: -------------------------------------------------------------------------------- 1 | import type { Metadata } from "next"; 2 | import { Inter } from "next/font/google"; 3 | import "./globals.css"; 4 | 5 | const inter = Inter({ subsets: ["latin"] }); 6 | 7 | export const metadata: Metadata = { 8 | title: "Create Next App", 9 | description: "Generated by create next app", 10 | }; 11 | 12 | export default function RootLayout({ 13 | children, 14 | }: Readonly<{ 15 | children: React.ReactNode; 16 | }>) { 17 | return ( 18 | 19 | {children} 20 | 21 | ); 22 | } 23 | -------------------------------------------------------------------------------- /app/page.tsx: -------------------------------------------------------------------------------- 1 | import Image from "next/image"; 2 | import GitHubLogin from './Login' 3 | import Guestbook from "./Guestbook"; 4 | 5 | export default function Home() { 6 | return ( 7 |
8 |
9 |

10 | My Self-hosted App 11 |

12 | 13 |
14 | 15 |
16 | 17 |
18 | 19 |
20 |
21 |
22 | 23 |
24 |
25 |
26 |
27 |
28 | ); 29 | } 30 | -------------------------------------------------------------------------------- /app/pocketbase.ts: -------------------------------------------------------------------------------- 1 | import PocketBase from 'pocketbase'; 2 | export const pb = new PocketBase(process.env.NEXT_PUBLIC_POCKETBASE_URL || 'http://127.0.0.1:8090') 3 | ; -------------------------------------------------------------------------------- /next.config.mjs: -------------------------------------------------------------------------------- 1 | /** @type {import('next').NextConfig} */ 2 | const nextConfig = {}; 3 | 4 | export default nextConfig; 5 | -------------------------------------------------------------------------------- /nginx.conf: -------------------------------------------------------------------------------- 1 | # Example nginx.conf for self hosting 2 | 3 | server { 4 | listen 80; 5 | server_name linux.fireship.app; 6 | 7 | # Redirect HTTP to HTTPS 8 | return 301 https://$server_name$request_uri; 9 | } 10 | 11 | server { 12 | listen 443 ssl; 13 | server_name linux.fireship.app; 14 | 15 | # SSL configuration using Cloudflare certificates 16 | ssl_certificate /etc/ssl/cert.pem; 17 | ssl_certificate_key /etc/ssl/key.pem; 18 | 19 | # SSL settings (recommended for security) 20 | ssl_protocols TLSv1.2 TLSv1.3; 21 | ssl_prefer_server_ciphers on; 22 | ssl_ciphers ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-CHACHA20-POLY1305:ECDHE-RSA-CHACHA20-POLY1305:DHE-RSA-AES128-GCM-SHA256:DHE-RSA-AES256-GCM-SHA384; 23 | 24 | # Next.js application 25 | location / { 26 | proxy_pass http://localhost:3000; 27 | proxy_http_version 1.1; 28 | proxy_set_header Upgrade $http_upgrade; 29 | proxy_set_header Connection 'upgrade'; 30 | proxy_set_header Host $host; 31 | proxy_cache_bypass $http_upgrade; 32 | } 33 | 34 | # PocketBase API and Admin UI 35 | location /pb/ { 36 | rewrite ^/pb(/.*)$ $1 break; 37 | proxy_pass http://localhost:8090; 38 | proxy_http_version 1.1; 39 | proxy_set_header Upgrade $http_upgrade; 40 | proxy_set_header Connection 'upgrade'; 41 | proxy_set_header Host $host; 42 | proxy_cache_bypass $http_upgrade; 43 | } 44 | } -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "linux-next", 3 | "version": "0.1.0", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "linux-next", 9 | "version": "0.1.0", 10 | "dependencies": { 11 | "next": "14.2.4", 12 | "pocketbase": "^0.21.3", 13 | "react": "^18", 14 | "react-dom": "^18" 15 | }, 16 | "devDependencies": { 17 | "@faker-js/faker": "^8.4.1", 18 | "@types/node": "^20", 19 | "@types/react": "^18", 20 | "@types/react-dom": "^18", 21 | "postcss": "^8", 22 | "tailwindcss": "^3.4.1", 23 | "typescript": "^5" 24 | } 25 | }, 26 | "node_modules/@alloc/quick-lru": { 27 | "version": "5.2.0", 28 | "resolved": "https://registry.npmjs.org/@alloc/quick-lru/-/quick-lru-5.2.0.tgz", 29 | "integrity": "sha512-UrcABB+4bUrFABwbluTIBErXwvbsU/V7TZWfmbgJfbkwiBuziS9gxdODUyuiecfdGQ85jglMW6juS3+z5TsKLw==", 30 | "dev": true, 31 | "engines": { 32 | "node": ">=10" 33 | }, 34 | "funding": { 35 | "url": "https://github.com/sponsors/sindresorhus" 36 | } 37 | }, 38 | "node_modules/@faker-js/faker": { 39 | "version": "8.4.1", 40 | "resolved": "https://registry.npmjs.org/@faker-js/faker/-/faker-8.4.1.tgz", 41 | "integrity": "sha512-XQ3cU+Q8Uqmrbf2e0cIC/QN43sTBSC8KF12u29Mb47tWrt2hAgBXSgpZMj4Ao8Uk0iJcU99QsOCaIL8934obCg==", 42 | "dev": true, 43 | "funding": [ 44 | { 45 | "type": "opencollective", 46 | "url": "https://opencollective.com/fakerjs" 47 | } 48 | ], 49 | "engines": { 50 | "node": "^14.17.0 || ^16.13.0 || >=18.0.0", 51 | "npm": ">=6.14.13" 52 | } 53 | }, 54 | "node_modules/@isaacs/cliui": { 55 | "version": "8.0.2", 56 | "resolved": "https://registry.npmjs.org/@isaacs/cliui/-/cliui-8.0.2.tgz", 57 | "integrity": "sha512-O8jcjabXaleOG9DQ0+ARXWZBTfnP4WNAqzuiJK7ll44AmxGKv/J2M4TPjxjY3znBCfvBXFzucm1twdyFybFqEA==", 58 | "dev": true, 59 | "dependencies": { 60 | "string-width": "^5.1.2", 61 | "string-width-cjs": "npm:string-width@^4.2.0", 62 | "strip-ansi": "^7.0.1", 63 | "strip-ansi-cjs": "npm:strip-ansi@^6.0.1", 64 | "wrap-ansi": "^8.1.0", 65 | "wrap-ansi-cjs": "npm:wrap-ansi@^7.0.0" 66 | }, 67 | "engines": { 68 | "node": ">=12" 69 | } 70 | }, 71 | "node_modules/@jridgewell/gen-mapping": { 72 | "version": "0.3.5", 73 | "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.5.tgz", 74 | "integrity": "sha512-IzL8ZoEDIBRWEzlCcRhOaCupYyN5gdIK+Q6fbFdPDg6HqX6jpkItn7DFIpW9LQzXG6Df9sA7+OKnq0qlz/GaQg==", 75 | "dev": true, 76 | "dependencies": { 77 | "@jridgewell/set-array": "^1.2.1", 78 | "@jridgewell/sourcemap-codec": "^1.4.10", 79 | "@jridgewell/trace-mapping": "^0.3.24" 80 | }, 81 | "engines": { 82 | "node": ">=6.0.0" 83 | } 84 | }, 85 | "node_modules/@jridgewell/resolve-uri": { 86 | "version": "3.1.2", 87 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz", 88 | "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==", 89 | "dev": true, 90 | "engines": { 91 | "node": ">=6.0.0" 92 | } 93 | }, 94 | "node_modules/@jridgewell/set-array": { 95 | "version": "1.2.1", 96 | "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.2.1.tgz", 97 | "integrity": "sha512-R8gLRTZeyp03ymzP/6Lil/28tGeGEzhx1q2k703KGWRAI1VdvPIXdG70VJc2pAMw3NA6JKL5hhFu1sJX0Mnn/A==", 98 | "dev": true, 99 | "engines": { 100 | "node": ">=6.0.0" 101 | } 102 | }, 103 | "node_modules/@jridgewell/sourcemap-codec": { 104 | "version": "1.4.15", 105 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", 106 | "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==", 107 | "dev": true 108 | }, 109 | "node_modules/@jridgewell/trace-mapping": { 110 | "version": "0.3.25", 111 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.25.tgz", 112 | "integrity": "sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==", 113 | "dev": true, 114 | "dependencies": { 115 | "@jridgewell/resolve-uri": "^3.1.0", 116 | "@jridgewell/sourcemap-codec": "^1.4.14" 117 | } 118 | }, 119 | "node_modules/@next/env": { 120 | "version": "14.2.4", 121 | "resolved": "https://registry.npmjs.org/@next/env/-/env-14.2.4.tgz", 122 | "integrity": "sha512-3EtkY5VDkuV2+lNmKlbkibIJxcO4oIHEhBWne6PaAp+76J9KoSsGvNikp6ivzAT8dhhBMYrm6op2pS1ApG0Hzg==" 123 | }, 124 | "node_modules/@next/swc-darwin-arm64": { 125 | "version": "14.2.4", 126 | "resolved": "https://registry.npmjs.org/@next/swc-darwin-arm64/-/swc-darwin-arm64-14.2.4.tgz", 127 | "integrity": "sha512-AH3mO4JlFUqsYcwFUHb1wAKlebHU/Hv2u2kb1pAuRanDZ7pD/A/KPD98RHZmwsJpdHQwfEc/06mgpSzwrJYnNg==", 128 | "cpu": [ 129 | "arm64" 130 | ], 131 | "optional": true, 132 | "os": [ 133 | "darwin" 134 | ], 135 | "engines": { 136 | "node": ">= 10" 137 | } 138 | }, 139 | "node_modules/@next/swc-darwin-x64": { 140 | "version": "14.2.4", 141 | "resolved": "https://registry.npmjs.org/@next/swc-darwin-x64/-/swc-darwin-x64-14.2.4.tgz", 142 | "integrity": "sha512-QVadW73sWIO6E2VroyUjuAxhWLZWEpiFqHdZdoQ/AMpN9YWGuHV8t2rChr0ahy+irKX5mlDU7OY68k3n4tAZTg==", 143 | "cpu": [ 144 | "x64" 145 | ], 146 | "optional": true, 147 | "os": [ 148 | "darwin" 149 | ], 150 | "engines": { 151 | "node": ">= 10" 152 | } 153 | }, 154 | "node_modules/@next/swc-linux-arm64-gnu": { 155 | "version": "14.2.4", 156 | "resolved": "https://registry.npmjs.org/@next/swc-linux-arm64-gnu/-/swc-linux-arm64-gnu-14.2.4.tgz", 157 | "integrity": "sha512-KT6GUrb3oyCfcfJ+WliXuJnD6pCpZiosx2X3k66HLR+DMoilRb76LpWPGb4tZprawTtcnyrv75ElD6VncVamUQ==", 158 | "cpu": [ 159 | "arm64" 160 | ], 161 | "optional": true, 162 | "os": [ 163 | "linux" 164 | ], 165 | "engines": { 166 | "node": ">= 10" 167 | } 168 | }, 169 | "node_modules/@next/swc-linux-arm64-musl": { 170 | "version": "14.2.4", 171 | "resolved": "https://registry.npmjs.org/@next/swc-linux-arm64-musl/-/swc-linux-arm64-musl-14.2.4.tgz", 172 | "integrity": "sha512-Alv8/XGSs/ytwQcbCHwze1HmiIkIVhDHYLjczSVrf0Wi2MvKn/blt7+S6FJitj3yTlMwMxII1gIJ9WepI4aZ/A==", 173 | "cpu": [ 174 | "arm64" 175 | ], 176 | "optional": true, 177 | "os": [ 178 | "linux" 179 | ], 180 | "engines": { 181 | "node": ">= 10" 182 | } 183 | }, 184 | "node_modules/@next/swc-linux-x64-gnu": { 185 | "version": "14.2.4", 186 | "resolved": "https://registry.npmjs.org/@next/swc-linux-x64-gnu/-/swc-linux-x64-gnu-14.2.4.tgz", 187 | "integrity": "sha512-ze0ShQDBPCqxLImzw4sCdfnB3lRmN3qGMB2GWDRlq5Wqy4G36pxtNOo2usu/Nm9+V2Rh/QQnrRc2l94kYFXO6Q==", 188 | "cpu": [ 189 | "x64" 190 | ], 191 | "optional": true, 192 | "os": [ 193 | "linux" 194 | ], 195 | "engines": { 196 | "node": ">= 10" 197 | } 198 | }, 199 | "node_modules/@next/swc-linux-x64-musl": { 200 | "version": "14.2.4", 201 | "resolved": "https://registry.npmjs.org/@next/swc-linux-x64-musl/-/swc-linux-x64-musl-14.2.4.tgz", 202 | "integrity": "sha512-8dwC0UJoc6fC7PX70csdaznVMNr16hQrTDAMPvLPloazlcaWfdPogq+UpZX6Drqb1OBlwowz8iG7WR0Tzk/diQ==", 203 | "cpu": [ 204 | "x64" 205 | ], 206 | "optional": true, 207 | "os": [ 208 | "linux" 209 | ], 210 | "engines": { 211 | "node": ">= 10" 212 | } 213 | }, 214 | "node_modules/@next/swc-win32-arm64-msvc": { 215 | "version": "14.2.4", 216 | "resolved": "https://registry.npmjs.org/@next/swc-win32-arm64-msvc/-/swc-win32-arm64-msvc-14.2.4.tgz", 217 | "integrity": "sha512-jxyg67NbEWkDyvM+O8UDbPAyYRZqGLQDTPwvrBBeOSyVWW/jFQkQKQ70JDqDSYg1ZDdl+E3nkbFbq8xM8E9x8A==", 218 | "cpu": [ 219 | "arm64" 220 | ], 221 | "optional": true, 222 | "os": [ 223 | "win32" 224 | ], 225 | "engines": { 226 | "node": ">= 10" 227 | } 228 | }, 229 | "node_modules/@next/swc-win32-ia32-msvc": { 230 | "version": "14.2.4", 231 | "resolved": "https://registry.npmjs.org/@next/swc-win32-ia32-msvc/-/swc-win32-ia32-msvc-14.2.4.tgz", 232 | "integrity": "sha512-twrmN753hjXRdcrZmZttb/m5xaCBFa48Dt3FbeEItpJArxriYDunWxJn+QFXdJ3hPkm4u7CKxncVvnmgQMY1ag==", 233 | "cpu": [ 234 | "ia32" 235 | ], 236 | "optional": true, 237 | "os": [ 238 | "win32" 239 | ], 240 | "engines": { 241 | "node": ">= 10" 242 | } 243 | }, 244 | "node_modules/@next/swc-win32-x64-msvc": { 245 | "version": "14.2.4", 246 | "resolved": "https://registry.npmjs.org/@next/swc-win32-x64-msvc/-/swc-win32-x64-msvc-14.2.4.tgz", 247 | "integrity": "sha512-tkLrjBzqFTP8DVrAAQmZelEahfR9OxWpFR++vAI9FBhCiIxtwHwBHC23SBHCTURBtwB4kc/x44imVOnkKGNVGg==", 248 | "cpu": [ 249 | "x64" 250 | ], 251 | "optional": true, 252 | "os": [ 253 | "win32" 254 | ], 255 | "engines": { 256 | "node": ">= 10" 257 | } 258 | }, 259 | "node_modules/@nodelib/fs.scandir": { 260 | "version": "2.1.5", 261 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 262 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 263 | "dev": true, 264 | "dependencies": { 265 | "@nodelib/fs.stat": "2.0.5", 266 | "run-parallel": "^1.1.9" 267 | }, 268 | "engines": { 269 | "node": ">= 8" 270 | } 271 | }, 272 | "node_modules/@nodelib/fs.stat": { 273 | "version": "2.0.5", 274 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 275 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 276 | "dev": true, 277 | "engines": { 278 | "node": ">= 8" 279 | } 280 | }, 281 | "node_modules/@nodelib/fs.walk": { 282 | "version": "1.2.8", 283 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 284 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 285 | "dev": true, 286 | "dependencies": { 287 | "@nodelib/fs.scandir": "2.1.5", 288 | "fastq": "^1.6.0" 289 | }, 290 | "engines": { 291 | "node": ">= 8" 292 | } 293 | }, 294 | "node_modules/@pkgjs/parseargs": { 295 | "version": "0.11.0", 296 | "resolved": "https://registry.npmjs.org/@pkgjs/parseargs/-/parseargs-0.11.0.tgz", 297 | "integrity": "sha512-+1VkjdD0QBLPodGrJUeqarH8VAIvQODIbwh9XpP5Syisf7YoQgsJKPNFoqqLQlu+VQ/tVSshMR6loPMn8U+dPg==", 298 | "dev": true, 299 | "optional": true, 300 | "engines": { 301 | "node": ">=14" 302 | } 303 | }, 304 | "node_modules/@swc/counter": { 305 | "version": "0.1.3", 306 | "resolved": "https://registry.npmjs.org/@swc/counter/-/counter-0.1.3.tgz", 307 | "integrity": "sha512-e2BR4lsJkkRlKZ/qCHPw9ZaSxc0MVUd7gtbtaB7aMvHeJVYe8sOB8DBZkP2DtISHGSku9sCK6T6cnY0CtXrOCQ==" 308 | }, 309 | "node_modules/@swc/helpers": { 310 | "version": "0.5.5", 311 | "resolved": "https://registry.npmjs.org/@swc/helpers/-/helpers-0.5.5.tgz", 312 | "integrity": "sha512-KGYxvIOXcceOAbEk4bi/dVLEK9z8sZ0uBB3Il5b1rhfClSpcX0yfRO0KmTkqR2cnQDymwLB+25ZyMzICg/cm/A==", 313 | "dependencies": { 314 | "@swc/counter": "^0.1.3", 315 | "tslib": "^2.4.0" 316 | } 317 | }, 318 | "node_modules/@types/node": { 319 | "version": "20.14.8", 320 | "resolved": "https://registry.npmjs.org/@types/node/-/node-20.14.8.tgz", 321 | "integrity": "sha512-DO+2/jZinXfROG7j7WKFn/3C6nFwxy2lLpgLjEXJz+0XKphZlTLJ14mo8Vfg8X5BWN6XjyESXq+LcYdT7tR3bA==", 322 | "dev": true, 323 | "dependencies": { 324 | "undici-types": "~5.26.4" 325 | } 326 | }, 327 | "node_modules/@types/prop-types": { 328 | "version": "15.7.12", 329 | "resolved": "https://registry.npmjs.org/@types/prop-types/-/prop-types-15.7.12.tgz", 330 | "integrity": "sha512-5zvhXYtRNRluoE/jAp4GVsSduVUzNWKkOZrCDBWYtE7biZywwdC2AcEzg+cSMLFRfVgeAFqpfNabiPjxFddV1Q==", 331 | "dev": true 332 | }, 333 | "node_modules/@types/react": { 334 | "version": "18.3.3", 335 | "resolved": "https://registry.npmjs.org/@types/react/-/react-18.3.3.tgz", 336 | "integrity": "sha512-hti/R0pS0q1/xx+TsI73XIqk26eBsISZ2R0wUijXIngRK9R/e7Xw/cXVxQK7R5JjW+SV4zGcn5hXjudkN/pLIw==", 337 | "dev": true, 338 | "dependencies": { 339 | "@types/prop-types": "*", 340 | "csstype": "^3.0.2" 341 | } 342 | }, 343 | "node_modules/@types/react-dom": { 344 | "version": "18.3.0", 345 | "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-18.3.0.tgz", 346 | "integrity": "sha512-EhwApuTmMBmXuFOikhQLIBUn6uFg81SwLMOAUgodJF14SOBOCMdU04gDoYi0WOJJHD144TL32z4yDqCW3dnkQg==", 347 | "dev": true, 348 | "dependencies": { 349 | "@types/react": "*" 350 | } 351 | }, 352 | "node_modules/ansi-regex": { 353 | "version": "6.0.1", 354 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.0.1.tgz", 355 | "integrity": "sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==", 356 | "dev": true, 357 | "engines": { 358 | "node": ">=12" 359 | }, 360 | "funding": { 361 | "url": "https://github.com/chalk/ansi-regex?sponsor=1" 362 | } 363 | }, 364 | "node_modules/ansi-styles": { 365 | "version": "6.2.1", 366 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz", 367 | "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==", 368 | "dev": true, 369 | "engines": { 370 | "node": ">=12" 371 | }, 372 | "funding": { 373 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 374 | } 375 | }, 376 | "node_modules/any-promise": { 377 | "version": "1.3.0", 378 | "resolved": "https://registry.npmjs.org/any-promise/-/any-promise-1.3.0.tgz", 379 | "integrity": "sha512-7UvmKalWRt1wgjL1RrGxoSJW/0QZFIegpeGvZG9kjp8vrRu55XTHbwnqq2GpXm9uLbcuhxm3IqX9OB4MZR1b2A==", 380 | "dev": true 381 | }, 382 | "node_modules/anymatch": { 383 | "version": "3.1.3", 384 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 385 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 386 | "dev": true, 387 | "dependencies": { 388 | "normalize-path": "^3.0.0", 389 | "picomatch": "^2.0.4" 390 | }, 391 | "engines": { 392 | "node": ">= 8" 393 | } 394 | }, 395 | "node_modules/arg": { 396 | "version": "5.0.2", 397 | "resolved": "https://registry.npmjs.org/arg/-/arg-5.0.2.tgz", 398 | "integrity": "sha512-PYjyFOLKQ9y57JvQ6QLo8dAgNqswh8M1RMJYdQduT6xbWSgK36P/Z/v+p888pM69jMMfS8Xd8F6I1kQ/I9HUGg==", 399 | "dev": true 400 | }, 401 | "node_modules/balanced-match": { 402 | "version": "1.0.2", 403 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 404 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 405 | "dev": true 406 | }, 407 | "node_modules/binary-extensions": { 408 | "version": "2.3.0", 409 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.3.0.tgz", 410 | "integrity": "sha512-Ceh+7ox5qe7LJuLHoY0feh3pHuUDHAcRUeyL2VYghZwfpkNIy/+8Ocg0a3UuSoYzavmylwuLWQOf3hl0jjMMIw==", 411 | "dev": true, 412 | "engines": { 413 | "node": ">=8" 414 | }, 415 | "funding": { 416 | "url": "https://github.com/sponsors/sindresorhus" 417 | } 418 | }, 419 | "node_modules/brace-expansion": { 420 | "version": "2.0.1", 421 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 422 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 423 | "dev": true, 424 | "dependencies": { 425 | "balanced-match": "^1.0.0" 426 | } 427 | }, 428 | "node_modules/braces": { 429 | "version": "3.0.3", 430 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.3.tgz", 431 | "integrity": "sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==", 432 | "dev": true, 433 | "dependencies": { 434 | "fill-range": "^7.1.1" 435 | }, 436 | "engines": { 437 | "node": ">=8" 438 | } 439 | }, 440 | "node_modules/busboy": { 441 | "version": "1.6.0", 442 | "resolved": "https://registry.npmjs.org/busboy/-/busboy-1.6.0.tgz", 443 | "integrity": "sha512-8SFQbg/0hQ9xy3UNTB0YEnsNBbWfhf7RtnzpL7TkBiTBRfrQ9Fxcnz7VJsleJpyp6rVLvXiuORqjlHi5q+PYuA==", 444 | "dependencies": { 445 | "streamsearch": "^1.1.0" 446 | }, 447 | "engines": { 448 | "node": ">=10.16.0" 449 | } 450 | }, 451 | "node_modules/camelcase-css": { 452 | "version": "2.0.1", 453 | "resolved": "https://registry.npmjs.org/camelcase-css/-/camelcase-css-2.0.1.tgz", 454 | "integrity": "sha512-QOSvevhslijgYwRx6Rv7zKdMF8lbRmx+uQGx2+vDc+KI/eBnsy9kit5aj23AgGu3pa4t9AgwbnXWqS+iOY+2aA==", 455 | "dev": true, 456 | "engines": { 457 | "node": ">= 6" 458 | } 459 | }, 460 | "node_modules/caniuse-lite": { 461 | "version": "1.0.30001636", 462 | "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001636.tgz", 463 | "integrity": "sha512-bMg2vmr8XBsbL6Lr0UHXy/21m84FTxDLWn2FSqMd5PrlbMxwJlQnC2YWYxVgp66PZE+BBNF2jYQUBKCo1FDeZg==", 464 | "funding": [ 465 | { 466 | "type": "opencollective", 467 | "url": "https://opencollective.com/browserslist" 468 | }, 469 | { 470 | "type": "tidelift", 471 | "url": "https://tidelift.com/funding/github/npm/caniuse-lite" 472 | }, 473 | { 474 | "type": "github", 475 | "url": "https://github.com/sponsors/ai" 476 | } 477 | ] 478 | }, 479 | "node_modules/chokidar": { 480 | "version": "3.6.0", 481 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.6.0.tgz", 482 | "integrity": "sha512-7VT13fmjotKpGipCW9JEQAusEPE+Ei8nl6/g4FBAmIm0GOOLMua9NDDo/DWp0ZAxCr3cPq5ZpBqmPAQgDda2Pw==", 483 | "dev": true, 484 | "dependencies": { 485 | "anymatch": "~3.1.2", 486 | "braces": "~3.0.2", 487 | "glob-parent": "~5.1.2", 488 | "is-binary-path": "~2.1.0", 489 | "is-glob": "~4.0.1", 490 | "normalize-path": "~3.0.0", 491 | "readdirp": "~3.6.0" 492 | }, 493 | "engines": { 494 | "node": ">= 8.10.0" 495 | }, 496 | "funding": { 497 | "url": "https://paulmillr.com/funding/" 498 | }, 499 | "optionalDependencies": { 500 | "fsevents": "~2.3.2" 501 | } 502 | }, 503 | "node_modules/chokidar/node_modules/glob-parent": { 504 | "version": "5.1.2", 505 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 506 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 507 | "dev": true, 508 | "dependencies": { 509 | "is-glob": "^4.0.1" 510 | }, 511 | "engines": { 512 | "node": ">= 6" 513 | } 514 | }, 515 | "node_modules/client-only": { 516 | "version": "0.0.1", 517 | "resolved": "https://registry.npmjs.org/client-only/-/client-only-0.0.1.tgz", 518 | "integrity": "sha512-IV3Ou0jSMzZrd3pZ48nLkT9DA7Ag1pnPzaiQhpW7c3RbcqqzvzzVu+L8gfqMp/8IM2MQtSiqaCxrrcfu8I8rMA==" 519 | }, 520 | "node_modules/color-convert": { 521 | "version": "2.0.1", 522 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 523 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 524 | "dev": true, 525 | "dependencies": { 526 | "color-name": "~1.1.4" 527 | }, 528 | "engines": { 529 | "node": ">=7.0.0" 530 | } 531 | }, 532 | "node_modules/color-name": { 533 | "version": "1.1.4", 534 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 535 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 536 | "dev": true 537 | }, 538 | "node_modules/commander": { 539 | "version": "4.1.1", 540 | "resolved": "https://registry.npmjs.org/commander/-/commander-4.1.1.tgz", 541 | "integrity": "sha512-NOKm8xhkzAjzFx8B2v5OAHT+u5pRQc2UCa2Vq9jYL/31o2wi9mxBA7LIFs3sV5VSC49z6pEhfbMULvShKj26WA==", 542 | "dev": true, 543 | "engines": { 544 | "node": ">= 6" 545 | } 546 | }, 547 | "node_modules/cross-spawn": { 548 | "version": "7.0.3", 549 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 550 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 551 | "dev": true, 552 | "dependencies": { 553 | "path-key": "^3.1.0", 554 | "shebang-command": "^2.0.0", 555 | "which": "^2.0.1" 556 | }, 557 | "engines": { 558 | "node": ">= 8" 559 | } 560 | }, 561 | "node_modules/cssesc": { 562 | "version": "3.0.0", 563 | "resolved": "https://registry.npmjs.org/cssesc/-/cssesc-3.0.0.tgz", 564 | "integrity": "sha512-/Tb/JcjK111nNScGob5MNtsntNM1aCNUDipB/TkwZFhyDrrE47SOx/18wF2bbjgc3ZzCSKW1T5nt5EbFoAz/Vg==", 565 | "dev": true, 566 | "bin": { 567 | "cssesc": "bin/cssesc" 568 | }, 569 | "engines": { 570 | "node": ">=4" 571 | } 572 | }, 573 | "node_modules/csstype": { 574 | "version": "3.1.3", 575 | "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.3.tgz", 576 | "integrity": "sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw==", 577 | "dev": true 578 | }, 579 | "node_modules/didyoumean": { 580 | "version": "1.2.2", 581 | "resolved": "https://registry.npmjs.org/didyoumean/-/didyoumean-1.2.2.tgz", 582 | "integrity": "sha512-gxtyfqMg7GKyhQmb056K7M3xszy/myH8w+B4RT+QXBQsvAOdc3XymqDDPHx1BgPgsdAA5SIifona89YtRATDzw==", 583 | "dev": true 584 | }, 585 | "node_modules/dlv": { 586 | "version": "1.1.3", 587 | "resolved": "https://registry.npmjs.org/dlv/-/dlv-1.1.3.tgz", 588 | "integrity": "sha512-+HlytyjlPKnIG8XuRG8WvmBP8xs8P71y+SKKS6ZXWoEgLuePxtDoUEiH7WkdePWrQ5JBpE6aoVqfZfJUQkjXwA==", 589 | "dev": true 590 | }, 591 | "node_modules/eastasianwidth": { 592 | "version": "0.2.0", 593 | "resolved": "https://registry.npmjs.org/eastasianwidth/-/eastasianwidth-0.2.0.tgz", 594 | "integrity": "sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==", 595 | "dev": true 596 | }, 597 | "node_modules/emoji-regex": { 598 | "version": "9.2.2", 599 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-9.2.2.tgz", 600 | "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==", 601 | "dev": true 602 | }, 603 | "node_modules/fast-glob": { 604 | "version": "3.3.2", 605 | "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.3.2.tgz", 606 | "integrity": "sha512-oX2ruAFQwf/Orj8m737Y5adxDQO0LAB7/S5MnxCdTNDd4p6BsyIVsv9JQsATbTSq8KHRpLwIHbVlUNatxd+1Ow==", 607 | "dev": true, 608 | "dependencies": { 609 | "@nodelib/fs.stat": "^2.0.2", 610 | "@nodelib/fs.walk": "^1.2.3", 611 | "glob-parent": "^5.1.2", 612 | "merge2": "^1.3.0", 613 | "micromatch": "^4.0.4" 614 | }, 615 | "engines": { 616 | "node": ">=8.6.0" 617 | } 618 | }, 619 | "node_modules/fast-glob/node_modules/glob-parent": { 620 | "version": "5.1.2", 621 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 622 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 623 | "dev": true, 624 | "dependencies": { 625 | "is-glob": "^4.0.1" 626 | }, 627 | "engines": { 628 | "node": ">= 6" 629 | } 630 | }, 631 | "node_modules/fastq": { 632 | "version": "1.17.1", 633 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.17.1.tgz", 634 | "integrity": "sha512-sRVD3lWVIXWg6By68ZN7vho9a1pQcN/WBFaAAsDDFzlJjvoGx0P8z7V1t72grFJfJhu3YPZBuu25f7Kaw2jN1w==", 635 | "dev": true, 636 | "dependencies": { 637 | "reusify": "^1.0.4" 638 | } 639 | }, 640 | "node_modules/fill-range": { 641 | "version": "7.1.1", 642 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.1.1.tgz", 643 | "integrity": "sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==", 644 | "dev": true, 645 | "dependencies": { 646 | "to-regex-range": "^5.0.1" 647 | }, 648 | "engines": { 649 | "node": ">=8" 650 | } 651 | }, 652 | "node_modules/foreground-child": { 653 | "version": "3.2.1", 654 | "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-3.2.1.tgz", 655 | "integrity": "sha512-PXUUyLqrR2XCWICfv6ukppP96sdFwWbNEnfEMt7jNsISjMsvaLNinAHNDYyvkyU+SZG2BTSbT5NjG+vZslfGTA==", 656 | "dev": true, 657 | "dependencies": { 658 | "cross-spawn": "^7.0.0", 659 | "signal-exit": "^4.0.1" 660 | }, 661 | "engines": { 662 | "node": ">=14" 663 | }, 664 | "funding": { 665 | "url": "https://github.com/sponsors/isaacs" 666 | } 667 | }, 668 | "node_modules/fsevents": { 669 | "version": "2.3.3", 670 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", 671 | "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", 672 | "dev": true, 673 | "hasInstallScript": true, 674 | "optional": true, 675 | "os": [ 676 | "darwin" 677 | ], 678 | "engines": { 679 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 680 | } 681 | }, 682 | "node_modules/function-bind": { 683 | "version": "1.1.2", 684 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", 685 | "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", 686 | "dev": true, 687 | "funding": { 688 | "url": "https://github.com/sponsors/ljharb" 689 | } 690 | }, 691 | "node_modules/glob": { 692 | "version": "10.4.2", 693 | "resolved": "https://registry.npmjs.org/glob/-/glob-10.4.2.tgz", 694 | "integrity": "sha512-GwMlUF6PkPo3Gk21UxkCohOv0PLcIXVtKyLlpEI28R/cO/4eNOdmLk3CMW1wROV/WR/EsZOWAfBbBOqYvs88/w==", 695 | "dev": true, 696 | "dependencies": { 697 | "foreground-child": "^3.1.0", 698 | "jackspeak": "^3.1.2", 699 | "minimatch": "^9.0.4", 700 | "minipass": "^7.1.2", 701 | "package-json-from-dist": "^1.0.0", 702 | "path-scurry": "^1.11.1" 703 | }, 704 | "bin": { 705 | "glob": "dist/esm/bin.mjs" 706 | }, 707 | "engines": { 708 | "node": ">=16 || 14 >=14.18" 709 | }, 710 | "funding": { 711 | "url": "https://github.com/sponsors/isaacs" 712 | } 713 | }, 714 | "node_modules/glob-parent": { 715 | "version": "6.0.2", 716 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 717 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 718 | "dev": true, 719 | "dependencies": { 720 | "is-glob": "^4.0.3" 721 | }, 722 | "engines": { 723 | "node": ">=10.13.0" 724 | } 725 | }, 726 | "node_modules/graceful-fs": { 727 | "version": "4.2.11", 728 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", 729 | "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==" 730 | }, 731 | "node_modules/hasown": { 732 | "version": "2.0.2", 733 | "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz", 734 | "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==", 735 | "dev": true, 736 | "dependencies": { 737 | "function-bind": "^1.1.2" 738 | }, 739 | "engines": { 740 | "node": ">= 0.4" 741 | } 742 | }, 743 | "node_modules/is-binary-path": { 744 | "version": "2.1.0", 745 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 746 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 747 | "dev": true, 748 | "dependencies": { 749 | "binary-extensions": "^2.0.0" 750 | }, 751 | "engines": { 752 | "node": ">=8" 753 | } 754 | }, 755 | "node_modules/is-core-module": { 756 | "version": "2.14.0", 757 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.14.0.tgz", 758 | "integrity": "sha512-a5dFJih5ZLYlRtDc0dZWP7RiKr6xIKzmn/oAYCDvdLThadVgyJwlaoQPmRtMSpz+rk0OGAgIu+TcM9HUF0fk1A==", 759 | "dev": true, 760 | "dependencies": { 761 | "hasown": "^2.0.2" 762 | }, 763 | "engines": { 764 | "node": ">= 0.4" 765 | }, 766 | "funding": { 767 | "url": "https://github.com/sponsors/ljharb" 768 | } 769 | }, 770 | "node_modules/is-extglob": { 771 | "version": "2.1.1", 772 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 773 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 774 | "dev": true, 775 | "engines": { 776 | "node": ">=0.10.0" 777 | } 778 | }, 779 | "node_modules/is-fullwidth-code-point": { 780 | "version": "3.0.0", 781 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 782 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 783 | "dev": true, 784 | "engines": { 785 | "node": ">=8" 786 | } 787 | }, 788 | "node_modules/is-glob": { 789 | "version": "4.0.3", 790 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 791 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 792 | "dev": true, 793 | "dependencies": { 794 | "is-extglob": "^2.1.1" 795 | }, 796 | "engines": { 797 | "node": ">=0.10.0" 798 | } 799 | }, 800 | "node_modules/is-number": { 801 | "version": "7.0.0", 802 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 803 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 804 | "dev": true, 805 | "engines": { 806 | "node": ">=0.12.0" 807 | } 808 | }, 809 | "node_modules/isexe": { 810 | "version": "2.0.0", 811 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 812 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 813 | "dev": true 814 | }, 815 | "node_modules/jackspeak": { 816 | "version": "3.4.0", 817 | "resolved": "https://registry.npmjs.org/jackspeak/-/jackspeak-3.4.0.tgz", 818 | "integrity": "sha512-JVYhQnN59LVPFCEcVa2C3CrEKYacvjRfqIQl+h8oi91aLYQVWRYbxjPcv1bUiUy/kLmQaANrYfNMCO3kuEDHfw==", 819 | "dev": true, 820 | "dependencies": { 821 | "@isaacs/cliui": "^8.0.2" 822 | }, 823 | "engines": { 824 | "node": ">=14" 825 | }, 826 | "funding": { 827 | "url": "https://github.com/sponsors/isaacs" 828 | }, 829 | "optionalDependencies": { 830 | "@pkgjs/parseargs": "^0.11.0" 831 | } 832 | }, 833 | "node_modules/jiti": { 834 | "version": "1.21.6", 835 | "resolved": "https://registry.npmjs.org/jiti/-/jiti-1.21.6.tgz", 836 | "integrity": "sha512-2yTgeWTWzMWkHu6Jp9NKgePDaYHbntiwvYuuJLbbN9vl7DC9DvXKOB2BC3ZZ92D3cvV/aflH0osDfwpHepQ53w==", 837 | "dev": true, 838 | "bin": { 839 | "jiti": "bin/jiti.js" 840 | } 841 | }, 842 | "node_modules/js-tokens": { 843 | "version": "4.0.0", 844 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 845 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==" 846 | }, 847 | "node_modules/lilconfig": { 848 | "version": "2.1.0", 849 | "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-2.1.0.tgz", 850 | "integrity": "sha512-utWOt/GHzuUxnLKxB6dk81RoOeoNeHgbrXiuGk4yyF5qlRz+iIVWu56E2fqGHFrXz0QNUhLB/8nKqvRH66JKGQ==", 851 | "dev": true, 852 | "engines": { 853 | "node": ">=10" 854 | } 855 | }, 856 | "node_modules/lines-and-columns": { 857 | "version": "1.2.4", 858 | "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz", 859 | "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==", 860 | "dev": true 861 | }, 862 | "node_modules/loose-envify": { 863 | "version": "1.4.0", 864 | "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", 865 | "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", 866 | "dependencies": { 867 | "js-tokens": "^3.0.0 || ^4.0.0" 868 | }, 869 | "bin": { 870 | "loose-envify": "cli.js" 871 | } 872 | }, 873 | "node_modules/lru-cache": { 874 | "version": "10.2.2", 875 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-10.2.2.tgz", 876 | "integrity": "sha512-9hp3Vp2/hFQUiIwKo8XCeFVnrg8Pk3TYNPIR7tJADKi5YfcF7vEaK7avFHTlSy3kOKYaJQaalfEo6YuXdceBOQ==", 877 | "dev": true, 878 | "engines": { 879 | "node": "14 || >=16.14" 880 | } 881 | }, 882 | "node_modules/merge2": { 883 | "version": "1.4.1", 884 | "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", 885 | "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", 886 | "dev": true, 887 | "engines": { 888 | "node": ">= 8" 889 | } 890 | }, 891 | "node_modules/micromatch": { 892 | "version": "4.0.7", 893 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.7.tgz", 894 | "integrity": "sha512-LPP/3KorzCwBxfeUuZmaR6bG2kdeHSbe0P2tY3FLRU4vYrjYz5hI4QZwV0njUx3jeuKe67YukQ1LSPZBKDqO/Q==", 895 | "dev": true, 896 | "dependencies": { 897 | "braces": "^3.0.3", 898 | "picomatch": "^2.3.1" 899 | }, 900 | "engines": { 901 | "node": ">=8.6" 902 | } 903 | }, 904 | "node_modules/minimatch": { 905 | "version": "9.0.4", 906 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.4.tgz", 907 | "integrity": "sha512-KqWh+VchfxcMNRAJjj2tnsSJdNbHsVgnkBhTNrW7AjVo6OvLtxw8zfT9oLw1JSohlFzJ8jCoTgaoXvJ+kHt6fw==", 908 | "dev": true, 909 | "dependencies": { 910 | "brace-expansion": "^2.0.1" 911 | }, 912 | "engines": { 913 | "node": ">=16 || 14 >=14.17" 914 | }, 915 | "funding": { 916 | "url": "https://github.com/sponsors/isaacs" 917 | } 918 | }, 919 | "node_modules/minipass": { 920 | "version": "7.1.2", 921 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-7.1.2.tgz", 922 | "integrity": "sha512-qOOzS1cBTWYF4BH8fVePDBOO9iptMnGUEZwNc/cMWnTV2nVLZ7VoNWEPHkYczZA0pdoA7dl6e7FL659nX9S2aw==", 923 | "dev": true, 924 | "engines": { 925 | "node": ">=16 || 14 >=14.17" 926 | } 927 | }, 928 | "node_modules/mz": { 929 | "version": "2.7.0", 930 | "resolved": "https://registry.npmjs.org/mz/-/mz-2.7.0.tgz", 931 | "integrity": "sha512-z81GNO7nnYMEhrGh9LeymoE4+Yr0Wn5McHIZMK5cfQCl+NDX08sCZgUc9/6MHni9IWuFLm1Z3HTCXu2z9fN62Q==", 932 | "dev": true, 933 | "dependencies": { 934 | "any-promise": "^1.0.0", 935 | "object-assign": "^4.0.1", 936 | "thenify-all": "^1.0.0" 937 | } 938 | }, 939 | "node_modules/nanoid": { 940 | "version": "3.3.7", 941 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.7.tgz", 942 | "integrity": "sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==", 943 | "funding": [ 944 | { 945 | "type": "github", 946 | "url": "https://github.com/sponsors/ai" 947 | } 948 | ], 949 | "bin": { 950 | "nanoid": "bin/nanoid.cjs" 951 | }, 952 | "engines": { 953 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" 954 | } 955 | }, 956 | "node_modules/next": { 957 | "version": "14.2.4", 958 | "resolved": "https://registry.npmjs.org/next/-/next-14.2.4.tgz", 959 | "integrity": "sha512-R8/V7vugY+822rsQGQCjoLhMuC9oFj9SOi4Cl4b2wjDrseD0LRZ10W7R6Czo4w9ZznVSshKjuIomsRjvm9EKJQ==", 960 | "dependencies": { 961 | "@next/env": "14.2.4", 962 | "@swc/helpers": "0.5.5", 963 | "busboy": "1.6.0", 964 | "caniuse-lite": "^1.0.30001579", 965 | "graceful-fs": "^4.2.11", 966 | "postcss": "8.4.31", 967 | "styled-jsx": "5.1.1" 968 | }, 969 | "bin": { 970 | "next": "dist/bin/next" 971 | }, 972 | "engines": { 973 | "node": ">=18.17.0" 974 | }, 975 | "optionalDependencies": { 976 | "@next/swc-darwin-arm64": "14.2.4", 977 | "@next/swc-darwin-x64": "14.2.4", 978 | "@next/swc-linux-arm64-gnu": "14.2.4", 979 | "@next/swc-linux-arm64-musl": "14.2.4", 980 | "@next/swc-linux-x64-gnu": "14.2.4", 981 | "@next/swc-linux-x64-musl": "14.2.4", 982 | "@next/swc-win32-arm64-msvc": "14.2.4", 983 | "@next/swc-win32-ia32-msvc": "14.2.4", 984 | "@next/swc-win32-x64-msvc": "14.2.4" 985 | }, 986 | "peerDependencies": { 987 | "@opentelemetry/api": "^1.1.0", 988 | "@playwright/test": "^1.41.2", 989 | "react": "^18.2.0", 990 | "react-dom": "^18.2.0", 991 | "sass": "^1.3.0" 992 | }, 993 | "peerDependenciesMeta": { 994 | "@opentelemetry/api": { 995 | "optional": true 996 | }, 997 | "@playwright/test": { 998 | "optional": true 999 | }, 1000 | "sass": { 1001 | "optional": true 1002 | } 1003 | } 1004 | }, 1005 | "node_modules/next/node_modules/postcss": { 1006 | "version": "8.4.31", 1007 | "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.31.tgz", 1008 | "integrity": "sha512-PS08Iboia9mts/2ygV3eLpY5ghnUcfLV/EXTOW1E2qYxJKGGBUtNjN76FYHnMs36RmARn41bC0AZmn+rR0OVpQ==", 1009 | "funding": [ 1010 | { 1011 | "type": "opencollective", 1012 | "url": "https://opencollective.com/postcss/" 1013 | }, 1014 | { 1015 | "type": "tidelift", 1016 | "url": "https://tidelift.com/funding/github/npm/postcss" 1017 | }, 1018 | { 1019 | "type": "github", 1020 | "url": "https://github.com/sponsors/ai" 1021 | } 1022 | ], 1023 | "dependencies": { 1024 | "nanoid": "^3.3.6", 1025 | "picocolors": "^1.0.0", 1026 | "source-map-js": "^1.0.2" 1027 | }, 1028 | "engines": { 1029 | "node": "^10 || ^12 || >=14" 1030 | } 1031 | }, 1032 | "node_modules/normalize-path": { 1033 | "version": "3.0.0", 1034 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1035 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1036 | "dev": true, 1037 | "engines": { 1038 | "node": ">=0.10.0" 1039 | } 1040 | }, 1041 | "node_modules/object-assign": { 1042 | "version": "4.1.1", 1043 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1044 | "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==", 1045 | "dev": true, 1046 | "engines": { 1047 | "node": ">=0.10.0" 1048 | } 1049 | }, 1050 | "node_modules/object-hash": { 1051 | "version": "3.0.0", 1052 | "resolved": "https://registry.npmjs.org/object-hash/-/object-hash-3.0.0.tgz", 1053 | "integrity": "sha512-RSn9F68PjH9HqtltsSnqYC1XXoWe9Bju5+213R98cNGttag9q9yAOTzdbsqvIa7aNm5WffBZFpWYr2aWrklWAw==", 1054 | "dev": true, 1055 | "engines": { 1056 | "node": ">= 6" 1057 | } 1058 | }, 1059 | "node_modules/package-json-from-dist": { 1060 | "version": "1.0.0", 1061 | "resolved": "https://registry.npmjs.org/package-json-from-dist/-/package-json-from-dist-1.0.0.tgz", 1062 | "integrity": "sha512-dATvCeZN/8wQsGywez1mzHtTlP22H8OEfPrVMLNr4/eGa+ijtLn/6M5f0dY8UKNrC2O9UCU6SSoG3qRKnt7STw==", 1063 | "dev": true 1064 | }, 1065 | "node_modules/path-key": { 1066 | "version": "3.1.1", 1067 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1068 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1069 | "dev": true, 1070 | "engines": { 1071 | "node": ">=8" 1072 | } 1073 | }, 1074 | "node_modules/path-parse": { 1075 | "version": "1.0.7", 1076 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 1077 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 1078 | "dev": true 1079 | }, 1080 | "node_modules/path-scurry": { 1081 | "version": "1.11.1", 1082 | "resolved": "https://registry.npmjs.org/path-scurry/-/path-scurry-1.11.1.tgz", 1083 | "integrity": "sha512-Xa4Nw17FS9ApQFJ9umLiJS4orGjm7ZzwUrwamcGQuHSzDyth9boKDaycYdDcZDuqYATXw4HFXgaqWTctW/v1HA==", 1084 | "dev": true, 1085 | "dependencies": { 1086 | "lru-cache": "^10.2.0", 1087 | "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0" 1088 | }, 1089 | "engines": { 1090 | "node": ">=16 || 14 >=14.18" 1091 | }, 1092 | "funding": { 1093 | "url": "https://github.com/sponsors/isaacs" 1094 | } 1095 | }, 1096 | "node_modules/picocolors": { 1097 | "version": "1.0.1", 1098 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.1.tgz", 1099 | "integrity": "sha512-anP1Z8qwhkbmu7MFP5iTt+wQKXgwzf7zTyGlcdzabySa9vd0Xt392U0rVmz9poOaBj0uHJKyyo9/upk0HrEQew==" 1100 | }, 1101 | "node_modules/picomatch": { 1102 | "version": "2.3.1", 1103 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 1104 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 1105 | "dev": true, 1106 | "engines": { 1107 | "node": ">=8.6" 1108 | }, 1109 | "funding": { 1110 | "url": "https://github.com/sponsors/jonschlinkert" 1111 | } 1112 | }, 1113 | "node_modules/pify": { 1114 | "version": "2.3.0", 1115 | "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", 1116 | "integrity": "sha512-udgsAY+fTnvv7kI7aaxbqwWNb0AHiB0qBO89PZKPkoTmGOgdbrHDKD+0B2X4uTfJ/FT1R09r9gTsjUjNJotuog==", 1117 | "dev": true, 1118 | "engines": { 1119 | "node": ">=0.10.0" 1120 | } 1121 | }, 1122 | "node_modules/pirates": { 1123 | "version": "4.0.6", 1124 | "resolved": "https://registry.npmjs.org/pirates/-/pirates-4.0.6.tgz", 1125 | "integrity": "sha512-saLsH7WeYYPiD25LDuLRRY/i+6HaPYr6G1OUlN39otzkSTxKnubR9RTxS3/Kk50s1g2JTgFwWQDQyplC5/SHZg==", 1126 | "dev": true, 1127 | "engines": { 1128 | "node": ">= 6" 1129 | } 1130 | }, 1131 | "node_modules/pocketbase": { 1132 | "version": "0.21.3", 1133 | "resolved": "https://registry.npmjs.org/pocketbase/-/pocketbase-0.21.3.tgz", 1134 | "integrity": "sha512-bsQRZ1mj4dhPJ4P5iSrDqWQtBX2NtuBkf6IOZwTv27zZOw6zrISgo963i5JD/99qKKD5aMSMDPGk1BE9ZyI7Cg==" 1135 | }, 1136 | "node_modules/postcss": { 1137 | "version": "8.4.38", 1138 | "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.38.tgz", 1139 | "integrity": "sha512-Wglpdk03BSfXkHoQa3b/oulrotAkwrlLDRSOb9D0bN86FdRyE9lppSp33aHNPgBa0JKCoB+drFLZkQoRRYae5A==", 1140 | "dev": true, 1141 | "funding": [ 1142 | { 1143 | "type": "opencollective", 1144 | "url": "https://opencollective.com/postcss/" 1145 | }, 1146 | { 1147 | "type": "tidelift", 1148 | "url": "https://tidelift.com/funding/github/npm/postcss" 1149 | }, 1150 | { 1151 | "type": "github", 1152 | "url": "https://github.com/sponsors/ai" 1153 | } 1154 | ], 1155 | "dependencies": { 1156 | "nanoid": "^3.3.7", 1157 | "picocolors": "^1.0.0", 1158 | "source-map-js": "^1.2.0" 1159 | }, 1160 | "engines": { 1161 | "node": "^10 || ^12 || >=14" 1162 | } 1163 | }, 1164 | "node_modules/postcss-import": { 1165 | "version": "15.1.0", 1166 | "resolved": "https://registry.npmjs.org/postcss-import/-/postcss-import-15.1.0.tgz", 1167 | "integrity": "sha512-hpr+J05B2FVYUAXHeK1YyI267J/dDDhMU6B6civm8hSY1jYJnBXxzKDKDswzJmtLHryrjhnDjqqp/49t8FALew==", 1168 | "dev": true, 1169 | "dependencies": { 1170 | "postcss-value-parser": "^4.0.0", 1171 | "read-cache": "^1.0.0", 1172 | "resolve": "^1.1.7" 1173 | }, 1174 | "engines": { 1175 | "node": ">=14.0.0" 1176 | }, 1177 | "peerDependencies": { 1178 | "postcss": "^8.0.0" 1179 | } 1180 | }, 1181 | "node_modules/postcss-js": { 1182 | "version": "4.0.1", 1183 | "resolved": "https://registry.npmjs.org/postcss-js/-/postcss-js-4.0.1.tgz", 1184 | "integrity": "sha512-dDLF8pEO191hJMtlHFPRa8xsizHaM82MLfNkUHdUtVEV3tgTp5oj+8qbEqYM57SLfc74KSbw//4SeJma2LRVIw==", 1185 | "dev": true, 1186 | "dependencies": { 1187 | "camelcase-css": "^2.0.1" 1188 | }, 1189 | "engines": { 1190 | "node": "^12 || ^14 || >= 16" 1191 | }, 1192 | "funding": { 1193 | "type": "opencollective", 1194 | "url": "https://opencollective.com/postcss/" 1195 | }, 1196 | "peerDependencies": { 1197 | "postcss": "^8.4.21" 1198 | } 1199 | }, 1200 | "node_modules/postcss-load-config": { 1201 | "version": "4.0.2", 1202 | "resolved": "https://registry.npmjs.org/postcss-load-config/-/postcss-load-config-4.0.2.tgz", 1203 | "integrity": "sha512-bSVhyJGL00wMVoPUzAVAnbEoWyqRxkjv64tUl427SKnPrENtq6hJwUojroMz2VB+Q1edmi4IfrAPpami5VVgMQ==", 1204 | "dev": true, 1205 | "funding": [ 1206 | { 1207 | "type": "opencollective", 1208 | "url": "https://opencollective.com/postcss/" 1209 | }, 1210 | { 1211 | "type": "github", 1212 | "url": "https://github.com/sponsors/ai" 1213 | } 1214 | ], 1215 | "dependencies": { 1216 | "lilconfig": "^3.0.0", 1217 | "yaml": "^2.3.4" 1218 | }, 1219 | "engines": { 1220 | "node": ">= 14" 1221 | }, 1222 | "peerDependencies": { 1223 | "postcss": ">=8.0.9", 1224 | "ts-node": ">=9.0.0" 1225 | }, 1226 | "peerDependenciesMeta": { 1227 | "postcss": { 1228 | "optional": true 1229 | }, 1230 | "ts-node": { 1231 | "optional": true 1232 | } 1233 | } 1234 | }, 1235 | "node_modules/postcss-load-config/node_modules/lilconfig": { 1236 | "version": "3.1.2", 1237 | "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-3.1.2.tgz", 1238 | "integrity": "sha512-eop+wDAvpItUys0FWkHIKeC9ybYrTGbU41U5K7+bttZZeohvnY7M9dZ5kB21GNWiFT2q1OoPTvncPCgSOVO5ow==", 1239 | "dev": true, 1240 | "engines": { 1241 | "node": ">=14" 1242 | }, 1243 | "funding": { 1244 | "url": "https://github.com/sponsors/antonk52" 1245 | } 1246 | }, 1247 | "node_modules/postcss-nested": { 1248 | "version": "6.0.1", 1249 | "resolved": "https://registry.npmjs.org/postcss-nested/-/postcss-nested-6.0.1.tgz", 1250 | "integrity": "sha512-mEp4xPMi5bSWiMbsgoPfcP74lsWLHkQbZc3sY+jWYd65CUwXrUaTp0fmNpa01ZcETKlIgUdFN/MpS2xZtqL9dQ==", 1251 | "dev": true, 1252 | "dependencies": { 1253 | "postcss-selector-parser": "^6.0.11" 1254 | }, 1255 | "engines": { 1256 | "node": ">=12.0" 1257 | }, 1258 | "funding": { 1259 | "type": "opencollective", 1260 | "url": "https://opencollective.com/postcss/" 1261 | }, 1262 | "peerDependencies": { 1263 | "postcss": "^8.2.14" 1264 | } 1265 | }, 1266 | "node_modules/postcss-selector-parser": { 1267 | "version": "6.1.0", 1268 | "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-6.1.0.tgz", 1269 | "integrity": "sha512-UMz42UD0UY0EApS0ZL9o1XnLhSTtvvvLe5Dc2H2O56fvRZi+KulDyf5ctDhhtYJBGKStV2FL1fy6253cmLgqVQ==", 1270 | "dev": true, 1271 | "dependencies": { 1272 | "cssesc": "^3.0.0", 1273 | "util-deprecate": "^1.0.2" 1274 | }, 1275 | "engines": { 1276 | "node": ">=4" 1277 | } 1278 | }, 1279 | "node_modules/postcss-value-parser": { 1280 | "version": "4.2.0", 1281 | "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-4.2.0.tgz", 1282 | "integrity": "sha512-1NNCs6uurfkVbeXG4S8JFT9t19m45ICnif8zWLd5oPSZ50QnwMfK+H3jv408d4jw/7Bttv5axS5IiHoLaVNHeQ==", 1283 | "dev": true 1284 | }, 1285 | "node_modules/queue-microtask": { 1286 | "version": "1.2.3", 1287 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 1288 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 1289 | "dev": true, 1290 | "funding": [ 1291 | { 1292 | "type": "github", 1293 | "url": "https://github.com/sponsors/feross" 1294 | }, 1295 | { 1296 | "type": "patreon", 1297 | "url": "https://www.patreon.com/feross" 1298 | }, 1299 | { 1300 | "type": "consulting", 1301 | "url": "https://feross.org/support" 1302 | } 1303 | ] 1304 | }, 1305 | "node_modules/react": { 1306 | "version": "18.3.1", 1307 | "resolved": "https://registry.npmjs.org/react/-/react-18.3.1.tgz", 1308 | "integrity": "sha512-wS+hAgJShR0KhEvPJArfuPVN1+Hz1t0Y6n5jLrGQbkb4urgPE/0Rve+1kMB1v/oWgHgm4WIcV+i7F2pTVj+2iQ==", 1309 | "dependencies": { 1310 | "loose-envify": "^1.1.0" 1311 | }, 1312 | "engines": { 1313 | "node": ">=0.10.0" 1314 | } 1315 | }, 1316 | "node_modules/react-dom": { 1317 | "version": "18.3.1", 1318 | "resolved": "https://registry.npmjs.org/react-dom/-/react-dom-18.3.1.tgz", 1319 | "integrity": "sha512-5m4nQKp+rZRb09LNH59GM4BxTh9251/ylbKIbpe7TpGxfJ+9kv6BLkLBXIjjspbgbnIBNqlI23tRnTWT0snUIw==", 1320 | "dependencies": { 1321 | "loose-envify": "^1.1.0", 1322 | "scheduler": "^0.23.2" 1323 | }, 1324 | "peerDependencies": { 1325 | "react": "^18.3.1" 1326 | } 1327 | }, 1328 | "node_modules/read-cache": { 1329 | "version": "1.0.0", 1330 | "resolved": "https://registry.npmjs.org/read-cache/-/read-cache-1.0.0.tgz", 1331 | "integrity": "sha512-Owdv/Ft7IjOgm/i0xvNDZ1LrRANRfew4b2prF3OWMQLxLfu3bS8FVhCsrSCMK4lR56Y9ya+AThoTpDCTxCmpRA==", 1332 | "dev": true, 1333 | "dependencies": { 1334 | "pify": "^2.3.0" 1335 | } 1336 | }, 1337 | "node_modules/readdirp": { 1338 | "version": "3.6.0", 1339 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1340 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1341 | "dev": true, 1342 | "dependencies": { 1343 | "picomatch": "^2.2.1" 1344 | }, 1345 | "engines": { 1346 | "node": ">=8.10.0" 1347 | } 1348 | }, 1349 | "node_modules/resolve": { 1350 | "version": "1.22.8", 1351 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.8.tgz", 1352 | "integrity": "sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw==", 1353 | "dev": true, 1354 | "dependencies": { 1355 | "is-core-module": "^2.13.0", 1356 | "path-parse": "^1.0.7", 1357 | "supports-preserve-symlinks-flag": "^1.0.0" 1358 | }, 1359 | "bin": { 1360 | "resolve": "bin/resolve" 1361 | }, 1362 | "funding": { 1363 | "url": "https://github.com/sponsors/ljharb" 1364 | } 1365 | }, 1366 | "node_modules/reusify": { 1367 | "version": "1.0.4", 1368 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 1369 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 1370 | "dev": true, 1371 | "engines": { 1372 | "iojs": ">=1.0.0", 1373 | "node": ">=0.10.0" 1374 | } 1375 | }, 1376 | "node_modules/run-parallel": { 1377 | "version": "1.2.0", 1378 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 1379 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 1380 | "dev": true, 1381 | "funding": [ 1382 | { 1383 | "type": "github", 1384 | "url": "https://github.com/sponsors/feross" 1385 | }, 1386 | { 1387 | "type": "patreon", 1388 | "url": "https://www.patreon.com/feross" 1389 | }, 1390 | { 1391 | "type": "consulting", 1392 | "url": "https://feross.org/support" 1393 | } 1394 | ], 1395 | "dependencies": { 1396 | "queue-microtask": "^1.2.2" 1397 | } 1398 | }, 1399 | "node_modules/scheduler": { 1400 | "version": "0.23.2", 1401 | "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.23.2.tgz", 1402 | "integrity": "sha512-UOShsPwz7NrMUqhR6t0hWjFduvOzbtv7toDH1/hIrfRNIDBnnBWd0CwJTGvTpngVlmwGCdP9/Zl/tVrDqcuYzQ==", 1403 | "dependencies": { 1404 | "loose-envify": "^1.1.0" 1405 | } 1406 | }, 1407 | "node_modules/shebang-command": { 1408 | "version": "2.0.0", 1409 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 1410 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 1411 | "dev": true, 1412 | "dependencies": { 1413 | "shebang-regex": "^3.0.0" 1414 | }, 1415 | "engines": { 1416 | "node": ">=8" 1417 | } 1418 | }, 1419 | "node_modules/shebang-regex": { 1420 | "version": "3.0.0", 1421 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 1422 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 1423 | "dev": true, 1424 | "engines": { 1425 | "node": ">=8" 1426 | } 1427 | }, 1428 | "node_modules/signal-exit": { 1429 | "version": "4.1.0", 1430 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz", 1431 | "integrity": "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==", 1432 | "dev": true, 1433 | "engines": { 1434 | "node": ">=14" 1435 | }, 1436 | "funding": { 1437 | "url": "https://github.com/sponsors/isaacs" 1438 | } 1439 | }, 1440 | "node_modules/source-map-js": { 1441 | "version": "1.2.0", 1442 | "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.2.0.tgz", 1443 | "integrity": "sha512-itJW8lvSA0TXEphiRoawsCksnlf8SyvmFzIhltqAHluXd88pkCd+cXJVHTDwdCr0IzwptSm035IHQktUu1QUMg==", 1444 | "engines": { 1445 | "node": ">=0.10.0" 1446 | } 1447 | }, 1448 | "node_modules/streamsearch": { 1449 | "version": "1.1.0", 1450 | "resolved": "https://registry.npmjs.org/streamsearch/-/streamsearch-1.1.0.tgz", 1451 | "integrity": "sha512-Mcc5wHehp9aXz1ax6bZUyY5afg9u2rv5cqQI3mRrYkGC8rW2hM02jWuwjtL++LS5qinSyhj2QfLyNsuc+VsExg==", 1452 | "engines": { 1453 | "node": ">=10.0.0" 1454 | } 1455 | }, 1456 | "node_modules/string-width": { 1457 | "version": "5.1.2", 1458 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-5.1.2.tgz", 1459 | "integrity": "sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA==", 1460 | "dev": true, 1461 | "dependencies": { 1462 | "eastasianwidth": "^0.2.0", 1463 | "emoji-regex": "^9.2.2", 1464 | "strip-ansi": "^7.0.1" 1465 | }, 1466 | "engines": { 1467 | "node": ">=12" 1468 | }, 1469 | "funding": { 1470 | "url": "https://github.com/sponsors/sindresorhus" 1471 | } 1472 | }, 1473 | "node_modules/string-width-cjs": { 1474 | "name": "string-width", 1475 | "version": "4.2.3", 1476 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 1477 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 1478 | "dev": true, 1479 | "dependencies": { 1480 | "emoji-regex": "^8.0.0", 1481 | "is-fullwidth-code-point": "^3.0.0", 1482 | "strip-ansi": "^6.0.1" 1483 | }, 1484 | "engines": { 1485 | "node": ">=8" 1486 | } 1487 | }, 1488 | "node_modules/string-width-cjs/node_modules/ansi-regex": { 1489 | "version": "5.0.1", 1490 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 1491 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 1492 | "dev": true, 1493 | "engines": { 1494 | "node": ">=8" 1495 | } 1496 | }, 1497 | "node_modules/string-width-cjs/node_modules/emoji-regex": { 1498 | "version": "8.0.0", 1499 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 1500 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 1501 | "dev": true 1502 | }, 1503 | "node_modules/string-width-cjs/node_modules/strip-ansi": { 1504 | "version": "6.0.1", 1505 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1506 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1507 | "dev": true, 1508 | "dependencies": { 1509 | "ansi-regex": "^5.0.1" 1510 | }, 1511 | "engines": { 1512 | "node": ">=8" 1513 | } 1514 | }, 1515 | "node_modules/strip-ansi": { 1516 | "version": "7.1.0", 1517 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz", 1518 | "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==", 1519 | "dev": true, 1520 | "dependencies": { 1521 | "ansi-regex": "^6.0.1" 1522 | }, 1523 | "engines": { 1524 | "node": ">=12" 1525 | }, 1526 | "funding": { 1527 | "url": "https://github.com/chalk/strip-ansi?sponsor=1" 1528 | } 1529 | }, 1530 | "node_modules/strip-ansi-cjs": { 1531 | "name": "strip-ansi", 1532 | "version": "6.0.1", 1533 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1534 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1535 | "dev": true, 1536 | "dependencies": { 1537 | "ansi-regex": "^5.0.1" 1538 | }, 1539 | "engines": { 1540 | "node": ">=8" 1541 | } 1542 | }, 1543 | "node_modules/strip-ansi-cjs/node_modules/ansi-regex": { 1544 | "version": "5.0.1", 1545 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 1546 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 1547 | "dev": true, 1548 | "engines": { 1549 | "node": ">=8" 1550 | } 1551 | }, 1552 | "node_modules/styled-jsx": { 1553 | "version": "5.1.1", 1554 | "resolved": "https://registry.npmjs.org/styled-jsx/-/styled-jsx-5.1.1.tgz", 1555 | "integrity": "sha512-pW7uC1l4mBZ8ugbiZrcIsiIvVx1UmTfw7UkC3Um2tmfUq9Bhk8IiyEIPl6F8agHgjzku6j0xQEZbfA5uSgSaCw==", 1556 | "dependencies": { 1557 | "client-only": "0.0.1" 1558 | }, 1559 | "engines": { 1560 | "node": ">= 12.0.0" 1561 | }, 1562 | "peerDependencies": { 1563 | "react": ">= 16.8.0 || 17.x.x || ^18.0.0-0" 1564 | }, 1565 | "peerDependenciesMeta": { 1566 | "@babel/core": { 1567 | "optional": true 1568 | }, 1569 | "babel-plugin-macros": { 1570 | "optional": true 1571 | } 1572 | } 1573 | }, 1574 | "node_modules/sucrase": { 1575 | "version": "3.35.0", 1576 | "resolved": "https://registry.npmjs.org/sucrase/-/sucrase-3.35.0.tgz", 1577 | "integrity": "sha512-8EbVDiu9iN/nESwxeSxDKe0dunta1GOlHufmSSXxMD2z2/tMZpDMpvXQGsc+ajGo8y2uYUmixaSRUc/QPoQ0GA==", 1578 | "dev": true, 1579 | "dependencies": { 1580 | "@jridgewell/gen-mapping": "^0.3.2", 1581 | "commander": "^4.0.0", 1582 | "glob": "^10.3.10", 1583 | "lines-and-columns": "^1.1.6", 1584 | "mz": "^2.7.0", 1585 | "pirates": "^4.0.1", 1586 | "ts-interface-checker": "^0.1.9" 1587 | }, 1588 | "bin": { 1589 | "sucrase": "bin/sucrase", 1590 | "sucrase-node": "bin/sucrase-node" 1591 | }, 1592 | "engines": { 1593 | "node": ">=16 || 14 >=14.17" 1594 | } 1595 | }, 1596 | "node_modules/supports-preserve-symlinks-flag": { 1597 | "version": "1.0.0", 1598 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 1599 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 1600 | "dev": true, 1601 | "engines": { 1602 | "node": ">= 0.4" 1603 | }, 1604 | "funding": { 1605 | "url": "https://github.com/sponsors/ljharb" 1606 | } 1607 | }, 1608 | "node_modules/tailwindcss": { 1609 | "version": "3.4.4", 1610 | "resolved": "https://registry.npmjs.org/tailwindcss/-/tailwindcss-3.4.4.tgz", 1611 | "integrity": "sha512-ZoyXOdJjISB7/BcLTR6SEsLgKtDStYyYZVLsUtWChO4Ps20CBad7lfJKVDiejocV4ME1hLmyY0WJE3hSDcmQ2A==", 1612 | "dev": true, 1613 | "dependencies": { 1614 | "@alloc/quick-lru": "^5.2.0", 1615 | "arg": "^5.0.2", 1616 | "chokidar": "^3.5.3", 1617 | "didyoumean": "^1.2.2", 1618 | "dlv": "^1.1.3", 1619 | "fast-glob": "^3.3.0", 1620 | "glob-parent": "^6.0.2", 1621 | "is-glob": "^4.0.3", 1622 | "jiti": "^1.21.0", 1623 | "lilconfig": "^2.1.0", 1624 | "micromatch": "^4.0.5", 1625 | "normalize-path": "^3.0.0", 1626 | "object-hash": "^3.0.0", 1627 | "picocolors": "^1.0.0", 1628 | "postcss": "^8.4.23", 1629 | "postcss-import": "^15.1.0", 1630 | "postcss-js": "^4.0.1", 1631 | "postcss-load-config": "^4.0.1", 1632 | "postcss-nested": "^6.0.1", 1633 | "postcss-selector-parser": "^6.0.11", 1634 | "resolve": "^1.22.2", 1635 | "sucrase": "^3.32.0" 1636 | }, 1637 | "bin": { 1638 | "tailwind": "lib/cli.js", 1639 | "tailwindcss": "lib/cli.js" 1640 | }, 1641 | "engines": { 1642 | "node": ">=14.0.0" 1643 | } 1644 | }, 1645 | "node_modules/thenify": { 1646 | "version": "3.3.1", 1647 | "resolved": "https://registry.npmjs.org/thenify/-/thenify-3.3.1.tgz", 1648 | "integrity": "sha512-RVZSIV5IG10Hk3enotrhvz0T9em6cyHBLkH/YAZuKqd8hRkKhSfCGIcP2KUY0EPxndzANBmNllzWPwak+bheSw==", 1649 | "dev": true, 1650 | "dependencies": { 1651 | "any-promise": "^1.0.0" 1652 | } 1653 | }, 1654 | "node_modules/thenify-all": { 1655 | "version": "1.6.0", 1656 | "resolved": "https://registry.npmjs.org/thenify-all/-/thenify-all-1.6.0.tgz", 1657 | "integrity": "sha512-RNxQH/qI8/t3thXJDwcstUO4zeqo64+Uy/+sNVRBx4Xn2OX+OZ9oP+iJnNFqplFra2ZUVeKCSa2oVWi3T4uVmA==", 1658 | "dev": true, 1659 | "dependencies": { 1660 | "thenify": ">= 3.1.0 < 4" 1661 | }, 1662 | "engines": { 1663 | "node": ">=0.8" 1664 | } 1665 | }, 1666 | "node_modules/to-regex-range": { 1667 | "version": "5.0.1", 1668 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1669 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1670 | "dev": true, 1671 | "dependencies": { 1672 | "is-number": "^7.0.0" 1673 | }, 1674 | "engines": { 1675 | "node": ">=8.0" 1676 | } 1677 | }, 1678 | "node_modules/ts-interface-checker": { 1679 | "version": "0.1.13", 1680 | "resolved": "https://registry.npmjs.org/ts-interface-checker/-/ts-interface-checker-0.1.13.tgz", 1681 | "integrity": "sha512-Y/arvbn+rrz3JCKl9C4kVNfTfSm2/mEp5FSz5EsZSANGPSlQrpRI5M4PKF+mJnE52jOO90PnPSc3Ur3bTQw0gA==", 1682 | "dev": true 1683 | }, 1684 | "node_modules/tslib": { 1685 | "version": "2.6.3", 1686 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.3.tgz", 1687 | "integrity": "sha512-xNvxJEOUiWPGhUuUdQgAJPKOOJfGnIyKySOc09XkKsgdUV/3E2zvwZYdejjmRgPCgcym1juLH3226yA7sEFJKQ==" 1688 | }, 1689 | "node_modules/typescript": { 1690 | "version": "5.5.2", 1691 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.5.2.tgz", 1692 | "integrity": "sha512-NcRtPEOsPFFWjobJEtfihkLCZCXZt/os3zf8nTxjVH3RvTSxjrCamJpbExGvYOF+tFHc3pA65qpdwPbzjohhew==", 1693 | "dev": true, 1694 | "bin": { 1695 | "tsc": "bin/tsc", 1696 | "tsserver": "bin/tsserver" 1697 | }, 1698 | "engines": { 1699 | "node": ">=14.17" 1700 | } 1701 | }, 1702 | "node_modules/undici-types": { 1703 | "version": "5.26.5", 1704 | "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-5.26.5.tgz", 1705 | "integrity": "sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA==", 1706 | "dev": true 1707 | }, 1708 | "node_modules/util-deprecate": { 1709 | "version": "1.0.2", 1710 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 1711 | "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==", 1712 | "dev": true 1713 | }, 1714 | "node_modules/which": { 1715 | "version": "2.0.2", 1716 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 1717 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 1718 | "dev": true, 1719 | "dependencies": { 1720 | "isexe": "^2.0.0" 1721 | }, 1722 | "bin": { 1723 | "node-which": "bin/node-which" 1724 | }, 1725 | "engines": { 1726 | "node": ">= 8" 1727 | } 1728 | }, 1729 | "node_modules/wrap-ansi": { 1730 | "version": "8.1.0", 1731 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-8.1.0.tgz", 1732 | "integrity": "sha512-si7QWI6zUMq56bESFvagtmzMdGOtoxfR+Sez11Mobfc7tm+VkUckk9bW2UeffTGVUbOksxmSw0AA2gs8g71NCQ==", 1733 | "dev": true, 1734 | "dependencies": { 1735 | "ansi-styles": "^6.1.0", 1736 | "string-width": "^5.0.1", 1737 | "strip-ansi": "^7.0.1" 1738 | }, 1739 | "engines": { 1740 | "node": ">=12" 1741 | }, 1742 | "funding": { 1743 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 1744 | } 1745 | }, 1746 | "node_modules/wrap-ansi-cjs": { 1747 | "name": "wrap-ansi", 1748 | "version": "7.0.0", 1749 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 1750 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 1751 | "dev": true, 1752 | "dependencies": { 1753 | "ansi-styles": "^4.0.0", 1754 | "string-width": "^4.1.0", 1755 | "strip-ansi": "^6.0.0" 1756 | }, 1757 | "engines": { 1758 | "node": ">=10" 1759 | }, 1760 | "funding": { 1761 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 1762 | } 1763 | }, 1764 | "node_modules/wrap-ansi-cjs/node_modules/ansi-regex": { 1765 | "version": "5.0.1", 1766 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 1767 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 1768 | "dev": true, 1769 | "engines": { 1770 | "node": ">=8" 1771 | } 1772 | }, 1773 | "node_modules/wrap-ansi-cjs/node_modules/ansi-styles": { 1774 | "version": "4.3.0", 1775 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 1776 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 1777 | "dev": true, 1778 | "dependencies": { 1779 | "color-convert": "^2.0.1" 1780 | }, 1781 | "engines": { 1782 | "node": ">=8" 1783 | }, 1784 | "funding": { 1785 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 1786 | } 1787 | }, 1788 | "node_modules/wrap-ansi-cjs/node_modules/emoji-regex": { 1789 | "version": "8.0.0", 1790 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 1791 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 1792 | "dev": true 1793 | }, 1794 | "node_modules/wrap-ansi-cjs/node_modules/string-width": { 1795 | "version": "4.2.3", 1796 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 1797 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 1798 | "dev": true, 1799 | "dependencies": { 1800 | "emoji-regex": "^8.0.0", 1801 | "is-fullwidth-code-point": "^3.0.0", 1802 | "strip-ansi": "^6.0.1" 1803 | }, 1804 | "engines": { 1805 | "node": ">=8" 1806 | } 1807 | }, 1808 | "node_modules/wrap-ansi-cjs/node_modules/strip-ansi": { 1809 | "version": "6.0.1", 1810 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1811 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1812 | "dev": true, 1813 | "dependencies": { 1814 | "ansi-regex": "^5.0.1" 1815 | }, 1816 | "engines": { 1817 | "node": ">=8" 1818 | } 1819 | }, 1820 | "node_modules/yaml": { 1821 | "version": "2.4.5", 1822 | "resolved": "https://registry.npmjs.org/yaml/-/yaml-2.4.5.tgz", 1823 | "integrity": "sha512-aBx2bnqDzVOyNKfsysjA2ms5ZlnjSAW2eG3/L5G/CSujfjLJTJsEw1bGw8kCf04KodQWk1pxlGnZ56CRxiawmg==", 1824 | "dev": true, 1825 | "bin": { 1826 | "yaml": "bin.mjs" 1827 | }, 1828 | "engines": { 1829 | "node": ">= 14" 1830 | } 1831 | } 1832 | } 1833 | } 1834 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "linux-next", 3 | "version": "0.1.0", 4 | "private": true, 5 | "scripts": { 6 | "dev": "next dev", 7 | "build": "next build", 8 | "start": "next start", 9 | "lint": "next lint" 10 | }, 11 | "dependencies": { 12 | "next": "14.2.4", 13 | "pocketbase": "^0.21.3", 14 | "react": "^18", 15 | "react-dom": "^18" 16 | }, 17 | "devDependencies": { 18 | "@faker-js/faker": "^8.4.1", 19 | "@types/node": "^20", 20 | "@types/react": "^18", 21 | "@types/react-dom": "^18", 22 | "postcss": "^8", 23 | "tailwindcss": "^3.4.1", 24 | "typescript": "^5" 25 | } 26 | } 27 | -------------------------------------------------------------------------------- /pb_migrations/1719093567_created_signatures.js: -------------------------------------------------------------------------------- 1 | /// 2 | migrate((db) => { 3 | const collection = new Collection({ 4 | "id": "4n0a6jkpglazeft", 5 | "created": "2024-06-22 21:59:27.654Z", 6 | "updated": "2024-06-22 21:59:27.654Z", 7 | "name": "signatures", 8 | "type": "base", 9 | "system": false, 10 | "schema": [ 11 | { 12 | "system": false, 13 | "id": "cet8bd6p", 14 | "name": "user", 15 | "type": "relation", 16 | "required": false, 17 | "presentable": false, 18 | "unique": false, 19 | "options": { 20 | "collectionId": "_pb_users_auth_", 21 | "cascadeDelete": false, 22 | "minSelect": null, 23 | "maxSelect": 1, 24 | "displayFields": null 25 | } 26 | }, 27 | { 28 | "system": false, 29 | "id": "p089ro9d", 30 | "name": "message", 31 | "type": "text", 32 | "required": false, 33 | "presentable": false, 34 | "unique": false, 35 | "options": { 36 | "min": null, 37 | "max": null, 38 | "pattern": "" 39 | } 40 | } 41 | ], 42 | "indexes": [], 43 | "listRule": null, 44 | "viewRule": null, 45 | "createRule": null, 46 | "updateRule": null, 47 | "deleteRule": null, 48 | "options": {} 49 | }); 50 | 51 | return Dao(db).saveCollection(collection); 52 | }, (db) => { 53 | const dao = new Dao(db); 54 | const collection = dao.findCollectionByNameOrId("4n0a6jkpglazeft"); 55 | 56 | return dao.deleteCollection(collection); 57 | }) 58 | -------------------------------------------------------------------------------- /pb_migrations/1719093799_updated_signatures.js: -------------------------------------------------------------------------------- 1 | /// 2 | migrate((db) => { 3 | const dao = new Dao(db) 4 | const collection = dao.findCollectionByNameOrId("4n0a6jkpglazeft") 5 | 6 | collection.listRule = "" 7 | collection.createRule = "" 8 | 9 | return dao.saveCollection(collection) 10 | }, (db) => { 11 | const dao = new Dao(db) 12 | const collection = dao.findCollectionByNameOrId("4n0a6jkpglazeft") 13 | 14 | collection.listRule = null 15 | collection.createRule = null 16 | 17 | return dao.saveCollection(collection) 18 | }) 19 | -------------------------------------------------------------------------------- /pb_migrations/1719093987_updated_signatures.js: -------------------------------------------------------------------------------- 1 | /// 2 | migrate((db) => { 3 | const dao = new Dao(db) 4 | const collection = dao.findCollectionByNameOrId("4n0a6jkpglazeft") 5 | 6 | collection.createRule = "@request.auth.id != user && message <= 500" 7 | 8 | return dao.saveCollection(collection) 9 | }, (db) => { 10 | const dao = new Dao(db) 11 | const collection = dao.findCollectionByNameOrId("4n0a6jkpglazeft") 12 | 13 | collection.createRule = "" 14 | 15 | return dao.saveCollection(collection) 16 | }) 17 | -------------------------------------------------------------------------------- /pb_migrations/1719094114_updated_signatures.js: -------------------------------------------------------------------------------- 1 | /// 2 | migrate((db) => { 3 | const dao = new Dao(db) 4 | const collection = dao.findCollectionByNameOrId("4n0a6jkpglazeft") 5 | 6 | collection.createRule = "@request.auth.id != user" 7 | 8 | return dao.saveCollection(collection) 9 | }, (db) => { 10 | const dao = new Dao(db) 11 | const collection = dao.findCollectionByNameOrId("4n0a6jkpglazeft") 12 | 13 | collection.createRule = "@request.auth.id != user && message <= 500" 14 | 15 | return dao.saveCollection(collection) 16 | }) 17 | -------------------------------------------------------------------------------- /pb_migrations/1719094869_updated_signatures.js: -------------------------------------------------------------------------------- 1 | /// 2 | migrate((db) => { 3 | const dao = new Dao(db) 4 | const collection = dao.findCollectionByNameOrId("4n0a6jkpglazeft") 5 | 6 | collection.createRule = "@request.auth.id = user" 7 | 8 | return dao.saveCollection(collection) 9 | }, (db) => { 10 | const dao = new Dao(db) 11 | const collection = dao.findCollectionByNameOrId("4n0a6jkpglazeft") 12 | 13 | collection.createRule = "@request.auth.id != user" 14 | 15 | return dao.saveCollection(collection) 16 | }) 17 | -------------------------------------------------------------------------------- /pb_migrations/1719095267_updated_signatures.js: -------------------------------------------------------------------------------- 1 | /// 2 | migrate((db) => { 3 | const dao = new Dao(db) 4 | const collection = dao.findCollectionByNameOrId("4n0a6jkpglazeft") 5 | 6 | collection.indexes = [ 7 | "CREATE UNIQUE INDEX `idx_kcoXgFo` ON `signatures` (`user`)" 8 | ] 9 | 10 | return dao.saveCollection(collection) 11 | }, (db) => { 12 | const dao = new Dao(db) 13 | const collection = dao.findCollectionByNameOrId("4n0a6jkpglazeft") 14 | 15 | collection.indexes = [] 16 | 17 | return dao.saveCollection(collection) 18 | }) 19 | -------------------------------------------------------------------------------- /pb_migrations/1719095351_updated_signatures.js: -------------------------------------------------------------------------------- 1 | /// 2 | migrate((db) => { 3 | const dao = new Dao(db) 4 | const collection = dao.findCollectionByNameOrId("4n0a6jkpglazeft") 5 | 6 | collection.createRule = "@request.auth.id = user && @request.context = \"oauth2\"" 7 | 8 | return dao.saveCollection(collection) 9 | }, (db) => { 10 | const dao = new Dao(db) 11 | const collection = dao.findCollectionByNameOrId("4n0a6jkpglazeft") 12 | 13 | collection.createRule = "@request.auth.id = user" 14 | 15 | return dao.saveCollection(collection) 16 | }) 17 | -------------------------------------------------------------------------------- /pb_migrations/1719095401_updated_signatures.js: -------------------------------------------------------------------------------- 1 | /// 2 | migrate((db) => { 3 | const dao = new Dao(db) 4 | const collection = dao.findCollectionByNameOrId("4n0a6jkpglazeft") 5 | 6 | collection.createRule = "@request.auth.id = user" 7 | 8 | return dao.saveCollection(collection) 9 | }, (db) => { 10 | const dao = new Dao(db) 11 | const collection = dao.findCollectionByNameOrId("4n0a6jkpglazeft") 12 | 13 | collection.createRule = "@request.auth.id = user && @request.context = \"oauth2\"" 14 | 15 | return dao.saveCollection(collection) 16 | }) 17 | -------------------------------------------------------------------------------- /pb_migrations/1719096282_updated_signatures.js: -------------------------------------------------------------------------------- 1 | /// 2 | migrate((db) => { 3 | const dao = new Dao(db) 4 | const collection = dao.findCollectionByNameOrId("4n0a6jkpglazeft") 5 | 6 | collection.indexes = [] 7 | 8 | return dao.saveCollection(collection) 9 | }, (db) => { 10 | const dao = new Dao(db) 11 | const collection = dao.findCollectionByNameOrId("4n0a6jkpglazeft") 12 | 13 | collection.indexes = [ 14 | "CREATE UNIQUE INDEX `idx_kcoXgFo` ON `signatures` (`user`)" 15 | ] 16 | 17 | return dao.saveCollection(collection) 18 | }) 19 | -------------------------------------------------------------------------------- /pb_migrations/1719096824_updated_users.js: -------------------------------------------------------------------------------- 1 | /// 2 | migrate((db) => { 3 | const dao = new Dao(db) 4 | const collection = dao.findCollectionByNameOrId("_pb_users_auth_") 5 | 6 | collection.listRule = null 7 | collection.viewRule = null 8 | 9 | return dao.saveCollection(collection) 10 | }, (db) => { 11 | const dao = new Dao(db) 12 | const collection = dao.findCollectionByNameOrId("_pb_users_auth_") 13 | 14 | collection.listRule = "id = @request.auth.id" 15 | collection.viewRule = "id = @request.auth.id" 16 | 17 | return dao.saveCollection(collection) 18 | }) 19 | -------------------------------------------------------------------------------- /pb_migrations/1719096961_updated_users.js: -------------------------------------------------------------------------------- 1 | /// 2 | migrate((db) => { 3 | const dao = new Dao(db) 4 | const collection = dao.findCollectionByNameOrId("_pb_users_auth_") 5 | 6 | collection.listRule = "" 7 | collection.viewRule = "" 8 | 9 | return dao.saveCollection(collection) 10 | }, (db) => { 11 | const dao = new Dao(db) 12 | const collection = dao.findCollectionByNameOrId("_pb_users_auth_") 13 | 14 | collection.listRule = null 15 | collection.viewRule = null 16 | 17 | return dao.saveCollection(collection) 18 | }) 19 | -------------------------------------------------------------------------------- /pb_migrations/1719096997_updated_users.js: -------------------------------------------------------------------------------- 1 | /// 2 | migrate((db) => { 3 | const dao = new Dao(db) 4 | const collection = dao.findCollectionByNameOrId("_pb_users_auth_") 5 | 6 | collection.options = { 7 | "allowEmailAuth": false, 8 | "allowOAuth2Auth": true, 9 | "allowUsernameAuth": false, 10 | "exceptEmailDomains": null, 11 | "manageRule": null, 12 | "minPasswordLength": 8, 13 | "onlyEmailDomains": null, 14 | "onlyVerified": false, 15 | "requireEmail": false 16 | } 17 | 18 | return dao.saveCollection(collection) 19 | }, (db) => { 20 | const dao = new Dao(db) 21 | const collection = dao.findCollectionByNameOrId("_pb_users_auth_") 22 | 23 | collection.options = { 24 | "allowEmailAuth": true, 25 | "allowOAuth2Auth": true, 26 | "allowUsernameAuth": true, 27 | "exceptEmailDomains": null, 28 | "manageRule": null, 29 | "minPasswordLength": 8, 30 | "onlyEmailDomains": null, 31 | "onlyVerified": false, 32 | "requireEmail": false 33 | } 34 | 35 | return dao.saveCollection(collection) 36 | }) 37 | -------------------------------------------------------------------------------- /pb_migrations/1719229813_updated_users.js: -------------------------------------------------------------------------------- 1 | /// 2 | migrate((db) => { 3 | const dao = new Dao(db) 4 | const collection = dao.findCollectionByNameOrId("_pb_users_auth_") 5 | 6 | // add 7 | collection.schema.addField(new SchemaField({ 8 | "system": false, 9 | "id": "v4tpp9zb", 10 | "name": "signature", 11 | "type": "text", 12 | "required": false, 13 | "presentable": false, 14 | "unique": false, 15 | "options": { 16 | "min": null, 17 | "max": null, 18 | "pattern": "" 19 | } 20 | })) 21 | 22 | return dao.saveCollection(collection) 23 | }, (db) => { 24 | const dao = new Dao(db) 25 | const collection = dao.findCollectionByNameOrId("_pb_users_auth_") 26 | 27 | // remove 28 | collection.schema.removeField("v4tpp9zb") 29 | 30 | return dao.saveCollection(collection) 31 | }) 32 | -------------------------------------------------------------------------------- /pb_migrations/1719229909_updated_users.js: -------------------------------------------------------------------------------- 1 | /// 2 | migrate((db) => { 3 | const dao = new Dao(db) 4 | const collection = dao.findCollectionByNameOrId("_pb_users_auth_") 5 | 6 | // add 7 | collection.schema.addField(new SchemaField({ 8 | "system": false, 9 | "id": "kjpcllkg", 10 | "name": "signed", 11 | "type": "date", 12 | "required": true, 13 | "presentable": false, 14 | "unique": false, 15 | "options": { 16 | "min": "", 17 | "max": "" 18 | } 19 | })) 20 | 21 | return dao.saveCollection(collection) 22 | }, (db) => { 23 | const dao = new Dao(db) 24 | const collection = dao.findCollectionByNameOrId("_pb_users_auth_") 25 | 26 | // remove 27 | collection.schema.removeField("kjpcllkg") 28 | 29 | return dao.saveCollection(collection) 30 | }) 31 | -------------------------------------------------------------------------------- /pocketbase: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/fireship-io/linux-course/78e997639faea32d69095b67d13b08291d7c727e/pocketbase -------------------------------------------------------------------------------- /postcss.config.mjs: -------------------------------------------------------------------------------- 1 | /** @type {import('postcss-load-config').Config} */ 2 | const config = { 3 | plugins: { 4 | tailwindcss: {}, 5 | }, 6 | }; 7 | 8 | export default config; 9 | -------------------------------------------------------------------------------- /public/next.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /public/vercel.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /tailwind.config.ts: -------------------------------------------------------------------------------- 1 | import type { Config } from "tailwindcss"; 2 | 3 | const config: Config = { 4 | content: [ 5 | "./pages/**/*.{js,ts,jsx,tsx,mdx}", 6 | "./components/**/*.{js,ts,jsx,tsx,mdx}", 7 | "./app/**/*.{js,ts,jsx,tsx,mdx}", 8 | ], 9 | theme: { 10 | extend: { 11 | backgroundImage: { 12 | "gradient-radial": "radial-gradient(var(--tw-gradient-stops))", 13 | "gradient-conic": 14 | "conic-gradient(from 180deg at 50% 50%, var(--tw-gradient-stops))", 15 | }, 16 | }, 17 | }, 18 | plugins: [], 19 | }; 20 | export default config; 21 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "lib": ["dom", "dom.iterable", "esnext"], 4 | "allowJs": true, 5 | "skipLibCheck": true, 6 | "strict": true, 7 | "noEmit": true, 8 | "esModuleInterop": true, 9 | "module": "esnext", 10 | "moduleResolution": "bundler", 11 | "resolveJsonModule": true, 12 | "isolatedModules": true, 13 | "jsx": "preserve", 14 | "incremental": true, 15 | "plugins": [ 16 | { 17 | "name": "next" 18 | } 19 | ], 20 | "paths": { 21 | "@/*": ["./*"] 22 | } 23 | }, 24 | "include": ["next-env.d.ts", "**/*.ts", "**/*.tsx", ".next/types/**/*.ts"], 25 | "exclude": ["node_modules"] 26 | } 27 | --------------------------------------------------------------------------------