Warning: Can't use blame annotator:
svn blame failed on trunk/webapps/cptms/js/cmsLayer.js: ("Can't find a temporary directory: Internal error", 20014)

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

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

cmsLayer.js,harLayer.js modified to use POST requests

RevLine 
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 = justifyCMStext(document.getElementById('msgcontent1').value.trim());
101        var response2 = justifyCMStext(document.getElementById('msgcontent2').value.trim());
102        var response3 = justifyCMStext(document.getElementById('msgcontent3').value.trim());
103        var response4 = justifyCMStext(document.getElementById('msgcontent4').value.trim());
104        var response5 = justifyCMStext(document.getElementById('msgcontent5').value.trim());
105        var response6 = justifyCMStext(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 = response1;
114            document.getElementById('msgdisplay2').value = response2;
115            document.getElementById('msgdisplay3').value = response3;
116            document.getElementById('msgdisplay4').value = response4;
117            document.getElementById('msgdisplay5').value = response5;
118            document.getElementById('msgdisplay6').value = 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        messageDict[cmsID].cms.message.phase1.Line1 = msgParts[0];
142        messageDict[cmsID].cms.message.phase1.Line2 = msgParts[1];
143        messageDict[cmsID].cms.message.phase1.Line3 = msgParts[2];
144        messageDict[cmsID].cms.message.phase2.Line1 = msgParts[3];
145        messageDict[cmsID].cms.message.phase2.Line2 = msgParts[4];
146        messageDict[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        // break the json string into lines for readability
159        jsonstring = JSON.stringify(Object.values(messageDict)); //Can't use these in GET parameter  ,null,4);
160        outString = "{\"data\":" + jsonstring + "}";
161        //console.log("outString = " + outString);
162        //var xhttp = new XMLHttpRequest();
163        //xhttp.open("GET", "../cgi-bin/saveCMSmessage.py?msg=" + outString, true);
164        //xhttp.send();
165        //console.log("status code: " + xhttp.status);
166        // Using POST to send the data
167        var xhr = new XMLHttpRequest();
168        xhr.open("POST", "../cgi-bin/saveCMSmessage.py", true);
169        xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded; charset=UTF-8');
170        // send the collected data as JSON
171        xhr.send("msg="+outString);
172    }
173
174    // retrieve the current cms message file
175    function showMessage(cmsID)
176    {
177        loadAllcmsMessages();  // because someone else may have made a recent update
178        // lookup the message for this cms ID
179        var message = messageDict[cmsID].cms.message;
180        // show the message in the display
181        document.getElementById('msgdisplay1').value = message.phase1.Line1;
182        document.getElementById('msgdisplay2').value = message.phase1.Line2;
183        document.getElementById('msgdisplay3').value = message.phase1.Line3;
184        document.getElementById('msgdisplay4').value = message.phase2.Line1;
185        document.getElementById('msgdisplay5').value = message.phase2.Line2;
186        document.getElementById('msgdisplay6').value = message.phase2.Line3;
187    }
188    function loadAllcmsMessages()
189    {
190        loadJSON("../dynamicdata/cms_messages.json", function(response)
191        {
192            // Parse JSON string into object
193            messagejson = JSON.parse(response);
194            // Add each message to a lookup dictionary
195            for (var i = 0; i < messagejson.data.length; i++)
196            {
197                var item = messagejson.data[i];
198                messageDict[item.cms.index] = item;
199                // Set the appropriate icon on the cms icon
200                // set a yellow flag if there's currently no message
201                if (item.cms.message.phase1.Line1 + 
202                    item.cms.message.phase1.Line2 +
203                    item.cms.message.phase1.Line3 +
204                    item.cms.message.phase2.Line1 + 
205                    item.cms.message.phase2.Line2 +
206                    item.cms.message.phase2.Line3 == "")
207                {
208                    cmsLayer.overrideStyle(cmsLayer.getFeatureById(item.cms.index), {icon: iconCMSidle})
209                }
210                else
211                {
212                    cmsLayer.overrideStyle(cmsLayer.getFeatureById(item.cms.index), {icon: iconCMSactive})
213                }
214            }
215        });
216    }
217
218
Note: See TracBrowser for help on using the repository browser.