HEX
Server: nginx/1.18.0
System: Linux test-ipsremont 5.4.0-214-generic #234-Ubuntu SMP Fri Mar 14 23:50:27 UTC 2025 x86_64
User: ips (1000)
PHP: 8.0.30
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/innodrive/src/js/modules/modal-message.js
import { disableBodyScroll, enableBodyScroll } from 'body-scroll-lock';
const template = `<div class="modal-message"><div><h2></h2><p></p><div><button class="button-link">Закрыть</button></div></div></div>`;

class ModalMessage {
  constructor () {
    this.container = document.createElement('div');
    this.container.innerHTML = template;
    this.modal = this.container.querySelector('.modal-message');
    this.msgContainer = this.container.querySelector('.modal-message p');
    this.headingContainer = this.container.querySelector('.modal-message h2');
    this.closeButton = this.container.querySelector('.modal-message button');

    document.querySelector('body').appendChild(this.container);

    this.hide = this.hide.bind(this);

    this.closeButton.addEventListener('click', this.hide);
  }

  show (heading, msg) {
    this.msgContainer.textContent = msg;
    this.headingContainer.textContent = heading;
    this.modal.classList.add('js-shown');
    disableBodyScroll();
  }

  hide () {
    this.msgContainer.textContent = '';
    this.headingContainer.textContent = '';
    this.modal.classList.remove('js-shown');
    enableBodyScroll();
  }
}

export default ModalMessage;