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

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

Update filenames in code to match dir reorg

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        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            saveCMSMessage(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        saveCMSMessage("|||||");
131    }
132
133    // Save an updated cms message to the file
134    function saveCMSMessage(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        // Check if there was any messages to save and
147        // Set icon to reflect message state
148        if (outMessage == "|||||")
149        {
150            currentIcon = {icon: iconCMSidle};
151        }
152        else
153        {
154            currentIcon = {icon: iconCMSactive};
155        }
156        cmsLayer.overrideStyle(cmsLayer.getFeatureById(cmsID), currentIcon)
157        // break the json string into lines for readability
158        jsonstring = JSON.stringify(Object.values(messageDict)); //Can't use these in GET parameter  ,null,4);
159        outString = "{\"data\":" + jsonstring + "}";
160        console.log("outString = " + outString);
161        var xhttp = new XMLHttpRequest();
162        xhttp.open("GET", "../cgi-bin/saveCMSmessage.py?msg=" + outString, true);
163        xhttp.send();
164        console.log("status code: " + xhttp.status);
165        // Using POST might be a better idea ... haven't tried this yet
166        //      var xhr = new XMLHttpRequest();
167        //      xhr.open("POST", "/cgi-bin/saveCMSmessage.py?", true);
168        //      xhr.setRequestHeader('Content-Type', 'application/json; charset=UTF-8');
169        // send the collected data as JSON
170        //      xhr.send(JSON.stringify(messageList));
171    }
172
173    // retrieve the current cms message file
174    function showMessage(cmsID)
175    {
176        loadAllcmsMessages();  // because someone else may have made a recent update
177        // lookup the message for this cms ID
178        var message = messageDict[cmsID].cms.message;
179        // show the message in the display
180        document.getElementById('msgdisplay1').value = message.phase1.Line1;
181        document.getElementById('msgdisplay2').value = message.phase1.Line2;
182        document.getElementById('msgdisplay3').value = message.phase1.Line3;
183        document.getElementById('msgdisplay4').value = message.phase2.Line1;
184        document.getElementById('msgdisplay5').value = message.phase2.Line2;
185        document.getElementById('msgdisplay6').value = message.phase2.Line3;
186    }
187    function loadAllcmsMessages()
188    {
189        loadJSON("../dynamicdata/cms_messages.json", function(response)
190        {
191            // Parse JSON string into object
192            messagejson = JSON.parse(response);
193            // Add each message to a lookup dictionary
194            for (var i = 0; i < messagejson.data.length; i++)
195            {
196                var item = messagejson.data[i];
197                messageDict[item.cms.index] = item;
198                // Set the appropriate icon on the cms icon
199                // set a yellow flag if there's currently no message
200                if (item.cms.message.phase1.Line1 + 
201                    item.cms.message.phase1.Line2 +
202                    item.cms.message.phase1.Line3 +
203                    item.cms.message.phase2.Line1 + 
204                    item.cms.message.phase2.Line2 +
205                    item.cms.message.phase2.Line3 == "")
206                {
207                    cmsLayer.overrideStyle(cmsLayer.getFeatureById(item.cms.index), {icon: iconCMSidle})
208                }
209                else
210                {
211                    cmsLayer.overrideStyle(cmsLayer.getFeatureById(item.cms.index), {icon: iconCMSactive})
212                }
213            }
214        });
215    }
216
217
Note: See TracBrowser for help on using the repository browser.