├── .gitignore ├── README.md ├── components.json ├── jsconfig.json ├── next.config.mjs ├── package-lock.json ├── package.json ├── postcss.config.mjs ├── public ├── next.svg └── vercel.svg ├── src ├── actions │ └── index.js ├── app │ ├── favicon.ico │ ├── globals.css │ ├── layout.js │ ├── page.js │ ├── theory │ │ ├── client-page-example │ │ │ └── page.js │ │ └── server-page-example │ │ │ └── page.js │ └── user-management │ │ └── page.js ├── components │ ├── add-new-user │ │ └── index.js │ ├── common-layout │ │ └── index.js │ ├── single-user-card │ │ └── index.js │ └── ui │ │ ├── button.jsx │ │ ├── card.jsx │ │ ├── dialog.jsx │ │ ├── input.jsx │ │ └── label.jsx ├── context │ └── index.js ├── database │ └── index.js ├── lib │ └── utils.js ├── models │ └── user.js └── utils │ └── index.js └── tailwind.config.js /.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 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | This is a [Next.js](https://nextjs.org/) project bootstrapped with [`create-next-app`](https://github.com/vercel/next.js/tree/canary/packages/create-next-app). 2 | 3 | ## Getting Started 4 | 5 | First, run the development server: 6 | 7 | ```bash 8 | npm run dev 9 | # or 10 | yarn dev 11 | # or 12 | pnpm dev 13 | # or 14 | bun dev 15 | ``` 16 | 17 | Open [http://localhost:3000](http://localhost:3000) with your browser to see the result. 18 | 19 | You can start editing the page by modifying `app/page.js`. The page auto-updates as you edit the file. 20 | 21 | This project uses [`next/font`](https://nextjs.org/docs/basic-features/font-optimization) to automatically optimize and load Inter, a custom Google Font. 22 | 23 | ## Learn More 24 | 25 | To learn more about Next.js, take a look at the following resources: 26 | 27 | - [Next.js Documentation](https://nextjs.org/docs) - learn about Next.js features and API. 28 | - [Learn Next.js](https://nextjs.org/learn) - an interactive Next.js tutorial. 29 | 30 | You can check out [the Next.js GitHub repository](https://github.com/vercel/next.js/) - your feedback and contributions are welcome! 31 | 32 | ## Deploy on Vercel 33 | 34 | The easiest way to deploy your Next.js app is to use the [Vercel Platform](https://vercel.com/new?utm_medium=default-template&filter=next.js&utm_source=create-next-app&utm_campaign=create-next-app-readme) from the creators of Next.js. 35 | 36 | Check out our [Next.js deployment documentation](https://nextjs.org/docs/deployment) for more details. 37 | -------------------------------------------------------------------------------- /components.json: -------------------------------------------------------------------------------- 1 | { 2 | "$schema": "https://ui.shadcn.com/schema.json", 3 | "style": "default", 4 | "rsc": true, 5 | "tsx": false, 6 | "tailwind": { 7 | "config": "tailwind.config.js", 8 | "css": "src/app/globals.css", 9 | "baseColor": "slate", 10 | "cssVariables": true, 11 | "prefix": "" 12 | }, 13 | "aliases": { 14 | "components": "@/components", 15 | "utils": "@/lib/utils" 16 | } 17 | } -------------------------------------------------------------------------------- /jsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "paths": { 4 | "@/*": ["./src/*"] 5 | } 6 | } 7 | } 8 | -------------------------------------------------------------------------------- /next.config.mjs: -------------------------------------------------------------------------------- 1 | /** @type {import('next').NextConfig} */ 2 | const nextConfig = {}; 3 | 4 | export default nextConfig; 5 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "next-js-server-actions-2024", 3 | "version": "0.1.0", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "next-js-server-actions-2024", 9 | "version": "0.1.0", 10 | "dependencies": { 11 | "@radix-ui/react-dialog": "^1.0.5", 12 | "@radix-ui/react-label": "^2.0.2", 13 | "@radix-ui/react-slot": "^1.0.2", 14 | "class-variance-authority": "^0.7.0", 15 | "clsx": "^2.1.1", 16 | "lucide-react": "^0.378.0", 17 | "mongoose": "^8.3.3", 18 | "next": "14.2.3", 19 | "react": "^18", 20 | "react-dom": "^18", 21 | "tailwind-merge": "^2.3.0", 22 | "tailwindcss-animate": "^1.0.7" 23 | }, 24 | "devDependencies": { 25 | "postcss": "^8", 26 | "tailwindcss": "^3.4.1" 27 | } 28 | }, 29 | "node_modules/@alloc/quick-lru": { 30 | "version": "5.2.0", 31 | "resolved": "https://registry.npmjs.org/@alloc/quick-lru/-/quick-lru-5.2.0.tgz", 32 | "integrity": "sha512-UrcABB+4bUrFABwbluTIBErXwvbsU/V7TZWfmbgJfbkwiBuziS9gxdODUyuiecfdGQ85jglMW6juS3+z5TsKLw==", 33 | "engines": { 34 | "node": ">=10" 35 | }, 36 | "funding": { 37 | "url": "https://github.com/sponsors/sindresorhus" 38 | } 39 | }, 40 | "node_modules/@babel/runtime": { 41 | "version": "7.24.5", 42 | "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.24.5.tgz", 43 | "integrity": "sha512-Nms86NXrsaeU9vbBJKni6gXiEXZ4CVpYVzEjDH9Sb8vmZ3UljyA1GSOJl/6LGPO8EHLuSF9H+IxNXHPX8QHJ4g==", 44 | "dependencies": { 45 | "regenerator-runtime": "^0.14.0" 46 | }, 47 | "engines": { 48 | "node": ">=6.9.0" 49 | } 50 | }, 51 | "node_modules/@isaacs/cliui": { 52 | "version": "8.0.2", 53 | "resolved": "https://registry.npmjs.org/@isaacs/cliui/-/cliui-8.0.2.tgz", 54 | "integrity": "sha512-O8jcjabXaleOG9DQ0+ARXWZBTfnP4WNAqzuiJK7ll44AmxGKv/J2M4TPjxjY3znBCfvBXFzucm1twdyFybFqEA==", 55 | "dependencies": { 56 | "string-width": "^5.1.2", 57 | "string-width-cjs": "npm:string-width@^4.2.0", 58 | "strip-ansi": "^7.0.1", 59 | "strip-ansi-cjs": "npm:strip-ansi@^6.0.1", 60 | "wrap-ansi": "^8.1.0", 61 | "wrap-ansi-cjs": "npm:wrap-ansi@^7.0.0" 62 | }, 63 | "engines": { 64 | "node": ">=12" 65 | } 66 | }, 67 | "node_modules/@jridgewell/gen-mapping": { 68 | "version": "0.3.5", 69 | "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.5.tgz", 70 | "integrity": "sha512-IzL8ZoEDIBRWEzlCcRhOaCupYyN5gdIK+Q6fbFdPDg6HqX6jpkItn7DFIpW9LQzXG6Df9sA7+OKnq0qlz/GaQg==", 71 | "dependencies": { 72 | "@jridgewell/set-array": "^1.2.1", 73 | "@jridgewell/sourcemap-codec": "^1.4.10", 74 | "@jridgewell/trace-mapping": "^0.3.24" 75 | }, 76 | "engines": { 77 | "node": ">=6.0.0" 78 | } 79 | }, 80 | "node_modules/@jridgewell/resolve-uri": { 81 | "version": "3.1.2", 82 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz", 83 | "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==", 84 | "engines": { 85 | "node": ">=6.0.0" 86 | } 87 | }, 88 | "node_modules/@jridgewell/set-array": { 89 | "version": "1.2.1", 90 | "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.2.1.tgz", 91 | "integrity": "sha512-R8gLRTZeyp03ymzP/6Lil/28tGeGEzhx1q2k703KGWRAI1VdvPIXdG70VJc2pAMw3NA6JKL5hhFu1sJX0Mnn/A==", 92 | "engines": { 93 | "node": ">=6.0.0" 94 | } 95 | }, 96 | "node_modules/@jridgewell/sourcemap-codec": { 97 | "version": "1.4.15", 98 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", 99 | "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==" 100 | }, 101 | "node_modules/@jridgewell/trace-mapping": { 102 | "version": "0.3.25", 103 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.25.tgz", 104 | "integrity": "sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==", 105 | "dependencies": { 106 | "@jridgewell/resolve-uri": "^3.1.0", 107 | "@jridgewell/sourcemap-codec": "^1.4.14" 108 | } 109 | }, 110 | "node_modules/@mongodb-js/saslprep": { 111 | "version": "1.1.6", 112 | "resolved": "https://registry.npmjs.org/@mongodb-js/saslprep/-/saslprep-1.1.6.tgz", 113 | "integrity": "sha512-jqTTXQ46H8cAxmXBu8wm1HTSIMBMrIcoVrsjdQkKdMBj3il/fSCgWyya4P2I1xjPBl69mw+nRphrPlcIqBd20Q==", 114 | "dependencies": { 115 | "sparse-bitfield": "^3.0.3" 116 | } 117 | }, 118 | "node_modules/@next/env": { 119 | "version": "14.2.3", 120 | "resolved": "https://registry.npmjs.org/@next/env/-/env-14.2.3.tgz", 121 | "integrity": "sha512-W7fd7IbkfmeeY2gXrzJYDx8D2lWKbVoTIj1o1ScPHNzvp30s1AuoEFSdr39bC5sjxJaxTtq3OTCZboNp0lNWHA==" 122 | }, 123 | "node_modules/@next/swc-darwin-arm64": { 124 | "version": "14.2.3", 125 | "resolved": "https://registry.npmjs.org/@next/swc-darwin-arm64/-/swc-darwin-arm64-14.2.3.tgz", 126 | "integrity": "sha512-3pEYo/RaGqPP0YzwnlmPN2puaF2WMLM3apt5jLW2fFdXD9+pqcoTzRk+iZsf8ta7+quAe4Q6Ms0nR0SFGFdS1A==", 127 | "cpu": [ 128 | "arm64" 129 | ], 130 | "optional": true, 131 | "os": [ 132 | "darwin" 133 | ], 134 | "engines": { 135 | "node": ">= 10" 136 | } 137 | }, 138 | "node_modules/@next/swc-darwin-x64": { 139 | "version": "14.2.3", 140 | "resolved": "https://registry.npmjs.org/@next/swc-darwin-x64/-/swc-darwin-x64-14.2.3.tgz", 141 | "integrity": "sha512-6adp7waE6P1TYFSXpY366xwsOnEXM+y1kgRpjSRVI2CBDOcbRjsJ67Z6EgKIqWIue52d2q/Mx8g9MszARj8IEA==", 142 | "cpu": [ 143 | "x64" 144 | ], 145 | "optional": true, 146 | "os": [ 147 | "darwin" 148 | ], 149 | "engines": { 150 | "node": ">= 10" 151 | } 152 | }, 153 | "node_modules/@next/swc-linux-arm64-gnu": { 154 | "version": "14.2.3", 155 | "resolved": "https://registry.npmjs.org/@next/swc-linux-arm64-gnu/-/swc-linux-arm64-gnu-14.2.3.tgz", 156 | "integrity": "sha512-cuzCE/1G0ZSnTAHJPUT1rPgQx1w5tzSX7POXSLaS7w2nIUJUD+e25QoXD/hMfxbsT9rslEXugWypJMILBj/QsA==", 157 | "cpu": [ 158 | "arm64" 159 | ], 160 | "optional": true, 161 | "os": [ 162 | "linux" 163 | ], 164 | "engines": { 165 | "node": ">= 10" 166 | } 167 | }, 168 | "node_modules/@next/swc-linux-arm64-musl": { 169 | "version": "14.2.3", 170 | "resolved": "https://registry.npmjs.org/@next/swc-linux-arm64-musl/-/swc-linux-arm64-musl-14.2.3.tgz", 171 | "integrity": "sha512-0D4/oMM2Y9Ta3nGuCcQN8jjJjmDPYpHX9OJzqk42NZGJocU2MqhBq5tWkJrUQOQY9N+In9xOdymzapM09GeiZw==", 172 | "cpu": [ 173 | "arm64" 174 | ], 175 | "optional": true, 176 | "os": [ 177 | "linux" 178 | ], 179 | "engines": { 180 | "node": ">= 10" 181 | } 182 | }, 183 | "node_modules/@next/swc-linux-x64-gnu": { 184 | "version": "14.2.3", 185 | "resolved": "https://registry.npmjs.org/@next/swc-linux-x64-gnu/-/swc-linux-x64-gnu-14.2.3.tgz", 186 | "integrity": "sha512-ENPiNnBNDInBLyUU5ii8PMQh+4XLr4pG51tOp6aJ9xqFQ2iRI6IH0Ds2yJkAzNV1CfyagcyzPfROMViS2wOZ9w==", 187 | "cpu": [ 188 | "x64" 189 | ], 190 | "optional": true, 191 | "os": [ 192 | "linux" 193 | ], 194 | "engines": { 195 | "node": ">= 10" 196 | } 197 | }, 198 | "node_modules/@next/swc-linux-x64-musl": { 199 | "version": "14.2.3", 200 | "resolved": "https://registry.npmjs.org/@next/swc-linux-x64-musl/-/swc-linux-x64-musl-14.2.3.tgz", 201 | "integrity": "sha512-BTAbq0LnCbF5MtoM7I/9UeUu/8ZBY0i8SFjUMCbPDOLv+un67e2JgyN4pmgfXBwy/I+RHu8q+k+MCkDN6P9ViQ==", 202 | "cpu": [ 203 | "x64" 204 | ], 205 | "optional": true, 206 | "os": [ 207 | "linux" 208 | ], 209 | "engines": { 210 | "node": ">= 10" 211 | } 212 | }, 213 | "node_modules/@next/swc-win32-arm64-msvc": { 214 | "version": "14.2.3", 215 | "resolved": "https://registry.npmjs.org/@next/swc-win32-arm64-msvc/-/swc-win32-arm64-msvc-14.2.3.tgz", 216 | "integrity": "sha512-AEHIw/dhAMLNFJFJIJIyOFDzrzI5bAjI9J26gbO5xhAKHYTZ9Or04BesFPXiAYXDNdrwTP2dQceYA4dL1geu8A==", 217 | "cpu": [ 218 | "arm64" 219 | ], 220 | "optional": true, 221 | "os": [ 222 | "win32" 223 | ], 224 | "engines": { 225 | "node": ">= 10" 226 | } 227 | }, 228 | "node_modules/@next/swc-win32-ia32-msvc": { 229 | "version": "14.2.3", 230 | "resolved": "https://registry.npmjs.org/@next/swc-win32-ia32-msvc/-/swc-win32-ia32-msvc-14.2.3.tgz", 231 | "integrity": "sha512-vga40n1q6aYb0CLrM+eEmisfKCR45ixQYXuBXxOOmmoV8sYST9k7E3US32FsY+CkkF7NtzdcebiFT4CHuMSyZw==", 232 | "cpu": [ 233 | "ia32" 234 | ], 235 | "optional": true, 236 | "os": [ 237 | "win32" 238 | ], 239 | "engines": { 240 | "node": ">= 10" 241 | } 242 | }, 243 | "node_modules/@next/swc-win32-x64-msvc": { 244 | "version": "14.2.3", 245 | "resolved": "https://registry.npmjs.org/@next/swc-win32-x64-msvc/-/swc-win32-x64-msvc-14.2.3.tgz", 246 | "integrity": "sha512-Q1/zm43RWynxrO7lW4ehciQVj+5ePBhOK+/K2P7pLFX3JaJ/IZVC69SHidrmZSOkqz7ECIOhhy7XhAFG4JYyHA==", 247 | "cpu": [ 248 | "x64" 249 | ], 250 | "optional": true, 251 | "os": [ 252 | "win32" 253 | ], 254 | "engines": { 255 | "node": ">= 10" 256 | } 257 | }, 258 | "node_modules/@nodelib/fs.scandir": { 259 | "version": "2.1.5", 260 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 261 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 262 | "dependencies": { 263 | "@nodelib/fs.stat": "2.0.5", 264 | "run-parallel": "^1.1.9" 265 | }, 266 | "engines": { 267 | "node": ">= 8" 268 | } 269 | }, 270 | "node_modules/@nodelib/fs.stat": { 271 | "version": "2.0.5", 272 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 273 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 274 | "engines": { 275 | "node": ">= 8" 276 | } 277 | }, 278 | "node_modules/@nodelib/fs.walk": { 279 | "version": "1.2.8", 280 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 281 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 282 | "dependencies": { 283 | "@nodelib/fs.scandir": "2.1.5", 284 | "fastq": "^1.6.0" 285 | }, 286 | "engines": { 287 | "node": ">= 8" 288 | } 289 | }, 290 | "node_modules/@pkgjs/parseargs": { 291 | "version": "0.11.0", 292 | "resolved": "https://registry.npmjs.org/@pkgjs/parseargs/-/parseargs-0.11.0.tgz", 293 | "integrity": "sha512-+1VkjdD0QBLPodGrJUeqarH8VAIvQODIbwh9XpP5Syisf7YoQgsJKPNFoqqLQlu+VQ/tVSshMR6loPMn8U+dPg==", 294 | "optional": true, 295 | "engines": { 296 | "node": ">=14" 297 | } 298 | }, 299 | "node_modules/@radix-ui/primitive": { 300 | "version": "1.0.1", 301 | "resolved": "https://registry.npmjs.org/@radix-ui/primitive/-/primitive-1.0.1.tgz", 302 | "integrity": "sha512-yQ8oGX2GVsEYMWGxcovu1uGWPCxV5BFfeeYxqPmuAzUyLT9qmaMXSAhXpb0WrspIeqYzdJpkh2vHModJPgRIaw==", 303 | "dependencies": { 304 | "@babel/runtime": "^7.13.10" 305 | } 306 | }, 307 | "node_modules/@radix-ui/react-compose-refs": { 308 | "version": "1.0.1", 309 | "resolved": "https://registry.npmjs.org/@radix-ui/react-compose-refs/-/react-compose-refs-1.0.1.tgz", 310 | "integrity": "sha512-fDSBgd44FKHa1FRMU59qBMPFcl2PZE+2nmqunj+BWFyYYjnhIDWL2ItDs3rrbJDQOtzt5nIebLCQc4QRfz6LJw==", 311 | "dependencies": { 312 | "@babel/runtime": "^7.13.10" 313 | }, 314 | "peerDependencies": { 315 | "@types/react": "*", 316 | "react": "^16.8 || ^17.0 || ^18.0" 317 | }, 318 | "peerDependenciesMeta": { 319 | "@types/react": { 320 | "optional": true 321 | } 322 | } 323 | }, 324 | "node_modules/@radix-ui/react-context": { 325 | "version": "1.0.1", 326 | "resolved": "https://registry.npmjs.org/@radix-ui/react-context/-/react-context-1.0.1.tgz", 327 | "integrity": "sha512-ebbrdFoYTcuZ0v4wG5tedGnp9tzcV8awzsxYph7gXUyvnNLuTIcCk1q17JEbnVhXAKG9oX3KtchwiMIAYp9NLg==", 328 | "dependencies": { 329 | "@babel/runtime": "^7.13.10" 330 | }, 331 | "peerDependencies": { 332 | "@types/react": "*", 333 | "react": "^16.8 || ^17.0 || ^18.0" 334 | }, 335 | "peerDependenciesMeta": { 336 | "@types/react": { 337 | "optional": true 338 | } 339 | } 340 | }, 341 | "node_modules/@radix-ui/react-dialog": { 342 | "version": "1.0.5", 343 | "resolved": "https://registry.npmjs.org/@radix-ui/react-dialog/-/react-dialog-1.0.5.tgz", 344 | "integrity": "sha512-GjWJX/AUpB703eEBanuBnIWdIXg6NvJFCXcNlSZk4xdszCdhrJgBoUd1cGk67vFO+WdA2pfI/plOpqz/5GUP6Q==", 345 | "dependencies": { 346 | "@babel/runtime": "^7.13.10", 347 | "@radix-ui/primitive": "1.0.1", 348 | "@radix-ui/react-compose-refs": "1.0.1", 349 | "@radix-ui/react-context": "1.0.1", 350 | "@radix-ui/react-dismissable-layer": "1.0.5", 351 | "@radix-ui/react-focus-guards": "1.0.1", 352 | "@radix-ui/react-focus-scope": "1.0.4", 353 | "@radix-ui/react-id": "1.0.1", 354 | "@radix-ui/react-portal": "1.0.4", 355 | "@radix-ui/react-presence": "1.0.1", 356 | "@radix-ui/react-primitive": "1.0.3", 357 | "@radix-ui/react-slot": "1.0.2", 358 | "@radix-ui/react-use-controllable-state": "1.0.1", 359 | "aria-hidden": "^1.1.1", 360 | "react-remove-scroll": "2.5.5" 361 | }, 362 | "peerDependencies": { 363 | "@types/react": "*", 364 | "@types/react-dom": "*", 365 | "react": "^16.8 || ^17.0 || ^18.0", 366 | "react-dom": "^16.8 || ^17.0 || ^18.0" 367 | }, 368 | "peerDependenciesMeta": { 369 | "@types/react": { 370 | "optional": true 371 | }, 372 | "@types/react-dom": { 373 | "optional": true 374 | } 375 | } 376 | }, 377 | "node_modules/@radix-ui/react-dismissable-layer": { 378 | "version": "1.0.5", 379 | "resolved": "https://registry.npmjs.org/@radix-ui/react-dismissable-layer/-/react-dismissable-layer-1.0.5.tgz", 380 | "integrity": "sha512-aJeDjQhywg9LBu2t/At58hCvr7pEm0o2Ke1x33B+MhjNmmZ17sy4KImo0KPLgsnc/zN7GPdce8Cnn0SWvwZO7g==", 381 | "dependencies": { 382 | "@babel/runtime": "^7.13.10", 383 | "@radix-ui/primitive": "1.0.1", 384 | "@radix-ui/react-compose-refs": "1.0.1", 385 | "@radix-ui/react-primitive": "1.0.3", 386 | "@radix-ui/react-use-callback-ref": "1.0.1", 387 | "@radix-ui/react-use-escape-keydown": "1.0.3" 388 | }, 389 | "peerDependencies": { 390 | "@types/react": "*", 391 | "@types/react-dom": "*", 392 | "react": "^16.8 || ^17.0 || ^18.0", 393 | "react-dom": "^16.8 || ^17.0 || ^18.0" 394 | }, 395 | "peerDependenciesMeta": { 396 | "@types/react": { 397 | "optional": true 398 | }, 399 | "@types/react-dom": { 400 | "optional": true 401 | } 402 | } 403 | }, 404 | "node_modules/@radix-ui/react-focus-guards": { 405 | "version": "1.0.1", 406 | "resolved": "https://registry.npmjs.org/@radix-ui/react-focus-guards/-/react-focus-guards-1.0.1.tgz", 407 | "integrity": "sha512-Rect2dWbQ8waGzhMavsIbmSVCgYxkXLxxR3ZvCX79JOglzdEy4JXMb98lq4hPxUbLr77nP0UOGf4rcMU+s1pUA==", 408 | "dependencies": { 409 | "@babel/runtime": "^7.13.10" 410 | }, 411 | "peerDependencies": { 412 | "@types/react": "*", 413 | "react": "^16.8 || ^17.0 || ^18.0" 414 | }, 415 | "peerDependenciesMeta": { 416 | "@types/react": { 417 | "optional": true 418 | } 419 | } 420 | }, 421 | "node_modules/@radix-ui/react-focus-scope": { 422 | "version": "1.0.4", 423 | "resolved": "https://registry.npmjs.org/@radix-ui/react-focus-scope/-/react-focus-scope-1.0.4.tgz", 424 | "integrity": "sha512-sL04Mgvf+FmyvZeYfNu1EPAaaxD+aw7cYeIB9L9Fvq8+urhltTRaEo5ysKOpHuKPclsZcSUMKlN05x4u+CINpA==", 425 | "dependencies": { 426 | "@babel/runtime": "^7.13.10", 427 | "@radix-ui/react-compose-refs": "1.0.1", 428 | "@radix-ui/react-primitive": "1.0.3", 429 | "@radix-ui/react-use-callback-ref": "1.0.1" 430 | }, 431 | "peerDependencies": { 432 | "@types/react": "*", 433 | "@types/react-dom": "*", 434 | "react": "^16.8 || ^17.0 || ^18.0", 435 | "react-dom": "^16.8 || ^17.0 || ^18.0" 436 | }, 437 | "peerDependenciesMeta": { 438 | "@types/react": { 439 | "optional": true 440 | }, 441 | "@types/react-dom": { 442 | "optional": true 443 | } 444 | } 445 | }, 446 | "node_modules/@radix-ui/react-id": { 447 | "version": "1.0.1", 448 | "resolved": "https://registry.npmjs.org/@radix-ui/react-id/-/react-id-1.0.1.tgz", 449 | "integrity": "sha512-tI7sT/kqYp8p96yGWY1OAnLHrqDgzHefRBKQ2YAkBS5ja7QLcZ9Z/uY7bEjPUatf8RomoXM8/1sMj1IJaE5UzQ==", 450 | "dependencies": { 451 | "@babel/runtime": "^7.13.10", 452 | "@radix-ui/react-use-layout-effect": "1.0.1" 453 | }, 454 | "peerDependencies": { 455 | "@types/react": "*", 456 | "react": "^16.8 || ^17.0 || ^18.0" 457 | }, 458 | "peerDependenciesMeta": { 459 | "@types/react": { 460 | "optional": true 461 | } 462 | } 463 | }, 464 | "node_modules/@radix-ui/react-label": { 465 | "version": "2.0.2", 466 | "resolved": "https://registry.npmjs.org/@radix-ui/react-label/-/react-label-2.0.2.tgz", 467 | "integrity": "sha512-N5ehvlM7qoTLx7nWPodsPYPgMzA5WM8zZChQg8nyFJKnDO5WHdba1vv5/H6IO5LtJMfD2Q3wh1qHFGNtK0w3bQ==", 468 | "dependencies": { 469 | "@babel/runtime": "^7.13.10", 470 | "@radix-ui/react-primitive": "1.0.3" 471 | }, 472 | "peerDependencies": { 473 | "@types/react": "*", 474 | "@types/react-dom": "*", 475 | "react": "^16.8 || ^17.0 || ^18.0", 476 | "react-dom": "^16.8 || ^17.0 || ^18.0" 477 | }, 478 | "peerDependenciesMeta": { 479 | "@types/react": { 480 | "optional": true 481 | }, 482 | "@types/react-dom": { 483 | "optional": true 484 | } 485 | } 486 | }, 487 | "node_modules/@radix-ui/react-portal": { 488 | "version": "1.0.4", 489 | "resolved": "https://registry.npmjs.org/@radix-ui/react-portal/-/react-portal-1.0.4.tgz", 490 | "integrity": "sha512-Qki+C/EuGUVCQTOTD5vzJzJuMUlewbzuKyUy+/iHM2uwGiru9gZeBJtHAPKAEkB5KWGi9mP/CHKcY0wt1aW45Q==", 491 | "dependencies": { 492 | "@babel/runtime": "^7.13.10", 493 | "@radix-ui/react-primitive": "1.0.3" 494 | }, 495 | "peerDependencies": { 496 | "@types/react": "*", 497 | "@types/react-dom": "*", 498 | "react": "^16.8 || ^17.0 || ^18.0", 499 | "react-dom": "^16.8 || ^17.0 || ^18.0" 500 | }, 501 | "peerDependenciesMeta": { 502 | "@types/react": { 503 | "optional": true 504 | }, 505 | "@types/react-dom": { 506 | "optional": true 507 | } 508 | } 509 | }, 510 | "node_modules/@radix-ui/react-presence": { 511 | "version": "1.0.1", 512 | "resolved": "https://registry.npmjs.org/@radix-ui/react-presence/-/react-presence-1.0.1.tgz", 513 | "integrity": "sha512-UXLW4UAbIY5ZjcvzjfRFo5gxva8QirC9hF7wRE4U5gz+TP0DbRk+//qyuAQ1McDxBt1xNMBTaciFGvEmJvAZCg==", 514 | "dependencies": { 515 | "@babel/runtime": "^7.13.10", 516 | "@radix-ui/react-compose-refs": "1.0.1", 517 | "@radix-ui/react-use-layout-effect": "1.0.1" 518 | }, 519 | "peerDependencies": { 520 | "@types/react": "*", 521 | "@types/react-dom": "*", 522 | "react": "^16.8 || ^17.0 || ^18.0", 523 | "react-dom": "^16.8 || ^17.0 || ^18.0" 524 | }, 525 | "peerDependenciesMeta": { 526 | "@types/react": { 527 | "optional": true 528 | }, 529 | "@types/react-dom": { 530 | "optional": true 531 | } 532 | } 533 | }, 534 | "node_modules/@radix-ui/react-primitive": { 535 | "version": "1.0.3", 536 | "resolved": "https://registry.npmjs.org/@radix-ui/react-primitive/-/react-primitive-1.0.3.tgz", 537 | "integrity": "sha512-yi58uVyoAcK/Nq1inRY56ZSjKypBNKTa/1mcL8qdl6oJeEaDbOldlzrGn7P6Q3Id5d+SYNGc5AJgc4vGhjs5+g==", 538 | "dependencies": { 539 | "@babel/runtime": "^7.13.10", 540 | "@radix-ui/react-slot": "1.0.2" 541 | }, 542 | "peerDependencies": { 543 | "@types/react": "*", 544 | "@types/react-dom": "*", 545 | "react": "^16.8 || ^17.0 || ^18.0", 546 | "react-dom": "^16.8 || ^17.0 || ^18.0" 547 | }, 548 | "peerDependenciesMeta": { 549 | "@types/react": { 550 | "optional": true 551 | }, 552 | "@types/react-dom": { 553 | "optional": true 554 | } 555 | } 556 | }, 557 | "node_modules/@radix-ui/react-slot": { 558 | "version": "1.0.2", 559 | "resolved": "https://registry.npmjs.org/@radix-ui/react-slot/-/react-slot-1.0.2.tgz", 560 | "integrity": "sha512-YeTpuq4deV+6DusvVUW4ivBgnkHwECUu0BiN43L5UCDFgdhsRUWAghhTF5MbvNTPzmiFOx90asDSUjWuCNapwg==", 561 | "dependencies": { 562 | "@babel/runtime": "^7.13.10", 563 | "@radix-ui/react-compose-refs": "1.0.1" 564 | }, 565 | "peerDependencies": { 566 | "@types/react": "*", 567 | "react": "^16.8 || ^17.0 || ^18.0" 568 | }, 569 | "peerDependenciesMeta": { 570 | "@types/react": { 571 | "optional": true 572 | } 573 | } 574 | }, 575 | "node_modules/@radix-ui/react-use-callback-ref": { 576 | "version": "1.0.1", 577 | "resolved": "https://registry.npmjs.org/@radix-ui/react-use-callback-ref/-/react-use-callback-ref-1.0.1.tgz", 578 | "integrity": "sha512-D94LjX4Sp0xJFVaoQOd3OO9k7tpBYNOXdVhkltUbGv2Qb9OXdrg/CpsjlZv7ia14Sylv398LswWBVVu5nqKzAQ==", 579 | "dependencies": { 580 | "@babel/runtime": "^7.13.10" 581 | }, 582 | "peerDependencies": { 583 | "@types/react": "*", 584 | "react": "^16.8 || ^17.0 || ^18.0" 585 | }, 586 | "peerDependenciesMeta": { 587 | "@types/react": { 588 | "optional": true 589 | } 590 | } 591 | }, 592 | "node_modules/@radix-ui/react-use-controllable-state": { 593 | "version": "1.0.1", 594 | "resolved": "https://registry.npmjs.org/@radix-ui/react-use-controllable-state/-/react-use-controllable-state-1.0.1.tgz", 595 | "integrity": "sha512-Svl5GY5FQeN758fWKrjM6Qb7asvXeiZltlT4U2gVfl8Gx5UAv2sMR0LWo8yhsIZh2oQ0eFdZ59aoOOMV7b47VA==", 596 | "dependencies": { 597 | "@babel/runtime": "^7.13.10", 598 | "@radix-ui/react-use-callback-ref": "1.0.1" 599 | }, 600 | "peerDependencies": { 601 | "@types/react": "*", 602 | "react": "^16.8 || ^17.0 || ^18.0" 603 | }, 604 | "peerDependenciesMeta": { 605 | "@types/react": { 606 | "optional": true 607 | } 608 | } 609 | }, 610 | "node_modules/@radix-ui/react-use-escape-keydown": { 611 | "version": "1.0.3", 612 | "resolved": "https://registry.npmjs.org/@radix-ui/react-use-escape-keydown/-/react-use-escape-keydown-1.0.3.tgz", 613 | "integrity": "sha512-vyL82j40hcFicA+M4Ex7hVkB9vHgSse1ZWomAqV2Je3RleKGO5iM8KMOEtfoSB0PnIelMd2lATjTGMYqN5ylTg==", 614 | "dependencies": { 615 | "@babel/runtime": "^7.13.10", 616 | "@radix-ui/react-use-callback-ref": "1.0.1" 617 | }, 618 | "peerDependencies": { 619 | "@types/react": "*", 620 | "react": "^16.8 || ^17.0 || ^18.0" 621 | }, 622 | "peerDependenciesMeta": { 623 | "@types/react": { 624 | "optional": true 625 | } 626 | } 627 | }, 628 | "node_modules/@radix-ui/react-use-layout-effect": { 629 | "version": "1.0.1", 630 | "resolved": "https://registry.npmjs.org/@radix-ui/react-use-layout-effect/-/react-use-layout-effect-1.0.1.tgz", 631 | "integrity": "sha512-v/5RegiJWYdoCvMnITBkNNx6bCj20fiaJnWtRkU18yITptraXjffz5Qbn05uOiQnOvi+dbkznkoaMltz1GnszQ==", 632 | "dependencies": { 633 | "@babel/runtime": "^7.13.10" 634 | }, 635 | "peerDependencies": { 636 | "@types/react": "*", 637 | "react": "^16.8 || ^17.0 || ^18.0" 638 | }, 639 | "peerDependenciesMeta": { 640 | "@types/react": { 641 | "optional": true 642 | } 643 | } 644 | }, 645 | "node_modules/@swc/counter": { 646 | "version": "0.1.3", 647 | "resolved": "https://registry.npmjs.org/@swc/counter/-/counter-0.1.3.tgz", 648 | "integrity": "sha512-e2BR4lsJkkRlKZ/qCHPw9ZaSxc0MVUd7gtbtaB7aMvHeJVYe8sOB8DBZkP2DtISHGSku9sCK6T6cnY0CtXrOCQ==" 649 | }, 650 | "node_modules/@swc/helpers": { 651 | "version": "0.5.5", 652 | "resolved": "https://registry.npmjs.org/@swc/helpers/-/helpers-0.5.5.tgz", 653 | "integrity": "sha512-KGYxvIOXcceOAbEk4bi/dVLEK9z8sZ0uBB3Il5b1rhfClSpcX0yfRO0KmTkqR2cnQDymwLB+25ZyMzICg/cm/A==", 654 | "dependencies": { 655 | "@swc/counter": "^0.1.3", 656 | "tslib": "^2.4.0" 657 | } 658 | }, 659 | "node_modules/@types/webidl-conversions": { 660 | "version": "7.0.3", 661 | "resolved": "https://registry.npmjs.org/@types/webidl-conversions/-/webidl-conversions-7.0.3.tgz", 662 | "integrity": "sha512-CiJJvcRtIgzadHCYXw7dqEnMNRjhGZlYK05Mj9OyktqV8uVT8fD2BFOB7S1uwBE3Kj2Z+4UyPmFw/Ixgw/LAlA==" 663 | }, 664 | "node_modules/@types/whatwg-url": { 665 | "version": "11.0.4", 666 | "resolved": "https://registry.npmjs.org/@types/whatwg-url/-/whatwg-url-11.0.4.tgz", 667 | "integrity": "sha512-lXCmTWSHJvf0TRSO58nm978b8HJ/EdsSsEKLd3ODHFjo+3VGAyyTp4v50nWvwtzBxSMQrVOK7tcuN0zGPLICMw==", 668 | "dependencies": { 669 | "@types/webidl-conversions": "*" 670 | } 671 | }, 672 | "node_modules/ansi-regex": { 673 | "version": "6.0.1", 674 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.0.1.tgz", 675 | "integrity": "sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==", 676 | "engines": { 677 | "node": ">=12" 678 | }, 679 | "funding": { 680 | "url": "https://github.com/chalk/ansi-regex?sponsor=1" 681 | } 682 | }, 683 | "node_modules/ansi-styles": { 684 | "version": "6.2.1", 685 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz", 686 | "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==", 687 | "engines": { 688 | "node": ">=12" 689 | }, 690 | "funding": { 691 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 692 | } 693 | }, 694 | "node_modules/any-promise": { 695 | "version": "1.3.0", 696 | "resolved": "https://registry.npmjs.org/any-promise/-/any-promise-1.3.0.tgz", 697 | "integrity": "sha512-7UvmKalWRt1wgjL1RrGxoSJW/0QZFIegpeGvZG9kjp8vrRu55XTHbwnqq2GpXm9uLbcuhxm3IqX9OB4MZR1b2A==" 698 | }, 699 | "node_modules/anymatch": { 700 | "version": "3.1.3", 701 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 702 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 703 | "dependencies": { 704 | "normalize-path": "^3.0.0", 705 | "picomatch": "^2.0.4" 706 | }, 707 | "engines": { 708 | "node": ">= 8" 709 | } 710 | }, 711 | "node_modules/arg": { 712 | "version": "5.0.2", 713 | "resolved": "https://registry.npmjs.org/arg/-/arg-5.0.2.tgz", 714 | "integrity": "sha512-PYjyFOLKQ9y57JvQ6QLo8dAgNqswh8M1RMJYdQduT6xbWSgK36P/Z/v+p888pM69jMMfS8Xd8F6I1kQ/I9HUGg==" 715 | }, 716 | "node_modules/aria-hidden": { 717 | "version": "1.2.4", 718 | "resolved": "https://registry.npmjs.org/aria-hidden/-/aria-hidden-1.2.4.tgz", 719 | "integrity": "sha512-y+CcFFwelSXpLZk/7fMB2mUbGtX9lKycf1MWJ7CaTIERyitVlyQx6C+sxcROU2BAJ24OiZyK+8wj2i8AlBoS3A==", 720 | "dependencies": { 721 | "tslib": "^2.0.0" 722 | }, 723 | "engines": { 724 | "node": ">=10" 725 | } 726 | }, 727 | "node_modules/balanced-match": { 728 | "version": "1.0.2", 729 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 730 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==" 731 | }, 732 | "node_modules/binary-extensions": { 733 | "version": "2.3.0", 734 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.3.0.tgz", 735 | "integrity": "sha512-Ceh+7ox5qe7LJuLHoY0feh3pHuUDHAcRUeyL2VYghZwfpkNIy/+8Ocg0a3UuSoYzavmylwuLWQOf3hl0jjMMIw==", 736 | "engines": { 737 | "node": ">=8" 738 | }, 739 | "funding": { 740 | "url": "https://github.com/sponsors/sindresorhus" 741 | } 742 | }, 743 | "node_modules/brace-expansion": { 744 | "version": "2.0.1", 745 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 746 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 747 | "dependencies": { 748 | "balanced-match": "^1.0.0" 749 | } 750 | }, 751 | "node_modules/braces": { 752 | "version": "3.0.2", 753 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 754 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 755 | "dependencies": { 756 | "fill-range": "^7.0.1" 757 | }, 758 | "engines": { 759 | "node": ">=8" 760 | } 761 | }, 762 | "node_modules/bson": { 763 | "version": "6.7.0", 764 | "resolved": "https://registry.npmjs.org/bson/-/bson-6.7.0.tgz", 765 | "integrity": "sha512-w2IquM5mYzYZv6rs3uN2DZTOBe2a0zXLj53TGDqwF4l6Sz/XsISrisXOJihArF9+BZ6Cq/GjVht7Sjfmri7ytQ==", 766 | "engines": { 767 | "node": ">=16.20.1" 768 | } 769 | }, 770 | "node_modules/busboy": { 771 | "version": "1.6.0", 772 | "resolved": "https://registry.npmjs.org/busboy/-/busboy-1.6.0.tgz", 773 | "integrity": "sha512-8SFQbg/0hQ9xy3UNTB0YEnsNBbWfhf7RtnzpL7TkBiTBRfrQ9Fxcnz7VJsleJpyp6rVLvXiuORqjlHi5q+PYuA==", 774 | "dependencies": { 775 | "streamsearch": "^1.1.0" 776 | }, 777 | "engines": { 778 | "node": ">=10.16.0" 779 | } 780 | }, 781 | "node_modules/camelcase-css": { 782 | "version": "2.0.1", 783 | "resolved": "https://registry.npmjs.org/camelcase-css/-/camelcase-css-2.0.1.tgz", 784 | "integrity": "sha512-QOSvevhslijgYwRx6Rv7zKdMF8lbRmx+uQGx2+vDc+KI/eBnsy9kit5aj23AgGu3pa4t9AgwbnXWqS+iOY+2aA==", 785 | "engines": { 786 | "node": ">= 6" 787 | } 788 | }, 789 | "node_modules/caniuse-lite": { 790 | "version": "1.0.30001615", 791 | "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001615.tgz", 792 | "integrity": "sha512-1IpazM5G3r38meiae0bHRnPhz+CBQ3ZLqbQMtrg+AsTPKAXgW38JNsXkyZ+v8waCsDmPq87lmfun5Q2AGysNEQ==", 793 | "funding": [ 794 | { 795 | "type": "opencollective", 796 | "url": "https://opencollective.com/browserslist" 797 | }, 798 | { 799 | "type": "tidelift", 800 | "url": "https://tidelift.com/funding/github/npm/caniuse-lite" 801 | }, 802 | { 803 | "type": "github", 804 | "url": "https://github.com/sponsors/ai" 805 | } 806 | ] 807 | }, 808 | "node_modules/chokidar": { 809 | "version": "3.6.0", 810 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.6.0.tgz", 811 | "integrity": "sha512-7VT13fmjotKpGipCW9JEQAusEPE+Ei8nl6/g4FBAmIm0GOOLMua9NDDo/DWp0ZAxCr3cPq5ZpBqmPAQgDda2Pw==", 812 | "dependencies": { 813 | "anymatch": "~3.1.2", 814 | "braces": "~3.0.2", 815 | "glob-parent": "~5.1.2", 816 | "is-binary-path": "~2.1.0", 817 | "is-glob": "~4.0.1", 818 | "normalize-path": "~3.0.0", 819 | "readdirp": "~3.6.0" 820 | }, 821 | "engines": { 822 | "node": ">= 8.10.0" 823 | }, 824 | "funding": { 825 | "url": "https://paulmillr.com/funding/" 826 | }, 827 | "optionalDependencies": { 828 | "fsevents": "~2.3.2" 829 | } 830 | }, 831 | "node_modules/chokidar/node_modules/glob-parent": { 832 | "version": "5.1.2", 833 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 834 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 835 | "dependencies": { 836 | "is-glob": "^4.0.1" 837 | }, 838 | "engines": { 839 | "node": ">= 6" 840 | } 841 | }, 842 | "node_modules/class-variance-authority": { 843 | "version": "0.7.0", 844 | "resolved": "https://registry.npmjs.org/class-variance-authority/-/class-variance-authority-0.7.0.tgz", 845 | "integrity": "sha512-jFI8IQw4hczaL4ALINxqLEXQbWcNjoSkloa4IaufXCJr6QawJyw7tuRysRsrE8w2p/4gGaxKIt/hX3qz/IbD1A==", 846 | "dependencies": { 847 | "clsx": "2.0.0" 848 | }, 849 | "funding": { 850 | "url": "https://joebell.co.uk" 851 | } 852 | }, 853 | "node_modules/class-variance-authority/node_modules/clsx": { 854 | "version": "2.0.0", 855 | "resolved": "https://registry.npmjs.org/clsx/-/clsx-2.0.0.tgz", 856 | "integrity": "sha512-rQ1+kcj+ttHG0MKVGBUXwayCCF1oh39BF5COIpRzuCEv8Mwjv0XucrI2ExNTOn9IlLifGClWQcU9BrZORvtw6Q==", 857 | "engines": { 858 | "node": ">=6" 859 | } 860 | }, 861 | "node_modules/client-only": { 862 | "version": "0.0.1", 863 | "resolved": "https://registry.npmjs.org/client-only/-/client-only-0.0.1.tgz", 864 | "integrity": "sha512-IV3Ou0jSMzZrd3pZ48nLkT9DA7Ag1pnPzaiQhpW7c3RbcqqzvzzVu+L8gfqMp/8IM2MQtSiqaCxrrcfu8I8rMA==" 865 | }, 866 | "node_modules/clsx": { 867 | "version": "2.1.1", 868 | "resolved": "https://registry.npmjs.org/clsx/-/clsx-2.1.1.tgz", 869 | "integrity": "sha512-eYm0QWBtUrBWZWG0d386OGAw16Z995PiOVo2B7bjWSbHedGl5e0ZWaq65kOGgUSNesEIDkB9ISbTg/JK9dhCZA==", 870 | "engines": { 871 | "node": ">=6" 872 | } 873 | }, 874 | "node_modules/color-convert": { 875 | "version": "2.0.1", 876 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 877 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 878 | "dependencies": { 879 | "color-name": "~1.1.4" 880 | }, 881 | "engines": { 882 | "node": ">=7.0.0" 883 | } 884 | }, 885 | "node_modules/color-name": { 886 | "version": "1.1.4", 887 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 888 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" 889 | }, 890 | "node_modules/commander": { 891 | "version": "4.1.1", 892 | "resolved": "https://registry.npmjs.org/commander/-/commander-4.1.1.tgz", 893 | "integrity": "sha512-NOKm8xhkzAjzFx8B2v5OAHT+u5pRQc2UCa2Vq9jYL/31o2wi9mxBA7LIFs3sV5VSC49z6pEhfbMULvShKj26WA==", 894 | "engines": { 895 | "node": ">= 6" 896 | } 897 | }, 898 | "node_modules/cross-spawn": { 899 | "version": "7.0.3", 900 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 901 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 902 | "dependencies": { 903 | "path-key": "^3.1.0", 904 | "shebang-command": "^2.0.0", 905 | "which": "^2.0.1" 906 | }, 907 | "engines": { 908 | "node": ">= 8" 909 | } 910 | }, 911 | "node_modules/cssesc": { 912 | "version": "3.0.0", 913 | "resolved": "https://registry.npmjs.org/cssesc/-/cssesc-3.0.0.tgz", 914 | "integrity": "sha512-/Tb/JcjK111nNScGob5MNtsntNM1aCNUDipB/TkwZFhyDrrE47SOx/18wF2bbjgc3ZzCSKW1T5nt5EbFoAz/Vg==", 915 | "bin": { 916 | "cssesc": "bin/cssesc" 917 | }, 918 | "engines": { 919 | "node": ">=4" 920 | } 921 | }, 922 | "node_modules/debug": { 923 | "version": "4.3.4", 924 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 925 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 926 | "dependencies": { 927 | "ms": "2.1.2" 928 | }, 929 | "engines": { 930 | "node": ">=6.0" 931 | }, 932 | "peerDependenciesMeta": { 933 | "supports-color": { 934 | "optional": true 935 | } 936 | } 937 | }, 938 | "node_modules/debug/node_modules/ms": { 939 | "version": "2.1.2", 940 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 941 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 942 | }, 943 | "node_modules/detect-node-es": { 944 | "version": "1.1.0", 945 | "resolved": "https://registry.npmjs.org/detect-node-es/-/detect-node-es-1.1.0.tgz", 946 | "integrity": "sha512-ypdmJU/TbBby2Dxibuv7ZLW3Bs1QEmM7nHjEANfohJLvE0XVujisn1qPJcZxg+qDucsr+bP6fLD1rPS3AhJ7EQ==" 947 | }, 948 | "node_modules/didyoumean": { 949 | "version": "1.2.2", 950 | "resolved": "https://registry.npmjs.org/didyoumean/-/didyoumean-1.2.2.tgz", 951 | "integrity": "sha512-gxtyfqMg7GKyhQmb056K7M3xszy/myH8w+B4RT+QXBQsvAOdc3XymqDDPHx1BgPgsdAA5SIifona89YtRATDzw==" 952 | }, 953 | "node_modules/dlv": { 954 | "version": "1.1.3", 955 | "resolved": "https://registry.npmjs.org/dlv/-/dlv-1.1.3.tgz", 956 | "integrity": "sha512-+HlytyjlPKnIG8XuRG8WvmBP8xs8P71y+SKKS6ZXWoEgLuePxtDoUEiH7WkdePWrQ5JBpE6aoVqfZfJUQkjXwA==" 957 | }, 958 | "node_modules/eastasianwidth": { 959 | "version": "0.2.0", 960 | "resolved": "https://registry.npmjs.org/eastasianwidth/-/eastasianwidth-0.2.0.tgz", 961 | "integrity": "sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==" 962 | }, 963 | "node_modules/emoji-regex": { 964 | "version": "9.2.2", 965 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-9.2.2.tgz", 966 | "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==" 967 | }, 968 | "node_modules/fast-glob": { 969 | "version": "3.3.2", 970 | "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.3.2.tgz", 971 | "integrity": "sha512-oX2ruAFQwf/Orj8m737Y5adxDQO0LAB7/S5MnxCdTNDd4p6BsyIVsv9JQsATbTSq8KHRpLwIHbVlUNatxd+1Ow==", 972 | "dependencies": { 973 | "@nodelib/fs.stat": "^2.0.2", 974 | "@nodelib/fs.walk": "^1.2.3", 975 | "glob-parent": "^5.1.2", 976 | "merge2": "^1.3.0", 977 | "micromatch": "^4.0.4" 978 | }, 979 | "engines": { 980 | "node": ">=8.6.0" 981 | } 982 | }, 983 | "node_modules/fast-glob/node_modules/glob-parent": { 984 | "version": "5.1.2", 985 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 986 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 987 | "dependencies": { 988 | "is-glob": "^4.0.1" 989 | }, 990 | "engines": { 991 | "node": ">= 6" 992 | } 993 | }, 994 | "node_modules/fastq": { 995 | "version": "1.17.1", 996 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.17.1.tgz", 997 | "integrity": "sha512-sRVD3lWVIXWg6By68ZN7vho9a1pQcN/WBFaAAsDDFzlJjvoGx0P8z7V1t72grFJfJhu3YPZBuu25f7Kaw2jN1w==", 998 | "dependencies": { 999 | "reusify": "^1.0.4" 1000 | } 1001 | }, 1002 | "node_modules/fill-range": { 1003 | "version": "7.0.1", 1004 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 1005 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 1006 | "dependencies": { 1007 | "to-regex-range": "^5.0.1" 1008 | }, 1009 | "engines": { 1010 | "node": ">=8" 1011 | } 1012 | }, 1013 | "node_modules/foreground-child": { 1014 | "version": "3.1.1", 1015 | "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-3.1.1.tgz", 1016 | "integrity": "sha512-TMKDUnIte6bfb5nWv7V/caI169OHgvwjb7V4WkeUvbQQdjr5rWKqHFiKWb/fcOwB+CzBT+qbWjvj+DVwRskpIg==", 1017 | "dependencies": { 1018 | "cross-spawn": "^7.0.0", 1019 | "signal-exit": "^4.0.1" 1020 | }, 1021 | "engines": { 1022 | "node": ">=14" 1023 | }, 1024 | "funding": { 1025 | "url": "https://github.com/sponsors/isaacs" 1026 | } 1027 | }, 1028 | "node_modules/fsevents": { 1029 | "version": "2.3.3", 1030 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", 1031 | "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", 1032 | "hasInstallScript": true, 1033 | "optional": true, 1034 | "os": [ 1035 | "darwin" 1036 | ], 1037 | "engines": { 1038 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 1039 | } 1040 | }, 1041 | "node_modules/function-bind": { 1042 | "version": "1.1.2", 1043 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", 1044 | "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", 1045 | "funding": { 1046 | "url": "https://github.com/sponsors/ljharb" 1047 | } 1048 | }, 1049 | "node_modules/get-nonce": { 1050 | "version": "1.0.1", 1051 | "resolved": "https://registry.npmjs.org/get-nonce/-/get-nonce-1.0.1.tgz", 1052 | "integrity": "sha512-FJhYRoDaiatfEkUK8HKlicmu/3SGFD51q3itKDGoSTysQJBnfOcxU5GxnhE1E6soB76MbT0MBtnKJuXyAx+96Q==", 1053 | "engines": { 1054 | "node": ">=6" 1055 | } 1056 | }, 1057 | "node_modules/glob": { 1058 | "version": "10.3.12", 1059 | "resolved": "https://registry.npmjs.org/glob/-/glob-10.3.12.tgz", 1060 | "integrity": "sha512-TCNv8vJ+xz4QiqTpfOJA7HvYv+tNIRHKfUWw/q+v2jdgN4ebz+KY9tGx5J4rHP0o84mNP+ApH66HRX8us3Khqg==", 1061 | "dependencies": { 1062 | "foreground-child": "^3.1.0", 1063 | "jackspeak": "^2.3.6", 1064 | "minimatch": "^9.0.1", 1065 | "minipass": "^7.0.4", 1066 | "path-scurry": "^1.10.2" 1067 | }, 1068 | "bin": { 1069 | "glob": "dist/esm/bin.mjs" 1070 | }, 1071 | "engines": { 1072 | "node": ">=16 || 14 >=14.17" 1073 | }, 1074 | "funding": { 1075 | "url": "https://github.com/sponsors/isaacs" 1076 | } 1077 | }, 1078 | "node_modules/glob-parent": { 1079 | "version": "6.0.2", 1080 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 1081 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 1082 | "dependencies": { 1083 | "is-glob": "^4.0.3" 1084 | }, 1085 | "engines": { 1086 | "node": ">=10.13.0" 1087 | } 1088 | }, 1089 | "node_modules/graceful-fs": { 1090 | "version": "4.2.11", 1091 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", 1092 | "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==" 1093 | }, 1094 | "node_modules/hasown": { 1095 | "version": "2.0.2", 1096 | "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz", 1097 | "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==", 1098 | "dependencies": { 1099 | "function-bind": "^1.1.2" 1100 | }, 1101 | "engines": { 1102 | "node": ">= 0.4" 1103 | } 1104 | }, 1105 | "node_modules/invariant": { 1106 | "version": "2.2.4", 1107 | "resolved": "https://registry.npmjs.org/invariant/-/invariant-2.2.4.tgz", 1108 | "integrity": "sha512-phJfQVBuaJM5raOpJjSfkiD6BpbCE4Ns//LaXl6wGYtUBY83nWS6Rf9tXm2e8VaK60JEjYldbPif/A2B1C2gNA==", 1109 | "dependencies": { 1110 | "loose-envify": "^1.0.0" 1111 | } 1112 | }, 1113 | "node_modules/is-binary-path": { 1114 | "version": "2.1.0", 1115 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 1116 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 1117 | "dependencies": { 1118 | "binary-extensions": "^2.0.0" 1119 | }, 1120 | "engines": { 1121 | "node": ">=8" 1122 | } 1123 | }, 1124 | "node_modules/is-core-module": { 1125 | "version": "2.13.1", 1126 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.13.1.tgz", 1127 | "integrity": "sha512-hHrIjvZsftOsvKSn2TRYl63zvxsgE0K+0mYMoH6gD4omR5IWB2KynivBQczo3+wF1cCkjzvptnI9Q0sPU66ilw==", 1128 | "dependencies": { 1129 | "hasown": "^2.0.0" 1130 | }, 1131 | "funding": { 1132 | "url": "https://github.com/sponsors/ljharb" 1133 | } 1134 | }, 1135 | "node_modules/is-extglob": { 1136 | "version": "2.1.1", 1137 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1138 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 1139 | "engines": { 1140 | "node": ">=0.10.0" 1141 | } 1142 | }, 1143 | "node_modules/is-fullwidth-code-point": { 1144 | "version": "3.0.0", 1145 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1146 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1147 | "engines": { 1148 | "node": ">=8" 1149 | } 1150 | }, 1151 | "node_modules/is-glob": { 1152 | "version": "4.0.3", 1153 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 1154 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 1155 | "dependencies": { 1156 | "is-extglob": "^2.1.1" 1157 | }, 1158 | "engines": { 1159 | "node": ">=0.10.0" 1160 | } 1161 | }, 1162 | "node_modules/is-number": { 1163 | "version": "7.0.0", 1164 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1165 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1166 | "engines": { 1167 | "node": ">=0.12.0" 1168 | } 1169 | }, 1170 | "node_modules/isexe": { 1171 | "version": "2.0.0", 1172 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1173 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==" 1174 | }, 1175 | "node_modules/jackspeak": { 1176 | "version": "2.3.6", 1177 | "resolved": "https://registry.npmjs.org/jackspeak/-/jackspeak-2.3.6.tgz", 1178 | "integrity": "sha512-N3yCS/NegsOBokc8GAdM8UcmfsKiSS8cipheD/nivzr700H+nsMOxJjQnvwOcRYVuFkdH0wGUvW2WbXGmrZGbQ==", 1179 | "dependencies": { 1180 | "@isaacs/cliui": "^8.0.2" 1181 | }, 1182 | "engines": { 1183 | "node": ">=14" 1184 | }, 1185 | "funding": { 1186 | "url": "https://github.com/sponsors/isaacs" 1187 | }, 1188 | "optionalDependencies": { 1189 | "@pkgjs/parseargs": "^0.11.0" 1190 | } 1191 | }, 1192 | "node_modules/jiti": { 1193 | "version": "1.21.0", 1194 | "resolved": "https://registry.npmjs.org/jiti/-/jiti-1.21.0.tgz", 1195 | "integrity": "sha512-gFqAIbuKyyso/3G2qhiO2OM6shY6EPP/R0+mkDbyspxKazh8BXDC5FiFsUjlczgdNz/vfra0da2y+aHrusLG/Q==", 1196 | "bin": { 1197 | "jiti": "bin/jiti.js" 1198 | } 1199 | }, 1200 | "node_modules/js-tokens": { 1201 | "version": "4.0.0", 1202 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1203 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==" 1204 | }, 1205 | "node_modules/kareem": { 1206 | "version": "2.6.3", 1207 | "resolved": "https://registry.npmjs.org/kareem/-/kareem-2.6.3.tgz", 1208 | "integrity": "sha512-C3iHfuGUXK2u8/ipq9LfjFfXFxAZMQJJq7vLS45r3D9Y2xQ/m4S8zaR4zMLFWh9AsNPXmcFfUDhTEO8UIC/V6Q==", 1209 | "engines": { 1210 | "node": ">=12.0.0" 1211 | } 1212 | }, 1213 | "node_modules/lilconfig": { 1214 | "version": "2.1.0", 1215 | "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-2.1.0.tgz", 1216 | "integrity": "sha512-utWOt/GHzuUxnLKxB6dk81RoOeoNeHgbrXiuGk4yyF5qlRz+iIVWu56E2fqGHFrXz0QNUhLB/8nKqvRH66JKGQ==", 1217 | "engines": { 1218 | "node": ">=10" 1219 | } 1220 | }, 1221 | "node_modules/lines-and-columns": { 1222 | "version": "1.2.4", 1223 | "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz", 1224 | "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==" 1225 | }, 1226 | "node_modules/loose-envify": { 1227 | "version": "1.4.0", 1228 | "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", 1229 | "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", 1230 | "dependencies": { 1231 | "js-tokens": "^3.0.0 || ^4.0.0" 1232 | }, 1233 | "bin": { 1234 | "loose-envify": "cli.js" 1235 | } 1236 | }, 1237 | "node_modules/lru-cache": { 1238 | "version": "10.2.2", 1239 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-10.2.2.tgz", 1240 | "integrity": "sha512-9hp3Vp2/hFQUiIwKo8XCeFVnrg8Pk3TYNPIR7tJADKi5YfcF7vEaK7avFHTlSy3kOKYaJQaalfEo6YuXdceBOQ==", 1241 | "engines": { 1242 | "node": "14 || >=16.14" 1243 | } 1244 | }, 1245 | "node_modules/lucide-react": { 1246 | "version": "0.378.0", 1247 | "resolved": "https://registry.npmjs.org/lucide-react/-/lucide-react-0.378.0.tgz", 1248 | "integrity": "sha512-u6EPU8juLUk9ytRcyapkWI18epAv3RU+6+TC23ivjR0e+glWKBobFeSgRwOIJihzktILQuy6E0E80P2jVTDR5g==", 1249 | "peerDependencies": { 1250 | "react": "^16.5.1 || ^17.0.0 || ^18.0.0" 1251 | } 1252 | }, 1253 | "node_modules/memory-pager": { 1254 | "version": "1.5.0", 1255 | "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.5.0.tgz", 1256 | "integrity": "sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg==" 1257 | }, 1258 | "node_modules/merge2": { 1259 | "version": "1.4.1", 1260 | "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", 1261 | "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", 1262 | "engines": { 1263 | "node": ">= 8" 1264 | } 1265 | }, 1266 | "node_modules/micromatch": { 1267 | "version": "4.0.5", 1268 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz", 1269 | "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==", 1270 | "dependencies": { 1271 | "braces": "^3.0.2", 1272 | "picomatch": "^2.3.1" 1273 | }, 1274 | "engines": { 1275 | "node": ">=8.6" 1276 | } 1277 | }, 1278 | "node_modules/minimatch": { 1279 | "version": "9.0.4", 1280 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.4.tgz", 1281 | "integrity": "sha512-KqWh+VchfxcMNRAJjj2tnsSJdNbHsVgnkBhTNrW7AjVo6OvLtxw8zfT9oLw1JSohlFzJ8jCoTgaoXvJ+kHt6fw==", 1282 | "dependencies": { 1283 | "brace-expansion": "^2.0.1" 1284 | }, 1285 | "engines": { 1286 | "node": ">=16 || 14 >=14.17" 1287 | }, 1288 | "funding": { 1289 | "url": "https://github.com/sponsors/isaacs" 1290 | } 1291 | }, 1292 | "node_modules/minipass": { 1293 | "version": "7.0.4", 1294 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-7.0.4.tgz", 1295 | "integrity": "sha512-jYofLM5Dam9279rdkWzqHozUo4ybjdZmCsDHePy5V/PbBcVMiSZR97gmAy45aqi8CK1lG2ECd356FU86avfwUQ==", 1296 | "engines": { 1297 | "node": ">=16 || 14 >=14.17" 1298 | } 1299 | }, 1300 | "node_modules/mongodb": { 1301 | "version": "6.5.0", 1302 | "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-6.5.0.tgz", 1303 | "integrity": "sha512-Fozq68InT+JKABGLqctgtb8P56pRrJFkbhW0ux+x1mdHeyinor8oNzJqwLjV/t5X5nJGfTlluxfyMnOXNggIUA==", 1304 | "dependencies": { 1305 | "@mongodb-js/saslprep": "^1.1.5", 1306 | "bson": "^6.4.0", 1307 | "mongodb-connection-string-url": "^3.0.0" 1308 | }, 1309 | "engines": { 1310 | "node": ">=16.20.1" 1311 | }, 1312 | "peerDependencies": { 1313 | "@aws-sdk/credential-providers": "^3.188.0", 1314 | "@mongodb-js/zstd": "^1.1.0", 1315 | "gcp-metadata": "^5.2.0", 1316 | "kerberos": "^2.0.1", 1317 | "mongodb-client-encryption": ">=6.0.0 <7", 1318 | "snappy": "^7.2.2", 1319 | "socks": "^2.7.1" 1320 | }, 1321 | "peerDependenciesMeta": { 1322 | "@aws-sdk/credential-providers": { 1323 | "optional": true 1324 | }, 1325 | "@mongodb-js/zstd": { 1326 | "optional": true 1327 | }, 1328 | "gcp-metadata": { 1329 | "optional": true 1330 | }, 1331 | "kerberos": { 1332 | "optional": true 1333 | }, 1334 | "mongodb-client-encryption": { 1335 | "optional": true 1336 | }, 1337 | "snappy": { 1338 | "optional": true 1339 | }, 1340 | "socks": { 1341 | "optional": true 1342 | } 1343 | } 1344 | }, 1345 | "node_modules/mongodb-connection-string-url": { 1346 | "version": "3.0.0", 1347 | "resolved": "https://registry.npmjs.org/mongodb-connection-string-url/-/mongodb-connection-string-url-3.0.0.tgz", 1348 | "integrity": "sha512-t1Vf+m1I5hC2M5RJx/7AtxgABy1cZmIPQRMXw+gEIPn/cZNF3Oiy+l0UIypUwVB5trcWHq3crg2g3uAR9aAwsQ==", 1349 | "dependencies": { 1350 | "@types/whatwg-url": "^11.0.2", 1351 | "whatwg-url": "^13.0.0" 1352 | } 1353 | }, 1354 | "node_modules/mongoose": { 1355 | "version": "8.3.3", 1356 | "resolved": "https://registry.npmjs.org/mongoose/-/mongoose-8.3.3.tgz", 1357 | "integrity": "sha512-3kSk0db9DM2tLttCdS6WNRqewPleamFEa4Vz/Qldc0dB4Zow/FiZxb9GExHTJjBZQ9T2xiGleQ3GzRrES3hhsA==", 1358 | "dependencies": { 1359 | "bson": "^6.5.0", 1360 | "kareem": "2.6.3", 1361 | "mongodb": "6.5.0", 1362 | "mpath": "0.9.0", 1363 | "mquery": "5.0.0", 1364 | "ms": "2.1.3", 1365 | "sift": "16.0.1" 1366 | }, 1367 | "engines": { 1368 | "node": ">=16.20.1" 1369 | }, 1370 | "funding": { 1371 | "type": "opencollective", 1372 | "url": "https://opencollective.com/mongoose" 1373 | } 1374 | }, 1375 | "node_modules/mpath": { 1376 | "version": "0.9.0", 1377 | "resolved": "https://registry.npmjs.org/mpath/-/mpath-0.9.0.tgz", 1378 | "integrity": "sha512-ikJRQTk8hw5DEoFVxHG1Gn9T/xcjtdnOKIU1JTmGjZZlg9LST2mBLmcX3/ICIbgJydT2GOc15RnNy5mHmzfSew==", 1379 | "engines": { 1380 | "node": ">=4.0.0" 1381 | } 1382 | }, 1383 | "node_modules/mquery": { 1384 | "version": "5.0.0", 1385 | "resolved": "https://registry.npmjs.org/mquery/-/mquery-5.0.0.tgz", 1386 | "integrity": "sha512-iQMncpmEK8R8ncT8HJGsGc9Dsp8xcgYMVSbs5jgnm1lFHTZqMJTUWTDx1LBO8+mK3tPNZWFLBghQEIOULSTHZg==", 1387 | "dependencies": { 1388 | "debug": "4.x" 1389 | }, 1390 | "engines": { 1391 | "node": ">=14.0.0" 1392 | } 1393 | }, 1394 | "node_modules/ms": { 1395 | "version": "2.1.3", 1396 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1397 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 1398 | }, 1399 | "node_modules/mz": { 1400 | "version": "2.7.0", 1401 | "resolved": "https://registry.npmjs.org/mz/-/mz-2.7.0.tgz", 1402 | "integrity": "sha512-z81GNO7nnYMEhrGh9LeymoE4+Yr0Wn5McHIZMK5cfQCl+NDX08sCZgUc9/6MHni9IWuFLm1Z3HTCXu2z9fN62Q==", 1403 | "dependencies": { 1404 | "any-promise": "^1.0.0", 1405 | "object-assign": "^4.0.1", 1406 | "thenify-all": "^1.0.0" 1407 | } 1408 | }, 1409 | "node_modules/nanoid": { 1410 | "version": "3.3.7", 1411 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.7.tgz", 1412 | "integrity": "sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==", 1413 | "funding": [ 1414 | { 1415 | "type": "github", 1416 | "url": "https://github.com/sponsors/ai" 1417 | } 1418 | ], 1419 | "bin": { 1420 | "nanoid": "bin/nanoid.cjs" 1421 | }, 1422 | "engines": { 1423 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" 1424 | } 1425 | }, 1426 | "node_modules/next": { 1427 | "version": "14.2.3", 1428 | "resolved": "https://registry.npmjs.org/next/-/next-14.2.3.tgz", 1429 | "integrity": "sha512-dowFkFTR8v79NPJO4QsBUtxv0g9BrS/phluVpMAt2ku7H+cbcBJlopXjkWlwxrk/xGqMemr7JkGPGemPrLLX7A==", 1430 | "dependencies": { 1431 | "@next/env": "14.2.3", 1432 | "@swc/helpers": "0.5.5", 1433 | "busboy": "1.6.0", 1434 | "caniuse-lite": "^1.0.30001579", 1435 | "graceful-fs": "^4.2.11", 1436 | "postcss": "8.4.31", 1437 | "styled-jsx": "5.1.1" 1438 | }, 1439 | "bin": { 1440 | "next": "dist/bin/next" 1441 | }, 1442 | "engines": { 1443 | "node": ">=18.17.0" 1444 | }, 1445 | "optionalDependencies": { 1446 | "@next/swc-darwin-arm64": "14.2.3", 1447 | "@next/swc-darwin-x64": "14.2.3", 1448 | "@next/swc-linux-arm64-gnu": "14.2.3", 1449 | "@next/swc-linux-arm64-musl": "14.2.3", 1450 | "@next/swc-linux-x64-gnu": "14.2.3", 1451 | "@next/swc-linux-x64-musl": "14.2.3", 1452 | "@next/swc-win32-arm64-msvc": "14.2.3", 1453 | "@next/swc-win32-ia32-msvc": "14.2.3", 1454 | "@next/swc-win32-x64-msvc": "14.2.3" 1455 | }, 1456 | "peerDependencies": { 1457 | "@opentelemetry/api": "^1.1.0", 1458 | "@playwright/test": "^1.41.2", 1459 | "react": "^18.2.0", 1460 | "react-dom": "^18.2.0", 1461 | "sass": "^1.3.0" 1462 | }, 1463 | "peerDependenciesMeta": { 1464 | "@opentelemetry/api": { 1465 | "optional": true 1466 | }, 1467 | "@playwright/test": { 1468 | "optional": true 1469 | }, 1470 | "sass": { 1471 | "optional": true 1472 | } 1473 | } 1474 | }, 1475 | "node_modules/next/node_modules/postcss": { 1476 | "version": "8.4.31", 1477 | "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.31.tgz", 1478 | "integrity": "sha512-PS08Iboia9mts/2ygV3eLpY5ghnUcfLV/EXTOW1E2qYxJKGGBUtNjN76FYHnMs36RmARn41bC0AZmn+rR0OVpQ==", 1479 | "funding": [ 1480 | { 1481 | "type": "opencollective", 1482 | "url": "https://opencollective.com/postcss/" 1483 | }, 1484 | { 1485 | "type": "tidelift", 1486 | "url": "https://tidelift.com/funding/github/npm/postcss" 1487 | }, 1488 | { 1489 | "type": "github", 1490 | "url": "https://github.com/sponsors/ai" 1491 | } 1492 | ], 1493 | "dependencies": { 1494 | "nanoid": "^3.3.6", 1495 | "picocolors": "^1.0.0", 1496 | "source-map-js": "^1.0.2" 1497 | }, 1498 | "engines": { 1499 | "node": "^10 || ^12 || >=14" 1500 | } 1501 | }, 1502 | "node_modules/normalize-path": { 1503 | "version": "3.0.0", 1504 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1505 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1506 | "engines": { 1507 | "node": ">=0.10.0" 1508 | } 1509 | }, 1510 | "node_modules/object-assign": { 1511 | "version": "4.1.1", 1512 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1513 | "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==", 1514 | "engines": { 1515 | "node": ">=0.10.0" 1516 | } 1517 | }, 1518 | "node_modules/object-hash": { 1519 | "version": "3.0.0", 1520 | "resolved": "https://registry.npmjs.org/object-hash/-/object-hash-3.0.0.tgz", 1521 | "integrity": "sha512-RSn9F68PjH9HqtltsSnqYC1XXoWe9Bju5+213R98cNGttag9q9yAOTzdbsqvIa7aNm5WffBZFpWYr2aWrklWAw==", 1522 | "engines": { 1523 | "node": ">= 6" 1524 | } 1525 | }, 1526 | "node_modules/path-key": { 1527 | "version": "3.1.1", 1528 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1529 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1530 | "engines": { 1531 | "node": ">=8" 1532 | } 1533 | }, 1534 | "node_modules/path-parse": { 1535 | "version": "1.0.7", 1536 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 1537 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==" 1538 | }, 1539 | "node_modules/path-scurry": { 1540 | "version": "1.10.2", 1541 | "resolved": "https://registry.npmjs.org/path-scurry/-/path-scurry-1.10.2.tgz", 1542 | "integrity": "sha512-7xTavNy5RQXnsjANvVvMkEjvloOinkAjv/Z6Ildz9v2RinZ4SBKTWFOVRbaF8p0vpHnyjV/UwNDdKuUv6M5qcA==", 1543 | "dependencies": { 1544 | "lru-cache": "^10.2.0", 1545 | "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0" 1546 | }, 1547 | "engines": { 1548 | "node": ">=16 || 14 >=14.17" 1549 | }, 1550 | "funding": { 1551 | "url": "https://github.com/sponsors/isaacs" 1552 | } 1553 | }, 1554 | "node_modules/picocolors": { 1555 | "version": "1.0.0", 1556 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", 1557 | "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==" 1558 | }, 1559 | "node_modules/picomatch": { 1560 | "version": "2.3.1", 1561 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 1562 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 1563 | "engines": { 1564 | "node": ">=8.6" 1565 | }, 1566 | "funding": { 1567 | "url": "https://github.com/sponsors/jonschlinkert" 1568 | } 1569 | }, 1570 | "node_modules/pify": { 1571 | "version": "2.3.0", 1572 | "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", 1573 | "integrity": "sha512-udgsAY+fTnvv7kI7aaxbqwWNb0AHiB0qBO89PZKPkoTmGOgdbrHDKD+0B2X4uTfJ/FT1R09r9gTsjUjNJotuog==", 1574 | "engines": { 1575 | "node": ">=0.10.0" 1576 | } 1577 | }, 1578 | "node_modules/pirates": { 1579 | "version": "4.0.6", 1580 | "resolved": "https://registry.npmjs.org/pirates/-/pirates-4.0.6.tgz", 1581 | "integrity": "sha512-saLsH7WeYYPiD25LDuLRRY/i+6HaPYr6G1OUlN39otzkSTxKnubR9RTxS3/Kk50s1g2JTgFwWQDQyplC5/SHZg==", 1582 | "engines": { 1583 | "node": ">= 6" 1584 | } 1585 | }, 1586 | "node_modules/postcss": { 1587 | "version": "8.4.38", 1588 | "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.38.tgz", 1589 | "integrity": "sha512-Wglpdk03BSfXkHoQa3b/oulrotAkwrlLDRSOb9D0bN86FdRyE9lppSp33aHNPgBa0JKCoB+drFLZkQoRRYae5A==", 1590 | "funding": [ 1591 | { 1592 | "type": "opencollective", 1593 | "url": "https://opencollective.com/postcss/" 1594 | }, 1595 | { 1596 | "type": "tidelift", 1597 | "url": "https://tidelift.com/funding/github/npm/postcss" 1598 | }, 1599 | { 1600 | "type": "github", 1601 | "url": "https://github.com/sponsors/ai" 1602 | } 1603 | ], 1604 | "dependencies": { 1605 | "nanoid": "^3.3.7", 1606 | "picocolors": "^1.0.0", 1607 | "source-map-js": "^1.2.0" 1608 | }, 1609 | "engines": { 1610 | "node": "^10 || ^12 || >=14" 1611 | } 1612 | }, 1613 | "node_modules/postcss-import": { 1614 | "version": "15.1.0", 1615 | "resolved": "https://registry.npmjs.org/postcss-import/-/postcss-import-15.1.0.tgz", 1616 | "integrity": "sha512-hpr+J05B2FVYUAXHeK1YyI267J/dDDhMU6B6civm8hSY1jYJnBXxzKDKDswzJmtLHryrjhnDjqqp/49t8FALew==", 1617 | "dependencies": { 1618 | "postcss-value-parser": "^4.0.0", 1619 | "read-cache": "^1.0.0", 1620 | "resolve": "^1.1.7" 1621 | }, 1622 | "engines": { 1623 | "node": ">=14.0.0" 1624 | }, 1625 | "peerDependencies": { 1626 | "postcss": "^8.0.0" 1627 | } 1628 | }, 1629 | "node_modules/postcss-js": { 1630 | "version": "4.0.1", 1631 | "resolved": "https://registry.npmjs.org/postcss-js/-/postcss-js-4.0.1.tgz", 1632 | "integrity": "sha512-dDLF8pEO191hJMtlHFPRa8xsizHaM82MLfNkUHdUtVEV3tgTp5oj+8qbEqYM57SLfc74KSbw//4SeJma2LRVIw==", 1633 | "dependencies": { 1634 | "camelcase-css": "^2.0.1" 1635 | }, 1636 | "engines": { 1637 | "node": "^12 || ^14 || >= 16" 1638 | }, 1639 | "funding": { 1640 | "type": "opencollective", 1641 | "url": "https://opencollective.com/postcss/" 1642 | }, 1643 | "peerDependencies": { 1644 | "postcss": "^8.4.21" 1645 | } 1646 | }, 1647 | "node_modules/postcss-load-config": { 1648 | "version": "4.0.2", 1649 | "resolved": "https://registry.npmjs.org/postcss-load-config/-/postcss-load-config-4.0.2.tgz", 1650 | "integrity": "sha512-bSVhyJGL00wMVoPUzAVAnbEoWyqRxkjv64tUl427SKnPrENtq6hJwUojroMz2VB+Q1edmi4IfrAPpami5VVgMQ==", 1651 | "funding": [ 1652 | { 1653 | "type": "opencollective", 1654 | "url": "https://opencollective.com/postcss/" 1655 | }, 1656 | { 1657 | "type": "github", 1658 | "url": "https://github.com/sponsors/ai" 1659 | } 1660 | ], 1661 | "dependencies": { 1662 | "lilconfig": "^3.0.0", 1663 | "yaml": "^2.3.4" 1664 | }, 1665 | "engines": { 1666 | "node": ">= 14" 1667 | }, 1668 | "peerDependencies": { 1669 | "postcss": ">=8.0.9", 1670 | "ts-node": ">=9.0.0" 1671 | }, 1672 | "peerDependenciesMeta": { 1673 | "postcss": { 1674 | "optional": true 1675 | }, 1676 | "ts-node": { 1677 | "optional": true 1678 | } 1679 | } 1680 | }, 1681 | "node_modules/postcss-load-config/node_modules/lilconfig": { 1682 | "version": "3.1.1", 1683 | "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-3.1.1.tgz", 1684 | "integrity": "sha512-O18pf7nyvHTckunPWCV1XUNXU1piu01y2b7ATJ0ppkUkk8ocqVWBrYjJBCwHDjD/ZWcfyrA0P4gKhzWGi5EINQ==", 1685 | "engines": { 1686 | "node": ">=14" 1687 | }, 1688 | "funding": { 1689 | "url": "https://github.com/sponsors/antonk52" 1690 | } 1691 | }, 1692 | "node_modules/postcss-nested": { 1693 | "version": "6.0.1", 1694 | "resolved": "https://registry.npmjs.org/postcss-nested/-/postcss-nested-6.0.1.tgz", 1695 | "integrity": "sha512-mEp4xPMi5bSWiMbsgoPfcP74lsWLHkQbZc3sY+jWYd65CUwXrUaTp0fmNpa01ZcETKlIgUdFN/MpS2xZtqL9dQ==", 1696 | "dependencies": { 1697 | "postcss-selector-parser": "^6.0.11" 1698 | }, 1699 | "engines": { 1700 | "node": ">=12.0" 1701 | }, 1702 | "funding": { 1703 | "type": "opencollective", 1704 | "url": "https://opencollective.com/postcss/" 1705 | }, 1706 | "peerDependencies": { 1707 | "postcss": "^8.2.14" 1708 | } 1709 | }, 1710 | "node_modules/postcss-selector-parser": { 1711 | "version": "6.0.16", 1712 | "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-6.0.16.tgz", 1713 | "integrity": "sha512-A0RVJrX+IUkVZbW3ClroRWurercFhieevHB38sr2+l9eUClMqome3LmEmnhlNy+5Mr2EYN6B2Kaw9wYdd+VHiw==", 1714 | "dependencies": { 1715 | "cssesc": "^3.0.0", 1716 | "util-deprecate": "^1.0.2" 1717 | }, 1718 | "engines": { 1719 | "node": ">=4" 1720 | } 1721 | }, 1722 | "node_modules/postcss-value-parser": { 1723 | "version": "4.2.0", 1724 | "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-4.2.0.tgz", 1725 | "integrity": "sha512-1NNCs6uurfkVbeXG4S8JFT9t19m45ICnif8zWLd5oPSZ50QnwMfK+H3jv408d4jw/7Bttv5axS5IiHoLaVNHeQ==" 1726 | }, 1727 | "node_modules/punycode": { 1728 | "version": "2.3.1", 1729 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", 1730 | "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", 1731 | "engines": { 1732 | "node": ">=6" 1733 | } 1734 | }, 1735 | "node_modules/queue-microtask": { 1736 | "version": "1.2.3", 1737 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 1738 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 1739 | "funding": [ 1740 | { 1741 | "type": "github", 1742 | "url": "https://github.com/sponsors/feross" 1743 | }, 1744 | { 1745 | "type": "patreon", 1746 | "url": "https://www.patreon.com/feross" 1747 | }, 1748 | { 1749 | "type": "consulting", 1750 | "url": "https://feross.org/support" 1751 | } 1752 | ] 1753 | }, 1754 | "node_modules/react": { 1755 | "version": "18.3.1", 1756 | "resolved": "https://registry.npmjs.org/react/-/react-18.3.1.tgz", 1757 | "integrity": "sha512-wS+hAgJShR0KhEvPJArfuPVN1+Hz1t0Y6n5jLrGQbkb4urgPE/0Rve+1kMB1v/oWgHgm4WIcV+i7F2pTVj+2iQ==", 1758 | "dependencies": { 1759 | "loose-envify": "^1.1.0" 1760 | }, 1761 | "engines": { 1762 | "node": ">=0.10.0" 1763 | } 1764 | }, 1765 | "node_modules/react-dom": { 1766 | "version": "18.3.1", 1767 | "resolved": "https://registry.npmjs.org/react-dom/-/react-dom-18.3.1.tgz", 1768 | "integrity": "sha512-5m4nQKp+rZRb09LNH59GM4BxTh9251/ylbKIbpe7TpGxfJ+9kv6BLkLBXIjjspbgbnIBNqlI23tRnTWT0snUIw==", 1769 | "dependencies": { 1770 | "loose-envify": "^1.1.0", 1771 | "scheduler": "^0.23.2" 1772 | }, 1773 | "peerDependencies": { 1774 | "react": "^18.3.1" 1775 | } 1776 | }, 1777 | "node_modules/react-remove-scroll": { 1778 | "version": "2.5.5", 1779 | "resolved": "https://registry.npmjs.org/react-remove-scroll/-/react-remove-scroll-2.5.5.tgz", 1780 | "integrity": "sha512-ImKhrzJJsyXJfBZ4bzu8Bwpka14c/fQt0k+cyFp/PBhTfyDnU5hjOtM4AG/0AMyy8oKzOTR0lDgJIM7pYXI0kw==", 1781 | "dependencies": { 1782 | "react-remove-scroll-bar": "^2.3.3", 1783 | "react-style-singleton": "^2.2.1", 1784 | "tslib": "^2.1.0", 1785 | "use-callback-ref": "^1.3.0", 1786 | "use-sidecar": "^1.1.2" 1787 | }, 1788 | "engines": { 1789 | "node": ">=10" 1790 | }, 1791 | "peerDependencies": { 1792 | "@types/react": "^16.8.0 || ^17.0.0 || ^18.0.0", 1793 | "react": "^16.8.0 || ^17.0.0 || ^18.0.0" 1794 | }, 1795 | "peerDependenciesMeta": { 1796 | "@types/react": { 1797 | "optional": true 1798 | } 1799 | } 1800 | }, 1801 | "node_modules/react-remove-scroll-bar": { 1802 | "version": "2.3.6", 1803 | "resolved": "https://registry.npmjs.org/react-remove-scroll-bar/-/react-remove-scroll-bar-2.3.6.tgz", 1804 | "integrity": "sha512-DtSYaao4mBmX+HDo5YWYdBWQwYIQQshUV/dVxFxK+KM26Wjwp1gZ6rv6OC3oujI6Bfu6Xyg3TwK533AQutsn/g==", 1805 | "dependencies": { 1806 | "react-style-singleton": "^2.2.1", 1807 | "tslib": "^2.0.0" 1808 | }, 1809 | "engines": { 1810 | "node": ">=10" 1811 | }, 1812 | "peerDependencies": { 1813 | "@types/react": "^16.8.0 || ^17.0.0 || ^18.0.0", 1814 | "react": "^16.8.0 || ^17.0.0 || ^18.0.0" 1815 | }, 1816 | "peerDependenciesMeta": { 1817 | "@types/react": { 1818 | "optional": true 1819 | } 1820 | } 1821 | }, 1822 | "node_modules/react-style-singleton": { 1823 | "version": "2.2.1", 1824 | "resolved": "https://registry.npmjs.org/react-style-singleton/-/react-style-singleton-2.2.1.tgz", 1825 | "integrity": "sha512-ZWj0fHEMyWkHzKYUr2Bs/4zU6XLmq9HsgBURm7g5pAVfyn49DgUiNgY2d4lXRlYSiCif9YBGpQleewkcqddc7g==", 1826 | "dependencies": { 1827 | "get-nonce": "^1.0.0", 1828 | "invariant": "^2.2.4", 1829 | "tslib": "^2.0.0" 1830 | }, 1831 | "engines": { 1832 | "node": ">=10" 1833 | }, 1834 | "peerDependencies": { 1835 | "@types/react": "^16.8.0 || ^17.0.0 || ^18.0.0", 1836 | "react": "^16.8.0 || ^17.0.0 || ^18.0.0" 1837 | }, 1838 | "peerDependenciesMeta": { 1839 | "@types/react": { 1840 | "optional": true 1841 | } 1842 | } 1843 | }, 1844 | "node_modules/read-cache": { 1845 | "version": "1.0.0", 1846 | "resolved": "https://registry.npmjs.org/read-cache/-/read-cache-1.0.0.tgz", 1847 | "integrity": "sha512-Owdv/Ft7IjOgm/i0xvNDZ1LrRANRfew4b2prF3OWMQLxLfu3bS8FVhCsrSCMK4lR56Y9ya+AThoTpDCTxCmpRA==", 1848 | "dependencies": { 1849 | "pify": "^2.3.0" 1850 | } 1851 | }, 1852 | "node_modules/readdirp": { 1853 | "version": "3.6.0", 1854 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1855 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1856 | "dependencies": { 1857 | "picomatch": "^2.2.1" 1858 | }, 1859 | "engines": { 1860 | "node": ">=8.10.0" 1861 | } 1862 | }, 1863 | "node_modules/regenerator-runtime": { 1864 | "version": "0.14.1", 1865 | "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.14.1.tgz", 1866 | "integrity": "sha512-dYnhHh0nJoMfnkZs6GmmhFknAGRrLznOu5nc9ML+EJxGvrx6H7teuevqVqCuPcPK//3eDrrjQhehXVx9cnkGdw==" 1867 | }, 1868 | "node_modules/resolve": { 1869 | "version": "1.22.8", 1870 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.8.tgz", 1871 | "integrity": "sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw==", 1872 | "dependencies": { 1873 | "is-core-module": "^2.13.0", 1874 | "path-parse": "^1.0.7", 1875 | "supports-preserve-symlinks-flag": "^1.0.0" 1876 | }, 1877 | "bin": { 1878 | "resolve": "bin/resolve" 1879 | }, 1880 | "funding": { 1881 | "url": "https://github.com/sponsors/ljharb" 1882 | } 1883 | }, 1884 | "node_modules/reusify": { 1885 | "version": "1.0.4", 1886 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 1887 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 1888 | "engines": { 1889 | "iojs": ">=1.0.0", 1890 | "node": ">=0.10.0" 1891 | } 1892 | }, 1893 | "node_modules/run-parallel": { 1894 | "version": "1.2.0", 1895 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 1896 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 1897 | "funding": [ 1898 | { 1899 | "type": "github", 1900 | "url": "https://github.com/sponsors/feross" 1901 | }, 1902 | { 1903 | "type": "patreon", 1904 | "url": "https://www.patreon.com/feross" 1905 | }, 1906 | { 1907 | "type": "consulting", 1908 | "url": "https://feross.org/support" 1909 | } 1910 | ], 1911 | "dependencies": { 1912 | "queue-microtask": "^1.2.2" 1913 | } 1914 | }, 1915 | "node_modules/scheduler": { 1916 | "version": "0.23.2", 1917 | "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.23.2.tgz", 1918 | "integrity": "sha512-UOShsPwz7NrMUqhR6t0hWjFduvOzbtv7toDH1/hIrfRNIDBnnBWd0CwJTGvTpngVlmwGCdP9/Zl/tVrDqcuYzQ==", 1919 | "dependencies": { 1920 | "loose-envify": "^1.1.0" 1921 | } 1922 | }, 1923 | "node_modules/shebang-command": { 1924 | "version": "2.0.0", 1925 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 1926 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 1927 | "dependencies": { 1928 | "shebang-regex": "^3.0.0" 1929 | }, 1930 | "engines": { 1931 | "node": ">=8" 1932 | } 1933 | }, 1934 | "node_modules/shebang-regex": { 1935 | "version": "3.0.0", 1936 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 1937 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 1938 | "engines": { 1939 | "node": ">=8" 1940 | } 1941 | }, 1942 | "node_modules/sift": { 1943 | "version": "16.0.1", 1944 | "resolved": "https://registry.npmjs.org/sift/-/sift-16.0.1.tgz", 1945 | "integrity": "sha512-Wv6BjQ5zbhW7VFefWusVP33T/EM0vYikCaQ2qR8yULbsilAT8/wQaXvuQ3ptGLpoKx+lihJE3y2UTgKDyyNHZQ==" 1946 | }, 1947 | "node_modules/signal-exit": { 1948 | "version": "4.1.0", 1949 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz", 1950 | "integrity": "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==", 1951 | "engines": { 1952 | "node": ">=14" 1953 | }, 1954 | "funding": { 1955 | "url": "https://github.com/sponsors/isaacs" 1956 | } 1957 | }, 1958 | "node_modules/source-map-js": { 1959 | "version": "1.2.0", 1960 | "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.2.0.tgz", 1961 | "integrity": "sha512-itJW8lvSA0TXEphiRoawsCksnlf8SyvmFzIhltqAHluXd88pkCd+cXJVHTDwdCr0IzwptSm035IHQktUu1QUMg==", 1962 | "engines": { 1963 | "node": ">=0.10.0" 1964 | } 1965 | }, 1966 | "node_modules/sparse-bitfield": { 1967 | "version": "3.0.3", 1968 | "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz", 1969 | "integrity": "sha512-kvzhi7vqKTfkh0PZU+2D2PIllw2ymqJKujUcyPMd9Y75Nv4nPbGJZXNhxsgdQab2BmlDct1YnfQCguEvHr7VsQ==", 1970 | "dependencies": { 1971 | "memory-pager": "^1.0.2" 1972 | } 1973 | }, 1974 | "node_modules/streamsearch": { 1975 | "version": "1.1.0", 1976 | "resolved": "https://registry.npmjs.org/streamsearch/-/streamsearch-1.1.0.tgz", 1977 | "integrity": "sha512-Mcc5wHehp9aXz1ax6bZUyY5afg9u2rv5cqQI3mRrYkGC8rW2hM02jWuwjtL++LS5qinSyhj2QfLyNsuc+VsExg==", 1978 | "engines": { 1979 | "node": ">=10.0.0" 1980 | } 1981 | }, 1982 | "node_modules/string-width": { 1983 | "version": "5.1.2", 1984 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-5.1.2.tgz", 1985 | "integrity": "sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA==", 1986 | "dependencies": { 1987 | "eastasianwidth": "^0.2.0", 1988 | "emoji-regex": "^9.2.2", 1989 | "strip-ansi": "^7.0.1" 1990 | }, 1991 | "engines": { 1992 | "node": ">=12" 1993 | }, 1994 | "funding": { 1995 | "url": "https://github.com/sponsors/sindresorhus" 1996 | } 1997 | }, 1998 | "node_modules/string-width-cjs": { 1999 | "name": "string-width", 2000 | "version": "4.2.3", 2001 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 2002 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 2003 | "dependencies": { 2004 | "emoji-regex": "^8.0.0", 2005 | "is-fullwidth-code-point": "^3.0.0", 2006 | "strip-ansi": "^6.0.1" 2007 | }, 2008 | "engines": { 2009 | "node": ">=8" 2010 | } 2011 | }, 2012 | "node_modules/string-width-cjs/node_modules/ansi-regex": { 2013 | "version": "5.0.1", 2014 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 2015 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 2016 | "engines": { 2017 | "node": ">=8" 2018 | } 2019 | }, 2020 | "node_modules/string-width-cjs/node_modules/emoji-regex": { 2021 | "version": "8.0.0", 2022 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 2023 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" 2024 | }, 2025 | "node_modules/string-width-cjs/node_modules/strip-ansi": { 2026 | "version": "6.0.1", 2027 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2028 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2029 | "dependencies": { 2030 | "ansi-regex": "^5.0.1" 2031 | }, 2032 | "engines": { 2033 | "node": ">=8" 2034 | } 2035 | }, 2036 | "node_modules/strip-ansi": { 2037 | "version": "7.1.0", 2038 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz", 2039 | "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==", 2040 | "dependencies": { 2041 | "ansi-regex": "^6.0.1" 2042 | }, 2043 | "engines": { 2044 | "node": ">=12" 2045 | }, 2046 | "funding": { 2047 | "url": "https://github.com/chalk/strip-ansi?sponsor=1" 2048 | } 2049 | }, 2050 | "node_modules/strip-ansi-cjs": { 2051 | "name": "strip-ansi", 2052 | "version": "6.0.1", 2053 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2054 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2055 | "dependencies": { 2056 | "ansi-regex": "^5.0.1" 2057 | }, 2058 | "engines": { 2059 | "node": ">=8" 2060 | } 2061 | }, 2062 | "node_modules/strip-ansi-cjs/node_modules/ansi-regex": { 2063 | "version": "5.0.1", 2064 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 2065 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 2066 | "engines": { 2067 | "node": ">=8" 2068 | } 2069 | }, 2070 | "node_modules/styled-jsx": { 2071 | "version": "5.1.1", 2072 | "resolved": "https://registry.npmjs.org/styled-jsx/-/styled-jsx-5.1.1.tgz", 2073 | "integrity": "sha512-pW7uC1l4mBZ8ugbiZrcIsiIvVx1UmTfw7UkC3Um2tmfUq9Bhk8IiyEIPl6F8agHgjzku6j0xQEZbfA5uSgSaCw==", 2074 | "dependencies": { 2075 | "client-only": "0.0.1" 2076 | }, 2077 | "engines": { 2078 | "node": ">= 12.0.0" 2079 | }, 2080 | "peerDependencies": { 2081 | "react": ">= 16.8.0 || 17.x.x || ^18.0.0-0" 2082 | }, 2083 | "peerDependenciesMeta": { 2084 | "@babel/core": { 2085 | "optional": true 2086 | }, 2087 | "babel-plugin-macros": { 2088 | "optional": true 2089 | } 2090 | } 2091 | }, 2092 | "node_modules/sucrase": { 2093 | "version": "3.35.0", 2094 | "resolved": "https://registry.npmjs.org/sucrase/-/sucrase-3.35.0.tgz", 2095 | "integrity": "sha512-8EbVDiu9iN/nESwxeSxDKe0dunta1GOlHufmSSXxMD2z2/tMZpDMpvXQGsc+ajGo8y2uYUmixaSRUc/QPoQ0GA==", 2096 | "dependencies": { 2097 | "@jridgewell/gen-mapping": "^0.3.2", 2098 | "commander": "^4.0.0", 2099 | "glob": "^10.3.10", 2100 | "lines-and-columns": "^1.1.6", 2101 | "mz": "^2.7.0", 2102 | "pirates": "^4.0.1", 2103 | "ts-interface-checker": "^0.1.9" 2104 | }, 2105 | "bin": { 2106 | "sucrase": "bin/sucrase", 2107 | "sucrase-node": "bin/sucrase-node" 2108 | }, 2109 | "engines": { 2110 | "node": ">=16 || 14 >=14.17" 2111 | } 2112 | }, 2113 | "node_modules/supports-preserve-symlinks-flag": { 2114 | "version": "1.0.0", 2115 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 2116 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 2117 | "engines": { 2118 | "node": ">= 0.4" 2119 | }, 2120 | "funding": { 2121 | "url": "https://github.com/sponsors/ljharb" 2122 | } 2123 | }, 2124 | "node_modules/tailwind-merge": { 2125 | "version": "2.3.0", 2126 | "resolved": "https://registry.npmjs.org/tailwind-merge/-/tailwind-merge-2.3.0.tgz", 2127 | "integrity": "sha512-vkYrLpIP+lgR0tQCG6AP7zZXCTLc1Lnv/CCRT3BqJ9CZ3ui2++GPaGb1x/ILsINIMSYqqvrpqjUFsMNLlW99EA==", 2128 | "dependencies": { 2129 | "@babel/runtime": "^7.24.1" 2130 | }, 2131 | "funding": { 2132 | "type": "github", 2133 | "url": "https://github.com/sponsors/dcastil" 2134 | } 2135 | }, 2136 | "node_modules/tailwindcss": { 2137 | "version": "3.4.3", 2138 | "resolved": "https://registry.npmjs.org/tailwindcss/-/tailwindcss-3.4.3.tgz", 2139 | "integrity": "sha512-U7sxQk/n397Bmx4JHbJx/iSOOv5G+II3f1kpLpY2QeUv5DcPdcTsYLlusZfq1NthHS1c1cZoyFmmkex1rzke0A==", 2140 | "dependencies": { 2141 | "@alloc/quick-lru": "^5.2.0", 2142 | "arg": "^5.0.2", 2143 | "chokidar": "^3.5.3", 2144 | "didyoumean": "^1.2.2", 2145 | "dlv": "^1.1.3", 2146 | "fast-glob": "^3.3.0", 2147 | "glob-parent": "^6.0.2", 2148 | "is-glob": "^4.0.3", 2149 | "jiti": "^1.21.0", 2150 | "lilconfig": "^2.1.0", 2151 | "micromatch": "^4.0.5", 2152 | "normalize-path": "^3.0.0", 2153 | "object-hash": "^3.0.0", 2154 | "picocolors": "^1.0.0", 2155 | "postcss": "^8.4.23", 2156 | "postcss-import": "^15.1.0", 2157 | "postcss-js": "^4.0.1", 2158 | "postcss-load-config": "^4.0.1", 2159 | "postcss-nested": "^6.0.1", 2160 | "postcss-selector-parser": "^6.0.11", 2161 | "resolve": "^1.22.2", 2162 | "sucrase": "^3.32.0" 2163 | }, 2164 | "bin": { 2165 | "tailwind": "lib/cli.js", 2166 | "tailwindcss": "lib/cli.js" 2167 | }, 2168 | "engines": { 2169 | "node": ">=14.0.0" 2170 | } 2171 | }, 2172 | "node_modules/tailwindcss-animate": { 2173 | "version": "1.0.7", 2174 | "resolved": "https://registry.npmjs.org/tailwindcss-animate/-/tailwindcss-animate-1.0.7.tgz", 2175 | "integrity": "sha512-bl6mpH3T7I3UFxuvDEXLxy/VuFxBk5bbzplh7tXI68mwMokNYd1t9qPBHlnyTwfa4JGC4zP516I1hYYtQ/vspA==", 2176 | "peerDependencies": { 2177 | "tailwindcss": ">=3.0.0 || insiders" 2178 | } 2179 | }, 2180 | "node_modules/thenify": { 2181 | "version": "3.3.1", 2182 | "resolved": "https://registry.npmjs.org/thenify/-/thenify-3.3.1.tgz", 2183 | "integrity": "sha512-RVZSIV5IG10Hk3enotrhvz0T9em6cyHBLkH/YAZuKqd8hRkKhSfCGIcP2KUY0EPxndzANBmNllzWPwak+bheSw==", 2184 | "dependencies": { 2185 | "any-promise": "^1.0.0" 2186 | } 2187 | }, 2188 | "node_modules/thenify-all": { 2189 | "version": "1.6.0", 2190 | "resolved": "https://registry.npmjs.org/thenify-all/-/thenify-all-1.6.0.tgz", 2191 | "integrity": "sha512-RNxQH/qI8/t3thXJDwcstUO4zeqo64+Uy/+sNVRBx4Xn2OX+OZ9oP+iJnNFqplFra2ZUVeKCSa2oVWi3T4uVmA==", 2192 | "dependencies": { 2193 | "thenify": ">= 3.1.0 < 4" 2194 | }, 2195 | "engines": { 2196 | "node": ">=0.8" 2197 | } 2198 | }, 2199 | "node_modules/to-regex-range": { 2200 | "version": "5.0.1", 2201 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 2202 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 2203 | "dependencies": { 2204 | "is-number": "^7.0.0" 2205 | }, 2206 | "engines": { 2207 | "node": ">=8.0" 2208 | } 2209 | }, 2210 | "node_modules/tr46": { 2211 | "version": "4.1.1", 2212 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-4.1.1.tgz", 2213 | "integrity": "sha512-2lv/66T7e5yNyhAAC4NaKe5nVavzuGJQVVtRYLyQ2OI8tsJ61PMLlelehb0wi2Hx6+hT/OJUWZcw8MjlSRnxvw==", 2214 | "dependencies": { 2215 | "punycode": "^2.3.0" 2216 | }, 2217 | "engines": { 2218 | "node": ">=14" 2219 | } 2220 | }, 2221 | "node_modules/ts-interface-checker": { 2222 | "version": "0.1.13", 2223 | "resolved": "https://registry.npmjs.org/ts-interface-checker/-/ts-interface-checker-0.1.13.tgz", 2224 | "integrity": "sha512-Y/arvbn+rrz3JCKl9C4kVNfTfSm2/mEp5FSz5EsZSANGPSlQrpRI5M4PKF+mJnE52jOO90PnPSc3Ur3bTQw0gA==" 2225 | }, 2226 | "node_modules/tslib": { 2227 | "version": "2.6.2", 2228 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz", 2229 | "integrity": "sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q==" 2230 | }, 2231 | "node_modules/use-callback-ref": { 2232 | "version": "1.3.2", 2233 | "resolved": "https://registry.npmjs.org/use-callback-ref/-/use-callback-ref-1.3.2.tgz", 2234 | "integrity": "sha512-elOQwe6Q8gqZgDA8mrh44qRTQqpIHDcZ3hXTLjBe1i4ph8XpNJnO+aQf3NaG+lriLopI4HMx9VjQLfPQ6vhnoA==", 2235 | "dependencies": { 2236 | "tslib": "^2.0.0" 2237 | }, 2238 | "engines": { 2239 | "node": ">=10" 2240 | }, 2241 | "peerDependencies": { 2242 | "@types/react": "^16.8.0 || ^17.0.0 || ^18.0.0", 2243 | "react": "^16.8.0 || ^17.0.0 || ^18.0.0" 2244 | }, 2245 | "peerDependenciesMeta": { 2246 | "@types/react": { 2247 | "optional": true 2248 | } 2249 | } 2250 | }, 2251 | "node_modules/use-sidecar": { 2252 | "version": "1.1.2", 2253 | "resolved": "https://registry.npmjs.org/use-sidecar/-/use-sidecar-1.1.2.tgz", 2254 | "integrity": "sha512-epTbsLuzZ7lPClpz2TyryBfztm7m+28DlEv2ZCQ3MDr5ssiwyOwGH/e5F9CkfWjJ1t4clvI58yF822/GUkjjhw==", 2255 | "dependencies": { 2256 | "detect-node-es": "^1.1.0", 2257 | "tslib": "^2.0.0" 2258 | }, 2259 | "engines": { 2260 | "node": ">=10" 2261 | }, 2262 | "peerDependencies": { 2263 | "@types/react": "^16.9.0 || ^17.0.0 || ^18.0.0", 2264 | "react": "^16.8.0 || ^17.0.0 || ^18.0.0" 2265 | }, 2266 | "peerDependenciesMeta": { 2267 | "@types/react": { 2268 | "optional": true 2269 | } 2270 | } 2271 | }, 2272 | "node_modules/util-deprecate": { 2273 | "version": "1.0.2", 2274 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 2275 | "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==" 2276 | }, 2277 | "node_modules/webidl-conversions": { 2278 | "version": "7.0.0", 2279 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-7.0.0.tgz", 2280 | "integrity": "sha512-VwddBukDzu71offAQR975unBIGqfKZpM+8ZX6ySk8nYhVoo5CYaZyzt3YBvYtRtO+aoGlqxPg/B87NGVZ/fu6g==", 2281 | "engines": { 2282 | "node": ">=12" 2283 | } 2284 | }, 2285 | "node_modules/whatwg-url": { 2286 | "version": "13.0.0", 2287 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-13.0.0.tgz", 2288 | "integrity": "sha512-9WWbymnqj57+XEuqADHrCJ2eSXzn8WXIW/YSGaZtb2WKAInQ6CHfaUUcTyyver0p8BDg5StLQq8h1vtZuwmOig==", 2289 | "dependencies": { 2290 | "tr46": "^4.1.1", 2291 | "webidl-conversions": "^7.0.0" 2292 | }, 2293 | "engines": { 2294 | "node": ">=16" 2295 | } 2296 | }, 2297 | "node_modules/which": { 2298 | "version": "2.0.2", 2299 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 2300 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 2301 | "dependencies": { 2302 | "isexe": "^2.0.0" 2303 | }, 2304 | "bin": { 2305 | "node-which": "bin/node-which" 2306 | }, 2307 | "engines": { 2308 | "node": ">= 8" 2309 | } 2310 | }, 2311 | "node_modules/wrap-ansi": { 2312 | "version": "8.1.0", 2313 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-8.1.0.tgz", 2314 | "integrity": "sha512-si7QWI6zUMq56bESFvagtmzMdGOtoxfR+Sez11Mobfc7tm+VkUckk9bW2UeffTGVUbOksxmSw0AA2gs8g71NCQ==", 2315 | "dependencies": { 2316 | "ansi-styles": "^6.1.0", 2317 | "string-width": "^5.0.1", 2318 | "strip-ansi": "^7.0.1" 2319 | }, 2320 | "engines": { 2321 | "node": ">=12" 2322 | }, 2323 | "funding": { 2324 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 2325 | } 2326 | }, 2327 | "node_modules/wrap-ansi-cjs": { 2328 | "name": "wrap-ansi", 2329 | "version": "7.0.0", 2330 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 2331 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 2332 | "dependencies": { 2333 | "ansi-styles": "^4.0.0", 2334 | "string-width": "^4.1.0", 2335 | "strip-ansi": "^6.0.0" 2336 | }, 2337 | "engines": { 2338 | "node": ">=10" 2339 | }, 2340 | "funding": { 2341 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 2342 | } 2343 | }, 2344 | "node_modules/wrap-ansi-cjs/node_modules/ansi-regex": { 2345 | "version": "5.0.1", 2346 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 2347 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 2348 | "engines": { 2349 | "node": ">=8" 2350 | } 2351 | }, 2352 | "node_modules/wrap-ansi-cjs/node_modules/ansi-styles": { 2353 | "version": "4.3.0", 2354 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 2355 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 2356 | "dependencies": { 2357 | "color-convert": "^2.0.1" 2358 | }, 2359 | "engines": { 2360 | "node": ">=8" 2361 | }, 2362 | "funding": { 2363 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 2364 | } 2365 | }, 2366 | "node_modules/wrap-ansi-cjs/node_modules/emoji-regex": { 2367 | "version": "8.0.0", 2368 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 2369 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" 2370 | }, 2371 | "node_modules/wrap-ansi-cjs/node_modules/string-width": { 2372 | "version": "4.2.3", 2373 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 2374 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 2375 | "dependencies": { 2376 | "emoji-regex": "^8.0.0", 2377 | "is-fullwidth-code-point": "^3.0.0", 2378 | "strip-ansi": "^6.0.1" 2379 | }, 2380 | "engines": { 2381 | "node": ">=8" 2382 | } 2383 | }, 2384 | "node_modules/wrap-ansi-cjs/node_modules/strip-ansi": { 2385 | "version": "6.0.1", 2386 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2387 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2388 | "dependencies": { 2389 | "ansi-regex": "^5.0.1" 2390 | }, 2391 | "engines": { 2392 | "node": ">=8" 2393 | } 2394 | }, 2395 | "node_modules/yaml": { 2396 | "version": "2.4.2", 2397 | "resolved": "https://registry.npmjs.org/yaml/-/yaml-2.4.2.tgz", 2398 | "integrity": "sha512-B3VqDZ+JAg1nZpaEmWtTXUlBneoGx6CPM9b0TENK6aoSu5t73dItudwdgmi6tHlIZZId4dZ9skcAQ2UbcyAeVA==", 2399 | "bin": { 2400 | "yaml": "bin.mjs" 2401 | }, 2402 | "engines": { 2403 | "node": ">= 14" 2404 | } 2405 | } 2406 | } 2407 | } 2408 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "next-js-server-actions-2024", 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 | "@radix-ui/react-dialog": "^1.0.5", 13 | "@radix-ui/react-label": "^2.0.2", 14 | "@radix-ui/react-slot": "^1.0.2", 15 | "class-variance-authority": "^0.7.0", 16 | "clsx": "^2.1.1", 17 | "lucide-react": "^0.378.0", 18 | "mongoose": "^8.3.3", 19 | "next": "14.2.3", 20 | "react": "^18", 21 | "react-dom": "^18", 22 | "tailwind-merge": "^2.3.0", 23 | "tailwindcss-animate": "^1.0.7" 24 | }, 25 | "devDependencies": { 26 | "postcss": "^8", 27 | "tailwindcss": "^3.4.1" 28 | } 29 | } 30 | -------------------------------------------------------------------------------- /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 | -------------------------------------------------------------------------------- /src/actions/index.js: -------------------------------------------------------------------------------- 1 | "use server"; 2 | 3 | import connectToDB from "@/database"; 4 | import User from "@/models/user"; 5 | import { revalidatePath } from "next/cache"; 6 | 7 | //add new user action 8 | 9 | export async function addNewUserAction(formData, pathToRevalidate) { 10 | await connectToDB(); 11 | 12 | try { 13 | //validate data using joi/ other packages you can use 14 | 15 | const newlyCreatedUser = await User.create(formData); 16 | if (newlyCreatedUser) { 17 | revalidatePath(pathToRevalidate); 18 | return { 19 | success: true, 20 | message: "User added successfully", 21 | }; 22 | } else { 23 | return { 24 | success: false, 25 | message: "Some error occured! Please try again", 26 | }; 27 | } 28 | } catch (error) { 29 | console.log(error); 30 | return { 31 | success: false, 32 | message: "Some error occured! Please try again", 33 | }; 34 | } 35 | } 36 | 37 | //fetch users actions 38 | export async function fetchUsersAction() { 39 | await connectToDB(); 40 | try { 41 | const listOfUsers = await User.find({}); 42 | if (listOfUsers) { 43 | return { 44 | success: true, 45 | data: JSON.parse(JSON.stringify(listOfUsers)), 46 | }; 47 | } else { 48 | return { 49 | success: false, 50 | message: "Some error occured! Please try again", 51 | }; 52 | } 53 | } catch (error) { 54 | console.log(error); 55 | return { 56 | success: false, 57 | message: "Some error occured! Please try again", 58 | }; 59 | } 60 | } 61 | 62 | //edit a user action 63 | export async function editUserAction( 64 | currentUserID, 65 | formData, 66 | pathToRevalidate 67 | ) { 68 | await connectToDB(); 69 | 70 | try { 71 | const { firstName, lastName, email, address } = formData; 72 | 73 | const updatedUser = await User.findOneAndUpdate( 74 | { 75 | _id: currentUserID, 76 | }, 77 | { firstName, email, lastName, address }, 78 | { new: true } 79 | ); 80 | if (updatedUser) { 81 | revalidatePath(pathToRevalidate); 82 | return { 83 | success: true, 84 | message: "User updated successfully", 85 | }; 86 | } else { 87 | return { 88 | success: false, 89 | message: "Not able to update the user! Please try again", 90 | }; 91 | } 92 | } catch (error) { 93 | console.log(error); 94 | return { 95 | success: false, 96 | message: "Some error occured! Please try again", 97 | }; 98 | } 99 | } 100 | 101 | //delete a user action 102 | 103 | export async function deleteUserAction(currentUserID, pathToRevalidate) { 104 | await connectToDB(); 105 | try { 106 | const deletedUser = await User.findByIdAndDelete(currentUserID); 107 | 108 | if (deletedUser) { 109 | revalidatePath(pathToRevalidate); 110 | return { 111 | success: true, 112 | message: "User deleted successfully", 113 | }; 114 | } else { 115 | return { 116 | success: false, 117 | message: "Not able perform delete operation! Please try again later", 118 | }; 119 | } 120 | } catch (error) { 121 | console.log(error); 122 | return { 123 | success: false, 124 | message: "Some error occured! Please try again", 125 | }; 126 | } 127 | } 128 | -------------------------------------------------------------------------------- /src/app/favicon.ico: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/sangammukherjee/nextjs-server-actions-2024/2bd1dd3b64b1a803165a17abac87f5d2e28d620a/src/app/favicon.ico -------------------------------------------------------------------------------- /src/app/globals.css: -------------------------------------------------------------------------------- 1 | @tailwind base; 2 | @tailwind components; 3 | @tailwind utilities; 4 | 5 | @layer base { 6 | :root { 7 | --background: 0 0% 100%; 8 | --foreground: 222.2 84% 4.9%; 9 | 10 | --card: 0 0% 100%; 11 | --card-foreground: 222.2 84% 4.9%; 12 | 13 | --popover: 0 0% 100%; 14 | --popover-foreground: 222.2 84% 4.9%; 15 | 16 | --primary: 222.2 47.4% 11.2%; 17 | --primary-foreground: 210 40% 98%; 18 | 19 | --secondary: 210 40% 96.1%; 20 | --secondary-foreground: 222.2 47.4% 11.2%; 21 | 22 | --muted: 210 40% 96.1%; 23 | --muted-foreground: 215.4 16.3% 46.9%; 24 | 25 | --accent: 210 40% 96.1%; 26 | --accent-foreground: 222.2 47.4% 11.2%; 27 | 28 | --destructive: 0 84.2% 60.2%; 29 | --destructive-foreground: 210 40% 98%; 30 | 31 | --border: 214.3 31.8% 91.4%; 32 | --input: 214.3 31.8% 91.4%; 33 | --ring: 222.2 84% 4.9%; 34 | 35 | --radius: 0.5rem; 36 | } 37 | 38 | .dark { 39 | --background: 222.2 84% 4.9%; 40 | --foreground: 210 40% 98%; 41 | 42 | --card: 222.2 84% 4.9%; 43 | --card-foreground: 210 40% 98%; 44 | 45 | --popover: 222.2 84% 4.9%; 46 | --popover-foreground: 210 40% 98%; 47 | 48 | --primary: 210 40% 98%; 49 | --primary-foreground: 222.2 47.4% 11.2%; 50 | 51 | --secondary: 217.2 32.6% 17.5%; 52 | --secondary-foreground: 210 40% 98%; 53 | 54 | --muted: 217.2 32.6% 17.5%; 55 | --muted-foreground: 215 20.2% 65.1%; 56 | 57 | --accent: 217.2 32.6% 17.5%; 58 | --accent-foreground: 210 40% 98%; 59 | 60 | --destructive: 0 62.8% 30.6%; 61 | --destructive-foreground: 210 40% 98%; 62 | 63 | --border: 217.2 32.6% 17.5%; 64 | --input: 217.2 32.6% 17.5%; 65 | --ring: 212.7 26.8% 83.9%; 66 | } 67 | } 68 | 69 | @layer base { 70 | * { 71 | @apply border-border; 72 | } 73 | body { 74 | @apply bg-background text-foreground; 75 | } 76 | } -------------------------------------------------------------------------------- /src/app/layout.js: -------------------------------------------------------------------------------- 1 | import { Inter } from "next/font/google"; 2 | import "./globals.css"; 3 | import CommonLayout from "@/components/common-layout"; 4 | 5 | const inter = Inter({ subsets: ["latin"] }); 6 | 7 | export const metadata = { 8 | title: "Create Next App", 9 | description: "Generated by create next app", 10 | }; 11 | 12 | export default function RootLayout({ children }) { 13 | return ( 14 | 15 | 16 | {children} 17 | 18 | 19 | ); 20 | } 21 | -------------------------------------------------------------------------------- /src/app/page.js: -------------------------------------------------------------------------------- 1 | import Image from "next/image"; 2 | 3 | export default function Home() { 4 | return ( 5 |
6 |

Server Actions

7 |
8 | ); 9 | } 10 | -------------------------------------------------------------------------------- /src/app/theory/client-page-example/page.js: -------------------------------------------------------------------------------- 1 | "use client"; 2 | 3 | import { fetchListOfProducts } from "@/actions"; 4 | import { useEffect, useState } from "react"; 5 | 6 | function ClientPageExample() { 7 | const [products, setProducts] = useState([]); 8 | const [loading, setLoading] = useState(true); 9 | 10 | async function getListOfProducts() { 11 | setLoading(true); 12 | const data = await fetchListOfProducts(); 13 | console.log(data); 14 | if (data) { 15 | setProducts(data); 16 | setLoading(false); 17 | } 18 | } 19 | 20 | useEffect(() => { 21 | getListOfProducts(); 22 | }, []); 23 | 24 | if (loading) return

Loading data! Please wait

; 25 | 26 | return ( 27 |
28 |

Client page server actions example

29 | 36 |
37 | ); 38 | } 39 | 40 | export default ClientPageExample; 41 | -------------------------------------------------------------------------------- /src/app/theory/server-page-example/page.js: -------------------------------------------------------------------------------- 1 | import { fetchListOfProducts } from "@/actions"; 2 | 3 | async function ServerActionsExample() { 4 | const products = await fetchListOfProducts(); 5 | console.log(products); 6 | 7 | return ( 8 |
9 |

Server actions example - server components

10 | 17 |
18 | ); 19 | } 20 | 21 | export default ServerActionsExample; 22 | -------------------------------------------------------------------------------- /src/app/user-management/page.js: -------------------------------------------------------------------------------- 1 | import { fetchUsersAction } from "@/actions"; 2 | import AddNewUser from "@/components/add-new-user"; 3 | import SingleUserCard from "@/components/single-user-card"; 4 | 5 | async function UserManagement() { 6 | const getListOfUsers = await fetchUsersAction(); 7 | 8 | console.log(getListOfUsers); 9 | 10 | return ( 11 |
12 |
13 |

User Management

14 | 15 |
16 |
17 | {getListOfUsers && 18 | getListOfUsers.data && 19 | getListOfUsers.data.length > 0 ? ( 20 | getListOfUsers.data.map((userItem) => ( 21 | 22 | )) 23 | ) : ( 24 |

No users found! Please create one

25 | )} 26 |
27 |
28 | ); 29 | } 30 | 31 | export default UserManagement; 32 | -------------------------------------------------------------------------------- /src/components/add-new-user/index.js: -------------------------------------------------------------------------------- 1 | "use client"; 2 | 3 | import { addNewUserAction, editUserAction } from "@/actions"; 4 | import { Button } from "../ui/button"; 5 | import { 6 | Dialog, 7 | DialogContent, 8 | DialogFooter, 9 | DialogHeader, 10 | DialogTitle, 11 | } from "@/components/ui/dialog"; 12 | import { Input } from "@/components/ui/input"; 13 | import { Label } from "@/components/ui/label"; 14 | import { addNewUserFormControls, addNewUserFormInitialState } from "@/utils"; 15 | import { useContext, useState } from "react"; 16 | import { UserContext } from "@/context"; 17 | 18 | function AddNewUser() { 19 | const { 20 | openPopup, 21 | setOpenPopup, 22 | addNewUserFormData, 23 | setAddNewUserFormData, 24 | currentEditedID, 25 | setCurrentEditedID, 26 | } = useContext(UserContext); 27 | console.log(addNewUserFormData); 28 | 29 | function handleSaveButtonValid() { 30 | return Object.keys(addNewUserFormData).every( 31 | (key) => addNewUserFormData[key].trim() !== "" 32 | ); 33 | } 34 | 35 | async function handleAddNewUserAction() { 36 | const result = 37 | currentEditedID !== null 38 | ? await editUserAction( 39 | currentEditedID, 40 | addNewUserFormData, 41 | "/user-management" 42 | ) 43 | : await addNewUserAction(addNewUserFormData, "/user-management"); 44 | console.log(result); 45 | setOpenPopup(false); 46 | setAddNewUserFormData(addNewUserFormInitialState); 47 | setCurrentEditedID(null); 48 | } 49 | 50 | return ( 51 |
52 | 53 | { 56 | setOpenPopup(false); 57 | setAddNewUserFormData(addNewUserFormInitialState); 58 | setCurrentEditedID(null); 59 | }} 60 | > 61 | 62 | 63 | 64 | {currentEditedID !== null ? "Edit User" : "Add New User"} 65 | 66 | 67 |
68 | {addNewUserFormControls.map((controlItem) => ( 69 |
70 | 73 | 81 | setAddNewUserFormData({ 82 | ...addNewUserFormData, 83 | [controlItem.name]: event.target.value, 84 | }) 85 | } 86 | /> 87 |
88 | ))} 89 | 90 | 97 | 98 |
99 |
100 |
101 |
102 | ); 103 | } 104 | 105 | export default AddNewUser; 106 | -------------------------------------------------------------------------------- /src/components/common-layout/index.js: -------------------------------------------------------------------------------- 1 | "use client"; 2 | 3 | import UserState from "@/context"; 4 | 5 | export default function CommonLayout({ children }) { 6 | return {children}; 7 | } 8 | -------------------------------------------------------------------------------- /src/components/single-user-card/index.js: -------------------------------------------------------------------------------- 1 | "use client"; 2 | import { 3 | Card, 4 | CardContent, 5 | CardDescription, 6 | CardFooter, 7 | CardHeader, 8 | CardTitle, 9 | } from "@/components/ui/card"; 10 | import { Button } from "../ui/button"; 11 | import { deleteUserAction } from "@/actions"; 12 | import { useContext } from "react"; 13 | import { UserContext } from "@/context"; 14 | 15 | function SingleUserCard({ user }) { 16 | const { setOpenPopup, setAddNewUserFormData, setCurrentEditedID } = 17 | useContext(UserContext); 18 | 19 | async function handleDelete(getCurrentUserID) { 20 | const result = await deleteUserAction(getCurrentUserID, "/user-management"); 21 | 22 | console.log(result); 23 | } 24 | 25 | function handleEdit(getCurrentUser) { 26 | setOpenPopup(true); 27 | setAddNewUserFormData({ 28 | firstName: getCurrentUser?.firstName, 29 | lastName: getCurrentUser?.lastName, 30 | email: getCurrentUser?.email, 31 | address: getCurrentUser?.address, 32 | }); 33 | setCurrentEditedID(getCurrentUser?._id); 34 | } 35 | 36 | return ( 37 | 38 | 39 | 40 | {user?.firstName} {user?.lastName} 41 | 42 | {user?.email} 43 | 44 | 45 |

{user?.address}

46 |
47 | 48 | 49 | 50 | 51 |
52 | ); 53 | } 54 | 55 | export default SingleUserCard; 56 | -------------------------------------------------------------------------------- /src/components/ui/button.jsx: -------------------------------------------------------------------------------- 1 | import * as React from "react" 2 | import { Slot } from "@radix-ui/react-slot" 3 | import { cva } from "class-variance-authority"; 4 | 5 | import { cn } from "@/lib/utils" 6 | 7 | const buttonVariants = cva( 8 | "inline-flex items-center justify-center whitespace-nowrap rounded-md text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50", 9 | { 10 | variants: { 11 | variant: { 12 | default: "bg-primary text-primary-foreground hover:bg-primary/90", 13 | destructive: 14 | "bg-destructive text-destructive-foreground hover:bg-destructive/90", 15 | outline: 16 | "border border-input bg-background hover:bg-accent hover:text-accent-foreground", 17 | secondary: 18 | "bg-secondary text-secondary-foreground hover:bg-secondary/80", 19 | ghost: "hover:bg-accent hover:text-accent-foreground", 20 | link: "text-primary underline-offset-4 hover:underline", 21 | }, 22 | size: { 23 | default: "h-10 px-4 py-2", 24 | sm: "h-9 rounded-md px-3", 25 | lg: "h-11 rounded-md px-8", 26 | icon: "h-10 w-10", 27 | }, 28 | }, 29 | defaultVariants: { 30 | variant: "default", 31 | size: "default", 32 | }, 33 | } 34 | ) 35 | 36 | const Button = React.forwardRef(({ className, variant, size, asChild = false, ...props }, ref) => { 37 | const Comp = asChild ? Slot : "button" 38 | return ( 39 | () 43 | ); 44 | }) 45 | Button.displayName = "Button" 46 | 47 | export { Button, buttonVariants } 48 | -------------------------------------------------------------------------------- /src/components/ui/card.jsx: -------------------------------------------------------------------------------- 1 | import * as React from "react" 2 | 3 | import { cn } from "@/lib/utils" 4 | 5 | const Card = React.forwardRef(({ className, ...props }, ref) => ( 6 |
10 | )) 11 | Card.displayName = "Card" 12 | 13 | const CardHeader = React.forwardRef(({ className, ...props }, ref) => ( 14 |
18 | )) 19 | CardHeader.displayName = "CardHeader" 20 | 21 | const CardTitle = React.forwardRef(({ className, ...props }, ref) => ( 22 |

26 | )) 27 | CardTitle.displayName = "CardTitle" 28 | 29 | const CardDescription = React.forwardRef(({ className, ...props }, ref) => ( 30 |

34 | )) 35 | CardDescription.displayName = "CardDescription" 36 | 37 | const CardContent = React.forwardRef(({ className, ...props }, ref) => ( 38 |

39 | )) 40 | CardContent.displayName = "CardContent" 41 | 42 | const CardFooter = React.forwardRef(({ className, ...props }, ref) => ( 43 |
47 | )) 48 | CardFooter.displayName = "CardFooter" 49 | 50 | export { Card, CardHeader, CardFooter, CardTitle, CardDescription, CardContent } 51 | -------------------------------------------------------------------------------- /src/components/ui/dialog.jsx: -------------------------------------------------------------------------------- 1 | "use client" 2 | 3 | import * as React from "react" 4 | import * as DialogPrimitive from "@radix-ui/react-dialog" 5 | import { X } from "lucide-react" 6 | 7 | import { cn } from "@/lib/utils" 8 | 9 | const Dialog = DialogPrimitive.Root 10 | 11 | const DialogTrigger = DialogPrimitive.Trigger 12 | 13 | const DialogPortal = DialogPrimitive.Portal 14 | 15 | const DialogClose = DialogPrimitive.Close 16 | 17 | const DialogOverlay = React.forwardRef(({ className, ...props }, ref) => ( 18 | 25 | )) 26 | DialogOverlay.displayName = DialogPrimitive.Overlay.displayName 27 | 28 | const DialogContent = React.forwardRef(({ className, children, ...props }, ref) => ( 29 | 30 | 31 | 38 | {children} 39 | 41 | 42 | Close 43 | 44 | 45 | 46 | )) 47 | DialogContent.displayName = DialogPrimitive.Content.displayName 48 | 49 | const DialogHeader = ({ 50 | className, 51 | ...props 52 | }) => ( 53 |
56 | ) 57 | DialogHeader.displayName = "DialogHeader" 58 | 59 | const DialogFooter = ({ 60 | className, 61 | ...props 62 | }) => ( 63 |
66 | ) 67 | DialogFooter.displayName = "DialogFooter" 68 | 69 | const DialogTitle = React.forwardRef(({ className, ...props }, ref) => ( 70 | 74 | )) 75 | DialogTitle.displayName = DialogPrimitive.Title.displayName 76 | 77 | const DialogDescription = React.forwardRef(({ className, ...props }, ref) => ( 78 | 82 | )) 83 | DialogDescription.displayName = DialogPrimitive.Description.displayName 84 | 85 | export { 86 | Dialog, 87 | DialogPortal, 88 | DialogOverlay, 89 | DialogClose, 90 | DialogTrigger, 91 | DialogContent, 92 | DialogHeader, 93 | DialogFooter, 94 | DialogTitle, 95 | DialogDescription, 96 | } 97 | -------------------------------------------------------------------------------- /src/components/ui/input.jsx: -------------------------------------------------------------------------------- 1 | import * as React from "react" 2 | 3 | import { cn } from "@/lib/utils" 4 | 5 | const Input = React.forwardRef(({ className, type, ...props }, ref) => { 6 | return ( 7 | () 15 | ); 16 | }) 17 | Input.displayName = "Input" 18 | 19 | export { Input } 20 | -------------------------------------------------------------------------------- /src/components/ui/label.jsx: -------------------------------------------------------------------------------- 1 | "use client" 2 | 3 | import * as React from "react" 4 | import * as LabelPrimitive from "@radix-ui/react-label" 5 | import { cva } from "class-variance-authority"; 6 | 7 | import { cn } from "@/lib/utils" 8 | 9 | const labelVariants = cva( 10 | "text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70" 11 | ) 12 | 13 | const Label = React.forwardRef(({ className, ...props }, ref) => ( 14 | 15 | )) 16 | Label.displayName = LabelPrimitive.Root.displayName 17 | 18 | export { Label } 19 | -------------------------------------------------------------------------------- /src/context/index.js: -------------------------------------------------------------------------------- 1 | "use client"; 2 | 3 | import { addNewUserFormInitialState } from "@/utils"; 4 | import { createContext, useState } from "react"; 5 | 6 | export const UserContext = createContext(null); 7 | 8 | export default function UserState({ children }) { 9 | const [openPopup, setOpenPopup] = useState(false); 10 | const [addNewUserFormData, setAddNewUserFormData] = useState( 11 | addNewUserFormInitialState 12 | ); 13 | const [currentEditedID, setCurrentEditedID] = useState(null); 14 | 15 | return ( 16 | 26 | {children} 27 | 28 | ); 29 | } 30 | -------------------------------------------------------------------------------- /src/database/index.js: -------------------------------------------------------------------------------- 1 | import mongoose from "mongoose"; 2 | 3 | const connectToDB = async () => { 4 | const url = 5 | "mongodb+srv://sangammukherjee2022:sangam2024@cluster0.xmyzton.mongodb.net/"; 6 | 7 | mongoose 8 | .connect(url) 9 | .then(() => console.log("Database connection is successful")) 10 | .catch((e) => console.log(e)); 11 | }; 12 | 13 | export default connectToDB; 14 | -------------------------------------------------------------------------------- /src/lib/utils.js: -------------------------------------------------------------------------------- 1 | import { clsx } from "clsx" 2 | import { twMerge } from "tailwind-merge" 3 | 4 | export function cn(...inputs) { 5 | return twMerge(clsx(inputs)) 6 | } 7 | -------------------------------------------------------------------------------- /src/models/user.js: -------------------------------------------------------------------------------- 1 | import mongoose from "mongoose"; 2 | const UserSchema = new mongoose.Schema({ 3 | firstName: String, 4 | lastName: String, 5 | email: String, 6 | address: String, 7 | }); 8 | 9 | const User = mongoose.models.User || mongoose.model("User", UserSchema); 10 | 11 | export default User; 12 | -------------------------------------------------------------------------------- /src/utils/index.js: -------------------------------------------------------------------------------- 1 | export const addNewUserFormControls = [ 2 | { 3 | name: "firstName", 4 | label: "First Name", 5 | placeholder: "Enter your first name", 6 | type: "input", 7 | }, 8 | { 9 | name: "lastName", 10 | label: "Last Name", 11 | placeholder: "Enter your last name", 12 | type: "input", 13 | }, 14 | { 15 | name: "email", 16 | label: "Email", 17 | placeholder: "Enter your email", 18 | type: "email", 19 | }, 20 | { 21 | name: "address", 22 | label: "Address", 23 | placeholder: "Enter your address", 24 | type: "input", 25 | }, 26 | ]; 27 | 28 | export const addNewUserFormInitialState = { 29 | firstName: "", 30 | lastName: "", 31 | email: "", 32 | address: "", 33 | }; 34 | -------------------------------------------------------------------------------- /tailwind.config.js: -------------------------------------------------------------------------------- 1 | /** @type {import('tailwindcss').Config} */ 2 | module.exports = { 3 | darkMode: ["class"], 4 | content: [ 5 | './pages/**/*.{js,jsx}', 6 | './components/**/*.{js,jsx}', 7 | './app/**/*.{js,jsx}', 8 | './src/**/*.{js,jsx}', 9 | ], 10 | prefix: "", 11 | theme: { 12 | container: { 13 | center: true, 14 | padding: "2rem", 15 | screens: { 16 | "2xl": "1400px", 17 | }, 18 | }, 19 | extend: { 20 | colors: { 21 | border: "hsl(var(--border))", 22 | input: "hsl(var(--input))", 23 | ring: "hsl(var(--ring))", 24 | background: "hsl(var(--background))", 25 | foreground: "hsl(var(--foreground))", 26 | primary: { 27 | DEFAULT: "hsl(var(--primary))", 28 | foreground: "hsl(var(--primary-foreground))", 29 | }, 30 | secondary: { 31 | DEFAULT: "hsl(var(--secondary))", 32 | foreground: "hsl(var(--secondary-foreground))", 33 | }, 34 | destructive: { 35 | DEFAULT: "hsl(var(--destructive))", 36 | foreground: "hsl(var(--destructive-foreground))", 37 | }, 38 | muted: { 39 | DEFAULT: "hsl(var(--muted))", 40 | foreground: "hsl(var(--muted-foreground))", 41 | }, 42 | accent: { 43 | DEFAULT: "hsl(var(--accent))", 44 | foreground: "hsl(var(--accent-foreground))", 45 | }, 46 | popover: { 47 | DEFAULT: "hsl(var(--popover))", 48 | foreground: "hsl(var(--popover-foreground))", 49 | }, 50 | card: { 51 | DEFAULT: "hsl(var(--card))", 52 | foreground: "hsl(var(--card-foreground))", 53 | }, 54 | }, 55 | borderRadius: { 56 | lg: "var(--radius)", 57 | md: "calc(var(--radius) - 2px)", 58 | sm: "calc(var(--radius) - 4px)", 59 | }, 60 | keyframes: { 61 | "accordion-down": { 62 | from: { height: "0" }, 63 | to: { height: "var(--radix-accordion-content-height)" }, 64 | }, 65 | "accordion-up": { 66 | from: { height: "var(--radix-accordion-content-height)" }, 67 | to: { height: "0" }, 68 | }, 69 | }, 70 | animation: { 71 | "accordion-down": "accordion-down 0.2s ease-out", 72 | "accordion-up": "accordion-up 0.2s ease-out", 73 | }, 74 | }, 75 | }, 76 | plugins: [require("tailwindcss-animate")], 77 | } --------------------------------------------------------------------------------