From 5377cac0a5e7011c4371c93310dbedc4a8f7befb Mon Sep 17 00:00:00 2001 From: Geksanit <31949379+Geksanit@users.noreply.github.com> Date: Fri, 24 Nov 2017 16:13:33 +0700 Subject: [PATCH] =?UTF-8?q?=D0=B4=D0=BE=D0=B1=D0=B0=D0=B2=D0=BB=D0=B5?= =?UTF-8?q?=D0=BD=20babel=20=D0=B4=D0=BB=D1=8F=20=D0=BF=D1=80=D0=BE=D0=B4?= =?UTF-8?q?=D0=B0=D0=BA=D1=88=D0=B5=D0=BD=D0=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- build/index.js | 628 ++++++------ frontend/controller/controller.spec.js | 26 +- karma.conf.js | 103 +- package.json | 1 + testing.webpack.js | 68 -- .../controller/controller.spec.js.html | 150 +-- .../report-html/controller/index.html | 36 +- tmp/coverage/report-html/index.html | 36 +- tmp/coverage/report-html/model/index.html | 2 +- tmp/coverage/report-html/view/index.html | 2 +- .../controller/controller.spec.js.html | 150 +-- .../lcov-report/controller/index.html | 36 +- .../report-lcov/lcov-report/index.html | 36 +- .../report-lcov/lcov-report/model/index.html | 2 +- .../report-lcov/lcov-report/view/index.html | 2 +- tmp/coverage/report-lcov/lcov.info | 899 +++++++++--------- webpack.config.js | 153 +-- 17 files changed, 1106 insertions(+), 1224 deletions(-) delete mode 100644 testing.webpack.js diff --git a/build/index.js b/build/index.js index daf5083..d813ccb 100644 --- a/build/index.js +++ b/build/index.js @@ -66,27 +66,26 @@ var scripts = /************************************************************************/ /******/ ([ /* 0 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { +/***/ (function(module, exports, __webpack_require__) { "use strict"; -Object.defineProperty(__webpack_exports__, "__esModule", { value: true }); -/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__index_styl__ = __webpack_require__(1); -/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__index_styl___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__index_styl__); -/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__favicons_favicons__ = __webpack_require__(2); -/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__favicons_favicons___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__favicons_favicons__); -/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__components_sliders_slider__ = __webpack_require__(13); -/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__components_sliders_slider___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2__components_sliders_slider__); -/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__components_standart_button_standart_button__ = __webpack_require__(14); -/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__components_standart_button_standart_button___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3__components_standart_button_standart_button__); -/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__controller_Controller__ = __webpack_require__(15); +__webpack_require__(1); + +__webpack_require__(2); + +__webpack_require__(13); +__webpack_require__(14); +var _Controller = __webpack_require__(15); +var _Controller2 = _interopRequireDefault(_Controller); -const controller = new __WEBPACK_IMPORTED_MODULE_4__controller_Controller__["a" /* default */](); +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } +var controller = new _Controller2.default(); /***/ }), /* 1 */ @@ -98,10 +97,12 @@ const controller = new __WEBPACK_IMPORTED_MODULE_4__controller_Controller__["a" /* 2 */ /***/ (function(module, exports, __webpack_require__) { -const faviconsContext = __webpack_require__(3); +"use strict"; -faviconsContext.keys().forEach(faviconsContext); +var faviconsContext = __webpack_require__(3); + +faviconsContext.keys().forEach(faviconsContext); /***/ }), /* 3 */ @@ -190,366 +191,453 @@ module.exports = __webpack_require__.p + "favicons/safari-pinned-tab.svg"; /***/ }), /* 13 */ -/***/ (function(module, exports) { +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + // slider -const sliderChange = function sliderChange(element) { - const { value } = element; - const width = element.parentElement.clientWidth - 20; - const min = element.attributes.min.value; - const max = element.attributes.max.value; +var sliderChange = function sliderChange(element) { + var value = element.value; + + var width = element.parentElement.clientWidth - 20; + var min = element.attributes.min.value; + var max = element.attributes.max.value; element.previousElementSibling.innerText = value; - element.previousElementSibling.style.left = (((width / (max - min)) * (value - min)) - 8.75) + 'px'; + element.previousElementSibling.style.left = width / (max - min) * (value - min) - 8.75 + 'px'; }; -const sliderInput = function sliderInput(event) { +var sliderInput = function sliderInput(event) { sliderChange(event.target); }; (function initSliders() { - const elements = document.querySelectorAll('.js-slider__input'); - for (let i = 0; i < elements.length; i += 1) { + var elements = document.querySelectorAll('.js-slider__input'); + for (var i = 0; i < elements.length; i += 1) { sliderChange(elements[i]); elements[i].oninput = sliderInput; } -}()); - +})(); /***/ }), /* 14 */ -/***/ (function(module, exports) { +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + // ripple effect -const buttonClick = function buttonClick(event) { - const div = document.createElement('div'); +var buttonClick = function buttonClick(event) { + var div = document.createElement('div'); div.id = 'ripple'; div.style.top = event.pageY - 25 + 'px'; div.style.left = event.pageX - 25 + 'px'; document.body.appendChild(div); - setTimeout(() => { document.body.removeChild(div); }, 550); + setTimeout(function () { + document.body.removeChild(div); + }, 550); }; (function initButtons() { - const elements = document.querySelectorAll('.standart-button'); - for (let i = 0; i < elements.length; i += 1) { + var elements = document.querySelectorAll('.standart-button'); + for (var i = 0; i < elements.length; i += 1) { elements[i].onclick = buttonClick; } -}()); - +})(); /***/ }), /* 15 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { +/***/ (function(module, exports, __webpack_require__) { "use strict"; -/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__model_Board__ = __webpack_require__(16); -/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__view_Painter__ = __webpack_require__(17); +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); + +var _Board = __webpack_require__(16); + +var _Board2 = _interopRequireDefault(_Board); +var _Painter = __webpack_require__(17); + +var _Painter2 = _interopRequireDefault(_Painter); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } + +var Controller = function () { + function Controller() { + _classCallCheck(this, Controller); -class Controller { - constructor() { this.running = false; this.table = document.getElementById('board'); this.controls = document.getElementById('controls'); - this.board = new __WEBPACK_IMPORTED_MODULE_0__model_Board__["a" /* default */](10, 10); - this.painter = new __WEBPACK_IMPORTED_MODULE_1__view_Painter__["a" /* default */](this.board, this.table); + this.board = new _Board2.default(10, 10); + this.painter = new _Painter2.default(this.board, this.table); this.fps = 1; - this.painter.newTable();// начальная отрисовка + this.painter.newTable(); // начальная отрисовка this.buttonsDisable(); this.table.onclick = this.tableSetCell.bind(this); this.controls.onclick = this.buttunsOnclick.bind(this); this.controls.onchange = this.slidersChange.bind(this); } - buttonsDisable() { - const buttons = document.getElementsByTagName('BUTTON'); - if (buttons === undefined) { - console.log('buttuns not found'); - return; - } - // console.log(buttons); - for (let i = 0; i < buttons.length; i += 1) { - const button = buttons[i]; - if (button.innerHTML === 'start') { - if (this.running) button.disabled = true; - else button.disabled = false; + + _createClass(Controller, [{ + key: 'buttonsDisable', + value: function buttonsDisable() { + var buttons = document.getElementsByTagName('BUTTON'); + if (buttons === undefined) { + console.log('buttuns not found'); + return; } - if (button.innerHTML === 'pause') { - if (this.running) button.disabled = false; - else button.disabled = true; + // console.log(buttons); + for (var i = 0; i < buttons.length; i += 1) { + var button = buttons[i]; + if (button.innerHTML === 'start') { + if (this.running) button.disabled = true;else button.disabled = false; + } + if (button.innerHTML === 'pause') { + if (this.running) button.disabled = false;else button.disabled = true; + } } } - } - tableSetCell(event) { - // console.log(event.target); - const { target } = event; - if (target.tagName !== 'TD') return; - const j = target.cellIndex; - const i = target.parentElement.sectionRowIndex; - target.classList.toggle('live'); - this.board.setCell(i, j); - } - anim(callback) { - // останавливается и вызывет аргумент, когда матрица перестает меняться - // console.log('anim started'); - let oldMatrix; - function loop() { - const { fps } = this; - setTimeout(() => { - if (this.running) { - requestAnimationFrame(loop.bind(this));// не блокирует поток! - this.board.worker(); - this.painter.repainter(); - // если матрица не меняется, ссылка остаетя актуальной - if (oldMatrix === this.board.matrix) { - this.running = false; - this.buttonsDisable(); - } else oldMatrix = this.board.matrix; - } else if (callback) { - // console.log('anim stopped'); - callback(); - } - }, 1000 / fps); + }, { + key: 'tableSetCell', + value: function tableSetCell(event) { + // console.log(event.target); + var target = event.target; + + if (target.tagName !== 'TD') return; + var j = target.cellIndex; + var i = target.parentElement.sectionRowIndex; + target.classList.toggle('live'); + this.board.setCell(i, j); } - loop.call(this); - } - buttunsOnclick(event) { - const { target } = event; - if (target.tagName !== 'BUTTON') return; - switch (target.innerHTML) { - case 'start': - this.running = true; - this.buttonsDisable(); - this.anim(); - break; - case 'pause': - this.running = false; - this.buttonsDisable(); - break; - case 'clear': - this.board.clear(); - this.running = false; - this.buttonsDisable(); - this.painter.repainter(); + }, { + key: 'anim', + value: function anim(callback) { + // останавливается и вызывет аргумент, когда матрица перестает меняться + // console.log('anim started'); + var oldMatrix = void 0; + function loop() { + var _this = this; + + var fps = this.fps; + + setTimeout(function () { + if (_this.running) { + requestAnimationFrame(loop.bind(_this)); // не блокирует поток! + _this.board.worker(); + _this.painter.repainter(); + // если матрица не меняется, ссылка остаетя актуальной + if (oldMatrix === _this.board.matrix) { + _this.running = false; + _this.buttonsDisable(); + } else oldMatrix = _this.board.matrix; + } else if (callback) { + // console.log('anim stopped'); + callback(); + } + }, 1000 / fps); + } + loop.call(this); } - } - slidersChange(event) { - const { target } = event; - if (target.tagName !== 'INPUT') return; - const value = target.valueAsNumber; - switch (target.parentElement.previousElementSibling.innerText) { - case 'speed': - this.fps = value; - break; - case 'width': - this.running = false; - this.buttonsDisable(); - this.board.resize(this.board.m, value); - this.painter.newTable(); - break; - case 'height': - this.running = false; - this.buttonsDisable(); - this.board.resize(value, this.board.n); - this.painter.newTable(); + }, { + key: 'buttunsOnclick', + value: function buttunsOnclick(event) { + var target = event.target; + + if (target.tagName !== 'BUTTON') return; + switch (target.innerHTML) { + case 'start': + this.running = true; + this.buttonsDisable(); + this.anim(); + break; + case 'pause': + this.running = false; + this.buttonsDisable(); + break; + case 'clear': + this.board.clear(); + this.running = false; + this.buttonsDisable(); + this.painter.repainter(); + } } - } -} -/* harmony export (immutable) */ __webpack_exports__["a"] = Controller; + }, { + key: 'slidersChange', + value: function slidersChange(event) { + var target = event.target; + + if (target.tagName !== 'INPUT') return; + var value = target.valueAsNumber; + switch (target.parentElement.previousElementSibling.innerText) { + case 'speed': + this.fps = value; + break; + case 'width': + this.running = false; + this.buttonsDisable(); + this.board.resize(this.board.m, value); + this.painter.newTable(); + break; + case 'height': + this.running = false; + this.buttonsDisable(); + this.board.resize(value, this.board.n); + this.painter.newTable(); + } + } + }]); + return Controller; +}(); +exports.default = Controller; /***/ }), /* 16 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { +/***/ (function(module, exports, __webpack_require__) { "use strict"; -class Board { - constructor(m = 10, n = 10) { + + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); + +function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } + +var Board = function () { + function Board() { + var m = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 10; + var n = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 10; + + _classCallCheck(this, Board); + // матрица m на n заполненная false this.matrix = []; - this.m = m;// строки - this.n = n;// столбцы - for (let i = 0; i < m; i += 1) { - const line = []; - for (let j = 0; j < n; j += 1) { + this.m = m; // строки + this.n = n; // столбцы + for (var i = 0; i < m; i += 1) { + var line = []; + for (var j = 0; j < n; j += 1) { line.push(false); } this.matrix.push(line); } } - resize(m, n) { - const { matrix } = this; - const o = matrix.length; - const p = matrix[0].length; - - // console.log('resize',o,p,' to ',m,n); - // убираем столбцы - if (p > n) { - for (let i = 0; i < o; i += 1) { - matrix[i].splice(n - 1, p - n);// изменить length? + + _createClass(Board, [{ + key: "resize", + value: function resize(m, n) { + var matrix = this.matrix; + + var o = matrix.length; + var p = matrix[0].length; + + // console.log('resize',o,p,' to ',m,n); + // убираем столбцы + if (p > n) { + for (var i = 0; i < o; i += 1) { + matrix[i].splice(n - 1, p - n); // изменить length? + } } - } - // добавляем столбцы - if (p < n) { - for (let i = 0; i < o; i += 1) { - for (let j = p; j < n; j += 1) { - matrix[i].push(false); + // добавляем столбцы + if (p < n) { + for (var _i = 0; _i < o; _i += 1) { + for (var j = p; j < n; j += 1) { + matrix[_i].push(false); + } } } - } - // убираем строки - if (o > m) matrix.splice(m - 1, o - m);// изменить length? + // убираем строки + if (o > m) matrix.splice(m - 1, o - m); // изменить length? - // добавляем строки - if (o < m) { - const line = []; - for (let j = 0; j < n; j += 1) { - line.push(false); - } + // добавляем строки + if (o < m) { + var line = []; + for (var _j = 0; _j < n; _j += 1) { + line.push(false); + } - for (let i = o; i < m; i += 1) { - matrix.push(line.slice()); + for (var _i2 = o; _i2 < m; _i2 += 1) { + matrix.push(line.slice()); + } } - } - this.m = m; - this.n = n; - return this; - } - clear() { - for (let i = 0; i < this.m; i += 1) { - for (let j = 0; j < this.n; j += 1) { - this.matrix[i][j] = false; + this.m = m; + this.n = n; + return this; + } + }, { + key: "clear", + value: function clear() { + for (var i = 0; i < this.m; i += 1) { + for (var j = 0; j < this.n; j += 1) { + this.matrix[i][j] = false; + } } + + return this; } + }, { + key: "worker", + value: function worker() { + // обход всех ячеек с записью нового состояния + var newMatrix = []; + var flag = false; // изменмлась ли матрица? + for (var i = 0; i < this.matrix.length; i += 1) { + var newLine = []; + for (var j = 0; j < this.matrix[0].length; j += 1) { + var cell = this.cell(i, j); + newLine.push(cell); + if (cell !== this.matrix[i][j]) flag = true; + } - return this; - } - worker() { - // обход всех ячеек с записью нового состояния - const newMatrix = []; - let flag = false;// изменмлась ли матрица? - for (let i = 0; i < this.matrix.length; i += 1) { - const newLine = []; - for (let j = 0; j < this.matrix[0].length; j += 1) { - const cell = this.cell(i, j); - newLine.push(cell); - if (cell !== this.matrix[i][j]) flag = true; + newMatrix.push(newLine); } - newMatrix.push(newLine); + if (flag) this.matrix = newMatrix; + return this; } + }, { + key: "cell", + value: function cell(i, j) { + // вычисляет новое состояние клетки + // соседи за пределами поля считаются мертвыми + var count = 0; // живые соседи + var newCell = this.matrix[i][j]; + + if (this.matrix[i - 1]) { + if (this.matrix[i - 1][j - 1]) count += 1; + if (this.matrix[i - 1][j]) count += 1; + if (this.matrix[i - 1][j + 1]) count += 1; + } - if (flag) this.matrix = newMatrix; - return this; - } - cell(i, j) { - // вычисляет новое состояние клетки - // соседи за пределами поля считаются мертвыми - let count = 0;// живые соседи - let newCell = this.matrix[i][j]; - - if (this.matrix[i - 1]) { - if (this.matrix[i - 1][j - 1]) count += 1; - if (this.matrix[i - 1][j]) count += 1; - if (this.matrix[i - 1][j + 1]) count += 1; - } + if (this.matrix[i][j - 1]) count += 1; + if (this.matrix[i][j + 1]) count += 1; - if (this.matrix[i][j - 1]) count += 1; - if (this.matrix[i][j + 1]) count += 1; + if (this.matrix[i + 1]) { + if (this.matrix[i + 1][j - 1]) count += 1; + if (this.matrix[i + 1][j]) count += 1; + if (this.matrix[i + 1][j + 1]) count += 1; + } - if (this.matrix[i + 1]) { - if (this.matrix[i + 1][j - 1]) count += 1; - if (this.matrix[i + 1][j]) count += 1; - if (this.matrix[i + 1][j + 1]) count += 1; + if (count < 2 || count > 3) newCell = false;else if (count === 3) newCell = true; + return newCell; } + }, { + key: "setCell", + value: function setCell(i, j) { + this.matrix[i][j] = !this.matrix[i][j]; + } + }]); - if (count < 2 || count > 3) newCell = false; - else if (count === 3) newCell = true; - return newCell; - } - setCell(i, j) { - this.matrix[i][j] = !this.matrix[i][j]; - } -} -/* harmony export (immutable) */ __webpack_exports__["a"] = Board; - + return Board; +}(); +exports.default = Board; /***/ }), /* 17 */ -/***/ (function(module, __webpack_exports__, __webpack_require__) { +/***/ (function(module, exports, __webpack_require__) { "use strict"; -class Painter { - constructor(board, table) { + + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); + +function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } + +var Painter = function () { + function Painter(board, table) { + _classCallCheck(this, Painter); + // console.log('construct', table); this.table = table; this.board = board; } - painter(tableWidth) { - // заполнение тела таблицы - const { matrix } = this.board; - const m = matrix.length; - const n = matrix[0].length; - // console.log(m,n); - const width = tableWidth / n; - const height = width; - - const tbody = document.createElement('tbody'); - for (let i = 0; i < m; i += 1) { - const tr = document.createElement('tr'); - for (let j = 0; j < n; j += 1) { - const td = document.createElement('td'); - td.style.width = width + 'px'; - td.style.height = height + 'px'; - if (matrix[i][j]) td.className = 'live'; - tr.appendChild(td); + _createClass(Painter, [{ + key: 'painter', + value: function painter(tableWidth) { + // заполнение тела таблицы + var matrix = this.board.matrix; + + var m = matrix.length; + var n = matrix[0].length; + // console.log(m,n); + var width = tableWidth / n; + var height = width; + + var tbody = document.createElement('tbody'); + for (var i = 0; i < m; i += 1) { + var tr = document.createElement('tr'); + for (var j = 0; j < n; j += 1) { + var td = document.createElement('td'); + td.style.width = width + 'px'; + td.style.height = height + 'px'; + if (matrix[i][j]) td.className = 'live'; + tr.appendChild(td); + } + + tbody.appendChild(tr); } - tbody.appendChild(tr); + return tbody; } - - return tbody; - } - - newTable() { - // для создания и ресайза таблицы - const { table } = this; - const tbody = this.painter(table.clientWidth); - if (table.children.length) table.replaceChild(tbody, table.children[0]); - else table.appendChild(tbody); - } - - repainter() { - // изменение класса у ячеек таблицы - const { table } = this; - const { matrix } = this.board; - const tbody = table.children[0]; - const m = matrix.length; - const n = matrix[0].length; - // console.log(m,n); - - for (let i = 0; i < m; i += 1) { - for (let j = 0; j < n; j += 1) { - const td = tbody.children[i].children[j]; - if (matrix[i][j]) td.className = 'live'; - else td.className = ''; + }, { + key: 'newTable', + value: function newTable() { + // для создания и ресайза таблицы + var table = this.table; + + var tbody = this.painter(table.clientWidth); + if (table.children.length) table.replaceChild(tbody, table.children[0]);else table.appendChild(tbody); + } + }, { + key: 'repainter', + value: function repainter() { + // изменение класса у ячеек таблицы + var table = this.table; + var matrix = this.board.matrix; + + var tbody = table.children[0]; + var m = matrix.length; + var n = matrix[0].length; + // console.log(m,n); + + for (var i = 0; i < m; i += 1) { + for (var j = 0; j < n; j += 1) { + var td = tbody.children[i].children[j]; + if (matrix[i][j]) td.className = 'live';else td.className = ''; + } } } - } -} -/* harmony export (immutable) */ __webpack_exports__["a"] = Painter; + }]); + return Painter; +}(); +exports.default = Painter; /***/ }) /******/ ]); -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///webpack/bootstrap 9b471eb21a22b6b2bce6","webpack:///./index.js","webpack:///./index.styl","webpack:///./favicons/favicons.js","webpack:///../node_modules/file-loader/dist/cjs.js","webpack:///./favicons/android-chrome-48x48.png","webpack:///./favicons/apple-touch-icon.png","webpack:///./favicons/browserconfig.xml","webpack:///./favicons/favicon-16x16.png","webpack:///./favicons/favicon-32x32.png","webpack:///./favicons/favicon.ico","webpack:///./favicons/manifest.json","webpack:///./favicons/mstile-150x150.png","webpack:///./favicons/safari-pinned-tab.svg","webpack:///./components/sliders/slider.js","webpack:///./components/standart-button/standart-button.js","webpack:///./controller/Controller.js","webpack:///./model/Board.js","webpack:///./view/Painter.js"],"names":[],"mappings":";;AAAA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;;AAGA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAK;AACL;AACA;;AAEA;AACA;AACA;AACA,mCAA2B,0BAA0B,EAAE;AACvD,yCAAiC,eAAe;AAChD;AACA;AACA;;AAEA;AACA,8DAAsD,+DAA+D;;AAErH;AACA;;AAEA;AACA;;;;;;;;;;;;;;;;;;AC7DA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACNA,yC;;;;;;ACAA;;AAEA;;;;;;;ACFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sB;;;;;;ACzBA,6E;;;;;;ACAA,yE;;;;;;ACAA,sE;;;;;;ACAA,sE;;;;;;ACAA,sE;;;;;;ACAA,gE;;;;;;ACAA,kE;;;;;;ACAA,uE;;;;;;ACAA,0E;;;;;;ACAA;AACA;AACA,SAAS,QAAQ;AACjB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,iBAAiB,qBAAqB;AACtC;AACA;AACA;AACA,CAAC;;;;;;;ACpBD;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,oBAAoB,gCAAgC,EAAE;AACtD;;AAEA;AACA;AACA,iBAAiB,qBAAqB;AACtC;AACA;AACA,CAAC;;;;;;;;;;;ACfD;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4BAA4B;AAC5B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,oBAAoB;AACvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,MAAM;AACnB;AACA;AACA,iDAAiD;AACjD;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX,SAAS;AACT;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;;;;;;;;AC/GA;AACA;AACA;AACA;AACA,eAAe;AACf,eAAe;AACf,mBAAmB,OAAO;AAC1B;AACA,qBAAqB,OAAO;AAC5B;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,SAAS;AACpB;AACA;;AAEA;AACA;AACA;AACA,qBAAqB,OAAO;AAC5B,uCAAuC;AACvC;AACA;;AAEA;AACA;AACA,qBAAqB,OAAO;AAC5B,uBAAuB,OAAO;AAC9B;AACA;AACA;AACA;;AAEA;AACA,2CAA2C;;AAE3C;AACA;AACA;AACA,qBAAqB,OAAO;AAC5B;AACA;;AAEA,qBAAqB,OAAO;AAC5B;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,mBAAmB,YAAY;AAC/B,qBAAqB,YAAY;AACjC;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB,mBAAmB,wBAAwB;AAC3C;AACA,qBAAqB,2BAA2B;AAChD;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB;AAClB;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;;;;;;;;AC/GA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,WAAW,SAAS;AACpB;AACA;AACA;AACA;AACA;;AAEA;AACA,mBAAmB,OAAO;AAC1B;AACA,qBAAqB,OAAO;AAC5B;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,WAAW,QAAQ;AACnB;AACA;AACA;AACA;;AAEA;AACA;AACA,WAAW,QAAQ;AACnB,WAAW,SAAS;AACpB;AACA;AACA;AACA;;AAEA,mBAAmB,OAAO;AAC1B,qBAAqB,OAAO;AAC5B;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA","file":"index.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, {\n \t\t\t\tconfigurable: false,\n \t\t\t\tenumerable: true,\n \t\t\t\tget: getter\n \t\t\t});\n \t\t}\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 0);\n\n\n\n// WEBPACK FOOTER //\n// webpack/bootstrap 9b471eb21a22b6b2bce6","import './index.styl';\r\nimport './favicons/favicons';\r\nimport './components/sliders/slider';\r\nimport './components/standart-button/standart-button';\r\nimport Controller from './controller/Controller';\r\n\r\nconst controller = new Controller();\r\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./index.js\n// module id = 0\n// module chunks = 0","// removed by extract-text-webpack-plugin\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./index.styl\n// module id = 1\n// module chunks = 0","const faviconsContext = require.context('!!file-loader?name=favicons/[name].[ext]!.', true, /\\.(svg|png|ico|xml|json)$/);\r\n\r\nfaviconsContext.keys().forEach(faviconsContext);\r\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./favicons/favicons.js\n// module id = 2\n// module chunks = 0","var map = {\n\t\"./android-chrome-48x48.png\": 4,\n\t\"./apple-touch-icon.png\": 5,\n\t\"./browserconfig.xml\": 6,\n\t\"./favicon-16x16.png\": 7,\n\t\"./favicon-32x32.png\": 8,\n\t\"./favicon.ico\": 9,\n\t\"./manifest.json\": 10,\n\t\"./mstile-150x150.png\": 11,\n\t\"./safari-pinned-tab.svg\": 12\n};\nfunction webpackContext(req) {\n\treturn __webpack_require__(webpackContextResolve(req));\n};\nfunction webpackContextResolve(req) {\n\tvar id = map[req];\n\tif(!(id + 1)) // check for number or string\n\t\tthrow new Error(\"Cannot find module '\" + req + \"'.\");\n\treturn id;\n};\nwebpackContext.keys = function webpackContextKeys() {\n\treturn Object.keys(map);\n};\nwebpackContext.resolve = webpackContextResolve;\nmodule.exports = webpackContext;\nwebpackContext.id = 3;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./favicons !../node_modules/file-loader/dist/cjs.js?name=favicons/[name].[ext] \\.(svg|png|ico|xml|json)$\n// module id = 3\n// module chunks = 0","module.exports = __webpack_public_path__ + \"favicons/android-chrome-48x48.png\";\n\n\n//////////////////\n// WEBPACK FOOTER\n// ../node_modules/file-loader/dist/cjs.js?name=favicons/[name].[ext]!./favicons/android-chrome-48x48.png\n// module id = 4\n// module chunks = 0","module.exports = __webpack_public_path__ + \"favicons/apple-touch-icon.png\";\n\n\n//////////////////\n// WEBPACK FOOTER\n// ../node_modules/file-loader/dist/cjs.js?name=favicons/[name].[ext]!./favicons/apple-touch-icon.png\n// module id = 5\n// module chunks = 0","module.exports = __webpack_public_path__ + \"favicons/browserconfig.xml\";\n\n\n//////////////////\n// WEBPACK FOOTER\n// ../node_modules/file-loader/dist/cjs.js?name=favicons/[name].[ext]!./favicons/browserconfig.xml\n// module id = 6\n// module chunks = 0","module.exports = __webpack_public_path__ + \"favicons/favicon-16x16.png\";\n\n\n//////////////////\n// WEBPACK FOOTER\n// ../node_modules/file-loader/dist/cjs.js?name=favicons/[name].[ext]!./favicons/favicon-16x16.png\n// module id = 7\n// module chunks = 0","module.exports = __webpack_public_path__ + \"favicons/favicon-32x32.png\";\n\n\n//////////////////\n// WEBPACK FOOTER\n// ../node_modules/file-loader/dist/cjs.js?name=favicons/[name].[ext]!./favicons/favicon-32x32.png\n// module id = 8\n// module chunks = 0","module.exports = __webpack_public_path__ + \"favicons/favicon.ico\";\n\n\n//////////////////\n// WEBPACK FOOTER\n// ../node_modules/file-loader/dist/cjs.js?name=favicons/[name].[ext]!./favicons/favicon.ico\n// module id = 9\n// module chunks = 0","module.exports = __webpack_public_path__ + \"favicons/manifest.json\";\n\n\n//////////////////\n// WEBPACK FOOTER\n// ../node_modules/file-loader/dist/cjs.js?name=favicons/[name].[ext]!./favicons/manifest.json\n// module id = 10\n// module chunks = 0","module.exports = __webpack_public_path__ + \"favicons/mstile-150x150.png\";\n\n\n//////////////////\n// WEBPACK FOOTER\n// ../node_modules/file-loader/dist/cjs.js?name=favicons/[name].[ext]!./favicons/mstile-150x150.png\n// module id = 11\n// module chunks = 0","module.exports = __webpack_public_path__ + \"favicons/safari-pinned-tab.svg\";\n\n\n//////////////////\n// WEBPACK FOOTER\n// ../node_modules/file-loader/dist/cjs.js?name=favicons/[name].[ext]!./favicons/safari-pinned-tab.svg\n// module id = 12\n// module chunks = 0","// slider\r\nconst sliderChange = function sliderChange(element) {\r\n  const { value } = element;\r\n  const width = element.parentElement.clientWidth - 20;\r\n  const min = element.attributes.min.value;\r\n  const max = element.attributes.max.value;\r\n  element.previousElementSibling.innerText = value;\r\n  element.previousElementSibling.style.left = (((width / (max - min)) * (value - min)) - 8.75) + 'px';\r\n};\r\n\r\nconst sliderInput = function sliderInput(event) {\r\n  sliderChange(event.target);\r\n};\r\n\r\n(function initSliders() {\r\n  const elements = document.querySelectorAll('.js-slider__input');\r\n  for (let i = 0; i < elements.length; i += 1) {\r\n    sliderChange(elements[i]);\r\n    elements[i].oninput = sliderInput;\r\n  }\r\n}());\r\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./components/sliders/slider.js\n// module id = 13\n// module chunks = 0","// ripple effect\r\nconst buttonClick = function buttonClick(event) {\r\n  const div = document.createElement('div');\r\n  div.id = 'ripple';\r\n  div.style.top = event.pageY - 25 + 'px';\r\n  div.style.left = event.pageX - 25 + 'px';\r\n\r\n  document.body.appendChild(div);\r\n  setTimeout(() => { document.body.removeChild(div); }, 550);\r\n};\r\n\r\n(function initButtons() {\r\n  const elements = document.querySelectorAll('.standart-button');\r\n  for (let i = 0; i < elements.length; i += 1) {\r\n    elements[i].onclick = buttonClick;\r\n  }\r\n}());\r\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./components/standart-button/standart-button.js\n// module id = 14\n// module chunks = 0","\r\nimport Board from '../model/Board';\r\nimport Painter from '../view/Painter';\r\n\r\nexport default class Controller {\r\n  constructor() {\r\n    this.running = false;\r\n    this.table = document.getElementById('board');\r\n    this.controls = document.getElementById('controls');\r\n    this.board = new Board(10, 10);\r\n    this.painter = new Painter(this.board, this.table);\r\n    this.fps = 1;\r\n    this.painter.newTable();// начальная отрисовка\r\n    this.buttonsDisable();\r\n    this.table.onclick = this.tableSetCell.bind(this);\r\n    this.controls.onclick = this.buttunsOnclick.bind(this);\r\n    this.controls.onchange = this.slidersChange.bind(this);\r\n  }\r\n  buttonsDisable() {\r\n    const buttons = document.getElementsByTagName('BUTTON');\r\n    if (buttons === undefined) {\r\n      console.log('buttuns not found');\r\n      return;\r\n    }\r\n    // console.log(buttons);\r\n    for (let i = 0; i < buttons.length; i += 1) {\r\n      const button = buttons[i];\r\n      if (button.innerHTML === 'start') {\r\n        if (this.running) button.disabled = true;\r\n        else button.disabled = false;\r\n      }\r\n      if (button.innerHTML === 'pause') {\r\n        if (this.running) button.disabled = false;\r\n        else button.disabled = true;\r\n      }\r\n    }\r\n  }\r\n  tableSetCell(event) {\r\n    // console.log(event.target);\r\n    const { target } = event;\r\n    if (target.tagName !== 'TD') return;\r\n    const j = target.cellIndex;\r\n    const i = target.parentElement.sectionRowIndex;\r\n    target.classList.toggle('live');\r\n    this.board.setCell(i, j);\r\n  }\r\n  anim(callback) {\r\n    // останавливается и вызывет аргумент, когда матрица перестает меняться\r\n    // console.log('anim started');\r\n    let oldMatrix;\r\n    function loop() {\r\n      const { fps } = this;\r\n      setTimeout(() => {\r\n        if (this.running) {\r\n          requestAnimationFrame(loop.bind(this));// не блокирует поток!\r\n          this.board.worker();\r\n          this.painter.repainter();\r\n          // если матрица не меняется, ссылка остаетя актуальной\r\n          if (oldMatrix === this.board.matrix) {\r\n            this.running = false;\r\n            this.buttonsDisable();\r\n          } else oldMatrix = this.board.matrix;\r\n        } else if (callback) {\r\n          // console.log('anim stopped');\r\n          callback();\r\n        }\r\n      }, 1000 / fps);\r\n    }\r\n    loop.call(this);\r\n  }\r\n  buttunsOnclick(event) {\r\n    const { target } = event;\r\n    if (target.tagName !== 'BUTTON') return;\r\n    switch (target.innerHTML) {\r\n      case 'start':\r\n        this.running = true;\r\n        this.buttonsDisable();\r\n        this.anim();\r\n        break;\r\n      case 'pause':\r\n        this.running = false;\r\n        this.buttonsDisable();\r\n        break;\r\n      case 'clear':\r\n        this.board.clear();\r\n        this.running = false;\r\n        this.buttonsDisable();\r\n        this.painter.repainter();\r\n    }\r\n  }\r\n  slidersChange(event) {\r\n    const { target } = event;\r\n    if (target.tagName !== 'INPUT') return;\r\n    const value = target.valueAsNumber;\r\n    switch (target.parentElement.previousElementSibling.innerText) {\r\n      case 'speed':\r\n        this.fps = value;\r\n        break;\r\n      case 'width':\r\n        this.running = false;\r\n        this.buttonsDisable();\r\n        this.board.resize(this.board.m, value);\r\n        this.painter.newTable();\r\n        break;\r\n      case 'height':\r\n        this.running = false;\r\n        this.buttonsDisable();\r\n        this.board.resize(value, this.board.n);\r\n        this.painter.newTable();\r\n    }\r\n  }\r\n}\r\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./controller/Controller.js\n// module id = 15\n// module chunks = 0","export default class Board {\r\n  constructor(m = 10, n = 10) {\r\n    // матрица m на n заполненная false\r\n    this.matrix = [];\r\n    this.m = m;// строки\r\n    this.n = n;// столбцы\r\n    for (let i = 0; i < m; i += 1) {\r\n      const line = [];\r\n      for (let j = 0; j < n; j += 1) {\r\n        line.push(false);\r\n      }\r\n\r\n      this.matrix.push(line);\r\n    }\r\n  }\r\n  resize(m, n) {\r\n    const { matrix } = this;\r\n    const o = matrix.length;\r\n    const p = matrix[0].length;\r\n\r\n    // console.log('resize',o,p,' to ',m,n);\r\n    // убираем столбцы\r\n    if (p > n) {\r\n      for (let i = 0; i < o; i += 1) {\r\n        matrix[i].splice(n - 1, p - n);// изменить length?\r\n      }\r\n    }\r\n\r\n    // добавляем столбцы\r\n    if (p < n) {\r\n      for (let i = 0; i < o; i += 1) {\r\n        for (let j = p; j < n; j += 1) {\r\n          matrix[i].push(false);\r\n        }\r\n      }\r\n    }\r\n\r\n    // убираем строки\r\n    if (o > m) matrix.splice(m - 1, o - m);// изменить length?\r\n\r\n    // добавляем строки\r\n    if (o < m) {\r\n      const line = [];\r\n      for (let j = 0; j < n; j += 1) {\r\n        line.push(false);\r\n      }\r\n\r\n      for (let i = o; i < m; i += 1) {\r\n        matrix.push(line.slice());\r\n      }\r\n    }\r\n\r\n    this.m = m;\r\n    this.n = n;\r\n    return this;\r\n  }\r\n  clear() {\r\n    for (let i = 0; i < this.m; i += 1) {\r\n      for (let j = 0; j < this.n; j += 1) {\r\n        this.matrix[i][j] = false;\r\n      }\r\n    }\r\n\r\n    return this;\r\n  }\r\n  worker() {\r\n    // обход всех ячеек с записью нового состояния\r\n    const newMatrix = [];\r\n    let flag = false;// изменмлась ли матрица?\r\n    for (let i = 0; i < this.matrix.length; i += 1) {\r\n      const newLine = [];\r\n      for (let j = 0; j < this.matrix[0].length; j += 1) {\r\n        const cell = this.cell(i, j);\r\n        newLine.push(cell);\r\n        if (cell !== this.matrix[i][j]) flag = true;\r\n      }\r\n\r\n      newMatrix.push(newLine);\r\n    }\r\n\r\n    if (flag) this.matrix = newMatrix;\r\n    return this;\r\n  }\r\n  cell(i, j) {\r\n    // вычисляет новое состояние клетки\r\n    // соседи за пределами поля считаются мертвыми\r\n    let count = 0;// живые соседи\r\n    let newCell = this.matrix[i][j];\r\n\r\n    if (this.matrix[i - 1]) {\r\n      if (this.matrix[i - 1][j - 1]) count += 1;\r\n      if (this.matrix[i - 1][j]) count += 1;\r\n      if (this.matrix[i - 1][j + 1]) count += 1;\r\n    }\r\n\r\n    if (this.matrix[i][j - 1]) count += 1;\r\n    if (this.matrix[i][j + 1]) count += 1;\r\n\r\n    if (this.matrix[i + 1]) {\r\n      if (this.matrix[i + 1][j - 1]) count += 1;\r\n      if (this.matrix[i + 1][j]) count += 1;\r\n      if (this.matrix[i + 1][j + 1]) count += 1;\r\n    }\r\n\r\n    if (count < 2 || count > 3) newCell = false;\r\n    else if (count === 3) newCell = true;\r\n    return newCell;\r\n  }\r\n  setCell(i, j) {\r\n    this.matrix[i][j] = !this.matrix[i][j];\r\n  }\r\n}\r\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./model/Board.js\n// module id = 16\n// module chunks = 0","export default class Painter {\r\n  constructor(board, table) {\r\n    // console.log('construct', table);\r\n    this.table = table;\r\n    this.board = board;\r\n  }\r\n\r\n  painter(tableWidth) {\r\n    // заполнение тела таблицы\r\n    const { matrix } = this.board;\r\n    const m = matrix.length;\r\n    const n = matrix[0].length;\r\n    // console.log(m,n);\r\n    const width = tableWidth / n;\r\n    const height = width;\r\n\r\n    const tbody = document.createElement('tbody');\r\n    for (let i = 0; i < m; i += 1) {\r\n      const tr = document.createElement('tr');\r\n      for (let j = 0; j < n; j += 1) {\r\n        const td = document.createElement('td');\r\n        td.style.width = width + 'px';\r\n        td.style.height = height + 'px';\r\n        if (matrix[i][j]) td.className = 'live';\r\n        tr.appendChild(td);\r\n      }\r\n\r\n      tbody.appendChild(tr);\r\n    }\r\n\r\n    return tbody;\r\n  }\r\n\r\n  newTable() {\r\n    // для  создания и ресайза таблицы\r\n    const { table } = this;\r\n    const tbody = this.painter(table.clientWidth);\r\n    if (table.children.length) table.replaceChild(tbody, table.children[0]);\r\n    else table.appendChild(tbody);\r\n  }\r\n\r\n  repainter() {\r\n    // изменение класса у ячеек таблицы\r\n    const { table } = this;\r\n    const { matrix } = this.board;\r\n    const tbody = table.children[0];\r\n    const m = matrix.length;\r\n    const n = matrix[0].length;\r\n    // console.log(m,n);\r\n\r\n    for (let i = 0; i < m; i += 1) {\r\n      for (let j = 0; j < n; j += 1) {\r\n        const td = tbody.children[i].children[j];\r\n        if (matrix[i][j]) td.className = 'live';\r\n        else td.className = '';\r\n      }\r\n    }\r\n  }\r\n}\r\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./view/Painter.js\n// module id = 17\n// module chunks = 0"],"sourceRoot":""} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///webpack/bootstrap 98f2870687b79237677f","webpack:///./index.js","webpack:///./index.styl","webpack:///./favicons/favicons.js","webpack:///../node_modules/file-loader/dist/cjs.js","webpack:///./favicons/android-chrome-48x48.png","webpack:///./favicons/apple-touch-icon.png","webpack:///./favicons/browserconfig.xml","webpack:///./favicons/favicon-16x16.png","webpack:///./favicons/favicon-32x32.png","webpack:///./favicons/favicon.ico","webpack:///./favicons/manifest.json","webpack:///./favicons/mstile-150x150.png","webpack:///./favicons/safari-pinned-tab.svg","webpack:///./components/sliders/slider.js","webpack:///./components/standart-button/standart-button.js","webpack:///./controller/Controller.js","webpack:///./model/Board.js","webpack:///./view/Painter.js"],"names":["controller","faviconsContext","keys","forEach","sliderChange","element","value","width","parentElement","clientWidth","min","attributes","max","previousElementSibling","innerText","style","left","sliderInput","event","target","initSliders","elements","document","querySelectorAll","i","length","oninput","buttonClick","div","createElement","id","top","pageY","pageX","body","appendChild","setTimeout","removeChild","initButtons","onclick","Controller","running","table","getElementById","controls","board","painter","fps","newTable","buttonsDisable","tableSetCell","bind","buttunsOnclick","onchange","slidersChange","buttons","getElementsByTagName","undefined","console","log","button","innerHTML","disabled","tagName","j","cellIndex","sectionRowIndex","classList","toggle","setCell","callback","oldMatrix","loop","requestAnimationFrame","worker","repainter","matrix","call","anim","clear","valueAsNumber","resize","m","n","Board","line","push","o","p","splice","slice","newMatrix","flag","newLine","cell","count","newCell","Painter","tableWidth","height","tbody","tr","td","className","children","replaceChild"],"mappings":"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","file":"index.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, {\n \t\t\t\tconfigurable: false,\n \t\t\t\tenumerable: true,\n \t\t\t\tget: getter\n \t\t\t});\n \t\t}\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 0);\n\n\n\n// WEBPACK FOOTER //\n// webpack/bootstrap 98f2870687b79237677f","import './index.styl';\r\nimport './favicons/favicons';\r\nimport './components/sliders/slider';\r\nimport './components/standart-button/standart-button';\r\nimport Controller from './controller/Controller';\r\n\r\nconst controller = new Controller();\r\n\n\n\n// WEBPACK FOOTER //\n// ./index.js","// removed by extract-text-webpack-plugin\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./index.styl\n// module id = 1\n// module chunks = 0","const faviconsContext = require.context('!!file-loader?name=favicons/[name].[ext]!.', true, /\\.(svg|png|ico|xml|json)$/);\r\n\r\nfaviconsContext.keys().forEach(faviconsContext);\r\n\n\n\n// WEBPACK FOOTER //\n// ./favicons/favicons.js","var map = {\n\t\"./android-chrome-48x48.png\": 4,\n\t\"./apple-touch-icon.png\": 5,\n\t\"./browserconfig.xml\": 6,\n\t\"./favicon-16x16.png\": 7,\n\t\"./favicon-32x32.png\": 8,\n\t\"./favicon.ico\": 9,\n\t\"./manifest.json\": 10,\n\t\"./mstile-150x150.png\": 11,\n\t\"./safari-pinned-tab.svg\": 12\n};\nfunction webpackContext(req) {\n\treturn __webpack_require__(webpackContextResolve(req));\n};\nfunction webpackContextResolve(req) {\n\tvar id = map[req];\n\tif(!(id + 1)) // check for number or string\n\t\tthrow new Error(\"Cannot find module '\" + req + \"'.\");\n\treturn id;\n};\nwebpackContext.keys = function webpackContextKeys() {\n\treturn Object.keys(map);\n};\nwebpackContext.resolve = webpackContextResolve;\nmodule.exports = webpackContext;\nwebpackContext.id = 3;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./favicons !../node_modules/file-loader/dist/cjs.js?name=favicons/[name].[ext] \\.(svg|png|ico|xml|json)$\n// module id = 3\n// module chunks = 0","module.exports = __webpack_public_path__ + \"favicons/android-chrome-48x48.png\";\n\n\n//////////////////\n// WEBPACK FOOTER\n// ../node_modules/file-loader/dist/cjs.js?name=favicons/[name].[ext]!./favicons/android-chrome-48x48.png\n// module id = 4\n// module chunks = 0","module.exports = __webpack_public_path__ + \"favicons/apple-touch-icon.png\";\n\n\n//////////////////\n// WEBPACK FOOTER\n// ../node_modules/file-loader/dist/cjs.js?name=favicons/[name].[ext]!./favicons/apple-touch-icon.png\n// module id = 5\n// module chunks = 0","module.exports = __webpack_public_path__ + \"favicons/browserconfig.xml\";\n\n\n//////////////////\n// WEBPACK FOOTER\n// ../node_modules/file-loader/dist/cjs.js?name=favicons/[name].[ext]!./favicons/browserconfig.xml\n// module id = 6\n// module chunks = 0","module.exports = __webpack_public_path__ + \"favicons/favicon-16x16.png\";\n\n\n//////////////////\n// WEBPACK FOOTER\n// ../node_modules/file-loader/dist/cjs.js?name=favicons/[name].[ext]!./favicons/favicon-16x16.png\n// module id = 7\n// module chunks = 0","module.exports = __webpack_public_path__ + \"favicons/favicon-32x32.png\";\n\n\n//////////////////\n// WEBPACK FOOTER\n// ../node_modules/file-loader/dist/cjs.js?name=favicons/[name].[ext]!./favicons/favicon-32x32.png\n// module id = 8\n// module chunks = 0","module.exports = __webpack_public_path__ + \"favicons/favicon.ico\";\n\n\n//////////////////\n// WEBPACK FOOTER\n// ../node_modules/file-loader/dist/cjs.js?name=favicons/[name].[ext]!./favicons/favicon.ico\n// module id = 9\n// module chunks = 0","module.exports = __webpack_public_path__ + \"favicons/manifest.json\";\n\n\n//////////////////\n// WEBPACK FOOTER\n// ../node_modules/file-loader/dist/cjs.js?name=favicons/[name].[ext]!./favicons/manifest.json\n// module id = 10\n// module chunks = 0","module.exports = __webpack_public_path__ + \"favicons/mstile-150x150.png\";\n\n\n//////////////////\n// WEBPACK FOOTER\n// ../node_modules/file-loader/dist/cjs.js?name=favicons/[name].[ext]!./favicons/mstile-150x150.png\n// module id = 11\n// module chunks = 0","module.exports = __webpack_public_path__ + \"favicons/safari-pinned-tab.svg\";\n\n\n//////////////////\n// WEBPACK FOOTER\n// ../node_modules/file-loader/dist/cjs.js?name=favicons/[name].[ext]!./favicons/safari-pinned-tab.svg\n// module id = 12\n// module chunks = 0","// slider\r\nconst sliderChange = function sliderChange(element) {\r\n  const { value } = element;\r\n  const width = element.parentElement.clientWidth - 20;\r\n  const min = element.attributes.min.value;\r\n  const max = element.attributes.max.value;\r\n  element.previousElementSibling.innerText = value;\r\n  element.previousElementSibling.style.left = (((width / (max - min)) * (value - min)) - 8.75) + 'px';\r\n};\r\n\r\nconst sliderInput = function sliderInput(event) {\r\n  sliderChange(event.target);\r\n};\r\n\r\n(function initSliders() {\r\n  const elements = document.querySelectorAll('.js-slider__input');\r\n  for (let i = 0; i < elements.length; i += 1) {\r\n    sliderChange(elements[i]);\r\n    elements[i].oninput = sliderInput;\r\n  }\r\n}());\r\n\n\n\n// WEBPACK FOOTER //\n// ./components/sliders/slider.js","// ripple effect\r\nconst buttonClick = function buttonClick(event) {\r\n  const div = document.createElement('div');\r\n  div.id = 'ripple';\r\n  div.style.top = event.pageY - 25 + 'px';\r\n  div.style.left = event.pageX - 25 + 'px';\r\n\r\n  document.body.appendChild(div);\r\n  setTimeout(() => { document.body.removeChild(div); }, 550);\r\n};\r\n\r\n(function initButtons() {\r\n  const elements = document.querySelectorAll('.standart-button');\r\n  for (let i = 0; i < elements.length; i += 1) {\r\n    elements[i].onclick = buttonClick;\r\n  }\r\n}());\r\n\n\n\n// WEBPACK FOOTER //\n// ./components/standart-button/standart-button.js","\r\nimport Board from '../model/Board';\r\nimport Painter from '../view/Painter';\r\n\r\nexport default class Controller {\r\n  constructor() {\r\n    this.running = false;\r\n    this.table = document.getElementById('board');\r\n    this.controls = document.getElementById('controls');\r\n    this.board = new Board(10, 10);\r\n    this.painter = new Painter(this.board, this.table);\r\n    this.fps = 1;\r\n    this.painter.newTable();// начальная отрисовка\r\n    this.buttonsDisable();\r\n    this.table.onclick = this.tableSetCell.bind(this);\r\n    this.controls.onclick = this.buttunsOnclick.bind(this);\r\n    this.controls.onchange = this.slidersChange.bind(this);\r\n  }\r\n  buttonsDisable() {\r\n    const buttons = document.getElementsByTagName('BUTTON');\r\n    if (buttons === undefined) {\r\n      console.log('buttuns not found');\r\n      return;\r\n    }\r\n    // console.log(buttons);\r\n    for (let i = 0; i < buttons.length; i += 1) {\r\n      const button = buttons[i];\r\n      if (button.innerHTML === 'start') {\r\n        if (this.running) button.disabled = true;\r\n        else button.disabled = false;\r\n      }\r\n      if (button.innerHTML === 'pause') {\r\n        if (this.running) button.disabled = false;\r\n        else button.disabled = true;\r\n      }\r\n    }\r\n  }\r\n  tableSetCell(event) {\r\n    // console.log(event.target);\r\n    const { target } = event;\r\n    if (target.tagName !== 'TD') return;\r\n    const j = target.cellIndex;\r\n    const i = target.parentElement.sectionRowIndex;\r\n    target.classList.toggle('live');\r\n    this.board.setCell(i, j);\r\n  }\r\n  anim(callback) {\r\n    // останавливается и вызывет аргумент, когда матрица перестает меняться\r\n    // console.log('anim started');\r\n    let oldMatrix;\r\n    function loop() {\r\n      const { fps } = this;\r\n      setTimeout(() => {\r\n        if (this.running) {\r\n          requestAnimationFrame(loop.bind(this));// не блокирует поток!\r\n          this.board.worker();\r\n          this.painter.repainter();\r\n          // если матрица не меняется, ссылка остаетя актуальной\r\n          if (oldMatrix === this.board.matrix) {\r\n            this.running = false;\r\n            this.buttonsDisable();\r\n          } else oldMatrix = this.board.matrix;\r\n        } else if (callback) {\r\n          // console.log('anim stopped');\r\n          callback();\r\n        }\r\n      }, 1000 / fps);\r\n    }\r\n    loop.call(this);\r\n  }\r\n  buttunsOnclick(event) {\r\n    const { target } = event;\r\n    if (target.tagName !== 'BUTTON') return;\r\n    switch (target.innerHTML) {\r\n      case 'start':\r\n        this.running = true;\r\n        this.buttonsDisable();\r\n        this.anim();\r\n        break;\r\n      case 'pause':\r\n        this.running = false;\r\n        this.buttonsDisable();\r\n        break;\r\n      case 'clear':\r\n        this.board.clear();\r\n        this.running = false;\r\n        this.buttonsDisable();\r\n        this.painter.repainter();\r\n    }\r\n  }\r\n  slidersChange(event) {\r\n    const { target } = event;\r\n    if (target.tagName !== 'INPUT') return;\r\n    const value = target.valueAsNumber;\r\n    switch (target.parentElement.previousElementSibling.innerText) {\r\n      case 'speed':\r\n        this.fps = value;\r\n        break;\r\n      case 'width':\r\n        this.running = false;\r\n        this.buttonsDisable();\r\n        this.board.resize(this.board.m, value);\r\n        this.painter.newTable();\r\n        break;\r\n      case 'height':\r\n        this.running = false;\r\n        this.buttonsDisable();\r\n        this.board.resize(value, this.board.n);\r\n        this.painter.newTable();\r\n    }\r\n  }\r\n}\r\n\n\n\n// WEBPACK FOOTER //\n// ./controller/Controller.js","export default class Board {\r\n  constructor(m = 10, n = 10) {\r\n    // матрица m на n заполненная false\r\n    this.matrix = [];\r\n    this.m = m;// строки\r\n    this.n = n;// столбцы\r\n    for (let i = 0; i < m; i += 1) {\r\n      const line = [];\r\n      for (let j = 0; j < n; j += 1) {\r\n        line.push(false);\r\n      }\r\n\r\n      this.matrix.push(line);\r\n    }\r\n  }\r\n  resize(m, n) {\r\n    const { matrix } = this;\r\n    const o = matrix.length;\r\n    const p = matrix[0].length;\r\n\r\n    // console.log('resize',o,p,' to ',m,n);\r\n    // убираем столбцы\r\n    if (p > n) {\r\n      for (let i = 0; i < o; i += 1) {\r\n        matrix[i].splice(n - 1, p - n);// изменить length?\r\n      }\r\n    }\r\n\r\n    // добавляем столбцы\r\n    if (p < n) {\r\n      for (let i = 0; i < o; i += 1) {\r\n        for (let j = p; j < n; j += 1) {\r\n          matrix[i].push(false);\r\n        }\r\n      }\r\n    }\r\n\r\n    // убираем строки\r\n    if (o > m) matrix.splice(m - 1, o - m);// изменить length?\r\n\r\n    // добавляем строки\r\n    if (o < m) {\r\n      const line = [];\r\n      for (let j = 0; j < n; j += 1) {\r\n        line.push(false);\r\n      }\r\n\r\n      for (let i = o; i < m; i += 1) {\r\n        matrix.push(line.slice());\r\n      }\r\n    }\r\n\r\n    this.m = m;\r\n    this.n = n;\r\n    return this;\r\n  }\r\n  clear() {\r\n    for (let i = 0; i < this.m; i += 1) {\r\n      for (let j = 0; j < this.n; j += 1) {\r\n        this.matrix[i][j] = false;\r\n      }\r\n    }\r\n\r\n    return this;\r\n  }\r\n  worker() {\r\n    // обход всех ячеек с записью нового состояния\r\n    const newMatrix = [];\r\n    let flag = false;// изменмлась ли матрица?\r\n    for (let i = 0; i < this.matrix.length; i += 1) {\r\n      const newLine = [];\r\n      for (let j = 0; j < this.matrix[0].length; j += 1) {\r\n        const cell = this.cell(i, j);\r\n        newLine.push(cell);\r\n        if (cell !== this.matrix[i][j]) flag = true;\r\n      }\r\n\r\n      newMatrix.push(newLine);\r\n    }\r\n\r\n    if (flag) this.matrix = newMatrix;\r\n    return this;\r\n  }\r\n  cell(i, j) {\r\n    // вычисляет новое состояние клетки\r\n    // соседи за пределами поля считаются мертвыми\r\n    let count = 0;// живые соседи\r\n    let newCell = this.matrix[i][j];\r\n\r\n    if (this.matrix[i - 1]) {\r\n      if (this.matrix[i - 1][j - 1]) count += 1;\r\n      if (this.matrix[i - 1][j]) count += 1;\r\n      if (this.matrix[i - 1][j + 1]) count += 1;\r\n    }\r\n\r\n    if (this.matrix[i][j - 1]) count += 1;\r\n    if (this.matrix[i][j + 1]) count += 1;\r\n\r\n    if (this.matrix[i + 1]) {\r\n      if (this.matrix[i + 1][j - 1]) count += 1;\r\n      if (this.matrix[i + 1][j]) count += 1;\r\n      if (this.matrix[i + 1][j + 1]) count += 1;\r\n    }\r\n\r\n    if (count < 2 || count > 3) newCell = false;\r\n    else if (count === 3) newCell = true;\r\n    return newCell;\r\n  }\r\n  setCell(i, j) {\r\n    this.matrix[i][j] = !this.matrix[i][j];\r\n  }\r\n}\r\n\n\n\n// WEBPACK FOOTER //\n// ./model/Board.js","export default class Painter {\r\n  constructor(board, table) {\r\n    // console.log('construct', table);\r\n    this.table = table;\r\n    this.board = board;\r\n  }\r\n\r\n  painter(tableWidth) {\r\n    // заполнение тела таблицы\r\n    const { matrix } = this.board;\r\n    const m = matrix.length;\r\n    const n = matrix[0].length;\r\n    // console.log(m,n);\r\n    const width = tableWidth / n;\r\n    const height = width;\r\n\r\n    const tbody = document.createElement('tbody');\r\n    for (let i = 0; i < m; i += 1) {\r\n      const tr = document.createElement('tr');\r\n      for (let j = 0; j < n; j += 1) {\r\n        const td = document.createElement('td');\r\n        td.style.width = width + 'px';\r\n        td.style.height = height + 'px';\r\n        if (matrix[i][j]) td.className = 'live';\r\n        tr.appendChild(td);\r\n      }\r\n\r\n      tbody.appendChild(tr);\r\n    }\r\n\r\n    return tbody;\r\n  }\r\n\r\n  newTable() {\r\n    // для  создания и ресайза таблицы\r\n    const { table } = this;\r\n    const tbody = this.painter(table.clientWidth);\r\n    if (table.children.length) table.replaceChild(tbody, table.children[0]);\r\n    else table.appendChild(tbody);\r\n  }\r\n\r\n  repainter() {\r\n    // изменение класса у ячеек таблицы\r\n    const { table } = this;\r\n    const { matrix } = this.board;\r\n    const tbody = table.children[0];\r\n    const m = matrix.length;\r\n    const n = matrix[0].length;\r\n    // console.log(m,n);\r\n\r\n    for (let i = 0; i < m; i += 1) {\r\n      for (let j = 0; j < n; j += 1) {\r\n        const td = tbody.children[i].children[j];\r\n        if (matrix[i][j]) td.className = 'live';\r\n        else td.className = '';\r\n      }\r\n    }\r\n  }\r\n}\r\n\n\n\n// WEBPACK FOOTER //\n// ./view/Painter.js"],"sourceRoot":""} \ No newline at end of file diff --git a/frontend/controller/controller.spec.js b/frontend/controller/controller.spec.js index f5e2d0e..28508c5 100644 --- a/frontend/controller/controller.spec.js +++ b/frontend/controller/controller.spec.js @@ -1,13 +1,12 @@ -import Controller from './Controller' -import '../components/standart-button/standart-button' +import Controller from './Controller'; describe('контроллер', function () { let controller; console.log('start controller test'); describe('вставка html кода', function () { const div = document.createElement('div'); - div.insertAdjacentHTML('beforeEnd', '
'use strict'; var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; Eif ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { Eif (protoProps) defineProperties(Constructor.prototype, protoProps); Iif (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); @@ -1302,9 +1262,9 @@/******/__webpack_require__.c = installedModules; /******/ /******/ // define getter function for harmony exports - /******/__webpack_require__.d = function (exports, name, getter) { - /******/Eif (!__webpack_require__.o(exports, name)) { - /******/Object.defineProperty(exports, name, { + /******/__webpack_require__.d = function (exports, name, getter) { + /******/if (!__webpack_require__.o(exports, name)) { + /******/Object.defineProperty(exports, name, { /******/configurable: false, /******/enumerable: true, /******/get: getter @@ -1315,22 +1275,22 @@
}; /******/ /******/ // getDefaultExport function for compatibility with non-harmony modules - /******/__webpack_require__.n = function (module) { - /******/var getter = module && module.__esModule ? - /******/function getDefault() { + /******/__webpack_require__.n = function (module) { + /******/var getter = module && module.__esModule ? + /******/function getDefault() { return module['default']; } : /******/function getModuleExports() { return module; }; - /******/__webpack_require__.d(getter, 'a', getter); - /******/return getter; + /******/__webpack_require__.d(getter, 'a', getter); + /******/return getter; /******/ }; /******/ /******/ // Object.prototype.hasOwnProperty.call - /******/__webpack_require__.o = function (object, property) { - return Object.prototype.hasOwnProperty.call(object, property); + /******/__webpack_require__.o = function (object, property) { + return Object.prototype.hasOwnProperty.call(object, property); }; /******/ /******/ // __webpack_public_path__ @@ -1349,15 +1309,13 @@
Object.defineProperty(__webpack_exports__, "__esModule", { value: true }); /* harmony import */var __WEBPACK_IMPORTED_MODULE_0__Controller__ = __webpack_require__(1); - /* harmony import */var __WEBPACK_IMPORTED_MODULE_1__components_standart_button_standart_button__ = __webpack_require__(4); - /* harmony import */var __WEBPACK_IMPORTED_MODULE_1__components_standart_button_standart_button___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__components_standart_button_standart_button__); describe('контроллер', function () { var controller = void 0; console.log('start controller test'); describe('вставка html кода', function () { var div = document.createElement('div'); - div.insertAdjacentHTML('beforeEnd', '<div class="game"> <table id="board"></table> <div id="controls"><button class="standart-button standart-button_ standart-button_small standart-button_-small" onclick="buttonClick(event)">start</button><button class="standart-button standart-button_ standart-button_small standart-button_-small" onclick="buttonClick(event)">pause</button><button class="standart-button standart-button_ standart-button_small standart-button_-small" onclick="buttonClick(event)">clear</button> <div class="container"> <div class="label">speed</div> <div class="slider"> <div class="slider__view">1</div><input class="slider" oninput="sliderInput(event)" type="range" min="1" max="10" value="1"> </div> </div> <div class="container"> <div class="label">width</div> <div class="slider"> <div class="slider__view">10</div><input class="slider" oninput="sliderInput(event)" type="range" min="0" max="100" value="10"> </div> </div> <div class="container"> <div class="label">height</div> <div class="slider"> <div class="slider__view">10</div><input class="slider" oninput="sliderInput(event)" type="range" min="0" max="100" value="10"> </div> </div> </div> </div>'); + div.insertAdjacentHTML('beforeEnd', '<div class="game"> <table id="board"></table> <div id="controls"><button class="standart-button standart-button_ standart-button_small standart-button_-small">start</button><button class="standart-button standart-button_ standart-button_small standart-button_-small">pause</button><button class="standart-button standart-button_ standart-button_small standart-button_-small">clear</button> <div class="container"> <div class="label">speed</div> <div class="slider"> <div class="slider__view">1</div><input class="slider" oninput="sliderInput(event)" type="range" min="1" max="10" value="1"> </div> </div> <div class="container"> <div class="label">width</div> <div class="slider"> <div class="slider__view">10</div><input class="slider" oninput="sliderInput(event)" type="range" min="0" max="100" value="10"> </div> </div> <div class="container"> <div class="label">height</div> <div class="slider"> <div class="slider__view">10</div><input class="slider" oninput="sliderInput(event)" type="range" min="0" max="100" value="10"> </div> </div> </div> </div>'); document.body.appendChild(div); it('проверка', function () { assert.notEqual(document.getElementsByClassName('game'), null, 'game not in DOM'); @@ -1368,7 +1326,6 @@
describe('Создание контроллера', function () { controller = new __WEBPACK_IMPORTED_MODULE_0__Controller__["a" /* default */](); - console.log(controller.table); it('находит таблицу', function () { assert.equal(controller.table !== undefined, true); }); @@ -1603,11 +1560,13 @@
break; case 'width': this.running = false; + this.buttonsDisable(); this.board.resize(this.board.m, value); this.painter.newTable(); break; case 'height': this.running = false; + this.buttonsDisable(); this.board.resize(value, this.board.n); this.painter.newTable(); } @@ -1843,34 +1802,15 @@
__webpack_exports__["a"] = Painter; /***/ -}, -/* 4 */ -/***/function (module, exports) { - - // ripple effect - document.buttonClick = function (event) { - // console.log(event.screenY,event.pageY,event.y,event); - var div = document.createElement('div'); - div.id = 'ripple'; - div.style.top = event.pageY - 25 + 'px'; - div.style.left = event.pageX - 25 + 'px'; - - document.body.appendChild(div); - setTimeout(function () { - document.body.removeChild(div); - }, 550); - }; - - /***/ }] /******/); -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["C:/Users/DNS/Desktop/Life/frontend/controller/Controller.spec.js"],"names":["modules","installedModules","__webpack_require__","moduleId","exports","module","i","l","call","m","c","d","name","getter","o","Object","defineProperty","configurable","enumerable","get","n","__esModule","getDefault","getModuleExports","object","property","prototype","hasOwnProperty","p","s","__webpack_exports__","value","__WEBPACK_IMPORTED_MODULE_0__Controller__","__WEBPACK_IMPORTED_MODULE_1__components_standart_button_standart_button__","__WEBPACK_IMPORTED_MODULE_1__components_standart_button_standart_button___default","describe","controller","console","log","div","document","createElement","insertAdjacentHTML","body","appendChild","it","assert","notEqual","getElementsByClassName","getElementById","table","equal","undefined","controls","board","painter","running","fps","buttons","children","disabled","buttonsDisable","cell","matrix","click","done","button","setTimeout","setCell","slider","querySelectorAll","slidersChange","target","resize","clear","anim","deepEqual","__WEBPACK_IMPORTED_MODULE_0__model_Board__","__WEBPACK_IMPORTED_MODULE_1__view_Painter__","Controller","newTable","onclick","tableSetCell","bind","buttunsOnclick","onchange","getElementsByTagName","length","innerHTML","event","tagName","j","cellIndex","parentElement","sectionRowIndex","classList","toggle","callback","oldMatrix","loop","requestAnimationFrame","worker","repainter","valueAsNumber","previousElementSibling","innerText","Board","line","push","splice","slice","newMatrix","flag","newLine","count","newCell","Painter","tableWidth","width","height","tbody","tr","td","style","className","clientWidth","replaceChild","buttonClick","id","top","pageY","left","pageX","removeChild"],"mappings":"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","file":"Controller.spec.es5.js","sourcesContent":["/******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, {\n/******/ \t\t\t\tconfigurable: false,\n/******/ \t\t\t\tenumerable: true,\n/******/ \t\t\t\tget: getter\n/******/ \t\t\t});\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"/_karma_webpack_/\";\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 0);\n/******/ })\n/************************************************************************/\n/******/ ([\n/* 0 */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\nObject.defineProperty(__webpack_exports__, \"__esModule\", { value: true });\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__Controller__ = __webpack_require__(1);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__components_standart_button_standart_button__ = __webpack_require__(4);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__components_standart_button_standart_button___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__components_standart_button_standart_button__);\n\r\n\r\n\r\n\r\ndescribe('контроллер', function () {\r\n  let controller;\r\n  console.log('start controller test');\r\n  describe('вставка html кода', function () {\r\n    const div = document.createElement('div');\r\n    div.insertAdjacentHTML('beforeEnd', '<div class=\"game\"> <table id=\"board\"></table> <div id=\"controls\"><button class=\"standart-button standart-button_ standart-button_small standart-button_-small\" onclick=\"buttonClick(event)\">start</button><button class=\"standart-button standart-button_ standart-button_small standart-button_-small\" onclick=\"buttonClick(event)\">pause</button><button class=\"standart-button standart-button_ standart-button_small standart-button_-small\" onclick=\"buttonClick(event)\">clear</button> <div class=\"container\"> <div class=\"label\">speed</div> <div class=\"slider\"> <div class=\"slider__view\">1</div><input class=\"slider\" oninput=\"sliderInput(event)\" type=\"range\" min=\"1\" max=\"10\" value=\"1\"> </div> </div> <div class=\"container\"> <div class=\"label\">width</div> <div class=\"slider\"> <div class=\"slider__view\">10</div><input class=\"slider\" oninput=\"sliderInput(event)\" type=\"range\" min=\"0\" max=\"100\" value=\"10\"> </div> </div> <div class=\"container\"> <div class=\"label\">height</div> <div class=\"slider\"> <div class=\"slider__view\">10</div><input class=\"slider\" oninput=\"sliderInput(event)\" type=\"range\" min=\"0\" max=\"100\" value=\"10\"> </div> </div> </div> </div>');\r\n    document.body.appendChild(div);\r\n    it('проверка', function () {\r\n      assert.notEqual(document.getElementsByClassName('game'), null, 'game not in DOM');\r\n      assert.notEqual(document.getElementById('board'), null, 'board not in DOM');\r\n      assert.notEqual(document.getElementById('controls'), null, ' controls not in DOM');\r\n    });\r\n  });\r\n  \r\n  describe('Создание контроллера', function () {\r\n    controller = new __WEBPACK_IMPORTED_MODULE_0__Controller__[\"a\" /* default */]();\r\n    console.log(controller.table);\r\n    it('находит таблицу', function () {\r\n      assert.equal(controller.table !== undefined, true);\r\n    });\r\n    it('находит панель управления', function () {\r\n      assert.equal(controller.controls !== undefined, true);\r\n    });\r\n    it('создает модель', function () {\r\n      assert.equal(controller.board !== undefined, true);\r\n    });\r\n    it('создает представление', function () {\r\n      assert.equal(controller.painter !== undefined, true);\r\n    });\r\n    it('создает свойства', function () {\r\n      assert.equal(controller.running === false, true);\r\n      assert.equal(controller.fps, 1)\r\n    });\r\n  });\r\n  \r\n  describe('метод buttonsDisable()', function () {\r\n    const buttons = controls.children;\r\n    it('состояние кнопок, когда running = false', function () {\r\n      assert.equal(buttons[0].disabled, false, 'start активен');\r\n      assert.equal(buttons[1].disabled, true, 'pause неактивна');\r\n      assert.equal(buttons[2].disabled, false, 'clear активна');\r\n    });\r\n    it('состояние кнопок, когда running = true', function () {\r\n      controller.running = true;\r\n      controller.buttonsDisable();\r\n      assert.equal(buttons[0].disabled, true, 'start неактивен');\r\n      assert.equal(buttons[1].disabled, false, 'pause активна');\r\n      assert.equal(buttons[2].disabled, false, 'clear активна');\r\n      controller.running = false;\r\n      controller.buttonsDisable();\r\n    });\r\n  });\r\n  \r\n  describe(\"события\", function () {\r\n    it('клик по ячейке таблицы', function () {\r\n      const cell = controller.table.children[0].children[0].children[0];\r\n      assert.equal(controller.board.matrix[0][0], false, 'изначально ячейка = false');\r\n      cell.click();\r\n      assert.equal(controller.board.matrix[0][0], true, 'клик по ячейке меняет состояние на true');\r\n      cell.click();\r\n      assert.equal(controller.board.matrix[0][0], false, 'клик по ячейке меняет состояние на false');\r\n    });\r\n    it('клик по кнопке start', function (done) {\r\n      const button = controller.controls.children[0];\r\n      assert.equal(controller.running,false, 'before false');\r\n      button.click();\r\n      assert.equal(button.disabled && controller.running,true,'after true');\r\n      controller.running = false;\r\n      setTimeout(done,1000);\r\n    });\r\n    it('клик по кнопке pause',function () {\r\n      const button = controller.controls.children[1];\r\n      controller.running = true;\r\n      assert.equal((!button.disabled && controller.running),true,'before true');\r\n      button.click();\r\n      assert.equal((button.disabled && !controller.running),true,'after false');\r\n    });\r\n    it('клик по кнопке clear',function () {\r\n      const board = controller.board;\r\n      const button = controller.controls.children[2];\r\n      controller.running = true;\r\n      board.setCell(0,0);\r\n      assert.equal((!button.disabled && board.matrix[0][0] && controller.running),true,'before true');\r\n      button.click();\r\n      assert.equal((!button.disabled && !board.matrix[0][0] && !controller.running),true,'after false');\r\n\r\n    });\r\n    it('слайдер speed',function () {\r\n      const slider = document.querySelectorAll('input.slider')[0];\r\n      slider.value = 5;\r\n      controller.slidersChange({target: slider});\r\n      assert.equal(controller.fps,5)\r\n    });\r\n    it('слайдер Width',function () {\r\n      const slider = document.querySelectorAll('input.slider')[1];\r\n      slider.value = 16;\r\n      controller.slidersChange({target: slider});\r\n      assert.equal(controller.board.n,16)\r\n    });\r\n    it('слайдер Height',function () {\r\n      const slider = document.querySelectorAll('input.slider')[2];\r\n      slider.value = 15;\r\n      controller.slidersChange({target: slider});\r\n      assert.equal(controller.board.m,15)\r\n    });\r\n  });\r\n  \r\n  describe('анимация', function () {\r\n    const board = controller.board;\r\n    it('anim 1', function (done) {\r\n      board.resize(2,3);\r\n      board.clear();\r\n      {\r\n        board.setCell(0,0);\r\n        board.setCell(0,1);\r\n        board.setCell(0,2);\r\n        board.setCell(1,0);\r\n      }\r\n      controller.running = true;\r\n      \r\n      // anim останавливается и вызывет аргумент, когда матрица перестает меняться\r\n      controller.anim(done);\r\n    });\r\n    it('anim 2', function () {\r\n      assert.deepEqual(board.matrix, [[true,true,false], [true,true,false]]);\r\n    });\r\n  });\r\n});\r\n\n\n/***/ }),\n/* 1 */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__model_Board__ = __webpack_require__(2);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__view_Painter__ = __webpack_require__(3);\n\r\n\r\n\r\n\r\nclass Controller {\r\n  constructor() {\r\n    this.running = false;\r\n    this.table = document.getElementById('board');\r\n    this.controls = document.getElementById('controls');\r\n    this.board = new __WEBPACK_IMPORTED_MODULE_0__model_Board__[\"a\" /* default */](10, 10);\r\n    this.painter = new __WEBPACK_IMPORTED_MODULE_1__view_Painter__[\"a\" /* default */](this.board, this.table);\r\n    this.fps = 1;\r\n    this.painter.newTable();// начальная отрисовка\r\n    this.buttonsDisable();\r\n    this.table.onclick = this.tableSetCell.bind(this);\r\n    this.controls.onclick = this.buttunsOnclick.bind(this);\r\n    this.controls.onchange = this.slidersChange.bind(this);\r\n  }\r\n  buttonsDisable() {\r\n    const buttons = document.getElementsByTagName('BUTTON');\r\n    if (buttons === undefined) {\r\n      console.log('buttuns not found');\r\n      return;\r\n    }\r\n    // console.log(buttons);\r\n    for (let i = 0; i < buttons.length; i += 1) {\r\n      const button = buttons[i];\r\n      if (button.innerHTML === 'start') {\r\n        if (this.running) button.disabled = true;\r\n        else button.disabled = false;\r\n      }\r\n      if (button.innerHTML === 'pause') {\r\n        if (this.running) button.disabled = false;\r\n        else button.disabled = true;\r\n      }\r\n    }\r\n  }\r\n  tableSetCell(event) {\r\n    // console.log(event.target);\r\n    const { target } = event;\r\n    if (target.tagName !== 'TD') return;\r\n    const j = target.cellIndex;\r\n    const i = target.parentElement.sectionRowIndex;\r\n    target.classList.toggle('live');\r\n    this.board.setCell(i, j);\r\n  }\r\n  anim(callback) {\r\n    // останавливается и вызывет аргумент, когда матрица перестает меняться\r\n    // console.log('anim started');\r\n    let oldMatrix;\r\n    function loop() {\r\n      const { fps } = this;\r\n      setTimeout(() => {\r\n        if (this.running) {\r\n          requestAnimationFrame(loop.bind(this));// не блокирует поток!\r\n          this.board.worker();\r\n          this.painter.repainter();\r\n          // если матрица не меняется, ссылка остаетя актуальной\r\n          if (oldMatrix === this.board.matrix) {\r\n            this.running = false;\r\n            this.buttonsDisable();\r\n          } else oldMatrix = this.board.matrix;\r\n        } else if (callback) {\r\n          // console.log('anim stopped');\r\n          callback();\r\n        }\r\n      }, 1000 / fps);\r\n    }\r\n    loop.call(this);\r\n  }\r\n  buttunsOnclick(event) {\r\n    const { target } = event;\r\n    if (target.tagName !== 'BUTTON') return;\r\n    switch (target.innerHTML) {\r\n      case 'start':\r\n        this.running = true;\r\n        this.buttonsDisable();\r\n        this.anim();\r\n        break;\r\n      case 'pause':\r\n        this.running = false;\r\n        this.buttonsDisable();\r\n        break;\r\n      case 'clear':\r\n        this.board.clear();\r\n        this.running = false;\r\n        this.buttonsDisable();\r\n        this.painter.repainter();\r\n    }\r\n  }\r\n  slidersChange(event) {\r\n    const { target } = event;\r\n    if (target.tagName !== 'INPUT') return;\r\n    const value = target.valueAsNumber;\r\n    switch (target.parentElement.previousElementSibling.innerText) {\r\n      case 'speed':\r\n        this.fps = value;\r\n        break;\r\n      case 'width':\r\n        this.running = false;\r\n        this.board.resize(this.board.m, value);\r\n        this.painter.newTable();\r\n        break;\r\n      case 'height':\r\n        this.running = false;\r\n        this.board.resize(value, this.board.n);\r\n        this.painter.newTable();\r\n    }\r\n  }\r\n}\n/* harmony export (immutable) */ __webpack_exports__[\"a\"] = Controller;\n\r\n\n\n/***/ }),\n/* 2 */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\nclass Board {\r\n  constructor(m = 10, n = 10) {\r\n    // матрица m на n заполненная false\r\n    this.matrix = [];\r\n    this.m = m;// строки\r\n    this.n = n;// столбцы\r\n    for (let i = 0; i < m; i += 1) {\r\n      const line = [];\r\n      for (let j = 0; j < n; j += 1) {\r\n        line.push(false);\r\n      }\r\n\r\n      this.matrix.push(line);\r\n    }\r\n  }\r\n  resize(m, n) {\r\n    const { matrix } = this;\r\n    const o = matrix.length;\r\n    const p = matrix[0].length;\r\n\r\n    // console.log('resize',o,p,' to ',m,n);\r\n    // убираем столбцы\r\n    if (p > n) {\r\n      for (let i = 0; i < o; i += 1) {\r\n        matrix[i].splice(n - 1, p - n);// изменить length?\r\n      }\r\n    }\r\n\r\n    // добавляем столбцы\r\n    if (p < n) {\r\n      for (let i = 0; i < o; i += 1) {\r\n        for (let j = p; j < n; j += 1) {\r\n          matrix[i].push(false);\r\n        }\r\n      }\r\n    }\r\n\r\n    // убираем строки\r\n    if (o > m) matrix.splice(m - 1, o - m);// изменить length?\r\n\r\n    // добавляем строки\r\n    if (o < m) {\r\n      const line = [];\r\n      for (let j = 0; j < n; j += 1) {\r\n        line.push(false);\r\n      }\r\n\r\n      for (let i = o; i < m; i += 1) {\r\n        matrix.push(line.slice());\r\n      }\r\n    }\r\n\r\n    this.m = m;\r\n    this.n = n;\r\n    return this;\r\n  }\r\n  clear() {\r\n    for (let i = 0; i < this.m; i += 1) {\r\n      for (let j = 0; j < this.n; j += 1) {\r\n        this.matrix[i][j] = false;\r\n      }\r\n    }\r\n\r\n    return this;\r\n  }\r\n  worker() {\r\n    // обход всех ячеек с записью нового состояния\r\n    const newMatrix = [];\r\n    let flag = false;// изменмлась ли матрица?\r\n    for (let i = 0; i < this.matrix.length; i += 1) {\r\n      const newLine = [];\r\n      for (let j = 0; j < this.matrix[0].length; j += 1) {\r\n        const cell = this.cell(i, j);\r\n        newLine.push(cell);\r\n        if (cell !== this.matrix[i][j]) flag = true;\r\n      }\r\n\r\n      newMatrix.push(newLine);\r\n    }\r\n\r\n    if (flag) this.matrix = newMatrix;\r\n    return this;\r\n  }\r\n  cell(i, j) {\r\n    // вычисляет новое состояние клетки\r\n    // соседи за пределами поля считаются мертвыми\r\n    let count = 0;// живые соседи\r\n    let newCell = this.matrix[i][j];\r\n\r\n    if (this.matrix[i - 1]) {\r\n      if (this.matrix[i - 1][j - 1]) count += 1;\r\n      if (this.matrix[i - 1][j]) count += 1;\r\n      if (this.matrix[i - 1][j + 1]) count += 1;\r\n    }\r\n\r\n    if (this.matrix[i][j - 1]) count += 1;\r\n    if (this.matrix[i][j + 1]) count += 1;\r\n\r\n    if (this.matrix[i + 1]) {\r\n      if (this.matrix[i + 1][j - 1]) count += 1;\r\n      if (this.matrix[i + 1][j]) count += 1;\r\n      if (this.matrix[i + 1][j + 1]) count += 1;\r\n    }\r\n\r\n    if (count < 2 || count > 3) newCell = false;\r\n    else if (count === 3) newCell = true;\r\n    return newCell;\r\n  }\r\n  setCell(i, j) {\r\n    this.matrix[i][j] = !this.matrix[i][j];\r\n  }\r\n}\n/* harmony export (immutable) */ __webpack_exports__[\"a\"] = Board;\n\r\n\n\n/***/ }),\n/* 3 */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\nclass Painter {\r\n  constructor(board, table) {\r\n    // console.log('construct', table);\r\n    this.table = table;\r\n    this.board = board;\r\n  }\r\n\r\n  painter(tableWidth) {\r\n    // заполнение тела таблицы\r\n    const { matrix } = this.board;\r\n    const m = matrix.length;\r\n    const n = matrix[0].length;\r\n    // console.log(m,n);\r\n    const width = tableWidth / n;\r\n    const height = width;\r\n\r\n    const tbody = document.createElement('tbody');\r\n    for (let i = 0; i < m; i += 1) {\r\n      const tr = document.createElement('tr');\r\n      for (let j = 0; j < n; j += 1) {\r\n        const td = document.createElement('td');\r\n        td.style.width = width + 'px';\r\n        td.style.height = height + 'px';\r\n        if (matrix[i][j]) td.className = 'live';\r\n        tr.appendChild(td);\r\n      }\r\n\r\n      tbody.appendChild(tr);\r\n    }\r\n\r\n    return tbody;\r\n  }\r\n\r\n  newTable() {\r\n    // для  создания и ресайза таблицы\r\n    const { table } = this;\r\n    const tbody = this.painter(table.clientWidth);\r\n    if (table.children.length) table.replaceChild(tbody, table.children[0]);\r\n    else table.appendChild(tbody);\r\n  }\r\n\r\n  repainter() {\r\n    // изменение класса у ячеек таблицы\r\n    const { table } = this;\r\n    const { matrix } = this.board;\r\n    const tbody = table.children[0];\r\n    const m = matrix.length;\r\n    const n = matrix[0].length;\r\n    // console.log(m,n);\r\n\r\n    for (let i = 0; i < m; i += 1) {\r\n      for (let j = 0; j < n; j += 1) {\r\n        const td = tbody.children[i].children[j];\r\n        if (matrix[i][j]) td.className = 'live';\r\n        else td.className = '';\r\n      }\r\n    }\r\n  }\r\n}\n/* harmony export (immutable) */ __webpack_exports__[\"a\"] = Painter;\n\r\n\n\n/***/ }),\n/* 4 */\n/***/ (function(module, exports) {\n\n// ripple effect\r\ndocument.buttonClick = function (event) {\r\n  // console.log(event.screenY,event.pageY,event.y,event);\r\n  const div = document.createElement('div');\r\n  div.id = 'ripple';\r\n  div.style.top = event.pageY - 25 + 'px';\r\n  div.style.left = event.pageX - 25 + 'px';\r\n\r\n  document.body.appendChild(div);\r\n  setTimeout(() => { document.body.removeChild(div); }, 550);\r\n};\r\n\n\n/***/ })\n/******/ ]);"]}
'use strict'; var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; Eif ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { Eif (protoProps) defineProperties(Constructor.prototype, protoProps); Iif (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); @@ -1302,9 +1262,9 @@/******/__webpack_require__.c = installedModules; /******/ /******/ // define getter function for harmony exports - /******/__webpack_require__.d = function (exports, name, getter) { - /******/Eif (!__webpack_require__.o(exports, name)) { - /******/Object.defineProperty(exports, name, { + /******/__webpack_require__.d = function (exports, name, getter) { + /******/if (!__webpack_require__.o(exports, name)) { + /******/Object.defineProperty(exports, name, { /******/configurable: false, /******/enumerable: true, /******/get: getter @@ -1315,22 +1275,22 @@
}; /******/ /******/ // getDefaultExport function for compatibility with non-harmony modules - /******/__webpack_require__.n = function (module) { - /******/var getter = module && module.__esModule ? - /******/function getDefault() { + /******/__webpack_require__.n = function (module) { + /******/var getter = module && module.__esModule ? + /******/function getDefault() { return module['default']; } : /******/function getModuleExports() { return module; }; - /******/__webpack_require__.d(getter, 'a', getter); - /******/return getter; + /******/__webpack_require__.d(getter, 'a', getter); + /******/return getter; /******/ }; /******/ /******/ // Object.prototype.hasOwnProperty.call - /******/__webpack_require__.o = function (object, property) { - return Object.prototype.hasOwnProperty.call(object, property); + /******/__webpack_require__.o = function (object, property) { + return Object.prototype.hasOwnProperty.call(object, property); }; /******/ /******/ // __webpack_public_path__ @@ -1349,15 +1309,13 @@
Object.defineProperty(__webpack_exports__, "__esModule", { value: true }); /* harmony import */var __WEBPACK_IMPORTED_MODULE_0__Controller__ = __webpack_require__(1); - /* harmony import */var __WEBPACK_IMPORTED_MODULE_1__components_standart_button_standart_button__ = __webpack_require__(4); - /* harmony import */var __WEBPACK_IMPORTED_MODULE_1__components_standart_button_standart_button___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__components_standart_button_standart_button__); describe('контроллер', function () { var controller = void 0; console.log('start controller test'); describe('вставка html кода', function () { var div = document.createElement('div'); - div.insertAdjacentHTML('beforeEnd', '<div class="game"> <table id="board"></table> <div id="controls"><button class="standart-button standart-button_ standart-button_small standart-button_-small" onclick="buttonClick(event)">start</button><button class="standart-button standart-button_ standart-button_small standart-button_-small" onclick="buttonClick(event)">pause</button><button class="standart-button standart-button_ standart-button_small standart-button_-small" onclick="buttonClick(event)">clear</button> <div class="container"> <div class="label">speed</div> <div class="slider"> <div class="slider__view">1</div><input class="slider" oninput="sliderInput(event)" type="range" min="1" max="10" value="1"> </div> </div> <div class="container"> <div class="label">width</div> <div class="slider"> <div class="slider__view">10</div><input class="slider" oninput="sliderInput(event)" type="range" min="0" max="100" value="10"> </div> </div> <div class="container"> <div class="label">height</div> <div class="slider"> <div class="slider__view">10</div><input class="slider" oninput="sliderInput(event)" type="range" min="0" max="100" value="10"> </div> </div> </div> </div>'); + div.insertAdjacentHTML('beforeEnd', '<div class="game"> <table id="board"></table> <div id="controls"><button class="standart-button standart-button_ standart-button_small standart-button_-small">start</button><button class="standart-button standart-button_ standart-button_small standart-button_-small">pause</button><button class="standart-button standart-button_ standart-button_small standart-button_-small">clear</button> <div class="container"> <div class="label">speed</div> <div class="slider"> <div class="slider__view">1</div><input class="slider" oninput="sliderInput(event)" type="range" min="1" max="10" value="1"> </div> </div> <div class="container"> <div class="label">width</div> <div class="slider"> <div class="slider__view">10</div><input class="slider" oninput="sliderInput(event)" type="range" min="0" max="100" value="10"> </div> </div> <div class="container"> <div class="label">height</div> <div class="slider"> <div class="slider__view">10</div><input class="slider" oninput="sliderInput(event)" type="range" min="0" max="100" value="10"> </div> </div> </div> </div>'); document.body.appendChild(div); it('проверка', function () { assert.notEqual(document.getElementsByClassName('game'), null, 'game not in DOM'); @@ -1368,7 +1326,6 @@
describe('Создание контроллера', function () { controller = new __WEBPACK_IMPORTED_MODULE_0__Controller__["a" /* default */](); - console.log(controller.table); it('находит таблицу', function () { assert.equal(controller.table !== undefined, true); }); @@ -1603,11 +1560,13 @@
break; case 'width': this.running = false; + this.buttonsDisable(); this.board.resize(this.board.m, value); this.painter.newTable(); break; case 'height': this.running = false; + this.buttonsDisable(); this.board.resize(value, this.board.n); this.painter.newTable(); } @@ -1843,34 +1802,15 @@
__webpack_exports__["a"] = Painter; /***/ -}, -/* 4 */ -/***/function (module, exports) { - - // ripple effect - document.buttonClick = function (event) { - // console.log(event.screenY,event.pageY,event.y,event); - var div = document.createElement('div'); - div.id = 'ripple'; - div.style.top = event.pageY - 25 + 'px'; - div.style.left = event.pageX - 25 + 'px'; - - document.body.appendChild(div); - setTimeout(function () { - document.body.removeChild(div); - }, 550); - }; - - /***/ }] /******/); -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["C:/Users/DNS/Desktop/Life/frontend/controller/Controller.spec.js"],"names":["modules","installedModules","__webpack_require__","moduleId","exports","module","i","l","call","m","c","d","name","getter","o","Object","defineProperty","configurable","enumerable","get","n","__esModule","getDefault","getModuleExports","object","property","prototype","hasOwnProperty","p","s","__webpack_exports__","value","__WEBPACK_IMPORTED_MODULE_0__Controller__","__WEBPACK_IMPORTED_MODULE_1__components_standart_button_standart_button__","__WEBPACK_IMPORTED_MODULE_1__components_standart_button_standart_button___default","describe","controller","console","log","div","document","createElement","insertAdjacentHTML","body","appendChild","it","assert","notEqual","getElementsByClassName","getElementById","table","equal","undefined","controls","board","painter","running","fps","buttons","children","disabled","buttonsDisable","cell","matrix","click","done","button","setTimeout","setCell","slider","querySelectorAll","slidersChange","target","resize","clear","anim","deepEqual","__WEBPACK_IMPORTED_MODULE_0__model_Board__","__WEBPACK_IMPORTED_MODULE_1__view_Painter__","Controller","newTable","onclick","tableSetCell","bind","buttunsOnclick","onchange","getElementsByTagName","length","innerHTML","event","tagName","j","cellIndex","parentElement","sectionRowIndex","classList","toggle","callback","oldMatrix","loop","requestAnimationFrame","worker","repainter","valueAsNumber","previousElementSibling","innerText","Board","line","push","splice","slice","newMatrix","flag","newLine","count","newCell","Painter","tableWidth","width","height","tbody","tr","td","style","className","clientWidth","replaceChild","buttonClick","id","top","pageY","left","pageX","removeChild"],"mappings":"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","file":"Controller.spec.es5.js","sourcesContent":["/******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, {\n/******/ \t\t\t\tconfigurable: false,\n/******/ \t\t\t\tenumerable: true,\n/******/ \t\t\t\tget: getter\n/******/ \t\t\t});\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"/_karma_webpack_/\";\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 0);\n/******/ })\n/************************************************************************/\n/******/ ([\n/* 0 */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\nObject.defineProperty(__webpack_exports__, \"__esModule\", { value: true });\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__Controller__ = __webpack_require__(1);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__components_standart_button_standart_button__ = __webpack_require__(4);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__components_standart_button_standart_button___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__components_standart_button_standart_button__);\n\r\n\r\n\r\n\r\ndescribe('контроллер', function () {\r\n  let controller;\r\n  console.log('start controller test');\r\n  describe('вставка html кода', function () {\r\n    const div = document.createElement('div');\r\n    div.insertAdjacentHTML('beforeEnd', '<div class=\"game\"> <table id=\"board\"></table> <div id=\"controls\"><button class=\"standart-button standart-button_ standart-button_small standart-button_-small\" onclick=\"buttonClick(event)\">start</button><button class=\"standart-button standart-button_ standart-button_small standart-button_-small\" onclick=\"buttonClick(event)\">pause</button><button class=\"standart-button standart-button_ standart-button_small standart-button_-small\" onclick=\"buttonClick(event)\">clear</button> <div class=\"container\"> <div class=\"label\">speed</div> <div class=\"slider\"> <div class=\"slider__view\">1</div><input class=\"slider\" oninput=\"sliderInput(event)\" type=\"range\" min=\"1\" max=\"10\" value=\"1\"> </div> </div> <div class=\"container\"> <div class=\"label\">width</div> <div class=\"slider\"> <div class=\"slider__view\">10</div><input class=\"slider\" oninput=\"sliderInput(event)\" type=\"range\" min=\"0\" max=\"100\" value=\"10\"> </div> </div> <div class=\"container\"> <div class=\"label\">height</div> <div class=\"slider\"> <div class=\"slider__view\">10</div><input class=\"slider\" oninput=\"sliderInput(event)\" type=\"range\" min=\"0\" max=\"100\" value=\"10\"> </div> </div> </div> </div>');\r\n    document.body.appendChild(div);\r\n    it('проверка', function () {\r\n      assert.notEqual(document.getElementsByClassName('game'), null, 'game not in DOM');\r\n      assert.notEqual(document.getElementById('board'), null, 'board not in DOM');\r\n      assert.notEqual(document.getElementById('controls'), null, ' controls not in DOM');\r\n    });\r\n  });\r\n  \r\n  describe('Создание контроллера', function () {\r\n    controller = new __WEBPACK_IMPORTED_MODULE_0__Controller__[\"a\" /* default */]();\r\n    console.log(controller.table);\r\n    it('находит таблицу', function () {\r\n      assert.equal(controller.table !== undefined, true);\r\n    });\r\n    it('находит панель управления', function () {\r\n      assert.equal(controller.controls !== undefined, true);\r\n    });\r\n    it('создает модель', function () {\r\n      assert.equal(controller.board !== undefined, true);\r\n    });\r\n    it('создает представление', function () {\r\n      assert.equal(controller.painter !== undefined, true);\r\n    });\r\n    it('создает свойства', function () {\r\n      assert.equal(controller.running === false, true);\r\n      assert.equal(controller.fps, 1)\r\n    });\r\n  });\r\n  \r\n  describe('метод buttonsDisable()', function () {\r\n    const buttons = controls.children;\r\n    it('состояние кнопок, когда running = false', function () {\r\n      assert.equal(buttons[0].disabled, false, 'start активен');\r\n      assert.equal(buttons[1].disabled, true, 'pause неактивна');\r\n      assert.equal(buttons[2].disabled, false, 'clear активна');\r\n    });\r\n    it('состояние кнопок, когда running = true', function () {\r\n      controller.running = true;\r\n      controller.buttonsDisable();\r\n      assert.equal(buttons[0].disabled, true, 'start неактивен');\r\n      assert.equal(buttons[1].disabled, false, 'pause активна');\r\n      assert.equal(buttons[2].disabled, false, 'clear активна');\r\n      controller.running = false;\r\n      controller.buttonsDisable();\r\n    });\r\n  });\r\n  \r\n  describe(\"события\", function () {\r\n    it('клик по ячейке таблицы', function () {\r\n      const cell = controller.table.children[0].children[0].children[0];\r\n      assert.equal(controller.board.matrix[0][0], false, 'изначально ячейка = false');\r\n      cell.click();\r\n      assert.equal(controller.board.matrix[0][0], true, 'клик по ячейке меняет состояние на true');\r\n      cell.click();\r\n      assert.equal(controller.board.matrix[0][0], false, 'клик по ячейке меняет состояние на false');\r\n    });\r\n    it('клик по кнопке start', function (done) {\r\n      const button = controller.controls.children[0];\r\n      assert.equal(controller.running,false, 'before false');\r\n      button.click();\r\n      assert.equal(button.disabled && controller.running,true,'after true');\r\n      controller.running = false;\r\n      setTimeout(done,1000);\r\n    });\r\n    it('клик по кнопке pause',function () {\r\n      const button = controller.controls.children[1];\r\n      controller.running = true;\r\n      assert.equal((!button.disabled && controller.running),true,'before true');\r\n      button.click();\r\n      assert.equal((button.disabled && !controller.running),true,'after false');\r\n    });\r\n    it('клик по кнопке clear',function () {\r\n      const board = controller.board;\r\n      const button = controller.controls.children[2];\r\n      controller.running = true;\r\n      board.setCell(0,0);\r\n      assert.equal((!button.disabled && board.matrix[0][0] && controller.running),true,'before true');\r\n      button.click();\r\n      assert.equal((!button.disabled && !board.matrix[0][0] && !controller.running),true,'after false');\r\n\r\n    });\r\n    it('слайдер speed',function () {\r\n      const slider = document.querySelectorAll('input.slider')[0];\r\n      slider.value = 5;\r\n      controller.slidersChange({target: slider});\r\n      assert.equal(controller.fps,5)\r\n    });\r\n    it('слайдер Width',function () {\r\n      const slider = document.querySelectorAll('input.slider')[1];\r\n      slider.value = 16;\r\n      controller.slidersChange({target: slider});\r\n      assert.equal(controller.board.n,16)\r\n    });\r\n    it('слайдер Height',function () {\r\n      const slider = document.querySelectorAll('input.slider')[2];\r\n      slider.value = 15;\r\n      controller.slidersChange({target: slider});\r\n      assert.equal(controller.board.m,15)\r\n    });\r\n  });\r\n  \r\n  describe('анимация', function () {\r\n    const board = controller.board;\r\n    it('anim 1', function (done) {\r\n      board.resize(2,3);\r\n      board.clear();\r\n      {\r\n        board.setCell(0,0);\r\n        board.setCell(0,1);\r\n        board.setCell(0,2);\r\n        board.setCell(1,0);\r\n      }\r\n      controller.running = true;\r\n      \r\n      // anim останавливается и вызывет аргумент, когда матрица перестает меняться\r\n      controller.anim(done);\r\n    });\r\n    it('anim 2', function () {\r\n      assert.deepEqual(board.matrix, [[true,true,false], [true,true,false]]);\r\n    });\r\n  });\r\n});\r\n\n\n/***/ }),\n/* 1 */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__model_Board__ = __webpack_require__(2);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__view_Painter__ = __webpack_require__(3);\n\r\n\r\n\r\n\r\nclass Controller {\r\n  constructor() {\r\n    this.running = false;\r\n    this.table = document.getElementById('board');\r\n    this.controls = document.getElementById('controls');\r\n    this.board = new __WEBPACK_IMPORTED_MODULE_0__model_Board__[\"a\" /* default */](10, 10);\r\n    this.painter = new __WEBPACK_IMPORTED_MODULE_1__view_Painter__[\"a\" /* default */](this.board, this.table);\r\n    this.fps = 1;\r\n    this.painter.newTable();// начальная отрисовка\r\n    this.buttonsDisable();\r\n    this.table.onclick = this.tableSetCell.bind(this);\r\n    this.controls.onclick = this.buttunsOnclick.bind(this);\r\n    this.controls.onchange = this.slidersChange.bind(this);\r\n  }\r\n  buttonsDisable() {\r\n    const buttons = document.getElementsByTagName('BUTTON');\r\n    if (buttons === undefined) {\r\n      console.log('buttuns not found');\r\n      return;\r\n    }\r\n    // console.log(buttons);\r\n    for (let i = 0; i < buttons.length; i += 1) {\r\n      const button = buttons[i];\r\n      if (button.innerHTML === 'start') {\r\n        if (this.running) button.disabled = true;\r\n        else button.disabled = false;\r\n      }\r\n      if (button.innerHTML === 'pause') {\r\n        if (this.running) button.disabled = false;\r\n        else button.disabled = true;\r\n      }\r\n    }\r\n  }\r\n  tableSetCell(event) {\r\n    // console.log(event.target);\r\n    const { target } = event;\r\n    if (target.tagName !== 'TD') return;\r\n    const j = target.cellIndex;\r\n    const i = target.parentElement.sectionRowIndex;\r\n    target.classList.toggle('live');\r\n    this.board.setCell(i, j);\r\n  }\r\n  anim(callback) {\r\n    // останавливается и вызывет аргумент, когда матрица перестает меняться\r\n    // console.log('anim started');\r\n    let oldMatrix;\r\n    function loop() {\r\n      const { fps } = this;\r\n      setTimeout(() => {\r\n        if (this.running) {\r\n          requestAnimationFrame(loop.bind(this));// не блокирует поток!\r\n          this.board.worker();\r\n          this.painter.repainter();\r\n          // если матрица не меняется, ссылка остаетя актуальной\r\n          if (oldMatrix === this.board.matrix) {\r\n            this.running = false;\r\n            this.buttonsDisable();\r\n          } else oldMatrix = this.board.matrix;\r\n        } else if (callback) {\r\n          // console.log('anim stopped');\r\n          callback();\r\n        }\r\n      }, 1000 / fps);\r\n    }\r\n    loop.call(this);\r\n  }\r\n  buttunsOnclick(event) {\r\n    const { target } = event;\r\n    if (target.tagName !== 'BUTTON') return;\r\n    switch (target.innerHTML) {\r\n      case 'start':\r\n        this.running = true;\r\n        this.buttonsDisable();\r\n        this.anim();\r\n        break;\r\n      case 'pause':\r\n        this.running = false;\r\n        this.buttonsDisable();\r\n        break;\r\n      case 'clear':\r\n        this.board.clear();\r\n        this.running = false;\r\n        this.buttonsDisable();\r\n        this.painter.repainter();\r\n    }\r\n  }\r\n  slidersChange(event) {\r\n    const { target } = event;\r\n    if (target.tagName !== 'INPUT') return;\r\n    const value = target.valueAsNumber;\r\n    switch (target.parentElement.previousElementSibling.innerText) {\r\n      case 'speed':\r\n        this.fps = value;\r\n        break;\r\n      case 'width':\r\n        this.running = false;\r\n        this.board.resize(this.board.m, value);\r\n        this.painter.newTable();\r\n        break;\r\n      case 'height':\r\n        this.running = false;\r\n        this.board.resize(value, this.board.n);\r\n        this.painter.newTable();\r\n    }\r\n  }\r\n}\n/* harmony export (immutable) */ __webpack_exports__[\"a\"] = Controller;\n\r\n\n\n/***/ }),\n/* 2 */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\nclass Board {\r\n  constructor(m = 10, n = 10) {\r\n    // матрица m на n заполненная false\r\n    this.matrix = [];\r\n    this.m = m;// строки\r\n    this.n = n;// столбцы\r\n    for (let i = 0; i < m; i += 1) {\r\n      const line = [];\r\n      for (let j = 0; j < n; j += 1) {\r\n        line.push(false);\r\n      }\r\n\r\n      this.matrix.push(line);\r\n    }\r\n  }\r\n  resize(m, n) {\r\n    const { matrix } = this;\r\n    const o = matrix.length;\r\n    const p = matrix[0].length;\r\n\r\n    // console.log('resize',o,p,' to ',m,n);\r\n    // убираем столбцы\r\n    if (p > n) {\r\n      for (let i = 0; i < o; i += 1) {\r\n        matrix[i].splice(n - 1, p - n);// изменить length?\r\n      }\r\n    }\r\n\r\n    // добавляем столбцы\r\n    if (p < n) {\r\n      for (let i = 0; i < o; i += 1) {\r\n        for (let j = p; j < n; j += 1) {\r\n          matrix[i].push(false);\r\n        }\r\n      }\r\n    }\r\n\r\n    // убираем строки\r\n    if (o > m) matrix.splice(m - 1, o - m);// изменить length?\r\n\r\n    // добавляем строки\r\n    if (o < m) {\r\n      const line = [];\r\n      for (let j = 0; j < n; j += 1) {\r\n        line.push(false);\r\n      }\r\n\r\n      for (let i = o; i < m; i += 1) {\r\n        matrix.push(line.slice());\r\n      }\r\n    }\r\n\r\n    this.m = m;\r\n    this.n = n;\r\n    return this;\r\n  }\r\n  clear() {\r\n    for (let i = 0; i < this.m; i += 1) {\r\n      for (let j = 0; j < this.n; j += 1) {\r\n        this.matrix[i][j] = false;\r\n      }\r\n    }\r\n\r\n    return this;\r\n  }\r\n  worker() {\r\n    // обход всех ячеек с записью нового состояния\r\n    const newMatrix = [];\r\n    let flag = false;// изменмлась ли матрица?\r\n    for (let i = 0; i < this.matrix.length; i += 1) {\r\n      const newLine = [];\r\n      for (let j = 0; j < this.matrix[0].length; j += 1) {\r\n        const cell = this.cell(i, j);\r\n        newLine.push(cell);\r\n        if (cell !== this.matrix[i][j]) flag = true;\r\n      }\r\n\r\n      newMatrix.push(newLine);\r\n    }\r\n\r\n    if (flag) this.matrix = newMatrix;\r\n    return this;\r\n  }\r\n  cell(i, j) {\r\n    // вычисляет новое состояние клетки\r\n    // соседи за пределами поля считаются мертвыми\r\n    let count = 0;// живые соседи\r\n    let newCell = this.matrix[i][j];\r\n\r\n    if (this.matrix[i - 1]) {\r\n      if (this.matrix[i - 1][j - 1]) count += 1;\r\n      if (this.matrix[i - 1][j]) count += 1;\r\n      if (this.matrix[i - 1][j + 1]) count += 1;\r\n    }\r\n\r\n    if (this.matrix[i][j - 1]) count += 1;\r\n    if (this.matrix[i][j + 1]) count += 1;\r\n\r\n    if (this.matrix[i + 1]) {\r\n      if (this.matrix[i + 1][j - 1]) count += 1;\r\n      if (this.matrix[i + 1][j]) count += 1;\r\n      if (this.matrix[i + 1][j + 1]) count += 1;\r\n    }\r\n\r\n    if (count < 2 || count > 3) newCell = false;\r\n    else if (count === 3) newCell = true;\r\n    return newCell;\r\n  }\r\n  setCell(i, j) {\r\n    this.matrix[i][j] = !this.matrix[i][j];\r\n  }\r\n}\n/* harmony export (immutable) */ __webpack_exports__[\"a\"] = Board;\n\r\n\n\n/***/ }),\n/* 3 */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\nclass Painter {\r\n  constructor(board, table) {\r\n    // console.log('construct', table);\r\n    this.table = table;\r\n    this.board = board;\r\n  }\r\n\r\n  painter(tableWidth) {\r\n    // заполнение тела таблицы\r\n    const { matrix } = this.board;\r\n    const m = matrix.length;\r\n    const n = matrix[0].length;\r\n    // console.log(m,n);\r\n    const width = tableWidth / n;\r\n    const height = width;\r\n\r\n    const tbody = document.createElement('tbody');\r\n    for (let i = 0; i < m; i += 1) {\r\n      const tr = document.createElement('tr');\r\n      for (let j = 0; j < n; j += 1) {\r\n        const td = document.createElement('td');\r\n        td.style.width = width + 'px';\r\n        td.style.height = height + 'px';\r\n        if (matrix[i][j]) td.className = 'live';\r\n        tr.appendChild(td);\r\n      }\r\n\r\n      tbody.appendChild(tr);\r\n    }\r\n\r\n    return tbody;\r\n  }\r\n\r\n  newTable() {\r\n    // для  создания и ресайза таблицы\r\n    const { table } = this;\r\n    const tbody = this.painter(table.clientWidth);\r\n    if (table.children.length) table.replaceChild(tbody, table.children[0]);\r\n    else table.appendChild(tbody);\r\n  }\r\n\r\n  repainter() {\r\n    // изменение класса у ячеек таблицы\r\n    const { table } = this;\r\n    const { matrix } = this.board;\r\n    const tbody = table.children[0];\r\n    const m = matrix.length;\r\n    const n = matrix[0].length;\r\n    // console.log(m,n);\r\n\r\n    for (let i = 0; i < m; i += 1) {\r\n      for (let j = 0; j < n; j += 1) {\r\n        const td = tbody.children[i].children[j];\r\n        if (matrix[i][j]) td.className = 'live';\r\n        else td.className = '';\r\n      }\r\n    }\r\n  }\r\n}\n/* harmony export (immutable) */ __webpack_exports__[\"a\"] = Painter;\n\r\n\n\n/***/ }),\n/* 4 */\n/***/ (function(module, exports) {\n\n// ripple effect\r\ndocument.buttonClick = function (event) {\r\n  // console.log(event.screenY,event.pageY,event.y,event);\r\n  const div = document.createElement('div');\r\n  div.id = 'ripple';\r\n  div.style.top = event.pageY - 25 + 'px';\r\n  div.style.left = event.pageX - 25 + 'px';\r\n\r\n  document.body.appendChild(div);\r\n  setTimeout(() => { document.body.removeChild(div); }, 550);\r\n};\r\n\n\n/***/ })\n/******/ ]);"]}