Skip to content

Commit

Permalink
feat: разбиение js-кода на модули
Browse files Browse the repository at this point in the history
  • Loading branch information
TatianaSenatorova committed Nov 1, 2024
1 parent 08922e3 commit da61ab0
Show file tree
Hide file tree
Showing 5 changed files with 113 additions and 126 deletions.
5 changes: 2 additions & 3 deletions index.html
Original file line number Diff line number Diff line change
Expand Up @@ -7,8 +7,6 @@
<link rel="stylesheet" href="css/style.css">
<link rel="shortcut icon" href="favicon.ico" type="image/x-icon">
<title>Кекстаграм</title>
<script src="js/functions.js" defer></script>
<script src="js/main.js" defer></script>
</head>

<body>
Expand Down Expand Up @@ -235,6 +233,7 @@ <h2 class="success__title">Изображение успешно загруже
<h2 class="data-error__title">Не удалось загрузить данные</h2>
</section>
</template>

<script src="js/main.js" type="module"></script>
<script src="js/functions.js"></script>
</body>
</html>
39 changes: 39 additions & 0 deletions js/create-photos.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
import {getRandomInteger, getIndexIncrement} from './utils.js';
import {getDataForPhotos} from './data.js';

const PHOTO_ITEMS_NUMBER = 25;
const MIN_COMMENTS = 0;
const MAX_COMMENTS = 30;
const MIN_LIKES = 15;
const MAX_LIKES = 200;
const MIN_AVATAR = 1;
const MAX_AVATAR = 6;

const {DESCRIPTIONS, COMMENTS, NAMES} = getDataForPhotos();

const getCommentCounter = getIndexIncrement();

const createComment = (index = getCommentCounter()) => ({
id: `${index}`,
avatar: `img/avatar-${getRandomInteger(MIN_AVATAR, MAX_AVATAR)}.svg`,
message: COMMENTS[getRandomInteger(0, COMMENTS.length - 1)],
name: NAMES[getRandomInteger(0, NAMES.length - 1)],
});

const getPhotoCounter = getIndexIncrement();

const createPhoto = (index = getPhotoCounter()) => ({
id: `${index}`,
url: `photos/${index}.jpg`,
description: DESCRIPTIONS[getRandomInteger(0, DESCRIPTIONS.length - 1)],
likes: getRandomInteger(MIN_LIKES, MAX_LIKES),
comments: Array.from({ length: getRandomInteger(MIN_COMMENTS, MAX_COMMENTS)},
createComment)
});

const listPhotos = Array.from(
{ length: PHOTO_ITEMS_NUMBER },
createPhoto
);

export {listPhotos};
55 changes: 55 additions & 0 deletions js/data.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,55 @@

function getDataForPhotos() {

const DESCRIPTIONS = [
'Самое красивое место',
'Солнечное утро',
'Необычный закат',
'Тихая гладь озера',
'Осенний лес',
'Беззаботная пора',
'Сама милота',
'Самое красивое место',
'Солнечное утро',
'Необычный закат',
'Тихая гладь озера',
'Осенний лес',
'Беззаботная пора',
'Сама милота',
'Самое красивое место',
'Солнечное утро',
'Необычный закат',
'Тихая гладь озера',
'Осенний лес',
'Беззаботная пора',
'Сама милота',
'Самое красивое место',
'Солнечное утро',
'Необычный закат',
'Тихая гладь озера',
'Волшебный закат'
];

const COMMENTS = [
'Всё отлично!',
'В целом всё неплохо. Но не всё.',
'Когда вы делаете фотографию, хорошо бы убирать палец из кадра. В конце концов это просто непрофессионально.',
'Моя бабушка случайно чихнула с фотоаппаратом в руках и у неё получилась фотография лучше.',
'Я поскользнулся на банановой кожуре и уронил фотоаппарат на кота и у меня получилась фотография лучше.',
'Лица у людей на фотке перекошены, как будто их избивают. Как можно было поймать такой неудачный момент?!',
];

const NAMES = [
'Иван',
'Татьяна',
'Мария',
'Владимир',
'Виктор',
'Юлия',
'Петр',
'Сергей',
];
return {DESCRIPTIONS, COMMENTS, NAMES};
}

