Added parser function
This commit is contained in:
@@ -23,6 +23,7 @@ module.exports = {
|
||||
'@typescript-eslint'
|
||||
],
|
||||
'rules': {
|
||||
'@typescript-eslint/no-explicit-any': 'off',
|
||||
'indent': [
|
||||
'warn',
|
||||
2,
|
||||
@@ -41,6 +42,7 @@ module.exports = {
|
||||
'never'
|
||||
],
|
||||
'react/react-in-jsx-scope': 'off',
|
||||
'no-async-promise-executor': 'off'
|
||||
'no-async-promise-executor': 'off',
|
||||
'@typescript-eslint/no-unused-vars': ['warn']
|
||||
}
|
||||
}
|
||||
|
||||
45
README.md
45
README.md
@@ -1,40 +1,21 @@
|
||||
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).
|
||||
# Schedule for колледж связи пгути
|
||||
|
||||
## Getting Started
|
||||
Reskin of https://lk.ks.psuti.ru/ since it lacks mobile support and is generally ugly.
|
||||
|
||||
First, run the development server:
|
||||

|
||||
|
||||
```bash
|
||||
npm run dev
|
||||
# or
|
||||
yarn dev
|
||||
# or
|
||||
pnpm dev
|
||||
# or
|
||||
bun dev
|
||||
```
|
||||
[Visit website](TODO: host anywhere in Russia)
|
||||
|
||||
Open [http://localhost:3000](http://localhost:3000) with your browser to see the result.
|
||||
## Tech stack
|
||||
|
||||
You can start editing the page by modifying `pages/index.tsx`. The page auto-updates as you edit the file.
|
||||
- React with Next.js v13.5 (pages router)
|
||||
- Tailwind CSS
|
||||
- @shadcn/ui components (built with Radix UI)
|
||||
- node-html-parser for scraping, rehydration strategy for cache
|
||||
- TypeScript with types for each package
|
||||
|
||||
[API routes](https://nextjs.org/docs/api-routes/introduction) can be accessed on [http://localhost:3000/api/hello](http://localhost:3000/api/hello). This endpoint can be edited in `pages/api/hello.ts`.
|
||||
Built in 1 day. Tools used: pnpm, eslint.
|
||||
|
||||
The `pages/api` directory is mapped to `/api/*`. Files in this directory are treated as [API routes](https://nextjs.org/docs/api-routes/introduction) instead of React pages.
|
||||
## Hire me!
|
||||
|
||||
This project uses [`next/font`](https://nextjs.org/docs/basic-features/font-optimization) to automatically optimize and load Inter, a custom Google Font.
|
||||
|
||||
## Learn More
|
||||
|
||||
To learn more about Next.js, take a look at the following resources:
|
||||
|
||||
- [Next.js Documentation](https://nextjs.org/docs) - learn about Next.js features and API.
|
||||
- [Learn Next.js](https://nextjs.org/learn) - an interactive Next.js tutorial.
|
||||
|
||||
You can check out [the Next.js GitHub repository](https://github.com/vercel/next.js/) - your feedback and contributions are welcome!
|
||||
|
||||
## Deploy on Vercel
|
||||
|
||||
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.
|
||||
|
||||
Check out our [Next.js deployment documentation](https://nextjs.org/docs/deployment) for more details.
|
||||
I'm available for hire if you can provide me with a work visa in Canada. Check out my resume: [cv.hloth.dev](https://cv.hloth.dev).
|
||||
@@ -9,10 +9,16 @@
|
||||
"lint": "next lint"
|
||||
},
|
||||
"dependencies": {
|
||||
"@radix-ui/react-label": "^2.0.2",
|
||||
"@radix-ui/react-select": "^2.0.0",
|
||||
"@radix-ui/react-slot": "^1.0.2",
|
||||
"@types/content-type": "^1.1.6",
|
||||
"class-variance-authority": "^0.7.0",
|
||||
"clsx": "^2.0.0",
|
||||
"content-type": "^1.0.5",
|
||||
"lucide-react": "^0.279.0",
|
||||
"next": "latest",
|
||||
"node-html-parser": "^6.1.10",
|
||||
"react": "latest",
|
||||
"react-dom": "latest",
|
||||
"tailwind-merge": "^1.14.0",
|
||||
@@ -22,6 +28,7 @@
|
||||
"@types/node": "latest",
|
||||
"@types/react": "latest",
|
||||
"@types/react-dom": "latest",
|
||||
"@typescript-eslint/eslint-plugin": "^6.7.3",
|
||||
"autoprefixer": "latest",
|
||||
"eslint": "latest",
|
||||
"eslint-config-next": "latest",
|
||||
|
||||
767
pnpm-lock.yaml
generated
767
pnpm-lock.yaml
generated
@@ -5,18 +5,36 @@ settings:
|
||||
excludeLinksFromLockfile: false
|
||||
|
||||
dependencies:
|
||||
'@radix-ui/react-label':
|
||||
specifier: ^2.0.2
|
||||
version: 2.0.2(@types/react-dom@18.2.8)(@types/react@18.2.24)(react-dom@18.2.0)(react@18.2.0)
|
||||
'@radix-ui/react-select':
|
||||
specifier: ^2.0.0
|
||||
version: 2.0.0(@types/react-dom@18.2.8)(@types/react@18.2.24)(react-dom@18.2.0)(react@18.2.0)
|
||||
'@radix-ui/react-slot':
|
||||
specifier: ^1.0.2
|
||||
version: 1.0.2(@types/react@18.2.24)(react@18.2.0)
|
||||
'@types/content-type':
|
||||
specifier: ^1.1.6
|
||||
version: 1.1.6
|
||||
class-variance-authority:
|
||||
specifier: ^0.7.0
|
||||
version: 0.7.0
|
||||
clsx:
|
||||
specifier: ^2.0.0
|
||||
version: 2.0.0
|
||||
content-type:
|
||||
specifier: ^1.0.5
|
||||
version: 1.0.5
|
||||
lucide-react:
|
||||
specifier: ^0.279.0
|
||||
version: 0.279.0(react@18.2.0)
|
||||
next:
|
||||
specifier: latest
|
||||
version: 13.5.3(react-dom@18.2.0)(react@18.2.0)
|
||||
node-html-parser:
|
||||
specifier: ^6.1.10
|
||||
version: 6.1.10
|
||||
react:
|
||||
specifier: latest
|
||||
version: 18.2.0
|
||||
@@ -40,6 +58,9 @@ devDependencies:
|
||||
'@types/react-dom':
|
||||
specifier: latest
|
||||
version: 18.2.8
|
||||
'@typescript-eslint/eslint-plugin':
|
||||
specifier: ^6.7.3
|
||||
version: 6.7.3(@typescript-eslint/parser@6.7.3)(eslint@8.50.0)(typescript@5.2.2)
|
||||
autoprefixer:
|
||||
specifier: latest
|
||||
version: 10.4.16(postcss@8.4.31)
|
||||
@@ -75,7 +96,6 @@ packages:
|
||||
engines: {node: '>=6.9.0'}
|
||||
dependencies:
|
||||
regenerator-runtime: 0.14.0
|
||||
dev: true
|
||||
|
||||
/@eslint-community/eslint-utils@4.4.0(eslint@8.50.0):
|
||||
resolution: {integrity: sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==}
|
||||
@@ -114,6 +134,34 @@ packages:
|
||||
engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0}
|
||||
dev: true
|
||||
|
||||
/@floating-ui/core@1.5.0:
|
||||
resolution: {integrity: sha512-kK1h4m36DQ0UHGj5Ah4db7R0rHemTqqO0QLvUqi1/mUUp3LuAWbWxdxSIf/XsnH9VS6rRVPLJCncjRzUvyCLXg==}
|
||||
dependencies:
|
||||
'@floating-ui/utils': 0.1.4
|
||||
dev: false
|
||||
|
||||
/@floating-ui/dom@1.5.3:
|
||||
resolution: {integrity: sha512-ClAbQnEqJAKCJOEbbLo5IUlZHkNszqhuxS4fHAVxRPXPya6Ysf2G8KypnYcOTpx6I8xcgF9bbHb6g/2KpbV8qA==}
|
||||
dependencies:
|
||||
'@floating-ui/core': 1.5.0
|
||||
'@floating-ui/utils': 0.1.4
|
||||
dev: false
|
||||
|
||||
/@floating-ui/react-dom@2.0.2(react-dom@18.2.0)(react@18.2.0):
|
||||
resolution: {integrity: sha512-5qhlDvjaLmAst/rKb3VdlCinwTF4EYMiVxuuc/HVUjs46W0zgtbMmAZ1UTsDrRTxRmUEzl92mOtWbeeXL26lSQ==}
|
||||
peerDependencies:
|
||||
react: '>=16.8.0'
|
||||
react-dom: '>=16.8.0'
|
||||
dependencies:
|
||||
'@floating-ui/dom': 1.5.3
|
||||
react: 18.2.0
|
||||
react-dom: 18.2.0(react@18.2.0)
|
||||
dev: false
|
||||
|
||||
/@floating-ui/utils@0.1.4:
|
||||
resolution: {integrity: sha512-qprfWkn82Iw821mcKofJ5Pk9wgioHicxcQMxx+5zt5GSKoqdWvgG5AxVmpmUUjzTLPVSH5auBrhI93Deayn/DA==}
|
||||
dev: false
|
||||
|
||||
/@humanwhocodes/config-array@0.11.11:
|
||||
resolution: {integrity: sha512-N2brEuAadi0CcdeMXUkhbZB84eskAc8MEX1By6qEchoVywSgXPIjou4rYsl0V3Hj0ZnuGycGCjdNgockbzeWNA==}
|
||||
engines: {node: '>=10.10.0'}
|
||||
@@ -268,6 +316,460 @@ packages:
|
||||
'@nodelib/fs.scandir': 2.1.5
|
||||
fastq: 1.15.0
|
||||
|
||||
/@radix-ui/number@1.0.1:
|
||||
resolution: {integrity: sha512-T5gIdVO2mmPW3NNhjNgEP3cqMXjXL9UbO0BzWcXfvdBs+BohbQxvd/K5hSVKmn9/lbTdsQVKbUcP5WLCwvUbBg==}
|
||||
dependencies:
|
||||
'@babel/runtime': 7.23.1
|
||||
dev: false
|
||||
|
||||
/@radix-ui/primitive@1.0.1:
|
||||
resolution: {integrity: sha512-yQ8oGX2GVsEYMWGxcovu1uGWPCxV5BFfeeYxqPmuAzUyLT9qmaMXSAhXpb0WrspIeqYzdJpkh2vHModJPgRIaw==}
|
||||
dependencies:
|
||||
'@babel/runtime': 7.23.1
|
||||
dev: false
|
||||
|
||||
/@radix-ui/react-arrow@1.0.3(@types/react-dom@18.2.8)(@types/react@18.2.24)(react-dom@18.2.0)(react@18.2.0):
|
||||
resolution: {integrity: sha512-wSP+pHsB/jQRaL6voubsQ/ZlrGBHHrOjmBnr19hxYgtS0WvAFwZhK2WP/YY5yF9uKECCEEDGxuLxq1NBK51wFA==}
|
||||
peerDependencies:
|
||||
'@types/react': '*'
|
||||
'@types/react-dom': '*'
|
||||
react: ^16.8 || ^17.0 || ^18.0
|
||||
react-dom: ^16.8 || ^17.0 || ^18.0
|
||||
peerDependenciesMeta:
|
||||
'@types/react':
|
||||
optional: true
|
||||
'@types/react-dom':
|
||||
optional: true
|
||||
dependencies:
|
||||
'@babel/runtime': 7.23.1
|
||||
'@radix-ui/react-primitive': 1.0.3(@types/react-dom@18.2.8)(@types/react@18.2.24)(react-dom@18.2.0)(react@18.2.0)
|
||||
'@types/react': 18.2.24
|
||||
'@types/react-dom': 18.2.8
|
||||
react: 18.2.0
|
||||
react-dom: 18.2.0(react@18.2.0)
|
||||
dev: false
|
||||
|
||||
/@radix-ui/react-collection@1.0.3(@types/react-dom@18.2.8)(@types/react@18.2.24)(react-dom@18.2.0)(react@18.2.0):
|
||||
resolution: {integrity: sha512-3SzW+0PW7yBBoQlT8wNcGtaxaD0XSu0uLUFgrtHY08Acx05TaHaOmVLR73c0j/cqpDy53KBMO7s0dx2wmOIDIA==}
|
||||
peerDependencies:
|
||||
'@types/react': '*'
|
||||
'@types/react-dom': '*'
|
||||
react: ^16.8 || ^17.0 || ^18.0
|
||||
react-dom: ^16.8 || ^17.0 || ^18.0
|
||||
peerDependenciesMeta:
|
||||
'@types/react':
|
||||
optional: true
|
||||
'@types/react-dom':
|
||||
optional: true
|
||||
dependencies:
|
||||
'@babel/runtime': 7.23.1
|
||||
'@radix-ui/react-compose-refs': 1.0.1(@types/react@18.2.24)(react@18.2.0)
|
||||
'@radix-ui/react-context': 1.0.1(@types/react@18.2.24)(react@18.2.0)
|
||||
'@radix-ui/react-primitive': 1.0.3(@types/react-dom@18.2.8)(@types/react@18.2.24)(react-dom@18.2.0)(react@18.2.0)
|
||||
'@radix-ui/react-slot': 1.0.2(@types/react@18.2.24)(react@18.2.0)
|
||||
'@types/react': 18.2.24
|
||||
'@types/react-dom': 18.2.8
|
||||
react: 18.2.0
|
||||
react-dom: 18.2.0(react@18.2.0)
|
||||
dev: false
|
||||
|
||||
/@radix-ui/react-compose-refs@1.0.1(@types/react@18.2.24)(react@18.2.0):
|
||||
resolution: {integrity: sha512-fDSBgd44FKHa1FRMU59qBMPFcl2PZE+2nmqunj+BWFyYYjnhIDWL2ItDs3rrbJDQOtzt5nIebLCQc4QRfz6LJw==}
|
||||
peerDependencies:
|
||||
'@types/react': '*'
|
||||
react: ^16.8 || ^17.0 || ^18.0
|
||||
peerDependenciesMeta:
|
||||
'@types/react':
|
||||
optional: true
|
||||
dependencies:
|
||||
'@babel/runtime': 7.23.1
|
||||
'@types/react': 18.2.24
|
||||
react: 18.2.0
|
||||
dev: false
|
||||
|
||||
/@radix-ui/react-context@1.0.1(@types/react@18.2.24)(react@18.2.0):
|
||||
resolution: {integrity: sha512-ebbrdFoYTcuZ0v4wG5tedGnp9tzcV8awzsxYph7gXUyvnNLuTIcCk1q17JEbnVhXAKG9oX3KtchwiMIAYp9NLg==}
|
||||
peerDependencies:
|
||||
'@types/react': '*'
|
||||
react: ^16.8 || ^17.0 || ^18.0
|
||||
peerDependenciesMeta:
|
||||
'@types/react':
|
||||
optional: true
|
||||
dependencies:
|
||||
'@babel/runtime': 7.23.1
|
||||
'@types/react': 18.2.24
|
||||
react: 18.2.0
|
||||
dev: false
|
||||
|
||||
/@radix-ui/react-direction@1.0.1(@types/react@18.2.24)(react@18.2.0):
|
||||
resolution: {integrity: sha512-RXcvnXgyvYvBEOhCBuddKecVkoMiI10Jcm5cTI7abJRAHYfFxeu+FBQs/DvdxSYucxR5mna0dNsL6QFlds5TMA==}
|
||||
peerDependencies:
|
||||
'@types/react': '*'
|
||||
react: ^16.8 || ^17.0 || ^18.0
|
||||
peerDependenciesMeta:
|
||||
'@types/react':
|
||||
optional: true
|
||||
dependencies:
|
||||
'@babel/runtime': 7.23.1
|
||||
'@types/react': 18.2.24
|
||||
react: 18.2.0
|
||||
dev: false
|
||||
|
||||
/@radix-ui/react-dismissable-layer@1.0.5(@types/react-dom@18.2.8)(@types/react@18.2.24)(react-dom@18.2.0)(react@18.2.0):
|
||||
resolution: {integrity: sha512-aJeDjQhywg9LBu2t/At58hCvr7pEm0o2Ke1x33B+MhjNmmZ17sy4KImo0KPLgsnc/zN7GPdce8Cnn0SWvwZO7g==}
|
||||
peerDependencies:
|
||||
'@types/react': '*'
|
||||
'@types/react-dom': '*'
|
||||
react: ^16.8 || ^17.0 || ^18.0
|
||||
react-dom: ^16.8 || ^17.0 || ^18.0
|
||||
peerDependenciesMeta:
|
||||
'@types/react':
|
||||
optional: true
|
||||
'@types/react-dom':
|
||||
optional: true
|
||||
dependencies:
|
||||
'@babel/runtime': 7.23.1
|
||||
'@radix-ui/primitive': 1.0.1
|
||||
'@radix-ui/react-compose-refs': 1.0.1(@types/react@18.2.24)(react@18.2.0)
|
||||
'@radix-ui/react-primitive': 1.0.3(@types/react-dom@18.2.8)(@types/react@18.2.24)(react-dom@18.2.0)(react@18.2.0)
|
||||
'@radix-ui/react-use-callback-ref': 1.0.1(@types/react@18.2.24)(react@18.2.0)
|
||||
'@radix-ui/react-use-escape-keydown': 1.0.3(@types/react@18.2.24)(react@18.2.0)
|
||||
'@types/react': 18.2.24
|
||||
'@types/react-dom': 18.2.8
|
||||
react: 18.2.0
|
||||
react-dom: 18.2.0(react@18.2.0)
|
||||
dev: false
|
||||
|
||||
/@radix-ui/react-focus-guards@1.0.1(@types/react@18.2.24)(react@18.2.0):
|
||||
resolution: {integrity: sha512-Rect2dWbQ8waGzhMavsIbmSVCgYxkXLxxR3ZvCX79JOglzdEy4JXMb98lq4hPxUbLr77nP0UOGf4rcMU+s1pUA==}
|
||||
peerDependencies:
|
||||
'@types/react': '*'
|
||||
react: ^16.8 || ^17.0 || ^18.0
|
||||
peerDependenciesMeta:
|
||||
'@types/react':
|
||||
optional: true
|
||||
dependencies:
|
||||
'@babel/runtime': 7.23.1
|
||||
'@types/react': 18.2.24
|
||||
react: 18.2.0
|
||||
dev: false
|
||||
|
||||
/@radix-ui/react-focus-scope@1.0.4(@types/react-dom@18.2.8)(@types/react@18.2.24)(react-dom@18.2.0)(react@18.2.0):
|
||||
resolution: {integrity: sha512-sL04Mgvf+FmyvZeYfNu1EPAaaxD+aw7cYeIB9L9Fvq8+urhltTRaEo5ysKOpHuKPclsZcSUMKlN05x4u+CINpA==}
|
||||
peerDependencies:
|
||||
'@types/react': '*'
|
||||
'@types/react-dom': '*'
|
||||
react: ^16.8 || ^17.0 || ^18.0
|
||||
react-dom: ^16.8 || ^17.0 || ^18.0
|
||||
peerDependenciesMeta:
|
||||
'@types/react':
|
||||
optional: true
|
||||
'@types/react-dom':
|
||||
optional: true
|
||||
dependencies:
|
||||
'@babel/runtime': 7.23.1
|
||||
'@radix-ui/react-compose-refs': 1.0.1(@types/react@18.2.24)(react@18.2.0)
|
||||
'@radix-ui/react-primitive': 1.0.3(@types/react-dom@18.2.8)(@types/react@18.2.24)(react-dom@18.2.0)(react@18.2.0)
|
||||
'@radix-ui/react-use-callback-ref': 1.0.1(@types/react@18.2.24)(react@18.2.0)
|
||||
'@types/react': 18.2.24
|
||||
'@types/react-dom': 18.2.8
|
||||
react: 18.2.0
|
||||
react-dom: 18.2.0(react@18.2.0)
|
||||
dev: false
|
||||
|
||||
/@radix-ui/react-id@1.0.1(@types/react@18.2.24)(react@18.2.0):
|
||||
resolution: {integrity: sha512-tI7sT/kqYp8p96yGWY1OAnLHrqDgzHefRBKQ2YAkBS5ja7QLcZ9Z/uY7bEjPUatf8RomoXM8/1sMj1IJaE5UzQ==}
|
||||
peerDependencies:
|
||||
'@types/react': '*'
|
||||
react: ^16.8 || ^17.0 || ^18.0
|
||||
peerDependenciesMeta:
|
||||
'@types/react':
|
||||
optional: true
|
||||
dependencies:
|
||||
'@babel/runtime': 7.23.1
|
||||
'@radix-ui/react-use-layout-effect': 1.0.1(@types/react@18.2.24)(react@18.2.0)
|
||||
'@types/react': 18.2.24
|
||||
react: 18.2.0
|
||||
dev: false
|
||||
|
||||
/@radix-ui/react-label@2.0.2(@types/react-dom@18.2.8)(@types/react@18.2.24)(react-dom@18.2.0)(react@18.2.0):
|
||||
resolution: {integrity: sha512-N5ehvlM7qoTLx7nWPodsPYPgMzA5WM8zZChQg8nyFJKnDO5WHdba1vv5/H6IO5LtJMfD2Q3wh1qHFGNtK0w3bQ==}
|
||||
peerDependencies:
|
||||
'@types/react': '*'
|
||||
'@types/react-dom': '*'
|
||||
react: ^16.8 || ^17.0 || ^18.0
|
||||
react-dom: ^16.8 || ^17.0 || ^18.0
|
||||
peerDependenciesMeta:
|
||||
'@types/react':
|
||||
optional: true
|
||||
'@types/react-dom':
|
||||
optional: true
|
||||
dependencies:
|
||||
'@babel/runtime': 7.23.1
|
||||
'@radix-ui/react-primitive': 1.0.3(@types/react-dom@18.2.8)(@types/react@18.2.24)(react-dom@18.2.0)(react@18.2.0)
|
||||
'@types/react': 18.2.24
|
||||
'@types/react-dom': 18.2.8
|
||||
react: 18.2.0
|
||||
react-dom: 18.2.0(react@18.2.0)
|
||||
dev: false
|
||||
|
||||
/@radix-ui/react-popper@1.1.3(@types/react-dom@18.2.8)(@types/react@18.2.24)(react-dom@18.2.0)(react@18.2.0):
|
||||
resolution: {integrity: sha512-cKpopj/5RHZWjrbF2846jBNacjQVwkP068DfmgrNJXpvVWrOvlAmE9xSiy5OqeE+Gi8D9fP+oDhUnPqNMY8/5w==}
|
||||
peerDependencies:
|
||||
'@types/react': '*'
|
||||
'@types/react-dom': '*'
|
||||
react: ^16.8 || ^17.0 || ^18.0
|
||||
react-dom: ^16.8 || ^17.0 || ^18.0
|
||||
peerDependenciesMeta:
|
||||
'@types/react':
|
||||
optional: true
|
||||
'@types/react-dom':
|
||||
optional: true
|
||||
dependencies:
|
||||
'@babel/runtime': 7.23.1
|
||||
'@floating-ui/react-dom': 2.0.2(react-dom@18.2.0)(react@18.2.0)
|
||||
'@radix-ui/react-arrow': 1.0.3(@types/react-dom@18.2.8)(@types/react@18.2.24)(react-dom@18.2.0)(react@18.2.0)
|
||||
'@radix-ui/react-compose-refs': 1.0.1(@types/react@18.2.24)(react@18.2.0)
|
||||
'@radix-ui/react-context': 1.0.1(@types/react@18.2.24)(react@18.2.0)
|
||||
'@radix-ui/react-primitive': 1.0.3(@types/react-dom@18.2.8)(@types/react@18.2.24)(react-dom@18.2.0)(react@18.2.0)
|
||||
'@radix-ui/react-use-callback-ref': 1.0.1(@types/react@18.2.24)(react@18.2.0)
|
||||
'@radix-ui/react-use-layout-effect': 1.0.1(@types/react@18.2.24)(react@18.2.0)
|
||||
'@radix-ui/react-use-rect': 1.0.1(@types/react@18.2.24)(react@18.2.0)
|
||||
'@radix-ui/react-use-size': 1.0.1(@types/react@18.2.24)(react@18.2.0)
|
||||
'@radix-ui/rect': 1.0.1
|
||||
'@types/react': 18.2.24
|
||||
'@types/react-dom': 18.2.8
|
||||
react: 18.2.0
|
||||
react-dom: 18.2.0(react@18.2.0)
|
||||
dev: false
|
||||
|
||||
/@radix-ui/react-portal@1.0.4(@types/react-dom@18.2.8)(@types/react@18.2.24)(react-dom@18.2.0)(react@18.2.0):
|
||||
resolution: {integrity: sha512-Qki+C/EuGUVCQTOTD5vzJzJuMUlewbzuKyUy+/iHM2uwGiru9gZeBJtHAPKAEkB5KWGi9mP/CHKcY0wt1aW45Q==}
|
||||
peerDependencies:
|
||||
'@types/react': '*'
|
||||
'@types/react-dom': '*'
|
||||
react: ^16.8 || ^17.0 || ^18.0
|
||||
react-dom: ^16.8 || ^17.0 || ^18.0
|
||||
peerDependenciesMeta:
|
||||
'@types/react':
|
||||
optional: true
|
||||
'@types/react-dom':
|
||||
optional: true
|
||||
dependencies:
|
||||
'@babel/runtime': 7.23.1
|
||||
'@radix-ui/react-primitive': 1.0.3(@types/react-dom@18.2.8)(@types/react@18.2.24)(react-dom@18.2.0)(react@18.2.0)
|
||||
'@types/react': 18.2.24
|
||||
'@types/react-dom': 18.2.8
|
||||
react: 18.2.0
|
||||
react-dom: 18.2.0(react@18.2.0)
|
||||
dev: false
|
||||
|
||||
/@radix-ui/react-primitive@1.0.3(@types/react-dom@18.2.8)(@types/react@18.2.24)(react-dom@18.2.0)(react@18.2.0):
|
||||
resolution: {integrity: sha512-yi58uVyoAcK/Nq1inRY56ZSjKypBNKTa/1mcL8qdl6oJeEaDbOldlzrGn7P6Q3Id5d+SYNGc5AJgc4vGhjs5+g==}
|
||||
peerDependencies:
|
||||
'@types/react': '*'
|
||||
'@types/react-dom': '*'
|
||||
react: ^16.8 || ^17.0 || ^18.0
|
||||
react-dom: ^16.8 || ^17.0 || ^18.0
|
||||
peerDependenciesMeta:
|
||||
'@types/react':
|
||||
optional: true
|
||||
'@types/react-dom':
|
||||
optional: true
|
||||
dependencies:
|
||||
'@babel/runtime': 7.23.1
|
||||
'@radix-ui/react-slot': 1.0.2(@types/react@18.2.24)(react@18.2.0)
|
||||
'@types/react': 18.2.24
|
||||
'@types/react-dom': 18.2.8
|
||||
react: 18.2.0
|
||||
react-dom: 18.2.0(react@18.2.0)
|
||||
dev: false
|
||||
|
||||
/@radix-ui/react-select@2.0.0(@types/react-dom@18.2.8)(@types/react@18.2.24)(react-dom@18.2.0)(react@18.2.0):
|
||||
resolution: {integrity: sha512-RH5b7af4oHtkcHS7pG6Sgv5rk5Wxa7XI8W5gvB1N/yiuDGZxko1ynvOiVhFM7Cis2A8zxF9bTOUVbRDzPepe6w==}
|
||||
peerDependencies:
|
||||
'@types/react': '*'
|
||||
'@types/react-dom': '*'
|
||||
react: ^16.8 || ^17.0 || ^18.0
|
||||
react-dom: ^16.8 || ^17.0 || ^18.0
|
||||
peerDependenciesMeta:
|
||||
'@types/react':
|
||||
optional: true
|
||||
'@types/react-dom':
|
||||
optional: true
|
||||
dependencies:
|
||||
'@babel/runtime': 7.23.1
|
||||
'@radix-ui/number': 1.0.1
|
||||
'@radix-ui/primitive': 1.0.1
|
||||
'@radix-ui/react-collection': 1.0.3(@types/react-dom@18.2.8)(@types/react@18.2.24)(react-dom@18.2.0)(react@18.2.0)
|
||||
'@radix-ui/react-compose-refs': 1.0.1(@types/react@18.2.24)(react@18.2.0)
|
||||
'@radix-ui/react-context': 1.0.1(@types/react@18.2.24)(react@18.2.0)
|
||||
'@radix-ui/react-direction': 1.0.1(@types/react@18.2.24)(react@18.2.0)
|
||||
'@radix-ui/react-dismissable-layer': 1.0.5(@types/react-dom@18.2.8)(@types/react@18.2.24)(react-dom@18.2.0)(react@18.2.0)
|
||||
'@radix-ui/react-focus-guards': 1.0.1(@types/react@18.2.24)(react@18.2.0)
|
||||
'@radix-ui/react-focus-scope': 1.0.4(@types/react-dom@18.2.8)(@types/react@18.2.24)(react-dom@18.2.0)(react@18.2.0)
|
||||
'@radix-ui/react-id': 1.0.1(@types/react@18.2.24)(react@18.2.0)
|
||||
'@radix-ui/react-popper': 1.1.3(@types/react-dom@18.2.8)(@types/react@18.2.24)(react-dom@18.2.0)(react@18.2.0)
|
||||
'@radix-ui/react-portal': 1.0.4(@types/react-dom@18.2.8)(@types/react@18.2.24)(react-dom@18.2.0)(react@18.2.0)
|
||||
'@radix-ui/react-primitive': 1.0.3(@types/react-dom@18.2.8)(@types/react@18.2.24)(react-dom@18.2.0)(react@18.2.0)
|
||||
'@radix-ui/react-slot': 1.0.2(@types/react@18.2.24)(react@18.2.0)
|
||||
'@radix-ui/react-use-callback-ref': 1.0.1(@types/react@18.2.24)(react@18.2.0)
|
||||
'@radix-ui/react-use-controllable-state': 1.0.1(@types/react@18.2.24)(react@18.2.0)
|
||||
'@radix-ui/react-use-layout-effect': 1.0.1(@types/react@18.2.24)(react@18.2.0)
|
||||
'@radix-ui/react-use-previous': 1.0.1(@types/react@18.2.24)(react@18.2.0)
|
||||
'@radix-ui/react-visually-hidden': 1.0.3(@types/react-dom@18.2.8)(@types/react@18.2.24)(react-dom@18.2.0)(react@18.2.0)
|
||||
'@types/react': 18.2.24
|
||||
'@types/react-dom': 18.2.8
|
||||
aria-hidden: 1.2.3
|
||||
react: 18.2.0
|
||||
react-dom: 18.2.0(react@18.2.0)
|
||||
react-remove-scroll: 2.5.5(@types/react@18.2.24)(react@18.2.0)
|
||||
dev: false
|
||||
|
||||
/@radix-ui/react-slot@1.0.2(@types/react@18.2.24)(react@18.2.0):
|
||||
resolution: {integrity: sha512-YeTpuq4deV+6DusvVUW4ivBgnkHwECUu0BiN43L5UCDFgdhsRUWAghhTF5MbvNTPzmiFOx90asDSUjWuCNapwg==}
|
||||
peerDependencies:
|
||||
'@types/react': '*'
|
||||
react: ^16.8 || ^17.0 || ^18.0
|
||||
peerDependenciesMeta:
|
||||
'@types/react':
|
||||
optional: true
|
||||
dependencies:
|
||||
'@babel/runtime': 7.23.1
|
||||
'@radix-ui/react-compose-refs': 1.0.1(@types/react@18.2.24)(react@18.2.0)
|
||||
'@types/react': 18.2.24
|
||||
react: 18.2.0
|
||||
dev: false
|
||||
|
||||
/@radix-ui/react-use-callback-ref@1.0.1(@types/react@18.2.24)(react@18.2.0):
|
||||
resolution: {integrity: sha512-D94LjX4Sp0xJFVaoQOd3OO9k7tpBYNOXdVhkltUbGv2Qb9OXdrg/CpsjlZv7ia14Sylv398LswWBVVu5nqKzAQ==}
|
||||
peerDependencies:
|
||||
'@types/react': '*'
|
||||
react: ^16.8 || ^17.0 || ^18.0
|
||||
peerDependenciesMeta:
|
||||
'@types/react':
|
||||
optional: true
|
||||
dependencies:
|
||||
'@babel/runtime': 7.23.1
|
||||
'@types/react': 18.2.24
|
||||
react: 18.2.0
|
||||
dev: false
|
||||
|
||||
/@radix-ui/react-use-controllable-state@1.0.1(@types/react@18.2.24)(react@18.2.0):
|
||||
resolution: {integrity: sha512-Svl5GY5FQeN758fWKrjM6Qb7asvXeiZltlT4U2gVfl8Gx5UAv2sMR0LWo8yhsIZh2oQ0eFdZ59aoOOMV7b47VA==}
|
||||
peerDependencies:
|
||||
'@types/react': '*'
|
||||
react: ^16.8 || ^17.0 || ^18.0
|
||||
peerDependenciesMeta:
|
||||
'@types/react':
|
||||
optional: true
|
||||
dependencies:
|
||||
'@babel/runtime': 7.23.1
|
||||
'@radix-ui/react-use-callback-ref': 1.0.1(@types/react@18.2.24)(react@18.2.0)
|
||||
'@types/react': 18.2.24
|
||||
react: 18.2.0
|
||||
dev: false
|
||||
|
||||
/@radix-ui/react-use-escape-keydown@1.0.3(@types/react@18.2.24)(react@18.2.0):
|
||||
resolution: {integrity: sha512-vyL82j40hcFicA+M4Ex7hVkB9vHgSse1ZWomAqV2Je3RleKGO5iM8KMOEtfoSB0PnIelMd2lATjTGMYqN5ylTg==}
|
||||
peerDependencies:
|
||||
'@types/react': '*'
|
||||
react: ^16.8 || ^17.0 || ^18.0
|
||||
peerDependenciesMeta:
|
||||
'@types/react':
|
||||
optional: true
|
||||
dependencies:
|
||||
'@babel/runtime': 7.23.1
|
||||
'@radix-ui/react-use-callback-ref': 1.0.1(@types/react@18.2.24)(react@18.2.0)
|
||||
'@types/react': 18.2.24
|
||||
react: 18.2.0
|
||||
dev: false
|
||||
|
||||
/@radix-ui/react-use-layout-effect@1.0.1(@types/react@18.2.24)(react@18.2.0):
|
||||
resolution: {integrity: sha512-v/5RegiJWYdoCvMnITBkNNx6bCj20fiaJnWtRkU18yITptraXjffz5Qbn05uOiQnOvi+dbkznkoaMltz1GnszQ==}
|
||||
peerDependencies:
|
||||
'@types/react': '*'
|
||||
react: ^16.8 || ^17.0 || ^18.0
|
||||
peerDependenciesMeta:
|
||||
'@types/react':
|
||||
optional: true
|
||||
dependencies:
|
||||
'@babel/runtime': 7.23.1
|
||||
'@types/react': 18.2.24
|
||||
react: 18.2.0
|
||||
dev: false
|
||||
|
||||
/@radix-ui/react-use-previous@1.0.1(@types/react@18.2.24)(react@18.2.0):
|
||||
resolution: {integrity: sha512-cV5La9DPwiQ7S0gf/0qiD6YgNqM5Fk97Kdrlc5yBcrF3jyEZQwm7vYFqMo4IfeHgJXsRaMvLABFtd0OVEmZhDw==}
|
||||
peerDependencies:
|
||||
'@types/react': '*'
|
||||
react: ^16.8 || ^17.0 || ^18.0
|
||||
peerDependenciesMeta:
|
||||
'@types/react':
|
||||
optional: true
|
||||
dependencies:
|
||||
'@babel/runtime': 7.23.1
|
||||
'@types/react': 18.2.24
|
||||
react: 18.2.0
|
||||
dev: false
|
||||
|
||||
/@radix-ui/react-use-rect@1.0.1(@types/react@18.2.24)(react@18.2.0):
|
||||
resolution: {integrity: sha512-Cq5DLuSiuYVKNU8orzJMbl15TXilTnJKUCltMVQg53BQOF1/C5toAaGrowkgksdBQ9H+SRL23g0HDmg9tvmxXw==}
|
||||
peerDependencies:
|
||||
'@types/react': '*'
|
||||
react: ^16.8 || ^17.0 || ^18.0
|
||||
peerDependenciesMeta:
|
||||
'@types/react':
|
||||
optional: true
|
||||
dependencies:
|
||||
'@babel/runtime': 7.23.1
|
||||
'@radix-ui/rect': 1.0.1
|
||||
'@types/react': 18.2.24
|
||||
react: 18.2.0
|
||||
dev: false
|
||||
|
||||
/@radix-ui/react-use-size@1.0.1(@types/react@18.2.24)(react@18.2.0):
|
||||
resolution: {integrity: sha512-ibay+VqrgcaI6veAojjofPATwledXiSmX+C0KrBk/xgpX9rBzPV3OsfwlhQdUOFbh+LKQorLYT+xTXW9V8yd0g==}
|
||||
peerDependencies:
|
||||
'@types/react': '*'
|
||||
react: ^16.8 || ^17.0 || ^18.0
|
||||
peerDependenciesMeta:
|
||||
'@types/react':
|
||||
optional: true
|
||||
dependencies:
|
||||
'@babel/runtime': 7.23.1
|
||||
'@radix-ui/react-use-layout-effect': 1.0.1(@types/react@18.2.24)(react@18.2.0)
|
||||
'@types/react': 18.2.24
|
||||
react: 18.2.0
|
||||
dev: false
|
||||
|
||||
/@radix-ui/react-visually-hidden@1.0.3(@types/react-dom@18.2.8)(@types/react@18.2.24)(react-dom@18.2.0)(react@18.2.0):
|
||||
resolution: {integrity: sha512-D4w41yN5YRKtu464TLnByKzMDG/JlMPHtfZgQAu9v6mNakUqGUI9vUrfQKz8NK41VMm/xbZbh76NUTVtIYqOMA==}
|
||||
peerDependencies:
|
||||
'@types/react': '*'
|
||||
'@types/react-dom': '*'
|
||||
react: ^16.8 || ^17.0 || ^18.0
|
||||
react-dom: ^16.8 || ^17.0 || ^18.0
|
||||
peerDependenciesMeta:
|
||||
'@types/react':
|
||||
optional: true
|
||||
'@types/react-dom':
|
||||
optional: true
|
||||
dependencies:
|
||||
'@babel/runtime': 7.23.1
|
||||
'@radix-ui/react-primitive': 1.0.3(@types/react-dom@18.2.8)(@types/react@18.2.24)(react-dom@18.2.0)(react@18.2.0)
|
||||
'@types/react': 18.2.24
|
||||
'@types/react-dom': 18.2.8
|
||||
react: 18.2.0
|
||||
react-dom: 18.2.0(react@18.2.0)
|
||||
dev: false
|
||||
|
||||
/@radix-ui/rect@1.0.1:
|
||||
resolution: {integrity: sha512-fyrgCaedtvMg9NK3en0pnOYJdtfwxUcNolezkNPUsoX57X8oQk+NkqcvzHXD2uKNij6GXmWU9NDru2IWjrO4BQ==}
|
||||
dependencies:
|
||||
'@babel/runtime': 7.23.1
|
||||
dev: false
|
||||
|
||||
/@rushstack/eslint-patch@1.5.1:
|
||||
resolution: {integrity: sha512-6i/8UoL0P5y4leBIGzvkZdS85RDMG9y1ihZzmTZQ5LdHUYmZ7pKFoj8X0236s3lusPs1Fa5HTQUpwI+UfTcmeA==}
|
||||
dev: true
|
||||
@@ -278,6 +780,14 @@ packages:
|
||||
tslib: 2.6.2
|
||||
dev: false
|
||||
|
||||
/@types/content-type@1.1.6:
|
||||
resolution: {integrity: sha512-WFHg/KFLCdUQl3m27WSQu0NEaLzoHGmgZHlsSYr0Y0iIvItMcBq7opZc6AGXPXqf+btIM6vTBJyLvuDAihB+zQ==}
|
||||
dev: false
|
||||
|
||||
/@types/json-schema@7.0.13:
|
||||
resolution: {integrity: sha512-RbSSoHliUbnXj3ny0CNFOoxrIDV6SUGyStHsvDqosw6CkdPV8TtWGlfecuK4ToyMEAql6pzNxgCFKanovUzlgQ==}
|
||||
dev: true
|
||||
|
||||
/@types/json5@0.0.29:
|
||||
resolution: {integrity: sha512-dRLjCWHYg4oaA77cxO64oO+7JwCwnIzkZPdrrC71jQmQtlhM556pwKo5bUzqvZndkVbeFLIIi+9TC40JNF5hNQ==}
|
||||
dev: true
|
||||
@@ -288,13 +798,11 @@ packages:
|
||||
|
||||
/@types/prop-types@15.7.8:
|
||||
resolution: {integrity: sha512-kMpQpfZKSCBqltAJwskgePRaYRFukDkm1oItcAbC3gNELR20XIBcN9VRgg4+m8DKsTfkWeA4m4Imp4DDuWy7FQ==}
|
||||
dev: true
|
||||
|
||||
/@types/react-dom@18.2.8:
|
||||
resolution: {integrity: sha512-bAIvO5lN/U8sPGvs1Xm61rlRHHaq5rp5N3kp9C+NJ/Q41P8iqjkXSu0+/qu8POsjH9pNWb0OYabFez7taP7omw==}
|
||||
dependencies:
|
||||
'@types/react': 18.2.24
|
||||
dev: true
|
||||
|
||||
/@types/react@18.2.24:
|
||||
resolution: {integrity: sha512-Ee0Jt4sbJxMu1iDcetZEIKQr99J1Zfb6D4F3qfUWoR1JpInkY1Wdg4WwCyBjL257D0+jGqSl1twBjV8iCaC0Aw==}
|
||||
@@ -302,10 +810,41 @@ packages:
|
||||
'@types/prop-types': 15.7.8
|
||||
'@types/scheduler': 0.16.4
|
||||
csstype: 3.1.2
|
||||
dev: true
|
||||
|
||||
/@types/scheduler@0.16.4:
|
||||
resolution: {integrity: sha512-2L9ifAGl7wmXwP4v3pN4p2FLhD0O1qsJpvKmNin5VA8+UvNVb447UDaAEV6UdrkA+m/Xs58U1RFps44x6TFsVQ==}
|
||||
|
||||
/@types/semver@7.5.3:
|
||||
resolution: {integrity: sha512-OxepLK9EuNEIPxWNME+C6WwbRAOOI2o2BaQEGzz5Lu2e4Z5eDnEo+/aVEDMIXywoJitJ7xWd641wrGLZdtwRyw==}
|
||||
dev: true
|
||||
|
||||
/@typescript-eslint/eslint-plugin@6.7.3(@typescript-eslint/parser@6.7.3)(eslint@8.50.0)(typescript@5.2.2):
|
||||
resolution: {integrity: sha512-vntq452UHNltxsaaN+L9WyuMch8bMd9CqJ3zhzTPXXidwbf5mqqKCVXEuvRZUqLJSTLeWE65lQwyXsRGnXkCTA==}
|
||||
engines: {node: ^16.0.0 || >=18.0.0}
|
||||
peerDependencies:
|
||||
'@typescript-eslint/parser': ^6.0.0 || ^6.0.0-alpha
|
||||
eslint: ^7.0.0 || ^8.0.0
|
||||
typescript: '*'
|
||||
peerDependenciesMeta:
|
||||
typescript:
|
||||
optional: true
|
||||
dependencies:
|
||||
'@eslint-community/regexpp': 4.9.0
|
||||
'@typescript-eslint/parser': 6.7.3(eslint@8.50.0)(typescript@5.2.2)
|
||||
'@typescript-eslint/scope-manager': 6.7.3
|
||||
'@typescript-eslint/type-utils': 6.7.3(eslint@8.50.0)(typescript@5.2.2)
|
||||
'@typescript-eslint/utils': 6.7.3(eslint@8.50.0)(typescript@5.2.2)
|
||||
'@typescript-eslint/visitor-keys': 6.7.3
|
||||
debug: 4.3.4
|
||||
eslint: 8.50.0
|
||||
graphemer: 1.4.0
|
||||
ignore: 5.2.4
|
||||
natural-compare: 1.4.0
|
||||
semver: 7.5.4
|
||||
ts-api-utils: 1.0.3(typescript@5.2.2)
|
||||
typescript: 5.2.2
|
||||
transitivePeerDependencies:
|
||||
- supports-color
|
||||
dev: true
|
||||
|
||||
/@typescript-eslint/parser@6.7.3(eslint@8.50.0)(typescript@5.2.2):
|
||||
@@ -337,6 +876,26 @@ packages:
|
||||
'@typescript-eslint/visitor-keys': 6.7.3
|
||||
dev: true
|
||||
|
||||
/@typescript-eslint/type-utils@6.7.3(eslint@8.50.0)(typescript@5.2.2):
|
||||
resolution: {integrity: sha512-Fc68K0aTDrKIBvLnKTZ5Pf3MXK495YErrbHb1R6aTpfK5OdSFj0rVN7ib6Tx6ePrZ2gsjLqr0s98NG7l96KSQw==}
|
||||
engines: {node: ^16.0.0 || >=18.0.0}
|
||||
peerDependencies:
|
||||
eslint: ^7.0.0 || ^8.0.0
|
||||
typescript: '*'
|
||||
peerDependenciesMeta:
|
||||
typescript:
|
||||
optional: true
|
||||
dependencies:
|
||||
'@typescript-eslint/typescript-estree': 6.7.3(typescript@5.2.2)
|
||||
'@typescript-eslint/utils': 6.7.3(eslint@8.50.0)(typescript@5.2.2)
|
||||
debug: 4.3.4
|
||||
eslint: 8.50.0
|
||||
ts-api-utils: 1.0.3(typescript@5.2.2)
|
||||
typescript: 5.2.2
|
||||
transitivePeerDependencies:
|
||||
- supports-color
|
||||
dev: true
|
||||
|
||||
/@typescript-eslint/types@6.7.3:
|
||||
resolution: {integrity: sha512-4g+de6roB2NFcfkZb439tigpAMnvEIg3rIjWQ+EM7IBaYt/CdJt6em9BJ4h4UpdgaBWdmx2iWsafHTrqmgIPNw==}
|
||||
engines: {node: ^16.0.0 || >=18.0.0}
|
||||
@@ -363,6 +922,25 @@ packages:
|
||||
- supports-color
|
||||
dev: true
|
||||
|
||||
/@typescript-eslint/utils@6.7.3(eslint@8.50.0)(typescript@5.2.2):
|
||||
resolution: {integrity: sha512-vzLkVder21GpWRrmSR9JxGZ5+ibIUSudXlW52qeKpzUEQhRSmyZiVDDj3crAth7+5tmN1ulvgKaCU2f/bPRCzg==}
|
||||
engines: {node: ^16.0.0 || >=18.0.0}
|
||||
peerDependencies:
|
||||
eslint: ^7.0.0 || ^8.0.0
|
||||
dependencies:
|
||||
'@eslint-community/eslint-utils': 4.4.0(eslint@8.50.0)
|
||||
'@types/json-schema': 7.0.13
|
||||
'@types/semver': 7.5.3
|
||||
'@typescript-eslint/scope-manager': 6.7.3
|
||||
'@typescript-eslint/types': 6.7.3
|
||||
'@typescript-eslint/typescript-estree': 6.7.3(typescript@5.2.2)
|
||||
eslint: 8.50.0
|
||||
semver: 7.5.4
|
||||
transitivePeerDependencies:
|
||||
- supports-color
|
||||
- typescript
|
||||
dev: true
|
||||
|
||||
/@typescript-eslint/visitor-keys@6.7.3:
|
||||
resolution: {integrity: sha512-HEVXkU9IB+nk9o63CeICMHxFWbHWr3E1mpilIQBe9+7L/lH97rleFLVtYsfnWB+JVMaiFnEaxvknvmIzX+CqVg==}
|
||||
engines: {node: ^16.0.0 || >=18.0.0}
|
||||
@@ -423,6 +1001,13 @@ packages:
|
||||
resolution: {integrity: sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==}
|
||||
dev: true
|
||||
|
||||
/aria-hidden@1.2.3:
|
||||
resolution: {integrity: sha512-xcLxITLe2HYa1cnYnwCjkOO1PqUHQpozB8x9AR0OgWN2woOBi5kSDVxKfd0b7sb1hw5qFeJhXm9H1nu3xSfLeQ==}
|
||||
engines: {node: '>=10'}
|
||||
dependencies:
|
||||
tslib: 2.6.2
|
||||
dev: false
|
||||
|
||||
/aria-query@5.3.0:
|
||||
resolution: {integrity: sha512-b0P0sZPKtyu8HkeRAfCq0IfURZK+SuwMjY1UXGBU27wpAiTwQAIlq56IbIO+ytk/JjS1fMR14ee5WBBfKi5J6A==}
|
||||
dependencies:
|
||||
@@ -555,6 +1140,10 @@ packages:
|
||||
resolution: {integrity: sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==}
|
||||
engines: {node: '>=8'}
|
||||
|
||||
/boolbase@1.0.0:
|
||||
resolution: {integrity: sha512-JZOSA7Mo9sNGB8+UjSgzdLtokWAky1zbztM3WRLCbZ70/3cTANmQmOdR7y2g+J0e2WXywy1yS468tY+IruqEww==}
|
||||
dev: false
|
||||
|
||||
/brace-expansion@1.1.11:
|
||||
resolution: {integrity: sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==}
|
||||
dependencies:
|
||||
@@ -659,6 +1248,11 @@ packages:
|
||||
/concat-map@0.0.1:
|
||||
resolution: {integrity: sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==}
|
||||
|
||||
/content-type@1.0.5:
|
||||
resolution: {integrity: sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==}
|
||||
engines: {node: '>= 0.6'}
|
||||
dev: false
|
||||
|
||||
/cross-spawn@7.0.3:
|
||||
resolution: {integrity: sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==}
|
||||
engines: {node: '>= 8'}
|
||||
@@ -668,6 +1262,21 @@ packages:
|
||||
which: 2.0.2
|
||||
dev: true
|
||||
|
||||
/css-select@5.1.0:
|
||||
resolution: {integrity: sha512-nwoRF1rvRRnnCqqY7updORDsuqKzqYJ28+oSMaJMMgOauh3fvwHqMS7EZpIPqK8GL+g9mKxF1vP/ZjSeNjEVHg==}
|
||||
dependencies:
|
||||
boolbase: 1.0.0
|
||||
css-what: 6.1.0
|
||||
domhandler: 5.0.3
|
||||
domutils: 3.1.0
|
||||
nth-check: 2.1.1
|
||||
dev: false
|
||||
|
||||
/css-what@6.1.0:
|
||||
resolution: {integrity: sha512-HTUrgRJ7r4dsZKU6GjmpfRK1O76h97Z8MfS1G0FozR+oF2kG6Vfe8JE6zwrkbxigziPHinCJ+gCPjA9EaBDtRw==}
|
||||
engines: {node: '>= 6'}
|
||||
dev: false
|
||||
|
||||
/cssesc@3.0.0:
|
||||
resolution: {integrity: sha512-/Tb/JcjK111nNScGob5MNtsntNM1aCNUDipB/TkwZFhyDrrE47SOx/18wF2bbjgc3ZzCSKW1T5nt5EbFoAz/Vg==}
|
||||
engines: {node: '>=4'}
|
||||
@@ -675,7 +1284,6 @@ packages:
|
||||
|
||||
/csstype@3.1.2:
|
||||
resolution: {integrity: sha512-I7K1Uu0MBPzaFKg4nI5Q7Vs2t+3gWWW648spaF+Rg7pI9ds18Ugn+lvg4SHczUdKlHI5LWBXyqfS8+DufyBsgQ==}
|
||||
dev: true
|
||||
|
||||
/damerau-levenshtein@1.0.8:
|
||||
resolution: {integrity: sha512-sdQSFB7+llfUcQHUQO3+B8ERRj0Oa4w9POWMI/puGtuf7gFywGmkaLCElnudfTiKZV+NvHqL0ifzdrI8Ro7ESA==}
|
||||
@@ -731,6 +1339,10 @@ packages:
|
||||
engines: {node: '>=6'}
|
||||
dev: true
|
||||
|
||||
/detect-node-es@1.1.0:
|
||||
resolution: {integrity: sha512-ypdmJU/TbBby2Dxibuv7ZLW3Bs1QEmM7nHjEANfohJLvE0XVujisn1qPJcZxg+qDucsr+bP6fLD1rPS3AhJ7EQ==}
|
||||
dev: false
|
||||
|
||||
/didyoumean@1.2.2:
|
||||
resolution: {integrity: sha512-gxtyfqMg7GKyhQmb056K7M3xszy/myH8w+B4RT+QXBQsvAOdc3XymqDDPHx1BgPgsdAA5SIifona89YtRATDzw==}
|
||||
|
||||
@@ -758,6 +1370,33 @@ packages:
|
||||
esutils: 2.0.3
|
||||
dev: true
|
||||
|
||||
/dom-serializer@2.0.0:
|
||||
resolution: {integrity: sha512-wIkAryiqt/nV5EQKqQpo3SToSOV9J0DnbJqwK7Wv/Trc92zIAYZ4FlMu+JPFW1DfGFt81ZTCGgDEabffXeLyJg==}
|
||||
dependencies:
|
||||
domelementtype: 2.3.0
|
||||
domhandler: 5.0.3
|
||||
entities: 4.5.0
|
||||
dev: false
|
||||
|
||||
/domelementtype@2.3.0:
|
||||
resolution: {integrity: sha512-OLETBj6w0OsagBwdXnPdN0cnMfF9opN69co+7ZrbfPGrdpPVNBUj02spi6B1N7wChLQiPn4CSH/zJvXw56gmHw==}
|
||||
dev: false
|
||||
|
||||
/domhandler@5.0.3:
|
||||
resolution: {integrity: sha512-cgwlv/1iFQiFnU96XXgROh8xTeetsnJiDsTc7TYCLFd9+/WNkIqPTxiM/8pSd8VIrhXGTf1Ny1q1hquVqDJB5w==}
|
||||
engines: {node: '>= 4'}
|
||||
dependencies:
|
||||
domelementtype: 2.3.0
|
||||
dev: false
|
||||
|
||||
/domutils@3.1.0:
|
||||
resolution: {integrity: sha512-H78uMmQtI2AhgDJjWeQmHwJJ2bLPD3GMmO7Zja/ZZh84wkm+4ut+IUnUdRa8uCGX88DiVx1j6FRe1XfxEgjEZA==}
|
||||
dependencies:
|
||||
dom-serializer: 2.0.0
|
||||
domelementtype: 2.3.0
|
||||
domhandler: 5.0.3
|
||||
dev: false
|
||||
|
||||
/electron-to-chromium@1.4.537:
|
||||
resolution: {integrity: sha512-W1+g9qs9hviII0HAwOdehGYkr+zt7KKdmCcJcjH0mYg6oL8+ioT3Skjmt7BLoAQqXhjf40AXd+HlR4oAWMlXjA==}
|
||||
dev: true
|
||||
@@ -774,6 +1413,11 @@ packages:
|
||||
tapable: 2.2.1
|
||||
dev: true
|
||||
|
||||
/entities@4.5.0:
|
||||
resolution: {integrity: sha512-V0hjH4dGPh9Ao5p0MoRY6BVqtwCjhz6vI5LT8AJ55H+4g9/4vbHx1I54fS0XuclLhDHArPQCiMjDxjaL8fPxhw==}
|
||||
engines: {node: '>=0.12'}
|
||||
dev: false
|
||||
|
||||
/es-abstract@1.22.2:
|
||||
resolution: {integrity: sha512-YoxfFcDmhjOgWPWsV13+2RNjq1F6UQnfs+8TftwNqtzlmFzEXvlUwdrNrYeaizfjQzRMxkZ6ElWMOJIFKdVqwA==}
|
||||
engines: {node: '>= 0.4'}
|
||||
@@ -1253,6 +1897,11 @@ packages:
|
||||
has-symbols: 1.0.3
|
||||
dev: true
|
||||
|
||||
/get-nonce@1.0.1:
|
||||
resolution: {integrity: sha512-FJhYRoDaiatfEkUK8HKlicmu/3SGFD51q3itKDGoSTysQJBnfOcxU5GxnhE1E6soB76MbT0MBtnKJuXyAx+96Q==}
|
||||
engines: {node: '>=6'}
|
||||
dev: false
|
||||
|
||||
/get-symbol-description@1.0.0:
|
||||
resolution: {integrity: sha512-2EmdH1YvIQiZpltCNgkuiUnyukzxM/R6NDJX31Ke3BG1Nq5b0S2PhX59UKi9vZpPDQVdqn+1IcaAwnzTT5vCjw==}
|
||||
engines: {node: '>= 0.4'}
|
||||
@@ -1392,6 +2041,11 @@ packages:
|
||||
dependencies:
|
||||
function-bind: 1.1.1
|
||||
|
||||
/he@1.2.0:
|
||||
resolution: {integrity: sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==}
|
||||
hasBin: true
|
||||
dev: false
|
||||
|
||||
/ignore@5.2.4:
|
||||
resolution: {integrity: sha512-MAb38BcSbH0eHNBxn7ql2NH/kX33OkB3lZ1BNdh7ENeRChHTYsTvWrMubiIAMNS2llXEEgZ1MUOBtXChP3kaFQ==}
|
||||
engines: {node: '>= 4'}
|
||||
@@ -1428,6 +2082,12 @@ packages:
|
||||
side-channel: 1.0.4
|
||||
dev: true
|
||||
|
||||
/invariant@2.2.4:
|
||||
resolution: {integrity: sha512-phJfQVBuaJM5raOpJjSfkiD6BpbCE4Ns//LaXl6wGYtUBY83nWS6Rf9tXm2e8VaK60JEjYldbPif/A2B1C2gNA==}
|
||||
dependencies:
|
||||
loose-envify: 1.4.0
|
||||
dev: false
|
||||
|
||||
/is-array-buffer@3.0.2:
|
||||
resolution: {integrity: sha512-y+FyyR/w8vfIRq4eQcM1EYgSTnmHXPqaF+IgzgraytCFq5Xh8lllDVmAZolPJiZttZLeFSINPYMaEJ7/vWUa1w==}
|
||||
dependencies:
|
||||
@@ -1792,6 +2452,13 @@ packages:
|
||||
- babel-plugin-macros
|
||||
dev: false
|
||||
|
||||
/node-html-parser@6.1.10:
|
||||
resolution: {integrity: sha512-6/uWdWxjQWQ7tMcFK2wWlrflsQUzh1HsEzlIf2j5+TtzfhT2yUvg3DwZYAmjEHeR3uX74ko7exjHW69J0tOzIg==}
|
||||
dependencies:
|
||||
css-select: 5.1.0
|
||||
he: 1.2.0
|
||||
dev: false
|
||||
|
||||
/node-releases@2.0.13:
|
||||
resolution: {integrity: sha512-uYr7J37ae/ORWdZeQ1xxMJe3NtdmqMC/JZK+geofDrkLUApKRHPd18/TxtBOJ4A0/+uUIliorNrfYV6s1b02eQ==}
|
||||
dev: true
|
||||
@@ -1805,6 +2472,12 @@ packages:
|
||||
engines: {node: '>=0.10.0'}
|
||||
dev: true
|
||||
|
||||
/nth-check@2.1.1:
|
||||
resolution: {integrity: sha512-lqjrjmaOoAnWfMmBPL+XNnynZh2+swxiX3WUE0s4yEHI6m+AwrK2UZOimIRl3X/4QctVqS8AiZjFqyOGrMXb/w==}
|
||||
dependencies:
|
||||
boolbase: 1.0.0
|
||||
dev: false
|
||||
|
||||
/object-assign@4.1.1:
|
||||
resolution: {integrity: sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==}
|
||||
engines: {node: '>=0.10.0'}
|
||||
@@ -2057,6 +2730,58 @@ packages:
|
||||
resolution: {integrity: sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ==}
|
||||
dev: true
|
||||
|
||||
/react-remove-scroll-bar@2.3.4(@types/react@18.2.24)(react@18.2.0):
|
||||
resolution: {integrity: sha512-63C4YQBUt0m6ALadE9XV56hV8BgJWDmmTPY758iIJjfQKt2nYwoUrPk0LXRXcB/yIj82T1/Ixfdpdk68LwIB0A==}
|
||||
engines: {node: '>=10'}
|
||||
peerDependencies:
|
||||
'@types/react': ^16.8.0 || ^17.0.0 || ^18.0.0
|
||||
react: ^16.8.0 || ^17.0.0 || ^18.0.0
|
||||
peerDependenciesMeta:
|
||||
'@types/react':
|
||||
optional: true
|
||||
dependencies:
|
||||
'@types/react': 18.2.24
|
||||
react: 18.2.0
|
||||
react-style-singleton: 2.2.1(@types/react@18.2.24)(react@18.2.0)
|
||||
tslib: 2.6.2
|
||||
dev: false
|
||||
|
||||
/react-remove-scroll@2.5.5(@types/react@18.2.24)(react@18.2.0):
|
||||
resolution: {integrity: sha512-ImKhrzJJsyXJfBZ4bzu8Bwpka14c/fQt0k+cyFp/PBhTfyDnU5hjOtM4AG/0AMyy8oKzOTR0lDgJIM7pYXI0kw==}
|
||||
engines: {node: '>=10'}
|
||||
peerDependencies:
|
||||
'@types/react': ^16.8.0 || ^17.0.0 || ^18.0.0
|
||||
react: ^16.8.0 || ^17.0.0 || ^18.0.0
|
||||
peerDependenciesMeta:
|
||||
'@types/react':
|
||||
optional: true
|
||||
dependencies:
|
||||
'@types/react': 18.2.24
|
||||
react: 18.2.0
|
||||
react-remove-scroll-bar: 2.3.4(@types/react@18.2.24)(react@18.2.0)
|
||||
react-style-singleton: 2.2.1(@types/react@18.2.24)(react@18.2.0)
|
||||
tslib: 2.6.2
|
||||
use-callback-ref: 1.3.0(@types/react@18.2.24)(react@18.2.0)
|
||||
use-sidecar: 1.1.2(@types/react@18.2.24)(react@18.2.0)
|
||||
dev: false
|
||||
|
||||
/react-style-singleton@2.2.1(@types/react@18.2.24)(react@18.2.0):
|
||||
resolution: {integrity: sha512-ZWj0fHEMyWkHzKYUr2Bs/4zU6XLmq9HsgBURm7g5pAVfyn49DgUiNgY2d4lXRlYSiCif9YBGpQleewkcqddc7g==}
|
||||
engines: {node: '>=10'}
|
||||
peerDependencies:
|
||||
'@types/react': ^16.8.0 || ^17.0.0 || ^18.0.0
|
||||
react: ^16.8.0 || ^17.0.0 || ^18.0.0
|
||||
peerDependenciesMeta:
|
||||
'@types/react':
|
||||
optional: true
|
||||
dependencies:
|
||||
'@types/react': 18.2.24
|
||||
get-nonce: 1.0.1
|
||||
invariant: 2.2.4
|
||||
react: 18.2.0
|
||||
tslib: 2.6.2
|
||||
dev: false
|
||||
|
||||
/react@18.2.0:
|
||||
resolution: {integrity: sha512-/3IjMdb2L9QbBdWiW5e3P2/npwMBaU9mHCSCUzNln0ZCYbcfTsGbTJrU/kGemdH2IWmB2ioZ+zkxtmq6g09fGQ==}
|
||||
engines: {node: '>=0.10.0'}
|
||||
@@ -2089,7 +2814,6 @@ packages:
|
||||
|
||||
/regenerator-runtime@0.14.0:
|
||||
resolution: {integrity: sha512-srw17NI0TUWHuGa5CFGGmhfNIeja30WMBfbslPNhf6JrqQlLN5gcrvig1oqPxiVaXb0oW0XRKtH6Nngs5lKCIA==}
|
||||
dev: true
|
||||
|
||||
/regexp.prototype.flags@1.5.1:
|
||||
resolution: {integrity: sha512-sy6TXMN+hnP/wMy+ISxg3krXx7BAtWVO4UouuCN/ziM9UEne0euamVNafDfvC83bRNr95y0V5iijeDQFUNpvrg==}
|
||||
@@ -2494,6 +3218,37 @@ packages:
|
||||
punycode: 2.3.0
|
||||
dev: true
|
||||
|
||||
/use-callback-ref@1.3.0(@types/react@18.2.24)(react@18.2.0):
|
||||
resolution: {integrity: sha512-3FT9PRuRdbB9HfXhEq35u4oZkvpJ5kuYbpqhCfmiZyReuRgpnhDlbr2ZEnnuS0RrJAPn6l23xjFg9kpDM+Ms7w==}
|
||||
engines: {node: '>=10'}
|
||||
peerDependencies:
|
||||
'@types/react': ^16.8.0 || ^17.0.0 || ^18.0.0
|
||||
react: ^16.8.0 || ^17.0.0 || ^18.0.0
|
||||
peerDependenciesMeta:
|
||||
'@types/react':
|
||||
optional: true
|
||||
dependencies:
|
||||
'@types/react': 18.2.24
|
||||
react: 18.2.0
|
||||
tslib: 2.6.2
|
||||
dev: false
|
||||
|
||||
/use-sidecar@1.1.2(@types/react@18.2.24)(react@18.2.0):
|
||||
resolution: {integrity: sha512-epTbsLuzZ7lPClpz2TyryBfztm7m+28DlEv2ZCQ3MDr5ssiwyOwGH/e5F9CkfWjJ1t4clvI58yF822/GUkjjhw==}
|
||||
engines: {node: '>=10'}
|
||||
peerDependencies:
|
||||
'@types/react': ^16.9.0 || ^17.0.0 || ^18.0.0
|
||||
react: ^16.8.0 || ^17.0.0 || ^18.0.0
|
||||
peerDependenciesMeta:
|
||||
'@types/react':
|
||||
optional: true
|
||||
dependencies:
|
||||
'@types/react': 18.2.24
|
||||
detect-node-es: 1.1.0
|
||||
react: 18.2.0
|
||||
tslib: 2.6.2
|
||||
dev: false
|
||||
|
||||
/util-deprecate@1.0.2:
|
||||
resolution: {integrity: sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==}
|
||||
|
||||
|
||||
361
src/app/agregator/mock.js
Normal file
361
src/app/agregator/mock.js
Normal file
@@ -0,0 +1,361 @@
|
||||
export const content = `<html><head><title>Расписание занятий</title>
|
||||
|
||||
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
|
||||
<link rel="StyleSheet" type="text/css" href="lib/css/wv_20230927.css">
|
||||
</head>
|
||||
<body bgcolor="#FFFFFF" text="#000000" link="#000000" vlink="#000000" alink="#ABB8DA" leftmargin="0" topmargin="0" marginwidth="0" marginheight="0">
|
||||
<table border="0" cellpadding="0" cellspacing="0" width="100%" bgcolor="3481A6"><tbody><tr><td height="30" align="right" bgcolor="ffffff" colspan="2" background="lib/img/itf_ht/mn_top_bg.gif"><a href="?mnt=2"></a><a href="?mnt=3"></a><table border="0" cellpadding="0" cellspacing="0"><tbody><tr><td background="lib/img/itf_ht/mn_top_bg.gif" align="right" bgcolor="ffffff" colspan="1"><a href="?mn=2" class="t_on"> Расписание занятий </a></td><td background="lib/img/itf_ht/mn_top_bg_btn.gif" align="right" bgcolor="ffffff"><img src="lib/img/itf_ht/mn_top_btn_r.gif"></td><td background="lib/img/itf_ht/mn_top_bg_btn.gif" align="right" bgcolor="ffffff"><a href="?mn=3" class="t_on">Расписание преподавателей</a></td><td background="lib/img/itf_ht/mn_top_bg_btn.gif" align="right" bgcolor="ffffff"><img src="lib/img/itf_ht/mn_top_btn_l.gif"><a href="?mnt=4"></a></td><td background="lib/img/itf_ht/mn_top_bg_btn.gif" align="right" bgcolor="ffffff"><img src="lib/img/itf_ht/mn_top_btn_r.gif"></td><td background="lib/img/itf_ht/mn_top_bg_btn.gif" align="right" bgcolor="ffffff"><a href="?mn=4" class="t_on"></a><a href="https://lk.ks.psuti.ru/std">Личный кабинет студента</a></td><td background="lib/img/itf_ht/mn_top_bg_btn.gif" align="right" bgcolor="ffffff"><img src="lib/img/itf_ht/mn_top_btn_l.gif"></td></tr></tbody></table></td></tr></tbody></table><center><a href="https://lk.ks.psuti.ru/lib/doc/lk_ks_psuti_manual.pdf" target="blank" class="t_green_14"><b><u><i>Инструкция: "Доступ в личный кабинет студента"</i></u></b></a><br>
|
||||
<a href="https://disk.yandex.ru/d/ioxTvdQXkPpU5w" target="_blank"><u><i>Расписание занятий на 1 семестр 2023-2024 уч. год (версия для печати)</i></u></a><br>
|
||||
<a href="https://disk.yandex.ru/i/WyzJ4DVeq5e_Vg" target="_blank"><u><i>График учебного процесса на 2023/2024 уч. год (версия для печати)</i></u></a><br>
|
||||
</center><br>
|
||||
<table border="0" cellpadding="0" cellspacing="0" width="100%" bgcolor="3481A6">
|
||||
<tbody><tr><td height="20" bgcolor="dddddd" align="center" colspan="7"><h7>Расписание занятий</h7></td></tr>
|
||||
<tr><td bgcolor="3481A6" align="center" colspan="7" background="lib/img/itf_ht/hr_b_01.gif"><img src="lib/img/itf_ht/hr_b_01.gif"></td></tr><tr><td height="10" bgcolor="ffffff" colspan="7" align="center">с 25.09.2023 по 01.10.2023
|
||||
</td></tr>
|
||||
<tr><td bgcolor="3481A6" align="center" colspan="7" background="lib/img/itf_ht/bg_h2_03.gif"><table border="0" cellpadding="0" cellspacing="0" bgcolor="ffffff">
|
||||
<tbody><tr><td width="1" valign="bottom" background="lib/img/itf_ht/bg_h2_03.gif"><a href="?mn=2&obj=146&wk=194"><img src="lib/img/itf_ht/frw_l.gif"></a></td><td height="20" bgcolor="3481A6" align="center" background="lib/img/itf_ht/bg_h2_03.gif"><a href="?mn=2&obj=146&wk=194"><h3>предыдущая неделя</h3></a></td><td width="1" valign="bottom" background="lib/img/itf_ht/bg_h2_03.gif"> </td><td width="1" valign="bottom" background="lib/img/itf_ht/bg_h2_03.gif"><img src="lib/img/itf_ht/rbl04.gif"></td><td width="1" valign="bottom" background="lib/img/itf_ht/bg_h2_03.gif"> </td><td width="1" valign="bottom" background="lib/img/itf_ht/bg_h2_03.gif"><img src="lib/img/itf_ht/rbl04.gif"></td><td width="1" valign="bottom" background="lib/img/itf_ht/bg_h2_03.gif"> </td><td height="20" bgcolor="3481A6" align="center" background="lib/img/itf_ht/bg_h2_03.gif"><a href="?mn=2&obj=146&wk=196"><h3>следующая неделя</h3></a></td><td width="1" valign="bottom" background="lib/img/itf_ht/bg_h2_03.gif"><a href="?mn=2&obj=146&wk=196"><img src="lib/img/itf_ht/frw_r.gif"></a></td></tr></tbody></table></td></tr>
|
||||
</tbody></table><table border="0" cellpadding="1" cellspacing="1" width="100%" bgcolor="3481A6">
|
||||
<tbody><tr><td height="20" bgcolor="ffffff" colspan="7"> <b>ПС-7</b></td></tr>
|
||||
<tr><td height="5" bgcolor="ffffff" colspan="7"></td></tr>
|
||||
<tr><td height="20" bgcolor="C0D8E3" colspan="7"><table border="0" cellpadding="0" cellspacing="0" bgcolor="ffffff">
|
||||
<tbody><tr><td bgcolor="3481A6"><h3>Понедельник 25.09.2023 / 4 неделя</h3></td><td bgcolor="C0D8E3"><img src="lib/img/itf_ht/days_bg.gif"></td></tr></tbody></table></td></tr>
|
||||
<tr align="center"><td bgcolor="ffffff"><b>№ пары</b></td>
|
||||
<td bgcolor="ffffff"><b>Время занятий</b></td>
|
||||
<td bgcolor="ffffff"><b>Способ</b></td>
|
||||
<td bgcolor="ffffff"><b>Дисциплина, преподаватель</b></td>
|
||||
<td bgcolor="ffffff"><b>Тема занятия</b></td>
|
||||
<td bgcolor="ffffff"><b>Ресурс</b></td>
|
||||
<td bgcolor="ffffff"><b>Задание для выполнения</b></td>
|
||||
</tr>
|
||||
<tr align="center"><td bgcolor="ffffff">1</td>
|
||||
<td bgcolor="ffffff">08:00 – 09:30
|
||||
</td>
|
||||
<td bgcolor="ffffff">Самостоятельная работа</td>
|
||||
<td bgcolor="ffffff">Физика<br>Кусаева Зарина Владимировна<font class="t_ur2"><br>Л. Толстого, 23<br>Кабинет: 410-2</font></td>
|
||||
<td bgcolor="ffffff">Силы в природе.</td>
|
||||
<td bgcolor="ffffff"><b><a href="https://cloud.mail.ru/public/eDk2/eV51SaUoU" target="blank">Лекция Задачи</a></b><br></td>
|
||||
<td bgcolor="ffffff">Сделать конспект по теме: выписать определения, формулы. Самостоятельно решить задачи.<br></td></tr>
|
||||
<tr align="center"><td bgcolor="ffffff">2</td>
|
||||
<td bgcolor="ffffff">09:40 – 11:10
|
||||
</td>
|
||||
<td bgcolor="ffffff"></td>
|
||||
<td bgcolor="ffffff">Математика<br>Амукова Светлана Николаевна<font class="t_ur2"><br>Л. Толстого, 23<br>Кабинет: 410-2</font></td>
|
||||
<td bgcolor="ffffff"></td>
|
||||
<td bgcolor="ffffff"></td>
|
||||
<td bgcolor="ffffff"><br></td></tr>
|
||||
<tr align="center"><td bgcolor="ffffff">3</td>
|
||||
<td bgcolor="ffffff">11:40 – 13:10
|
||||
</td>
|
||||
<td bgcolor="ffffff"></td>
|
||||
<td bgcolor="ffffff">Математика<br>Амукова Светлана Николаевна<font class="t_ur2"><br>Л. Толстого, 23<br>Кабинет: 410-2</font></td>
|
||||
<td bgcolor="ffffff"></td>
|
||||
<td bgcolor="ffffff"></td>
|
||||
<td bgcolor="ffffff"><br></td></tr>
|
||||
<tr align="center"><td bgcolor="ffffff">4</td>
|
||||
<td bgcolor="ffffff">13:20 – 14:50
|
||||
</td>
|
||||
<td bgcolor="ffffff"></td>
|
||||
<td bgcolor="ffffff">Химия<br>Тарасова Таисия Евгеньевна<font class="t_ur2"><br>Л. Толстого, 23<br>Кабинет: 410-2</font></td>
|
||||
<td bgcolor="ffffff"></td>
|
||||
<td bgcolor="ffffff"></td>
|
||||
<td bgcolor="ffffff"><br></td></tr>
|
||||
<tr><td height="5" bgcolor="ffffff" colspan="7"></td></tr>
|
||||
<tr><td height="20" bgcolor="C0D8E3" colspan="7"><table border="0" cellpadding="0" cellspacing="0" bgcolor="ffffff">
|
||||
<tbody><tr><td bgcolor="3481A6"><h3>Вторник 26.09.2023 / 4 неделя</h3></td><td bgcolor="C0D8E3"><img src="lib/img/itf_ht/days_bg.gif"></td></tr></tbody></table></td></tr>
|
||||
<tr align="center"><td bgcolor="ffffff"><b>№ пары</b></td>
|
||||
<td bgcolor="ffffff"><b>Время занятий</b></td>
|
||||
<td bgcolor="ffffff"><b>Способ</b></td>
|
||||
<td bgcolor="ffffff"><b>Дисциплина, преподаватель</b></td>
|
||||
<td bgcolor="ffffff"><b>Тема занятия</b></td>
|
||||
<td bgcolor="ffffff"><b>Ресурс</b></td>
|
||||
<td bgcolor="ffffff"><b>Задание для выполнения</b></td>
|
||||
</tr>
|
||||
<tr align="center"><td bgcolor="ffffff">3</td>
|
||||
<td bgcolor="ffffff">11:40 – 13:10
|
||||
</td>
|
||||
<td bgcolor="ffffff"></td>
|
||||
<td bgcolor="ffffff">История<br>Арефьев Андрей Андреевич<font class="t_green_10"><br>Московское шоссе, 120<br>Кабинет: 401</font></td>
|
||||
<td bgcolor="ffffff"></td>
|
||||
<td bgcolor="ffffff"></td>
|
||||
<td bgcolor="ffffff"><br></td></tr>
|
||||
<tr align="center"><td bgcolor="ffffbb">4</td>
|
||||
<td bgcolor="ffffbb">13:20 – 14:50
|
||||
<br><a class="t_zm">дистанционно</a></td>
|
||||
<td bgcolor="ffffbb"></td>
|
||||
<td bgcolor="ffffbb">Физическая культура<br> </td>
|
||||
<td bgcolor="ffffbb"></td>
|
||||
<td bgcolor="ffffbb"></td>
|
||||
<td bgcolor="ffffbb"><br></td></tr>
|
||||
<tr align="center"><td bgcolor="ffffff">5</td>
|
||||
<td bgcolor="ffffff">15:10 – 16:40
|
||||
</td>
|
||||
<td bgcolor="ffffff"></td>
|
||||
<td bgcolor="ffffff">Информатика<br>Ларионова Софья Николаевна<font class="t_green_10"><br>Московское шоссе, 120<br>Кабинет: 208</font></td>
|
||||
<td bgcolor="ffffff"></td>
|
||||
<td bgcolor="ffffff"></td>
|
||||
<td bgcolor="ffffff"><br></td></tr>
|
||||
<tr><td height="5" bgcolor="ffffff" colspan="7"></td></tr>
|
||||
<tr><td height="20" bgcolor="C0D8E3" colspan="7"><table border="0" cellpadding="0" cellspacing="0" bgcolor="ffffff">
|
||||
<tbody><tr><td bgcolor="3481A6"><h3>Среда 27.09.2023 / 4 неделя</h3></td><td bgcolor="C0D8E3"><img src="lib/img/itf_ht/days_bg.gif"></td></tr></tbody></table></td></tr>
|
||||
<tr align="center"><td bgcolor="ffffff"><b>№ пары</b></td>
|
||||
<td bgcolor="ffffff"><b>Время занятий</b></td>
|
||||
<td bgcolor="ffffff"><b>Способ</b></td>
|
||||
<td bgcolor="ffffff"><b>Дисциплина, преподаватель</b></td>
|
||||
<td bgcolor="ffffff"><b>Тема занятия</b></td>
|
||||
<td bgcolor="ffffff"><b>Ресурс</b></td>
|
||||
<td bgcolor="ffffff"><b>Задание для выполнения</b></td>
|
||||
</tr>
|
||||
<tr align="center"><td bgcolor="ffffff">3</td>
|
||||
<td bgcolor="ffffff">11:40 – 13:10
|
||||
</td>
|
||||
<td bgcolor="ffffff"></td>
|
||||
<td bgcolor="ffffff">Физика<br>Кусаева Зарина Владимировна<font class="t_green_10"><br>Московское шоссе, 120<br>Кабинет: 310</font></td>
|
||||
<td bgcolor="ffffff">Импульс. Закон сохранения импульса.</td>
|
||||
<td bgcolor="ffffff"></td>
|
||||
<td bgcolor="ffffff">Проверка конспекта и задач<br></td></tr>
|
||||
<tr align="center"><td bgcolor="ffffbb">4</td>
|
||||
<td bgcolor="ffffbb">13:20 – 14:50
|
||||
<br><a class="t_zm">перенос с 02.10.23</a></td>
|
||||
<td bgcolor="ffffbb"></td>
|
||||
<td bgcolor="ffffbb">Физика<br>Кусаева Зарина Владимировна<font class="t_green_10"><br>Московское шоссе, 120<br>Кабинет: 310</font></td>
|
||||
<td bgcolor="ffffbb">Закон сохранения энергии</td>
|
||||
<td bgcolor="ffffbb"></td>
|
||||
<td bgcolor="ffffbb"><br></td></tr>
|
||||
<tr align="center"><td bgcolor="ffffff">5</td>
|
||||
<td bgcolor="ffffff">15:10 – 16:40
|
||||
</td>
|
||||
<td bgcolor="ffffff"></td>
|
||||
<td bgcolor="ffffff">Иностранный язык<br>Карпеева Александра Сергеевна<font class="t_green_10"><br>Московское шоссе, 120<br>Кабинет: 234</font></td>
|
||||
<td bgcolor="ffffff"></td>
|
||||
<td bgcolor="ffffff"></td>
|
||||
<td bgcolor="ffffff"><br></td></tr>
|
||||
<tr align="center"><td bgcolor="ffffbb">6</td>
|
||||
<td bgcolor="ffffbb">16:50 – 18:20
|
||||
<br><a class="t_zm">дистанционно</a></td>
|
||||
<td bgcolor="ffffbb"></td>
|
||||
<td bgcolor="ffffbb">География<br> </td>
|
||||
<td bgcolor="ffffbb"></td>
|
||||
<td bgcolor="ffffbb"></td>
|
||||
<td bgcolor="ffffbb"><br></td></tr>
|
||||
<tr><td height="5" bgcolor="ffffff" colspan="7"></td></tr>
|
||||
<tr><td height="20" bgcolor="C0D8E3" colspan="7"><table border="0" cellpadding="0" cellspacing="0" bgcolor="ffffff">
|
||||
<tbody><tr><td bgcolor="3481A6"><h3>Четверг 28.09.2023 / 4 неделя</h3></td><td bgcolor="C0D8E3"><img src="lib/img/itf_ht/days_bg.gif"></td></tr></tbody></table></td></tr>
|
||||
<tr align="center"><td bgcolor="ffffff"><b>№ пары</b></td>
|
||||
<td bgcolor="ffffff"><b>Время занятий</b></td>
|
||||
<td bgcolor="ffffff"><b>Способ</b></td>
|
||||
<td bgcolor="ffffff"><b>Дисциплина, преподаватель</b></td>
|
||||
<td bgcolor="ffffff"><b>Тема занятия</b></td>
|
||||
<td bgcolor="ffffff"><b>Ресурс</b></td>
|
||||
<td bgcolor="ffffff"><b>Задание для выполнения</b></td>
|
||||
</tr>
|
||||
<tr align="center"><td bgcolor="ffffbb">2</td>
|
||||
<td bgcolor="ffffbb">09:40 – 11:10
|
||||
<br><a class="t_zm">дистанционно</a></td>
|
||||
<td bgcolor="ffffbb"></td>
|
||||
<td bgcolor="ffffbb">География<br> </td>
|
||||
<td bgcolor="ffffbb"></td>
|
||||
<td bgcolor="ffffbb"></td>
|
||||
<td bgcolor="ffffbb"><br></td></tr>
|
||||
<tr align="center"><td bgcolor="ffffff">3</td>
|
||||
<td bgcolor="ffffff">11:40 – 13:10
|
||||
</td>
|
||||
<td bgcolor="ffffff"></td>
|
||||
<td bgcolor="ffffff">Математика<br>Амукова Светлана Николаевна<font class="t_ur2"><br>Л. Толстого, 23<br>Кабинет: 410-2</font></td>
|
||||
<td bgcolor="ffffff"></td>
|
||||
<td bgcolor="ffffff"></td>
|
||||
<td bgcolor="ffffff"><br></td></tr>
|
||||
<tr align="center"><td bgcolor="ffffff">4</td>
|
||||
<td bgcolor="ffffff">13:20 – 14:50
|
||||
</td>
|
||||
<td bgcolor="ffffff">Очно</td>
|
||||
<td bgcolor="ffffff">Русский язык<br>Назарова Елена Федоровна<font class="t_ur2"><br>Л. Толстого, 23<br>Кабинет: 410-2</font></td>
|
||||
<td bgcolor="ffffff">Признаки заимствованного слова. Практическая работа 2</td>
|
||||
<td bgcolor="ffffff"><b><a href="https://cloud.mail.ru/public/7mwL/Ui6a7ftsP" target="blank">Практическая работа 2</a></b><br></td>
|
||||
<td bgcolor="ffffff"><br></td></tr>
|
||||
<tr align="center"><td bgcolor="ffffff">5</td>
|
||||
<td bgcolor="ffffff">15:10 – 16:40
|
||||
</td>
|
||||
<td bgcolor="ffffff">Очно</td>
|
||||
<td bgcolor="ffffff">Литература<br>Назарова Елена Федоровна<font class="t_ur2"><br>Л. Толстого, 23<br>Кабинет: 410-2</font></td>
|
||||
<td bgcolor="ffffff">Роман И. А. Гончарова "Обломов"</td>
|
||||
<td bgcolor="ffffff"><b><a href="https://cloud.mail.ru/public/5f3Y/vYGed416U" target="blank">лекция</a></b><br></td>
|
||||
<td bgcolor="ffffff">пересказ лекции, ответить на вопросы викторины<br></td></tr>
|
||||
<tr><td height="5" bgcolor="ffffff" colspan="7"></td></tr>
|
||||
<tr><td height="20" bgcolor="C0D8E3" colspan="7"><table border="0" cellpadding="0" cellspacing="0" bgcolor="ffffff">
|
||||
<tbody><tr><td bgcolor="3481A6"><h3>Пятница 29.09.2023 / 5 неделя</h3></td><td bgcolor="C0D8E3"><img src="lib/img/itf_ht/days_bg.gif"></td></tr></tbody></table></td></tr>
|
||||
<tr align="center"><td bgcolor="ffffff"><b>№ пары</b></td>
|
||||
<td bgcolor="ffffff"><b>Время занятий</b></td>
|
||||
<td bgcolor="ffffff"><b>Способ</b></td>
|
||||
<td bgcolor="ffffff"><b>Дисциплина, преподаватель</b></td>
|
||||
<td bgcolor="ffffff"><b>Тема занятия</b></td>
|
||||
<td bgcolor="ffffff"><b>Ресурс</b></td>
|
||||
<td bgcolor="ffffff"><b>Задание для выполнения</b></td>
|
||||
</tr>
|
||||
<tr align="center"><td bgcolor="ffffff">2</td>
|
||||
<td bgcolor="ffffff">09:40 – 11:10
|
||||
</td>
|
||||
<td bgcolor="ffffff">Очно</td>
|
||||
<td bgcolor="ffffff">Русский язык<br>Назарова Елена Федоровна<font class="t_green_10"><br>Московское шоссе, 120<br>Кабинет: 324</font></td>
|
||||
<td bgcolor="ffffff">Язык как система</td>
|
||||
<td bgcolor="ffffff"><b><a href="https://cloud.mail.ru/public/EBc5/MYaGgXqKe" target="blank">презентация</a></b><br></td>
|
||||
<td bgcolor="ffffff">изучить презентацию, выучить определения<br></td></tr>
|
||||
<tr align="center"><td bgcolor="ffffff">3</td>
|
||||
<td bgcolor="ffffff">11:40 – 13:10
|
||||
</td>
|
||||
<td bgcolor="ffffff">Очно</td>
|
||||
<td bgcolor="ffffff">Литература<br>Назарова Елена Федоровна<font class="t_green_10"><br>Московское шоссе, 120<br>Кабинет: 321</font></td>
|
||||
<td bgcolor="ffffff">"Илья Ильич Обломов как временной тип и одна из граней национального характера"</td>
|
||||
<td bgcolor="ffffff"></td>
|
||||
<td bgcolor="ffffff">написать сочинение на тему "Что во мне есть от Обломова"<br></td></tr>
|
||||
<tr><td height="5" bgcolor="ffffff" colspan="7"></td></tr>
|
||||
<tr><td height="20" bgcolor="C0D8E3" colspan="7"><table border="0" cellpadding="0" cellspacing="0" bgcolor="ffffff">
|
||||
<tbody><tr><td bgcolor="3481A6"><h3>Суббота 30.09.2023 / 5 неделя</h3></td><td bgcolor="C0D8E3"><img src="lib/img/itf_ht/days_bg.gif"></td></tr></tbody></table></td></tr>
|
||||
<tr align="center"><td bgcolor="ffffff"><b>№ пары</b></td>
|
||||
<td bgcolor="ffffff"><b>Время занятий</b></td>
|
||||
<td bgcolor="ffffff"><b>Способ</b></td>
|
||||
<td bgcolor="ffffff"><b>Дисциплина, преподаватель</b></td>
|
||||
<td bgcolor="ffffff"><b>Тема занятия</b></td>
|
||||
<td bgcolor="ffffff"><b>Ресурс</b></td>
|
||||
<td bgcolor="ffffff"><b>Задание для выполнения</b></td>
|
||||
</tr>
|
||||
<tr align="center"><td bgcolor="ffffff">1</td>
|
||||
<td bgcolor="ffffff">08:00 – 09:30
|
||||
</td>
|
||||
<td bgcolor="ffffff"></td>
|
||||
<td bgcolor="ffffff">Основы безопасности жизнедеятельности<br>Корнилова Светлана Александровна<font class="t_green_10"><br>Московское шоссе, 120<br>Кабинет: 110</font></td>
|
||||
<td bgcolor="ffffff">Пр№1 Обеспечение личной безопасности на дорогах</td>
|
||||
<td bgcolor="ffffff"></td>
|
||||
<td bgcolor="ffffff">оформить отчет<br></td></tr>
|
||||
<tr align="center"><td bgcolor="ffffff">2</td>
|
||||
<td bgcolor="ffffff">09:40 – 11:10
|
||||
</td>
|
||||
<td bgcolor="ffffff">Очно</td>
|
||||
<td bgcolor="ffffff">Литература<br>Назарова Елена Федоровна<font class="t_green_10"><br>Московское шоссе, 120<br>Кабинет: 321</font></td>
|
||||
<td bgcolor="ffffff">Новый герой, «отрицающий все», в романе И. С. Тургенева (1818- 1883) «Отцы и дети»</td>
|
||||
<td bgcolor="ffffff"></td>
|
||||
<td bgcolor="ffffff">читать роман "Отцы и дети"<br></td></tr>
|
||||
<tr align="center"><td bgcolor="ffffff">3</td>
|
||||
<td bgcolor="ffffff">11:30 – 13:00
|
||||
</td>
|
||||
<td bgcolor="ffffff"></td>
|
||||
<td bgcolor="ffffff"><i>Свободное время</i><br> </td>
|
||||
<td bgcolor="ffffff"></td>
|
||||
<td bgcolor="ffffff"></td>
|
||||
<td bgcolor="ffffff"><br></td></tr>
|
||||
|
||||
<tr><td height="5" bgcolor="ffffff" colspan="7"></td></tr>
|
||||
</tbody></table><table border="0" cellpadding="0" cellspacing="0" width="100%" bgcolor="3481A6">
|
||||
<tbody><tr><td bgcolor="3481A6" align="center" colspan="7" background="lib/img/itf_ht/bg_h2_03.gif"><table border="0" cellpadding="0" cellspacing="0" bgcolor="ffffff">
|
||||
<tbody><tr><td width="1" valign="bottom" background="lib/img/itf_ht/bg_h2_03.gif"><a href="?mn=2&obj=146&wk=194"><img src="lib/img/itf_ht/frw_l.gif"></a></td><td height="20" bgcolor="3481A6" align="center" background="lib/img/itf_ht/bg_h2_03.gif"><a href="?mn=2&obj=146&wk=194"><h3>предыдущая неделя</h3></a></td><td width="1" valign="bottom" background="lib/img/itf_ht/bg_h2_03.gif"> </td><td width="1" valign="bottom" background="lib/img/itf_ht/bg_h2_03.gif"><img src="lib/img/itf_ht/rbl04.gif"></td><td width="1" valign="bottom" background="lib/img/itf_ht/bg_h2_03.gif"> </td><td width="1" valign="bottom" background="lib/img/itf_ht/bg_h2_03.gif"><img src="lib/img/itf_ht/rbl04.gif"></td><td width="1" valign="bottom" background="lib/img/itf_ht/bg_h2_03.gif"> </td><td height="20" bgcolor="3481A6" align="center" background="lib/img/itf_ht/bg_h2_03.gif"><a href="?mn=2&obj=146&wk=196"><h3>следующая неделя</h3></a></td><td width="1" valign="bottom" background="lib/img/itf_ht/bg_h2_03.gif"><a href="?mn=2&obj=146&wk=196"><img src="lib/img/itf_ht/frw_r.gif"></a></td></tr></tbody></table></td></tr>
|
||||
</tbody></table><br><table border="0" cellpadding="0" cellspacing="0" width="100%" bgcolor="ffffff">
|
||||
<tbody><tr><td height="20" bgcolor="dddddd" align="center" colspan="8"><h7>Дневное отделение:</h7></td></tr>
|
||||
<tr><td bgcolor="3481A6" align="center" colspan="8" background="lib/img/itf_ht/hr_b_01.gif"><img src="lib/img/itf_ht/hr_b_01.gif"></td></tr><tr><td height="20" bgcolor="3481A6" align="center" colspan="8" background="lib/img/itf_ht/bg_h2_03.gif"><h3>Выберите группу:</h3></td></tr>
|
||||
<tr><td bgcolor="3481A6" align="center" colspan="8" background="lib/img/itf_ht/hr_b_03.gif"><img src="lib/img/itf_ht/hr_b_03.gif"></td></tr><tr><td bgcolor="3481A6" valign="bottom" colspan="2"><img src="lib/img/itf_ht/rtl02.gif"></td><td bgcolor="3481A6" valign="bottom" colspan="2"><img src="lib/img/itf_ht/rtl02.gif"></td><td bgcolor="3481A6" valign="bottom" colspan="2"><img src="lib/img/itf_ht/rtl02.gif"></td><td bgcolor="3481A6" valign="bottom" colspan="2"><img src="lib/img/itf_ht/rtl02.gif"></td></tr><tr><td width="1" valign="bottom"><img src="lib/img/itf_ht/rbl04.gif"></td><td height="20" width="25%" bgcolor="3481A6" align="center" background="lib/img/itf_ht/bg_h2_02.gif"><h3>Первый курс:</h3></td><td width="1" valign="bottom"><img src="lib/img/itf_ht/rbl04.gif"></td><td height="20" width="25%" bgcolor="3481A6" align="center" background="lib/img/itf_ht/bg_h2_02.gif"><h3>Второй курс:</h3></td><td width="1" valign="bottom"><img src="lib/img/itf_ht/rbl04.gif"></td><td height="20" width="25%" bgcolor="3481A6" align="center" background="lib/img/itf_ht/bg_h2_02.gif"><h3>Третий курс:</h3></td><td width="1" valign="bottom"><img src="lib/img/itf_ht/rbl04.gif"></td><td height="20" width="25%" bgcolor="3481A6" align="center" background="lib/img/itf_ht/bg_h2_02.gif"><h3>Четвертый курс:</h3></td></tr>
|
||||
<tr><td width="1" valign="bottom"></td><td width="25%" bgcolor="ffffff" align="center" valign="top"><table border="0" cellpadding="0" cellspacing="0" width="100%"><tbody><tr><td><table border="0" cellpadding="1" cellspacing="1" width="100%" bgcolor="3481A6">
|
||||
<tbody><tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=144"><b>ИБ-5</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=145"><b>ИБ-6</b></a> </td></tr>
|
||||
<tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=152"><b>ИКС-6</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=153"><b>ИКС-7к</b></a> </td></tr>
|
||||
<tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=150"><b>ИСПВ-6</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=151"><b>ИСПВ-7</b></a> </td></tr>
|
||||
<tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=161"><b>ИСПВ-8к</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=154"><b>ИСПИ-5</b></a> </td></tr>
|
||||
<tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=155"><b>ИСПИ-6к</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=156"><b>ИСПП-22</b></a> </td></tr>
|
||||
<tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=157"><b>ИСПП-23</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=158"><b>ИСПП-24к</b></a> </td></tr>
|
||||
<tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=159"><b>ИСПП-25к</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=160"><b>ИСПП-26к</b></a> </td></tr>
|
||||
<tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=163"><b>ИСПП-27к</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=146"><b>ПС-7</b></a> </td></tr>
|
||||
<tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=162"><b>СБ-1к</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=147"><b>ССА-10</b></a> </td></tr>
|
||||
<tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=148"><b>ССА-11</b></a> </td></tr>
|
||||
</tbody></table></td></tr><tr><td align="right" colspan="8" background="lib/img/itf_ht/hr_b_04.gif"><img src="lib/img/itf_ht/hr_b_05.gif"></td></tr></tbody></table></td>
|
||||
<td width="1" valign="bottom"></td><td width="25%" bgcolor="ffffff" align="center" valign="top"><table border="0" cellpadding="0" cellspacing="0" width="100%"><tbody><tr><td><table border="0" cellpadding="1" cellspacing="1" width="100%" bgcolor="3481A6">
|
||||
<tbody><tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=123"><b>ИБ-3</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=138"><b>ИБ-4к</b></a> </td></tr>
|
||||
<tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=124"><b>ИКС-4</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=126"><b>ИКС-5к</b></a> </td></tr>
|
||||
<tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=127"><b>ИСПВ-4</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=128"><b>ИСПВ-5к</b></a> </td></tr>
|
||||
<tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=129"><b>ИСПИ-3</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=130"><b>ИСПИ-4к</b></a> </td></tr>
|
||||
<tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=131"><b>ИСПП-16</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=132"><b>ИСПП-17</b></a> </td></tr>
|
||||
<tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=133"><b>ИСПП-18к</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=134"><b>ИСПП-19к</b></a> </td></tr>
|
||||
<tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=140"><b>ИСПП-20к</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=141"><b>ИСПП-21к</b></a> </td></tr>
|
||||
<tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=135"><b>ПС-6</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=136"><b>ССА-7</b></a> </td></tr>
|
||||
<tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=137"><b>ССА-8к</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=149"><b>ССА-9к</b></a> </td></tr>
|
||||
</tbody></table></td></tr><tr><td align="right" colspan="8" background="lib/img/itf_ht/hr_b_04.gif"><img src="lib/img/itf_ht/hr_b_05.gif"></td></tr></tbody></table></td>
|
||||
<td width="1" valign="bottom"></td><td width="25%" bgcolor="ffffff" align="center" valign="top"><table border="0" cellpadding="0" cellspacing="0" width="100%"><tbody><tr><td><table border="0" cellpadding="1" cellspacing="1" width="100%" bgcolor="3481A6">
|
||||
<tbody><tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=114"><b>ИБ-1к</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=115"><b>ИБ-2к</b></a> </td></tr>
|
||||
<tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=117"><b>ИКС-2</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=121"><b>ИКС-3к</b></a> </td></tr>
|
||||
<tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=111"><b>ИСПВ-1</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=112"><b>ИСПВ-2к</b></a> </td></tr>
|
||||
<tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=113"><b>ИСПВ-3к</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=109"><b>ИСПИ-1</b></a> </td></tr>
|
||||
<tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=110"><b>ИСПИ-2к</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=105"><b>ИСПП-11</b></a> </td></tr>
|
||||
<tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=106"><b>ИСПП-12</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=107"><b>ИСПП-13к</b></a> </td></tr>
|
||||
<tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=108"><b>ИСПП-14к</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=122"><b>ИСПП-15к</b></a> </td></tr>
|
||||
<tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=116"><b>ПС-5</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=102"><b>ССА-4</b></a> </td></tr>
|
||||
<tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=103"><b>ССА-5</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=104"><b>ССА-6к</b></a> </td></tr>
|
||||
</tbody></table></td></tr><tr><td align="right" colspan="8" background="lib/img/itf_ht/hr_b_04.gif"><img src="lib/img/itf_ht/hr_b_05.gif"></td></tr></tbody></table></td>
|
||||
<td width="1" valign="bottom"></td><td width="25%" bgcolor="ffffff" align="center" valign="top"><table border="0" cellpadding="0" cellspacing="0" width="100%"><tbody><tr><td><table border="0" cellpadding="1" cellspacing="1" width="100%" bgcolor="3481A6">
|
||||
<tbody><tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=101"><b>ИКС-1</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=67"><b>ИС-21</b></a> </td></tr>
|
||||
<tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=68"><b>ИС-22</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=70"><b>ИСПП-5</b></a> </td></tr>
|
||||
<tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=71"><b>ИСПП-6</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=72"><b>ИСПП-7к</b></a> </td></tr>
|
||||
<tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=73"><b>ИСПП-8к</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=74"><b>ИСПП-9к</b></a> </td></tr>
|
||||
<tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=75"><b>МТС-78</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=76"><b>ПКС-33</b></a> </td></tr>
|
||||
<tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=77"><b>ПКС-34</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=78"><b>ПКС-35к</b></a> </td></tr>
|
||||
<tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=80"><b>СК-69</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=81"><b>ССА-1к</b></a> </td></tr>
|
||||
<tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=100"><b>ССА-3к</b></a> </td></tr>
|
||||
</tbody></table></td></tr><tr><td align="right" colspan="8" background="lib/img/itf_ht/hr_b_04.gif"><img src="lib/img/itf_ht/hr_b_05.gif"></td></tr></tbody></table></td>
|
||||
</tr>
|
||||
</tbody></table><br><table border="0" cellpadding="0" cellspacing="0" width="100%" bgcolor="ffffff">
|
||||
<tbody><tr><td height="20" bgcolor="dddddd" align="center" colspan="12"><h7>Заочное отделение:</h7></td></tr>
|
||||
<tr><td bgcolor="3481A6" align="center" colspan="12" background="lib/img/itf_ht/hr_b_01.gif"><img src="lib/img/itf_ht/hr_b_01.gif"></td></tr><tr><td height="20" bgcolor="3481A6" align="center" colspan="12" background="lib/img/itf_ht/bg_h2_03.gif"><h3>Выберите группу:</h3></td></tr>
|
||||
<tr><td bgcolor="3481A6" align="center" colspan="12" background="lib/img/itf_ht/hr_b_03.gif"><img src="lib/img/itf_ht/hr_b_03.gif"></td></tr><tr><td bgcolor="3481A6" valign="bottom" colspan="2"><img src="lib/img/itf_ht/rtl02.gif"></td><td bgcolor="3481A6" valign="bottom" colspan="2"><img src="lib/img/itf_ht/rtl02.gif"></td><td bgcolor="3481A6" valign="bottom" colspan="2"><img src="lib/img/itf_ht/rtl02.gif"></td><td bgcolor="3481A6" valign="bottom" colspan="2"><img src="lib/img/itf_ht/rtl02.gif"></td><td bgcolor="3481A6" valign="bottom" colspan="2"><img src="lib/img/itf_ht/rtl02.gif"></td></tr><tr><td width="1" valign="bottom"><img src="lib/img/itf_ht/rbl04.gif"></td><td height="20" width="20%" bgcolor="3481A6" align="center" background="lib/img/itf_ht/bg_h2_02.gif"><h3>Первый курс:</h3></td><td width="1" valign="bottom"><img src="lib/img/itf_ht/rbl04.gif"></td>
|
||||
<td height="20" width="20%" bgcolor="3481A6" align="center" background="lib/img/itf_ht/bg_h2_02.gif"><h3>Второй курс:</h3></td><td width="1" valign="bottom"><img src="lib/img/itf_ht/rbl04.gif"></td>
|
||||
<td height="20" width="20%" bgcolor="3481A6" align="center" background="lib/img/itf_ht/bg_h2_02.gif"><h3>Третий курс:</h3></td><td width="1" valign="bottom"><img src="lib/img/itf_ht/rbl04.gif"></td>
|
||||
<td height="20" width="20%" bgcolor="3481A6" align="center" background="lib/img/itf_ht/bg_h2_02.gif"><h3>Четвертый курс:</h3></td><td width="1" valign="bottom"><img src="lib/img/itf_ht/rbl04.gif"></td>
|
||||
<td height="20" width="20%" bgcolor="3481A6" align="center" background="lib/img/itf_ht/bg_h2_02.gif"><h3>Пятый курс:</h3></td></tr>
|
||||
<tr><td width="1" valign="bottom"></td><td width="20%" bgcolor="ffffff" align="center" valign="top"><table border="0" cellpadding="0" cellspacing="0" width="100%"><tbody><tr><td><table border="0" cellpadding="1" cellspacing="1" width="100%" bgcolor="3481A6">
|
||||
<tbody><tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=166"><b>(з/о)иксс-23</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=165"><b>(з/о)ПС-23к</b></a> </td></tr>
|
||||
</tbody></table></td></tr><tr><td align="right" colspan="8" background="lib/img/itf_ht/hr_b_04.gif"><img src="lib/img/itf_ht/hr_b_05.gif"></td></tr></tbody></table></td>
|
||||
<td width="1" valign="bottom"></td><td width="20%" bgcolor="ffffff" align="center" valign="top"><table border="0" cellpadding="0" cellspacing="0" width="100%"><tbody><tr><td><table border="0" cellpadding="1" cellspacing="1" width="100%" bgcolor="3481A6">
|
||||
<tbody><tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=142"><b>(з/о)ИКСС-22к</b></a> </td></tr>
|
||||
</tbody></table></td></tr><tr><td align="right" colspan="8" background="lib/img/itf_ht/hr_b_04.gif"><img src="lib/img/itf_ht/hr_b_05.gif"></td></tr></tbody></table></td>
|
||||
<td width="1" valign="bottom"></td><td width="20%" bgcolor="ffffff" align="center" valign="top"><table border="0" cellpadding="0" cellspacing="0" width="100%"><tbody><tr><td><table border="0" cellpadding="1" cellspacing="1" width="100%" bgcolor="3481A6">
|
||||
<tbody><tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=118"><b>(з/о)ИКСС-21к</b></a> </td></tr>
|
||||
<tr><td bgcolor="dddddd" align="center"><a href="?mn=2&obj=143"><b>(з/о)ПС-22к</b></a> </td></tr>
|
||||
</tbody></table></td></tr><tr><td align="right" colspan="8" background="lib/img/itf_ht/hr_b_04.gif"><img src="lib/img/itf_ht/hr_b_05.gif"></td></tr></tbody></table></td>
|
||||
<td width="1" valign="bottom"></td><td width="20%" bgcolor="ffffff" align="center" valign="top"><table border="0" cellpadding="0" cellspacing="0" width="100%"><tbody><tr><td><table border="0" cellpadding="1" cellspacing="1" width="100%" bgcolor="3481A6">
|
||||
<tbody><tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=87"><b>(з/о)ПКС-20</b></a> </td></tr>
|
||||
</tbody></table></td></tr><tr><td align="right" colspan="8" background="lib/img/itf_ht/hr_b_04.gif"><img src="lib/img/itf_ht/hr_b_05.gif"></td></tr></tbody></table></td>
|
||||
<td width="1" valign="bottom"></td><td width="20%" bgcolor="ffffff" align="center" valign="top"><table border="0" cellpadding="0" cellspacing="0" width="100%"><tbody><tr><td><table border="0" cellpadding="1" cellspacing="1" width="100%" bgcolor="3481A6">
|
||||
<tbody><tr><td bgcolor="eeeeee" align="center"><a href="?mn=2&obj=46"><b>(з/о)ПКС-19</b></a> </td></tr>
|
||||
</tbody></table></td></tr><tr><td align="right" colspan="8" background="lib/img/itf_ht/hr_b_04.gif"><img src="lib/img/itf_ht/hr_b_05.gif"></td></tr></tbody></table></td>
|
||||
</tr>
|
||||
</tbody></table><br>
|
||||
|
||||
</body></html>`
|
||||
21
src/app/agregator/schedule.ts
Normal file
21
src/app/agregator/schedule.ts
Normal file
@@ -0,0 +1,21 @@
|
||||
import { Day } from '@/shared/model/day'
|
||||
import { parsePage } from '@/app/parser/schedule'
|
||||
import contentTypeParser from 'content-type'
|
||||
import { parse } from 'node-html-parser'
|
||||
import { content as mockContent } from './mock'
|
||||
|
||||
// ПС-7: 146
|
||||
export async function getSchedule(groupID: number): Promise<Day[]> {
|
||||
// const page = await fetch(`https://lk.ks.psuti.ru/?mn=2&obj=${groupID}`)
|
||||
const page = { text: async () => mockContent, status: 200, headers: { get: (s: string) => s && 'text/html' } }
|
||||
const content = await page.text()
|
||||
const contentType = page.headers.get('content-type')
|
||||
if (page.status === 200 && contentType && contentTypeParser.parse(contentType).type === 'text/html') {
|
||||
const root = parse(content)
|
||||
return parsePage(root)
|
||||
} else {
|
||||
console.error(page.status, contentType)
|
||||
console.error(content.length > 500 ? content.slice(0, 500 - 3) + '...' : content)
|
||||
throw new Error('Error while fetching lk.ks.psuti.ru')
|
||||
}
|
||||
}
|
||||
97
src/app/parser/schedule.ts
Normal file
97
src/app/parser/schedule.ts
Normal file
@@ -0,0 +1,97 @@
|
||||
import { Day } from '@/shared/model/day'
|
||||
import { Lesson } from '@/shared/model/lesson'
|
||||
import { HTMLElement } from 'node-html-parser'
|
||||
|
||||
const dayTitleParser = (text: string) => {
|
||||
const [dateString, week] = text.trim().split(' / ')
|
||||
const weekNumber = Number(week.trim().match(/^(\d+) неделя$/)![1])
|
||||
const [, day, month, year] = dateString.trim().match(/^[а-яА-Я]+ (\d{1,2})\.(\d{1,2})\.(\d{4})$/)!
|
||||
const date = new Date(Number(year), Number(month) - 1, Number(day), 12)
|
||||
return { date, weekNumber }
|
||||
}
|
||||
|
||||
const parseLesson = (row: HTMLElement): Lesson => {
|
||||
const cells = row.querySelectorAll(':scope > td')
|
||||
|
||||
const isChange = cells.every(td => td.getAttribute('bgcolor') === 'ffffbb')
|
||||
|
||||
const timeCell = cells[1].childNodes
|
||||
const [startTime, endTime] = timeCell[0].textContent.trim().split(' – ')
|
||||
const time: Lesson['time'] = {
|
||||
start: startTime,
|
||||
end: endTime
|
||||
}
|
||||
if (timeCell[2]) {
|
||||
time.hint = timeCell[2].textContent.trim()
|
||||
}
|
||||
|
||||
const subject = ''
|
||||
const teacher = ''
|
||||
|
||||
const place: Lesson['place'] = {
|
||||
address: '1',
|
||||
classroom: 1
|
||||
}
|
||||
|
||||
const topic = cells[4].textContent.trim()
|
||||
|
||||
const resources: Lesson['resources'] = []
|
||||
// {
|
||||
// type: 'link'
|
||||
// title: string
|
||||
// url: string
|
||||
// } []
|
||||
|
||||
return {
|
||||
isChange,
|
||||
time,
|
||||
type: cells[2].textContent.trim(),
|
||||
subject,
|
||||
teacher,
|
||||
place,
|
||||
...(topic && { topic }),
|
||||
resources,
|
||||
homework: cells[6].textContent.trim()
|
||||
}
|
||||
}
|
||||
|
||||
export function parsePage(document: HTMLElement): Day[] {
|
||||
const tables = Array.from(document.querySelectorAll('body > table'))
|
||||
const table = tables.find(table => table.querySelector(':scope > tbody > tr:first-child')?.textContent?.trim() === 'ПС-7')
|
||||
const rows = Array.from(table!.querySelectorAll(':scope > tbody > tr')).slice(1)
|
||||
|
||||
const days = []
|
||||
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
||||
// @ts-ignore
|
||||
let dayInfo: Day = {}
|
||||
let dayLessons: Lesson[] = []
|
||||
let previousRowIsDayTitle = false
|
||||
for (let i = 0; i < rows.length; i++) {
|
||||
const row = rows[i]
|
||||
|
||||
const isDivider = row.textContent?.trim() === ''
|
||||
const isDayTitle = dayLessons.length === 0 && !('date' in dayInfo)
|
||||
const isTableHeader = previousRowIsDayTitle
|
||||
|
||||
if (isDivider) {
|
||||
days.push({ ...dayInfo, lessons: dayLessons })
|
||||
dayLessons = []
|
||||
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
||||
// @ts-ignore
|
||||
dayInfo = {}
|
||||
previousRowIsDayTitle = false
|
||||
} else if (isTableHeader) {
|
||||
previousRowIsDayTitle = false
|
||||
continue
|
||||
} else if (isDayTitle) {
|
||||
const { date, weekNumber } = dayTitleParser(row.querySelector('h3')!.textContent!)
|
||||
dayInfo.date = date
|
||||
dayInfo.weekNumber = weekNumber
|
||||
previousRowIsDayTitle = true
|
||||
} else {
|
||||
dayLessons.push(parseLesson(row))
|
||||
}
|
||||
}
|
||||
|
||||
return days
|
||||
}
|
||||
44
src/app/utils/date-serializer.ts
Normal file
44
src/app/utils/date-serializer.ts
Normal file
@@ -0,0 +1,44 @@
|
||||
const isDate = (value: any): boolean => Object.prototype.toString.call(value) === '[object Date]'
|
||||
|
||||
export const nextSerialized = (obj: any): any => {
|
||||
if (Array.isArray(obj)) {
|
||||
return obj.map(nextSerialized)
|
||||
}
|
||||
|
||||
if (typeof obj === 'object' && obj !== null) {
|
||||
const newObj: any = {}
|
||||
for (const [key, value] of Object.entries(obj)) {
|
||||
newObj[key] = isDate(value as Date) ? (value as Date).toISOString() : nextSerialized(value)
|
||||
}
|
||||
return newObj
|
||||
}
|
||||
|
||||
return obj
|
||||
}
|
||||
|
||||
const looksLikeISODate = (value: string): boolean => /^(\d{4})-(\d{2})-(\d{2})T(\d{2}):(\d{2}):(\d{2}(?:\.\d*)?)Z?$/.test(value)
|
||||
|
||||
export const nextDeserializer = (obj: any): any => {
|
||||
if (Array.isArray(obj)) {
|
||||
return obj.map(nextDeserializer)
|
||||
}
|
||||
|
||||
if (typeof obj === 'object' && obj !== null) {
|
||||
const newObj: any = {}
|
||||
for (const [key, value] of Object.entries(obj)) {
|
||||
newObj[key] = typeof value === 'string' && looksLikeISODate(value) ? new Date(value) : nextDeserializer(value)
|
||||
}
|
||||
return newObj
|
||||
}
|
||||
|
||||
return obj
|
||||
}
|
||||
|
||||
|
||||
export type NextSerialized<T> = {
|
||||
[K in keyof T]:
|
||||
T[K] extends Date ? string :
|
||||
T[K] extends Array<infer U> ? NextSerialized<U>[] :
|
||||
T[K] extends object ? NextSerialized<T[K]> :
|
||||
T[K]
|
||||
};
|
||||
@@ -1,4 +1,4 @@
|
||||
import '@/styles/globals.css'
|
||||
import '@/shared/styles/globals.css'
|
||||
import type { AppProps } from 'next/app'
|
||||
|
||||
export default function App({ Component, pageProps }: AppProps) {
|
||||
|
||||
@@ -1,118 +1,27 @@
|
||||
import Image from 'next/image'
|
||||
import { Inter } from 'next/font/google'
|
||||
import { Schedule } from '@/widgets/schedule'
|
||||
import { Day } from '@/shared/model/day'
|
||||
import { GetServerSidePropsResult } from 'next'
|
||||
import { getSchedule } from '@/app/agregator/schedule'
|
||||
import { NextSerialized, nextDeserializer, nextSerialized } from '@/app/utils/date-serializer'
|
||||
|
||||
const inter = Inter({ subsets: ['latin'] })
|
||||
type PageProps = NextSerialized<{
|
||||
schedule: Day[]
|
||||
}>
|
||||
|
||||
export default function HomePage(props: PageProps) {
|
||||
const { schedule } = nextDeserializer(props)
|
||||
|
||||
export default function Home() {
|
||||
return (
|
||||
<main
|
||||
className={`flex min-h-screen flex-col items-center justify-between p-24 ${inter.className}`}
|
||||
>
|
||||
<div className="z-10 max-w-5xl w-full items-center justify-between font-mono text-sm lg:flex">
|
||||
<p className="fixed left-0 top-0 flex w-full justify-center border-b border-gray-300 bg-gradient-to-b from-zinc-200 pb-6 pt-8 backdrop-blur-2xl dark:border-neutral-800 dark:bg-zinc-800/30 dark:from-inherit lg:static lg:w-auto lg:rounded-xl lg:border lg:bg-gray-200 lg:p-4 lg:dark:bg-zinc-800/30">
|
||||
Get started by editing
|
||||
<code className="font-mono font-bold">src/pages/index.tsx</code>
|
||||
</p>
|
||||
<div className="fixed bottom-0 left-0 flex h-48 w-full items-end justify-center bg-gradient-to-t from-white via-white dark:from-black dark:via-black lg:static lg:h-auto lg:w-auto lg:bg-none">
|
||||
<a
|
||||
className="pointer-events-none flex place-items-center gap-2 p-8 lg:pointer-events-auto lg:p-0"
|
||||
href="https://vercel.com?utm_source=create-next-app&utm_medium=default-template-tw&utm_campaign=create-next-app"
|
||||
target="_blank"
|
||||
rel="noopener noreferrer"
|
||||
>
|
||||
By{' '}
|
||||
<Image
|
||||
src="/vercel.svg"
|
||||
alt="Vercel Logo"
|
||||
className="dark:invert"
|
||||
width={100}
|
||||
height={24}
|
||||
priority
|
||||
/>
|
||||
</a>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div className="relative flex place-items-center before:absolute before:h-[300px] before:w-[480px] before:-translate-x-1/2 before:rounded-full before:bg-gradient-radial before:from-white before:to-transparent before:blur-2xl before:content-[''] after:absolute after:-z-20 after:h-[180px] after:w-[240px] after:translate-x-1/3 after:bg-gradient-conic after:from-sky-200 after:via-blue-200 after:blur-2xl after:content-[''] before:dark:bg-gradient-to-br before:dark:from-transparent before:dark:to-blue-700/10 after:dark:from-sky-900 after:dark:via-[#0141ff]/40 before:lg:h-[360px]">
|
||||
<Image
|
||||
className="relative dark:drop-shadow-[0_0_0.3rem_#ffffff70] dark:invert"
|
||||
src="/next.svg"
|
||||
alt="Next.js Logo"
|
||||
width={180}
|
||||
height={37}
|
||||
priority
|
||||
/>
|
||||
</div>
|
||||
|
||||
<div className="mb-32 grid text-center lg:max-w-5xl lg:w-full lg:mb-0 lg:grid-cols-4 lg:text-left">
|
||||
<a
|
||||
href="https://nextjs.org/docs?utm_source=create-next-app&utm_medium=default-template-tw&utm_campaign=create-next-app"
|
||||
className="group rounded-lg border border-transparent px-5 py-4 transition-colors hover:border-gray-300 hover:bg-gray-100 hover:dark:border-neutral-700 hover:dark:bg-neutral-800/30"
|
||||
target="_blank"
|
||||
rel="noopener noreferrer"
|
||||
>
|
||||
<h2 className={`mb-3 text-2xl font-semibold`}>
|
||||
Docs{' '}
|
||||
<span className="inline-block transition-transform group-hover:translate-x-1 motion-reduce:transform-none">
|
||||
->
|
||||
</span>
|
||||
</h2>
|
||||
<p className={`m-0 max-w-[30ch] text-sm opacity-50`}>
|
||||
Find in-depth information about Next.js features and API.
|
||||
</p>
|
||||
</a>
|
||||
|
||||
<a
|
||||
href="https://nextjs.org/learn?utm_source=create-next-app&utm_medium=default-template-tw&utm_campaign=create-next-app"
|
||||
className="group rounded-lg border border-transparent px-5 py-4 transition-colors hover:border-gray-300 hover:bg-gray-100 hover:dark:border-neutral-700 hover:dark:bg-neutral-800/30"
|
||||
target="_blank"
|
||||
rel="noopener noreferrer"
|
||||
>
|
||||
<h2 className={`mb-3 text-2xl font-semibold`}>
|
||||
Learn{' '}
|
||||
<span className="inline-block transition-transform group-hover:translate-x-1 motion-reduce:transform-none">
|
||||
->
|
||||
</span>
|
||||
</h2>
|
||||
<p className={`m-0 max-w-[30ch] text-sm opacity-50`}>
|
||||
Learn about Next.js in an interactive course with quizzes!
|
||||
</p>
|
||||
</a>
|
||||
|
||||
<a
|
||||
href="https://vercel.com/templates?framework=next.js&utm_source=create-next-app&utm_medium=default-template-tw&utm_campaign=create-next-app"
|
||||
className="group rounded-lg border border-transparent px-5 py-4 transition-colors hover:border-gray-300 hover:bg-gray-100 hover:dark:border-neutral-700 hover:dark:bg-neutral-800/30"
|
||||
target="_blank"
|
||||
rel="noopener noreferrer"
|
||||
>
|
||||
<h2 className={`mb-3 text-2xl font-semibold`}>
|
||||
Templates{' '}
|
||||
<span className="inline-block transition-transform group-hover:translate-x-1 motion-reduce:transform-none">
|
||||
->
|
||||
</span>
|
||||
</h2>
|
||||
<p className={`m-0 max-w-[30ch] text-sm opacity-50`}>
|
||||
Discover and deploy boilerplate example Next.js projects.
|
||||
</p>
|
||||
</a>
|
||||
|
||||
<a
|
||||
href="https://vercel.com/new?utm_source=create-next-app&utm_medium=default-template-tw&utm_campaign=create-next-app"
|
||||
className="group rounded-lg border border-transparent px-5 py-4 transition-colors hover:border-gray-300 hover:bg-gray-100 hover:dark:border-neutral-700 hover:dark:bg-neutral-800/30"
|
||||
target="_blank"
|
||||
rel="noopener noreferrer"
|
||||
>
|
||||
<h2 className={`mb-3 text-2xl font-semibold`}>
|
||||
Deploy{' '}
|
||||
<span className="inline-block transition-transform group-hover:translate-x-1 motion-reduce:transform-none">
|
||||
->
|
||||
</span>
|
||||
</h2>
|
||||
<p className={`m-0 max-w-[30ch] text-sm opacity-50`}>
|
||||
Instantly deploy your Next.js site to a shareable URL with Vercel.
|
||||
</p>
|
||||
</a>
|
||||
</div>
|
||||
</main>
|
||||
<Schedule days={schedule} />
|
||||
)
|
||||
}
|
||||
|
||||
export async function getServerSideProps(): Promise<GetServerSidePropsResult<PageProps>> {
|
||||
const schedule = await getSchedule(146)
|
||||
|
||||
return {
|
||||
props: {
|
||||
schedule: nextSerialized(schedule)
|
||||
}
|
||||
}
|
||||
}
|
||||
56
src/shadcn/ui/button.tsx
Normal file
56
src/shadcn/ui/button.tsx
Normal file
@@ -0,0 +1,56 @@
|
||||
import * as React from "react"
|
||||
import { Slot } from "@radix-ui/react-slot"
|
||||
import { cva, type VariantProps } from "class-variance-authority"
|
||||
|
||||
import { cn } from "@/shared/utils"
|
||||
|
||||
const buttonVariants = cva(
|
||||
"inline-flex items-center justify-center 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",
|
||||
{
|
||||
variants: {
|
||||
variant: {
|
||||
default: "bg-primary text-primary-foreground hover:bg-primary/90",
|
||||
destructive:
|
||||
"bg-destructive text-destructive-foreground hover:bg-destructive/90",
|
||||
outline:
|
||||
"border border-input bg-background hover:bg-accent hover:text-accent-foreground",
|
||||
secondary:
|
||||
"bg-secondary text-secondary-foreground hover:bg-secondary/80",
|
||||
ghost: "hover:bg-accent hover:text-accent-foreground",
|
||||
link: "text-primary underline-offset-4 hover:underline",
|
||||
},
|
||||
size: {
|
||||
default: "h-10 px-4 py-2",
|
||||
sm: "h-9 rounded-md px-3",
|
||||
lg: "h-11 rounded-md px-8",
|
||||
icon: "h-10 w-10",
|
||||
},
|
||||
},
|
||||
defaultVariants: {
|
||||
variant: "default",
|
||||
size: "default",
|
||||
},
|
||||
}
|
||||
)
|
||||
|
||||
export interface ButtonProps
|
||||
extends React.ButtonHTMLAttributes<HTMLButtonElement>,
|
||||
VariantProps<typeof buttonVariants> {
|
||||
asChild?: boolean
|
||||
}
|
||||
|
||||
const Button = React.forwardRef<HTMLButtonElement, ButtonProps>(
|
||||
({ className, variant, size, asChild = false, ...props }, ref) => {
|
||||
const Comp = asChild ? Slot : "button"
|
||||
return (
|
||||
<Comp
|
||||
className={cn(buttonVariants({ variant, size, className }))}
|
||||
ref={ref}
|
||||
{...props}
|
||||
/>
|
||||
)
|
||||
}
|
||||
)
|
||||
Button.displayName = "Button"
|
||||
|
||||
export { Button, buttonVariants }
|
||||
25
src/shadcn/ui/input.tsx
Normal file
25
src/shadcn/ui/input.tsx
Normal file
@@ -0,0 +1,25 @@
|
||||
import * as React from "react"
|
||||
|
||||
import { cn } from "@/shared/utils"
|
||||
|
||||
export interface InputProps
|
||||
extends React.InputHTMLAttributes<HTMLInputElement> {}
|
||||
|
||||
const Input = React.forwardRef<HTMLInputElement, InputProps>(
|
||||
({ className, type, ...props }, ref) => {
|
||||
return (
|
||||
<input
|
||||
type={type}
|
||||
className={cn(
|
||||
"flex h-10 w-full rounded-md border border-input bg-background px-3 py-2 text-sm ring-offset-background file:border-0 file:bg-transparent file:text-sm file:font-medium placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50",
|
||||
className
|
||||
)}
|
||||
ref={ref}
|
||||
{...props}
|
||||
/>
|
||||
)
|
||||
}
|
||||
)
|
||||
Input.displayName = "Input"
|
||||
|
||||
export { Input }
|
||||
24
src/shadcn/ui/label.tsx
Normal file
24
src/shadcn/ui/label.tsx
Normal file
@@ -0,0 +1,24 @@
|
||||
import * as React from "react"
|
||||
import * as LabelPrimitive from "@radix-ui/react-label"
|
||||
import { cva, type VariantProps } from "class-variance-authority"
|
||||
|
||||
import { cn } from "@/shared/utils"
|
||||
|
||||
const labelVariants = cva(
|
||||
"text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70"
|
||||
)
|
||||
|
||||
const Label = React.forwardRef<
|
||||
React.ElementRef<typeof LabelPrimitive.Root>,
|
||||
React.ComponentPropsWithoutRef<typeof LabelPrimitive.Root> &
|
||||
VariantProps<typeof labelVariants>
|
||||
>(({ className, ...props }, ref) => (
|
||||
<LabelPrimitive.Root
|
||||
ref={ref}
|
||||
className={cn(labelVariants(), className)}
|
||||
{...props}
|
||||
/>
|
||||
))
|
||||
Label.displayName = LabelPrimitive.Root.displayName
|
||||
|
||||
export { Label }
|
||||
119
src/shadcn/ui/select.tsx
Normal file
119
src/shadcn/ui/select.tsx
Normal file
@@ -0,0 +1,119 @@
|
||||
import * as React from "react"
|
||||
import * as SelectPrimitive from "@radix-ui/react-select"
|
||||
import { Check, ChevronDown } from "lucide-react"
|
||||
|
||||
import { cn } from "@/shared/utils"
|
||||
|
||||
const Select = SelectPrimitive.Root
|
||||
|
||||
const SelectGroup = SelectPrimitive.Group
|
||||
|
||||
const SelectValue = SelectPrimitive.Value
|
||||
|
||||
const SelectTrigger = React.forwardRef<
|
||||
React.ElementRef<typeof SelectPrimitive.Trigger>,
|
||||
React.ComponentPropsWithoutRef<typeof SelectPrimitive.Trigger>
|
||||
>(({ className, children, ...props }, ref) => (
|
||||
<SelectPrimitive.Trigger
|
||||
ref={ref}
|
||||
className={cn(
|
||||
"flex h-10 w-full items-center justify-between rounded-md border border-input bg-background px-3 py-2 text-sm ring-offset-background placeholder:text-muted-foreground focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50",
|
||||
className
|
||||
)}
|
||||
{...props}
|
||||
>
|
||||
{children}
|
||||
<SelectPrimitive.Icon asChild>
|
||||
<ChevronDown className="h-4 w-4 opacity-50" />
|
||||
</SelectPrimitive.Icon>
|
||||
</SelectPrimitive.Trigger>
|
||||
))
|
||||
SelectTrigger.displayName = SelectPrimitive.Trigger.displayName
|
||||
|
||||
const SelectContent = React.forwardRef<
|
||||
React.ElementRef<typeof SelectPrimitive.Content>,
|
||||
React.ComponentPropsWithoutRef<typeof SelectPrimitive.Content>
|
||||
>(({ className, children, position = "popper", ...props }, ref) => (
|
||||
<SelectPrimitive.Portal>
|
||||
<SelectPrimitive.Content
|
||||
ref={ref}
|
||||
className={cn(
|
||||
"relative z-50 min-w-[8rem] overflow-hidden rounded-md border bg-popover text-popover-foreground shadow-md data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2",
|
||||
position === "popper" &&
|
||||
"data-[side=bottom]:translate-y-1 data-[side=left]:-translate-x-1 data-[side=right]:translate-x-1 data-[side=top]:-translate-y-1",
|
||||
className
|
||||
)}
|
||||
position={position}
|
||||
{...props}
|
||||
>
|
||||
<SelectPrimitive.Viewport
|
||||
className={cn(
|
||||
"p-1",
|
||||
position === "popper" &&
|
||||
"h-[var(--radix-select-trigger-height)] w-full min-w-[var(--radix-select-trigger-width)]"
|
||||
)}
|
||||
>
|
||||
{children}
|
||||
</SelectPrimitive.Viewport>
|
||||
</SelectPrimitive.Content>
|
||||
</SelectPrimitive.Portal>
|
||||
))
|
||||
SelectContent.displayName = SelectPrimitive.Content.displayName
|
||||
|
||||
const SelectLabel = React.forwardRef<
|
||||
React.ElementRef<typeof SelectPrimitive.Label>,
|
||||
React.ComponentPropsWithoutRef<typeof SelectPrimitive.Label>
|
||||
>(({ className, ...props }, ref) => (
|
||||
<SelectPrimitive.Label
|
||||
ref={ref}
|
||||
className={cn("py-1.5 pl-8 pr-2 text-sm font-semibold", className)}
|
||||
{...props}
|
||||
/>
|
||||
))
|
||||
SelectLabel.displayName = SelectPrimitive.Label.displayName
|
||||
|
||||
const SelectItem = React.forwardRef<
|
||||
React.ElementRef<typeof SelectPrimitive.Item>,
|
||||
React.ComponentPropsWithoutRef<typeof SelectPrimitive.Item>
|
||||
>(({ className, children, ...props }, ref) => (
|
||||
<SelectPrimitive.Item
|
||||
ref={ref}
|
||||
className={cn(
|
||||
"relative flex w-full cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",
|
||||
className
|
||||
)}
|
||||
{...props}
|
||||
>
|
||||
<span className="absolute left-2 flex h-3.5 w-3.5 items-center justify-center">
|
||||
<SelectPrimitive.ItemIndicator>
|
||||
<Check className="h-4 w-4" />
|
||||
</SelectPrimitive.ItemIndicator>
|
||||
</span>
|
||||
|
||||
<SelectPrimitive.ItemText>{children}</SelectPrimitive.ItemText>
|
||||
</SelectPrimitive.Item>
|
||||
))
|
||||
SelectItem.displayName = SelectPrimitive.Item.displayName
|
||||
|
||||
const SelectSeparator = React.forwardRef<
|
||||
React.ElementRef<typeof SelectPrimitive.Separator>,
|
||||
React.ComponentPropsWithoutRef<typeof SelectPrimitive.Separator>
|
||||
>(({ className, ...props }, ref) => (
|
||||
<SelectPrimitive.Separator
|
||||
ref={ref}
|
||||
className={cn("-mx-1 my-1 h-px bg-muted", className)}
|
||||
{...props}
|
||||
/>
|
||||
))
|
||||
SelectSeparator.displayName = SelectPrimitive.Separator.displayName
|
||||
|
||||
export {
|
||||
Select,
|
||||
SelectGroup,
|
||||
SelectValue,
|
||||
SelectTrigger,
|
||||
SelectContent,
|
||||
SelectLabel,
|
||||
SelectItem,
|
||||
SelectSeparator,
|
||||
}
|
||||
7
src/shared/model/day.ts
Normal file
7
src/shared/model/day.ts
Normal file
@@ -0,0 +1,7 @@
|
||||
import { Lesson } from '@/shared/model/lesson'
|
||||
|
||||
export type Day = {
|
||||
date: Date
|
||||
weekNumber: number
|
||||
lessons: Lesson[]
|
||||
}
|
||||
22
src/shared/model/lesson.ts
Normal file
22
src/shared/model/lesson.ts
Normal file
@@ -0,0 +1,22 @@
|
||||
export type Lesson = {
|
||||
isChange?: boolean
|
||||
time: {
|
||||
start: string
|
||||
end: string
|
||||
hint?: string
|
||||
}
|
||||
type: string
|
||||
subject: string
|
||||
teacher: string
|
||||
place: {
|
||||
address: string
|
||||
classroom: number
|
||||
}
|
||||
topic?: string
|
||||
resources: {
|
||||
type: 'link'
|
||||
title: string
|
||||
url: string
|
||||
}[]
|
||||
homework: string
|
||||
}
|
||||
9
src/widgets/schedule/day.tsx
Normal file
9
src/widgets/schedule/day.tsx
Normal file
@@ -0,0 +1,9 @@
|
||||
import type { Day as DayType } from '@/shared/model/day'
|
||||
|
||||
export function Day({ day }: {
|
||||
day: DayType
|
||||
}) {
|
||||
return (
|
||||
<p></p>
|
||||
)
|
||||
}
|
||||
15
src/widgets/schedule/index.tsx
Normal file
15
src/widgets/schedule/index.tsx
Normal file
@@ -0,0 +1,15 @@
|
||||
import type { Day as DayType } from '@/shared/model/day'
|
||||
import { Day } from '@/widgets/schedule/day'
|
||||
|
||||
export function Schedule({ days }: {
|
||||
days: DayType[]
|
||||
}) {
|
||||
|
||||
return (
|
||||
<div>
|
||||
{days.map((day, i) => (
|
||||
<Day day={day} key={i} />
|
||||
))}
|
||||
</div>
|
||||
)
|
||||
}
|
||||
57
src/widgets/schedule/lesson.tsx
Normal file
57
src/widgets/schedule/lesson.tsx
Normal file
@@ -0,0 +1,57 @@
|
||||
import { Button } from '@/shadcn/ui/button'
|
||||
import {
|
||||
Card,
|
||||
CardContent,
|
||||
CardDescription,
|
||||
CardFooter,
|
||||
CardHeader,
|
||||
CardTitle,
|
||||
} from '@/shadcn/ui/card'
|
||||
import { Input } from '@/shadcn/ui/input'
|
||||
import { Label } from '@/shadcn/ui/label'
|
||||
import {
|
||||
Select,
|
||||
SelectContent,
|
||||
SelectItem,
|
||||
SelectTrigger,
|
||||
SelectValue,
|
||||
} from '@/shadcn/ui/select'
|
||||
|
||||
export function Lesson() {
|
||||
return (
|
||||
<Card className="w-[350px]">
|
||||
<CardHeader>
|
||||
<CardTitle>Create project</CardTitle>
|
||||
<CardDescription>Deploy your new project in one-click.</CardDescription>
|
||||
</CardHeader>
|
||||
<CardContent>
|
||||
<form>
|
||||
<div className="grid w-full items-center gap-4">
|
||||
<div className="flex flex-col space-y-1.5">
|
||||
<Label htmlFor="name">Name</Label>
|
||||
<Input id="name" placeholder="Name of your project" />
|
||||
</div>
|
||||
<div className="flex flex-col space-y-1.5">
|
||||
<Label htmlFor="framework">Framework</Label>
|
||||
<Select>
|
||||
<SelectTrigger id="framework">
|
||||
<SelectValue placeholder="Select" />
|
||||
</SelectTrigger>
|
||||
<SelectContent position="popper">
|
||||
<SelectItem value="next">Next.js</SelectItem>
|
||||
<SelectItem value="sveltekit">SvelteKit</SelectItem>
|
||||
<SelectItem value="astro">Astro</SelectItem>
|
||||
<SelectItem value="nuxt">Nuxt.js</SelectItem>
|
||||
</SelectContent>
|
||||
</Select>
|
||||
</div>
|
||||
</div>
|
||||
</form>
|
||||
</CardContent>
|
||||
<CardFooter className="flex justify-between">
|
||||
<Button variant="outline">Cancel</Button>
|
||||
<Button>Deploy</Button>
|
||||
</CardFooter>
|
||||
</Card>
|
||||
)
|
||||
}
|
||||
Reference in New Issue
Block a user