2
0
mirror of https://github.com/frappe/books.git synced 2024-11-08 23:00:56 +00:00

init webpack and client with primercss

This commit is contained in:
Rushabh Mehta 2018-01-03 22:08:17 +05:30
parent d8551b9909
commit 17c65bd894
11 changed files with 5636 additions and 7 deletions

1
.gitignore vendored
View File

@ -3,6 +3,7 @@ node_modules
Thumbs.db
test.db
*.log
.cache
/dist
/temp

10
.sassrc.js Normal file
View File

@ -0,0 +1,10 @@
const path = require('path')
const CWD = process.cwd()
module.exports = {
"includePaths": [
path.resolve(CWD, 'node_modules'),
path.resolve(CWD, 'client/scss')
]
}

19
frappe/client/index.html Normal file
View File

@ -0,0 +1,19 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<div class="container-md">
<nav class="menu" aria-label="Person settings">
<a class="menu-item selected" href="#url" aria-current="page">Account</a>
<a class="menu-item" href="#url">Profile</a>
<a class="menu-item" href="#url">Emails</a>
<a class="menu-item" href="#url">Notifications</a>
</nav>
</div>
<script src="js/bundle.js"></script>
</body>
</html>

1
frappe/client/index.js Normal file
View File

@ -0,0 +1 @@
require('./scss/main.scss');

667
frappe/client/js/bundle.js Normal file

File diff suppressed because one or more lines are too long

View File

@ -0,0 +1,5 @@
@import "primer/index.scss";
.container {
margin-top: 20px;
}

View File

