mirror of
https://github.com/ascribe/onion.git
synced 2025-02-14 21:10:27 +01:00
[wip] add server to serve app
This commit is contained in:
parent
38ab68b599
commit
a1bfbb8f86
26
gulpfile.js
26
gulpfile.js
@ -15,6 +15,9 @@ var sass = require('gulp-sass');
|
|||||||
var concat = require('gulp-concat');
|
var concat = require('gulp-concat');
|
||||||
var _ = require('lodash');
|
var _ = require('lodash');
|
||||||
var eslint = require('gulp-eslint');
|
var eslint = require('gulp-eslint');
|
||||||
|
var argv = require('yargs').argv;
|
||||||
|
var server = require('./server.js').app;
|
||||||
|
|
||||||
|
|
||||||
var config = {
|
var config = {
|
||||||
bootstrapDir: './node_modules/bootstrap-sass'
|
bootstrapDir: './node_modules/bootstrap-sass'
|
||||||
@ -24,16 +27,19 @@ gulp.task('build', function() {
|
|||||||
bundle(false);
|
bundle(false);
|
||||||
});
|
});
|
||||||
|
|
||||||
gulp.task('serve', ['browser-sync', 'lint:watch', 'sass', 'sass:watch', 'copy'], function() {
|
gulp.task('serve', ['browser-sync', 'run-server', 'lint:watch', 'sass', 'sass:watch', 'copy'], function() {
|
||||||
bundle(true);
|
bundle(true);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
gulp.task('run-server', function() {
|
||||||
|
server.listen(4000);
|
||||||
|
});
|
||||||
|
|
||||||
gulp.task('browser-sync', function() {
|
gulp.task('browser-sync', function() {
|
||||||
browserSync({
|
browserSync({
|
||||||
server: {
|
files: ['build/css/*.css', 'build/js/*.js'],
|
||||||
baseDir: "."
|
proxy: 'http://localhost:4000',
|
||||||
},
|
port: 3000
|
||||||
port: process.env.PORT || 3000
|
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -47,7 +53,7 @@ gulp.task('sass', function () {
|
|||||||
}).on('error', sass.logError))
|
}).on('error', sass.logError))
|
||||||
.pipe(sourcemaps.write('./maps'))
|
.pipe(sourcemaps.write('./maps'))
|
||||||
.pipe(gulp.dest('./build/css'))
|
.pipe(gulp.dest('./build/css'))
|
||||||
.pipe(browserSync.stream());;
|
.pipe(browserSync.stream());
|
||||||
});
|
});
|
||||||
|
|
||||||
gulp.task('sass:watch', function () {
|
gulp.task('sass:watch', function () {
|
||||||
@ -55,13 +61,13 @@ gulp.task('sass:watch', function () {
|
|||||||
});
|
});
|
||||||
|
|
||||||
gulp.task('copy', function () {
|
gulp.task('copy', function () {
|
||||||
var files = [
|
var staticAssets = [
|
||||||
'./fonts/**/*',
|
'./fonts/**/*',
|
||||||
'./img/**/*'
|
'./img/**/*'
|
||||||
];
|
];
|
||||||
|
|
||||||
gulp.src(files, {base: './'})
|
gulp.src(staticAssets, {base: './'})
|
||||||
.pipe(gulp.dest('build'));
|
.pipe(gulp.dest('./build'));
|
||||||
|
|
||||||
gulp.src(config.bootstrapDir + '/assets/fonts/**/*')
|
gulp.src(config.bootstrapDir + '/assets/fonts/**/*')
|
||||||
.pipe(gulp.dest('./build/fonts'));
|
.pipe(gulp.dest('./build/fonts'));
|
||||||
@ -115,7 +121,7 @@ function bundle(watch) {
|
|||||||
loadMaps: true
|
loadMaps: true
|
||||||
})) // loads map from browserify file
|
})) // loads map from browserify file
|
||||||
.pipe(sourcemaps.write()) // writes .map file
|
.pipe(sourcemaps.write()) // writes .map file
|
||||||
.pipe(gulp.dest('./build'))
|
.pipe(gulp.dest('./build/js'))
|
||||||
.pipe(browserSync.stream());
|
.pipe(browserSync.stream());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -6,11 +6,11 @@
|
|||||||
<title>ascribe</title>
|
<title>ascribe</title>
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1">
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||||
<link rel="stylesheet" href="//brick.a.ssl.fastly.net/Source+Sans+Pro:400,600,700,900">
|
<link rel="stylesheet" href="//brick.a.ssl.fastly.net/Source+Sans+Pro:400,600,700,900">
|
||||||
<link rel="stylesheet" href="build/css/main.css">
|
<link rel="stylesheet" href="/static/css/main.css">
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<div id="main" class="container"></div>
|
<div id="main" class="container"></div>
|
||||||
<div id="modal" class="container"></div>
|
<div id="modal" class="container"></div>
|
||||||
<script src="build/app.js"></script>
|
<script src="/static/js/app.js"></script>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
@ -47,7 +47,7 @@ fetch.defaults({
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
Router.run(routes, Router.HashLocation, (AscribeApp) => {
|
Router.run(routes, Router.HistoryLocation, (AscribeApp) => {
|
||||||
React.render(
|
React.render(
|
||||||
<AscribeApp />,
|
<AscribeApp />,
|
||||||
document.getElementById('main')
|
document.getElementById('main')
|
||||||
|
@ -46,8 +46,8 @@ let Image = React.createClass({
|
|||||||
this.inject('http://code.jquery.com/jquery-2.1.4.min.js')
|
this.inject('http://code.jquery.com/jquery-2.1.4.min.js')
|
||||||
.then(() =>
|
.then(() =>
|
||||||
Promise.all([
|
Promise.all([
|
||||||
this.inject('node_modules/shmui/shmui.css'),
|
this.inject('/static/thirdparty/shmui/shmui.css'),
|
||||||
this.inject('node_modules/shmui/jquery.shmui.js')
|
this.inject('/static/thirdparty/shmui/jquery.shmui.js')
|
||||||
]).then(() => { window.jQuery('.shmui-ascribe').shmui(); }));
|
]).then(() => { window.jQuery('.shmui-ascribe').shmui(); }));
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -38,7 +38,7 @@ let Header = React.createClass({
|
|||||||
return (
|
return (
|
||||||
<Navbar>
|
<Navbar>
|
||||||
<Nav>
|
<Nav>
|
||||||
<a className="navbar-brand" href="#">
|
<a className="navbar-brand" href="/">
|
||||||
<span>ascribe </span>
|
<span>ascribe </span>
|
||||||
<span className="glyph-ascribe-spool-chunked ascribe-color"></span>
|
<span className="glyph-ascribe-spool-chunked ascribe-color"></span>
|
||||||
</a>
|
</a>
|
||||||
|
@ -4,7 +4,10 @@
|
|||||||
"description": "Das neue web client for Ascribe",
|
"description": "Das neue web client for Ascribe",
|
||||||
"main": "js/app.js",
|
"main": "js/app.js",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"lint": "eslint ./js"
|
"lint": "eslint ./js",
|
||||||
|
"postinstall": "npm run build",
|
||||||
|
"build": "gulp build --production",
|
||||||
|
"start": "node server.js"
|
||||||
},
|
},
|
||||||
"author": "Ascribe",
|
"author": "Ascribe",
|
||||||
"license": "Copyright",
|
"license": "Copyright",
|
||||||
@ -33,12 +36,14 @@
|
|||||||
"reactify": "^1.1.0",
|
"reactify": "^1.1.0",
|
||||||
"vinyl-buffer": "^1.0.0",
|
"vinyl-buffer": "^1.0.0",
|
||||||
"vinyl-source-stream": "^1.1.0",
|
"vinyl-source-stream": "^1.1.0",
|
||||||
"watchify": "^3.1.2"
|
"watchify": "^3.1.2",
|
||||||
|
"yargs": "^3.10.0"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"alt": "^0.16.5",
|
"alt": "^0.16.5",
|
||||||
"classnames": "^1.2.2",
|
"classnames": "^1.2.2",
|
||||||
"es6-promise": "^2.1.1",
|
"es6-promise": "^2.1.1",
|
||||||
|
"express": "^4.12.4",
|
||||||
"isomorphic-fetch": "^2.0.2",
|
"isomorphic-fetch": "^2.0.2",
|
||||||
"object-assign": "^2.0.0",
|
"object-assign": "^2.0.0",
|
||||||
"react": "^0.13.2",
|
"react": "^0.13.2",
|
||||||
|
@ -1,10 +1,10 @@
|
|||||||
@font-face {
|
@font-face {
|
||||||
font-family: 'ascribe';
|
font-family: 'ascribe';
|
||||||
src:url('../../fonts/ascribe.eot?-oi6ttk');
|
src:url('/static/fonts/ascribe.eot?-oi6ttk');
|
||||||
src:url('../../fonts/ascribe.eot?#iefix-oi6ttk') format('embedded-opentype'),
|
src:url('/static/fonts/ascribe.eot?#iefix-oi6ttk') format('embedded-opentype'),
|
||||||
url('../../fonts/ascribe.woff?-oi6ttk') format('woff'),
|
url('/static/fonts/ascribe.woff?-oi6ttk') format('woff'),
|
||||||
url('../../fonts/ascribe.ttf?-oi6ttk') format('truetype'),
|
url('/static/fonts/ascribe.ttf?-oi6ttk') format('truetype'),
|
||||||
url('../../fonts/ascribe.svg?-oi6ttk#ascribe') format('svg');
|
url('/static/fonts/ascribe.svg?-oi6ttk#ascribe') format('svg');
|
||||||
font-weight: normal;
|
font-weight: normal;
|
||||||
font-style: normal;
|
font-style: normal;
|
||||||
}
|
}
|
||||||
|
18
server.js
Normal file
18
server.js
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
var express = require('express');
|
||||||
|
var app = express();
|
||||||
|
|
||||||
|
app.use('/static/js', express.static(__dirname + '/build/js'));
|
||||||
|
app.use('/static/css', express.static(__dirname + '/build/css'));
|
||||||
|
app.use('/static/fonts', express.static(__dirname + '/build/fonts'));
|
||||||
|
app.use('/static/thirdparty/', express.static(__dirname + '/node_modules'));
|
||||||
|
|
||||||
|
app.get(/.*/, function(req, res) {
|
||||||
|
res.sendFile(__dirname + '/index.html');
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
if (require.main === module) {
|
||||||
|
app.listen(process.env.PORT || 4000);
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports.app = app;
|
Loading…
x
Reference in New Issue
Block a user