// ==UserScript==
// @name WME Form Filler
// @description Use info from WME to automatically fill out related forms
// @namespace https://greasyfork.org/users/6605
// @version 1.3.8.1
// @homepage https://github.com/WazeDev/WME-Form-Filler
// @supportURL https://github.com/WazeDev/WME-Form-Filler/issues
// @include https://www.waze.com/editor
// @include /^https:\/\/(www|beta)\.waze\.com\/(?!user\/)(.{2,6}\/)?editor.*$/
// @author crazycaveman
// @license MIT
// @run-at document-end
// @icon 
// @grant none
// ==/UserScript==
/*****************
To-Do:
*Allow manual user entries
*Update closure date to number of days to close
******************/
(function()
{
"use strict";
var WMEFFName = GM_info.script.name;
var WMEFFVersion = GM_info.script.version;
var WMEFFIcon = "";
var forms = {};
function formfiller_bootstrap()
{
formfiller_log("Running bootstrap");
if (typeof W.app === "undefined" || !window.W.map)
{
setTimeout(formfiller_bootstrap,500);
return;
}
formfiller_log("Starting init");
formfiller_init();
}
function formfiller_init()
{
// Check document elements are ready
var userInfo = document.getElementById("user-info");
if (userInfo === null)
{
window.setTimeout(formfiller_init,500);
return;
}
var userTabs = document.getElementById("user-tabs");
if (userTabs === null)
{
window.setTimeout(formfiller_init,500);
return;
}
var navTab = userInfo.getElementsByTagName("ul");
if (navTab.length === 0)
{
window.setTimeout(formfiller_init,500);
return;
}
if (typeof navTab[0] === "undefined")
{
window.setTimeout(formfiller_init,500);
return;
}
var tabContent = userInfo.getElementsByTagName("div");
if (tabContent.length === 0)
{
window.setTimeout(formfiller_init,500);
return;
}
if (typeof tabContent[0] === "undefined")
{
window.setTimeout(formfiller_init,500);
return;
}
ff_addUserTab();
ff_addFormBtn();
var formFillerObserver = new MutationObserver(function(mutations) {
mutations.forEach(function(mutation) {
// Mutation is a NodeList and doesn't support forEach like an array
for (var i = 0; i < mutation.addedNodes.length; i+=1) {
var addedNode = mutation.addedNodes[i];
// Only fire up if it's a node
if (addedNode.nodeType === Node.ELEMENT_NODE) {
var selectionDiv = addedNode.querySelector("div.selection");
if (selectionDiv) {
ff_addFormBtn();
}
}
}
});
});
formFillerObserver.observe(document.getElementById("edit-panel"), { childList: true, subtree: true });
//W.selectionManager.events.register("selectionchanged", null, ff_addFormBtn);
if (W.app.modeController) {
W.app.modeController.model.bind("change:mode", function(model, modeId) {
if (modeId === 0) {
ff_addUserTab();
}
});
}
formfiller_log("Init done");
return;
}
//Shamelessly copied from https://gist.github.com/CalebGrove/c285a9510948b633aa47
function abbrState(input, to)
{
var states = [
["ARIZONA", "AZ"],
["ALABAMA", "AL"],
["ALASKA", "AK"],
["ARIZONA", "AZ"],
["ARKANSAS", "AR"],
["CALIFORNIA", "CA"],
["COLORADO", "CO"],
["CONNECTICUT", "CT"],
["DELAWARE", "DE"],
["FLORIDA", "FL"],
["GEORGIA", "GA"],
["HAWAII", "HI"],
["IDAHO", "ID"],
["ILLINOIS", "IL"],
["INDIANA", "IN"],
["IOWA", "IA"],
["KANSAS", "KS"],
["KENTUCKY", "KY"],
["KENTUCKY", "KY"],
["LOUISIANA", "LA"],
["MAINE", "ME"],
["MARYLAND", "MD"],
["MASSACHUSETTS", "MA"],
["MICHIGAN", "MI"],
["MINNESOTA", "MN"],
["MISSISSIPPI", "MS"],
["MISSOURI", "MO"],
["MONTANA", "MT"],
["NEBRASKA", "NE"],
["NEVADA", "NV"],
["NEW HAMPSHIRE", "NH"],
["NEW JERSEY", "NJ"],
["NEW MEXICO", "NM"],
["NEW YORK", "NY"],
["NORTH CAROLINA", "NC"],
["NORTH DAKOTA", "ND"],
["OHIO", "OH"],
["OKLAHOMA", "OK"],
["OREGON", "OR"],
["PENNSYLVANIA", "PA"],
["RHODE ISLAND", "RI"],
["SOUTH CAROLINA", "SC"],
["SOUTH DAKOTA", "SD"],
["TENNESSEE", "TN"],
["TEXAS", "TX"],
["UTAH", "UT"],
["VERMONT", "VT"],
["VIRGINIA", "VA"],
["WASHINGTON", "WA"],
["WEST VIRGINIA", "WV"],
["WISCONSIN", "WI"],
["WYOMING", "WY"],
["PUERTO RICO", "PR"],
["VIRGIN ISLANDS (U.S.)", "VI"]
];
var i;
if (to == "abbr"){
input = input.toUpperCase();
for(i = 0; i < states.length; i+=1){
if(states[i][0] == input){
return(states[i][1]);
}
}
} else if (to == "name"){
input = input.toUpperCase();
for(i = 0; i < states.length; i+=1){
if(states[i][1] == input){
return(states[i][0]);
}
}
}
}
function formfiller_log(message)
{
if (typeof message === "string")
console.log("FormFiller: " + message);
else
console.log("FormFiller: ", message);
}
function ff_getStreetName(sel)
{
var streetName = "", i;
for (i=0; i<sel.length; i+=1)
{
var newStreet = W.model.streets.get(sel[i].model.attributes.primaryStreetID);
if (typeof newStreet === "undefined" || newStreet.name === null)
newStreet = "No Name";
if (streetName === "")
streetName = newStreet.name;
else if (streetName != newStreet.name)
streetName += ", "+newStreet.name;
}
return streetName;
}
function ff_getState(sel)
{
var stateName = "", i;
for (i=0; i<sel.length; i+=1)
{
var cID = W.model.streets.get(sel[i].model.attributes.primaryStreetID).cityID;
var sID = W.model.cities.get(cID).attributes.stateID;
var newState = W.model.states.get(sID).name;
if (newState === "")
{
sID = W.model.cities.get(cID).attributes.countryID;
newState = W.model.countries.get(sID).name;
formfiller_log("cID: "+cID);
formfiller_log("sID: "+sID);
formfiller_log("newState: "+newState);
}
if (stateName === "")
stateName = newState;
else if (stateName != newState)
{
stateName = "";
break;
}
}
return stateName;
}
function ff_getCity(sel)
{
var cityName = "", i;
for (i=0; i<sel.length; i+=1)
{
var cID = W.model.streets.get(sel[i].model.attributes.primaryStreetID).cityID;
var newCity = W.model.cities.get(cID).attributes.name;
if (cityName === "")
cityName = newCity;
else if (cityName != newCity)
{
cityName = "";
break;
}
}
return cityName;
}
function ff_getCounty(sel)
{
var county = "";
var center = W.map.center.clone().transform(W.map.projection.projCode,W.map.displayProjection.projCode);
//formfiller_log("Getting county for "+center.lat.toString()+","+center.lon.toString());
var xhr = new XMLHttpRequest();
xhr.open("GET","https://maps.googleapis.com/maps/api/geocode/json?latlng="+center.lat+","+center.lon,false);
xhr.onload = function () {
if (xhr.readyState === 4) {
if (xhr.status === 200) {
var response = JSON.parse(xhr.responseText);
var addrComps = response.results[0].address_components;
var comp;
for (comp = 0; comp < addrComps.length; comp+=1)
{
if (addrComps[comp].types.indexOf("administrative_area_level_2") !== -1)
{
county = addrComps[comp].long_name;
//formfiller_log("ff_getCounty: "+county);
var countyIndex = (county.indexOf(" County") !== -1 ? county.indexOf(" County") : county.indexOf(" Parish"));
if (countyIndex !== -1)
county = county.slice(0,countyIndex);
break;
}
}
}
}
};
xhr.send(null);
return county;
//Async call. Figure this out!
/*return $.getJSON("https://maps.googleapis.com/maps/api/geocode/json?latlng="+center.lat+","+center.lon, function(data) {
if (data.status === "OK")
{
var addrComps = data.results[0].address_components;
for (comp = 0; comp < addrComps.length; comp+=1)
{
if (addrComps[comp].types.indexOf("administrative_area_level_2") !== -1)
{
county = addrComps[comp].long_name;
county = county.slice(0,county.indexOf(" County"));
formfiller_log("JSON func "+county);
break;
}
}
}
if (county === "")
county = "Not found";
formfiller_log("Got county");
formfiller_log(county);
return county;
});*/
}
function ff_closureActive(sel)
{
var i;
for (i=0; i<sel.length; i+=1)
{
if (sel[i].model.hasClosures())
if (W.model.roadClosures.getByAttributes({segID: sel[i].model.attributes.id})[0].active)
return true;
}
return false;
}
function ff_getClosureInfo(seg)
{
var closureInfo = {
direction: "",
endDate: "",
idFwd: "",
idRev: "",
reason: ""
};
var segID = seg.model.attributes.id;
var closureList = W.model.roadClosures.getByAttributes({segID: segID,active: true});
var i;
for (i=0; i<closureList.length; i+=1)
{
if (closureList[i].active === true)
{
if (closureInfo.endDate === "")
{
closureInfo.endDate = closureList[i].endDate;
}
else if (closureInfo.endDate > closureList[i].endDate)
{
closureInfo.endDate = closureList[i].endDate;
}
if (closureList[i].forward === true)
{
closureInfo.idFwd = closureList[i].id;
}
else
{
closureInfo.idRev = closureList[i].id;
}
if (closureInfo.reason === "")
{
closureInfo.reason = closureList[i].reason;
}
}
}
if (closureInfo.idFwd !== "" && closureInfo.idRev !== "")
closureInfo.direction = "Two-Way";
else
closureInfo.direction = "One-Way";
return closureInfo;
}
function ff_createPermalink(selection)
{
//https://www.waze.com/editor/?env=usa&lon=-79.79248&lat=32.86150&layers=12709&zoom=5&mode=0&mapProblemFilter=1&mapUpdateRequestFilter=0&venueFilter=0&segments=504534141
//https://www.waze.com/editor/?env=usa&lon=-79.79248&lat=32.86150&layers=12709&zoom=5&mode=0&mapProblemFilter=1&mapUpdateRequestFilter=0&venueFilter=0&venues=183632201.1836387542.3102948
var permalink = "https://www.waze.com/editor/?", segIDs = [];
var latLon = W.map.center.clone().transform(W.map.projection.projCode,W.map.displayProjection.projCode);
var lat = latLon.lat,
lon = latLon.lon;
var env = W.location.code;
var type = "segments";
var zoom = W.map.zoom;
var zoomToRoadType = W.Config.segments.zoomToRoadType;
var i;
//To get lat and long centered on segment
if (selection.length == 1)
{
latLon = selection[0].model.getCenter().clone();
latLon.transform(W.map.projection.projCode,W.map.displayProjection.projCode);
lat = latLon.y;
lon = latLon.x;
}
for (i=0; i<selection.length; i+=1)
{
var segment = selection[i].model;
if (segment.type != "segment")
continue;
segIDs.push(segment.attributes.id);
if (zoomToRoadType[zoom] !== -1 && zoomToRoadType[zoom].indexOf(segment.attributes.roadType) === -1)
{
alert("This zoom level ("+ zoom.toString() +") cannot be used for this road type! Please increase your zoom:\n"+
"Streets: 4+\nOther drivable and Non-drivable: 3+\nHighways and PS: 2+");
formfiller_log("Zoom level not correct for segment: "+ zoom.toString() +" "+ segment.attributes.roadType.toString());
return;
}
}
permalink += "env="+env+"&lon="+lon+"&lat="+lat+"&zoom="+zoom.toString()+"&"+type+"="+segIDs.join();
return permalink;
}
function ff_createFormLink(formIndx)
{
var selection = W.selectionManager.selectedItems;
var formInfo = {};
var formDt = forms[formIndx];
var formLink = formDt.url;
if (selection.length === 0 || selection[0].model.type != "segment")
{
formfiller_log("No segments selected.");
return;
}
formInfo.username = W.loginManager.user.userName;
formInfo.streetname = ff_getStreetName(selection);
formInfo.permalink = ff_createPermalink(selection);
if (formInfo.permalink === "undefined")
{
formfiller_log("No permalink generated");
return;
}
if (formDt.hasOwnProperty("stateabbr"))
{
formInfo.stateabbr = abbrState(ff_getState(selection),"abbr"); //Abbreviation
} else if (formDt.hasOwnProperty("state"))
{
formInfo.state = ff_getState(selection);
}
formInfo.county = ff_getCounty(selection);
if (formDt.hasOwnProperty("city"))
{
formInfo.city = ff_getCity(selection);
}
if (ff_closureActive(selection))
{
formInfo.status = "CLOSED";
var closureInfo = ff_getClosureInfo(selection[0]);
formInfo.direction = closureInfo.direction;
formInfo.reason = closureInfo.reason;
formInfo.endDate = closureInfo.endDate;
} else {
formInfo.status = "REPORTED";
formInfo.direction = "Two-Way";
formInfo.reason = document.getElementById("ff-closure-reason").value;
formInfo.endDate = document.getElementById("ff-closure-endDate").value +"+"+ document.getElementById("ff-closure-endTime").value;
}
formInfo.notes = "Form filled by "+WMEFFName+" v"+WMEFFVersion;
formLink += "?entry.";
var formArgs = [];
/*for (var key in formDt)
{
if (formDt[key].hasOwnProperty() && formInfo[key] !== undefined && formInfo[key] !== null)
{
formArgs[i] = formDt[key] +"="+ encodeURIComponent(formInfo[key]);
i+=1;
}
}*/
Object.keys(formDt).forEach(function(key,index) {
if (formInfo[key] !== undefined && formInfo[key] !== null)
{
formArgs[index] = formDt[key] +"="+ encodeURIComponent(formInfo[key]);
}
});
formLink += formArgs.join("&entry.");
/*
//Need to do this part better, works for now
formLink += "?entry."+formDt.username+"="+formInfo.username;
formLink += "&entry."+formDt.streetname+"="+formInfo.streetname;
formLink += "&entry."+formDt.permalink+"="+formInfo.permalink;
if (formDt.hasOwnProperty("stateabbr"))
{
formInfo.state = abbrState(ff_getState(selection),"abbr"); //Abbreviation
formLink += "&entry."+formDt.state+"="+formInfo.state;
} else if (formDt.hasOwnProperty("state"))
{
formInfo.state = ff_getState(selection);
formLink += "&entry."+formDt.state+"="+formInfo.state;
}
if (formDt.hasOwnProperty("city"))
{
formInfo.city = encodeURIComponent(ff_getCity(selection));
formLink += "&entry."+formDt.city+"="+formInfo.city;
}
formLink += "&entry."+formDt.county+"="+formInfo.county;
formLink += "&entry."+formDt.status+"="+formInfo.status;
formLink += "&entry."+formDt.direction+"="+formInfo.direction;
formLink += "&entry."+formDt.reason+"="+formInfo.reason;
formLink += "&entry."+formDt.endDate+"="+formInfo.endDate;
formLink += "&entry."+formDt.notes+"="+formInfo.notes;*/
formfiller_log(formLink);
return formLink;
}
function ff_addFormBtn()
{
var selection = W.selectionManager.selectedItems;
var ffDiv = document.createElement("div"),
ffMnu = document.createElement("select"),
ffBtn = document.createElement("button");
var formWindowName = "WME Form Filler result",
formWindowSpecs = "resizable=1,menubar=0,scrollbars=1,status=0,toolbar=0";
var editPanel, selElem, formLink;
ffDiv.id = "formfillerDiv";
editPanel = document.getElementById("edit-panel");
selElem = editPanel.getElementsByClassName("selection");
if (selection.length === 0 || selection[0].model.type != "segment")
{
//formfiller_log("No segments selected.");
return;
}
if (document.getElementById("formfillerDiv"))
{
//formfiller_log("Div already created");
return;
}
forms = [
{
//https://docs.google.com/forms/d/e/1FAIpQLSduBiLMhbg6nRpsEVCTcVbV4eWmHDXdIKGtuaOvzy6NZLbSgw/viewform?entry.1553765347=username&entry.1264424583=CLOSED&entry.1811077109=permalink&entry.792657790=Two-Way&entry.345142186=reason&entry.1102521735=2016-09-20+03:00&entry.2015424420=street+name&entry.1547375393=from+street&entry.1335391716=to+street&entry.1867193205=SC&entry.1714138473=county&entry.1803937317=source&entry.1648634142=notes
name: "USA VEOC closures",
url: "https://docs.google.com/forms/d/e/1FAIpQLSduBiLMhbg6nRpsEVCTcVbV4eWmHDXdIKGtuaOvzy6NZLbSgw/viewform",
username: "1553765347",
status: "1264424583",
permalink: "1811077109",
direction: "792657790",
reason: "345142186",
endDate: "1102521735",
streetname: "2015424420",
fromStreet: "1547375393",
toStreet: "1335391716",
stateabbr: "1867193205",
county: "1714138473",
source: "1803937317",
notes: "1648634142",
},
{
//https://docs.google.com/forms/d/e/1FAIpQLSff7nsBw8qxCojBdxrjTPl6tercqyyzGy92Vif_SBdHkYDchw/viewform?entry.1204781462=Reporter&entry.828228572=Reported&entry.1647952662=Street+name+&entry.1501712688=From+street+&entry.2094306654=To+street+&entry.1414240321=Two-Way&entry.900957975=10/27/2016+00:00&entry.1051351191=Adams&entry.1093044522=City+&entry.1540676081=IDOT&entry.430378754=Reason+&entry.1754051160=Permalink+&entry.172235277=Source+&entry.1722909714=Notes+
name: "Illinois event/weather closures",
url: "https://docs.google.com/forms/d/e/1FAIpQLSff7nsBw8qxCojBdxrjTPl6tercqyyzGy92Vif_SBdHkYDchw/viewform",
username: "1204781462",
status: "828228572",
permalink: "1754051160",
direction: "1414240321",
reason: "430378754",
endDate: "900957975",
streetname: "1647952662",
fromStreet: "1501712688",
toStreet: "2094306654",
county: "1051351191",
city: "1093044522",
source: "172235277",
notes: "1722909714",
},
{
//https://docs.google.com/forms/d/e/1FAIpQLSeiKY0KsO0xN69Asw77MARQFmxOy6zQXF-k2OQdWOfwtiCp7Q/viewform?entry.1204781462=ojlaw&entry.828228572=CLOSED&entry.1647952662=Test1&entry.1501712688=Test2&entry.2094306654=Test3&entry.1414240321=One-Way&entry.900957975=00/00/0000+00:00&entry.1051351191=Adams&entry.1093044522=Test4&entry.1540676081=City&entry.430378754=Test5&entry.1754051160=Test6&entry.172235277=Test7&entry.1722909714=Test8
name: "Wisconsin event/weather closures",
url: "https://docs.google.com/forms/d/e/1FAIpQLSeiKY0KsO0xN69Asw77MARQFmxOy6zQXF-k2OQdWOfwtiCp7Q/viewform",
username: "1204781462",
status: "828228572",
permalink: "1754051160",
direction: "1414240321",
reason: "430378754",
endDate: "900957975",
streetname: "1647952662",
fromStreet: "1501712688",
toStreet: "2094306654",
county: "1051351191",
city: "1093044522",
source: "172235277",
notes: "1722909714",
},
{
name: "US Jane TTS Pronunciation",
url: "https://docs.google.com/forms/d/e/1FAIpQLSeuCmC0zy7GEQDJQP5R8dndxYhXCkqzadrPgP89BvatVl1bdg/viewform",
username: "324217272",
state: "1065619417",
issue: "1086951221",
streetname: "1163516948",
incorrectp: "1191620241",
correctp: "1649051316",
permalink: "2028167849",
instructions: "2120232339",
comments: "1917392591" //In comments
}
/*{
//https://docs.google.com/forms/d/e/1FAIpQLScY_5WKyYTqvH1fdiBThqLO4DRIzFzgdBtBexw5-iKL_LOzBw/viewform?entry.1553765347=username&entry.1264424583=CLOSED&entry.1811077109=permalink&entry.792657790=Two-Way&entry.345142186=reason&entry.1102521735=2016-09-20+03:00&entry.2015424420=street+name&entry.1547375393=from+street&entry.1335391716=to+street&entry.1867193205=SC&entry.1714138473=county&entry.1803937317=source&entry.1648634142=notes
name: "USA Weather related closures",
url: "https://docs.google.com/forms/d/e/1FAIpQLScY_5WKyYTqvH1fdiBThqLO4DRIzFzgdBtBexw5-iKL_LOzBw/viewform",
username: "1553765347",
status: "1264424583",
permalink: "1811077109",
direction: "792657790",
reason: "345142186",
endDate: "1102521735",
streetname: "2015424420",
fromStreet: "1547375393",
toStreet: "1335391716",
state: "1867193205",
county: "1714138473",
source: "1803937317",
notes: "1648634142",
}*/
];
forms.forEach(function(key, i){
ffMnu.options.add(new Option(forms[i].name,i));
});
ffBtn.innerHTML = "Go to Form";
ffBtn.onclick = function()
{
//alert(ffMnu.options[ffMnu.selectedIndex].value+": "+forms[ffMnu.options[ffMnu.selectedIndex].value].name);
ff_saveSettings();
formLink = ff_createFormLink(ffMnu.options[ffMnu.selectedIndex].value);
if (typeof formLink === "undefined")
return;
if ($("#ff-open-in-tab").prop("checked"))
window.open(formLink,"_blank");
else
window.open(formLink,formWindowName,formWindowSpecs);
};
ffDiv.appendChild(ffMnu);
ffDiv.appendChild(ffBtn);
selElem[0].appendChild(ffDiv);
return;
}
function ff_loadSettings()
{
var todayDate = new Date(),
futureDate = new Date(),
daysInFuture = 3;
var today = todayDate.getFullYear() +"-"+ (todayDate.getMonth()+1<10 ? "0"+(todayDate.getMonth()+1) : todayDate.getMonth()+1) +"-"+ todayDate.getDate();
futureDate.setDate(futureDate.getDate() + daysInFuture);
var ffOpenInTab = localStorage.getItem("ff-open-in-tab");
if (ffOpenInTab === "1")
$("#ff-open-in-tab").trigger("click");
var ffClosureReason = localStorage.getItem("ff-closure-reason");
if (ffClosureReason !== null)
$("#ff-closure-reason").val(ffClosureReason);
var ffClosureEndDate = localStorage.getItem("ff-closure-endDate");
if (ffClosureEndDate !== null && ffClosureEndDate !== "" && ffClosureEndDate >= today)
$("#ff-closure-endDate").val(ffClosureEndDate);
else
{
var closureDate = futureDate.getFullYear() +"-"+ (futureDate.getMonth()+1<10 ? "0"+(futureDate.getMonth()+1) : futureDate.getMonth()+1) +"-"+ (futureDate.getDate() < 10 ? "0"+futureDate.getDate() : futureDate.getDate());
$("#ff-closure-endDate").val(closureDate);
}
var ffClosureEndTime = localStorage.getItem("ff-closure-endTime");
if (ffClosureEndTime !== null && ffClosureEndTime !== "")
$("#ff-closure-endTime").val(ffClosureEndTime);
//formfiller_log("Settings loaded");
return;
}
function ff_saveSettings()
{
if ($("#ff-open-in-tab").prop("checked"))
localStorage.setItem("ff-open-in-tab", "1");
else
localStorage.setItem("ff-open-in-tab", "0");
localStorage.setItem("ff-closure-reason", $("#ff-closure-reason").val());
localStorage.setItem("ff-closure-endDate", $("#ff-closure-endDate").val());
localStorage.setItem("ff-closure-endTime", $("#ff-closure-endTime").val());
//formfiller_log("Settings saved");
return;
}
function ff_addUserTab()
{
var userInfo = document.getElementById("user-info"),
userTabs = document.getElementById("user-tabs"),
navTabs = userTabs.getElementsByClassName("nav-tabs"),
tabContent = userInfo.getElementsByClassName("tab-content");
var ffTab = document.createElement("li"),
ffPanel = document.createElement("div"),
ffReason = document.createElement("div"),
ffEndDate = document.createElement("div"),
ffNewTabBox = document.createElement("input"),
ffNewTabLabel = document.createElement("label"),
ffTabInfo = document.createElement("div");
ffTab.innerHTML = '<a title="Form Filler" href="#sidepanel-formfill" data-toggle="tab"><img class="fa" src="'+WMEFFIcon+'" width="15px" /></a>';
ffPanel.id = "sidepanel-formfill";
ffPanel.className = "tab-pane";
ffTabInfo.innerHTML = '<b>'+ WMEFFName +'</b> v'+ WMEFFVersion;
ffNewTabBox.id = "ff-open-in-tab";
ffNewTabBox.type = "checkbox";
ffNewTabBox.name = "ff_open_tab";
ffNewTabLabel.innerHTML = "Open form in new tab";
ffNewTabLabel.for = "ff_open_tab";
ffReason.className = "form-group";
ffReason.innerHTML = '<label class="control-label" for="ff_closure_reason">Closures reason:</label><div class="controls"><input id="ff-closure-reason" class="form-control" type="text" name="ff_closure_reason"></div>';
ffEndDate.className = "form-group";
ffEndDate.innerHTML = '<label class="control-label" for="ff_closure_endDate">Closures end:</label><div class="controls"><div class="date date-input-group input-group pull-left" style="width: 62%"><input id="ff-closure-endDate" class="form-control end-date" type="text" name="ff_closure_endDate"><span class="input-group-addon"><i class="fa fa-calendar"></i></span></div><div class="bootstrap-timepicker input-group style="width: 38%""><input id="ff-closure-endTime" class="end-time form-control" type="text" name="ff_closure_endTime"><span class="input-group-addon"><i class="fa fa-clock-o"></i></span></div></div>';
ffPanel.appendChild(ffTabInfo);
ffPanel.appendChild(ffNewTabBox);
ffPanel.appendChild(ffNewTabLabel);
ffPanel.appendChild(ffReason);
ffPanel.appendChild(ffEndDate);
navTabs[0].appendChild(ffTab);
tabContent[0].appendChild(ffPanel);
if (typeof $.fn.datepicker !== "undefined") {
$("#ff-closure-endDate").datepicker({format:"yyyy-mm-dd", todayHighlight:true, autoclose:true});
} else {
if (typeof $.fn.daterangepicker !== "undefined") {
$("#ff-closure-endDate").daterangepicker({singleDatePicker:true, locale:{format:"YYYY-MM-DD"}});
}
}
if (typeof $.fn.timepicker !== "undefined") {
$("#ff-closure-endTime").timepicker({template:false,defaultTime:"00:00",showMeridian:false});
}
ff_loadSettings();
$("#ff-closure-reason").change(function() {ff_saveSettings();});
$("#ff-closure-endDate").change(function() {ff_saveSettings();});
$("#ff-closure-endTime").change(function() {ff_saveSettings();});
$("#ff-open-in-tab").click(function() {ff_saveSettings();});
}
setTimeout(formfiller_bootstrap,2000);
})();