export {getDataForPhotos};
124 changes: 1 addition & 123 deletions js/main.js
Original file line number Diff line number Diff line change
@@ -1,126 +1,4 @@
/*
В файле main.js напишите необходимые функции для создания массива из 25 сгенерированных объектов. Каждый объект массива — описание фотографии, опубликованной пользователем.
Структура каждого объекта должна быть следующей:
id, число — идентификатор опубликованной фотографии. Это число от 1 до 25. Идентификаторы не должны повторяться.
url, строка — адрес картинки вида photos/{{i}}.jpg, где {{i}} — это число от 1 до 25. Адреса картинок не должны повторяться.
description, строка — описание фотографии. Описание придумайте самостоятельно.
likes, число — количество лайков, поставленных фотографии. Случайное число от 15 до 200.
comments, массив объектов — список комментариев, оставленных другими пользователями к этой фотографии. Количество комментариев к каждой фотографии — случайное число от 0 до 30. Все комментарии генерируются случайным образом. Пример описания объекта с комментарием:
{
id: 135,
avatar: 'img/avatar-6.svg',
message: 'В целом всё неплохо. Но не всё.',
name: 'Артём',
}
У каждого комментария есть идентификатор — id — любое число. Идентификаторы не должны повторяться.
Поле avatar — это строка, значение которой формируется по правилу img/avatar-{{случайное число от 1 до 6}}.svg. Аватарки подготовлены в директории img.
Для формирования текста комментария — message — вам необходимо взять одно или два случайных предложения из представленных ниже:
Имена авторов также должны быть случайными. Набор имён для комментаторов составьте сами. Подставляйте случайное имя в поле name.*/

const PHOTO_ITEMS_NUMBER = 25;
const MIN_COMMENTS = 0;
const MAX_COMMENTS = 30;
const MIN_LIKES = 15;
const MAX_LIKES = 200;
const MIN_AVATAR = 1;
const MAX_AVATAR = 6;

const DESCRIPTIONS = [
'Самое красивое место',
'Солнечное утро',
'Необычный закат',
'Тихая гладь озера',
'Осенний лес',
'Беззаботная пора',
'Сама милота',
'Самое красивое место',
'Солнечное утро',
'Необычный закат',
'Тихая гладь озера',
'Осенний лес',
'Беззаботная пора',
'Сама милота',
'Самое красивое место',
'Солнечное утро',
'Необычный закат',
'Тихая гладь озера',
'Осенний лес',
'Беззаботная пора',
'Сама милота',
'Самое красивое место',
'Солнечное утро',
'Необычный закат',
'Тихая гладь озера',
'Волшебный закат'
];

const COMMENTS = [
'Всё отлично!',
'В целом всё неплохо. Но не всё.',
'Когда вы делаете фотографию, хорошо бы убирать палец из кадра. В конце концов это просто непрофессионально.',
'Моя бабушка случайно чихнула с фотоаппаратом в руках и у неё получилась фотография лучше.',
'Я поскользнулся на банановой кожуре и уронил фотоаппарат на кота и у меня получилась фотография лучше.',
'Лица у людей на фотке перекошены, как будто их избивают. Как можно было поймать такой неудачный момент?!',
];

const NAMES = [
'Иван',
'Татьяна',
'Мария',
'Владимир',
'Виктор',
'Юлия',
'Петр',
'Сергей',
];

const getRandomInteger = (a, b) => {
const lower = Math.ceil(Math.min(a, b));
const upper = Math.floor(Math.max(a, b));
const result = Math.random() * (upper - lower + 1) + lower;
return Math.floor(result);
};

function getIndexIncrement () {
let count = 0;
return function () {
return ++count;
};
}

const getCommentCounter = getIndexIncrement();

const createComment = (index = getCommentCounter()) => ({
id: `${index}`,
avatar: `img/avatar-${getRandomInteger(MIN_AVATAR, MAX_AVATAR)}.svg`,
message: COMMENTS[getRandomInteger(0, COMMENTS.length - 1)],
name: NAMES[getRandomInteger(0, NAMES.length - 1)],
});

const getPhotoCounter = getIndexIncrement();

const createPhoto = (index = getPhotoCounter()) => ({
id: `${index}`,
url: `photos/${index}.jpg`,
description: DESCRIPTIONS[getRandomInteger(0, DESCRIPTIONS.length - 1)],
likes: getRandomInteger(MIN_LIKES, MAX_LIKES),
comments: Array.from({ length: getRandomInteger(MIN_COMMENTS, MAX_COMMENTS)},
createComment)
});

const listPhotos = Array.from(
{ length: PHOTO_ITEMS_NUMBER },
createPhoto
);
import { listPhotos } from './create-photos.js';

// eslint-disable-next-line no-console
console.log(listPhotos);
16 changes: 16 additions & 0 deletions js/utils.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
const getRandomInteger = (a, b) => {
const lower = Math.ceil(Math.min(a, b));
const upper = Math.floor(Math.max(a, b));
const result = Math.random() * (upper - lower + 1) + lower;
return Math.floor(result);
};

function getIndexIncrement () {
let count = 0;
return function () {
return ++count;
};
}

export {getRandomInteger, getIndexIncrement};

0 comments on commit da61ab0

Please sign in to comment.