Показать сообщение отдельно
  #2 (permalink)  
Старый 16.01.2021, 00:14
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,127

seven8959,
медитируйте, и возможно исправлено не всё
class CoursView {
    constructor() {
        this.courseList = document.querySelector('#exchange_rates');
        this.courseWidget = document.querySelector('.course_widget');
        this.clearCourse = this.clearCourse.bind(this);
    }


    renderCours(ccy, base_ccy, buy, sale) {
        let li = document.createElement("li");
        let currency = document.createElement("h3");
        let course = document.createElement("p");
        let courseUsd = document.querySelector('.usd');
        let courseEuro = document.querySelector('.euro');
        let courseRur = document.querySelector('.rur');
        let courseBtc = document.querySelector('.btc');

        currency.innerText = ccy;
        course.innerText = `Продажа: ${(buy*1).toFixed(2)}${base_ccy} / Покупка: ${(sale*1).toFixed(2)}${base_ccy}`;

        this.courseList.append(li);
        li.append(currency, course);

    }


    courseError(msg) {
        this.clearCourse();
        let li = document.createElement("li");
        li.innerText = `Ошибка: ${msg}`;
        this.courseList.appendChild(li);
    }


    clearCourse() {
        this.courseList.innerHTML = '';
    }
}



class CoursModel {
    constructor() {
        this.courses = [];
    }


    setCourses(courses) {
        this.courses = courses;
    }


    clear() {
        this.courses = [];
    }
}



class CoursControler {
    constructor(model, view) {
        this.model = model;
        this.view = view;
        this.loadCourse = this.loadCourse;
    }


    handle() {
        this.loadCourse();
        setInterval(this.loadCourse, 3600000);
    }


    loadCourse() {
        this.model.clear();
        fetch('https://api.privatbank.ua/p24api/pubinfo?json&exchange&coursid=5')
            .then(res => res.json())
            .then(result => {
                this.model.setCourses(result);
            })
            .catch(err => {
                console.log(err);
            })
            .finally(() => {
                if(this.model.courses.length === 0) return this.view.courseError('Нет данных');
                let item = this.model.courses[0];
                this.view.renderCours(item.ccy, item.base_ccy, item.buy, item.sale);
                
                this.view.courseWidget.addEventListener('click', function(e) {
                    this.view.clearCourse();
                    if (e.target.className == 'usd') {
                        let item = this.model.courses[0]
                        this.view.renderCours(item.ccy, item.base_ccy, item.buy, item.sale);
                    }
                    else if (e.target.className =='euro') {
                        let item = this.model.courses[1]
                        this.view.renderCours(item.ccy, item.base_ccy, item.buy, item.sale);
                    }
                    else if (e.target.className =='rur') {
                        let item = this.model.courses[2]
                        this.view.renderCours(item.ccy, item.base_ccy, item.buy, item.sale);
                    }
                    else if (e.target.className =='btc') {
                        let item = this.model.courses[3]
                        this.view.renderCours(item.ccy, item.base_ccy, item.buy, item.sale);
                    }
                }.bind(this))
            });
    }

}


const coursView = new CoursView();
const coursModel = new CoursModel();
const coursController = new CoursControler(coursModel, coursView);

coursController.handle();

Последний раз редактировалось рони, 16.01.2021 в 00:25.
Ответить с цитированием