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

Revision 335, 9.0 KB checked in by jdalbey, 7 years ago (diff)

Define clickable region for CMS and CCTV icons.

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