Skip to content

Commit

Permalink
Шаблонизируй то
Browse files Browse the repository at this point in the history
  • Loading branch information
lunianka committed Apr 14, 2024
1 parent c3761aa commit 74f65ab
Show file tree
Hide file tree
Showing 9 changed files with 125 additions and 23 deletions.
10 changes: 9 additions & 1 deletion src/const.js
Original file line number Diff line number Diff line change
Expand Up @@ -59,6 +59,13 @@ const POINT_EMPTY = {
type: DEFAULT_TYPE
};

const FilterType = {
EVERYTHING: 'everything',
FUTURE: 'future',
PRESENT: 'present',
PAST: 'past'
}

Check failure on line 67 in src/const.js

View workflow job for this annotation

GitHub Actions / Check

Missing semicolon

export {
OFFER_COUNT,
DESTINATION_COUNT,
Expand All @@ -69,5 +76,6 @@ export {
Price,
TYPES,
DEFAULT_TYPE,
POINT_EMPTY
POINT_EMPTY,
FilterType
}

Check failure on line 81 in src/const.js

View workflow job for this annotation

GitHub Actions / Check

Missing semicolon
6 changes: 4 additions & 2 deletions src/main.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import TripInfoView from './view/trip-info-view.js';
import FilterView from './view/filter-view.js';
import TripPresenter from './presenter/trip-presenter.js';
import FilterPresenter from './presenter/filter-presenter.js';
import MockService from './service/mock-service.js';
import DestinationsModel from './model/destinations-model.js';
import OffersModel from './model/offers-model.js';
Expand All @@ -10,15 +10,17 @@ import { render, RenderPosition } from './framework/render.js';
const tripInfoElement = document.querySelector('.trip-main');
const siteMainElement = document.querySelector('.page-main');
const eventListElement = siteMainElement.querySelector('.trip-events');
const filterElement = tripInfoElement.querySelector('.trip-controls__filters');

const mockService = new MockService();
const destinationsModel = new DestinationsModel(mockService);
const offersModel = new OffersModel(mockService);
const pointsModel = new PointsModel(mockService);

const tripPresenter = new TripPresenter({ tripContainer: eventListElement, destinationsModel, offersModel, pointsModel });
const filterPresenter = new FilterPresenter({ container: filterElement, pointsModel });

render(new TripInfoView(), tripInfoElement, RenderPosition.AFTERBEGIN);
render(new FilterView(), tripInfoElement.querySelector('.trip-controls__filters'));

tripPresenter.init();
filterPresenter.init();
11 changes: 11 additions & 0 deletions src/mock/filter.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
import { filter } from "../utils/filter.js";

Check failure on line 1 in src/mock/filter.js

View workflow job for this annotation

GitHub Actions / Check

Strings must use singlequote

const generateFilters = (points) => {

Check failure on line 3 in src/mock/filter.js

View workflow job for this annotation

GitHub Actions / Check

Unexpected block statement surrounding arrow body; move the returned value immediately after the `=>`
return Object.entries(filter)
.map(([filterType, filterPoints]) => ({
type: filterType,
hasPoints: filterPoints(points).length > 0
}));
};

export { generateFilters };
19 changes: 19 additions & 0 deletions src/presenter/filter-presenter.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
import FilterView from "../view/filter-view.js";

Check failure on line 1 in src/presenter/filter-presenter.js

View workflow job for this annotation

GitHub Actions / Check

Strings must use singlequote
import { render } from "../framework/render.js";

Check failure on line 2 in src/presenter/filter-presenter.js

View workflow job for this annotation

GitHub Actions / Check

Strings must use singlequote
import { generateFilters } from "../mock/filter.js";

Check failure on line 3 in src/presenter/filter-presenter.js

View workflow job for this annotation

GitHub Actions / Check

Strings must use singlequote

export default class FilterPresenter {
#container = null;
#pointsModel = null;
#filters = [];

constructor({ container, pointsModel }) {
this.#container = container;
this.#pointsModel = pointsModel;
this.#filters = generateFilters(this.#pointsModel.get());
}

init() {
render(new FilterView(this.#filters), this.#container);
}
}
6 changes: 6 additions & 0 deletions src/presenter/trip-presenter.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ import SortView from '../view/sort-view.js';
import EditPointView from '../view/edit-point-view.js';
import PointView from '../view/point-view.js';
import TripView from '../view/point-list-view.js';
import EmptyListView from '../view/empty-list-view.js';
import { render, replace } from '../framework/render.js';

export default class TripPresenter {
Expand All @@ -23,6 +24,11 @@ export default class TripPresenter {
}

init() {
if (this.#points.length === 0) {
render(new EmptyListView(), this.#tripContainer);
return;
}

render(this.#sortComponent, this.#tripContainer);
render(this.#pointListComponent, this.#tripContainer);

Expand Down
22 changes: 21 additions & 1 deletion src/utils.js
Original file line number Diff line number Diff line change
Expand Up @@ -62,6 +62,10 @@ function formatStringToTime(date) {
return dayjs(date).format('HH:mm');
}

function capitalize(string) {
return `${string[0].toUpperCase()}${string.slice(1)}`;
}

function getPointDuration(dateFrom, dateTo) {
const timeDiff = dayjs(dateTo).diff(dayjs(dateFrom));

Expand All @@ -82,12 +86,28 @@ function getPointDuration(dateFrom, dateTo) {
return pointDuration;
}

function isPointFuture(point) {
return dayjs().isBefore(point.dateFrom);
}

function isPointPresent(point) {
return (dayjs().isAfter(point.dateFrom) && dayjs().isBefore(point.dateTo));
}

function isPointPast(point) {
return dayjs().isAfter(point.dateTo);
}

export {
getDate,
getRandomInteger,
getRandomValue,
formatStringToDateTime,
formatStringToShortDate,
formatStringToTime,
getPointDuration
capitalize,
getPointDuration,
isPointFuture,
isPointPast,
isPointPresent
}
11 changes: 11 additions & 0 deletions src/utils/filter.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
import { FilterType } from "../const.js";
import { isPointFuture, isPointPresent, isPointPast } from "../utils.js";

const filter = {
[FilterType.EVERYTHING]: (points) => [...points],
[FilterType.FUTURE]: (points) => points.filter((point) => isPointFuture(point)),
[FilterType.PRESENT]: (points) => points.filter((point) => isPointPresent(point)),
[FilterType.PAST]: (points) => points.filter((point) => isPointPast(point))
};

export { filter };
16 changes: 16 additions & 0 deletions src/view/empty-list-view.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
import AbstractView from "../framework/view/abstract-view.js";

const createEmptyListViewTemplate = () => {
return (
`<section class="trip-events">
<h2 class="visually-hidden">Trip events</h2>
<p class="trip-events__msg">Click New Event to create your first point</p>
</section>`
);
}

export default class EmptyListView extends AbstractView {
get template() {
return createEmptyListViewTemplate();
}
}
47 changes: 28 additions & 19 deletions src/view/filter-view.js
Original file line number Diff line number Diff line change
@@ -1,32 +1,41 @@
import AbstractView from '../framework/view/abstract-view.js';
import { capitalize } from '../utils.js';

const createFilterTemplate = () => {
const createFilterItemsTemplate = ({ filters }) => {
const filterItems = filters.map(filter => {
return (
`<div class="trip-filters__filter">
<input id="filter-${filter.type}" class="trip-filters__filter-input visually-hidden" type="radio" name="trip-filter" value="${filter.type}"
${(filter.hasPoints) ? '' : 'disabled'}>
<label class="trip-filters__filter-label" for="filter-${filter.type}">${capitalize(filter.type)}</label>
</div>`
)
}).join('');

return filterItems;
}

const createFilterTemplate = ({ filters }) => {
return (
`<form class="trip-filters" action="#" method="get">
<div class="trip-filters__filter">
<input id="filter-everything" class="trip-filters__filter-input visually-hidden" type="radio" name="trip-filter" value="everything">
<label class="trip-filters__filter-label" for="filter-everything">Everything</label>
</div>
<div class="trip-filters__filter">
<input id="filter-future" class="trip-filters__filter-input visually-hidden" type="radio" name="trip-filter" value="future">
<label class="trip-filters__filter-label" for="filter-future">Future</label>
</div>
<div class="trip-filters__filter">
<input id="filter-present" class="trip-filters__filter-input visually-hidden" type="radio" name="trip-filter" value="present">
<label class="trip-filters__filter-label" for="filter-present">Present</label>
</div>
<div class="trip-filters__filter">
<input id="filter-past" class="trip-filters__filter-input visually-hidden" type="radio" name="trip-filter" value="past" checked>
<label class="trip-filters__filter-label" for="filter-past">Past</label>
</div>
<button class="visually-hidden" type="submit">Accept filter</button>
${createFilterItemsTemplate({ filters })}
<button class="visually-hidden" type="submit">Accept filter</button>
</form>`
);
}

export default class FilterView extends AbstractView {
#filters = [];

constructor(filters) {
super();
this.#filters = filters;
}

get template() {
return createFilterTemplate();
return createFilterTemplate({
filters: this.#filters
});
}

}

0 comments on commit 74f65ab

Please sign in to comment.