forked from foting/1md034-project-skeleton
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.js
167 lines (147 loc) · 5.63 KB
/
app.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
/*jslint node: true */
/* eslint-env node */
'use strict';
// Require express, socket.io, and vue
var express = require('express');
var app = express();
var http = require('http').Server(app);
var io = require('socket.io')(http);
var path = require('path');
// Pick arbitrary port for server
var port = 3000;
app.set('port', (process.env.PORT || port));
// Serve static assets from public/
app.use(express.static(path.join(__dirname, 'public/')));
// Serve vue from node_modules as vue/
app.use('/vue', express.static(path.join(__dirname, '/node_modules/vue/dist/')));
// Serve leaflet from node_modules as leaflet/
app.use('/leaflet', express.static(path.join(__dirname, '/node_modules/leaflet/dist/')));
// Serve esri leaflet geocoder from node_modules as esri-leaflet/
app.use('/esri-leaflet', express.static(path.join(__dirname, '/node_modules/esri-leaflet/dist/')));
// Serve esri leaflet geocoder from node_modules as esri-leaflet-geocoder/
app.use('/esri-leaflet-geocoder', express.static(path.join(__dirname, '/node_modules/esri-leaflet-geocoder/dist/')));
// Serve index.html directly as root page
app.get('/', function (req, res) {
res.sendFile(path.join(__dirname, 'views/customer.html'));
});
// Serve driver.html as /driver
app.get('/driver', function (req, res) {
res.sendFile(path.join(__dirname, 'views/driver.html'));
});
// Serve dispatcher.html as /dispatcher
app.get('/dispatcher', function (req, res) {
res.sendFile(path.join(__dirname, 'views/dispatcher.html'));
});
// Store data in an object to keep the global namespace clean and
// prepare for multiple instances of data if necessary
function Data() {
this.orders = {};
this.drivers = {};
this.baseLatLong = { "lat": 59.84091407485801, "lng": 17.64924108548685 };
this.currentOrderNumber = 1000;
}
Data.prototype.getOrderNumber = function () {
this.currentOrderNumber += 1;
return this.currentOrderNumber;
}
/*
Adds an order to the queue
*/
Data.prototype.addOrder = function (order) {
var orderId = this.getOrderNumber();
//Store the order in an "associative array" with orderId as key
this.orders[orderId] = order;
return orderId;
};
/*
Delete the order when it's considered finished
*/
Data.prototype.orderDropOff = function (orderId) {
delete this.orders[orderId];
};
/*
Only needs to know orderId. The rest is up to the client to decide
*/
Data.prototype.updateOrderDetails = function (order) {
for (var key in order) {
this.orders[order.orderId][key] = order[key];
}
};
Data.prototype.getAllOrders = function () {
return this.orders;
};
Data.prototype.addDriver = function (driver) {
//Store info about the drivers in an "associative array" with driverId as key
this.drivers[driver.driverId] = driver;
};
Data.prototype.updateDriverDetails = function (driver) {
for (var key in driver) {
this.drivers[driver.driverId][key] = driver[key];
}
};
Data.prototype.removeDriver = function (driverId) {
delete this.drivers[driverId];
};
Data.prototype.getAllDrivers = function () {
return this.drivers;
};
var data = new Data();
io.on('connection', function (socket) {
// Send the current lists of orders and drivers when a client connects
socket.emit('initialize', { orders: data.getAllOrders(),
drivers: data.getAllDrivers(), base: data.baseLatLong });
// Add a listener for when a connected client emits a "placeOrder" message
socket.on('placeOrder', function (order) {
var orderId = data.addOrder(order);
order.orderId = orderId;
console.log("An order was placed:",order);
// send updated info to all connected clients, note the use of "io" instead of "socket"
io.emit('orderPlaced', order);
// send the orderId back to the customer who ordered
socket.emit('orderId', orderId);
});
socket.on('addDriver', function (driver) {
data.addDriver(driver);
console.log("Driver",driver,"is on the job");
// send updated info to all connected clients, note the use of io instead of socket
io.emit('driverAdded', driver);
});
socket.on('updateDriver', function (driver) {
console.log("Driver", driver.driverId,"was updated");
data.updateDriverDetails(driver);
// send updated info to all connected clients, note the use of io instead of socket
io.emit('driverUpdated', driver);
});
socket.on('moveDriver', function (driver) {
console.log("Driver", driver.driverId,"moved to",driver.latLong);
data.updateDriverDetails(driver);
// send updated info to all connected clients, note the use of io instead of socket
io.emit('driverMoved', driver);
});
socket.on('driverQuit', function (driver) {
data.removeDriver(driver);
console.log("Driver",driver,"has left the job");
// send updated info to all connected clients, note the use of io instead of socket
io.emit('driverQuit', driver);
});
socket.on('orderPickedUp', function(order) {
console.log("Order",order.orderId,"was picked up");
data.updateOrderDetails(order);
io.emit('orderPickedUp', order );
});
socket.on('driverAssigned', function(order) {
// Track assigned driver by adding driverId to the order
console.log("Order",order.orderId,"was assigned to driver",order.driverId);
data.updateOrderDetails(order);
io.emit('currentQueue', { orders: data.getAllOrders() });
});
socket.on('orderDroppedOff', function (orderId) {
console.log("Order",orderId,"was dropped off");
data.orderDropOff(orderId);
// send updated info to all connected clients, note the use of io instead of socket
io.emit('orderDroppedOff', orderId);
});
});
var server = http.listen(app.get('port'), function () {
console.log('Server listening on port ' + app.get('port'));
});