From 19ab3a98496380fe5b38d6156a14e9eb3e50fc61 Mon Sep 17 00:00:00 2001 From: Ishan Ajwani Date: Sat, 6 May 2023 19:31:12 -0400 Subject: [PATCH] feat(bus): mark a bus as delayed in afternoon menu closes #1414 feat(bus): option to mark bus as delayed closes #1414 feat(bus): mark a bus as delayed in afternoon menu closes #1414 feat(bus): mark a bus as delayed in afternoon menu closes #1414 feat(bus): option to mark bus as delayed closes #1414 feat(bus): mark a bus as delayed in afternoon menu closes #1414 --- intranet/static/js/bus-afternoon.js | 179 ++++++++++++++++++++-------- 1 file changed, 129 insertions(+), 50 deletions(-) diff --git a/intranet/static/js/bus-afternoon.js b/intranet/static/js/bus-afternoon.js index 0576065f546..7ea118fd2ab 100644 --- a/intranet/static/js/bus-afternoon.js +++ b/intranet/static/js/bus-afternoon.js @@ -3,11 +3,11 @@ import { getSocket } from "./bus-shared.js"; /* globals Messenger */ var bus = {}; -$(function() { +$(function () { let base_url = window.location.host; bus.sendUpdate = function (data) { - //console.log('Sending data:', data); + data.time = "afternoon"; socket.send(JSON.stringify(data)); }; @@ -28,11 +28,11 @@ $(function() { bus.StatusGroupModel = Backbone.Model.extend(); bus.PersonalStatusView = Backbone.View.extend({ - initialize: function() { + initialize: function () { _.bindAll(this, 'render'); this.template = _.template($('#personal-status').html()); }, - render: function() { + render: function () { var container = this.$el, renderedContent = this.template(this.model.toJSON()); container.html(renderedContent); @@ -84,7 +84,7 @@ $(function() { 'text': this.text }; this.$el.html(this.buttonTemplate(data)) - .removeClass('search-widget'); + .removeClass('search-widget'); return this; }, renderSearchView: function (routeList, action) { @@ -95,23 +95,74 @@ $(function() { let busList = []; if (action === 'Search for a bus') { busList = routeList.filter(bus => bus.attributes.status === 'a') - .filter(bus => bus.attributes.route_name.includes('JT')) - .map(bus => bus.attributes); + .filter(bus => bus.attributes.route_name.includes('JT')) + .map(bus => bus.attributes); } else if (action === 'Mark a bus as arrived or on time') { - busList = routeList.filter(bus => !bus.attributes.route_name.includes('JT')) - .map(bus => { - if (bus.attributes.status === 'a') { - // TODO: less hacky deep copy - let attr = JSON.parse(JSON.stringify(bus.attributes)); - attr.route_name = `Mark ${bus.attributes.route_name} as on time`; - return attr; - } else { - return bus.attributes; - } - }); +<<<<<<< HEAD +<<<<<<< HEAD +<<<<<<< HEAD +======= +>>>>>>> 443647ab (feat(bus): option to mark bus as delayed) + busList = routeList.map(bus => { + if ((bus.attributes.status === 'a' || bus.attributes.status === 'd') && !bus.attributes.route_name.includes('JT')) { + let attr = JSON.parse(JSON.stringify(bus.attributes)); + attr.route_name = `Mark ${bus.attributes.route_name} as on time`; + return attr; + } + else if (bus.attributes.status === 'o') { + let attr = JSON.parse(JSON.stringify(bus.attributes)); + let attr2 = JSON.parse(JSON.stringify(bus.attributes)); + if (bus.attributes.route_name.includes('JT')) { + attr.route_name = `Mark ${bus.attributes.route_name} as delayed`; + return attr; + } + attr.route_name = `Mark ${bus.attributes.route_name} as delayed`; + attr2.route_name = `Mark ${bus.attributes.route_name} as arrived`; + return [attr, attr2]; + } else { + if (!bus.attributes.route_name.includes('JT')) { + return bus.attributes; + } + return null; + + } + }).flat().filter((element) => element != null); +======= +<<<<<<< HEAD +======= +>>>>>>> dcacb3b1 (feat(bus): mark a bus as delayed in afternoon menu) +======= +>>>>>>> 443647ab (feat(bus): option to mark bus as delayed) + busList = routeList.filter(bus => bus.attributes.route_name.includes('')) + .map(bus => { + if (bus.attributes.status === 'a' || bus.attributes.status === 'd') { + // TODO: less hacky deep copy + let attr = JSON.parse(JSON.stringify(bus.attributes)); + attr.route_name = `Mark ${bus.attributes.route_name} as on time`; + return attr; + } + //Adds two elements, one for marking delayed one for arrived + //.flat() so that the added array gets convereted to two elements + else if (bus.attributes.status === 'o') { + let attr = JSON.parse(JSON.stringify(bus.attributes)); + let attr2 = JSON.parse(JSON.stringify(bus.attributes)); + attr.route_name = `Mark ${bus.attributes.route_name} as delayed`; + attr2.route_name = `Mark ${bus.attributes.route_name} as arrived`; + return [attr, attr2] + } else { + return bus.attributes; + } + }).flat(); +<<<<<<< HEAD +<<<<<<< HEAD +>>>>>>> dcacb3b1 (feat(bus): mark a bus as delayed in afternoon menu) +======= +======= +>>>>>>> 443647ab (feat(bus): option to mark bus as delayed) +>>>>>>> dcacb3b1 (feat(bus): mark a bus as delayed in afternoon menu) } else if (action === 'Assign a bus to this space') { busList = routeList.filter(bus => bus.attributes.status !== 'a') - .map(bus => bus.attributes); + .map(bus => bus.attributes); } let selectField = container.find('select').selectize({ 'options': busList, @@ -130,15 +181,7 @@ $(function() { ] })[0].selectize; - // Make search input readonly on mobile by default so the keyboard doesn't pop up - // if (window.innerWidth < 768) { - // selectField.$control_input.prop('readonly', true); - // $('.selectize-control').one("focus click", function (){ - // selectField.$control_input.prop('readonly', false); - // // TODO: Auto-focus the input field again and get the virtual keyboard to show up. - // // There doesn't seem to be an easy way to do this. - // }); - // } + selectField.$control_input.prop('pattern', '[0-9]*'); selectField.focus(); @@ -159,24 +202,60 @@ $(function() { if (!this.selected) { return; } - let route = this.model.findWhere({route_name: e.target.value}).attributes; + let route = this.model.findWhere({ route_name: e.target.value }).attributes; route.space = this.selected.id; route.status = 'a'; bus.sendUpdate(route); } else if (this.action === 'Mark a bus as arrived or on time') { let route_name = ''; let st = ''; +<<<<<<< HEAD + if (e.target.value.includes('on')) { + route_name = e.target.value.split(' ')[1]; + +======= // TODO: this is also super hacky // Essentially, this checks if the selected route has "Mark" // at the beginning, implying that it's to be marked on time. - if (e.target.value.indexOf('Mark') === 0) { + if (e.target.value.includes('on time')) { route_name = e.target.value.split(' ')[1]; + alert(route_name); +<<<<<<< HEAD +<<<<<<< HEAD +>>>>>>> dcacb3b1 (feat(bus): mark a bus as delayed in afternoon menu) +======= +======= +>>>>>>> 443647ab (feat(bus): option to mark bus as delayed) +>>>>>>> dcacb3b1 (feat(bus): mark a bus as delayed in afternoon menu) st = 'o'; - } else { + } + else if (e.target.value.includes('delayed')) { + route_name = e.target.value.split(' ')[1]; +<<<<<<< HEAD +<<<<<<< HEAD +<<<<<<< HEAD +======= +>>>>>>> 443647ab (feat(bus): option to mark bus as delayed) + + st = 'd'; + } + else { + route_name = e.target.value.split(' ')[1]; +======= +<<<<<<< HEAD +======= +>>>>>>> dcacb3b1 (feat(bus): mark a bus as delayed in afternoon menu) +======= +>>>>>>> 443647ab (feat(bus): option to mark bus as delayed) + alert(route_name); + st = 'd'; + } + else { route_name = e.target.value; +>>>>>>> dcacb3b1 (feat(bus): mark a bus as delayed in afternoon menu) st = 'a'; } - let route = this.model.findWhere({route_name: route_name}).attributes; + let route = this.model.findWhere({ route_name: route_name }).attributes; route.status = st; bus.sendUpdate(route); } @@ -350,18 +429,18 @@ $(function() { // fallbacks to avoid issues that have appeared in the past with the "sans-serif" default. text.font("family", "Helvetica, Arial, 'Open Sans', 'Liberation Sans', sans-serif"); - if(window.isSignage) { + if (window.isSignage) { var tspan = $(text.node).find("tspan"); - tspan.attr({"x": 0, "dy": 20.5}); + tspan.attr({ "x": 0, "dy": 20.5 }); // If we run this directly, it hasn't rendered yet, so we have to run it after a timeout - setTimeout(function() { + setTimeout(function () { var tbox = tspan.get(0).getBBox(); var sbox = space.getBBox(); var offset; var dimenDiff; - if(tbox.width > tbox.height) { + if (tbox.width > tbox.height) { dimenDiff = sbox.width - tbox.width; offset = tbox.x - sbox.x; } @@ -370,9 +449,9 @@ $(function() { offset = tbox.y - sbox.y; } - if(dimenDiff < offset + 5) { + if (dimenDiff < offset + 5) { text.node.classList.add("small"); - if(route.attributes.route_name.length > 5) { + if (route.attributes.route_name.length > 5) { text.node.classList.add("extra-small"); } } @@ -381,13 +460,13 @@ $(function() { else { var tspan = $(text.node).find("tspan"); - setTimeout(function() { + setTimeout(function () { var tbox = tspan.get(0).getBBox(); var sbox = space.getBBox(); var offset; var dimenDiff; - if(tbox.width > tbox.height) { + if (tbox.width > tbox.height) { dimenDiff = sbox.width - tbox.width; offset = tbox.x - sbox.x; } @@ -395,7 +474,7 @@ $(function() { dimenDiff = sbox.height - tbox.height; offset = tbox.y - sbox.y; } - if(dimenDiff < offset + 5 || route.attributes.route_name.length > 5) { + if (dimenDiff < offset + 5 || route.attributes.route_name.length > 5) { text.node.classList.add("extra-small"); } }, 0); @@ -560,7 +639,7 @@ $(function() { // equatorial radius of Earth = 6,378.1370 km // polar radius of Earth = 6,356.7523 km - // length of 1 deg equatorial longitude + // length of 1 deg equatorial longitude let deg_lng_eq = 6378.1370 * 2 * Math.PI / 360; // length of 1 deg equatorial latitude let deg_lat_eq = 6356.7523 * 2 * Math.PI / 360; @@ -587,7 +666,7 @@ $(function() { }*/ let degrees = (direction) * (180 / Math.PI) - 49 + 90; // let degrees = (direction) * (180 / Math.PI); - this.busDriverEl.css({'transform' : 'rotate('+ degrees +'deg)'}); + this.busDriverEl.css({ 'transform': 'rotate(' + degrees + 'deg)' }); this.mapbox.setCenter(this.busDriverBus.point.coordinates); this.busDriverBus.lastFrame = time; @@ -634,7 +713,7 @@ $(function() { container.empty(); container.append(this.template(this.model.toJSON())); _.each(this.model.attributes.collection, function (route) { - container.append(new bus.RouteView({model: route}).render().el); + container.append(new bus.RouteView({ model: route }).render().el); }); return this; } @@ -699,23 +778,23 @@ $(function() { } }); - if(isAdmin) { - $(".bus-announcement-save").click(function() { + if (isAdmin) { + $(".bus-announcement-save").click(function () { bus.sendUpdate({ announcement: $(".bus-announcement").text() }); $(".bus-announcement-save").text("Saved!").css("color", "green"); - setTimeout(function() { + setTimeout(function () { $(".bus-announcement-save").text("Save").css("color", ""); }, 1500); }); - $(".bus-announcement-clear").click(function() { + $(".bus-announcement-clear").click(function () { $(".bus-announcement").text(""); bus.sendUpdate({ announcement: "", }); $(".bus-announcement-clear").text("Cleared!").css("color", "green"); - setTimeout(function() { + setTimeout(function () { $(".bus-announcement-clear").text("Clear").css("color", ""); }, 1500); }); @@ -740,7 +819,7 @@ $(function() { Backbone.trigger('recordScore', e); }); } -// window.personalStatusView = new bus.personalStatusView(); + // window.personalStatusView = new bus.personalStatusView(); }); /* TODO: flip bus map to be horizontal