Compare commits
10 Commits
dd54924933
...
991f703d05
Author | SHA1 | Date | |
---|---|---|---|
|
991f703d05 | ||
|
34e7d30aef | ||
|
947290016d | ||
|
eb66c0dc93 | ||
|
c932911657 | ||
|
21c9e3b623 | ||
|
65c2ac4709 | ||
|
d13f75ab6c | ||
|
2b11dd3624 | ||
|
2400d188ea |
3
.gitignore
vendored
3
.gitignore
vendored
@ -0,0 +1,3 @@
|
|||||||
|
.DS_Store
|
||||||
|
node_modules
|
||||||
|
dist
|
47
index.html
47
index.html
@ -1,47 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang="en">
|
|
||||||
<head>
|
|
||||||
<meta charset="UTF-8" />
|
|
||||||
<meta
|
|
||||||
name="viewport"
|
|
||||||
content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0"
|
|
||||||
/>
|
|
||||||
<meta http-equiv="X-UA-Compatible" content="ie=edge" />
|
|
||||||
<link
|
|
||||||
rel="stylesheet"
|
|
||||||
href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css"
|
|
||||||
integrity="sha384-MCw98/SFnGE8fJT3GXwEOngsV7Zt27NXFoaoApmYm81iuXoPkFOJwJ8ERdknLPMO"
|
|
||||||
crossorigin="anonymous"
|
|
||||||
/>
|
|
||||||
<title>Webpack Demo</title>
|
|
||||||
</head>
|
|
||||||
<body class="container">
|
|
||||||
<h1 class="text-center mt-5">
|
|
||||||
Welcome!
|
|
||||||
</h1>
|
|
||||||
<div class="alert alert-danger" id="error" role="alert"></div>
|
|
||||||
<div class="row mt-5">
|
|
||||||
<div class="col">
|
|
||||||
<div class="input-group">
|
|
||||||
<input type="text" id="numberOne" class="form-control" />
|
|
||||||
<div class="input-group-append input-group-prepend">
|
|
||||||
<span class="input-group-text">+</span>
|
|
||||||
</div>
|
|
||||||
<input type="text" id="numberTwo" class="form-control" />
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="col">
|
|
||||||
<button id="addValues" class="btn btn-primary">Add Values</button>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="card mt-5">
|
|
||||||
<div class="card-body">The result is: <span id="result"></span></div>
|
|
||||||
</div>
|
|
||||||
<img src="./assets/webpack.svg" />
|
|
||||||
</body>
|
|
||||||
<script src="./src/app/alert.service.js"></script>
|
|
||||||
<script src="./src/app/component.service.js"></script>
|
|
||||||
<script src="./src/app/utils/inputs-are-valid.js"></script>
|
|
||||||
<script src="./src/app/utils/parse-inputs.js"></script>
|
|
||||||
<script src="./src/app/app.js"></script>
|
|
||||||
</html>
|
|
8162
package-lock.json
generated
Normal file
8162
package-lock.json
generated
Normal file
File diff suppressed because it is too large
Load Diff
35
package.json
Normal file
35
package.json
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
{
|
||||||
|
"name": "code",
|
||||||
|
"version": "1.0.0",
|
||||||
|
"private": true,
|
||||||
|
"description": "",
|
||||||
|
"main": "index.js",
|
||||||
|
"scripts": {
|
||||||
|
"start": "webpack-dev-server --config webpack.dev.js --open",
|
||||||
|
"build": "webpack --config webpack.prod.js"
|
||||||
|
},
|
||||||
|
"keywords": [],
|
||||||
|
"author": "",
|
||||||
|
"license": "ISC",
|
||||||
|
"devDependencies": {
|
||||||
|
"bootstrap": "^4.3.1",
|
||||||
|
"css-loader": "^2.1.0",
|
||||||
|
"file-loader": "^3.0.1",
|
||||||
|
"html-loader": "^0.5.5",
|
||||||
|
"html-webpack-plugin": "^3.2.0",
|
||||||
|
"jquery": "^3.3.1",
|
||||||
|
"mini-css-extract-plugin": "^0.5.0",
|
||||||
|
"node-sass": "^4.11.0",
|
||||||
|
"optimize-css-assets-webpack-plugin": "^5.0.1",
|
||||||
|
"popper.js": "^1.14.7",
|
||||||
|
"sass-loader": "^7.1.0",
|
||||||
|
"style-loader": "^0.23.1",
|
||||||
|
"webpack": "^4.29.6",
|
||||||
|
"webpack-cli": "^3.2.3",
|
||||||
|
"webpack-dev-server": "^3.2.1",
|
||||||
|
"webpack-merge": "^4.2.1"
|
||||||
|
},
|
||||||
|
"dependencies": {
|
||||||
|
"clean-webpack-plugin": "^2.0.0"
|
||||||
|
}
|
||||||
|
}
|
@ -1,4 +1,5 @@
|
|||||||
class AlertService {
|
import { inputsAreValid } from "./utils/inputs-are-valid";
|
||||||
|
export class AlertService {
|
||||||
constructor() {
|
constructor() {
|
||||||
this.errorBox = document.getElementById("error");
|
this.errorBox = document.getElementById("error");
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
const alertService = new AlertService();
|
import { inputsAreValid } from "./utils/inputs-are-valid";
|
||||||
const componentService = new ComponentService();
|
import { parseInputs } from "./utils/parse-inputs";
|
||||||
const run = (alertService, componentService) => {
|
export const run = (alertService, componentService) => {
|
||||||
alertService.hideErrors();
|
alertService.hideErrors();
|
||||||
|
|
||||||
componentService.onClick(() => {
|
componentService.onClick(() => {
|
||||||
@ -16,4 +16,3 @@ const run = (alertService, componentService) => {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
run(alertService, componentService);
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
class ComponentService {
|
export class ComponentService {
|
||||||
constructor() {
|
constructor() {
|
||||||
this.numberOneInput = document.getElementById("numberOne");
|
this.numberOneInput = document.getElementById("numberOne");
|
||||||
this.numberTwoInput = document.getElementById("numberTwo");
|
this.numberTwoInput = document.getElementById("numberTwo");
|
||||||
|
@ -1,3 +1,3 @@
|
|||||||
const inputsAreValid = (...input) => {
|
export const inputsAreValid = (...input) => {
|
||||||
return input.every(num => typeof num === "number" && !isNaN(num));
|
return input.every(num => typeof num === "number" && !isNaN(num));
|
||||||
};
|
};
|
||||||
|
@ -1,3 +1,3 @@
|
|||||||
const parseInputs = (...input) => {
|
export const parseInputs = (...input) => {
|
||||||
return input.map(str => parseInt(str));
|
return input.map(str => parseInt(str));
|
||||||
};
|
};
|
||||||
|
Before Width: | Height: | Size: 2.3 KiB After Width: | Height: | Size: 2.3 KiB |
8
src/index.js
Normal file
8
src/index.js
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
import { run } from "./app/app";
|
||||||
|
import "./main.scss";
|
||||||
|
import { AlertService } from "./app/alert.service";
|
||||||
|
import { ComponentService } from "./app/component.service";
|
||||||
|
const alertService = new AlertService();
|
||||||
|
const componentService = new ComponentService();
|
||||||
|
run(alertService, componentService);
|
||||||
|
console.log("J");
|
3
src/main.scss
Normal file
3
src/main.scss
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
$primary: teal;
|
||||||
|
$danger: purple;
|
||||||
|
@import "~bootstrap/scss/bootstrap";
|
72
src/template.html
Normal file
72
src/template.html
Normal file
@ -0,0 +1,72 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="en">
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8" />
|
||||||
|
<meta http-equiv="X-UA-Compatible" content="ie=edge" />
|
||||||
|
<title>Webpack Demo</title>
|
||||||
|
</head>
|
||||||
|
<body class="container">
|
||||||
|
<!-- Bootstrap Navbar -->
|
||||||
|
<nav class="navbar navbar-expand-lg navbar-light bg-light">
|
||||||
|
<a class="navbar-brand" href="#">Navbar</a>
|
||||||
|
<button
|
||||||
|
class="navbar-toggler"
|
||||||
|
type="button"
|
||||||
|
data-toggle="collapse"
|
||||||
|
data-target="#navbarNav"
|
||||||
|
aria-controls="navbarNav"
|
||||||
|
aria-expanded="false"
|
||||||
|
aria-label="Toggle navigation"
|
||||||
|
>
|
||||||
|
<span class="navbar-toggler-icon"></span>
|
||||||
|
</button>
|
||||||
|
<div class="collapse navbar-collapse" id="navbarNav">
|
||||||
|
<ul class="navbar-nav">
|
||||||
|
<li class="nav-item active">
|
||||||
|
<a class="nav-link" href="#"
|
||||||
|
>Home <span class="sr-only">(current)</span></a
|
||||||
|
>
|
||||||
|
</li>
|
||||||
|
<li class="nav-item">
|
||||||
|
<a class="nav-link" href="#">Features</a>
|
||||||
|
</li>
|
||||||
|
<li class="nav-item">
|
||||||
|
<a class="nav-link" href="#">Pricing</a>
|
||||||
|
</li>
|
||||||
|
<li class="nav-item">
|
||||||
|
<a
|
||||||
|
class="nav-link disabled"
|
||||||
|
href="#"
|
||||||
|
tabindex="-1"
|
||||||
|
aria-disabled="true"
|
||||||
|
>Disabled</a
|
||||||
|
>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</nav>
|
||||||
|
<h1 class="text-center mt-5">
|
||||||
|
Welcome!
|
||||||
|
</h1>
|
||||||
|
|
||||||
|
<div class="alert alert-danger" id="error" role="alert"></div>
|
||||||
|
<div class="row mt-5">
|
||||||
|
<div class="col">
|
||||||
|
<div class="input-group">
|
||||||
|
<input type="text" id="numberOne" class="form-control" />
|
||||||
|
<div class="input-group-append input-group-prepend">
|
||||||
|
<span class="input-group-text">+</span>
|
||||||
|
</div>
|
||||||
|
<input type="text" id="numberTwo" class="form-control" />
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="col">
|
||||||
|
<button id="addValues" class="btn btn-primary">Add Values</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="card mt-5">
|
||||||
|
<div class="card-body">The result is: <span id="result"></span></div>
|
||||||
|
</div>
|
||||||
|
<img src="./assets/webpack.svg" />
|
||||||
|
</body>
|
||||||
|
</html>
|
1
src/vendor.js
Normal file
1
src/vendor.js
Normal file
@ -0,0 +1 @@
|
|||||||
|
import "bootstrap";
|
27
webpack.common.js
Normal file
27
webpack.common.js
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
const path = require("path");
|
||||||
|
var HtmlWebpackPlugin = require("html-webpack-plugin");
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
entry: {
|
||||||
|
main: "./src/index.js",
|
||||||
|
vendor: "./src/vendor.js"
|
||||||
|
},
|
||||||
|
module: {
|
||||||
|
rules: [
|
||||||
|
{
|
||||||
|
test: /\.html$/,
|
||||||
|
use: ["html-loader"]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
test: /\.(svg|png|jpg|gif)$/,
|
||||||
|
use: {
|
||||||
|
loader: "file-loader",
|
||||||
|
options: {
|
||||||
|
name: "[name].[hash].[ext]",
|
||||||
|
outputPath: "imgs"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
};
|
29
webpack.dev.js
Normal file
29
webpack.dev.js
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
const path = require("path");
|
||||||
|
const common = require("./webpack.common");
|
||||||
|
const merge = require("webpack-merge");
|
||||||
|
var HtmlWebpackPlugin = require("html-webpack-plugin");
|
||||||
|
|
||||||
|
module.exports = merge(common, {
|
||||||
|
mode: "development",
|
||||||
|
output: {
|
||||||
|
filename: "[name].bundle.js",
|
||||||
|
path: path.resolve(__dirname, "dist")
|
||||||
|
},
|
||||||
|
plugins: [
|
||||||
|
new HtmlWebpackPlugin({
|
||||||
|
template: "./src/template.html"
|
||||||
|
})
|
||||||
|
],
|
||||||
|
module: {
|
||||||
|
rules: [
|
||||||
|
{
|
||||||
|
test: /\.scss$/,
|
||||||
|
use: [
|
||||||
|
"style-loader", //3. Inject styles into DOM
|
||||||
|
"css-loader", //2. Turns css into commonjs
|
||||||
|
"sass-loader" //1. Turns sass into css
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
});
|
46
webpack.prod.js
Normal file
46
webpack.prod.js
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
const path = require("path");
|
||||||
|
const common = require("./webpack.common");
|
||||||
|
const merge = require("webpack-merge");
|
||||||
|
const CleanWebpackPlugin = require("clean-webpack-plugin");
|
||||||
|
const MiniCssExtractPlugin = require("mini-css-extract-plugin");
|
||||||
|
const OptimizeCssAssetsPlugin = require("optimize-css-assets-webpack-plugin");
|
||||||
|
const TerserPlugin = require("terser-webpack-plugin");
|
||||||
|
var HtmlWebpackPlugin = require("html-webpack-plugin");
|
||||||
|
|
||||||
|
module.exports = merge(common, {
|
||||||
|
mode: "production",
|
||||||
|
output: {
|
||||||
|
filename: "[name].[contentHash].bundle.js",
|
||||||
|
path: path.resolve(__dirname, "dist")
|
||||||
|
},
|
||||||
|
optimization: {
|
||||||
|
minimizer: [
|
||||||
|
new OptimizeCssAssetsPlugin(),
|
||||||
|
new TerserPlugin(),
|
||||||
|
new HtmlWebpackPlugin({
|
||||||
|
template: "./src/template.html",
|
||||||
|
minify: {
|
||||||
|
removeAttributeQuotes: true,
|
||||||
|
collapseWhitespace: true,
|
||||||
|
removeComments: true
|
||||||
|
}
|
||||||
|
})
|
||||||
|
]
|
||||||
|
},
|
||||||
|
plugins: [
|
||||||
|
new MiniCssExtractPlugin({ filename: "[name].[contentHash].css" }),
|
||||||
|
new CleanWebpackPlugin()
|
||||||
|
],
|
||||||
|
module: {
|
||||||
|
rules: [
|
||||||
|
{
|
||||||
|
test: /\.scss$/,
|
||||||
|
use: [
|
||||||
|
MiniCssExtractPlugin.loader, //3. Extract css into files
|
||||||
|
"css-loader", //2. Turns css into commonjs
|
||||||
|
"sass-loader" //1. Turns sass into css
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
});
|
Loading…
x
Reference in New Issue
Block a user