@ -1,5 +1,6 @@
const path = require('path');
const bodyParser = require('body-parser');
const express = require('express');
module.exports = {
async init() {
@ -49,6 +50,7 @@ module.exports = {
init_middleware() {
this.app.use(bodyParser.json());
this.app.use(bodyParser.urlencoded({ extended: true }));
this.app.use(express.static('frappe/client'));
},
async start(port=8000) {

307
package-lock.json generated
View File

@ -3444,6 +3444,308 @@
"resolved": "https://registry.npmjs.org/preserve/-/preserve-0.2.0.tgz",
"integrity": "sha1-gV7R9uvGWSb4ZbMQwHE7yzMVzks="
},
"primer": {
"version": "10.2.0",
"resolved": "https://registry.npmjs.org/primer/-/primer-10.2.0.tgz",
"integrity": "sha1-HJ8H6dF2fFfDZKzHHfL6fkiUXSI=",
"requires": {
"primer-alerts": "1.5.4",
"primer-avatars": "1.5.1",
"primer-base": "1.6.2",
"primer-blankslate": "1.4.4",
"primer-box": "2.5.4",
"primer-branch-name": "1.0.2",
"primer-breadcrumb": "1.5.0",
"primer-buttons": "2.5.2",
"primer-core": "6.6.1",
"primer-forms": "2.0.2",
"primer-labels": "1.5.4",
"primer-layout": "1.4.4",
"primer-markdown": "3.7.4",
"primer-marketing": "6.1.0",
"primer-marketing-buttons": "1.0.3",
"primer-marketing-support": "1.4.0",
"primer-marketing-type": "1.4.4",
"primer-marketing-utilities": "1.6.0",
"primer-navigation": "1.5.2",
"primer-page-headers": "1.4.4",
"primer-page-sections": "1.4.4",
"primer-popover": "0.0.5",
"primer-product": "5.6.1",
"primer-subhead": "1.0.2",
"primer-support": "4.5.1",
"primer-table-object": "1.4.4",
"primer-tables": "1.4.4",
"primer-tooltips": "1.5.1",
"primer-truncate": "1.4.4",
"primer-utilities": "4.8.4"
}
},
"primer-alerts": {
"version": "1.5.4",
"resolved": "https://registry.npmjs.org/primer-alerts/-/primer-alerts-1.5.4.tgz",
"integrity": "sha1-sR3RPkiZAX10hkfzh+xUSuYo5aE=",
"requires": {
"primer-support": "4.5.1"
}
},
"primer-avatars": {
"version": "1.5.1",
"resolved": "https://registry.npmjs.org/primer-avatars/-/primer-avatars-1.5.1.tgz",
"integrity": "sha1-pu0Oh2+BVjzeJ1LVgabT3kYykXk=",
"requires": {
"primer-support": "4.5.1"
}
},
"primer-base": {
"version": "1.6.2",
"resolved": "https://registry.npmjs.org/primer-base/-/primer-base-1.6.2.tgz",
"integrity": "sha1-v2tAxi59NVrF9jwzkyEztJID9Qw=",
"requires": {
"primer-support": "4.5.1"
}
},
"primer-blankslate": {
"version": "1.4.4",
"resolved": "https://registry.npmjs.org/primer-blankslate/-/primer-blankslate-1.4.4.tgz",
"integrity": "sha1-jDyJrXKwEb07VNABKq54yOUk3PI=",
"requires": {
"primer-support": "4.5.1"
}
},
"primer-box": {
"version": "2.5.4",
"resolved": "https://registry.npmjs.org/primer-box/-/primer-box-2.5.4.tgz",
"integrity": "sha1-UNv8pyf3Yqvqx9Z4Ac/JkDjX/sQ=",
"requires": {
"primer-support": "4.5.1"
}
},
"primer-branch-name": {
"version": "1.0.2",
"resolved": "https://registry.npmjs.org/primer-branch-name/-/primer-branch-name-1.0.2.tgz",
"integrity": "sha1-hW1hyLyfJDiq//T23qNK7fZ/7aQ=",
"requires": {
"primer-support": "4.5.1"
}
},
"primer-breadcrumb": {
"version": "1.5.0",
"resolved": "https://registry.npmjs.org/primer-breadcrumb/-/primer-breadcrumb-1.5.0.tgz",
"integrity": "sha1-z+eMQpHwUDHX87fa2SFi6FcW12w=",
"requires": {
"primer-support": "4.5.1"
}
},
"primer-buttons": {
"version": "2.5.2",
"resolved": "https://registry.npmjs.org/primer-buttons/-/primer-buttons-2.5.2.tgz",
"integrity": "sha1-nUzV3YjUFEm1B/BcvgIIoN3ym7k=",
"requires": {
"primer-support": "4.5.1"
}
},
"primer-core": {
"version": "6.6.1",
"resolved": "https://registry.npmjs.org/primer-core/-/primer-core-6.6.1.tgz",
"integrity": "sha1-dqlGSOFg7aN5EU/m9UDdl0mw1gQ=",
"requires": {
"primer-base": "1.6.2",
"primer-box": "2.5.4",
"primer-breadcrumb": "1.5.0",
"primer-buttons": "2.5.2",
"primer-forms": "2.0.2",
"primer-layout": "1.4.4",
"primer-navigation": "1.5.2",
"primer-support": "4.5.1",
"primer-table-object": "1.4.4",
"primer-tooltips": "1.5.1",
"primer-truncate": "1.4.4",
"primer-utilities": "4.8.4"
}
},
"primer-forms": {
"version": "2.0.2",
"resolved": "https://registry.npmjs.org/primer-forms/-/primer-forms-2.0.2.tgz",
"integrity": "sha1-wziYVArOPXn96QY+7zllWiv/j7g=",
"requires": {
"primer-support": "4.5.1"
}
},
"primer-labels": {
"version": "1.5.4",
"resolved": "https://registry.npmjs.org/primer-labels/-/primer-labels-1.5.4.tgz",
"integrity": "sha1-1PUF3bpo5Q6p06wlkF/oNI5VjgY=",
"requires": {
"primer-support": "4.5.1"
}
},
"primer-layout": {
"version": "1.4.4",
"resolved": "https://registry.npmjs.org/primer-layout/-/primer-layout-1.4.4.tgz",
"integrity": "sha1-3epEMPPpTuhJtT4GJxjv6hsNESk=",
"requires": {
"primer-support": "4.5.1"
}
},
"primer-markdown": {
"version": "3.7.4",
"resolved": "https://registry.npmjs.org/primer-markdown/-/primer-markdown-3.7.4.tgz",
"integrity": "sha1-tGZvFLrVWUM00rJ5Kmuz7e8sbOc=",
"requires": {
"primer-support": "4.5.1"
}
},
"primer-marketing": {
"version": "6.1.0",
"resolved": "https://registry.npmjs.org/primer-marketing/-/primer-marketing-6.1.0.tgz",
"integrity": "sha1-uPWrfMI8+++f08NgK9DI4XoMtN0=",
"requires": {
"primer-marketing-buttons": "1.0.3",
"primer-marketing-support": "1.4.0",
"primer-marketing-type": "1.4.4",
"primer-marketing-utilities": "1.6.0",
"primer-page-headers": "1.4.4",
"primer-page-sections": "1.4.4",
"primer-support": "4.5.1",
"primer-tables": "1.4.4"
}
},
"primer-marketing-buttons": {
"version": "1.0.3",
"resolved": "https://registry.npmjs.org/primer-marketing-buttons/-/primer-marketing-buttons-1.0.3.tgz",
"integrity": "sha1-VubCJLotrafYdxxj8TNJ7oyboug=",
"requires": {
"primer-support": "4.5.1"
}
},
"primer-marketing-support": {
"version": "1.4.0",
"resolved": "https://registry.npmjs.org/primer-marketing-support/-/primer-marketing-support-1.4.0.tgz",
"integrity": "sha1-CB899Z7+3d0OUHV2RbpTTbMElbQ="
},
"primer-marketing-type": {
"version": "1.4.4",
"resolved": "https://registry.npmjs.org/primer-marketing-type/-/primer-marketing-type-1.4.4.tgz",
"integrity": "sha1-TgGYPqziTUVMa8a3RHPd+sSnU8w=",
"requires": {
"primer-marketing-support": "1.4.0",
"primer-support": "4.5.1"
}
},
"primer-marketing-utilities": {
"version": "1.6.0",
"resolved": "https://registry.npmjs.org/primer-marketing-utilities/-/primer-marketing-utilities-1.6.0.tgz",
"integrity": "sha1-pO1GaXKQ54AhwcV00HHpI+YT81k=",
"requires": {
"primer-marketing-support": "1.4.0",
"primer-support": "4.5.1"
}
},
"primer-navigation": {
"version": "1.5.2",
"resolved": "https://registry.npmjs.org/primer-navigation/-/primer-navigation-1.5.2.tgz",
"integrity": "sha1-qExQ+7ZZ8tcP21+6tFuPQrvyc+Q=",
"requires": {
"primer-support": "4.5.1"
}
},
"primer-page-headers": {
"version": "1.4.4",
"resolved": "https://registry.npmjs.org/primer-page-headers/-/primer-page-headers-1.4.4.tgz",
"integrity": "sha1-olDnBzrmSD+nyrbeWk4fzm8UycU=",
"requires": {
"primer-marketing-support": "1.4.0",
"primer-support": "4.5.1"
}
},
"primer-page-sections": {
"version": "1.4.4",
"resolved": "https://registry.npmjs.org/primer-page-sections/-/primer-page-sections-1.4.4.tgz",
"integrity": "sha1-pGfcCPx9XrauuqtLQGhzuK4XNFw=",
"requires": {
"primer-marketing-support": "1.4.0",
"primer-support": "4.5.1"
}
},
"primer-popover": {
"version": "0.0.5",
"resolved": "https://registry.npmjs.org/primer-popover/-/primer-popover-0.0.5.tgz",
"integrity": "sha1-XebWLeBnZ99edfUoHKp7ZigLAP0=",
"requires": {
"primer-support": "4.5.1"
}
},
"primer-product": {
"version": "5.6.1",
"resolved": "https://registry.npmjs.org/primer-product/-/primer-product-5.6.1.tgz",
"integrity": "sha1-Uxpx3mQcGUGFhkCxwjYfEFaT9mU=",
"requires": {
"primer-alerts": "1.5.4",
"primer-avatars": "1.5.1",
"primer-blankslate": "1.4.4",
"primer-branch-name": "1.0.2",
"primer-labels": "1.5.4",
"primer-markdown": "3.7.4",
"primer-popover": "0.0.5",
"primer-subhead": "1.0.2",
"primer-support": "4.5.1"
}
},
"primer-subhead": {
"version": "1.0.2",
"resolved": "https://registry.npmjs.org/primer-subhead/-/primer-subhead-1.0.2.tgz",
"integrity": "sha1-UwMw/1FoFXnpu9y6T6+cnO3wgEs=",
"requires": {
"primer-support": "4.5.1"
}
},
"primer-support": {
"version": "4.5.1",
"resolved": "https://registry.npmjs.org/primer-support/-/primer-support-4.5.1.tgz",
"integrity": "sha1-MnOm79A2ugBTlEfWm6ZpvosR32Y="
},
"primer-table-object": {
"version": "1.4.4",
"resolved": "https://registry.npmjs.org/primer-table-object/-/primer-table-object-1.4.4.tgz",
"integrity": "sha1-NbCZQqfVMGuDD9V9dhkMilols3Q=",
"requires": {
"primer-support": "4.5.1"
}
},
"primer-tables": {
"version": "1.4.4",
"resolved": "https://registry.npmjs.org/primer-tables/-/primer-tables-1.4.4.tgz",
"integrity": "sha1-W+IdzMZLt7GD/ImhIIozbZn2HdU=",
"requires": {
"primer-marketing-support": "1.4.0",
"primer-support": "4.5.1"
}
},
"primer-tooltips": {
"version": "1.5.1",
"resolved": "https://registry.npmjs.org/primer-tooltips/-/primer-tooltips-1.5.1.tgz",
"integrity": "sha1-nNOpODZ73n1fBhaJbyeAFq8sMh8=",
"requires": {
"primer-support": "4.5.1"
}
},
"primer-truncate": {
"version": "1.4.4",
"resolved": "https://registry.npmjs.org/primer-truncate/-/primer-truncate-1.4.4.tgz",
"integrity": "sha1-Jc3hLDegiALuPTX80on224y3ojU=",
"requires": {
"primer-support": "4.5.1"
}
},
"primer-utilities": {
"version": "4.8.4",
"resolved": "https://registry.npmjs.org/primer-utilities/-/primer-utilities-4.8.4.tgz",
"integrity": "sha1-7Qqu8rNZCSBDnA5r3YjdCyCZlqc=",
"requires": {
"primer-support": "4.5.1"
}
},
"process": {
"version": "0.11.10",
"resolved": "https://registry.npmjs.org/process/-/process-0.11.10.tgz",
@ -3969,11 +4271,6 @@
"integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=",
"dev": true
},
"sql.js": {
"version": "0.4.0",
"resolved": "https://registry.npmjs.org/sql.js/-/sql.js-0.4.0.tgz",
"integrity": "sha1-I76WNVIOsP9Dp0Hn6DA5cmbohEU="
},
"sqlite3": {
"version": "3.1.13",
"resolved": "https://registry.npmjs.org/sqlite3/-/sqlite3-3.1.13.tgz",

View File

@ -11,7 +11,6 @@
"body-parser": "^1.18.2",
"express": "^4.16.2",
"node-fetch": "^1.7.3",
"nodemon": "^1.14.7",
"sqlite3": "^3.1.13",
"walk": "^2.3.9"
},
@ -29,8 +28,14 @@
},
"homepage": "https://github.com/frappe/frappe-js#readme",
"devDependencies": {
"css-loader": "^0.28.7",
"eslint": "^4.9.0",
"mocha": "^4.0.1",
"webpack": "^3.8.1"
"node-sass": "^4.7.2",
"nodemon": "^1.14.7",
"primer": "10.2.0",
"sass-loader": "^6.0.6",
"style-loader": "^0.19.1",
"webpack": "^3.10.0"
}
}

21
webpack.config.js Normal file
View File

@ -0,0 +1,21 @@
module.exports = {
entry: './frappe/client/index.js',
output: {
filename: './frappe/client/js/bundle.js'
},
module: {
rules: [{
test: /\.scss$/,
use: [{
loader: "style-loader" // creates style nodes from JS strings
}, {
loader: "css-loader" // translates CSS into CommonJS
}, {
loader: "sass-loader", // compiles Sass to CSS
options: {
includePaths: ["node_modules", "./frappe/client/scss"]
}
}]
}]
}
};

4601
yarn.lock Normal file

File diff suppressed because it is too large Load Diff