diff --git a/source/use-case/todoapp/.babelrc b/source/use-case/todoapp/.babelrc deleted file mode 100644 index 02f08fb6c0..0000000000 --- a/source/use-case/todoapp/.babelrc +++ /dev/null @@ -1,5 +0,0 @@ -{ - "presets": [ - "es2015" - ] -} \ No newline at end of file diff --git a/source/use-case/todoapp/.esmrc b/source/use-case/todoapp/.esmrc new file mode 100644 index 0000000000..740d222ba6 --- /dev/null +++ b/source/use-case/todoapp/.esmrc @@ -0,0 +1 @@ +{"cjs":true,"esm":"js"} diff --git a/source/use-case/todoapp/build.js b/source/use-case/todoapp/build.js deleted file mode 100644 index 3dde3f4047..0000000000 --- a/source/use-case/todoapp/build.js +++ /dev/null @@ -1,291 +0,0 @@ -(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o 0) { - todoListModel.addTodo({ title: title }); - } - }; - form.addEventListener("submit", function (event) { - // prevent submit action - event.preventDefault(); - // try to add - var text = inputTextArea.value; - addTodo(text); - inputTextArea.value = ""; - }); - - var unbindHandler = todoListModel.onChange(function () { - var todoItemList = todoListModel.getAllTodoList(); - console.log("change", todoItemList); - - rendering.render(todoItemList, { - toggleComplete: toggleComplete - }); - }); -} -window.addEventListener("load", onLoad); - -},{"./models/TodoListModel":3,"./views/TodoListRendering":4}],3:[function(require,module,exports){ -// LICENSE : MIT -"use strict"; - -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.TodoListModel = exports.TodoItemModel = undefined; - -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 _EventEmitter2 = require("./../EventEmitter"); - -var _EventEmitter3 = _interopRequireDefault(_EventEmitter2); - -function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } - -function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } - -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } - -function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - -// unique id -var todoIdx = 0; - -var TodoItemModel = exports.TodoItemModel = function () { - function TodoItemModel() { - var _ref = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0]; - - var title = _ref.title; - var _ref$completed = _ref.completed; - var completed = _ref$completed === undefined ? false : _ref$completed; - - _classCallCheck(this, TodoItemModel); - - this.id = todoIdx++; - this.title = title; - this.completed = completed; - } - - _createClass(TodoItemModel, [{ - key: "isCompleted", - get: function get() { - return this.completed; - } - }]); - - return TodoItemModel; -}(); -// model - - -var TodoListModel = exports.TodoListModel = function (_EventEmitter) { - _inherits(TodoListModel, _EventEmitter); - - function TodoListModel() { - var todoList = arguments.length <= 0 || arguments[0] === undefined ? [] : arguments[0]; - - _classCallCheck(this, TodoListModel); - - var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(TodoListModel).call(this)); - - _this.todoList = todoList.map(function (todoItem) { - return new TodoItemModel(todoItem); - }); - return _this; - } - - _createClass(TodoListModel, [{ - key: "getAllTodoList", - value: function getAllTodoList() { - return this.todoList; - } - }, { - key: "onChange", - value: function onChange(handler) { - var _this2 = this; - - this.on("change", handler); - return function () { - _this2.off("change", handler); - }; - } - }, { - key: "changeComplete", - value: function changeComplete(_ref2) { - var id = _ref2.id; - var isCompleted = _ref2.isCompleted; - - // state change - var todoItem = this.todoList.find(function (todo) { - return todo.id === id; - }); - if (!todoItem) { - return; - } - todoItem.completed = isCompleted; - this.emit("change"); - } - }, { - key: "addTodo", - value: function addTodo(todo) { - this.todoList.push(new TodoItemModel(todo)); - // emit change - this.emit("change"); - } - }]); - - return TodoListModel; -}(_EventEmitter3.default); - -},{"./../EventEmitter":1}],4:[function(require,module,exports){ -// LICENSE : MIT -"use strict"; -// rendering - -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 TodoListRendering = function () { - function TodoListRendering(containerNode) { - _classCallCheck(this, TodoListRendering); - - this.containerNode = containerNode; - } - - _createClass(TodoListRendering, [{ - key: "_createTodoElement", - value: function _createTodoElement(todo, toggleComplete) { - var todoItemList = document.createElement("li"); - var text = document.createTextNode(todo.title); - var todoItemCheckBox = document.createElement("input"); - todoItemCheckBox.type = "checkbox"; - todoItemCheckBox.checked = todo.isCompleted; - todoItemCheckBox.addEventListener("change", function (event) { - var isCompleted = event.target.checked; - toggleComplete({ - id: todo.id, - isCompleted: isCompleted - }); - }); - todoItemList.appendChild(todoItemCheckBox); - todoItemList.appendChild(text); - return todoItemList; - } - }, { - key: "render", - value: function render(todoItemList, _ref) { - var _this = this; - - var toggleComplete = _ref.toggleComplete; - - var listTags = todoItemList.map(function (todoItem) { - return _this._createTodoElement(todoItem, toggleComplete); - }); - var orderListTag = document.createElement("ul"); - listTags.forEach(function (listTag) { - return orderListTag.appendChild(listTag); - }); - // clean up - var range = document.createRange(); - range.selectNodeContents(this.containerNode); - range.deleteContents(); - // render - this.containerNode.appendChild(orderListTag); - } - }]); - - return TodoListRendering; -}(); - -exports.default = TodoListRendering; - -},{}]},{},[2]) -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","src/EventEmitter.js","src/index.js","src/models/TodoListModel.js","src/views/TodoListRendering.js"],"names":[],"mappings":"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","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","// LICENSE : MIT\n\"use strict\";\n/*\n    Simple EventEmitter\n */\nexport default class EventEmitter {\n    constructor() {\n        this._handlers = {};\n    }\n\n    on(type, handler) {\n        if (typeof this._handlers[type] === 'undefined') {\n            this._handlers[type] = [];\n        }\n\n        this._handlers[type].push(handler);\n    }\n\n    emit(type, data) {\n        var handlers = this._handlers[type] || [];\n        for (var i = 0; i < handlers.length; i++) {\n            var handler = handlers[i];\n            handler.call(this, data);\n        }\n    }\n\n    off(type, handler) {\n        var handlers = this._handlers[type] || [];\n        for (var i = 0; i < handlers.length; i++) {\n            var ownHandler = handlers[i];\n            if (ownHandler === handler) {\n                handlers.splice(i, 1);\n            }\n        }\n    }\n}\n","// LICENSE : MIT\n\"use strict\";\nimport {TodoListModel} from \"./models/TodoListModel\";\nimport TodoListRendering from \"./views/TodoListRendering\"\n// Entry Point\nfunction onLoad() {\n    // add event to DOM elements\n    const form = document.getElementById(\"js-form\");\n    const inputTextArea = document.getElementById(\"js-form-input\");\n    const TODOListArea = document.getElementById(\"js-todo-list\");\n\n    const rendering = new TodoListRendering(TODOListArea);\n    const todoListModel = new TodoListModel();\n    const toggleComplete = ({id, isCompleted}) => {\n        todoListModel.changeComplete({id, isCompleted})\n    };\n    const addTodo = (title) => {\n        if (title.length > 0) {\n            todoListModel.addTodo({title});\n        }\n    };\n    form.addEventListener(\"submit\", (event) => {\n        // prevent submit action\n        event.preventDefault();\n        // try to add\n        const text = inputTextArea.value;\n        addTodo(text);\n        inputTextArea.value = \"\";\n    });\n\n    const unbindHandler = todoListModel.onChange(() => {\n        const todoItemList = todoListModel.getAllTodoList();\n        console.log(\"change\", todoItemList);\n\n        rendering.render(todoItemList, {\n            toggleComplete\n        });\n    });\n}\nwindow.addEventListener(\"load\", onLoad);","// LICENSE : MIT\n\"use strict\";\nimport EventEmitter from \"./../EventEmitter\";\n// unique id\nlet todoIdx = 0;\nexport class TodoItemModel {\n    constructor({title, completed = false} = {}) {\n        this.id = todoIdx++;\n        this.title = title;\n        this.completed = completed;\n    }\n\n    get isCompleted() {\n        return this.completed;\n    }\n}\n// model\nexport class TodoListModel extends EventEmitter {\n    constructor(todoList = []) {\n        super();\n        this.todoList = todoList.map(todoItem => new TodoItemModel(todoItem));\n    }\n\n    getAllTodoList() {\n        return this.todoList;\n    }\n\n    onChange(handler) {\n        this.on(\"change\", handler);\n        return () => {\n            this.off(\"change\", handler);\n        };\n    }\n\n    changeComplete({id, isCompleted}) {\n        // state change\n        const todoItem = this.todoList.find(todo => todo.id === id);\n        if (!todoItem) {\n            return;\n        }\n        todoItem.completed = isCompleted;\n        this.emit(\"change\");\n    }\n\n    addTodo(todo) {\n        this.todoList.push(new TodoItemModel(todo));\n        // emit change\n        this.emit(\"change\");\n    }\n}","// LICENSE : MIT\n\"use strict\";\n// rendering\nexport default class TodoListRendering {\n    constructor(containerNode) {\n        this.containerNode = containerNode;\n    }\n\n    _createTodoElement(todo, toggleComplete) {\n        const todoItemList = document.createElement(\"li\");\n        const text = document.createTextNode(todo.title);\n        const todoItemCheckBox = document.createElement(\"input\");\n        todoItemCheckBox.type = \"checkbox\";\n        todoItemCheckBox.checked = todo.isCompleted;\n        todoItemCheckBox.addEventListener(\"change\", (event) => {\n            const isCompleted = event.target.checked;\n            toggleComplete({\n                id: todo.id,\n                isCompleted\n            })\n        });\n        todoItemList.appendChild(todoItemCheckBox);\n        todoItemList.appendChild(text);\n        return todoItemList;\n    }\n\n    render(todoItemList, {toggleComplete}) {\n        const listTags = todoItemList.map(todoItem => {\n            return this._createTodoElement(todoItem, toggleComplete);\n        });\n        const orderListTag = document.createElement(\"ul\");\n        listTags.forEach(listTag => orderListTag.appendChild(listTag));\n        // clean up\n        var range = document.createRange();\n        range.selectNodeContents(this.containerNode);\n        range.deleteContents();\n        // render\n        this.containerNode.appendChild(orderListTag);\n    }\n}"]} diff --git a/source/use-case/todoapp/index.html b/source/use-case/todoapp/index.html index d76bd18b0d..b385cd2a9c 100644 --- a/source/use-case/todoapp/index.html +++ b/source/use-case/todoapp/index.html @@ -13,6 +13,6 @@ - + diff --git a/source/use-case/todoapp/package.json b/source/use-case/todoapp/package.json index 00551fd50d..8736233bd8 100644 --- a/source/use-case/todoapp/package.json +++ b/source/use-case/todoapp/package.json @@ -10,9 +10,7 @@ "test": "test" }, "scripts": { - "build": "browserify src/index.js -o build.js", - "watch": "watchify -d src/index.js -o build.js", - "test": "mocha" + "test": "mocha test/" }, "browserify": { "transform": [ @@ -24,13 +22,7 @@ "es6" ], "devDependencies": { - "babel-cli": "^6.5.1", - "babel-plugin-add-module-exports": "^0.1.2", - "babel-preset-es2015": "^6.5.0", - "babel-register": "^6.9.0", - "babelify": "^7.2.0", - "browserify": "^13.0.0", - "mocha": "^2.5.3", - "watchify": "^3.7.0" + "@std/esm": "^0.20.0", + "mocha": "^2.5.3" } } diff --git a/source/use-case/todoapp/src/EventEmitter.js b/source/use-case/todoapp/src/EventEmitter.js index b0b00bf5f4..16dba7bc32 100644 --- a/source/use-case/todoapp/src/EventEmitter.js +++ b/source/use-case/todoapp/src/EventEmitter.js @@ -1,9 +1,10 @@ // LICENSE : MIT "use strict"; + /* - Simple EventEmitter + * Simple EventEmitter */ -export default class EventEmitter { +export class EventEmitter { constructor() { this._handlers = {}; } diff --git a/source/use-case/todoapp/src/index.js b/source/use-case/todoapp/src/index.js index 97edd241a4..3f8682cb6f 100644 --- a/source/use-case/todoapp/src/index.js +++ b/source/use-case/todoapp/src/index.js @@ -1,7 +1,8 @@ // LICENSE : MIT "use strict"; -import { TodoListModel } from "./models/TodoListModel"; -import TodoListRendering from "./views/TodoListRendering"; +import { TodoListModel } from "./models/TodoListModel.js"; +import { TodoListRendering } from "./views/TodoListRendering.js"; + // Entry Point function onLoad() { // add event to DOM elements @@ -30,10 +31,12 @@ function onLoad() { const unbindHandler = todoListModel.onChange(() => { const todoItemList = todoListModel.getAllTodoList(); - console.log("changed", todoItemList); rendering.render(todoItemList, { toggleComplete }); }); + + window.addEventListener("unload", unbindHandler); } -window.addEventListener("load", onLoad); \ No newline at end of file + +window.addEventListener("load", onLoad); diff --git a/source/use-case/todoapp/src/models/TodoListModel.js b/source/use-case/todoapp/src/models/TodoListModel.js index c908af685b..14a0639099 100644 --- a/source/use-case/todoapp/src/models/TodoListModel.js +++ b/source/use-case/todoapp/src/models/TodoListModel.js @@ -1,8 +1,9 @@ // LICENSE : MIT "use strict"; -import EventEmitter from "./../EventEmitter"; +import { EventEmitter } from "../EventEmitter.js"; // unique id let todoIdx = 0; + export class TodoItemModel { constructor({ title, completed = false } = {}) { this.id = todoIdx++; @@ -14,6 +15,7 @@ export class TodoItemModel { return this.completed; } } + // model export class TodoListModel extends EventEmitter { constructor(todoList = []) { @@ -47,4 +49,4 @@ export class TodoListModel extends EventEmitter { // emit change this.emit("change"); } -} \ No newline at end of file +} diff --git a/source/use-case/todoapp/src/views/TodoListRendering.js b/source/use-case/todoapp/src/views/TodoListRendering.js index 35a203d756..17b00ef633 100644 --- a/source/use-case/todoapp/src/views/TodoListRendering.js +++ b/source/use-case/todoapp/src/views/TodoListRendering.js @@ -1,7 +1,6 @@ -// LICENSE : MIT "use strict"; -// rendering -export default class TodoListRendering { +// Rendering Todo List +export class TodoListRendering { constructor(containerNode) { this.containerNode = containerNode; } @@ -37,4 +36,4 @@ export default class TodoListRendering { // render this.containerNode.appendChild(orderListTag); } -} \ No newline at end of file +} diff --git a/source/use-case/todoapp/test/EventEmitter-test.js b/source/use-case/todoapp/test/EventEmitter-test.js index 4d1f70a92b..7d57388d19 100644 --- a/source/use-case/todoapp/test/EventEmitter-test.js +++ b/source/use-case/todoapp/test/EventEmitter-test.js @@ -1,7 +1,8 @@ // LICENSE : MIT "use strict"; const assert = require("assert"); -import EventEmitter from "../src/EventEmitter"; +import { EventEmitter } from "../src/EventEmitter.js"; + describe("EventEmitter", function() { let emitter; beforeEach(function() { @@ -40,4 +41,4 @@ describe("EventEmitter", function() { emitter.emit(key); }); }); -}); \ No newline at end of file +}); diff --git a/source/use-case/todoapp/test/mocha.opts b/source/use-case/todoapp/test/mocha.opts index b76d223924..e1d283bc86 100644 --- a/source/use-case/todoapp/test/mocha.opts +++ b/source/use-case/todoapp/test/mocha.opts @@ -1 +1 @@ ---compilers js:babel-register \ No newline at end of file +--require @std/esm