-
Notifications
You must be signed in to change notification settings - Fork 0
/
index.html
284 lines (272 loc) · 16.7 KB
/
index.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
<!DOCTYPE html>
<html lang="ru">
<head>
<meta charset="utf-8">
<link rel="stylesheet" href="css/normalize.css">
<link rel="stylesheet" href="css/style.css">
<link rel="shortcut icon" href="favicon.ico" type="image/x-icon">
<title>Кексобукинг</title>
</head>
<body>
<main>
<div class="promo">
<h1 class="promo__title visually-hidden">Keksobooking. Кексы по соседству</h1>
<img src="img/keksobooking.svg" alt="Keksobooking. Кексы по соседству" width="215" height="45">
</div>
<!-- Карта объявлений -->
<section class="map map--faded">
<!-- Метки объявлений -->
<div class="map__pins">
<div class="map__overlay">
<h2 class="map__title">И снова Токио!</h2>
</div>
<button class="map__pin map__pin--main" style="left: 570px; top: 375px;">
<img src="img/muffin-red.svg" width="40" height="44" draggable="false" alt="Метка объявления">
<svg viewBox="0 0 70 70" width="156" height="156" aria-label="Метка для поиска жилья">
<defs>
<path d="M35,35m-23,0a23,23 0 1,1 46,0a23,23 0 1,1 -46,0" id="tophalf"/>
</defs>
<ellipse cx="35" cy="35" rx="35" ry="35" fill="rgba(255, 86, 53, 0.7)"/>
<text>
<textPath xlink:href="#tophalf" startOffset="0">Поставь меня куда-нибудь</textPath>
</text>
</svg>
</button>
</div>
<!-- Фильтрация объявлений -->
<div class="map__filters-container">
<form action="#" class="map__filters" autocomplete="off">
<select name="housing-type" id="housing-type" class="map__filter">
<option value="any" selected>Любой тип жилья</option>
<option value="palace">Дворец</option>
<option value="flat">Квартира</option>
<option value="house">Дом</option>
<option value="bungalo">Бунгало</option>
</select>
<select name="housing-price" id="housing-price" class="map__filter">
<option value="any" selected>Любая</option>
<option value="middle">10000 - 50000₽</option>
<option value="low">до 10000₽</option>
<option value="high">от 50000₽</option>
</select>
<select name="housing-rooms" id="housing-rooms" class="map__filter">
<option value="any" selected>Любое число комнат</option>
<option value="1">Одна комната</option>
<option value="2">Две комнаты</option>
<option value="3">Три комнаты</option>
</select>
<select name="housing-guests" id="housing-guests" class="map__filter">
<option value="any" selected>Любое число гостей</option>
<option value="2">Два гостя</option>
<option value="1">Один гость</option>
<option value="0">Не для гостей</option>
</select>
<fieldset id="housing-features" class="map__features">
<input type="checkbox" name="features" value="wifi" id="filter-wifi" class="map__checkbox visually-hidden">
<label class="map__feature map__feature--wifi" for="filter-wifi">Wi-Fi</label>
<input type="checkbox" name="features" value="dishwasher" id="filter-dishwasher" class="map__checkbox visually-hidden">
<label class="map__feature map__feature--dishwasher" for="filter-dishwasher">Посудомоечная машина</label>
<input type="checkbox" name="features" value="parking" id="filter-parking" class="map__checkbox visually-hidden">
<label class="map__feature map__feature--parking" for="filter-parking">Парковка</label>
<input type="checkbox" name="features" value="washer" id="filter-washer" class="map__checkbox visually-hidden">
<label class="map__feature map__feature--washer" for="filter-washer">Стиральная машина</label>
<input type="checkbox" name="features" value="elevator" id="filter-elevator" class="map__checkbox visually-hidden">
<label class="map__feature map__feature--elevator" for="filter-elevator">Лифт</label>
<input type="checkbox" name="features" value="conditioner" id="filter-conditioner" class="map__checkbox visually-hidden">
<label class="map__feature map__feature--conditioner" for="filter-conditioner">Кондиционер</label>
</fieldset>
</form>
</div>
</section>
<!-- Форма объявления -->
<section class="notice">
<h2 class="notice__title">Ваше объявление</h2>
<form class="ad-form ad-form--disabled" method="post" action="https://js.dump.academy/keksobooking" enctype="multipart/form-data" autocomplete="off">
<fieldset class="ad-form-header">
<legend class="ad-form-header__title">Ваша фотография (для карты)</legend>
<div class="ad-form-header__upload">
<div class="ad-form-header__preview">
<img src="img/muffin-grey.svg" alt="Аватар пользователя" width="40" height="44">
</div>
<div class="ad-form__field">
<input type="file" id="avatar" name="avatar" class="ad-form-header__input visually-hidden">
<label class="ad-form-header__drop-zone" for="avatar">Загрузите или перетащите сюда фото</label>
</div>
<p class="ad-form-header__info">Заполните все обязательные поля, назначьте цену, загрузите фотографии.
Придумайте интересное описание. Оно сделает объявление более живым и привлекательным. Получившееся
объявление должно давать гостям полное представление о вашем жилье.</p>
</div>
</fieldset>
<fieldset class="ad-form__element ad-form__element--wide">
<label class="ad-form__label" for="title">Заголовок объявления</label>
<input id="title" name="title" type="text" placeholder="Милая, уютная квартирка в центре Токио" minlength="30" maxlength="100" required>
</fieldset>
<fieldset class="ad-form__element ad-form__element--wide">
<label class="ad-form__label" for="address">Адрес</label>
<input id="address" name="address" type="text" value="602, 455" readonly>
</fieldset>
<fieldset class="ad-form__element">
<label class="ad-form__label" for="type">Тип жилья</label>
<select id="type" name="type">
<option value="bungalo" data-min-price="0">Бунгало</option>
<option value="flat" data-min-price="1000" selected>Квартира</option>
<option value="house" data-min-price="5000">Дом</option>
<option value="palace" data-min-price="10000">Дворец</option>
</select>
</fieldset>
<fieldset class="ad-form__element">
<label class="ad-form__label" for="price">Цена за ночь, руб.</label>
<input id="price" name="price" type="number" placeholder="1000" min="1000" max="1000000" required>
</fieldset>
<fieldset class="ad-form__element ad-form__element--time">
<label class="ad-form__label" for="timein">Время заезда и выезда</label>
<select id="timein" name="timein">
<option value="12:00" selected>После 12</option>
<option value="13:00">После 13</option>
<option value="14:00">После 14</option>
</select>
<select id="timeout" name="timeout" title="Time to go out">
<option value="12:00" selected>Выезд до 12</option>
<option value="13:00">Выезд до 13</option>
<option value="14:00">Выезд до 14</option>
</select>
</fieldset>
<fieldset class="ad-form__element">
<label class="ad-form__label" for="room_number">Кол-во комнат</label>
<select id="room_number" name="rooms">
<option value="1" selected>1 комната</option>
<option value="2">2 комнаты</option>
<option value="3">3 комнаты</option>
<option value="100">100 комнат</option>
</select>
</fieldset>
<fieldset class="ad-form__element">
<label class="ad-form__label" for="capacity">Количество мест</label>
<select id="capacity" name="capacity">
<option value="3" disabled>для 3 гостей</option>
<option value="2" disabled>для 2 гостей</option>
<option value="1" selected>для 1 гостя</option>
<option value="0" disabled>не для гостей</option>
</select>
</fieldset>
<fieldset class="ad-form__element ad-form__element--wide features">
<legend>Удобства: Wi-Fi, кухня, парковка, стиралка, лифт, кондиционер</legend>
<input type="checkbox" name="features" value="wifi" id="feature-wifi" class="feature__checkbox visually-hidden">
<label class="feature feature--wifi" for="feature-wifi">Wi-Fi</label>
<input type="checkbox" name="features" value="dishwasher" id="feature-dishwasher" class="feature__checkbox visually-hidden">
<label class="feature feature--dishwasher" for="feature-dishwasher">Посудомоечная машина</label>
<input type="checkbox" name="features" value="parking" id="feature-parking" class="feature__checkbox visually-hidden">
<label class="feature feature--parking" for="feature-parking">Парковка</label>
<input type="checkbox" name="features" value="washer" id="feature-washer" class="feature__checkbox visually-hidden">
<label class="feature feature--washer" for="feature-washer">Стиральная машина</label>
<input type="checkbox" name="features" value="elevator" id="feature-elevator" class="feature__checkbox visually-hidden">
<label class="feature feature--elevator" for="feature-elevator">Лифт</label>
<input type="checkbox" name="features" value="conditioner" id="feature-conditioner" class="feature__checkbox visually-hidden">
<label class="feature feature--conditioner" for="feature-conditioner">Кондиционер</label>
</fieldset>
<fieldset class="ad-form__element ad-form__element--wide">
<label class="ad-form__label" for="description">Описание (не обязательно)</label>
<textarea id="description" name="description" placeholder="Здесь расскажите о том, какое ваше жилье замечательное и вообще"></textarea>
</fieldset>
<fieldset class="ad-form__element ad-form__element--wide">
<label class="ad-form__label">Фотографии жилья</label>
<div class="ad-form__photo-container">
<div class="ad-form__upload">
<input type="file" id="images" name="images" class="ad-form__input visually-hidden">
<label for="images" class="ad-form__drop-zone">Загрузите или перетащите сюда фото</label>
</div>
<div class="ad-form__photo">
<img src="img/muffin-grey.svg" alt="Изображение объявления пользователя" class="visually-hidden" width="70" height="70">
</div>
</div>
</fieldset>
<fieldset class="ad-form__element ad-form__element--submit">
<button class="ad-form__submit" type="submit">Опубликовать</button>
или
<button class="ad-form__reset" type="reset">очистить</button>
</fieldset>
</form>
</section>
</main>
<footer class="footer container">
<div class="footer__copyright copyright">
<a class="copyright__link copyright__link--image" href="https://htmlacademy.ru/intensive/javascript">
<img src="img/htmla-logo.svg" width="130" height="45" alt="HTML Academy" class="copyright__logo">
</a>
<p>Сделано в <a class="copyright__link copyright__link--text" href="https://htmlacademy.ru/intensive/javascript">HTMLAcademy</a>
© 2018</p>
</div>
<ul class="footer__contacts contacts">
<li><a href="https://twitter.com/htmlacademy_ru" class="contacts__link contacts__link--twitter">Twitter</a></li>
<li>
<a href="https://www.instagram.com/htmlacademy/" class="contacts__link contacts__link--instagram">Instagtam</a>
</li>
<li><a href="https://www.facebook.com/htmlacademy" class="contacts__link contacts__link--facebook">Facebook</a>
</li>
<li><a href="https://vk.com/htmlacademy" class="contacts__link contacts__link--vk">VK</a></li>
</ul>
</footer>
<!-- Модальное окно с информацией об объявлении -->
<template id="card">
<article class="map__card popup">
<img src="img/avatars/user01.png" class="popup__avatar" width="70" height="70" alt="Аватар пользователя">
<button type="button" class="popup__close">Закрыть</button>
<h3 class="popup__title">Уютное гнездышко для молодоженов</h3>
<p class="popup__text popup__text--address">102-0082 Tōkyō-to, Chiyoda-ku, Ichibanchō, 14−3</p>
<p class="popup__text popup__text--price">5200₽<span>/ночь</span></p>
<h4 class="popup__type">Квартира</h4>
<p class="popup__text popup__text--capacity">2 комнаты для 3 гостей</p>
<p class="popup__text popup__text--time">Заезд после 14:00, выезд до 10:00</p>
<ul class="popup__features">
<li class="popup__feature popup__feature--wifi"></li>
<li class="popup__feature popup__feature--dishwasher"></li>
<li class="popup__feature popup__feature--parking"></li>
<li class="popup__feature popup__feature--washer"></li>
<li class="popup__feature popup__feature--elevator"></li>
<li class="popup__feature popup__feature--conditioner"></li>
</ul>
<p class="popup__description">Великолепная квартира-студия в центре Токио. Подходит как туристам, так и
бизнесменам. Квартира полностью укомплектована и недавно отремонтирована.</p>
<div class="popup__photos">
<!--<img src="" class="popup__photo" width="45" height="40" alt="Фотография жилья">-->
</div>
</article>
</template>
<!-- Метка объявления -->
<template id="pin">
<button type="button" class="map__pin" style="left: 200px; top: 400px;">
<img src="img/avatars/user07.png" width="40" height="40" draggable="false" alt="Метка объявления"></button>
</template>
<!-- Сообщение о неудачной загрузке похожих объявлений -->
<template id="pin-error">
<div class="error">
<p class="error__message">Не удалось загрузить<br>похожие объявления</p>
</div>
</template>
<!-- Сообщение об успешном создании объявления -->
<template id="success">
<div class="success">
<p class="success__message">Ваше объявление<br>успешно размещено!</p>
</div>
</template>
<!-- Сообщение об ошибке создания объеявления -->
<template id="error">
<div class="error">
<p class="error__message">Ошибка загрузки объявления</p>
<button class="error__button" href="#">Попробовать снова</button>
</div>
</template>
<script src="js/constants.js"></script>
<script src="js/util.js"></script>
<!--<script src="js/data.js"></script>-->
<script src="js/backend.js"></script>
<script src="js/slider.js"></script>
<script src="js/map.js"></script>
<script src="js/offer.js"></script>
<script src="js/debounce.js"></script>
<script src="js/sort.js"></script>
<script src="js/picture.js"></script>
<script src="js/validation.js"></script>
<script src="js/form.js"></script>
</body>
</html>