source: tmcsimulator/trunk/webapps/js/cmsLayer.js @ 334

Revision 334, 8.8 KB checked in by jdalbey, 7 years ago (diff)

cptms modify css layout for Chrome

Line 
1function initCMSbutton()
2{
3    var cmsBtnDiv = document.getElementById('cmsButton');
4    map.controls[google.maps.ControlPosition.LEFT_BOTTOM].push(cmsBtnDiv)
5    cmsBtnDiv.title = 'Click to toggle cms view';
6    // Setup the click event listeners to toggle icon display
7    cmsBtnDiv.addEventListener('click', function()
8    {
9        cms_showing = !cms_showing;
10        // Determine which button image to show
11        if (cms_showing)
12        {
13            pic = "images/btnDepressed_CMS.png"
14            // It's nice when icons become visible that the messages have been refreshed.
15            loadAllcmsMessages();
16        }
17        else
18        {
19            pic = "images/btnReady_CMS.png"
20        }
21        document.getElementById('cmsBtnImg').src = pic;
22        // reveal or hide all the icons
23        cmsLayer.forEach(function(feature)
24        {
25            cmsLayer.overrideStyle(feature,
26            {
27                visible: cms_showing
28            });
29        });
30    });
31}
32function loadCMSlayer()
33{
34    cmsLayer = new google.maps.Data();
35    cmsLayer.setMap(map);
36    cmsLayer.loadGeoJson(kCMSfile); 
37    cmsLayer.setStyle(function(feature)
38    {
39        // return the StyleOptions
40        return {
41            icon: iconCMSidle,
42            title: feature.getId()+ " " +feature.getProperty("location")+ " " 
43                    + feature.getProperty("street"),
44            visible: false
45        };
46    });
47   
48    cmsLayer.addListener('click', function(event)
49    {
50        var dialog = document.getElementById('cms-dialog');
51        // Note: If the dialog is already being displayed when someone else
52        // updates the message, it won't be reflected in the dialog, until
53        // you close and reopen it.
54        dialog.style.display = 'block';
55        cmsID = event.feature.getId();
56        // Assign to the hidden field
57        document.getElementById('cmsID').value = cmsID;
58        showMessage(cmsID); // note: this is async
59        document.getElementById('cms-info-label').innerHTML = "CMS ID: " +
60            cmsID + "   LOCATION: " + event.feature.getProperty("location")
61            + "  " + event.feature.getProperty("street");
62        // clear input fields
63        document.getElementById('msgcontent1').value = "";
64        document.getElementById('msgcontent2').value = "";
65        document.getElementById('msgcontent3').value = "";
66        document.getElementById('msgcontent4').value = "";
67        document.getElementById('msgcontent5').value = "";
68        document.getElementById('msgcontent6').value = "";
69        document.getElementById('msgcontent1').focus();
70        var span = document.getElementById("cms-close");
71            // When the user clicks on <span> (x), close the modal
72        span.onclick = function()
73        {
74            handleDialogClose('cms-dialog');
75        }
76    });
77}
78
79    // Center justify message text in a 16 column field
80    function justifyCMStext(message)
81    {
82        // don't bother justifying a blank message
83        if (message.length == 0) return message;   
84        // determine how much padding is needed
85        var kBlanks = "                ";
86        var padLen = (16 - message.length) / 2;
87        // apply the padding
88        var padding = kBlanks.substring(0, padLen);
89        return padding + message;
90    }
91
92    function handleCMSsubmit()
93    {
94        // recover the user's response
95        var response1 = justifyCMStext(document.getElementById('msgcontent1').value.trim());
96        var response2 = justifyCMStext(document.getElementById('msgcontent2').value.trim());
97        var response3 = justifyCMStext(document.getElementById('msgcontent3').value.trim());
98        var response4 = justifyCMStext(document.getElementById('msgcontent4').value.trim());
99        var response5 = justifyCMStext(document.getElementById('msgcontent5').value.trim());
100        var response6 = justifyCMStext(document.getElementById('msgcontent6').value.trim());
101        var newMsg = response1 + response2 + response3 + response4 + response5 + response6;
102        if (newMsg.length == 0)
103        {
104            alert("Nothing to Send ... input fields are empty.");
105        }
106        else
107        {
108            document.getElementById('msgdisplay1').value = response1;
109            document.getElementById('msgdisplay2').value = response2;
110            document.getElementById('msgdisplay3').value = response3;
111            document.getElementById('msgdisplay4').value = response4;
112            document.getElementById('msgdisplay5').value = response5;
113            document.getElementById('msgdisplay6').value = response6;
114            saveMessage(response1 + "|" + response2 + "|" + response3 + "|" +
115                        response4 + "|" + response5 + "|" + response6);
116        }
117    }
118
119    function handleCMSclear()
120    {
121        document.getElementById('msgdisplay1').value = "";
122        document.getElementById('msgdisplay2').value = "";
123        document.getElementById('msgdisplay3').value = "";
124        document.getElementById('msgdisplay4').value = "";
125        document.getElementById('msgdisplay5').value = "";
126        document.getElementById('msgdisplay6').value = "";
127        saveMessage("|||||");
128    }
129
130    // Save an updated cms message to the file
131    function saveMessage(outMessage)
132    {
133        // Fetch cmsID from hidden field where it was put when dialog opened.
134        var cmsID = document.getElementById('cmsID').value;
135        //console.log("Saving " + outMessage + " for cmsID " + cmsID)
136        msgParts = outMessage.split("|");
137        messageDict[cmsID].cms.message.phase1.Line1 = msgParts[0];
138        messageDict[cmsID].cms.message.phase1.Line2 = msgParts[1];
139        messageDict[cmsID].cms.message.phase1.Line3 = msgParts[2];
140        messageDict[cmsID].cms.message.phase2.Line1 = msgParts[3];
141        messageDict[cmsID].cms.message.phase2.Line2 = msgParts[4];
142        messageDict[cmsID].cms.message.phase2.Line3 = msgParts[5];
143        // Set icon to reflect message state
144        if (outMessage == "|||||")
145        {
146            currentIcon = {icon: iconCMSidle};
147        }
148        else
149        {
150            currentIcon = {icon: iconCMSactive};
151        }
152        cmsLayer.overrideStyle(cmsLayer.getFeatureById(cmsID), currentIcon)
153        // break the json string into lines for readability
154        jsonstring = JSON.stringify(Object.values(messageDict)); //,null,4);
155        outString = "{\"data\":" + jsonstring + "}";
156
157        var xhttp = new XMLHttpRequest();
158        xhttp.open("GET", "cgi-bin/saveCMSmessage.py?msg=" + outString, true);
159        xhttp.send();
160        // Using POST might be a better idea ... haven't tried this yet
161        //      var xhr = new XMLHttpRequest();
162        //      xhr.open("POST", "/cgi-bin/saveMessage.py?", true);
163        //      xhr.setRequestHeader('Content-Type', 'application/json; charset=UTF-8');
164        // send the collected data as JSON
165        //      xhr.send(JSON.stringify(messageList));
166    }
167
168    // retrieve the current cms message file
169    function showMessage(cmsID)
170    {
171        loadAllcmsMessages();  // because someone else may have made a recent update
172        // lookup the message for this cms ID
173        var message = messageDict[cmsID].cms.message;
174        // show the message in the display
175        document.getElementById('msgdisplay1').value = message.phase1.Line1;
176        document.getElementById('msgdisplay2').value = message.phase1.Line2;
177        document.getElementById('msgdisplay3').value = message.phase1.Line3;
178        document.getElementById('msgdisplay4').value = message.phase2.Line1;
179        document.getElementById('msgdisplay5').value = message.phase2.Line2;
180        document.getElementById('msgdisplay6').value = message.phase2.Line3;
181    }
182    function loadAllcmsMessages()
183    {
184        loadJSON("cms_messages.json", function(response)
185        {
186            // Parse JSON string into object
187            messagejson = JSON.parse(response);
188            // Add each message to a lookup dictionary
189            for (var i = 0; i < messagejson.data.length; i++)
190            {
191                var item = messagejson.data[i];
192                messageDict[item.cms.index] = item;
193                // Set the appropriate icon on the cms icon
194                // set a yellow flag if there's currently no message
195                if (item.cms.message.phase1.Line1 + 
196                    item.cms.message.phase1.Line2 +
197                    item.cms.message.phase1.Line3 +
198                    item.cms.message.phase2.Line1 + 
199                    item.cms.message.phase2.Line2 +
200                    item.cms.message.phase2.Line3 == "")
201                {
202                    cmsLayer.overrideStyle(cmsLayer.getFeatureById(item.cms.index), {icon: iconCMSidle})
203                }
204                else
205                {
206                    cmsLayer.overrideStyle(cmsLayer.getFeatureById(item.cms.index), {icon: iconCMSactive})
207                }
208            }
209        });
210    }
211
212
Note: See TracBrowser for help on using the repository browser.