Modifications

Aller à : navigation, rechercher

Widget:CartoFab

447 octets ajouté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 # -
|?structures
|format=csv
|limit=500
}}
 
 
 
 
cartographie tous les fablabs
{{#ask: [[Category:Fablabs]] [[intitulé::fablab]]
|?long # -
|?latt #
|?site
|?adresse
|?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><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);
 
 
//appel de la liste des labs
document.getElementById("nombreLabos").innerHTML = "Recherche des labs...";
 
numLabs=0;
 
$.ajax({
url: '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/limit%3D500/searchlabel%3D/format%3Djson',
data: {
format: 'json'
},
dataType: 'json',
success: function(jsondata) {
 
console.log(jsondata.results);
 
 
 
$.each(jsondata.results, function(i,item){
numLabs++;
console.log(numLabs);
 
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);
 
 
 
 
 
});
document.getElementById("nombreLabos").innerHTML = "Il ya actuellement "+numLabs+" Labos renseignés sur cette page";
//le fichier arrive en CSV (valeurs séparées par des virgules)
var lignes=new RegExp("[\n]+", "g");
var tableau=xhr.responseText.split(lignes);
var colones=new RegExp("[,]+", "g");
for(var i=1;i<tableau.length-1;i++)
{
var coords=tableau[i].split(colones);
// alert(coords[0]);
L.marker([coords[2], coords[1]]).addTo(map).bindPopup("<b><a href="+coords[3]+" target=\"_blank\">"+coords[0]+"</a></b>");
}
document.getElementById("nombreLabos").innerHTML = "Il ya actuellement "+tableau.length+" laboratoires renseignés sur cette page";
}
else {
alert("La requête AJAX a rencontré un problème ..");
}
}
}
});
///////////fin javaload
</script>
var map = L.map('<!--{$nom|escape:'quotes'|default:'carte'}--noinclude>').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(map);àvoir requete json semantik mieux
=====documentation=====
//appel de la liste des labsrequete("Sp%C3%A9cialhttp:Ask/-5B-5BCategory:Fablabs-5D-5D/semantic-3FLong-23-2Dmediawiki.org/-3FLatt-23-2D/-3FSite/limit%3D150wiki/formatSerialization_%3Dcsv/sep%3D,/headers28JSON%3Dshow");29
https://www.mediawiki.org/wiki/Category:Snippets_with_JavaScript</scriptnoinclude>

Menu de navigation