WME Requests

Opens the Requests module with precompiled fields to submit an request

目前为 2017-06-20 提交的版本。查看 最新版本

  1. // ==UserScript==
  2. // @name WME Requests
  3. // @namespace https://greasyfork.org/ru/scripts/5085-wme-requests
  4. // @description Opens the Requests module with precompiled fields to submit an request
  5. // @include https://*.waze.com/editor/*
  6. // @include https://*.waze.com/*/editor/*
  7. // @include https://*.waze.com/map-editor/*
  8. // @include https://*.waze.com/beta_editor/*
  9. // @include http://fias.nalog.ru/*
  10. // @grant none
  11. // @author skirda
  12. // @version 2.12.0.1
  13. // ==/UserScript==
  14.  
  15. var wmer_Version = '2.12.0.1';
  16.  
  17. if (location.hostname === "fias.nalog.ru")
  18. {
  19. if (window.location.search && window.location.search[0]==='?')
  20. {
  21. setTimeout(function(){
  22. var s=unescape(decodeURI(window.location.search.substr(1)));
  23. $("#MainForm").find(".rcbInput").val(s).change();
  24. $("#MainForm").find(".rcbArrowCell").find("A")[0].click();
  25. },1000);
  26. }
  27. return;
  28. }
  29.  
  30.  
  31. var CL=new Array(
  32. {
  33. c:'Russia',
  34. cc:'ru',
  35. al:'ru_RU',
  36.  
  37. // Запрос на добавление населенного пункта
  38. f:'https://docs.google.com/forms/d/1ck0cCIV6vPy16YQZJvfmM0clOdAE2Z-kDsXn06ZwQ1s/viewform', // форма
  39. d:'https://docs.google.com/spreadsheets/d/1ddcW8EmNjojJp7EQ4AYPdfBqNWe28WqRaQ_RtkB8JAU', // таблица
  40. l:'https://script.google.com/macros/s/AKfycbzqA15-fy4g4StdRUmnuMj9z6rJ56gQPjCYpgCMni7h/exec', // Level5
  41. // WME Request (ответы)
  42. fr:'https://docs.google.com/forms/d/1QzvF3-lH8MuuEaSw0GA6LgLW62EiSHzQXBmG5-rQdIQ/viewform', // форма
  43. dr:'https://docs.google.com/spreadsheet/ccc?key=0AtcEFFDNcic4dEE2UFh5X0lDdlRZbno3YVFYUkg0Unc', // таблица
  44.  
  45. cs:'https://script.google.com/macros/s/AKfycbzqA15-fy4g4StdRUmnuMj9z6rJ56gQPjCYpgCMni7h/exec', // change state
  46.  
  47. ttst:'Marussia',
  48. ttsd:'https://docs.google.com/spreadsheets/d/16rSWBWfRi5gXhywAlTGu6O3c3kH0B49ksp56hdh-xlI', // TTS таблица RU
  49. ttsf:'https://docs.google.com/forms/d/e/1FAIpQLSfUdwm1Jlv5h_tauxcWZRDnFSOv2QR8vzi2XcjWPe-TKnxzMQ/viewform' // TTS форма RU
  50. },
  51. {
  52. c:'Belarus',
  53. cc:'by',
  54. al:'be_BY', // ru_BY
  55.  
  56. // Запрос на добавление населенного пункта
  57. f:'https://docs.google.com/forms/d/1a7g7ONWOIHfxr8ZEXKxRXUkIxFF7xFb-2uX4LlydWXo/viewform',
  58. d:'https://docs.google.com/spreadsheets/d/1uuRY8ib5h_8xMfpzgXG2N78foMtftUNkPzJxP56mDXI',
  59. l:'https://script.google.com/macros/s/AKfycbz8_xLefn_06nLRsfwnupviEEStCXfttg777KryBMnD/exec',
  60. // WME Request (ответы)
  61. fr:'https://docs.google.com/forms/d/1a9wXzngDV_KGoYZC65X_-xAUfcyA7vgftaEBC9aHAMM/viewform',
  62. dr:'https://docs.google.com/spreadsheets/d/1gge9vlSuDrxkzH0ubiRGcx3VOawYA-Hub7EZzP94siI',
  63.  
  64. cs: '', // change state
  65.  
  66. ttst:'Marussia',
  67. ttsd:'https://docs.google.com/spreadsheets/d/16rSWBWfRi5gXhywAlTGu6O3c3kH0B49ksp56hdh-xlI', // TTS таблица RU
  68. ttsf:'https://docs.google.com/forms/d/e/1FAIpQLSfUdwm1Jlv5h_tauxcWZRDnFSOv2QR8vzi2XcjWPe-TKnxzMQ/viewform' // TTS форма RU
  69. },
  70. {
  71. c:'Uzbekistan',
  72. cc:'uz',
  73. al:'uz_UZ', //
  74.  
  75. // Запрос на добавление населенного пункта
  76. f:'https://docs.google.com/forms/d/1wr3Bjkm1SKbThThdZ0ea80iriuoX9JJ4xRvutXcPGws/viewform', //
  77. d:'https://docs.google.com/spreadsheets/d/1sjniZzrQT5ygaZaMUzXKeoPFweASF7S7QPebNrHLo0Y', //
  78. l:'https://script.google.com/macros/s/AKfycbwKbjrauFor_XH4woPWrW9mkqvYCGzGXFoi6saWync/exec', //
  79. // WME Request (ответы)
  80. fr:'https://docs.google.com/forms/d/12oEAxVdrQZPUwHWK2AxKH0pIQwzG9UagRO0_ehRoaa4/viewform', //
  81. dr:'https://docs.google.com/spreadsheets/d/1wDYm7BKOpktL7MACucV-p94n-6M4HuyJy8HGntbumY4', //
  82.  
  83. cs: '', // change state
  84.  
  85. ttst:'Marussia',
  86. ttsd:'https://docs.google.com/spreadsheets/d/16rSWBWfRi5gXhywAlTGu6O3c3kH0B49ksp56hdh-xlI', // TTS таблица RU
  87. ttsf:'https://docs.google.com/forms/d/e/1FAIpQLSfUdwm1Jlv5h_tauxcWZRDnFSOv2QR8vzi2XcjWPe-TKnxzMQ/viewform' // TTS форма RU
  88. },
  89. {
  90. c:'Kazakhstan',
  91. cc:'kz',
  92. al:'kk_KZ', // ru_KZ
  93.  
  94. // Запрос на добавление населенного пункта
  95. f:'https://docs.google.com/forms/d/1zdqseCwkJqxkmb7w9geTcKI-VKA5dNl-QKvuIw1rObg/viewform',//
  96. d:'https://docs.google.com/spreadsheets/d/1rmmxyNOh7zSYU0U9v0nN0yx8ZOW9Vr83YepmC3vt8ms', //
  97. l:'https://script.google.com/macros/s/AKfycbyvmneTt9c8HuwuDevm5tGB8vBvkL9lHu9Bl_JWrNo/exec', //
  98. // WME Request (ответы)
  99. fr:'https://docs.google.com/forms/d/1Ap4i0pSbBc7OKfggSao8XmirjdlxQWIBEVQ1Cq1WYyQ/viewform', //
  100. dr:'https://docs.google.com/spreadsheets/d/1Vl1sXOCRK4eTCihfHJPB5oI2nDu9g7cVIu0gpcxI0-g', //
  101.  
  102. cs: '', // change state
  103.  
  104. ttst:'Marussia',
  105. ttsd:'https://docs.google.com/spreadsheets/d/16rSWBWfRi5gXhywAlTGu6O3c3kH0B49ksp56hdh-xlI', // TTS таблица RU
  106. ttsf:'https://docs.google.com/forms/d/e/1FAIpQLSfUdwm1Jlv5h_tauxcWZRDnFSOv2QR8vzi2XcjWPe-TKnxzMQ/viewform' // TTS форма RU
  107. },
  108. {
  109. c:'Ukraine',
  110. cc:'ua',// uk
  111. al:'uk_UA',
  112.  
  113. // Запрос на добавление населенного пункта
  114. f:'https://docs.google.com/forms/d/13BWQv9Kvwzii8IDyCBfztLqBAoQnI-dDLL4exTv4DOw/viewform',//
  115. d:'https://docs.google.com/spreadsheets/d/1C6P-VmSTR2KTS9LMIFZFQyf7r57ki9Mzi7B-HNwjBbM', //
  116. l:'https://script.google.com/macros/s/AKfycby2OUnHmGkbTNeJDBcXu4zZ6eyNngh6XHpkcU_tsoVSmHn-NzY/exec', //
  117. // WME Request (ответы)
  118. fr:'https://docs.google.com/forms/d/1VLcIJAFKrLumCINck6bWKJAXvHiJPriZKam3k309--k/viewform', //
  119. dr:'https://docs.google.com/spreadsheets/d/1_R8f_0_j57gU7EYKYBCaiIWi-vKWsPgtM-xuEBNGfks', //
  120.  
  121. cs: '', // change state
  122.  
  123. ttst:'Марічка',
  124. ttsd:'https://docs.google.com/spreadsheets/d/1B2xEnhZmiJa1rUAdrQa-kbBZANyU3uxBLWoNzlm3_4o', // TTS таблица UA
  125. ttsf:'https://docs.google.com/forms/d/e/1FAIpQLSepm_CwbQEyAIr-w8DqCXZsSgyEjSJIPG1AAigvOxwmXayADg/viewform' // TTS форма UA
  126. },
  127. {
  128. c:'Lithuania',
  129. cc:'lt',
  130. al:'lt_LT',
  131.  
  132. // Запрос на добавление населенного пункта
  133. f:'https://docs.google.com/forms/d/e/1FAIpQLSdiCSLrUX_mWGPzkCDzqmb_qvfY66Qgczz-AlvGN2ZLM7T5vg/viewform',//
  134. d:'https://docs.google.com/spreadsheets/d/1fKYvSYi2Hr8C8tiOVKr3IvpWvuwNtlm-kEBvsHSzljA', //
  135. l:'https://script.google.com/macros/s/AKfycbyt6joK8cqU3nLZwvi2DlFEGd9QjV0Sw5WbSuGrLjhK9fHBUO9Y/exec', //
  136. //https://script.google.com/macros/s/AKfycbztAHmVTR94oKtNo4pbx2ZCg30sjhYD59qMvQsKp1ob/dev
  137. // WME Request (ответы)
  138. fr:'https://docs.google.com/forms/d/e/1FAIpQLSf7karoWLOdSqthcdVpEG0VohJOZ8g33fvzRifMZMAun78nOg/viewform', //
  139. dr:'https://docs.google.com/spreadsheets/d/1TkvBW7Zc3thL9w44Hs42LVquhivibQwMrdEkCiLlSuM', //
  140.  
  141. cs: '', // change state
  142.  
  143. ttst:'Marussia',
  144. ttsd:'https://docs.google.com/spreadsheets/d/16rSWBWfRi5gXhywAlTGu6O3c3kH0B49ksp56hdh-xlI', // TTS таблица RU
  145. ttsf:'https://docs.google.com/forms/d/e/1FAIpQLSfUdwm1Jlv5h_tauxcWZRDnFSOv2QR8vzi2XcjWPe-TKnxzMQ/viewform' // TTS форма RU
  146. }
  147. );
  148.  
  149. //var wner_TTS_d="https://docs.google.com/spreadsheets/d/16rSWBWfRi5gXhywAlTGu6O3c3kH0B49ksp56hdh-xlI";
  150. //var wner_TTS_f="https://docs.google.com/forms/d/e/1FAIpQLSfUdwm1Jlv5h_tauxcWZRDnFSOv2QR8vzi2XcjWPe-TKnxzMQ/viewform";
  151.  
  152. // через солько дней вернуть лок обратно
  153. var wmer_CountDays = 5;
  154. var wmer_UserCache = new Array();
  155. var wmer_LanguageRU = false;
  156. var wmer_Debug = false;
  157. var wmer_MousePos = '';
  158. var wmer_MapCenter = false;
  159. var WMERequestEmail='';
  160. var WMERequestCountry=0;
  161.  
  162.  
  163. /* helper function */
  164. function getElementsByClassName(classname, node)
  165. {
  166. if(!node)
  167. node = document.getElementsByTagName("body")[0];
  168. var a = [];
  169. var re = new RegExp('\\b' + classname + '\\b');
  170. var els = node.getElementsByTagName("*");
  171. for (var i=0,j=els.length; i<j; i++)
  172. if (re.test(els[i].className)) a.push(els[i]);
  173. return a;
  174. }
  175.  
  176.  
  177. function wmer_getUsername()
  178. {
  179. var thisUser = Waze.loginManager.user;
  180. if (thisUser === null)
  181. {
  182. alert(wmer_LanguageRU?'Невозможно получить имя текущего пользователя':'Nobody\'s logged in.');
  183. return "";
  184. }
  185. return Waze.loginManager.user.userName;
  186. }
  187.  
  188. function timeConverter(UNIX_timestamp)
  189. {
  190. var datetime = new Date();
  191. var mEpoch = parseInt(UNIX_timestamp);
  192. if (mEpoch<10000000000) mEpoch *= 1000;
  193. datetime.setTime(mEpoch);
  194. // !!! UTC !!!
  195. return datetime.getUTCFullYear()+"-"+('0' + (datetime.getUTCMonth() + 1)).slice(-2)+"-"+('0' + datetime.getUTCDate()).slice(-2)+"+"+('0' + datetime.getUTCHours()).slice(-2) + ':' + ('0' + datetime.getUTCMinutes()).slice(-2);
  196.  
  197. }
  198.  
  199. function wmer_getCCSD(segment) // BUBBUB!!! need use "hasOwnProperty" or "in"
  200. {
  201. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'start wmer_getCCSD');
  202.  
  203. var oID="";
  204. var streetName="";
  205. var cityName="";
  206. var countryName="";
  207. var countryID="";
  208. var description="";
  209. var typeName= "";
  210. var stateID="";
  211. var stateName="";
  212. var cityID="";
  213. var userID="";
  214. var forumUserID="";
  215. var userName="";
  216. var updatedOn="";
  217. var poiaddress="";
  218.  
  219. try {
  220. typeName=segment.type;
  221. /*
  222. "segment"
  223. "venue"
  224. "node"
  225. "camera" typeName: "Speed camera"
  226. "bigJunction"
  227. */
  228. oID=segment.attributes.id;
  229. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': oID=' + oID);
  230.  
  231. if(segment.attributes.hasOwnProperty('updatedOn'))
  232. updatedOn=segment.attributes.updatedOn;
  233. else
  234. updatedOn=segment.attributes.createdOn;
  235.  
  236. if (segment.attributes.hasOwnProperty('primaryStreetID'))
  237. {
  238. //Waze.model.streets.get(Waze.selectionManager.selectedItems[0].model.attributes.primaryStreetID).cityID
  239. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'found street');
  240. var sID=segment.attributes.primaryStreetID;
  241. if (sID)
  242. {
  243. var streetsObj = Waze.model.streets.get(sID);
  244. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'typeof streetsObj='+(typeof streetsObj));
  245. if (typeof streetsObj !== "undefined")
  246. {
  247. cityID=streetsObj.cityID;
  248. streetName=streetsObj.name;
  249. }
  250. }
  251. }
  252. else if (typeName === "camera")
  253. {
  254. //Waze.selectionManager.selectedItems[0].model.model.cities.additionalInfo[0].id
  255. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'found camera');
  256. streetName=segment.typeName;
  257. description= "\n "+(wmer_LanguageRU?'Скорость':'Speed')+": "+segment.attributes.speed
  258. +"\n "+(wmer_LanguageRU?'Подтверждено':'Approved')+": "+segment.attributes.validated
  259. +"\n "+(wmer_LanguageRU?'Тип':'Type')+": "+I18n.translations[wmer_LanguageRU?"ru":window.I18n.currentLocale()].edit.camera.fields.type[segment.attributes.type];
  260. // +"\n "+(wmer_LanguageRU?'Азимут':'Azymuth')+": "+segment.attributes.azymuth
  261. //if(segment.attributes.hasOwnProperty('updatedOn'))
  262. cityID=segment.model.cities.additionalInfo[0].id;
  263. if (cityID == null)
  264. cityID="";
  265. }
  266. else if (typeName === "node")
  267. {
  268. //Waze.selectionManager.selectedItems[0].model.segments.topCityID
  269. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'found node');
  270. cityID=''+segment.model.segments.topCityID;
  271.  
  272. if (cityID == null)
  273. cityID="";
  274. description="\n count segment(s)="+segment.attributes.segIDs.length;
  275. }
  276. else if(typeName === "bigJunction")
  277. {
  278. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'found bigJunction');
  279. cityID=''+segment.model.segments.topCityID;
  280. if (cityID == null)
  281. cityID="";
  282. description="\n count segment(s)="+segment.attributes.segIDs.length;
  283. }
  284. else // "venue"
  285. {
  286. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'found POI ('+typeName+')');
  287. //Waze.model.streets.get(Waze.selectionManager.selectedItems[0].attributes.streetID).cityID
  288. var sID=segment.attributes.streetID;
  289. if (sID == null)
  290. cityID="";
  291. else
  292. cityID=Waze.model.streets.get(sID).cityID;
  293.  
  294. if (sID == null)
  295. cityID="";
  296.  
  297. if (cityID !== "")
  298. {
  299. var cityObj=Waze.model.cities.get(cityID);
  300. if (typeof cityObj !== "undefined")
  301. {
  302. countryID=cityObj.getAttributes().countryID;
  303. stateID=cityObj.getAttributes().stateID;
  304. cityName=cityObj.getAttributes().name;
  305.  
  306. var stateObj=Waze.model.states.get(stateID);
  307. if (typeof stateObj !== "undefined")
  308. stateName=stateObj.getAttributes().name;
  309.  
  310. var countriesObj=Waze.model.countries.get(countryID);
  311. if(wmer_Debug) console.log(countriesObj);
  312. if (typeof countriesObj !== "undefined")
  313. countryName = countriesObj.name;
  314. }
  315. }
  316.  
  317. if (typeof Waze.selectionManager.selectedItems[0].model.attributes.categories === "undefined")
  318. {
  319. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'categories=undefined');
  320. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'segment.attributes.description='+segment.attributes.description);
  321.  
  322. }
  323. else
  324. {
  325. var vcats=segment.attributes.categories;
  326. var arrvcats=[];
  327. for(var i=0; i < vcats.length; ++i)
  328. {
  329. //if(wmer_Debug) console.log("segment.attributes.categories["+i+"]='"+segment.attributes.categories[i]+"'")
  330. arrvcats.push(window.I18n.translations[wmer_LanguageRU?"ru":window.I18n.currentLocale()].venues.categories[vcats[i]]);
  331. //if(wmer_Debug) console.log("segment.attributes.categories["+i+"]='"+segment.attributes.categories[i]+"'")
  332. }
  333. description='\n '+(wmer_LanguageRU?'Категории':'Categories')+': '+(arrvcats.length > 0?arrvcats.join(';')+'.':'')+'\n ' + segment.attributes.description;
  334. //if(wmer_Debug) console.log(description)
  335. arrvcats=[];
  336.  
  337.  
  338. if (segment.attributes.categories.indexOf("GAS_STATION") != -1) // Gas Station
  339. {
  340. typeName="gas_station";
  341. description="\n "+(wmer_LanguageRU?'Брэнд':'Brand')+": "+segment.attributes.brand
  342. + "\n "+(wmer_LanguageRU?'Адрес':'Address')+": " + segment.attributes.address
  343. + "\n "+(wmer_LanguageRU?'Описание':'Description')+": " + segment.attributes.description;
  344. }
  345. }
  346.  
  347. if(segment.attributes.hasOwnProperty('streetID'))
  348. {
  349. var name=Waze.model.streets.get(segment.attributes.streetID).name;
  350. poiaddress+=name?name:"";
  351. }
  352. if(segment.attributes.hasOwnProperty('houseNumber'))
  353. {
  354. if(poiaddress.length > 0)
  355. poiaddress+= " ";
  356. poiaddress+=segment.attributes.houseNumber;
  357. }
  358. streetName=segment.attributes.name;
  359. }
  360.  
  361. if (!(/*typeName === "camera" || */typeName === "node" || cityID === "")) // BUGBUG!!!
  362. {
  363. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': cityID=' + cityID);
  364. var cityObj=Waze.model.cities.get(cityID);
  365. if (typeof cityObj !== "undefined")
  366. {
  367. countryID=cityObj.getAttributes().countryID;
  368. stateID=cityObj.getAttributes().stateID;
  369. cityName=cityObj.getAttributes().name;
  370.  
  371. var stateObj=Waze.model.states.get(stateID);
  372. if (typeof stateObj !== "undefined")
  373. stateName=stateObj.getAttributes().name;
  374.  
  375. var countriesObj=Waze.model.countries.get(countryID);
  376. if(wmer_Debug) console.log(countriesObj);
  377. if (typeof countriesObj !== "undefined")
  378. countryName = countriesObj.name;
  379. }
  380. }
  381.  
  382. if (!(typeName === "node"))
  383. {
  384. userID=segment.attributes.updatedBy;
  385. if (userID === null)
  386. userID=segment.attributes.createdBy;
  387.  
  388. if (userID==-1 || userID === null)
  389. {
  390. userID=segment.attributes.createdBy;
  391. if (userID==-1)
  392. {
  393. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'Do not PM Admin!');
  394. }
  395. }
  396.  
  397. userName=Waze.model.users.get(userID).userName;
  398. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'userName='+userName);
  399. }
  400. else
  401. userID="-1";
  402.  
  403. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'userID=' +userID);
  404.  
  405. }
  406. catch (err) {
  407. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': error['+err.columnNumber+','+err.lineNumber+']: ' +err.name);
  408. }
  409.  
  410. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'return from wmer_getCCSD');
  411. return {
  412. objid : oID,
  413. type : typeName,
  414. street : streetName,
  415. city : cityName,
  416. cityID : cityID,
  417. stateID : stateID,
  418. stateName : stateName,
  419. country : countryName,
  420. description : description,
  421. username : userName,
  422. userID : userID,
  423. forumuserID : forumUserID,
  424. updatedOn : updatedOn,
  425. poiaddress : poiaddress
  426. };
  427. }
  428.  
  429.  
  430. function wmer_userRank(segment)
  431. {
  432. var usrRank = 0;
  433. /*
  434. if (segment.attributes.lockRank)
  435. {
  436. var updatedBy = Waze.model.users.get(segment.attributes.updatedBy);
  437. return updatedBy != null ? updatedBy.rank : 0;
  438. }
  439. return 0;
  440. */
  441. if (Waze.selectionManager.selectedItems[0].model.attributes.hasOwnProperty('lockRank'))
  442. return segment.attributes.lockRank;
  443. else
  444. return 0;
  445. }
  446.  
  447. //It returns the maximum lock level
  448. function wmer_GetLevel() {
  449. //attributes.rank dovrebbe essere il road rank
  450. var sel = Waze.selectionManager.selectedItems;
  451. var maxR = wmer_userRank(sel[0].model);
  452.  
  453. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'wmer_GetLevel() maxR='+maxR);
  454. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'wmer_GetLevel() sel.length='+sel.length);
  455.  
  456. for (i = 1; i < sel.length; i++)
  457. {
  458. if (maxR == 5)
  459. {
  460. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'wmer_GetLevel() return 6');
  461. return 6;
  462. }
  463. var usrRank = wmer_userRank(sel[i].model);
  464. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'wmer_GetLevel() usrRank='+usrRank);
  465. if (usrRank > maxR) {
  466. maxR = usrRank;
  467. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'wmer_GetLevel() '+maxR);
  468. }
  469. }
  470. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'wmer_GetLevel() return [maxR + 1] = '+(maxR + 1));
  471. return maxR + 1;
  472. }
  473.  
  474. // получить данные имени НП у OSM
  475. function WmeR_GetCityFromOSM(ll,zoom,country)
  476. {
  477. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'WmeR_GetCityFromOSM([lat='+ll.lat+',lon='+ll.lon+'],'+zoom+',"'+country+'")');
  478. var cityName='';
  479. var country_code='';
  480. var address_json='';
  481.  
  482. if (country === '')
  483. {
  484. if (WMERequestCountry >= 0 && WMERequestCountry < CL.length)
  485. country=CL[WMERequestCountry].c;
  486. }
  487. zoom += 7;
  488. var url = 'https://nominatim.openstreetmap.org/reverse';
  489. var data = {
  490. "lat": ll.lat,
  491. "lon": ll.lon,
  492. "zoom": zoom,
  493. "format": "json",
  494. "addressdetails": 1,
  495. "countrycodes": (WMERequestCountry >= 0 && WMERequestCountry < CL.length?CL[WMERequestCountry].cc:"ru"),
  496. "accept-language": (WMERequestCountry >= 0 && WMERequestCountry < CL.length?CL[WMERequestCountry].al:"ru_RU")
  497. };
  498.  
  499. $.ajax({
  500. dataType: "json",
  501. cache: false,
  502. url: url,
  503. async: false,
  504. data: data,
  505. error: function() {
  506. },
  507. success: function(json) {
  508. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'WmeR_GetCityFromOSM(): json='+json);
  509. if (json.display_name !== undefined) {
  510. var li = '';
  511. if(wmer_Debug) console.dir(json);
  512. // json.address.country_code
  513. // json.address.state
  514. // json.address.region
  515. // json.address.city_district
  516. // json.address.suburb
  517. if (json.address.country_code !== undefined) {
  518. country_code=json.address.country_code;
  519. }
  520. address_json=json.address;
  521.  
  522. if (json.address.city !== undefined) {
  523. li = json.address.city;
  524. }
  525. else if (json.address.town !== undefined) {
  526. li = json.address.town;
  527. }
  528. else if (json.address.village !== undefined) {
  529. li = json.address.village;
  530. }
  531. else if (json.address.hamlet !== undefined) {
  532. li = json.address.hamlet;
  533. }
  534.  
  535. if (wmer_AddCounty && li.length > 0 && json.address.county !== undefined) {
  536. //console.log("country=",country)
  537. if (country==='Russia')
  538. {
  539. li += " (" + json.address.county.replace("район","").replace("область","").replace("городской округ","");
  540. //if (json.address.state !== undefined) {li += " / " + json.address.state; }
  541. //li += ")";
  542. li=li.trim();
  543. }
  544. else if (country==='Lithuania')
  545. {
  546. if(wmer_Debug) console.dir(json.address);
  547. // {village: "Sujainiai", county: "Paliepių seniūnija", state_district: "Raseinių rajono savivaldybė", state: "Kauno apskritis", country: "Lietuva", country_code: "lt"}
  548. li += ", " + json.address.county.replace("seniūnija","sen.").replace("rajono","r.").replace("savivaldybė","sav.").replace("apskritis","aps.");
  549. //Sujainiai, Paliepių seniūnija, Raseinių rajono savivaldybė, Kauno apskritis, Lietuva
  550. //if (json.address.state !== undefined) {li += " / " + json.address.state; }
  551. //li += ")";
  552. li=li.trim();
  553. }
  554. else
  555. {
  556. li += " (" + json.address.county.replace("район","р-н").replace("область","обл.").replace("городской округ","р-н");
  557. //if (json.address.state !== undefined) {li += " / " + json.address.state; }
  558. li += ")";
  559. }
  560. }
  561.  
  562. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'WmeR_GetCityFromOSM(): li='+li);
  563.  
  564. //$('#topbar-container .topbar .location-info-region .alt-location-info').html(alispan);
  565. cityName=li;
  566. }
  567. }
  568. });
  569.  
  570. return {cityName:cityName,country_code:country_code,address_json:address_json};
  571. }
  572.  
  573.  
  574. function PtInPoly(x, y, components)
  575. {
  576. npol = components.length;
  577. jj = npol - 1;
  578. var c = 0;
  579. for (var ii = 0; ii < npol;ii++)
  580. {
  581. if ((((components[ii].y<=y) && (y<components[jj].y)) || ((components[jj].y<=y) && (y<components[ii].y))) &&
  582. (x > (components[jj].x - components[ii].x) * (y - components[ii].y) / (components[jj].y - components[ii].y) + components[ii].x))
  583. {
  584. c = !c;
  585. }
  586. jj = ii;
  587. }
  588. return c;
  589. }
  590.  
  591. function checkPosKG(ll)
  592. {
  593. var p=[{x:33.545723,y:46.0000621},{x:33.5925865,y:46.0695387},{x:33.5961914,y:46.0775176},{x:33.5941315,y:46.0858525},{x:33.5924149,y:46.0875788},{x:33.5927582,y:46.1139437},{x:33.6037445,y:46.1303633},{x:33.610611,y:46.1339321},{x:33.6373901,y:46.1405933},{x:33.6178207,y:46.2135757},{x:33.6160183,y:46.2131599},{x:33.61413,y:46.2123878},{x:33.6128426,y:46.212863},{x:33.6133575,y:46.2138132},{x:33.6139584,y:46.2144666},{x:33.6172199,y:46.2153574},{x:33.6143875,y:46.2264623},{x:33.6461449,y:46.2293718},{x:33.6508656,y:46.2264623},{x:33.6551571,y:46.2247403},{x:33.6583328,y:46.2227807},{x:33.6642551,y:46.2217118},{x:33.674469,y:46.2151199},{x:33.6811638,y:46.2092993},{x:33.6857128,y:46.2060323},{x:33.6888027,y:46.2044879},{x:33.696785,y:46.2034186},{x:33.7084579,y:46.1999731},{x:33.7359238,y:46.1859512},{x:33.738842,y:46.1851788},{x:33.7409878,y:46.1850005},{x:33.7502575,y:46.188031},{x:33.7567806,y:46.191299},{x:33.7744617,y:46.1988444},{x:33.7851048,y:46.2014583},{x:33.7966919,y:46.2030028},{x:33.8113689,y:46.2035968},{x:33.8264751,y:46.2034186},{x:33.8388348,y:46.2018147},{x:33.8487053,y:46.1994979},{x:33.8618374,y:46.1941509},{x:33.9044952,y:46.1658034},{x:33.9177132,y:46.1585507},{x:33.9377975,y:46.150762},{x:33.961916,y:46.14321},{x:33.9851761,y:46.1343485},{x:34.0131569,y:46.1185845},{x:34.0213966,y:46.1143602},{x:34.0280914,y:46.1117422},{x:34.0356445,y:46.1101951},{x:34.0439701,y:46.109124},{x:34.0525532,y:46.1090645},{x:34.0565872,y:46.1099571},{x:34.0653419,y:46.1148362},{x:34.0695477,y:46.1162047},{x:34.0741825,y:46.1173946},{x:34.0812206,y:46.1172161},{x:34.091177,y:46.1156097},{x:34.1224194,y:46.1054941},{x:34.1291142,y:46.1015663},{x:34.1351223,y:46.0971621},{x:34.1409588,y:46.0913886},{x:34.1450787,y:46.0861502},{x:34.1502285,y:46.082102},{x:34.15658,y:46.078887},{x:34.1721153,y:46.0728734},{x:34.1776943,y:46.0693601},{x:34.1830158,y:46.0670377},{x:34.1866207,y:46.0660849},{x:34.1976929,y:46.0651916},{x:34.2121124,y:46.0627499},{x:34.2249012,y:46.0583426},{x:34.2339134,y:46.0557219},{x:34.247303,y:46.0530415},{x:34.2535686,y:46.0529224},{x:34.2642975,y:46.0543519},{x:34.2909908,y:46.0592956},{x:34.306097,y:46.0612014},{x:34.3175125,y:46.0614992},{x:34.3246365,y:46.061261},{x:34.3295288,y:46.0604272},{x:34.3405151,y:46.0576279},{x:34.3625736,y:46.0482165},{x:34.3809414,y:46.0369564},{x:34.39785,y:46.0214626},{x:34.4082355,y:46.0037586},{x:34.4124413,y:45.9900445},{x:34.4163036,y:45.9852736},{x:34.4254017,y:45.9760885},{x:34.4411945,y:45.9627255},{x:34.4570732,y:45.9520448},{x:34.4660854,y:45.9473303},{x:34.4773293,y:45.9433913},{x:34.4841957,y:45.942317},{x:34.4909763,y:45.9421976},{x:34.4974136,y:45.9429138},{x:34.5029068,y:45.94363},{x:34.5100307,y:45.9470319},{x:34.5228195,y:45.9550285},{x:34.5481396,y:45.9793691},{x:34.5511436,y:45.9867049},{x:34.5532036,y:45.9893289},{x:34.5601559,y:45.9929665},{x:34.5669365,y:45.9948747},{x:34.5747471,y:45.9955902},{x:34.5835018,y:45.9957691},{x:34.5995522,y:45.9945169},{x:34.6073627,y:45.9929069},{x:34.6297646,y:45.9859297},{x:34.6582603,y:45.97412},{x:34.6691608,y:45.968095},{x:34.7247791,y:45.9287071},{x:34.7531891,y:45.9100179},{x:34.8019409,y:45.902433},{x:34.7999668,y:45.8046917},{x:34.8609924,y:45.7945192},{x:34.8807335,y:45.7888935},{x:34.8975563,y:45.7824294},{x:34.9585819,y:45.7593198},{x:35.053854,y:45.787517},{x:36.7630005,y:45.8000844},{x:36.6778564,y:45.395316},{x:36.6081619,y:45.321013},{x:36.5068817,y:45.2903466},{x:36.529541,y:44.1664447},{x:31.9921875,y:44.1703849},{x:32.0361328,y:45.7253564},{x:33.545723,y:46.0000621}];
  594. if (PtInPoly(ll.lon, ll.lat, p))
  595. {
  596. return true;
  597. }
  598.  
  599. return false;
  600. }
  601.  
  602. function click_WMERequest() {
  603. var RenamePref="";
  604.  
  605. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'click_WMERequest()::Action: '+this.id);
  606. if (typeof Waze.selectionManager === "undefined")
  607. {
  608. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'Waze.selectionManager not found');
  609. return;
  610. }
  611. if (Waze.selectionManager.selectedItems.length == 0)
  612. {
  613. alert(wmer_LanguageRU?'Нет выделенных объектов':'No selected segments.');
  614. return;
  615. }
  616. if (Waze.selectionManager.selectedItems.length < 2 && this.id === 'wmerBtn_join')
  617. {
  618. alert(wmer_LanguageRU?'Вы должны выделить 2 сегмента':'You must select 2 segments.');
  619. return;
  620. }
  621.  
  622. var username = wmer_getUsername();
  623. var sccObj = wmer_getCCSD(Waze.selectionManager.selectedItems[0].model);
  624. if(wmer_Debug) console.log("sccObj="+JSON.stringify(sccObj));
  625. if(sccObj.city && sccObj.city.length > 0)
  626. RenamePref="Rename: '" + sccObj.city + "' => '";
  627.  
  628. var lockLevel = wmer_GetLevel();
  629. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'lockLevel= '+lockLevel);
  630. if (lockLevel == 1 && this.id == 'wmerBtn_lock')
  631. {
  632. alert(wmer_LanguageRU?'Выбранные сегменты уже разблокированы':'Selected segments are already unlocked');
  633. return;
  634. }
  635.  
  636. var normalizedLevel=Waze.loginManager.user.normalizedLevel;
  637. //normalizedLevel=2;
  638. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'My level: '+normalizedLevel);
  639. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'Lock level: '+lockLevel);
  640.  
  641. if (lockLevel <= normalizedLevel && this.id == 'wmerBtn_lock') {
  642. alert(wmer_LanguageRU?'Выбранные сегменты имеют доступный вам уровень блокировки':'Selected segments have a lock level that is less or equal to yours');
  643. return;
  644. }
  645.  
  646. lockLevel=normalizedLevel;
  647.  
  648. var description='type: ' + sccObj.type + '\r' +
  649. 'country: '+ sccObj.country + '\r' +
  650. 'city: ' + sccObj.city + '\r' +
  651. 'street/name: ' + sccObj.street + '\r' +
  652. 'description: ' + sccObj.description;
  653.  
  654. description = description.replace(/%/g, '%25');
  655. description = description.replace(/\+/g, '%2B'); // +
  656. description = description.replace(' ', '%20'); // ' '
  657. description = description.replace(/\r\n/g, '\r'); // '\r\n'
  658. description = description.replace(/\r/g, '%0A'); // '\n'
  659. description = description.replace(/&/g, '%26');
  660. description = description.replace(/</g, '%3C');
  661. description = description.replace(/\>/g, '%3E');
  662. description = description.replace(/\?/g, '%3F');
  663. description = description.replace(/=/g, '%3D');
  664.  
  665. var permalink = wmer_generate_permalink();
  666.  
  667. // попытка центрировать...
  668. var urPos;
  669. if(wmer_MapCenter)
  670. urPos=new OpenLayers.LonLat(Waze.map.center.lon,Waze.map.center.lat);
  671. else
  672. urPos=new OpenLayers.LonLat(
  673. Waze.selectionManager.selectedItems[0].geometry.bounds.left+(Waze.selectionManager.selectedItems[0].geometry.bounds.right-Waze.selectionManager.selectedItems[0].geometry.bounds.left)/2,
  674. Waze.selectionManager.selectedItems[0].geometry.bounds.top-(Waze.selectionManager.selectedItems[0].geometry.bounds.top-Waze.selectionManager.selectedItems[0].geometry.bounds.bottom)/2
  675. );
  676. urPos.transform(new OpenLayers.Projection("EPSG:900913"),new OpenLayers.Projection("EPSG:4326"));
  677.  
  678. var venues0='';
  679. if(getQueryString(permalink, 'venues') != -1)
  680. venues0="&venues=" + getQueryString(permalink, 'venues');
  681. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'venues0: '+venues0);
  682.  
  683. // https://www.waze.com/editor/?env=row&lon=36.11483&lat=53.96670&zoom=4&marker=yes
  684. var segments0='';
  685. if(getQueryString(permalink, 'segments') != -1)
  686. segments0="&segments=" + getQueryString(permalink, 'segments');
  687. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'segments0: '+segments0);
  688.  
  689.  
  690. var permalink5=permalink.split("&")[0] +
  691. "&zoom=" + parseInt(getQueryString(permalink, 'zoom')) +
  692. "&lon=" + urPos.lon +
  693. "&lat=" + urPos.lat +
  694. segments0 +
  695. venues0;
  696. var permalink50=permalink5;
  697.  
  698. function preparePermalink(s)
  699. {
  700. s = s.replace(/%/g, '%25'); //???
  701. s = s.replace(/&/g, '%26');
  702. s = s.replace(/\?/g, '%3F');
  703. s = s.replace(/=/g, '%3D');
  704. s = s.replace(/</g, '%3C');
  705. s = s.replace(/\>/g, '%3E');
  706. return s;
  707. }
  708.  
  709. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'permalink=' + permalink);
  710. permalink = preparePermalink(permalink);
  711. permalink5 = preparePermalink(permalink5);
  712.  
  713. //You can get entry numbers in google stylesheet: "Answers->Get precompiled URL"
  714. var curDate=new Date();
  715. curDate.setDate(curDate.getDate() + wmer_CountDays);
  716.  
  717. var action="";
  718. switch(this.id)
  719. {
  720. case 'wmerBtn_lock':
  721. action='lock';
  722. break;
  723. case 'wmerBtn_join':
  724. action='join';
  725. break;
  726. case 'wmerBtn_dir':
  727. action='direction';
  728. break;
  729. case 'wmerBtn_turn':
  730. action='turn';
  731. break;
  732. case 'wmerBtn_closures':
  733. action='closures';
  734. break;
  735.  
  736. }
  737.  
  738. function zero2(d){
  739. if((""+d).length == 1)
  740. d="0" + "" + d;
  741. return d;
  742. }
  743.  
  744. // для автозаполнения имени НП в форме
  745. var osmName=WmeR_GetCityFromOSM(urPos,parseInt(getQueryString(permalink50, 'zoom')),sccObj.country);
  746.  
  747. var suffix="";
  748. var suffixCS="";
  749.  
  750. if(sccObj.country === '')
  751. {
  752. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': sccObj.country=""; work with osmName!!!');
  753. switch(osmName.country_code)
  754. {
  755. case 'ru': sccObj.country='Russia'; break;
  756. case 'by': sccObj.country='Belarus'; break;
  757. case 'uz': sccObj.country='Uzbekistan'; break;
  758. case 'kz': sccObj.country='Kazakhstan'; break;
  759. case 'ua': sccObj.country='Ukraine'; break;
  760. case 'lt': sccObj.country='Lithuania'; break;
  761. }
  762. }
  763.  
  764. if (checkPosKG(urPos) && sccObj.country==='Ukraine')
  765. {
  766. sccObj.country='Russia';
  767. suffix=" / Крым";
  768. }
  769.  
  770.  
  771.  
  772. var idCL=(sccObj.country=='Russia'?0:(sccObj.country=='Belarus'?1:(sccObj.country=='Uzbekistan'?2:(sccObj.country==='Kazakhstan'?3:(sccObj.country==='Ukraine'?4:(sccObj.country==='Lithuania'?5:-1))))));
  773. if(idCL == -1)
  774. {
  775. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': idCL = ' +idCL + ', sccObj.countryName='+sccObj.country);
  776. return;
  777. }
  778.  
  779. if(this.id === 'wmerBtn_tts')
  780. {
  781. /*
  782. entry.587168531=nik
  783. entry.846152130=email
  784. entry.1316827755=country
  785. entry.1780120881=Какое действие предпринять
  786. entry.722429754=Название сегмента как на карте
  787. entry.543004173=Сейчас произноситься так
  788. entry.495130616=...должно звучать так
  789. entry.1226154757=permalink
  790. entry.1360508522=remark
  791. */
  792. description='';
  793.  
  794. // TTS: always zoom = 4
  795. var urlTTS=CL[idCL].ttsf +
  796. '?entry.587168531=' + username +
  797. '&entry.846152130=' + WMERequestEmail +
  798. '&entry.1226154757=' + permalink5.replace(/zoom\%3D([0-9]+)\%26/,"zoom%3D4%26") +
  799. '&entry.1316827755=' + sccObj.country +
  800. //'&entry.1780120881=' + // Какое действие предпринять
  801. '&entry.722429754=' + sccObj.street + // Название сегмента как на карте
  802. '&entry.543004173=' + sccObj.street + // Сейчас произноситься так
  803. '&entry.495130616=' + sccObj.street + // ...должно звучать так
  804. '';
  805.  
  806. window.open(urlTTS, '_blank');
  807.  
  808. return;
  809. }
  810.  
  811.  
  812. if(wmer_Debug) console.log("--- osmName & sccObj ---");
  813. if(wmer_Debug) console.log(osmName);
  814. if(wmer_Debug) console.log(sccObj);
  815.  
  816. if (!sccObj.city || sccObj.city.length === 0)
  817. {
  818. sccObj.city=osmName.cityName;
  819. }
  820.  
  821. if (!sccObj.city || (typeof sccObj.city === "undefined"))
  822. sccObj.city='';
  823.  
  824. /*
  825. entry.1230839078 username
  826. entry.1797072526 e-mail
  827. entry.390417455 permalink
  828. entry.1508498769 Country
  829. entry.1856604039 Action
  830. entry.1939939237 Start Closures
  831. entry.1229617197 End Closures
  832. entry.1746680078 Причина перекрытия
  833. entry.1224334113 locklevel
  834. entry.571885954 EndUnlock
  835. entry.2082027069 Узел
  836. entry.259824358 Description
  837. */
  838. // !!!
  839. var url = CL[idCL].fr +
  840. '?entry.1230839078=' + username +
  841. '&entry.390417455=' + permalink5 +
  842. '&entry.1224334113=' + lockLevel +
  843. '&entry.1508498769=' + sccObj.country +
  844. '&entry.1856604039=' + action +
  845. '&entry.259824358=' + description + suffix +
  846. '&entry.1797072526=' + WMERequestEmail +
  847. '&entry.571885954='+curDate.getUTCFullYear()+'-'+zero2(curDate.getUTCMonth()+1)+'-'+zero2(curDate.getUTCDate()) +
  848. '';
  849.  
  850. // CL: always zoom = 4
  851. var urlCL = CL[idCL].f +
  852. '?entry.1109766685=' + username +
  853. '&entry.1785513403=' + WMERequestEmail +
  854. '&entry.1300384005=' + permalink5.replace(/zoom\%3D([0-9]+)\%26/,"zoom%3D4%26") +
  855. '&entry.1967623256=' + RenamePref+ sccObj.city + suffix + (RenamePref.length>0?"'":"") +
  856. '&entry.1393986642=' + sccObj.stateID +
  857. // '&entry.address_json=' + JSON.stringify(osmName.address_json) +
  858. '';
  859.  
  860. if (this.id == 'wmerA_cl') // доп проверка
  861. {
  862. if (sccObj.username === '' || sccObj.city === '' || sccObj.cityID === '')
  863. {
  864. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ALERT!!! ' + 'sccObj.username=',sccObj.username,"sccObj.city=",sccObj.city,"sccObj.cityID=",sccObj.cityID);
  865. alert(wmer_LanguageRU?"Внимание! Не полные данные (UserName, City или CityID). Сохранение не возможно.":"Attention! UserName, City or CityID ==> empty. Saving is not possible.");
  866. return;
  867. }
  868. }
  869.  
  870. var urlL5 = CL[idCL].l +
  871. '?p1=' + sccObj.username +
  872. '&p2=' + sccObj.city + suffix +
  873. '&p3=' + permalink5 +
  874. '&p4=' + timeConverter(sccObj.updatedOn) +
  875. '&p5=' + sccObj.cityID +
  876. '';
  877.  
  878.  
  879. var urlCS = null;
  880. if (CL[idCL].cs !== '')
  881. urlCS = CL[idCL].cs +
  882. '?p1=' + username +
  883. '&p2=' + WMERequestEmail +
  884. '&p3=' + permalink5 +
  885. '&p4=' + sccObj.city + ': изменить регион' +
  886. '&p5=' + sccObj.stateID +
  887. '&p6=' + sccObj.cityID +
  888. '';
  889.  
  890. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'urlL5=' + urlL5);
  891.  
  892. if(this.id === 'wmerA_cl')
  893. {
  894. if(sccObj.city === null || sccObj.city === '')
  895. {
  896. alert(wmer_LanguageRU?"Внимание! Имя НП пустое. Сохранение не возможно.":"Attention! The name of the city is empty. Saving is not possible.");
  897. return;
  898. }
  899. }
  900.  
  901. if(this.id === 'wmerCS_cl')
  902. {
  903. if(urlCS === null || sccObj.stateName === null || sccObj.stateName === '')
  904. {
  905. alert(wmer_LanguageRU?"Внимание! Имя Района пустое. Сохранение не возможно.":"Attention! The name of the state is empty. Saving is not possible.");
  906. return;
  907. }
  908. }
  909.  
  910.  
  911. window.open(this.id == 'wmerBtn_cl'?urlCL:(this.id == 'wmerA_cl'?urlL5:(this.id == 'wmerCS_cl'?urlCS:url)), '_blank');
  912. }
  913.  
  914. function getQueryString(link, name)
  915. {
  916. if (link.indexOf( name + '=' ) <= 0)
  917. return -1;
  918. var pos = link.indexOf( name + '=' ) + name.length + 1;
  919. var len = link.substr(pos).indexOf('&');
  920. return (len == -1)?link.substr(pos):link.substr(pos,len);
  921. }
  922.  
  923. function wmer_generate_permalink() {
  924. var wcp=document.getElementsByClassName('WazeControlPermalink');
  925. for(var i=0; i < wcp.length; ++i)
  926. for (var j=0; j < wcp[i].getElementsByTagName('a').length;++j)
  927. {
  928. var href=wcp[i].getElementsByTagName('a')[j].href;
  929. if (href.indexOf(".waze.com/") > 0 && href.indexOf("/editor") > 0)
  930. {
  931. // kill "/ru/", kill "layers"
  932. href=href.replace("/ru/","/").replace(/layers=([0-9]+)\&/,"") + "&marker=yes";
  933. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'href=' + href);
  934. return href;
  935. }
  936. }
  937. return "";
  938. }
  939.  
  940. function CreateID()
  941. {
  942. return 'WME-Request-' + wmer_Version.replace(/\./g,"-");
  943. }
  944.  
  945.  
  946. function wmer_insertButton(z)
  947. {
  948. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'wmer_insertButton()',Waze.selectionManager.selectedItems.length);
  949. /*{
  950. var permalink=wmer_generate_permalink();
  951. var p = document.getElementsByClassName('WazeControlMousePosition')[0].lastChild.innerHTML.split(' ');
  952. permalink=permalink.replace(/#/g, "").replace(/&lat=([0-9\.]+)/g, '&lat='+p[1]).replace(/&lon=([0-9\.]+)/g, '&lon='+p[0]);
  953. }*/
  954.  
  955. // if(document.getElementById(CreateID()) != null)
  956. // document.getElementById(CreateID()).setAttribute('style', 'display:'+(Waze.selectionManager && Waze.selectionManager.selectedItems.length == 0?'none':'')+';');
  957.  
  958. if(Waze.selectionManager.selectedItems.length <= 0)
  959. return;
  960.  
  961. if (typeof Waze.selectionManager.selectedItems[0].model === "undefined")
  962. return;
  963.  
  964. switch(Waze.selectionManager.selectedItems[0].model.type)
  965. {
  966. case "segment":
  967. case "venue":
  968. break;
  969. case "city":
  970. /*
  971. attributes:
  972. countryID: 186
  973. englishName: null
  974. id: 1501075
  975. isEmpty: false
  976. name: "Веселовский (Чертковский р-н)"
  977. permissions: -1
  978. rank: 4
  979. stateID: 1839712
  980. geometry:
  981. bounds: null
  982. id: "OpenLayers.Geometry.Point_910"
  983. x: 4518527.665247766
  984. y: 6312163.836996106
  985. */
  986. case "camera":
  987. case "node":
  988. case "bigJunction":
  989. case "country":
  990. case "houseNumber":
  991. case "junction":
  992. case "mapProblem":
  993. case "roadClosure":
  994. case "state":
  995. default:
  996. return;
  997. }
  998.  
  999.  
  1000. //
  1001. if (Waze.selectionManager.selectedItems[0].model.type === "venue")
  1002. {
  1003. var area_poi=document.getElementById('WME.PlaceNames-Square');
  1004. if(!area_poi)
  1005. {
  1006. var wcp=document.getElementsByClassName('additional-attributes list-unstyled side-panel-section');
  1007. if (wcp)
  1008. {
  1009. var li=document.createElement("LI");
  1010. li.setAttribute('id', 'WME.PlaceNames-Square');
  1011. wcp[0].appendChild(li);
  1012. area_poi=document.getElementById('WME.PlaceNames-Square');
  1013. }
  1014. }
  1015.  
  1016. if(area_poi)
  1017. {
  1018. var v_id=Waze.selectionManager.selectedItems[0].model.attributes.id;
  1019. if (typeof Waze.model.venues.get(v_id).geometry.getGeodesicArea === "undefined")
  1020. area_poi.innerHTML="";
  1021. else
  1022. {
  1023. var square=Waze.model.venues.get(v_id).geometry.getGeodesicArea(Waze.map.getProjectionObject());
  1024. area_poi.style=(square < 650)?"color: red;":"color: black;";
  1025. area_poi.innerHTML="Площадь: " + square.toFixed(2) + " м&#178;";
  1026. }
  1027. }
  1028.  
  1029. }
  1030. /*
  1031. else if (Waze.selectionManager.selectedItems[0].model.type === "camera") // camera-edit-general
  1032. {
  1033. var cam=document.getElementsByClassName('additional-attributes list-unstyled side-panel-section');
  1034. if (cam && cam.length > 0)
  1035. {
  1036. var camDate = Waze.selectionManager.selectedItems[0].model.attributes.updatedOn;
  1037. if (!camDate)
  1038. camDate = Waze.selectionManager.selectedItems[0].model.attributes.createdOn;
  1039. if (camDate)
  1040. {
  1041. var dateNow = new Date();
  1042. var age=Math.floor((dateNow.getTime() - camDate) / 86400000);
  1043. var li=document.createElement("LI");
  1044. li.setAttribute('id', 'WME.Age');
  1045. cam[0].appendChild(li);
  1046. camage=document.getElementById('WME.Age');
  1047. camage.innerHTML="Age: " + age + " day(s)";
  1048. }
  1049.  
  1050. }
  1051.  
  1052. }
  1053. */
  1054. //
  1055.  
  1056. var editPanelID='';
  1057. var disabled=false;
  1058. var disabledjoin=false;
  1059. var disabledLock=false;
  1060. var disabledPM=false;
  1061.  
  1062. if (document.getElementById('segment-edit-general') !== null)
  1063. {
  1064. editPanelID='segment-edit-general';
  1065. disabled=false;
  1066. disabledjoin=false;
  1067. disabledLock=false;
  1068. }
  1069. else if (document.getElementById('landmark-edit-general') !== null)
  1070. {
  1071. editPanelID='landmark-edit-general';
  1072. disabledLock=false;
  1073. disabledjoin=true;
  1074. disabled=true;
  1075. }
  1076. else if (document.getElementById('node-edit-general') !== null)
  1077. {
  1078. editPanelID='node-edit-general';
  1079. disabled=true;
  1080. disabledjoin=true;
  1081. disabledPM=true;
  1082. disabledLock=true;
  1083. }
  1084. else if (document.getElementById('edit-panel') !== null)
  1085. {
  1086. editPanelID='edit-panel';
  1087. disabled=true;
  1088. disabledjoin=true;
  1089. disabledLock=true;
  1090. }
  1091.  
  1092.  
  1093. var sccObj = wmer_getCCSD(Waze.selectionManager.selectedItems[0].model);
  1094. if(wmer_Debug) console.dir(sccObj);
  1095.  
  1096. var urPos;
  1097. if(wmer_MapCenter)
  1098. urPos=new OpenLayers.LonLat(Waze.map.center.lon,Waze.map.center.lat);
  1099. else
  1100. urPos=new OpenLayers.LonLat(
  1101. Waze.selectionManager.selectedItems[0].geometry.bounds.left+(Waze.selectionManager.selectedItems[0].geometry.bounds.right-Waze.selectionManager.selectedItems[0].geometry.bounds.left)/2,
  1102. Waze.selectionManager.selectedItems[0].geometry.bounds.top-(Waze.selectionManager.selectedItems[0].geometry.bounds.top-Waze.selectionManager.selectedItems[0].geometry.bounds.bottom)/2
  1103. );
  1104. urPos.transform(new OpenLayers.Projection("EPSG:900913"),new OpenLayers.Projection("EPSG:4326"));
  1105.  
  1106. var osmName=WmeR_GetCityFromOSM(urPos,parseInt(getQueryString(wmer_generate_permalink(), 'zoom')),sccObj.country);
  1107. if(sccObj.country === '')
  1108. {
  1109. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': sccObj.country=""; work with osmName!!!');
  1110. // попытка центрировать...
  1111. //var osmName=WmeR_GetCityFromOSM(urPos,parseInt(getQueryString(wmer_generate_permalink(), 'zoom')),sccObj.country);
  1112. switch(osmName.country_code)
  1113. {
  1114. case 'ru': sccObj.country='Russia'; break;
  1115. case 'by': sccObj.country='Belarus'; break;
  1116. case 'uz': sccObj.country='Uzbekistan'; break;
  1117. case 'kz': sccObj.country='Kazakhstan'; break;
  1118. case 'ua': sccObj.country='Ukraine'; break;
  1119. case 'lt': sccObj.country='Lithuania'; break;
  1120. }
  1121. }
  1122. if (checkPosKG(urPos) && sccObj.country==='Ukraine')
  1123. {
  1124. sccObj.country='Russia';
  1125. }
  1126.  
  1127. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': sccObj.cityID=' + sccObj.cityID + ', sccObj.country='+sccObj.country);
  1128. var idCL=(sccObj.country=='Russia'?0:(sccObj.country=='Belarus'?1:(sccObj.country=='Uzbekistan'?2:(sccObj.country=='Kazakhstan'?3:(sccObj.country==='Ukraine'?4:(sccObj.country==='Lithuania'?5:-1))))));
  1129. if(idCL == -1)
  1130. {
  1131. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': idCL = ' +idCL + ', sccObj.country='+sccObj.country);
  1132. idCL=0;
  1133. }
  1134.  
  1135. if(!document.getElementById(CreateID()))
  1136. {
  1137. // add new edit tab to left of the map
  1138. var srsCtrl = document.createElement('div');
  1139. srsCtrl.id = CreateID();
  1140.  
  1141. // inject new tab
  1142. var userTabs = document.getElementById('edit-panel');
  1143. var navTabs = getElementsByClassName('nav-tabs', userTabs)[0];
  1144. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': typeof navTabs=' + (typeof navTabs));
  1145. if (typeof navTabs !== "undefined")
  1146. {
  1147. var tabContent = getElementsByClassName('tab-content', userTabs)[0];
  1148.  
  1149. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': typeof tabContent=' + (typeof tabContent));
  1150. if (typeof tabContent !== "undefined")
  1151. {
  1152. newtab = document.createElement('li');
  1153. newtab.innerHTML = '<a href="#' + CreateID() + '" id="pwmerequest" data-toggle="tab">'+(wmer_LanguageRU?'Запросы':'Requests')+'</a>';
  1154. navTabs.appendChild(newtab);
  1155.  
  1156. var padding="padding:5px 9px";
  1157. var html= /*'<hr>'+*/
  1158. '<div class="form-group">'+
  1159. '<h4>WME Requests <sup>' + wmer_Version + '</sup>&nbsp;<sub><a href="https://greasyfork.org/ru/scripts/5085-wme-requests" title="Link" target="_blank"><span class="fa fa-external-link"></span></a></sub></h4>'+
  1160. '<form class="attributes-form side-panel-section" action="javascript:return false;">'+
  1161. '<div class="controls-container">' +
  1162. '<label class="control-label">' + (wmer_LanguageRU?'Общие':'Common') +'</label>' +
  1163. '<label><a href="' + CL[idCL].dr + '" id="wmerA_dr" target="_gdocRequest" title="' + sccObj.country + '">' + (wmer_LanguageRU?'Таблица':'Table') +'</a></label> | '+
  1164. '<label><a href="https://www.waze.com/forum/viewtopic.php?p=662218#p662218" title="City Lock ' + wmer_Version + '" target="_blank">' + (wmer_LanguageRU?'О проекте':'About') +'</a></label></br>'+
  1165. '<button id="wmerBtn_lock" class="btn btn-default" style="font-size:9px;'+padding+'" title="'+
  1166. (wmer_LanguageRU?'Отправить запрос на изменение уровня блокировки объектов':'Send a request to lock/unlock segment(s)')+
  1167. '"><i class="fa fa-unlock"></i>&nbsp;Lock</button>&nbsp;' +
  1168. '<button id="wmerBtn_join" class="btn btn-default" style="font-size:9px;'+padding+'" title="'+
  1169. (wmer_LanguageRU?'Отправить запрос на присоединение сегментов':'Send a request to join several segments')+
  1170. '"><i class="fa fa-cogs"></i>&nbsp;Join</button>&nbsp;' +
  1171. '<button id="wmerBtn_dir" class="btn btn-default" style="font-size:9px;'+padding+'" title="'+
  1172. (wmer_LanguageRU?'Отправить запрос на изменение направления движения сегментов':'Send a request to change the direction of segment(s)')+
  1173. '"><i class="fa fa-random"></i>&nbsp;Dir</button>&nbsp;' +
  1174. '<button id="wmerBtn_turn" class="btn btn-default" style="font-size:9px;'+padding+'" title="'+
  1175. (wmer_LanguageRU?'Отправить запрос на изменение разрешения поворотов':'Send a request to change the turn restriction.')+
  1176. '"><i class="fa fa-arrows-alt"></i>&nbsp;Turn</button>&nbsp;' +
  1177. '<button id="wmerBtn_closures" class="btn btn-default" style="font-size:9px;'+padding+'" title="'+
  1178. (wmer_LanguageRU?'Отправить запрос на изменение перекрытие сегментов':'Send a request to change the Real Time Closures.')+
  1179. '"><i class="fa fa-calendar"></i>&nbsp;Closures</button>' +
  1180. '</div></div>' +
  1181.  
  1182.  
  1183. '<div class="form-group">'+
  1184. '<label class="control-label">' + (wmer_LanguageRU?'CityLock':'CityLock') +'</label>' +
  1185. '<div class="controls-container">' +
  1186. '<label><a href="' + CL[idCL].d + '" id="wmerA_d" target="_gdocRequest" title="' + sccObj.country + '">' + (wmer_LanguageRU?'Таблица':'Table') +'</a></label> | '+
  1187. '<label><a href="https://www.waze.com/forum/viewtopic.php?f=787&t=105793" title="City Lock ' + wmer_Version + '" target="_blank">' + (wmer_LanguageRU?'О проекте':'About') +'</a></label></br>'+
  1188. '<button id="wmerBtn_cl" class="btn btn-default" style="font-size:9px;'+padding+'" title="'+
  1189. (wmer_LanguageRU?'Отправить запрос на изменение наименования населенного пункта':'Send a request to CityLock')+
  1190. '"><i class="fa fa-home"></i>&nbsp;City</button>'+
  1191. '&nbsp;<span id="wmerChangeState0"></span>' +
  1192. '&nbsp;<span id="wmerCitySave0"></span></br>' +
  1193. '<label><span id="wmerCityID"></span><br>'+
  1194. '<span id="wmerStateID"></span></label>';
  1195. html += ''+
  1196. '<div class="controls-container">' +
  1197. '<label>Language from OSM:</label>' +
  1198. '<select class="form-control" id="wmerEdt_country" title="Для запросов по созданию/изменению НП принудительно задавать язык получемых данных из OSM">';
  1199.  
  1200. for(var cli=0; cli < CL.length; ++cli)
  1201. html+='<option value="'+cli+'">'+CL[cli].c+'</option>';
  1202.  
  1203. html += ''+
  1204. '</select>'+
  1205. '</div>'+
  1206. '<div class="controls-container" style="display:none">' +
  1207. '<input name="wmerChk_county" value="" id="wmerChk_county" type="checkbox"><label for="wmerChk_county" title="'+(wmer_LanguageRU?'Добавлять РАЙОН в название НП':'Adding DISTRICT in the name of the locality')+'">&nbsp;'+(wmer_LanguageRU?'Добавлять район':'Add District')+'</label><br>' +
  1208. '</div>' +
  1209. '</br><label><span id="wmerLatLon"></span></label>'+
  1210. '</div></div>' +
  1211.  
  1212. '<div class="form-group">'+
  1213. '<label class="control-label">TTS '+CL[idCL].ttst +'</label>' +
  1214. '<div class="controls-container">' +
  1215. '<label><a href="' + CL[idCL].ttsd + '" id="wmerTTS_d" target="_gdocRequest" title="TTS '+CL[idCL].ttst +'">' + (wmer_LanguageRU?'Таблица':'Table') +'</a></label> | '+
  1216. '<label><a href="https://www.waze.com/forum/viewtopic.php?f=785&t=148400" title="'+CL[idCL].ttst +' - новый TTS-голос" target="_blank">' + (wmer_LanguageRU?'О проекте':'About') +'</a></label></br>'+
  1217. '<button id="wmerBtn_tts" class="btn btn-default" style="font-size:9px;'+padding+'" title="'+
  1218. (wmer_LanguageRU?'Отправить запрос по проблеме произношения или сокращения в Waze TTS '+CL[idCL].ttst:'Send a request to the pronunciation problem or reduction in Waze TTS '+CL[idCL].ttst)+
  1219. '"><i class="fa fa-volume-up"></i>&nbsp;TTS</button></br>' +
  1220. '</div></div>' +
  1221.  
  1222. '<div class="form-group">'+
  1223. '<label class="control-label">' + (wmer_LanguageRU?'Прочее':'Other') +'</label>' +
  1224. '<div class="controls-container">' +
  1225. '<button id="wmerBtn_pm" class="btn btn-default" style="font-size:9px;'+padding+'" title="'+
  1226. (wmer_LanguageRU?'Отправить приватное сообщение в форум авторам выделенных объектов':'Send (in forum) a Private Message to the author of the segment')+
  1227. '"><li class="fa fa-envelope"></li>&nbsp;PM</button>'+
  1228. '</div></div>';
  1229.  
  1230.  
  1231.  
  1232. html += ''+
  1233. '<div class="form-group">' +
  1234. '<label class="control-label">' + (wmer_LanguageRU?'Настройки':'Config') +'</label>';
  1235.  
  1236. html += ''+
  1237. '<div class="controls-container">' +
  1238. '<label>E-mail:' +
  1239. '<input title="' + (wmer_LanguageRU?'Ваш e-mail адрес':'Your e-mail address') +'" type="text" class="form-control" autocomplete="off" id="wmerEdt_email" name="wmerEdt_email" value="" size="15"/></label><br>' +
  1240. '</div>'+
  1241. '<div class="controls-container">' +
  1242. '<input name="wmerChk_mapcenter" value="" id="wmerChk_mapcenter" type="checkbox"><label for="wmerChk_mapcenter" title="'+(wmer_LanguageRU?'Брать координаты центра карты':'Брать координаты центра карты')+'">Map Center</label>' +
  1243. '</div>'+
  1244. '<div class="controls-container">' +
  1245. '<input name="wmerEdt_lang" value="" id="wmerEdt_lang" type="checkbox"><label for="wmerEdt_lang" title="'+(wmer_LanguageRU?'Принудительно использовать русскоязычный интерфейс для WME Request':'Forced to use Russian-language interface for WM Request')+'">Russian UI</label>' +
  1246. '</div>'+
  1247. '<div class="controls-container">' +
  1248. '<input name="wmerChk_debug" value="" id="wmerChk_debug" type="checkbox"><label for="wmerChk_debug" title="'+(wmer_LanguageRU?'Включить логирование':'Enable debug script')+'">Debug script</label><br>' +
  1249. '</div>'+
  1250. '</form>'+
  1251. '</div>' +
  1252. '';
  1253.  
  1254. srsCtrl.innerHTML = html;
  1255. //srsCtrl.id = "sidepanel-wmerequest";
  1256. srsCtrl.className = "tab-pane";
  1257. tabContent.appendChild(srsCtrl);
  1258. }
  1259. else
  1260. srsCtrl.id='';
  1261. }
  1262. else
  1263. srsCtrl.id='';
  1264. //http://www.earthtools.org/sun/51.65500265464235/39.18297673378902/22/1/99/0
  1265. //document.getElementById(editPanelID).appendChild(srsCtrl);
  1266.  
  1267. if(srsCtrl.id !== '')
  1268. {
  1269. document.getElementById('wmerBtn_lock').onclick = click_WMERequest;
  1270. document.getElementById('wmerBtn_dir').onclick = click_WMERequest;
  1271. document.getElementById('wmerBtn_turn').onclick = click_WMERequest;
  1272. document.getElementById('wmerBtn_closures').onclick = click_WMERequest;
  1273. document.getElementById('wmerBtn_join').onclick = click_WMERequest;
  1274. document.getElementById('wmerBtn_pm').onclick = click_submitPMForm;
  1275. document.getElementById('wmerBtn_cl').onclick = click_WMERequest;
  1276. document.getElementById('wmerBtn_tts').onclick = click_WMERequest;
  1277. }
  1278.  
  1279. //var permalink=wmer_generate_permalink();
  1280. //var p = document.getElementsByClassName('WazeControlMousePosition')[0].innerHTML.replace(' ', '').split(',');
  1281. //var p = document.getElementsByClassName('WazeControlMousePosition')[0].lastChild.innerHTML.split(' ');
  1282. //permalink=permalink.replace(/#/g, "").replace(/&lat=([0-9\.]+)/g, '&lat='+p[1]).replace(/&lon=([0-9\.]+)/g, '&lon='+p[0]);
  1283. /*
  1284. if (typeof Waze.selectionManager.selectedItems[0].geometry.x !== "undefined")
  1285. {
  1286. // корректировка пермалинка для камеры, жанкшина и Place (point)
  1287. var urPos=new OpenLayers.LonLat(Waze.selectionManager.selectedItems[0].geometry.x,Waze.selectionManager.selectedItems[0].geometry.y);
  1288. urPos.transform(new OpenLayers.Projection("EPSG:900913"),new OpenLayers.Projection("EPSG:4326")); // {lon, lat}
  1289. permalink=permalink.replace(/#/g, "").replace(/&lat=([0-9\.]+)/g, '&lat='+urPos.lat).replace(/&lon=([0-9\.]+)/g, '&lon='+urPos.lon);
  1290. }
  1291. */
  1292. //document.getElementById('wmerCityID').innerHTML='<small><a href="'+permalink+'">cityID: '+sccObj.cityID+'</a></small>';
  1293. //document.getElementById('wmerCityID').innerHTML='<small>cityID: '+sccObj.cityID+'</small>';
  1294. /*
  1295. if(Waze.loginManager.user.rank >= 4)
  1296. {
  1297. document.getElementById('wmerCityID').innerHTML+='&nbsp;(<small><a style="cursor: pointer" title="Save the name of the new city in the Google Table" id="wmerA_cl">save</a></small>)';
  1298. document.getElementById('wmerA_cl').onclick = click_WMERequest;
  1299. }
  1300. */
  1301.  
  1302. //document.getElementById('wmerLatLon').innerHTML='<small>'+p[0]+','+p[1]+'</a></small>';
  1303.  
  1304. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'initialised');
  1305. }
  1306.  
  1307. if(document.getElementById(CreateID()) != null)
  1308. {
  1309.  
  1310. // ********************
  1311. if(document.getElementById('wmerA_dr'))
  1312. {
  1313. document.getElementById('wmerA_dr').href=CL[idCL].dr;
  1314. document.getElementById('wmerA_dr').title=sccObj.country;
  1315. }
  1316. if(document.getElementById('wmerA_d'))
  1317. {
  1318. document.getElementById('wmerA_d').href=CL[idCL].d;
  1319. document.getElementById('wmerA_d').title=sccObj.country;
  1320. }
  1321.  
  1322. // ********************
  1323. if(document.getElementById('wmerCityID'))
  1324. {
  1325. //console.log("osmName.cityName=",osmName.cityName)
  1326. if (sccObj.country === 'Russia') // need script!
  1327. //document.getElementById('wmerCityID').innerHTML='<small>cityID: <a href="http://fias.nalog.ru/?'+osmName.cityName+'" target="_blank">'+sccObj.cityID+'</a></small>';
  1328. document.getElementById('wmerCityID').innerHTML='<small><a href="http://fias.nalog.ru/?'+sccObj.city+' ('+sccObj.stateName+'" title="Проверить имя в fias" target="_blank">cityID:</a> <span id="__clpCI" style="cursor:pointer;" title="Копировать CityID">'+sccObj.cityID+'</span></small>';
  1329. else
  1330. document.getElementById('wmerCityID').innerHTML='<small>cityID: <span id="__clpCI" style="cursor:pointer;" title="Копировать cityID">'+sccObj.cityID+'</span></small>';
  1331. document.getElementById('__clpCI').onclick=function(){clipboard.copy(this.innerText);}
  1332. }
  1333. if(document.getElementById('wmerStateID'))
  1334. {
  1335. document.getElementById('wmerStateID').innerHTML='<small>stateID: <span id="__clpSI" style="cursor:pointer;" title="Копировать stateID">'+sccObj.stateID+'</span></small>';
  1336. document.getElementById('__clpSI').onclick=function(){clipboard.copy(this.innerText);}
  1337. }
  1338.  
  1339.  
  1340. // ********************
  1341. // config e-mail
  1342. if(document.getElementById('wmerEdt_email'))
  1343. {
  1344. document.getElementById('wmerEdt_email').value=WMERequestEmail;
  1345. document.getElementById('wmerEdt_email').onchange=function(){WMERequestEmail=this.value;localStorage.setItem('WMERequestEmail', WMERequestEmail);}
  1346. }
  1347.  
  1348. if(document.getElementById('wmerEdt_country'))
  1349. {
  1350. document.getElementById("wmerEdt_country").selectedIndex = WMERequestCountry;
  1351. document.getElementById("wmerEdt_country").onchange = function(){WMERequestCountry=parseInt(this.value);localStorage.setItem("WMERequestCountry",WMERequestCountry);};
  1352. }
  1353.  
  1354. // ********************
  1355. // config language
  1356. if (document.getElementById('wmerEdt_lang'))
  1357. {
  1358. var WMELanguageRU=localStorage.getItem("WMELanguageRU");
  1359. if (WMELanguageRU)
  1360. wmer_LanguageRU=WMELanguageRU === "1"?true:false;
  1361. document.getElementById('wmerEdt_lang').checked=wmer_LanguageRU;
  1362. document.getElementById('wmerEdt_lang').onchange=function(){wmer_LanguageRU=this.checked;localStorage.setItem('WMELanguageRU', wmer_LanguageRU?"1":"0");}
  1363. }
  1364.  
  1365. // ********************
  1366. // config debug
  1367. document.getElementById('wmerChk_debug').checked=wmer_Debug;
  1368. document.getElementById('wmerChk_debug').onchange=function(){wmer_Debug=this.checked;localStorage.setItem('wmer_Debug', wmer_Debug?"1":"0");}
  1369.  
  1370.  
  1371. document.getElementById('wmerChk_mapcenter').checked=wmer_MapCenter;
  1372. document.getElementById('wmerChk_mapcenter').onchange=function(){wmer_MapCenter=this.checked;localStorage.setItem('WMERequestMapCenter', wmer_MapCenter?"1":"0");}
  1373.  
  1374. // ********************
  1375. // config debug AddCounty
  1376. document.getElementById('wmerChk_county').checked=wmer_AddCounty;
  1377. document.getElementById('wmerChk_county').onchange=function(){wmer_AddCounty=this.checked;localStorage.setItem('WMERequestAddCounty', wmer_AddCounty?"1":"0");}
  1378.  
  1379.  
  1380. // ********************
  1381. if(sccObj.country==='Russia')
  1382. {
  1383. document.getElementById('wmerChangeState0').innerHTML=
  1384. '<button id="wmerCS_cl" class="btn btn-default" style="font-size:9px;'+padding+'" title="'+
  1385. (wmer_LanguageRU?'Изменить район':'Change State')+
  1386. '"><i class="fa fa-map-marker"></i>&nbsp;State</button>';
  1387.  
  1388. document.getElementById('wmerCS_cl').onclick = click_WMERequest;
  1389. }
  1390.  
  1391. if(Waze.loginManager.user.rank >= 4 || (sccObj.country=='Belarus' && Waze.loginManager.user.rank >= 3)) // ??? Uzbekistan ???
  1392. {
  1393. document.getElementById('wmerCitySave0').innerHTML=
  1394. '<button id="wmerA_cl" class="btn btn-default" style="font-size:9px;'+padding+'" title="'+
  1395. (wmer_LanguageRU?'Сохранить имя нового НП в Google-таблице':'Save the name of the new city in the Google Table')+
  1396. '"><i class="fa fa-floppy-o"></i>&nbsp;Save</button>';
  1397.  
  1398. //document.getElementById('wmerCityID').innerHTML+='&nbsp;(<small><a style="cursor: pointer" title="Save the name of the new city in the Google Table" id="wmerA_cl">save</a></small>)';
  1399. document.getElementById('wmerA_cl').onclick = click_WMERequest;
  1400. }
  1401. }
  1402.  
  1403. if(document.getElementById(CreateID()) != null)
  1404. {
  1405. document.getElementById('wmerBtn_lock').disabled=disabledLock;
  1406. document.getElementById('wmerBtn_dir').disabled=disabled;
  1407. document.getElementById('wmerBtn_turn').disabled=disabled;
  1408. document.getElementById('wmerBtn_closures').disabled=disabled;
  1409. document.getElementById('wmerBtn_join').disabled=disabled;
  1410. document.getElementById('wmerBtn_pm').disabled=disabledPM;
  1411. document.getElementById('wmerBtn_cl').disabled=disabled;
  1412. //document.getElementById('wmerBtn_tts').disabled=disabled;
  1413. if(document.getElementById('wmerA_cl'))
  1414. document.getElementById('wmerA_cl').disabled=disabled;
  1415. if(document.getElementById('wmerCS_cl'))
  1416. document.getElementById('wmerCS_cl').disabled=disabled;
  1417.  
  1418. }
  1419. }
  1420.  
  1421.  
  1422. // <WME Fancy permalink> - http://userscripts.org/users/548866
  1423. function getId(node) {
  1424. return document.getElementById(node);
  1425. }
  1426.  
  1427. function getForumUserIdFromID(wmeUserID)
  1428. {
  1429. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'call getForumUserIdFromID(' + wmeUserID + ')');
  1430. var userName=Waze.model.users.get(wmeUserID);
  1431. if(wmer_Debug) console.dir(userName);
  1432. return (getForumUserIdFromName(userName.userName));
  1433. }
  1434.  
  1435. function getForumUserIdFromName(userName)
  1436. {
  1437. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'call getForumUserIdFromName(' + userName + ')');
  1438. var forumID=-1;
  1439. var forumIDs=new Array();
  1440.  
  1441. if (userName.indexOf('/')!=-1)
  1442. {
  1443. var userNames=userName.split('/');
  1444. for (var i=0; i<userNames.length; i++)
  1445. {
  1446. forumID=getForumUserIdFromName(userNames[i]);
  1447. forumIDs[i]=forumID[0];
  1448. }
  1449. return forumIDs;
  1450. }
  1451.  
  1452. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'looking for ' + userName + ' in the forum.');
  1453.  
  1454. var xhr3_object;
  1455.  
  1456. if(window.XMLHttpRequest) // Firefox & Chrome
  1457. xhr3_object = new XMLHttpRequest();
  1458. else if(window.ActiveXObject) // Internet Explorer
  1459. xhr3_object = new ActiveXObject("Microsoft.XMLHTTP");
  1460.  
  1461. xhr3_object.open("GET", "https://www.waze.com/forum/memberlist.php?username=" + userName, false);
  1462.  
  1463. xhr3_object.onreadystatechange = function() {
  1464. if(xhr3_object.readyState == 4)
  1465. {
  1466. var test = xhr3_object.responseText.match(/u=([0-9]+)"/g);
  1467. if (test==null)
  1468. {
  1469. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'Forum return null');
  1470. return(-1); // no match
  1471. }
  1472. if (test.length>1)
  1473. {
  1474. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'Forum return multiple match:');
  1475. if(wmer_Debug) console.dir(test);
  1476. return(-2); // multiple match
  1477. }
  1478. forumID=test[0].substring(2, test[0].length-1);
  1479. }
  1480. };
  1481.  
  1482. if(wmer_Debug) console.dir(xhr3_object);
  1483.  
  1484. try {
  1485. xhr3_object.send(null);
  1486. }
  1487. catch (err) {
  1488. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'XMLHttpRequest error: ' +err.name);
  1489. if(wmer_Debug) console.dir(err);
  1490. return(-3);
  1491. }
  1492. forumIDs[0]=forumID;
  1493. return (forumIDs);
  1494. }
  1495.  
  1496. function click_submitPMForm()
  1497. {
  1498. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'click_submitPMForm() start');
  1499. if (typeof Waze.selectionManager === "undefined")
  1500. {
  1501. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'Waze.selectionManager not found');
  1502. return;
  1503. }
  1504.  
  1505. if (Waze.selectionManager.selectedItems.length == 0)
  1506. {
  1507. alert(wmer_LanguageRU?'Сначала необходимо выделить сегмент':'Please, select one segment before');
  1508. return false;
  1509. }
  1510.  
  1511. //-------------
  1512. var sccObjs=new Array();
  1513. for (var i=0; i < Waze.selectionManager.selectedItems.length; ++i)
  1514. {
  1515. var sccObj = wmer_getCCSD(Waze.selectionManager.selectedItems[i].model);
  1516. if (sccObj.userID==-1)
  1517. {
  1518. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'PM request - Do not PM Admin!');
  1519. alert("Can't PM admin!");
  1520. return false;
  1521. }
  1522.  
  1523. var j;
  1524. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'sccObj.userID='+sccObj.userID);
  1525. for (j=0; j < wmer_UserCache.length; j+=2)
  1526. {
  1527. if (wmer_UserCache[j] === sccObj.userID)
  1528. {
  1529. sccObj.forumuserID=wmer_UserCache[j+1];
  1530. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'found ['+j+']'+wmer_UserCache[j+1]);
  1531. break;
  1532. }
  1533. }
  1534.  
  1535. if (sccObj.forumuserID == "")
  1536. {
  1537. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'not found '+sccObj.userID);
  1538. sccObj.forumuserID=getForumUserIdFromID(sccObj.userID);
  1539. wmer_UserCache.push(sccObj.userID,sccObj.forumuserID);
  1540. }
  1541.  
  1542. sccObjs.push(sccObj);
  1543. }
  1544.  
  1545. var forumIDs=new Array();
  1546. for (var i=0; i < sccObjs.length; ++i)
  1547. forumIDs[i]=sccObjs[i].forumuserID;
  1548. //-------------
  1549.  
  1550. if (forumIDs.length==1 && forumIDs[0]==-1)
  1551. {
  1552. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'PM request - User never logged to the forum...');
  1553. alert(wmer_LanguageRU?'Автор сегмента не найден на форуме':'Sorry: unable to find the user in the forum');
  1554. return false;
  1555. }
  1556. if (forumIDs.length==1 && forumIDs[0]==-2)
  1557. {
  1558. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'PM request - Several users match name. Should never happen :s');
  1559. alert(wmer_LanguageRU?'Найдено более одного пользователя\nОтправьте сообщение самостоятельно.':'Sorry: more than one user found in the forum.\nYou should look for him/her by yourself.');
  1560. return false;
  1561. }
  1562. if (forumIDs.length==1 && forumIDs[0]==-3)
  1563. {
  1564. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'A network error occurred.');
  1565. alert(wmer_LanguageRU?'Сетевые проблемы\nОтправьте сообщение самостоятельно.':'Sorry: a network error occurred.\nYou should look for him/her by yourself.');
  1566. return false;
  1567. }
  1568.  
  1569. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'PM request - all OK. go to PM!');
  1570.  
  1571. var formID="WMER-PM-FORM";
  1572.  
  1573. var nodePM;
  1574.  
  1575. if (getId("WMER-PM-Send") == null)
  1576. {
  1577. nodePM= document.createElement('div');
  1578. nodePM.id = 'WMER-PM-Send';
  1579. nodePM.style.display='hidden';
  1580. getId(CreateID()).appendChild(nodePM);
  1581. }
  1582. else
  1583. {
  1584. nodePM=getId("WMER-PM-Send");
  1585. }
  1586.  
  1587. var PMForm;
  1588. PMForm='<form id="' + formID + '" target="_blank" method="post" style="display: inline">';
  1589. PMForm+='<input id="' + formID + '-subject" type="hidden" name="subject" value="" />';
  1590. PMForm+='<input type="hidden" name="addbbcode20" value="100" />';
  1591. PMForm+='<input id="' + formID + '-message" type="hidden" name="message" value="" />';
  1592. PMForm+='<input type="hidden" name="preview" value="Preview" />';
  1593. PMForm+='<input type="hidden" name="attach_sig" value="on" />';
  1594. PMForm+='<input id="' + formID + '-ct" type="hidden" name="creation_time" value="0" />';
  1595. PMForm+='<input id="' + formID + '-lc" type="hidden" name="lastclick" value="0" />';
  1596. for (var i=0; i<forumIDs.length; i++)
  1597. {
  1598. PMForm+='<input type="hidden" name="address_list[u]['+forumIDs[i]+']" value="to" />';
  1599. }
  1600. PMForm+='</form>';
  1601. nodePM.innerHTML=PMForm;
  1602.  
  1603. var permalink=wmer_generate_permalink();
  1604. //if(wmer_Debug) console.log(permalink);
  1605. var name_object=""
  1606. linkParts=permalink.replace(/#/g, "").split('&');
  1607. for (var j=0; j<linkParts.length; j++)
  1608. {
  1609. if (linkParts[j].indexOf("segments=")==0 || linkParts[j].indexOf("venues=")==0 || linkParts[j].indexOf("cameras=")==0 || linkParts[j].indexOf("bigJunctions=")==0)
  1610. {
  1611. name_object=linkParts[j].split('=')[0]
  1612. linkParts.splice (j,1);
  1613. break;
  1614. }
  1615. }
  1616. permalink=linkParts.join('&');
  1617.  
  1618. if(wmer_Debug) console.dir(linkParts);
  1619.  
  1620. var message=wmer_LanguageRU?
  1621. 'Есть вопросы по правкам в [url=' + permalink + ']этой области редактирования[/url]:\n\n':
  1622. 'Some questions about [url=' + permalink + ']this area[/url]:\n\n';
  1623.  
  1624. function NullToEmpty(s)
  1625. {
  1626. return !s?"":s;
  1627. }
  1628. function GetTypeName(s)
  1629. {
  1630. if(wmer_LanguageRU)
  1631. {
  1632. switch(s)
  1633. {
  1634. case "segment": return "сегмент"
  1635. case "venue": return "ПОИ"
  1636. case "node": return "узел"
  1637. case "camera": return "камера"
  1638. case "bigJunction": return "развязка"
  1639. }
  1640. }
  1641. return s
  1642. //'+(wmer_LanguageRU?'Категории':'Categories')+'
  1643. }
  1644.  
  1645. for (var i=0; i < sccObjs.length; ++i)
  1646. {
  1647. var on=sccObjs[i].type === "segment"?(wmer_LanguageRU?'Улица':"Street"):(wmer_LanguageRU?'Название':"Name");
  1648. message += ''
  1649. + (wmer_LanguageRU?'Автор':'Author')+': [b]' + sccObjs[i].username + '[/b]\n'
  1650. + (wmer_LanguageRU?'Тип':'Type')+': [b]' + GetTypeName(sccObjs[i].type) + '[/b]\n'
  1651. + (sccObj.country=='Belarus'?'':(wmer_LanguageRU?'Страна':'Country')+': [b]' + sccObjs[i].country + '[/b]\n')
  1652. + (wmer_LanguageRU?'НП':'City')+': [b]' + NullToEmpty(sccObjs[i].city) + '[/b]\n'
  1653. + (sccObjs[i].poiaddress.length > 0?(wmer_LanguageRU?'Адрес':'Address')+': [b]'+sccObjs[i].poiaddress+'[/b]\n':'')
  1654. + on+ ': [b]' + NullToEmpty(sccObjs[i].street) + '[/b]\n'
  1655. + (wmer_LanguageRU?'Дата':'Date')+': [b]' + timeConverter(sccObjs[i].updatedOn).replace('+',' ') + '[/b]\n'
  1656. + (wmer_LanguageRU?'Ссылка':'Permalink')+': [url]' + permalink + '&' + name_object + '=' + sccObjs[i].objid + '[/url]\n'
  1657. + (wmer_LanguageRU?'Дополнительно':'Description')+': {' + NullToEmpty(sccObjs[i].description) + '\n}\n'
  1658. + '\n';
  1659. }
  1660. //if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + message);
  1661.  
  1662. getId(formID + '-message').value=message;
  1663. var now=new Date().getTime();
  1664. now /= 1000;
  1665. now = Math.floor(now);
  1666. getId(formID + '-ct').value=now;
  1667. getId(formID + '-lc').value=now;
  1668.  
  1669. getId(formID).action="https://www.waze.com/forum/ucp.php?i=pm&mode=compose&action=post";
  1670. getId(formID + '-subject').value=
  1671. wmer_LanguageRU?
  1672. '[WME Request] Уточнение по правкам':
  1673. '[WME Request] Question about map edits';
  1674.  
  1675. if(wmer_Debug) console.dir(getId(formID));
  1676.  
  1677. getId(formID).submit();
  1678. return true; // this forces to open in new tab!
  1679. }
  1680. // </WME Fancy permalink>
  1681.  
  1682.  
  1683. function wmer_WazeBits()
  1684. {
  1685. // if (typeof Waze === "undefined")
  1686. // Waze=unsafeWindow.Waze;
  1687.  
  1688. if (typeof Waze === "undefined")
  1689. Waze=window.Waze;
  1690. }
  1691.  
  1692.  
  1693. function wmer_HandCreateRequest()
  1694. {
  1695. if ((typeof arguments[0]) === "object")
  1696. {
  1697. switch(arguments[0].type)
  1698. {
  1699. case 'click': // click button
  1700. {
  1701. var e=document.getElementById(arguments[0].id);
  1702. if(e)
  1703. e.click();
  1704.  
  1705. break;
  1706. }
  1707. }
  1708. }
  1709. }
  1710.  
  1711. function wmer_initBindKey() {
  1712. var Config =[
  1713. {handler: 'WMERequest_Lock', title: "Запрос на изменение уровня блокировки объекта", func:wmer_HandCreateRequest , key:-1, arg:{type:'click',id:'wmerBtn_lock'}},
  1714. {handler: 'WMERequest_Join', title: "Запрос на присоединение сегментов", func:wmer_HandCreateRequest , key:-1, arg:{type:'click',id:'wmerBtn_join'}},
  1715. {handler: 'WMERequest_Dir', title: "Запрос на изменение направления сегментов", func:wmer_HandCreateRequest , key:-1, arg:{type:'click',id:'wmerBtn_dir'}},
  1716. {handler: 'WMERequest_Turn', title: "Запрос на изменение разрешения поворотов", func:wmer_HandCreateRequest , key:-1, arg:{type:'click',id:'wmerBtn_turn'}},
  1717. {handler: 'WMERequest_Closures', title: "Запрос на перекрытие сегментов", func:wmer_HandCreateRequest , key:-1, arg:{type:'click',id:'wmerBtn_closures'}},
  1718. {handler: 'WMERequest_City', title: "Запрос на создание/изменение НП", func:wmer_HandCreateRequest , key:-1, arg:{type:'click',id:'wmerBtn_cl'}},
  1719. ];
  1720. /*
  1721. Waze.loginManager.user.editableCountryIDs
  1722. 186 - Russia
  1723. 180 - Poland
  1724. 123 - Latvia
  1725. 37 - Belarus
  1726. 129 - Lithuania
  1727. 232 - Ukraine
  1728. */
  1729. if(Waze.loginManager.user.rank >= 4 || (Waze.loginManager.user.editableCountryIDs.indexOf(37) >= 0 && Waze.loginManager.user.rank >= 3)) // ??? Uzbekistan ???
  1730. {
  1731. Config.push({handler: 'WMERequest_CitySave', title: "Сохранить название НП", func:wmer_HandCreateRequest , key:-1, arg:{type:'click',id:'wmerA_cl'}});
  1732. }
  1733.  
  1734. for(var i=0; i < Config.length; ++i)
  1735. {
  1736. WMEKSRegisterKeyboardShortcut('WME-Requests', 'WME-Requests', Config[i].handler, Config[i].title, Config[i].func, Config[i].key, Config[i].arg);
  1737. }
  1738.  
  1739. WMEKSLoadKeyboardShortcuts('WME-Requests');
  1740.  
  1741. window.addEventListener("beforeunload", function() {
  1742. WMEKSSaveKeyboardShortcuts('WME-Requests');
  1743. }, false);
  1744.  
  1745. }
  1746.  
  1747. function wmer_FakeLoad()
  1748. {
  1749. wmer_WazeBits();
  1750.  
  1751. if (typeof Waze === "undefined")
  1752. {
  1753. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'Waze not found, retrying in 500ms...');
  1754. setTimeout(wmer_FakeLoad,500);
  1755. return;
  1756. }
  1757. if (typeof Waze.selectionManager === "undefined")
  1758. {
  1759. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'Waze.selectionManager not found, retrying in 500ms...');
  1760. setTimeout(wmer_FakeLoad,500);
  1761. return;
  1762. }
  1763. if (typeof Waze.model === "undefined")
  1764. {
  1765. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'Waze.model not found, retrying in 500ms...');
  1766. setTimeout(wmer_FakeLoad,500);
  1767. return;
  1768. }
  1769.  
  1770. try {
  1771. Waze.selectionManager.events.register("selectionchanged", null, wmer_insertButton);
  1772. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'added event handler for selectionchanged');
  1773. }
  1774. catch (err) {
  1775. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'added event handler error: ' +err.name);
  1776. }
  1777. setTimeout(wmer_initBindKey, 500);
  1778. }
  1779.  
  1780.  
  1781. function wmer_Init() {
  1782. if(wmer_Debug) console.log('WME Requests v.' + wmer_Version + ': ' + 'init');
  1783. setTimeout(wmer_FakeLoad, 500);
  1784. }
  1785.  
  1786.  
  1787. function wmer_bootstrap()
  1788. {
  1789. wmer_LanguageRU=I18n.locale === "ru"?true:false;
  1790.  
  1791. wmer_Debug = __GetLocalStorageItem("wmer_Debug",'bool',false);
  1792. WMELanguageRU = __GetLocalStorageItem("WMELanguageRU",'bool',false);
  1793. wmer_MapCenter = __GetLocalStorageItem("WMERequestMapCenter",'bool',false);
  1794. wmer_AddCounty = true;//__GetLocalStorageItem("WMERequestAddCounty",'bool',false);
  1795. WMERequestEmail = __GetLocalStorageItem("WMERequestEmail",'string','');
  1796. WMERequestCountry= __GetLocalStorageItem("WMERequestCountry",'int',0);
  1797.  
  1798. wmer_Init();
  1799. }
  1800.  
  1801. wmer_bootstrap();
  1802.  
  1803.  
  1804. function __GetLocalStorageItem(Name,Type,Def,Arr)
  1805. {
  1806. //if (wme2GIS_debug) console.log("__GetLocalStorageItem(): Name="+Name+",Type="+Type+",Def="+Def+",Arr="+Arr);
  1807. var tmp0=localStorage.getItem(Name);
  1808. if (tmp0)
  1809. {
  1810. switch(Type)
  1811. {
  1812. case 'string':
  1813. break;
  1814. case 'bool':
  1815. tmp0=(tmp0 === "true" || tmp0 === "1")?true:false;
  1816. break;
  1817. case 'int':
  1818. tmp0=(!isNaN(parseInt(tmp0)))?parseInt(tmp0):0;
  1819. break;
  1820. case 'arr':
  1821. if (tmp0.length > 0)
  1822. if(!Arr[tmp0])
  1823. tmp0=Def;
  1824. break;
  1825. }
  1826. }
  1827. else
  1828. tmp0=Def;
  1829. return tmp0;
  1830. }
  1831.  
  1832.  
  1833.  
  1834. // from: https://greasyfork.org/ru/scripts/16071-wme-keyboard-shortcuts (modify)
  1835. /*
  1836. when adding shortcuts each shortcut will need a uniuque name
  1837. the command to add links is WMERegisterKeyboardShortcut(ScriptName, ShortcutsHeader, NewShortcut, ShortcutDescription, FunctionToCall, ShortcutKeysObj) {
  1838. ScriptName: This is the name of your script used to track all of your shortcuts on load and save.
  1839. ScriptName: replace 'WMEAwesome' with your scripts name such as 'SomeOtherScript'
  1840. ShortcutsHeader: this is the header that will show up in the keyboard editor
  1841. NewShortcut: This is the name of the shortcut and needs to be uniuque from all of the other shortcuts, from other scripts, and WME
  1842. ShortcutDescription: This wil show up as the text next to your shortcut
  1843. FunctionToCall: this is the name of your function that will be called when the keyboard shortcut is presses
  1844. ShortcutKeysObj: the is the object representing the keys watched set this to '-1' to let the users specify their own shortcuts.
  1845. ShortcutKeysObj: The alt, shift, and ctrl keys are A=alt, S=shift, C=ctrl. for short cut to use "alt shift ctrl and l" the object would be 'ASC+l'
  1846. */
  1847. function WMEKSRegisterKeyboardShortcut(a,b,c,d,e,f,g){try{I18n.translations[I18n.locale].keyboard_shortcuts.groups[a].members.length}catch(c){Waze.accelerators.Groups[a]=[],Waze.accelerators.Groups[a].members=[],I18n.translations[I18n.locale].keyboard_shortcuts.groups[a]=[],I18n.translations[I18n.locale].keyboard_shortcuts.groups[a].description=b,I18n.translations[I18n.locale].keyboard_shortcuts.groups[a].members=[]}if(e&&"function"==typeof e){I18n.translations[I18n.locale].keyboard_shortcuts.groups[a].members[c]=d,Waze.accelerators.addAction(c,{group:a});var i="-1",j={};j[i]=c,Waze.accelerators._registerShortcuts(j),null!==f&&(j={},j[f]=c,Waze.accelerators._registerShortcuts(j)),W.accelerators.events.register(c,null,function(){e(g)})}else alert("The function "+e+" has not been declared")}function WMEKSLoadKeyboardShortcuts(a){if(console.log("WMEKSLoadKeyboardShortcuts("+a+")"),localStorage[a+"KBS"])for(var b=JSON.parse(localStorage[a+"KBS"]),c=0;c<b.length;c++)try{Waze.accelerators._registerShortcuts(b[c])}catch(a){console.log(a)}}function WMEKSSaveKeyboardShortcuts(a){console.log("WMEKSSaveKeyboardShortcuts("+a+")");var b=[];for(var c in Waze.accelerators.Actions){var d="";if(Waze.accelerators.Actions[c].group==a){Waze.accelerators.Actions[c].shortcut?(Waze.accelerators.Actions[c].shortcut.altKey===!0&&(d+="A"),Waze.accelerators.Actions[c].shortcut.shiftKey===!0&&(d+="S"),Waze.accelerators.Actions[c].shortcut.ctrlKey===!0&&(d+="C"),""!==d&&(d+="+"),Waze.accelerators.Actions[c].shortcut.keyCode&&(d+=Waze.accelerators.Actions[c].shortcut.keyCode)):d="-1";var e={};e[d]=Waze.accelerators.Actions[c].id,b[b.length]=e}}localStorage[a+"KBS"]=JSON.stringify(b)}
  1848. /* ********************************************************** */
  1849.  
  1850. // from https://github.com/lgarron/clipboard.js/blob/master/clipboard.min.js
  1851. // АХТУНГ!!! если вызов в $.ajax, то ставим параметр "async: false,"
  1852. (function(f,c){"undefined"!==typeof module?module.exports=c():"function"===typeof define&&"object"===typeof define.amd?define(c):this[f]=c()})("clipboard",function(){if(!document.addEventListener)return null;var f={};f.copy=function(){function c(){d=!1;b=null;e&&window.getSelection().removeAllRanges();e=!1}var d=!1,b=null,e=!1;document.addEventListener("copy",function(c){if(d){for(var e in b)c.clipboardData.setData(e,b[e]);c.preventDefault()}});return function(g){return new Promise(function(k,f){d=!0;b="string"===typeof g?{"text/plain":g}:g instanceof Node?{"text/html":(new XMLSerializer).serializeToString(g)}:g;try{var n=document.getSelection();if(!document.queryCommandEnabled("copy")&&n.isCollapsed){var l=document.createRange();l.selectNodeContents(document.body);n.addRange(l);e=!0}if(document.execCommand("copy"))c(),k();else throw Error("Unable to copy. Perhaps it's not available in your browser?");}catch(p){c(),f(p)}})}}();f.paste=function(){var c=!1,d,b;document.addEventListener("paste",function(e){if(c){c=!1;e.preventDefault();var g=d;d=null;g(e.clipboardData.getData(b))}});return function(e){return new Promise(function(g,f){c=!0;d=g;b=e||"text/plain";try{document.execCommand("paste")||(c=!1,f(Error("Unable to paste. Pasting only works in Internet Explorer at the moment.")))}catch(m){c=!1,f(Error(m))}})}}();"undefined"===typeof ClipboardEvent&&"undefined"!==typeof window.clipboardData&&"undefined"!==typeof window.clipboardData.setData&&(function(c){function d(a,b){return function(){a.apply(b,arguments)}}function b(a){if("object"!=typeof this)throw new TypeError("Promises must be constructed via new");if("function"!=typeof a)throw new TypeError("not a function");this._value=this._state=null;this._deferreds=[];l(a,d(f,this),d(k,this))}function e(a){var b=this;return null===this._state?void this._deferreds.push(a):void p(function(){var c=b._state?a.onFulfilled:a.onRejected;if(null===c)return void(b._state?a.resolve:a.reject)(b._value);var h;try{h=c(b._value)}catch(d){return void a.reject(d)}a.resolve(h)})}function f(a){try{if(a===this)throw new TypeError("A promise cannot be resolved with itself.");if(a&&("object"==typeof a||"function"==typeof a)){var b=a.then;if("function"==typeof b)return void l(d(b,a),d(f,this),d(k,this))}this._state=!0;this._value=a;m.call(this)}catch(c){k.call(this,c)}}function k(a){this._state=!1;this._value=a;m.call(this)}function m(){for(var a=0,b=this._deferreds.length;b>a;a++)e.call(this,this._deferreds[a]);this._deferreds=null}function n(a,b,c,h){this.onFulfilled="function"==typeof a?a:null;this.onRejected="function"==typeof b?b:null;this.resolve=c;this.reject=h}function l(a,b,c){var h=!1;try{a(function(a){h||(h=!0,b(a))},function(a){h||(h=!0,c(a))})}catch(d){h||(h=!0,c(d))}}var p=b.immediateFn||"function"==typeof setImmediate&&setImmediate||function(a){setTimeout(a,1)},q=Array.isArray||function(a){return"[object Array]"===Object.prototype.toString.call(a)};b.prototype["catch"]=function(a){return this.then(null,a)};b.prototype.then=function(a,c){var d=this;return new b(function(b,f){e.call(d,new n(a,c,b,f))})};b.all=function(){var a=Array.prototype.slice.call(1===arguments.length&&q(arguments[0])?arguments[0]:arguments);return new b(function(b,c){function d(e,g){try{if(g&&("object"==typeof g||"function"==typeof g)){var k=g.then;if("function"==typeof k)return void k.call(g,function(a){d(e,a)},c)}a[e]=g;0===--f&&b(a)}catch(l){c(l)}}if(0===a.length)return b([]);for(var f=a.length,e=0;e<a.length;e++)d(e,a[e])})};b.resolve=function(a){return a&&"object"==typeof a&&a.constructor===b?a:new b(function(b){b(a)})};b.reject=function(a){return new b(function(b,c){c(a)})};b.race=function(a){return new b(function(b,c){for(var d=0,e=a.length;e>d;d++)a[d].then(b,c)})};"undefined"!=typeof module&&module.exports?module.exports=b:c.Promise||(c.Promise=b)}(this),f.copy=function(c){return new Promise(function(d,b){if("string"!==typeof c&&!("text/plain"in c))throw Error("You must provide a text/plain type.");window.clipboardData.setData("Text","string"===typeof c?c:c["text/plain"])?d():b(Error("Copying was rejected."))})},f.paste=function(){return new Promise(function(c,d){var b=window.clipboardData.getData("Text");b?c(b):d(Error("Pasting was rejected."))})});return f});
  1853. /* ********************************************************** */