Modifications

Widget:CartoFab

224 octets supprimés, 21 février 2017 à 11:05
aucun résumé de modification
<noinclude>
Proto de développement de[[widget:CarteFablabs]]
inspiration: http://www.mediawikiwidgets.org/w/index.php?title=Widget:Google_Maps&action=edit
item
nom artlab
adresse 11ème ParisParislabel
site http://www.digitalarti.com/fr/blog/artlab_blog
long 2.3
ne pas effacer ! ça sert !
{{#ask: [[Category:Fablabs]] [[long::!:]]
|?long # -
|?latt #label
|?site
|?adresse
|?intitulé
|?structures
|format=json
|limit=500
}} : tous les fablabs qui ont une longitude...
 
 
tous les fablabs en format CSV :
{{#ask: [[Category:Fablabs]]
|?long # -
|?intitulé
|?structures
|format=jsoncsv|limit=500
}}
 
 
 
 
cartographie tous les fablabs
{{#ask: [[Category:Fablabs]] [[intitulé::fablab]]
|?long # -
|?latt #
|?intitulé
|?structures
|limit=500
}}
 
 
<script src="http://cdn.leafletjs.com/leaflet-0.4/leaflet.js"></script>
<div id="<!--{$nom|escape:'quotes'|default:'carte'}-->" style="width: <!--{$largeur|escape:'quotes'|default:'720700'}-->px; height: <!--{$hauteur|escape:'quotes'|default:'420'}-->px"></div>csv<div id="nombreLabos">chargement...</div>
<script>
 /////////fonction pour recuperer la liste des coords des labsfunction requete(url) {if (window.XMLHttpRequest) // Mozilla, Safari,...fin javaload  xhr = new XMLHttpRequest();else if (window.ActiveXObject) xhr var cartofab = new ActiveXObject("MicrosoftL.XMLHTTP");if map('<!xhr) --{ alert("Abandon $nom|escape:'quotes'|default: Impossible de créer une instance Ajax"'carte'}-->'); return false;}xhr.onreadystatechange = reponse;xhr.opensetView("GET"[<!--{$longitude|escape:'quotes'|default:'47'}-->, url<!--{$latitude|escape:'quotes'|default:'1.7'}-->], true<!--{$zoom|escape:'quotes'|default:'5'}-->);xhr.send(null);}
function reponse() {
if (xhr.readyState == 4) {
if (xhr.status == 200) {
//alert(xhr.responseText);
// add an OpenStreetMap tile layer
L.tileLayer('http://{s}.tile.osm.org/{z}/{x}/{y}.png', {
attribution: '&copy; <a href="http://osm.org/copyright">OpenStreetMap</a> contributors'
}).addTo(cartofab);
//le fichier arrive en CSV (valeurs séparées par des virgules)var lignes=new RegExp("[\n]+", "g");//alert(responseText);var tableau=xhr.responseText.split(lignes);var colones=new RegExp("[,]+", "g");for(var i=1;i<tableau.length-1;i++) {
//appel de la liste des labs
document.getElementById("nombreLabos").innerHTML = "Recherche des labs...";
var donneesnumLabs=tableau[i].split(colones)0;
var coords=new Array$.ajax(donnees[2],donnees[1]); var nom=donnees[0];{ var url=donnees[3]; var intitule=donnees[5];: 'Sp%C3%A9cial:Ask/-5B-5BCategory:Fablabs-5D-5D-20-5B-5Blong::!:-5D-5D/-3FLong-23-2D/-3FLatt-23label/-3FSite/-3FAdresse/-3FIntitul%C3%A9/-3FStructures/type de lieu var structure=donnees[6];limit%3D500/searchlabel%3D/structure juridiqueformat%3Djson', data: { format: 'json' }, dataType: 'json', success: function(jsondata) {
// alert(coords[0]); L.marker([coords[0], coords[1]]).addTo(cartofab).bindPopup("<b><a href="+url+" target=\"_blank\">"+nom+"</a></b><br/>"+intitule+"<br/>"+structure); } document.getElementById("nombreLabos").innerHTML = "Il ya actuellement "+tableau.length+" laboratoires renseignés sur cette page";document.getElementById("nombreLabos")console.innerHTML =responseText; } else { alertlog("La requête AJAX a rencontré un problème .jsondata."results); } }}
$.each(jsondata.results, function(i,item){ numLabs++;console.log(numLabs);
///////////fin javaload Intitulés=""; for(var j= 0; j < item.printouts.Intitulé.length; j++) { Intitulés=Intitulés+" "+item.printouts.Intitulé[j].fulltext; } structures=""; for(var k= 0; k < item.printouts.Structures.length; k++) { structures=structures+" "+item.printouts.Structures[k].fulltext; }
L.marker([item.printouts.Latt[0],item.printouts.Long[0]]).addTo(cartofab).bindPopup("<b><a href="+item.printouts.Site[0]+" target=\"_blank\">"+i+"</a></b><br/>"+Intitulés+"<br/>"+structures);
var cartofab = L.map('<!--{$nom|escape:'quotes'|default:'carte'}-->').setView([<!--{$longitude|escape:'quotes'|default:'47'}-->, <!--{$latitude|escape:'quotes'|default:'1.7'}-->], <!--{$zoom|escape:'quotes'|default:'5'}-->);
L.tileLayer('http://{s}.tile.cloudmade.com/7ad1b23bf3f347f8b0ab2416f66737fc/997/256/{z}/{x}/{y}.png', { maxZoom: 18, attribution: 'Map data &copy; <a href="http://openstreetmap.org">OpenStreetMap</a> contributors, <a href="http://creativecommons.org/licenses/by-sa/2.0/">CC-BY-SA</a>, Imagery © <a href="http://cloudmade.com">CloudMade</a>' }).addTo(cartofab);
}); document.getElementById("nombreLabos").innerHTML = "Il ya actuellement "+numLabs+" Labos renseignés sur cette page";
//appel de la liste des labsrequete("Sp%C3%A9cial:Ask/-5B-5BCategory:Fablabs-5D-5D/-3FLong-23-2D/-3FLatt-23-2D/-3FSite/-3FAdresse/-3FIntitul%C3%A9/-3FStructures/limit%3D50/format%3Djson/sep%3D,/headers%3Dshow"); }
});
$.getJSON("Sp%C3%A9cial:Ask/-5B-5BCategory:Fablabs-5D-5D/-3FLong-23-2D/-3FLatt-23-2D/-3FSite/-3FAdresse/-3FIntitul%C3%A9/-3FStructures/limit%3D50/searchlabel%3D/format%3Djson",
function(data) {
$.each(data.items, function(i,item){
alert(item.Label);
});
});
</script>
 
<noinclude>
 
àvoir requete json semantik mieux
 
 
 
=====documentation=====
 
http://semantic-mediawiki.org/wiki/Serialization_%28JSON%29
 
https://www.mediawiki.org/wiki/Category:Snippets_with_JavaScript
</noinclude>