source: tmcsimulator/trunk/webapps/cptms/js/cmsLayer.js @ 426

Revision 426, 9.2 KB checked in by jdalbey, 7 years ago (diff)

cmsLayer.js, harLayer.js updated to fix #107.

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            hideElementById('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        // Fix defect #122.   Remove semicolons from input.
93        message = message.replace(/;/gi, ""); 
94        return padding + message;
95    }
96
97    function handleCMSsubmit()
98    {
99        // recover the user's response
100        var response1 = document.getElementById('msgcontent1').value.trim();
101        var response2 = document.getElementById('msgcontent2').value.trim();
102        var response3 = document.getElementById('msgcontent3').value.trim();
103        var response4 = document.getElementById('msgcontent4').value.trim();
104        var response5 = document.getElementById('msgcontent5').value.trim();
105        var response6 = document.getElementById('msgcontent6').value.trim();
106        var newMsg = response1 + response2 + response3 + response4 + response5 + response6;
107        if (newMsg.length == 0)
108        {
109            alert("Nothing to Send ... input fields are empty.");
110        }
111        else
112        {
113            document.getElementById('msgdisplay1').value = justifyCMStext(response1);
114            document.getElementById('msgdisplay2').value = justifyCMStext(response2);
115            document.getElementById('msgdisplay3').value = justifyCMStext(response3);
116            document.getElementById('msgdisplay4').value = justifyCMStext(response4);
117            document.getElementById('msgdisplay5').value = justifyCMStext(response5);
118            document.getElementById('msgdisplay6').value = justifyCMStext(response6);
119            saveCMSMessage(response1 + "|" + response2 + "|" + response3 + "|" +
120                        response4 + "|" + response5 + "|" + response6);
121        }
122    }
123
124    function handleCMSclear()
125    {
126        document.getElementById('msgdisplay1').value = "";
127        document.getElementById('msgdisplay2').value = "";
128        document.getElementById('msgdisplay3').value = "";
129        document.getElementById('msgdisplay4').value = "";
130        document.getElementById('msgdisplay5').value = "";
131        document.getElementById('msgdisplay6').value = "";
132        saveCMSMessage("|||||");
133    }
134
135    // Save an updated cms message to the file
136    function saveCMSMessage(outMessage)
137    {
138        // Fetch cmsID from hidden field where it was put when dialog opened.
139        var cmsID = document.getElementById('cmsID').value;
140        msgParts = outMessage.split("|");
141        CMSmessageDict[cmsID].cms.message.phase1.Line1 = msgParts[0];
142        CMSmessageDict[cmsID].cms.message.phase1.Line2 = msgParts[1];
143        CMSmessageDict[cmsID].cms.message.phase1.Line3 = msgParts[2];
144        CMSmessageDict[cmsID].cms.message.phase2.Line1 = msgParts[3];
145        CMSmessageDict[cmsID].cms.message.phase2.Line2 = msgParts[4];
146        CMSmessageDict[cmsID].cms.message.phase2.Line3 = msgParts[5];
147        // Check if there was any messages to save and
148        // Set icon to reflect message state
149        if (outMessage == "|||||")
150        {
151            currentIcon = {icon: iconCMSidle};
152        }
153        else
154        {
155            currentIcon = {icon: iconCMSactive};
156        }
157        cmsLayer.overrideStyle(cmsLayer.getFeatureById(cmsID), currentIcon);
158        // Examine each message in the dict and convert to json format
159        var lineOut = "";
160        for (var id in CMSmessageDict)
161        {
162            // convert and append to output string
163            lineOut += JSON.stringify(CMSmessageDict[id]) + ',\n';
164        }
165        // remove trailing comma
166        lineOut = lineOut.substring(0,lineOut.length-2);
167        outString = "{\"data\":[\n" + lineOut + "\n]}";
168
169        // Using POST to send the data
170        var xhr = new XMLHttpRequest();
171        xhr.open("POST", "../cgi-bin/saveCMSmessage.py", true);
172        xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded; charset=UTF-8');
173        // send the collected data as JSON
174        xhr.send("msg="+outString);
175    }
176
177    // retrieve the current cms message file
178    function showMessage(cmsID)
179    {
180        loadAllcmsMessages();  // because someone else may have made a recent update
181        // lookup the message for this cms ID
182        var message = CMSmessageDict[cmsID].cms.message;
183        // show the message in the display
184        document.getElementById('msgdisplay1').value = justifyCMStext(message.phase1.Line1);
185        document.getElementById('msgdisplay2').value = justifyCMStext(message.phase1.Line2);
186        document.getElementById('msgdisplay3').value = justifyCMStext(message.phase1.Line3);
187        document.getElementById('msgdisplay4').value = justifyCMStext(message.phase2.Line1);
188        document.getElementById('msgdisplay5').value = justifyCMStext(message.phase2.Line2);
189        document.getElementById('msgdisplay6').value = justifyCMStext(message.phase2.Line3);
190    }
191    function loadAllcmsMessages()
192    {
193        loadJSON("../dynamicdata/cms_messages.json", function(response)
194        {
195            // Parse JSON string into object
196            messagejson = JSON.parse(response);
197            // Add each message to a lookup dictionary
198            for (var i = 0; i < messagejson.data.length; i++)
199            {
200                var item = messagejson.data[i];
201                CMSmessageDict[item.cms.index] = item;
202                // Set the appropriate icon on the cms icon
203                // set a yellow flag if there's currently no message
204                if (item.cms.message.phase1.Line1 + 
205                    item.cms.message.phase1.Line2 +
206                    item.cms.message.phase1.Line3 +
207                    item.cms.message.phase2.Line1 + 
208                    item.cms.message.phase2.Line2 +
209                    item.cms.message.phase2.Line3 == "")
210                {
211                    cmsLayer.overrideStyle(cmsLayer.getFeatureById(item.cms.index), {icon: iconCMSidle})
212                }
213                else
214                {
215                    cmsLayer.overrideStyle(cmsLayer.getFeatureById(item.cms.index), {icon: iconCMSactive})
216                }
217            }
218        });
219    }
220
221
Note: See TracBrowser for help on using the repository browser.