add simple frontend
This commit is contained in:
parent
5024953ac8
commit
066e2cca08
10 changed files with 266 additions and 19 deletions
60
nodejs/app.js
Normal file
60
nodejs/app.js
Normal file
|
@ -0,0 +1,60 @@
|
|||
var express = require('express');
|
||||
var path = require('path');
|
||||
var favicon = require('serve-favicon');
|
||||
var logger = require('morgan');
|
||||
var cookieParser = require('cookie-parser');
|
||||
var bodyParser = require('body-parser');
|
||||
|
||||
var routes = require('./routes/index');
|
||||
var users = require('./routes/users');
|
||||
|
||||
var app = express();
|
||||
|
||||
// view engine setup
|
||||
app.set('views', path.join(__dirname, 'views'));
|
||||
app.set('view engine', 'ejs');
|
||||
|
||||
// uncomment after placing your favicon in /public
|
||||
//app.use(favicon(path.join(__dirname, 'public', 'favicon.ico')));
|
||||
app.use(logger('dev'));
|
||||
app.use(bodyParser.json());
|
||||
app.use(bodyParser.urlencoded({ extended: false }));
|
||||
app.use(cookieParser());
|
||||
app.use(express.static(path.join(__dirname, 'public')));
|
||||
|
||||
app.use('/', routes);
|
||||
app.use('/users', users);
|
||||
|
||||
// catch 404 and forward to error handler
|
||||
app.use(function(req, res, next) {
|
||||
var err = new Error('Not Found');
|
||||
err.status = 404;
|
||||
next(err);
|
||||
});
|
||||
|
||||
// error handlers
|
||||
|
||||
// development error handler
|
||||
// will print stacktrace
|
||||
if (app.get('env') === 'development') {
|
||||
app.use(function(err, req, res, next) {
|
||||
res.status(err.status || 500);
|
||||
res.render('error', {
|
||||
message: err.message,
|
||||
error: err
|
||||
});
|
||||
});
|
||||
}
|
||||
|
||||
// production error handler
|
||||
// no stacktraces leaked to user
|
||||
app.use(function(err, req, res, next) {
|
||||
res.status(err.status || 500);
|
||||
res.render('error', {
|
||||
message: err.message,
|
||||
error: {}
|
||||
});
|
||||
});
|
||||
|
||||
|
||||
module.exports = app;
|
90
nodejs/bin/www
Executable file
90
nodejs/bin/www
Executable file
|
@ -0,0 +1,90 @@
|
|||
#!/usr/bin/env node
|
||||
|
||||
/**
|
||||
* Module dependencies.
|
||||
*/
|
||||
|
||||
var app = require('../app');
|
||||
var debug = require('debug')('nodejs:server');
|
||||
var http = require('http');
|
||||
|
||||
/**
|
||||
* Get port from environment and store in Express.
|
||||
*/
|
||||
|
||||
var port = normalizePort(process.env.PORT || '3000');
|
||||
app.set('port', port);
|
||||
|
||||
/**
|
||||
* Create HTTP server.
|
||||
*/
|
||||
|
||||
var server = http.createServer(app);
|
||||
|
||||
/**
|
||||
* Listen on provided port, on all network interfaces.
|
||||
*/
|
||||
|
||||
server.listen(port);
|
||||
server.on('error', onError);
|
||||
server.on('listening', onListening);
|
||||
|
||||
/**
|
||||
* Normalize a port into a number, string, or false.
|
||||
*/
|
||||
|
||||
function normalizePort(val) {
|
||||
var port = parseInt(val, 10);
|
||||
|
||||
if (isNaN(port)) {
|
||||
// named pipe
|
||||
return val;
|
||||
}
|
||||
|
||||
if (port >= 0) {
|
||||
// port number
|
||||
return port;
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Event listener for HTTP server "error" event.
|
||||
*/
|
||||
|
||||
function onError(error) {
|
||||
if (error.syscall !== 'listen') {
|
||||
throw error;
|
||||
}
|
||||
|
||||
var bind = typeof port === 'string'
|
||||
? 'Pipe ' + port
|
||||
: 'Port ' + port;
|
||||
|
||||
// handle specific listen errors with friendly messages
|
||||
switch (error.code) {
|
||||
case 'EACCES':
|
||||
console.error(bind + ' requires elevated privileges');
|
||||
process.exit(1);
|
||||
break;
|
||||
case 'EADDRINUSE':
|
||||
console.error(bind + ' is already in use');
|
||||
process.exit(1);
|
||||
break;
|
||||
default:
|
||||
throw error;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Event listener for HTTP server "listening" event.
|
||||
*/
|
||||
|
||||
function onListening() {
|
||||
var addr = server.address();
|
||||
var bind = typeof addr === 'string'
|
||||
? 'pipe ' + addr
|
||||
: 'port ' + addr.port;
|
||||
debug('Listening on ' + bind);
|
||||
}
|
|
@ -1,23 +1,18 @@
|
|||
{
|
||||
"name": "auto-home",
|
||||
"version": "1.0.0",
|
||||
"description": "A way of controlling your home, hopefully.",
|
||||
"main": "index.js",
|
||||
"dependencies": {
|
||||
"serialport": "^2.0.6"
|
||||
},
|
||||
"devDependencies": {},
|
||||
"name": "nodejs",
|
||||
"version": "0.0.0",
|
||||
"private": true,
|
||||
"scripts": {
|
||||
"test": "echo \"Error: no test specified\" && exit 1"
|
||||
"start": "node ./bin/www"
|
||||
},
|
||||
"repository": {
|
||||
"type": "git",
|
||||
"url": "https://svs.ankaa.uberspace.de/sterzy/auto-home.git"
|
||||
},
|
||||
"keywords": [
|
||||
"home",
|
||||
"automation"
|
||||
],
|
||||
"author": "Stefan Sterz",
|
||||
"license": "ISC"
|
||||
"dependencies": {
|
||||
"body-parser": "~1.13.2",
|
||||
"cookie-parser": "~1.3.5",
|
||||
"debug": "~2.2.0",
|
||||
"ejs": "~2.3.3",
|
||||
"express": "~4.13.1",
|
||||
"morgan": "~1.6.1",
|
||||
"serialport": "^2.0.6",
|
||||
"serve-favicon": "~2.3.0"
|
||||
}
|
||||
}
|
||||
|
|
35
nodejs/public/javascripts/angularApp.js
vendored
Normal file
35
nodejs/public/javascripts/angularApp.js
vendored
Normal file
|
@ -0,0 +1,35 @@
|
|||
var app = angular.module('autome', ['ui.router']);
|
||||
|
||||
app.config(['$stateProvider', '$urlRouterProvider',function($stateProvider, $urlRouterProvider) {
|
||||
|
||||
$stateProvider
|
||||
.state('home', {
|
||||
url: '/home',
|
||||
templateUrl: '/home.html',
|
||||
controller: 'MainCtrl',
|
||||
|
||||
});
|
||||
|
||||
$urlRouterProvider.otherwise('home');
|
||||
|
||||
}]);
|
||||
|
||||
app.factory('arduino', ['$http', function($http, auth){
|
||||
var o = {};
|
||||
|
||||
o.toggleLight = function ( ) {
|
||||
return $http.get('/toggleLight');
|
||||
}
|
||||
|
||||
return o;
|
||||
}]);
|
||||
|
||||
app.controller('MainCtrl', ['$scope', 'arduino', function ($scope, arduino){
|
||||
$scope.test = 'Hello World!';
|
||||
|
||||
$scope.toggleLight = function(){
|
||||
|
||||
|
||||
};
|
||||
|
||||
}]);
|
6
nodejs/public/snippets/home.html
Normal file
6
nodejs/public/snippets/home.html
Normal file
|
@ -0,0 +1,6 @@
|
|||
<div class="page-header">
|
||||
<h1>Autome</h1>
|
||||
<form ng-submit="toggleLight()" style="margin-top:30px;">
|
||||
<button type="submit" class="btn btn-primary">Post</button>
|
||||
</form>
|
||||
</div>
|
8
nodejs/public/stylesheets/style.css
Normal file
8
nodejs/public/stylesheets/style.css
Normal file
|
@ -0,0 +1,8 @@
|
|||
body {
|
||||
padding: 50px;
|
||||
font: 14px "Lucida Grande", Helvetica, Arial, sans-serif;
|
||||
}
|
||||
|
||||
a {
|
||||
color: #00B7FF;
|
||||
}
|
9
nodejs/routes/index.js
Normal file
9
nodejs/routes/index.js
Normal file
|
@ -0,0 +1,9 @@
|
|||
var express = require('express');
|
||||
var router = express.Router();
|
||||
|
||||
/* GET home page. */
|
||||
router.get('/', function(req, res, next) {
|
||||
res.render('index', { title: 'Express' });
|
||||
});
|
||||
|
||||
module.exports = router;
|
9
nodejs/routes/users.js
Normal file
9
nodejs/routes/users.js
Normal file
|
@ -0,0 +1,9 @@
|
|||
var express = require('express');
|
||||
var router = express.Router();
|
||||
|
||||
/* GET users listing. */
|
||||
router.get('/', function(req, res, next) {
|
||||
res.send('respond with a resource');
|
||||
});
|
||||
|
||||
module.exports = router;
|
3
nodejs/views/error.ejs
Normal file
3
nodejs/views/error.ejs
Normal file
|
@ -0,0 +1,3 @@
|
|||
<h1><%= message %></h1>
|
||||
<h2><%= error.status %></h2>
|
||||
<pre><%= error.stack %></pre>
|
32
nodejs/views/index.ejs
Normal file
32
nodejs/views/index.ejs
Normal file
|
@ -0,0 +1,32 @@
|
|||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<title>Auto Home</title>
|
||||
|
||||
<link href="http://maxcdn.bootstrapcdn.com/bootstrap/3.2.0/css/bootstrap.min.css" rel="stylesheet">
|
||||
|
||||
<script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.3.10/angular.min.js"></script>
|
||||
<script src="http://cdnjs.cloudflare.com/ajax/libs/angular-ui-router/0.2.10/angular-ui-router.js"></script>
|
||||
<script src="/javascripts/angularApp.js"></script>
|
||||
|
||||
<style> .glyphicon-thumbs-up { cursor:pointer } </style>
|
||||
|
||||
</head>
|
||||
<body ng-app="autome">
|
||||
<div class="row">
|
||||
<div class="col-md-6 col-md-offset-3">
|
||||
<ui-view></ui-view>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<script src="/snippets/home.html" type="text/ng-template" id="/home.html">
|
||||
<div class="page-header">
|
||||
<h1>Autome</h1>
|
||||
<form ng-submit="toggleLight()" style="margin-top:30px;">
|
||||
<button type="submit" class="btn btn-primary">Light Switch</button>
|
||||
</form>
|
||||
</div>
|
||||
</script>
|
||||
|
||||
</body>
|
||||
</html>
|
Reference in a new issue