hw 6 data.tsx created and copied all from lab
@@ -1,118 +0,0 @@
|
||||
import Image1 from './images/image1.jpg';
|
||||
import Image2 from './images/image2.jpg';
|
||||
import Image3 from './images/image3.jpg';
|
||||
import Image4 from './images/image4.jpg';
|
||||
import Image5 from './images/image5.jpg';
|
||||
import Image6 from './images/image6.jpg';
|
||||
import Image7 from './images/image7.jpg';
|
||||
import Image8 from './images/image8.jpg';
|
||||
import Image9 from './images/image9.jpg';
|
||||
import Image10 from './images/image10.jpg';
|
||||
|
||||
const structures = [
|
||||
{
|
||||
img: Image1,
|
||||
title: "Раффлз-Сити, Китай",
|
||||
description: [
|
||||
`Раффлз-Сити — комплекс небоскрёбов, расположенный в китайском городе Чунцин, в деловом районе Юйчжун. Построен в 2019 году. Архитекторами комплекса выступили Моше Сафди и Чунцинский архитектурный институт, владельцем является сингапурская группа CapitaLand.`,
|
||||
`В состав многофункционального комплекса Раффлз-Сити входят восемь высотных башен и обширный подиум, в котором располагаются продуктовый супермаркет, магазины, автосалоны, рестораны, выставочные залы и паркинг. Общая площадь комплекса — свыше 1,1 млн м²,
|
||||
в том числе пятиэтажный торговый центр — 230 тыс. м², офисы — 160 тыс. м² и мультиплекс сети CGV — 5,6 тыс. м². В одной из 350-метровых башен Раффлз-Сити расположен пятизвёздочный отель InterContinental,
|
||||
также в комплексе насчитывается 1,4 тыс. жилых апартаментов сети Ascott и 26,4 тыс. парковочных мест.`
|
||||
],
|
||||
},
|
||||
{
|
||||
img: Image2,
|
||||
title: "Авичи-Арена, Швеция",
|
||||
description: [
|
||||
`Авичи-Арена - 85-метровая многоцелевая арена в Стокгольме. Второе по величине сферическое сооружение в мире. Место проведения концертов и спортивных мероприятий.
|
||||
Арена находится в микрорайоне Глобен-Сити, созданном специально для неё. Имеет вместимость 16 000 человек во время концертов и 13 850 во время хоккейных матчей.`,
|
||||
`Арена была построена специально к чемпионату мира по хоккею 1989 года и открыта 19 февраля 1989 года. Олицетворяет собой Солнце в Шведской Солнечной системе, крупнейшей в мире модели Солнечной системы.`
|
||||
]
|
||||
},
|
||||
{
|
||||
img: Image3,
|
||||
title: "Труба ГРЭС-2, Казахстан",
|
||||
description: [
|
||||
`Железобетонная дымовая труба, построенная в 1987 году, имея высоту 420 м, является самой высокой в мире и занесена в Книгу рекордов Гиннесса.
|
||||
Суммарная масса трубы составляет 60 тысяч тонн, её диаметр у основания составляет 44 м, диаметр устья — 14,2 м.`,
|
||||
`ГРЭС-2 вырабатывает электроэнергию из высокозольного экибастузского угля двумя энергоблоками по 500 МВт, имеет установленную мощность 1000 МВт. Два её энергоблока вырабатывают около 12 % всей электроэнергии,
|
||||
производимой в республике. Энергия ГРЭС-2 предназначена для обеспечения севера Казахстана. Потребителями являются десятки предприятий не только Казахстана, но и России.`
|
||||
]
|
||||
},
|
||||
{
|
||||
img: Image4,
|
||||
title: 'Бурдж-Халифа, Дубай, ОАЭ',
|
||||
description: [
|
||||
`Небоскрёб высотой 828 метров, самое высокое сооружение в мире. Форма здания напоминает сталагмит.`,
|
||||
`Строительство небоскрёба началось в 2004 году и шло со скоростью 1—2 этажа в неделю. Ежедневно на строительстве работало до 12 000 рабочих.
|
||||
На его создание ушло около 320 тыс. м³ бетона и более 60 тыс. тонн стальной арматуры.
|
||||
Бетонные работы были завершены после возведения 160 этажа, далее шла сборка 180-метрового шпиля из металлических конструкций.`
|
||||
]
|
||||
},
|
||||
{
|
||||
img: Image5,
|
||||
title: "Интинская радиомачта, Инта, Россия",
|
||||
description: [
|
||||
`На подъезде к железнодорожной станции Инта 1, кроме величественных вершин Урала, бросается в глаза металлическая вышка-мачта высотой 462,8 метра.
|
||||
Она больше чем знаменитая Эйфелева башня, но меньше на 77 метров, чем телевизионная Останкинская в Москве. Антенна навигационной системы «Чайка» предназначена
|
||||
для определения координат самолётов и кораблей с погрешностью 50–100 метров. Вышка-мачта находится на территории действующей военной части.`,
|
||||
`По конструкции это классическая GP антенна. Длинна волны передачи - приёма кратна высоте. Планировалось, чтотакие антенны должны были быть построены в нескольких
|
||||
точках по Полярному кругу.`
|
||||
]
|
||||
},
|
||||
{
|
||||
img: Image6,
|
||||
title: "Ворота Запада, США",
|
||||
description: [
|
||||
`Арка в Сент-Луисе, также известная под именем «Врата на запад» — мемориал, являющийся частью Джефферсоновского национального экспансиального мемориала, а также визитной карточкой Сент-Луиса, штат Миссури, США.`,
|
||||
`Арка была спроектирована финско-американским архитектором Ээро Саариненом в 1947 году. Её высота 192 метра в самой высокой точке, ширина её основания также 192 метра.
|
||||
Таким образом арка является самым высоким памятником на территории США. Её строительство началось 12 февраля 1963 года и было закончено 28 октября 1965 года. Памятник открылся для посетителей 24 июля 1967 года.`
|
||||
]
|
||||
},
|
||||
{
|
||||
img: Image7,
|
||||
title: 'CN Tower, Торонто, Канада',
|
||||
description: [
|
||||
`553.3-метровая телевизионная башня. Была самым высоким свободно стоящим сооружением в мире с 1976 по 2007 год, до сих пор остаётся
|
||||
таковым в Западном полушарии. Является символом Торонто. На высоте 447 м находится астрономическая обсерватория.`,
|
||||
`Земляные работы для сооружения железобетонной конструкции с последующим натяжением арматуры весом 130 000т начались 12 февраля 1973 г.,
|
||||
а уже 2 апреля 1975 г. возведение башни было завершено.`
|
||||
]
|
||||
},
|
||||
{
|
||||
img: Image8,
|
||||
title: 'Небесное дерево, Токио, Япония',
|
||||
description: [
|
||||
`Телевизионная башня в районе Сумида самая высокая среди телебашен мира. Высота телебашни вместе с антенной составляет 634 метра.
|
||||
Высота башни была выбрана так, чтобы цифры: 6 (на старом японском «му»), 3 («са»), 4 («си») были созвучны «Мусаси» — названию исторической области,
|
||||
где находится современный Токио.`,
|
||||
`Здание напоминает пятиярусную пагоду, что хорошо сочетается с историческим районом Асакуса на другом берегу реки.
|
||||
Основание башни напоминает штатив; с высоты примерно 350 м она имеет цилиндрическую форму, позволяющую наслаждаться панорамными видами реки и города.`
|
||||
]
|
||||
},
|
||||
{
|
||||
img: Image9,
|
||||
title: 'The Clock Towers, Мекка, Саудовская Аравия',
|
||||
description: [
|
||||
`Отель «Королевская часовая башня» имеет высоту 601 м. Его строительство которого завершилось в 2012 году. Внешне здание отдалённо напоминает Биг-Бен в Лондоне,
|
||||
при этом выше последнего в 6 раз.`,
|
||||
`На Королевской башне установлены часы диаметром 43 метра (длина часовой стрелки составляет 17 метров, минутной — 22),
|
||||
расположенные на высоте более 400 метров над землёй. Четыре их циферблата установлены по четырём сторонам света. Часы видны из любого места города,
|
||||
и являются самыми большими и самыми высотными часами в мире`
|
||||
]
|
||||
},
|
||||
{
|
||||
img: Image10,
|
||||
title: 'Merdeka 118, Куала-Лумпур, Малайзия',
|
||||
description: [
|
||||
`Общая высота здания составляет 678.9 м, причём более 160 м приходится на шпиль. Строительство Merdeka 118 началось в 2014 году.`,
|
||||
`Название «Merdeka» означает «независимость», оно отсылает к наименованию расположенного рядом с башней стадиона,
|
||||
который известен как место официального провозглашения независимости.`,
|
||||
`Здание находится в центре Куала-Лумпура. В небоскрёбе откроется первый отель Park Hyatt в Малайзии.
|
||||
Также в здании будут расположены самая высокая смотровая площадка в Юго-Восточной Азии, торговый центр, музей, мечеть, офисы и квартиры.`
|
||||
]
|
||||
},
|
||||
|
||||
];
|
||||
|
||||
export default structures;
|
||||
748
site/package-lock.json
generated
@@ -10,6 +10,10 @@
|
||||
"preview": "vite preview"
|
||||
},
|
||||
"dependencies": {
|
||||
"@emotion/react": "^11.14.0",
|
||||
"@emotion/styled": "^11.14.1",
|
||||
"@mui/icons-material": "^9.0.0",
|
||||
"@mui/material": "^9.0.0",
|
||||
"react": "^19.2.4",
|
||||
"react-dom": "^19.2.4"
|
||||
},
|
||||
|
||||
123
site/src/App.tsx
@@ -1,119 +1,18 @@
|
||||
import { useState } from 'react'
|
||||
import reactLogo from './assets/react.svg'
|
||||
import viteLogo from './assets/vite.svg'
|
||||
import heroImg from './assets/hero.png'
|
||||
import './App.css'
|
||||
import NavBar from './components/Navbar'
|
||||
import Gallery from "./components/Gallery";
|
||||
import Content from "./components/Content";
|
||||
import CustomFooter from "./components/CustomFooter";
|
||||
|
||||
|
||||
import './styles/App.css'
|
||||
|
||||
function App() {
|
||||
const [count, setCount] = useState(0)
|
||||
|
||||
return (
|
||||
<>
|
||||
<section id="center">
|
||||
<div className="hero">
|
||||
<img src={heroImg} className="base" width="170" height="179" alt="" />
|
||||
<img src={reactLogo} className="framework" alt="React logo" />
|
||||
<img src={viteLogo} className="vite" alt="Vite logo" />
|
||||
</div>
|
||||
<div>
|
||||
<h1>Get started</h1>
|
||||
<p>
|
||||
Edit <code>src/App.tsx</code> and save to test <code>HMR</code>
|
||||
</p>
|
||||
</div>
|
||||
<button
|
||||
className="counter"
|
||||
onClick={() => setCount((count) => count + 1)}
|
||||
>
|
||||
Count is {count}
|
||||
</button>
|
||||
</section>
|
||||
|
||||
<div className="ticks"></div>
|
||||
|
||||
<section id="next-steps">
|
||||
<div id="docs">
|
||||
<svg className="icon" role="presentation" aria-hidden="true">
|
||||
<use href="/icons.svg#documentation-icon"></use>
|
||||
</svg>
|
||||
<h2>Documentation</h2>
|
||||
<p>Your questions, answered</p>
|
||||
<ul>
|
||||
<li>
|
||||
<a href="https://vite.dev/" target="_blank">
|
||||
<img className="logo" src={viteLogo} alt="" />
|
||||
Explore Vite
|
||||
</a>
|
||||
</li>
|
||||
<li>
|
||||
<a href="https://react.dev/" target="_blank">
|
||||
<img className="button-icon" src={reactLogo} alt="" />
|
||||
Learn more
|
||||
</a>
|
||||
</li>
|
||||
</ul>
|
||||
</div>
|
||||
<div id="social">
|
||||
<svg className="icon" role="presentation" aria-hidden="true">
|
||||
<use href="/icons.svg#social-icon"></use>
|
||||
</svg>
|
||||
<h2>Connect with us</h2>
|
||||
<p>Join the Vite community</p>
|
||||
<ul>
|
||||
<li>
|
||||
<a href="https://github.com/vitejs/vite" target="_blank">
|
||||
<svg
|
||||
className="button-icon"
|
||||
role="presentation"
|
||||
aria-hidden="true"
|
||||
>
|
||||
<use href="/icons.svg#github-icon"></use>
|
||||
</svg>
|
||||
GitHub
|
||||
</a>
|
||||
</li>
|
||||
<li>
|
||||
<a href="https://chat.vite.dev/" target="_blank">
|
||||
<svg
|
||||
className="button-icon"
|
||||
role="presentation"
|
||||
aria-hidden="true"
|
||||
>
|
||||
<use href="/icons.svg#discord-icon"></use>
|
||||
</svg>
|
||||
Discord
|
||||
</a>
|
||||
</li>
|
||||
<li>
|
||||
<a href="https://x.com/vite_js" target="_blank">
|
||||
<svg
|
||||
className="button-icon"
|
||||
role="presentation"
|
||||
aria-hidden="true"
|
||||
>
|
||||
<use href="/icons.svg#x-icon"></use>
|
||||
</svg>
|
||||
X.com
|
||||
</a>
|
||||
</li>
|
||||
<li>
|
||||
<a href="https://bsky.app/profile/vite.dev" target="_blank">
|
||||
<svg
|
||||
className="button-icon"
|
||||
role="presentation"
|
||||
aria-hidden="true"
|
||||
>
|
||||
<use href="/icons.svg#bluesky-icon"></use>
|
||||
</svg>
|
||||
Bluesky
|
||||
</a>
|
||||
</li>
|
||||
</ul>
|
||||
</div>
|
||||
</section>
|
||||
|
||||
<div className="ticks"></div>
|
||||
<section id="spacer"></section>
|
||||
<NavBar active='2'/>
|
||||
<Gallery/>
|
||||
<Content/>
|
||||
<CustomFooter/>
|
||||
</>
|
||||
)
|
||||
}
|
||||
|
||||
|
Before Width: | Height: | Size: 44 KiB |
@@ -1 +0,0 @@
|
||||
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" aria-hidden="true" role="img" class="iconify iconify--logos" width="35.93" height="32" preserveAspectRatio="xMidYMid meet" viewBox="0 0 256 228"><path fill="#00D8FF" d="M210.483 73.824a171.49 171.49 0 0 0-8.24-2.597c.465-1.9.893-3.777 1.273-5.621c6.238-30.281 2.16-54.676-11.769-62.708c-13.355-7.7-35.196.329-57.254 19.526a171.23 171.23 0 0 0-6.375 5.848a155.866 155.866 0 0 0-4.241-3.917C100.759 3.829 77.587-4.822 63.673 3.233C50.33 10.957 46.379 33.89 51.995 62.588a170.974 170.974 0 0 0 1.892 8.48c-3.28.932-6.445 1.924-9.474 2.98C17.309 83.498 0 98.307 0 113.668c0 15.865 18.582 31.778 46.812 41.427a145.52 145.52 0 0 0 6.921 2.165a167.467 167.467 0 0 0-2.01 9.138c-5.354 28.2-1.173 50.591 12.134 58.266c13.744 7.926 36.812-.22 59.273-19.855a145.567 145.567 0 0 0 5.342-4.923a168.064 168.064 0 0 0 6.92 6.314c21.758 18.722 43.246 26.282 56.54 18.586c13.731-7.949 18.194-32.003 12.4-61.268a145.016 145.016 0 0 0-1.535-6.842c1.62-.48 3.21-.974 4.76-1.488c29.348-9.723 48.443-25.443 48.443-41.52c0-15.417-17.868-30.326-45.517-39.844Zm-6.365 70.984c-1.4.463-2.836.91-4.3 1.345c-3.24-10.257-7.612-21.163-12.963-32.432c5.106-11 9.31-21.767 12.459-31.957c2.619.758 5.16 1.557 7.61 2.4c23.69 8.156 38.14 20.213 38.14 29.504c0 9.896-15.606 22.743-40.946 31.14Zm-10.514 20.834c2.562 12.94 2.927 24.64 1.23 33.787c-1.524 8.219-4.59 13.698-8.382 15.893c-8.067 4.67-25.32-1.4-43.927-17.412a156.726 156.726 0 0 1-6.437-5.87c7.214-7.889 14.423-17.06 21.459-27.246c12.376-1.098 24.068-2.894 34.671-5.345a134.17 134.17 0 0 1 1.386 6.193ZM87.276 214.515c-7.882 2.783-14.16 2.863-17.955.675c-8.075-4.657-11.432-22.636-6.853-46.752a156.923 156.923 0 0 1 1.869-8.499c10.486 2.32 22.093 3.988 34.498 4.994c7.084 9.967 14.501 19.128 21.976 27.15a134.668 134.668 0 0 1-4.877 4.492c-9.933 8.682-19.886 14.842-28.658 17.94ZM50.35 144.747c-12.483-4.267-22.792-9.812-29.858-15.863c-6.35-5.437-9.555-10.836-9.555-15.216c0-9.322 13.897-21.212 37.076-29.293c2.813-.98 5.757-1.905 8.812-2.773c3.204 10.42 7.406 21.315 12.477 32.332c-5.137 11.18-9.399 22.249-12.634 32.792a134.718 134.718 0 0 1-6.318-1.979Zm12.378-84.26c-4.811-24.587-1.616-43.134 6.425-47.789c8.564-4.958 27.502 2.111 47.463 19.835a144.318 144.318 0 0 1 3.841 3.545c-7.438 7.987-14.787 17.08-21.808 26.988c-12.04 1.116-23.565 2.908-34.161 5.309a160.342 160.342 0 0 1-1.76-7.887Zm110.427 27.268a347.8 347.8 0 0 0-7.785-12.803c8.168 1.033 15.994 2.404 23.343 4.08c-2.206 7.072-4.956 14.465-8.193 22.045a381.151 381.151 0 0 0-7.365-13.322Zm-45.032-43.861c5.044 5.465 10.096 11.566 15.065 18.186a322.04 322.04 0 0 0-30.257-.006c4.974-6.559 10.069-12.652 15.192-18.18ZM82.802 87.83a323.167 323.167 0 0 0-7.227 13.238c-3.184-7.553-5.909-14.98-8.134-22.152c7.304-1.634 15.093-2.97 23.209-3.984a321.524 321.524 0 0 0-7.848 12.897Zm8.081 65.352c-8.385-.936-16.291-2.203-23.593-3.793c2.26-7.3 5.045-14.885 8.298-22.6a321.187 321.187 0 0 0 7.257 13.246c2.594 4.48 5.28 8.868 8.038 13.147Zm37.542 31.03c-5.184-5.592-10.354-11.779-15.403-18.433c4.902.192 9.899.29 14.978.29c5.218 0 10.376-.117 15.453-.343c-4.985 6.774-10.018 12.97-15.028 18.486Zm52.198-57.817c3.422 7.8 6.306 15.345 8.596 22.52c-7.422 1.694-15.436 3.058-23.88 4.071a382.417 382.417 0 0 0 7.859-13.026a347.403 347.403 0 0 0 7.425-13.565Zm-16.898 8.101a358.557 358.557 0 0 1-12.281 19.815a329.4 329.4 0 0 1-23.444.823c-7.967 0-15.716-.248-23.178-.732a310.202 310.202 0 0 1-12.513-19.846h.001a307.41 307.41 0 0 1-10.923-20.627a310.278 310.278 0 0 1 10.89-20.637l-.001.001a307.318 307.318 0 0 1 12.413-19.761c7.613-.576 15.42-.876 23.31-.876H128c7.926 0 15.743.303 23.354.883a329.357 329.357 0 0 1 12.335 19.695a358.489 358.489 0 0 1 11.036 20.54a329.472 329.472 0 0 1-11 20.722Zm22.56-122.124c8.572 4.944 11.906 24.881 6.52 51.026c-.344 1.668-.73 3.367-1.15 5.09c-10.622-2.452-22.155-4.275-34.23-5.408c-7.034-10.017-14.323-19.124-21.64-27.008a160.789 160.789 0 0 1 5.888-5.4c18.9-16.447 36.564-22.941 44.612-18.3ZM128 90.808c12.625 0 22.86 10.235 22.86 22.86s-10.235 22.86-22.86 22.86s-22.86-10.235-22.86-22.86s10.235-22.86 22.86-22.86Z"></path></svg>
|
||||
|
Before Width: | Height: | Size: 4.0 KiB |
|
Before Width: | Height: | Size: 8.5 KiB |
53
site/src/components/BuildCard.tsx
Normal file
@@ -0,0 +1,53 @@
|
||||
import Card from '@mui/material/Card';
|
||||
import CardActions from '@mui/material/CardActions';
|
||||
import CardContent from '@mui/material/CardContent';
|
||||
import CardMedia from '@mui/material/CardMedia';
|
||||
import Button from '@mui/material/Button';
|
||||
import Typography from '@mui/material/Typography';
|
||||
import Box from '@mui/material/Box';
|
||||
import { styled } from '@mui/material/styles';
|
||||
interface ComponentProps {
|
||||
building: {
|
||||
img: string,
|
||||
title: string,
|
||||
description: string[]
|
||||
},
|
||||
cardNum: number;
|
||||
}
|
||||
|
||||
|
||||
const StyledTypography = styled(Typography)(({ theme }) => ({
|
||||
color: theme.palette.text.secondary,
|
||||
textAlign: 'justify',
|
||||
marginBottom: '1em',
|
||||
}));
|
||||
|
||||
|
||||
function BuildCard({ building,cardNum} : ComponentProps) {
|
||||
return (
|
||||
<Card style={cardNum%2==0?{'flexDirection':'row-reverse'}:{}}sx={{ display: 'flex' }} >
|
||||
<CardMedia
|
||||
component="img"
|
||||
alt={ building.title }
|
||||
image={ building.img }
|
||||
/>
|
||||
<Box>
|
||||
<CardContent>
|
||||
<Typography gutterBottom variant="h5" >
|
||||
{ building.title }
|
||||
</Typography>
|
||||
{ building.description.map((item, ind) => (
|
||||
<StyledTypography key={ind} variant="body2">
|
||||
{ item }
|
||||
</StyledTypography>
|
||||
))}
|
||||
</CardContent>
|
||||
<CardActions sx={{ justifyContent: cardNum%2!=0?'end':"start"}} >
|
||||
<Button size="small">Подробнее</Button>
|
||||
</CardActions>
|
||||
</Box>
|
||||
</Card>
|
||||
)
|
||||
}
|
||||
|
||||
export default BuildCard;
|
||||
21
site/src/components/Content.tsx
Normal file
@@ -0,0 +1,21 @@
|
||||
import Container from '@mui/material/Container';
|
||||
import Grid from '@mui/material/Grid';
|
||||
import structures from "../data";
|
||||
import BuildCard from "./BuildCard"
|
||||
const cardData = [structures[3], structures[6], structures[9], structures[7]]
|
||||
|
||||
function Content() {
|
||||
return (
|
||||
<Container maxWidth="xl">
|
||||
<Grid container spacing={{ xs: 3, md: 6 }}>
|
||||
{cardData.map((item, index) => (
|
||||
<Grid key={index} size={{ xs: 12, md: 6 }} >
|
||||
<BuildCard building={ item } cardNum={index} />
|
||||
</Grid>
|
||||
))}
|
||||
</Grid>
|
||||
</Container>
|
||||
);
|
||||
}
|
||||
|
||||
export default Content;
|
||||
26
site/src/components/CustomFooter.tsx
Normal file
@@ -0,0 +1,26 @@
|
||||
import Container from '@mui/material/Container';
|
||||
import Grid from '@mui/material/Grid';
|
||||
import Typography from '@mui/material/Typography';
|
||||
import { styled } from '@mui/material/styles';
|
||||
|
||||
const StyledContainer = styled(Container)(({ theme }) => ({
|
||||
backgroundColor: theme.palette.action.hover,
|
||||
borderRadius: `calc(${theme.shape.borderRadius}px + 8px)`,
|
||||
marginTop: "50px",
|
||||
padding: "20px",
|
||||
color: theme.palette.text.secondary
|
||||
}));
|
||||
|
||||
function CustomFooter() {
|
||||
return (
|
||||
<StyledContainer >
|
||||
<Grid style={{ justifyContent: "space-around",}} container>
|
||||
<Typography> OkunElya</Typography>
|
||||
<Typography> 2026</Typography>
|
||||
<Typography> FEFU</Typography>
|
||||
</Grid>
|
||||
</StyledContainer>
|
||||
);
|
||||
}
|
||||
|
||||
export default CustomFooter;
|
||||
41
site/src/components/Gallery.tsx
Normal file
@@ -0,0 +1,41 @@
|
||||
import ImageList from '@mui/material/ImageList';
|
||||
import ImageListItem from '@mui/material/ImageListItem';
|
||||
import structures from "../data";
|
||||
import Box from '@mui/material/Box';
|
||||
import Container from '@mui/material/Container';
|
||||
import ImageListItemBar from '@mui/material/ImageListItemBar';
|
||||
const imgData = structures.slice(0, -1);
|
||||
|
||||
function Gallery() {
|
||||
return (
|
||||
<Container maxWidth="lg">
|
||||
<Box sx={{ width: 800, height: 585, overflowY: 'scroll', m: '20px auto' }}>
|
||||
<ImageList
|
||||
variant="masonry"
|
||||
sx={{
|
||||
columnCount: {
|
||||
xs: '1 !important',
|
||||
sm: '2 !important',
|
||||
md: '3 !important',
|
||||
lg: '4 !important',
|
||||
},
|
||||
}}
|
||||
gap={8}>
|
||||
{imgData.map((item) => (
|
||||
<ImageListItem key={item.img}>
|
||||
<img
|
||||
srcSet={item.img}
|
||||
src={item.img}
|
||||
alt={item.title}
|
||||
loading="lazy"
|
||||
/>
|
||||
<ImageListItemBar position="bottom" title={ item.title } />
|
||||
</ImageListItem>
|
||||
))}
|
||||
</ImageList>
|
||||
</Box>
|
||||
</Container>
|
||||
);
|
||||
}
|
||||
|
||||
export default Gallery;
|
||||
105
site/src/components/Navbar.tsx
Normal file
@@ -0,0 +1,105 @@
|
||||
import AppBar from '@mui/material/AppBar';
|
||||
import Toolbar from '@mui/material/Toolbar';
|
||||
import { styled } from '@mui/material/styles';
|
||||
import Container from '@mui/material/Container';
|
||||
import Typography from '@mui/material/Typography';
|
||||
import Box from '@mui/material/Box';
|
||||
import Button from '@mui/material/Button';
|
||||
import IconButton from '@mui/material/IconButton';
|
||||
import CloseRoundedIcon from '@mui/icons-material/CloseRounded';
|
||||
import MenuItem from '@mui/material/MenuItem';
|
||||
import Drawer from '@mui/material/Drawer';
|
||||
import MenuIcon from '@mui/icons-material/Menu';
|
||||
import MenuList from '@mui/material/MenuList';
|
||||
|
||||
import { useState } from 'react';
|
||||
|
||||
|
||||
const StyledToolbar = styled(Toolbar)(({ theme }) => ({
|
||||
display: 'flex',
|
||||
alignItems: 'center',
|
||||
justifyContent: 'space-between',
|
||||
flexShrink: 0,
|
||||
borderRadius: `calc(${theme.shape.borderRadius}px + 8px)`,
|
||||
border: '1px solid',
|
||||
borderColor: theme.palette.divider,
|
||||
padding: '8px 12px',
|
||||
}));
|
||||
|
||||
|
||||
const StyledMenuItem =styled(MenuItem)(({}) => ({
|
||||
'&.Mui-selected': {
|
||||
backgroundColor: '#1976d2',
|
||||
color: "white",
|
||||
},
|
||||
'&.Mui-selected:hover': {
|
||||
backgroundColor: '#11579c',
|
||||
color: "white",
|
||||
},
|
||||
'&:hover': {
|
||||
backgroundColor: 'rgba(69, 146, 223, 0.45)',
|
||||
},
|
||||
|
||||
}));
|
||||
interface ComponentProps {
|
||||
active: string;
|
||||
}
|
||||
|
||||
function NavBar({ active }: ComponentProps) {
|
||||
const [open, setOpen] = useState(false);
|
||||
|
||||
const toggleDrawer = (newOpen: boolean) => () => {
|
||||
setOpen(newOpen);
|
||||
};
|
||||
return (
|
||||
<AppBar
|
||||
position="static"
|
||||
sx={{
|
||||
boxShadow: 0,
|
||||
bgcolor: 'transparent',
|
||||
mt: '28px',
|
||||
}}
|
||||
>
|
||||
<Container maxWidth="xl">
|
||||
<StyledToolbar>
|
||||
<Typography variant="h6" sx={{ color: '#5d8aa8' }}>
|
||||
Самые высокие здания и сооружения
|
||||
</Typography>
|
||||
<Box sx={{ display: { xs: 'none', md: 'flex' } }}>
|
||||
<Button variant={active == '1' ? 'contained' : 'text'} color="info" size="medium">
|
||||
Главная
|
||||
</Button>
|
||||
<Button variant={active == '2' ? 'contained' : 'text'} color="info" size="medium">
|
||||
Список зданий
|
||||
</Button>
|
||||
<Button variant={active == '3' ? 'contained' : 'text'} color="info" size="medium">
|
||||
Контакты
|
||||
</Button>
|
||||
</Box>
|
||||
<Box sx={{ display: { xs: 'flex', md: 'none' } }}>
|
||||
<IconButton aria-label="Menu button" onClick={toggleDrawer(true)}>
|
||||
<MenuIcon />
|
||||
</IconButton>
|
||||
<Drawer
|
||||
anchor="top"
|
||||
open={open}
|
||||
onClose={toggleDrawer(false)}
|
||||
>
|
||||
<Box>
|
||||
<IconButton onClick={toggleDrawer(false)}>
|
||||
<CloseRoundedIcon />
|
||||
</IconButton>
|
||||
</Box>
|
||||
<MenuList>
|
||||
<StyledMenuItem selected={active == '1'}> Главная </StyledMenuItem>
|
||||
<StyledMenuItem selected={active == '2'}>Список зданий</StyledMenuItem>
|
||||
<StyledMenuItem selected={active == '3'}>Контакты</StyledMenuItem>
|
||||
</MenuList>
|
||||
</Drawer>
|
||||
</Box>
|
||||
</StyledToolbar>
|
||||
</Container>
|
||||
</AppBar>
|
||||
);
|
||||
}
|
||||
export default NavBar;
|
||||
93
site/src/data.tsx
Normal file
@@ -0,0 +1,93 @@
|
||||
import IrlPhoto0 from "./images/photos/image0.png";
|
||||
import IrlPhoto1 from "./images/photos/image1.png";
|
||||
import IrlPhoto2 from "./images/photos/image2.png";
|
||||
import IrlPhoto3 from "./images/photos/image3.png";
|
||||
import IrlPhoto4 from "./images/photos/image4.png";
|
||||
import IrlPhoto5 from "./images/photos/image5.png";
|
||||
import IrlPhoto7 from "./images/photos/image7.png";
|
||||
import Playback from "./images/photos/playback.mp4";
|
||||
|
||||
const realPhotos = [
|
||||
IrlPhoto0,
|
||||
IrlPhoto1,
|
||||
IrlPhoto2,
|
||||
IrlPhoto3,
|
||||
IrlPhoto4,
|
||||
IrlPhoto5,
|
||||
IrlPhoto7
|
||||
]
|
||||
|
||||
//import sideards photos
|
||||
import SidecardPhoto0 from "./images/sidecards/AQ_monitor.png";
|
||||
import SidecardPhoto1 from "./images/sidecards/plant waterer.png";
|
||||
import SidecardPhoto2 from "./images/sidecards/thermostat.jpeg";
|
||||
import SidecardPhoto3 from "./images/sidecards/remote.jpeg";
|
||||
|
||||
|
||||
import hardliyWorkingImage from "./images/hardly-working.gif";
|
||||
import instititePhoto from "./images/institute.png";
|
||||
|
||||
const sidecardData = [
|
||||
{
|
||||
img: SidecardPhoto0,
|
||||
title: "Air Quality Monitor",
|
||||
description: [
|
||||
`Here in valdivostok air is not always fresh , so to prevent suffocation from gudron™ fumes i made an air auality monitor`,
|
||||
`Monitored parameters include: PM2.5, PM10, CO2, temperature, and humidity. Data is readable via BLE`
|
||||
],
|
||||
},
|
||||
{
|
||||
img: SidecardPhoto1,
|
||||
title: "Plant Waterer",
|
||||
description: [
|
||||
`I love plannts, and have about 5 or 6 of them. Sadly they are not watered ona regular basis, so now there is a plant waterer to automate the process`,
|
||||
`it has 6 output channels with membrane pumps and 6 inputs for analog soil moisture sensors.`,
|
||||
`the system could be controlled or setuppd via BLE. also this is my first project with encllosure modeled in FreeCAD`
|
||||
|
||||
]
|
||||
},
|
||||
{
|
||||
img: SidecardPhoto2,
|
||||
title: "Thermostat",
|
||||
description: [
|
||||
`I have a heater in my room, but it is not very smart, so i made a thermostat to control it`,
|
||||
`it has a temperature sensor and a relay to control the heater. also it is controlled via BLE`
|
||||
]
|
||||
},
|
||||
{
|
||||
img: SidecardPhoto3,
|
||||
title: "Remote Control",
|
||||
description: [
|
||||
"it's fun to have controll over something, and also it;s nice when the interface is small and handheld",
|
||||
"here is a small display eith button, neopixel and esp32c3"
|
||||
]
|
||||
}
|
||||
];
|
||||
|
||||
|
||||
const mainCards = [
|
||||
{
|
||||
title: "funny thingy",
|
||||
img: hardliyWorkingImage,
|
||||
description: [
|
||||
"Hardly workign or Working hard? that is the question. Can't choose one - choose both!",
|
||||
"This is a small mechinised sign that can display one of two beforementioned word combinations.",
|
||||
"i was working hard on it , and still the neopixel is hardly working, but everething else is ok",
|
||||
"the sign is povered over type-c and can be controlled via button push or serial or even ble ( i love ble )",
|
||||
"the project is open source and you have any ideas for other word combinations just contribute",
|
||||
]
|
||||
},
|
||||
{
|
||||
title: "Books!",
|
||||
img: instititePhoto,
|
||||
description: [
|
||||
"I love science fiction or horror books, mostly i read from screen.",
|
||||
"Rigth now my favoriteauthos is Stephen King. In my favorites are It, The stand, and the whole Dark Tower series.",
|
||||
"And you cant forget The Institute, here is the recreation of book cover with a photo of the institute in my city. hope it's never go the same path as the one in the book)))"
|
||||
]
|
||||
}
|
||||
]
|
||||
|
||||
|
||||
|
||||
export default {sidecardData, realPhotos, Playback, mainCards};
|
||||
BIN
site/src/images/arduino.png
Normal file
|
After Width: | Height: | Size: 80 KiB |
BIN
site/src/images/arucos.png
Normal file
|
After Width: | Height: | Size: 347 KiB |
BIN
site/src/images/blheli-esc.jpeg
Normal file
|
After Width: | Height: | Size: 159 KiB |
BIN
site/src/images/esp32.png
Normal file
|
After Width: | Height: | Size: 41 KiB |
BIN
site/src/images/hardly-working.gif
Normal file
|
After Width: | Height: | Size: 2.6 MiB |
BIN
site/src/images/institute.png
Normal file
|
After Width: | Height: | Size: 1.1 MiB |
BIN
site/src/images/opencv.png
Normal file
|
After Width: | Height: | Size: 13 KiB |
BIN
site/src/images/photos/image0.png
Normal file
|
After Width: | Height: | Size: 2.3 MiB |
BIN
site/src/images/photos/image1.png
Normal file
|
After Width: | Height: | Size: 5.2 MiB |
BIN
site/src/images/photos/image2.png
Normal file
|
After Width: | Height: | Size: 99 KiB |
BIN
site/src/images/photos/image3.png
Normal file
|
After Width: | Height: | Size: 3.9 MiB |
BIN
site/src/images/photos/image4.png
Normal file
|
After Width: | Height: | Size: 4.4 MiB |
BIN
site/src/images/photos/image5.png
Normal file
|
After Width: | Height: | Size: 1.9 MiB |
BIN
site/src/images/photos/image7.png
Normal file
|
After Width: | Height: | Size: 3.1 MiB |
BIN
site/src/images/photos/playback.mp4
Normal file
BIN
site/src/images/rpi-nano.jpeg
Normal file
|
After Width: | Height: | Size: 106 KiB |
BIN
site/src/images/sidecards/AQ_monitor.png
Normal file
|
After Width: | Height: | Size: 1.2 MiB |
BIN
site/src/images/sidecards/plant waterer.png
Normal file
|
After Width: | Height: | Size: 478 KiB |
BIN
site/src/images/sidecards/remote.jpeg
Normal file
|
After Width: | Height: | Size: 65 KiB |
BIN
site/src/images/sidecards/thermostat.jpeg
Normal file
|
After Width: | Height: | Size: 126 KiB |
BIN
site/src/images/stm32.png
Normal file
|
After Width: | Height: | Size: 99 KiB |
@@ -1,6 +1,6 @@
|
||||
import { StrictMode } from 'react'
|
||||
import { createRoot } from 'react-dom/client'
|
||||
import './index.css'
|
||||
import './styles/index.css'
|
||||
import App from './App.tsx'
|
||||
|
||||
createRoot(document.getElementById('root')!).render(
|
||||
|
||||