├── .gitignore ├── app_screenshot.png ├── src ├── modules │ ├── task.js │ └── display_manager.js ├── index.js ├── index.html └── style.css ├── .stylelintrc.json ├── .hintrc ├── .eslintrc.json ├── dist ├── index.html └── main.js ├── webpack.config.js ├── README.md ├── package.json └── .github └── workflows └── linters.yml /.gitignore: -------------------------------------------------------------------------------- 1 | /node_modules 2 | .prettierrc -------------------------------------------------------------------------------- /app_screenshot.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Tobinchilongo/TodoList/HEAD/app_screenshot.png -------------------------------------------------------------------------------- /src/modules/task.js: -------------------------------------------------------------------------------- 1 | export default class Task { 2 | constructor(index, description, completed) { 3 | this.index = index; 4 | this.description = description; 5 | this.completed = completed; 6 | } 7 | } 8 | -------------------------------------------------------------------------------- /.stylelintrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "extends": ["stylelint-config-standard"], 3 | "plugins": ["stylelint-scss", "stylelint-csstree-validator"], 4 | "rules": { 5 | "at-rule-no-unknown": null, 6 | "scss/at-rule-no-unknown": true, 7 | "csstree/validator": true 8 | }, 9 | "ignoreFiles": ["build/**", "dist/**", "**/reset*.css", "**/bootstrap*.css", "**/*.js", "**/*.jsx"] 10 | } 11 | -------------------------------------------------------------------------------- /.hintrc: -------------------------------------------------------------------------------- 1 | { 2 | "connector": { 3 | "name": "local", 4 | "options": { 5 | "pattern": ["**", "!.git/**", "!node_modules/**"] 6 | } 7 | }, 8 | "extends": ["development"], 9 | "formatters": ["stylish"], 10 | "hints": [ 11 | "button-type", 12 | "disown-opener", 13 | "html-checker", 14 | "meta-charset-utf-8", 15 | "meta-viewport", 16 | "no-inline-styles:error" 17 | ] 18 | } -------------------------------------------------------------------------------- /src/index.js: -------------------------------------------------------------------------------- 1 | import './style.css'; 2 | import Task from './modules/task.js'; 3 | import DisplayManager from './modules/display_manager.js'; 4 | 5 | const selector = (element) => document.querySelector(element); 6 | 7 | let tasks = [new Task(1, 'one', 'ok'), new Task(2, 'two', 'ok'), new Task(4, 'four', 'ok'), new Task(3, 'three', 'ok'), new Task(5, 'five', 'ok')]; 8 | 9 | tasks = tasks.sort((a, b) => a.index - b.index); 10 | 11 | tasks.forEach((task) => DisplayManager.displayTask(selector('.tasks'), task)); 12 | -------------------------------------------------------------------------------- /.eslintrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "env": { 3 | "browser": true, 4 | "es6": true, 5 | "jest": true 6 | }, 7 | "parser": "babel-eslint", 8 | "parserOptions": { 9 | "ecmaVersion": 2018, 10 | "sourceType": "module" 11 | }, 12 | "extends": ["airbnb-base"], 13 | "rules": { 14 | "no-shadow": "off", 15 | "no-param-reassign": "off", 16 | "eol-last": "off", 17 | "import/extensions": [ 1, { 18 | "js": "always", "json": "always" 19 | }] 20 | }, 21 | "ignorePatterns": [ 22 | "dist/", 23 | "build/" 24 | ] 25 | } 26 | -------------------------------------------------------------------------------- /dist/index.html: -------------------------------------------------------------------------------- 1 | My TodoList

Today's To Do

-------------------------------------------------------------------------------- /webpack.config.js: -------------------------------------------------------------------------------- 1 | const path = require('path'); 2 | const HtmlWebpackPlugin = require('html-webpack-plugin'); 3 | 4 | module.exports = { 5 | entry: './src/index.js', 6 | mode: 'production', 7 | devServer: { 8 | static: './dist', 9 | }, 10 | devtool: 'inline-source-map', 11 | plugins: [ 12 | new HtmlWebpackPlugin({ 13 | template: './src/index.html', 14 | }), 15 | ], 16 | output: { 17 | filename: 'main.js', 18 | path: path.resolve(__dirname, 'dist'), 19 | }, 20 | module: { 21 | rules: [ 22 | { 23 | test: /\.css$/i, 24 | use: ['style-loader', 'css-loader'], 25 | }, 26 | ], 27 | }, 28 | performance: { 29 | maxAssetSize: 800000, 30 | maxEntrypointSize: 700000, 31 | }, 32 | }; 33 | -------------------------------------------------------------------------------- /src/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | My TodoList 9 | 10 | 11 |
12 |
13 |
14 |

Today's To Do

