Skip to content
This repository has been archived by the owner on May 14, 2024. It is now read-only.

Homework Week 1 #555

Open
wants to merge 1 commit into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
135 changes: 127 additions & 8 deletions Week1/homework/app.js
Original file line number Diff line number Diff line change
@@ -1,11 +1,130 @@
'use strict';

{
const bookTitles = [
// Replace with your own book titles
'harry_potter_chamber_secrets',
];

// Replace with your own code
console.log(bookTitles);
const container = document.querySelector('.main');

const bookTitles = [
'sailor_song',
'lame_fate',
'roadside_picnic',
'a_mind_for_numbers',
'other_shores',
'the_luzhin_defense',
'the_brothers_karamazov',
'one_flew_over_the_cuckoos_nest',
'sharp_objects',
'the_idiot',
];

const bookInfo = {
sailor_song: {
title: 'Sailor song',
language: 'english',
author: 'Ken Kesey',
},
lame_fate: {
title: 'Lame fate',
language: 'russian',
author: 'Arkady Strugatsky and Boris Strugatsky',
},
roadside_picnic: {
title: 'Roadside picnic',
language: 'russian',
author: 'Arkady Strugatsky and Boris Strugatsky',
},
a_mind_for_numbers: {
title: 'A mind for numbers',
language: 'english',
author: 'Barbara Oakley',
},
other_shores: {
title: 'Other Shores',
language: 'russian',
author: 'Vladimir Nabokov',
},
the_luzhin_defense: {
title: 'The Luzhin defense',
language: 'russian',
author: 'Vladimir Nabokov',
},
the_brothers_karamazov: {
title: 'The brothers Karamazov',
language: 'russian',
author: 'Fyodor Dostoyevsky',
},
one_flew_over_the_cuckoos_nest: {
title: "One flew over the cuckoo's nest",
language: 'english',
author: 'Ken Kesey',
},
sharp_objects: {
title: 'Sharp objects',
language: 'english',
author: 'Gillian Flynn',
},
the_idiot: {
title: 'The idiot',
language: 'russian',
author: 'Fyodor Dostoyevsky',
},
};

const bookCovers = {
sailor_song: './images/sailor_song.jpg',
lame_fate: './images/lame_fate.jpg',
roadside_picnic: './images/roadside_picnic.jpg',
a_mind_for_numbers: './images/a_mind_for_numbers.jpg',
other_shores: './images/other_shores.jpg',
the_luzhin_defense: './images/the_luzhin_defense.jpg',
the_brothers_karamazov: './images/the_brothers_karamazov.jpg',
one_flew_over_the_cuckoos_nest: './images/one_flew_over_the_cuckoo_nest.jpg',
sharp_objects: './images/sharp_objects.jpg',
the_idiot: './images/the_idiot.jpg',
};

const ul = document.createElement('ul');
container.append(ul);

function makeBookList(arr, obj) {
for (let i = 0; i < arr.length; i++) {
const li = document.createElement('li');
ul.append(li);
li.setAttribute('id', arr[i]);
const bookContainer = document.createElement('div');
bookContainer.classList.add('book_container');
li.append(bookContainer);
for (const key in obj) {
if (key === arr[i]) {
const title = document.createElement('h1');
title.classList.add('title', `title_${key}`);
const author = document.createElement('h2');
author.classList.add('book_author');
const language = document.createElement('p');
language.classList.add('book_language');
title.textContent = obj[key].title;
author.textContent = obj[key].author;
language.textContent = obj[key].language;
bookContainer.append(title, author, language);
}
}
}
}

makeBookList(bookTitles, bookInfo);

function putBookCovers(bookCoversObj) {
for (const key in bookCoversObj) {
if (typeof bookCoversObj === 'object') {
const li = document.querySelector(`#${key}`);
const h1 = document.querySelector(`.title_${key}`);
if (key === li.getAttribute('id')) {
const image = document.createElement('img');
image.setAttribute('src', `${bookCoversObj[key]}`);
image.setAttribute('alt', `book cover ${key}`);
image.classList.add('book_image');
h1.insertAdjacentElement('afterend', image);
}
}
}
}

putBookCovers(bookCovers);
Binary file added Week1/homework/images/a_mind_for_numbers.jpg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added Week1/homework/images/lame_fate.jpg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added Week1/homework/images/other_shores.jpg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added Week1/homework/images/roadside_picnic.jpg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added Week1/homework/images/sailor_song.jpg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added Week1/homework/images/sharp_objects.jpg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added Week1/homework/images/the_brothers_karamazov.jpg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added Week1/homework/images/the_idiot.jpg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added Week1/homework/images/the_luzhin_defense.jpg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
19 changes: 18 additions & 1 deletion Week1/homework/index.html
Original file line number Diff line number Diff line change
@@ -1 +1,18 @@
<!-- replace this with your HTML content -->
<!DOCTYPE html>
<html>

<head>
<meta charset="UTF-8">
<link href="./style.css" rel="stylesheet">
<link rel="preconnect" href="https://fonts.gstatic.com">
<link href="https://fonts.googleapis.com/css2?family=Brygada+1918:wght@600&display=swap" rel="stylesheet">
</head>

<body>
<div class="main">

</div>
<script src='./app.js'></script>
</body>

</html>
65 changes: 64 additions & 1 deletion Week1/homework/style.css
Original file line number Diff line number Diff line change
@@ -1 +1,64 @@
/* add your styling here */
body {
margin: 0;
}
.main {
margin: 0 auto;
font-family: 'Brygada 1918', serif;
background-color: #1d2247;
}

ul {
margin: 0;
list-style-type: none;
padding: 0;
display: grid;
grid-template-columns: repeat(5, 1fr);
gap: 20px;
margin-left: 20px;
}

.book_image {
width: 180px;
height: 280px;
transition: transform 200ms linear;
}

.book_image:hover {
transform: scale(1.2);
}

.book_container {
display: flex;
flex-direction: column;
justify-content: center;
}

.title {
margin: 0;
margin-top: 40px;
color: #fff;
font-size: 27px;
width: 180px;
text-align: center;
min-height: 93px;
}

.book_author {
margin: 0;
margin-top: 20px;
color: #fff;
font-size: 18px;
width: 180px;
height: 45px;
text-align: center;
}

.book_language {
margin: 0;
margin-top: 10px;
margin-bottom: 30px;
color: #fff;
font-size: 15px;
width: 180px;
text-align: center;
}