15 | 16 |
17 |
18 |
19 | 20 |
21 |
22 | 23 | 24 | -------------------------------------------------------------------------------- /src/modules/display_manager.js: -------------------------------------------------------------------------------- 1 | export default class DisplayManager { 2 | static displayTask = (parent, task) => { 3 | const taskDiv = DisplayManager.createHtml(parent, 'div', 'task'); 4 | const taskInput = DisplayManager.createHtml(taskDiv, 'div', 'task_input'); 5 | const input = DisplayManager.createHtml(taskInput, 'input'); 6 | input.setAttribute('type', 'checkbox'); 7 | input.setAttribute('name', `tasK_${task.index}`); 8 | DisplayManager.createHtml(taskInput, 'label', '', task.description).setAttribute('for', `tasK_${task.index}`); 9 | DisplayManager.createHtml(taskDiv, 'i', 'fas fa-ellipsis-v'); 10 | }; 11 | 12 | static createHtml = (parent, tag, className, content = null) => { 13 | const element = document.createElement(tag); 14 | element.className = className; 15 | element.innerHTML = content; 16 | parent.appendChild(element); 17 | return element; 18 | }; 19 | } 20 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # To-do list 2 | 3 | > "To-do list" is a tool that helps to organize your day. It simply lists the things that you need to do and allows you to mark them as complete. 4 | 5 | ![screenshot](./app_screenshot.png) 6 | 7 | ## Built With 8 | 9 | - Webpack 10 | - HTML 11 | - CSS 12 | - JS 13 | 14 | ## Live Demo 15 | 16 | [Live Demo Link](https://jihaneh.github.io/TodoList/dist/) 17 | 18 | ## Getting Started 19 | 20 | To get a local copy up and running follow these steps. 21 | 22 | ### Prerequisites 23 | 24 | You need to have NODE.JS set up on your local machine. 25 | 26 | ### Setup 27 | 28 | Download the project and unzip it. 29 | 30 | ### Install 31 | 32 | Execute this command on your terminal 33 | 34 | ``` 35 | npm install 36 | ``` 37 | 38 | ### Deployment 39 | 40 | Execute this command on your terminal 41 | 42 | ``` 43 | npm start 44 | ``` 45 | 46 | It will open your browser with the project homepage 47 | 48 | ## Authors 49 | 50 | 👤 **JihaneH** 51 | 52 | - GitHub: [@jihaneH](https://github.com/jihaneH) 53 | - Twitter: [@jijihaddad](https://twitter.com/jijihaddad) 54 | - LinkedIn: [LinkedIn](https://linkedin.com/in/jihane-haddad/) 55 | 56 | ## 🤝 Contributing 57 | 58 | Contributions, issues, and feature requests are welcome! 59 | 60 | Feel free to check the [issues page](../../issues/). 61 | 62 | ## Show your support 63 | 64 | Give a ⭐️ if you like this project! 65 | 66 | ## 📝 License 67 | 68 | This project is [MIT](./MIT.md) licensed. 69 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "todolist", 3 | "version": "1.0.0", 4 | "description": "![]()", 5 | "main": "index.js", 6 | "private": true, 7 | "scripts": { 8 | "test": "echo \"Error: no test specified\" && exit 1", 9 | "build": "webpack", 10 | "watch": "webpack --watch", 11 | "start": "webpack serve --open", 12 | "lcss": "stylelint '**/*.{css,scss}'", 13 | "lfcss": "stylelint '**/*.{css,scss}' --fix", 14 | "lhtml": "npx eslint .", 15 | "ljs": "npx eslint .", 16 | "lfjs": "npx eslint . --fix", 17 | "deploy": "gh-pages -d dist" 18 | }, 19 | "repository": { 20 | "type": "git", 21 | "url": "git+https://github.com/jihaneH/TodoList.git" 22 | }, 23 | "keywords": [], 24 | "author": "", 25 | "license": "ISC", 26 | "bugs": { 27 | "url": "https://github.com/jihaneH/TodoList/issues" 28 | }, 29 | "homepage": "https://github.com/jihaneH/TodoList#readme", 30 | "devDependencies": { 31 | "babel-eslint": "^10.1.0", 32 | "css-loader": "^6.5.1", 33 | "eslint": "^7.32.0", 34 | "eslint-config-airbnb-base": "^14.2.1", 35 | "eslint-plugin-import": "^2.25.4", 36 | "hint": "^6.1.9", 37 | "html-webpack-plugin": "^5.5.0", 38 | "style-loader": "^3.3.1", 39 | "stylelint": "^13.13.1", 40 | "stylelint-config-standard": "^21.0.0", 41 | "stylelint-csstree-validator": "^1.9.0", 42 | "stylelint-scss": "^3.21.0", 43 | "webpack": "^5.65.0", 44 | "webpack-cli": "^4.9.1", 45 | "webpack-dev-server": "^4.7.2" 46 | }, 47 | "dependencies": { 48 | "gh-pages": "^3.2.3", 49 | "lodash": "^4.17.21" 50 | } 51 | } 52 | -------------------------------------------------------------------------------- /src/style.css: -------------------------------------------------------------------------------- 1 | @import url('https://fonts.googleapis.com/css2?family=Roboto&display=swap'); 2 | 3 | body { 4 | background-color: #f6f6f6; 5 | font-family: 'Roboto', sans-serif; 6 | box-sizing: border-box; 7 | margin: 0; 8 | color: #645f5f; 9 | } 10 | 11 | section { 12 | width: 100vw; 13 | height: 100vh; 14 | display: flex; 15 | justify-content: center; 16 | align-items: center; 17 | } 18 | 19 | .todo { 20 | box-shadow: 3px 2px 4px gray; 21 | } 22 | 23 | .todo > div, 24 | .task { 25 | min-width: 400px; 26 | max-width: 550px; 27 | display: flex; 28 | justify-content: space-between; 29 | border-bottom: 1px solid #dcdbdb; 30 | } 31 | 32 | .todo .header { 33 | background-color: white; 34 | padding: 20px; 35 | display: flex; 36 | justify-content: space-between; 37 | } 38 | 39 | .todo .header h1 { 40 | margin: 0; 41 | font-size: 16px; 42 | font-weight: 400; 43 | } 44 | 45 | .todo .tasks, 46 | .todo .add_task { 47 | background-color: white; 48 | } 49 | 50 | .todo .add_task, 51 | .task { 52 | padding: 20px; 53 | } 54 | 55 | .task { 56 | display: flex; 57 | justify-content: space-between; 58 | } 59 | 60 | .todo .tasks { 61 | display: flex; 62 | flex-direction: column; 63 | align-items: flex-start; 64 | } 65 | 66 | input, 67 | input:focus, 68 | textarea:focus, 69 | select:focus { 70 | border: 0; 71 | outline: 0; 72 | font-size: 14px; 73 | color: cadetblue; 74 | line-height: 28px; 75 | margin-right: 10px; 76 | } 77 | 78 | input::placeholder { 79 | font-style: italic; 80 | } 81 | 82 | .todo .footer { 83 | text-align: center; 84 | color: grey; 85 | display: flex; 86 | justify-content: center; 87 | padding: 20px; 88 | } 89 | -------------------------------------------------------------------------------- /.github/workflows/linters.yml: -------------------------------------------------------------------------------- 1 | name: Linters 2 | 3 | on: pull_request 4 | 5 | env: 6 | FORCE_COLOR: 1 7 | 8 | jobs: 9 | lighthouse: 10 | name: Lighthouse 11 | runs-on: ubuntu-18.04 12 | steps: 13 | - uses: actions/checkout@v2 14 | - uses: actions/setup-node@v1 15 | with: 16 | node-version: "12.x" 17 | - name: Setup Lighthouse 18 | run: npm install -g @lhci/cli@0.7.x 19 | - name: Lighthouse Report 20 | run: lhci autorun --upload.target=temporary-public-storage --collect.staticDistDir=. 21 | webhint: 22 | name: Webhint 23 | runs-on: ubuntu-18.04 24 | steps: 25 | - uses: actions/checkout@v2 26 | - uses: actions/setup-node@v1 27 | with: 28 | node-version: "12.x" 29 | - name: Setup Webhint 30 | run: | 31 | npm install --save-dev hint@6.x 32 | [ -f .hintrc ] || wget https://raw.githubusercontent.com/microverseinc/linters-config/master/html-css-js/.hintrc 33 | - name: Webhint Report 34 | run: npx hint . 35 | stylelint: 36 | name: Stylelint 37 | runs-on: ubuntu-18.04 38 | steps: 39 | - uses: actions/checkout@v2 40 | - uses: actions/setup-node@v1 41 | with: 42 | node-version: "12.x" 43 | - name: Setup Stylelint 44 | run: | 45 | npm install --save-dev stylelint@13.x stylelint-scss@3.x stylelint-config-standard@21.x stylelint-csstree-validator@1.x 46 | [ -f .stylelintrc.json ] || wget https://raw.githubusercontent.com/microverseinc/linters-config/master/html-css-js/.stylelintrc.json 47 | - name: Stylelint Report 48 | run: npx stylelint "**/*.{css,scss}" 49 | eslint: 50 | name: ESLint 51 | runs-on: ubuntu-18.04 52 | steps: 53 | - uses: actions/checkout@v2 54 | - uses: actions/setup-node@v1 55 | with: 56 | node-version: "12.x" 57 | - name: Setup ESLint 58 | run: | 59 | npm install --save-dev eslint@7.x eslint-config-airbnb-base@14.x eslint-plugin-import@2.x babel-eslint@10.x 60 | [ -f .eslintrc.json ] || wget https://raw.githubusercontent.com/microverseinc/linters-config/master/html-css-js/.eslintrc.json 61 | - name: ESLint Report 62 | run: npx eslint . 63 | -------------------------------------------------------------------------------- /dist/main.js: -------------------------------------------------------------------------------- 1 | (()=>{"use strict";var n={426:(n,t,e)=>{e.d(t,{Z:()=>s});var o=e(537),a=e.n(o),r=e(645),i=e.n(r)()(a());i.push([n.id,"@import url(https://fonts.googleapis.com/css2?family=Roboto&display=swap);"]),i.push([n.id,"body {\n background-color: #f6f6f6;\n font-family: 'Roboto', sans-serif;\n box-sizing: border-box;\n margin: 0;\n color: #645f5f;\n}\n\nsection {\n width: 100vw;\n height: 100vh;\n display: flex;\n justify-content: center;\n align-items: center;\n}\n\n.todo {\n box-shadow: 3px 2px 4px gray;\n}\n\n.todo > div,\n.task {\n min-width: 400px;\n max-width: 550px;\n display: flex;\n justify-content: space-between;\n border-bottom: 1px solid #dcdbdb;\n}\n\n.todo .header {\n background-color: white;\n padding: 20px;\n display: flex;\n justify-content: space-between;\n}\n\n.todo .header h1 {\n margin: 0;\n font-size: 16px;\n font-weight: 400;\n}\n\n.todo .tasks,\n.todo .add_task {\n background-color: white;\n}\n\n.todo .add_task,\n.task {\n padding: 20px;\n}\n\n.task {\n display: flex;\n justify-content: space-between;\n}\n\n.todo .tasks {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n}\n\ninput,\ninput:focus,\ntextarea:focus,\nselect:focus {\n border: 0;\n outline: 0;\n font-size: 14px;\n color: cadetblue;\n line-height: 28px;\n margin-right: 10px;\n}\n\ninput::placeholder {\n font-style: italic;\n}\n\n.todo .footer {\n text-align: center;\n color: grey;\n display: flex;\n justify-content: center;\n padding: 20px;\n}\n","",{version:3,sources:["webpack://./src/style.css"],names:[],mappings:"AAEA;EACE,yBAAyB;EACzB,iCAAiC;EACjC,sBAAsB;EACtB,SAAS;EACT,cAAc;AAChB;;AAEA;EACE,YAAY;EACZ,aAAa;EACb,aAAa;EACb,uBAAuB;EACvB,mBAAmB;AACrB;;AAEA;EACE,4BAA4B;AAC9B;;AAEA;;EAEE,gBAAgB;EAChB,gBAAgB;EAChB,aAAa;EACb,8BAA8B;EAC9B,gCAAgC;AAClC;;AAEA;EACE,uBAAuB;EACvB,aAAa;EACb,aAAa;EACb,8BAA8B;AAChC;;AAEA;EACE,SAAS;EACT,eAAe;EACf,gBAAgB;AAClB;;AAEA;;EAEE,uBAAuB;AACzB;;AAEA;;EAEE,aAAa;AACf;;AAEA;EACE,aAAa;EACb,8BAA8B;AAChC;;AAEA;EACE,aAAa;EACb,sBAAsB;EACtB,uBAAuB;AACzB;;AAEA;;;;EAIE,SAAS;EACT,UAAU;EACV,eAAe;EACf,gBAAgB;EAChB,iBAAiB;EACjB,kBAAkB;AACpB;;AAEA;EACE,kBAAkB;AACpB;;AAEA;EACE,kBAAkB;EAClB,WAAW;EACX,aAAa;EACb,uBAAuB;EACvB,aAAa;AACf",sourcesContent:["@import url('https://fonts.googleapis.com/css2?family=Roboto&display=swap');\n\nbody {\n background-color: #f6f6f6;\n font-family: 'Roboto', sans-serif;\n box-sizing: border-box;\n margin: 0;\n color: #645f5f;\n}\n\nsection {\n width: 100vw;\n height: 100vh;\n display: flex;\n justify-content: center;\n align-items: center;\n}\n\n.todo {\n box-shadow: 3px 2px 4px gray;\n}\n\n.todo > div,\n.task {\n min-width: 400px;\n max-width: 550px;\n display: flex;\n justify-content: space-between;\n border-bottom: 1px solid #dcdbdb;\n}\n\n.todo .header {\n background-color: white;\n padding: 20px;\n display: flex;\n justify-content: space-between;\n}\n\n.todo .header h1 {\n margin: 0;\n font-size: 16px;\n font-weight: 400;\n}\n\n.todo .tasks,\n.todo .add_task {\n background-color: white;\n}\n\n.todo .add_task,\n.task {\n padding: 20px;\n}\n\n.task {\n display: flex;\n justify-content: space-between;\n}\n\n.todo .tasks {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n}\n\ninput,\ninput:focus,\ntextarea:focus,\nselect:focus {\n border: 0;\n outline: 0;\n font-size: 14px;\n color: cadetblue;\n line-height: 28px;\n margin-right: 10px;\n}\n\ninput::placeholder {\n font-style: italic;\n}\n\n.todo .footer {\n text-align: center;\n color: grey;\n display: flex;\n justify-content: center;\n padding: 20px;\n}\n"],sourceRoot:""}]);const s=i},645:n=>{n.exports=function(n){var t=[];return t.toString=function(){return this.map((function(t){var e="",o=void 0!==t[5];return t[4]&&(e+="@supports (".concat(t[4],") {")),t[2]&&(e+="@media ".concat(t[2]," {")),o&&(e+="@layer".concat(t[5].length>0?" ".concat(t[5]):""," {")),e+=n(t),o&&(e+="}"),t[2]&&(e+="}"),t[4]&&(e+="}"),e})).join("")},t.i=function(n,e,o,a,r){"string"==typeof n&&(n=[[null,n,void 0]]);var i={};if(o)for(var s=0;s0?" ".concat(d[5]):""," {").concat(d[1],"}")),d[5]=r),e&&(d[2]?(d[1]="@media ".concat(d[2]," {").concat(d[1],"}"),d[2]=e):d[2]=e),a&&(d[4]?(d[1]="@supports (".concat(d[4],") {").concat(d[1],"}"),d[4]=a):d[4]="".concat(a)),t.push(d))}},t}},537:n=>{n.exports=function(n){var t=n[1],e=n[3];if(!e)return t;if("function"==typeof btoa){var o=btoa(unescape(encodeURIComponent(JSON.stringify(e)))),a="sourceMappingURL=data:application/json;charset=utf-8;base64,".concat(o),r="/*# ".concat(a," */"),i=e.sources.map((function(n){return"/*# sourceURL=".concat(e.sourceRoot||"").concat(n," */")}));return[t].concat(i).concat([r]).join("\n")}return[t].join("\n")}},379:n=>{var t=[];function e(n){for(var e=-1,o=0;o{var t={};n.exports=function(n,e){var o=function(n){if(void 0===t[n]){var e=document.querySelector(n);if(window.HTMLIFrameElement&&e instanceof window.HTMLIFrameElement)try{e=e.contentDocument.head}catch(n){e=null}t[n]=e}return t[n]}(n);if(!o)throw new Error("Couldn't find a style target. This probably means that the value for the 'insert' parameter is invalid.");o.appendChild(e)}},216:n=>{n.exports=function(n){var t=document.createElement("style");return n.setAttributes(t,n.attributes),n.insert(t,n.options),t}},565:(n,t,e)=>{n.exports=function(n){var t=e.nc;t&&n.setAttribute("nonce",t)}},795:n=>{n.exports=function(n){var t=n.insertStyleElement(n);return{update:function(e){!function(n,t,e){var o="";e.supports&&(o+="@supports (".concat(e.supports,") {")),e.media&&(o+="@media ".concat(e.media," {"));var a=void 0!==e.layer;a&&(o+="@layer".concat(e.layer.length>0?" ".concat(e.layer):""," {")),o+=e.css,a&&(o+="}"),e.media&&(o+="}"),e.supports&&(o+="}");var r=e.sourceMap;r&&"undefined"!=typeof btoa&&(o+="\n/*# sourceMappingURL=data:application/json;base64,".concat(btoa(unescape(encodeURIComponent(JSON.stringify(r))))," */")),t.styleTagTransform(o,n,t.options)}(t,n,e)},remove:function(){!function(n){if(null===n.parentNode)return!1;n.parentNode.removeChild(n)}(t)}}}},589:n=>{n.exports=function(n,t){if(t.styleSheet)t.styleSheet.cssText=n;else{for(;t.firstChild;)t.removeChild(t.firstChild);t.appendChild(document.createTextNode(n))}}}},t={};function e(o){var a=t[o];if(void 0!==a)return a.exports;var r=t[o]={id:o,exports:{}};return n[o](r,r.exports,e),r.exports}e.n=n=>{var t=n&&n.__esModule?()=>n.default:()=>n;return e.d(t,{a:t}),t},e.d=(n,t)=>{for(var o in t)e.o(t,o)&&!e.o(n,o)&&Object.defineProperty(n,o,{enumerable:!0,get:t[o]})},e.o=(n,t)=>Object.prototype.hasOwnProperty.call(n,t),(()=>{var n=e(379),t=e.n(n),o=e(795),a=e.n(o),r=e(569),i=e.n(r),s=e(565),c=e.n(s),A=e(216),d=e.n(A),l=e(589),p=e.n(l),u=e(426),f={};f.styleTagTransform=p(),f.setAttributes=c(),f.insert=i().bind(null,"head"),f.domAPI=a(),f.insertStyleElement=d(),t()(u.Z,f),u.Z&&u.Z.locals&&u.Z.locals;class h{constructor(n,t,e){this.index=n,this.description=t,this.completed=e}}class E{static displayTask=(n,t)=>{const e=E.createHtml(n,"div","task"),o=E.createHtml(e,"div","task_input"),a=E.createHtml(o,"input");a.setAttribute("type","checkbox"),a.setAttribute("name",`tasK_${t.index}`),E.createHtml(o,"label","",t.description).setAttribute("for",`tasK_${t.index}`),E.createHtml(e,"i","fas fa-ellipsis-v")};static createHtml=(n,t,e,o=null)=>{const a=document.createElement(t);return a.className=e,a.innerHTML=o,n.appendChild(a),a}}let m=[new h(1,"one","ok"),new h(2,"two","ok"),new h(4,"four","ok"),new h(3,"three","ok"),new h(5,"five","ok")];m=m.sort(((n,t)=>n.index-t.index)),m.forEach((n=>E.displayTask((".tasks",document.querySelector(".tasks")),n)))})()})(); 2 | //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"main.js","mappings":"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","sources":["webpack://todolist/./src/style.css","webpack://todolist/./node_modules/css-loader/dist/runtime/api.js","webpack://todolist/./node_modules/css-loader/dist/runtime/sourceMaps.js","webpack://todolist/./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js","webpack://todolist/./node_modules/style-loader/dist/runtime/insertBySelector.js","webpack://todolist/./node_modules/style-loader/dist/runtime/insertStyleElement.js","webpack://todolist/./node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js","webpack://todolist/./node_modules/style-loader/dist/runtime/styleDomAPI.js","webpack://todolist/./node_modules/style-loader/dist/runtime/styleTagTransform.js","webpack://todolist/webpack/bootstrap","webpack://todolist/webpack/runtime/compat get default export","webpack://todolist/webpack/runtime/define property getters","webpack://todolist/webpack/runtime/hasOwnProperty shorthand","webpack://todolist/./src/style.css?7163","webpack://todolist/./src/modules/task.js","webpack://todolist/./src/modules/display_manager.js","webpack://todolist/./src/index.js"],"sourcesContent":["// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\n___CSS_LOADER_EXPORT___.push([module.id, \"@import url(https://fonts.googleapis.com/css2?family=Roboto&display=swap);\"]);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, \"body {\\n  background-color: #f6f6f6;\\n  font-family: 'Roboto', sans-serif;\\n  box-sizing: border-box;\\n  margin: 0;\\n  color: #645f5f;\\n}\\n\\nsection {\\n  width: 100vw;\\n  height: 100vh;\\n  display: flex;\\n  justify-content: center;\\n  align-items: center;\\n}\\n\\n.todo {\\n  box-shadow: 3px 2px 4px gray;\\n}\\n\\n.todo > div,\\n.task {\\n  min-width: 400px;\\n  max-width: 550px;\\n  display: flex;\\n  justify-content: space-between;\\n  border-bottom: 1px solid #dcdbdb;\\n}\\n\\n.todo .header {\\n  background-color: white;\\n  padding: 20px;\\n  display: flex;\\n  justify-content: space-between;\\n}\\n\\n.todo .header h1 {\\n  margin: 0;\\n  font-size: 16px;\\n  font-weight: 400;\\n}\\n\\n.todo .tasks,\\n.todo .add_task {\\n  background-color: white;\\n}\\n\\n.todo .add_task,\\n.task {\\n  padding: 20px;\\n}\\n\\n.task {\\n  display: flex;\\n  justify-content: space-between;\\n}\\n\\n.todo .tasks {\\n  display: flex;\\n  flex-direction: column;\\n  align-items: flex-start;\\n}\\n\\ninput,\\ninput:focus,\\ntextarea:focus,\\nselect:focus {\\n  border: 0;\\n  outline: 0;\\n  font-size: 14px;\\n  color: cadetblue;\\n  line-height: 28px;\\n  margin-right: 10px;\\n}\\n\\ninput::placeholder {\\n  font-style: italic;\\n}\\n\\n.todo .footer {\\n  text-align: center;\\n  color: grey;\\n  display: flex;\\n  justify-content: center;\\n  padding: 20px;\\n}\\n\", \"\",{\"version\":3,\"sources\":[\"webpack://./src/style.css\"],\"names\":[],\"mappings\":\"AAEA;EACE,yBAAyB;EACzB,iCAAiC;EACjC,sBAAsB;EACtB,SAAS;EACT,cAAc;AAChB;;AAEA;EACE,YAAY;EACZ,aAAa;EACb,aAAa;EACb,uBAAuB;EACvB,mBAAmB;AACrB;;AAEA;EACE,4BAA4B;AAC9B;;AAEA;;EAEE,gBAAgB;EAChB,gBAAgB;EAChB,aAAa;EACb,8BAA8B;EAC9B,gCAAgC;AAClC;;AAEA;EACE,uBAAuB;EACvB,aAAa;EACb,aAAa;EACb,8BAA8B;AAChC;;AAEA;EACE,SAAS;EACT,eAAe;EACf,gBAAgB;AAClB;;AAEA;;EAEE,uBAAuB;AACzB;;AAEA;;EAEE,aAAa;AACf;;AAEA;EACE,aAAa;EACb,8BAA8B;AAChC;;AAEA;EACE,aAAa;EACb,sBAAsB;EACtB,uBAAuB;AACzB;;AAEA;;;;EAIE,SAAS;EACT,UAAU;EACV,eAAe;EACf,gBAAgB;EAChB,iBAAiB;EACjB,kBAAkB;AACpB;;AAEA;EACE,kBAAkB;AACpB;;AAEA;EACE,kBAAkB;EAClB,WAAW;EACX,aAAa;EACb,uBAAuB;EACvB,aAAa;AACf\",\"sourcesContent\":[\"@import url('https://fonts.googleapis.com/css2?family=Roboto&display=swap');\\n\\nbody {\\n  background-color: #f6f6f6;\\n  font-family: 'Roboto', sans-serif;\\n  box-sizing: border-box;\\n  margin: 0;\\n  color: #645f5f;\\n}\\n\\nsection {\\n  width: 100vw;\\n  height: 100vh;\\n  display: flex;\\n  justify-content: center;\\n  align-items: center;\\n}\\n\\n.todo {\\n  box-shadow: 3px 2px 4px gray;\\n}\\n\\n.todo > div,\\n.task {\\n  min-width: 400px;\\n  max-width: 550px;\\n  display: flex;\\n  justify-content: space-between;\\n  border-bottom: 1px solid #dcdbdb;\\n}\\n\\n.todo .header {\\n  background-color: white;\\n  padding: 20px;\\n  display: flex;\\n  justify-content: space-between;\\n}\\n\\n.todo .header h1 {\\n  margin: 0;\\n  font-size: 16px;\\n  font-weight: 400;\\n}\\n\\n.todo .tasks,\\n.todo .add_task {\\n  background-color: white;\\n}\\n\\n.todo .add_task,\\n.task {\\n  padding: 20px;\\n}\\n\\n.task {\\n  display: flex;\\n  justify-content: space-between;\\n}\\n\\n.todo .tasks {\\n  display: flex;\\n  flex-direction: column;\\n  align-items: flex-start;\\n}\\n\\ninput,\\ninput:focus,\\ntextarea:focus,\\nselect:focus {\\n  border: 0;\\n  outline: 0;\\n  font-size: 14px;\\n  color: cadetblue;\\n  line-height: 28px;\\n  margin-right: 10px;\\n}\\n\\ninput::placeholder {\\n  font-style: italic;\\n}\\n\\n.todo .footer {\\n  text-align: center;\\n  color: grey;\\n  display: flex;\\n  justify-content: center;\\n  padding: 20px;\\n}\\n\"],\"sourceRoot\":\"\"}]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___;\n","\"use strict\";\n\n/*\n  MIT License http://www.opensource.org/licenses/mit-license.php\n  Author Tobias Koppers @sokra\n*/\nmodule.exports = function (cssWithMappingToString) {\n  var list = []; // return the list of modules as css string\n\n  list.toString = function toString() {\n    return this.map(function (item) {\n      var content = \"\";\n      var needLayer = typeof item[5] !== \"undefined\";\n\n      if (item[4]) {\n        content += \"@supports (\".concat(item[4], \") {\");\n      }\n\n      if (item[2]) {\n        content += \"@media \".concat(item[2], \" {\");\n      }\n\n      if (needLayer) {\n        content += \"@layer\".concat(item[5].length > 0 ? \" \".concat(item[5]) : \"\", \" {\");\n      }\n\n      content += cssWithMappingToString(item);\n\n      if (needLayer) {\n        content += \"}\";\n      }\n\n      if (item[2]) {\n        content += \"}\";\n      }\n\n      if (item[4]) {\n        content += \"}\";\n      }\n\n      return content;\n    }).join(\"\");\n  }; // import a list of modules into the list\n\n\n  list.i = function i(modules, media, dedupe, supports, layer) {\n    if (typeof modules === \"string\") {\n      modules = [[null, modules, undefined]];\n    }\n\n    var alreadyImportedModules = {};\n\n    if (dedupe) {\n      for (var k = 0; k < this.length; k++) {\n        var id = this[k][0];\n\n        if (id != null) {\n          alreadyImportedModules[id] = true;\n        }\n      }\n    }\n\n    for (var _k = 0; _k < modules.length; _k++) {\n      var item = [].concat(modules[_k]);\n\n      if (dedupe && alreadyImportedModules[item[0]]) {\n        continue;\n      }\n\n      if (typeof layer !== \"undefined\") {\n        if (typeof item[5] === \"undefined\") {\n          item[5] = layer;\n        } else {\n          item[1] = \"@layer\".concat(item[5].length > 0 ? \" \".concat(item[5]) : \"\", \" {\").concat(item[1], \"}\");\n          item[5] = layer;\n        }\n      }\n\n      if (media) {\n        if (!item[2]) {\n          item[2] = media;\n        } else {\n          item[1] = \"@media \".concat(item[2], \" {\").concat(item[1], \"}\");\n          item[2] = media;\n        }\n      }\n\n      if (supports) {\n        if (!item[4]) {\n          item[4] = \"\".concat(supports);\n        } else {\n          item[1] = \"@supports (\".concat(item[4], \") {\").concat(item[1], \"}\");\n          item[4] = supports;\n        }\n      }\n\n      list.push(item);\n    }\n  };\n\n  return list;\n};","\"use strict\";\n\nmodule.exports = function (item) {\n  var content = item[1];\n  var cssMapping = item[3];\n\n  if (!cssMapping) {\n    return content;\n  }\n\n  if (typeof btoa === \"function\") {\n    var base64 = btoa(unescape(encodeURIComponent(JSON.stringify(cssMapping))));\n    var data = \"sourceMappingURL=data:application/json;charset=utf-8;base64,\".concat(base64);\n    var sourceMapping = \"/*# \".concat(data, \" */\");\n    var sourceURLs = cssMapping.sources.map(function (source) {\n      return \"/*# sourceURL=\".concat(cssMapping.sourceRoot || \"\").concat(source, \" */\");\n    });\n    return [content].concat(sourceURLs).concat([sourceMapping]).join(\"\\n\");\n  }\n\n  return [content].join(\"\\n\");\n};","\"use strict\";\n\nvar stylesInDOM = [];\n\nfunction getIndexByIdentifier(identifier) {\n  var result = -1;\n\n  for (var i = 0; i < stylesInDOM.length; i++) {\n    if (stylesInDOM[i].identifier === identifier) {\n      result = i;\n      break;\n    }\n  }\n\n  return result;\n}\n\nfunction modulesToDom(list, options) {\n  var idCountMap = {};\n  var identifiers = [];\n\n  for (var i = 0; i < list.length; i++) {\n    var item = list[i];\n    var id = options.base ? item[0] + options.base : item[0];\n    var count = idCountMap[id] || 0;\n    var identifier = \"\".concat(id, \" \").concat(count);\n    idCountMap[id] = count + 1;\n    var indexByIdentifier = getIndexByIdentifier(identifier);\n    var obj = {\n      css: item[1],\n      media: item[2],\n      sourceMap: item[3],\n      supports: item[4],\n      layer: item[5]\n    };\n\n    if (indexByIdentifier !== -1) {\n      stylesInDOM[indexByIdentifier].references++;\n      stylesInDOM[indexByIdentifier].updater(obj);\n    } else {\n      var updater = addElementStyle(obj, options);\n      options.byIndex = i;\n      stylesInDOM.splice(i, 0, {\n        identifier: identifier,\n        updater: updater,\n        references: 1\n      });\n    }\n\n    identifiers.push(identifier);\n  }\n\n  return identifiers;\n}\n\nfunction addElementStyle(obj, options) {\n  var api = options.domAPI(options);\n  api.update(obj);\n\n  var updater = function updater(newObj) {\n    if (newObj) {\n      if (newObj.css === obj.css && newObj.media === obj.media && newObj.sourceMap === obj.sourceMap && newObj.supports === obj.supports && newObj.layer === obj.layer) {\n        return;\n      }\n\n      api.update(obj = newObj);\n    } else {\n      api.remove();\n    }\n  };\n\n  return updater;\n}\n\nmodule.exports = function (list, options) {\n  options = options || {};\n  list = list || [];\n  var lastIdentifiers = modulesToDom(list, options);\n  return function update(newList) {\n    newList = newList || [];\n\n    for (var i = 0; i < lastIdentifiers.length; i++) {\n      var identifier = lastIdentifiers[i];\n      var index = getIndexByIdentifier(identifier);\n      stylesInDOM[index].references--;\n    }\n\n    var newLastIdentifiers = modulesToDom(newList, options);\n\n    for (var _i = 0; _i < lastIdentifiers.length; _i++) {\n      var _identifier = lastIdentifiers[_i];\n\n      var _index = getIndexByIdentifier(_identifier);\n\n      if (stylesInDOM[_index].references === 0) {\n        stylesInDOM[_index].updater();\n\n        stylesInDOM.splice(_index, 1);\n      }\n    }\n\n    lastIdentifiers = newLastIdentifiers;\n  };\n};","\"use strict\";\n\nvar memo = {};\n/* istanbul ignore next  */\n\nfunction getTarget(target) {\n  if (typeof memo[target] === \"undefined\") {\n    var styleTarget = document.querySelector(target); // Special case to return head of iframe instead of iframe itself\n\n    if (window.HTMLIFrameElement && styleTarget instanceof window.HTMLIFrameElement) {\n      try {\n        // This will throw an exception if access to iframe is blocked\n        // due to cross-origin restrictions\n        styleTarget = styleTarget.contentDocument.head;\n      } catch (e) {\n        // istanbul ignore next\n        styleTarget = null;\n      }\n    }\n\n    memo[target] = styleTarget;\n  }\n\n  return memo[target];\n}\n/* istanbul ignore next  */\n\n\nfunction insertBySelector(insert, style) {\n  var target = getTarget(insert);\n\n  if (!target) {\n    throw new Error(\"Couldn't find a style target. This probably means that the value for the 'insert' parameter is invalid.\");\n  }\n\n  target.appendChild(style);\n}\n\nmodule.exports = insertBySelector;","\"use strict\";\n\n/* istanbul ignore next  */\nfunction insertStyleElement(options) {\n  var element = document.createElement(\"style\");\n  options.setAttributes(element, options.attributes);\n  options.insert(element, options.options);\n  return element;\n}\n\nmodule.exports = insertStyleElement;","\"use strict\";\n\n/* istanbul ignore next  */\nfunction setAttributesWithoutAttributes(styleElement) {\n  var nonce = typeof __webpack_nonce__ !== \"undefined\" ? __webpack_nonce__ : null;\n\n  if (nonce) {\n    styleElement.setAttribute(\"nonce\", nonce);\n  }\n}\n\nmodule.exports = setAttributesWithoutAttributes;","\"use strict\";\n\n/* istanbul ignore next  */\nfunction apply(styleElement, options, obj) {\n  var css = \"\";\n\n  if (obj.supports) {\n    css += \"@supports (\".concat(obj.supports, \") {\");\n  }\n\n  if (obj.media) {\n    css += \"@media \".concat(obj.media, \" {\");\n  }\n\n  var needLayer = typeof obj.layer !== \"undefined\";\n\n  if (needLayer) {\n    css += \"@layer\".concat(obj.layer.length > 0 ? \" \".concat(obj.layer) : \"\", \" {\");\n  }\n\n  css += obj.css;\n\n  if (needLayer) {\n    css += \"}\";\n  }\n\n  if (obj.media) {\n    css += \"}\";\n  }\n\n  if (obj.supports) {\n    css += \"}\";\n  }\n\n  var sourceMap = obj.sourceMap;\n\n  if (sourceMap && typeof btoa !== \"undefined\") {\n    css += \"\\n/*# sourceMappingURL=data:application/json;base64,\".concat(btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap)))), \" */\");\n  } // For old IE\n\n  /* istanbul ignore if  */\n\n\n  options.styleTagTransform(css, styleElement, options.options);\n}\n\nfunction removeStyleElement(styleElement) {\n  // istanbul ignore if\n  if (styleElement.parentNode === null) {\n    return false;\n  }\n\n  styleElement.parentNode.removeChild(styleElement);\n}\n/* istanbul ignore next  */\n\n\nfunction domAPI(options) {\n  var styleElement = options.insertStyleElement(options);\n  return {\n    update: function update(obj) {\n      apply(styleElement, options, obj);\n    },\n    remove: function remove() {\n      removeStyleElement(styleElement);\n    }\n  };\n}\n\nmodule.exports = domAPI;","\"use strict\";\n\n/* istanbul ignore next  */\nfunction styleTagTransform(css, styleElement) {\n  if (styleElement.styleSheet) {\n    styleElement.styleSheet.cssText = css;\n  } else {\n    while (styleElement.firstChild) {\n      styleElement.removeChild(styleElement.firstChild);\n    }\n\n    styleElement.appendChild(document.createTextNode(css));\n  }\n}\n\nmodule.exports = styleTagTransform;","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\tid: moduleId,\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","\n      import API from \"!../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n      import domAPI from \"!../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n      import insertFn from \"!../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n      import setAttributes from \"!../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n      import insertStyleElement from \"!../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n      import styleTagTransformFn from \"!../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n      import content, * as namedExport from \"!!../node_modules/css-loader/dist/cjs.js!./style.css\";\n      \n      \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\n\n      options.insert = insertFn.bind(null, \"head\");\n    \noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../node_modules/css-loader/dist/cjs.js!./style.css\";\n       export default content && content.locals ? content.locals : undefined;\n","export default class Task {\n  constructor(index, description, completed) {\n    this.index = index;\n    this.description = description;\n    this.completed = completed;\n  }\n}\n","export default class DisplayManager {\n  static displayTask = (parent, task) => {\n    const taskDiv = DisplayManager.createHtml(parent, 'div', 'task');\n    const taskInput = DisplayManager.createHtml(taskDiv, 'div', 'task_input');\n    const input = DisplayManager.createHtml(taskInput, 'input');\n    input.setAttribute('type', 'checkbox');\n    input.setAttribute('name', `tasK_${task.index}`);\n    DisplayManager.createHtml(taskInput, 'label', '', task.description).setAttribute('for', `tasK_${task.index}`);\n    DisplayManager.createHtml(taskDiv, 'i', 'fas fa-ellipsis-v');\n  };\n\n  static createHtml = (parent, tag, className, content = null) => {\n    const element = document.createElement(tag);\n    element.className = className;\n    element.innerHTML = content;\n    parent.appendChild(element);\n    return element;\n  };\n}\n","import './style.css';\nimport Task from './modules/task.js';\nimport DisplayManager from './modules/display_manager.js';\n\nconst selector = (element) => document.querySelector(element);\n\nlet tasks = [new Task(1, 'one', 'ok'), new Task(2, 'two', 'ok'), new Task(4, 'four', 'ok'), new Task(3, 'three', 'ok'), new Task(5, 'five', 'ok')];\n\ntasks = tasks.sort((a, b) => a.index - b.index);\n\ntasks.forEach((task) => DisplayManager.displayTask(selector('.tasks'), task));\n"],"names":["___CSS_LOADER_EXPORT___","push","module","id","exports","cssWithMappingToString","list","toString","this","map","item","content","needLayer","concat","length","join","i","modules","media","dedupe","supports","layer","undefined","alreadyImportedModules","k","_k","cssMapping","btoa","base64","unescape","encodeURIComponent","JSON","stringify","data","sourceMapping","sourceURLs","sources","source","sourceRoot","stylesInDOM","getIndexByIdentifier","identifier","result","modulesToDom","options","idCountMap","identifiers","base","count","indexByIdentifier","obj","css","sourceMap","references","updater","addElementStyle","byIndex","splice","api","domAPI","update","newObj","remove","lastIdentifiers","newList","index","newLastIdentifiers","_i","_index","memo","insert","style","target","styleTarget","document","querySelector","window","HTMLIFrameElement","contentDocument","head","e","getTarget","Error","appendChild","element","createElement","setAttributes","attributes","styleElement","nonce","setAttribute","insertStyleElement","styleTagTransform","apply","parentNode","removeChild","removeStyleElement","styleSheet","cssText","firstChild","createTextNode","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","__webpack_modules__","n","getter","__esModule","d","a","definition","key","o","Object","defineProperty","enumerable","get","prop","prototype","hasOwnProperty","call","Task","constructor","description","completed","DisplayManager","static","parent","task","taskDiv","createHtml","taskInput","input","tag","className","innerHTML","tasks","sort","b","forEach","displayTask"],"sourceRoot":""} --------------------------------------------------------------------------------