Modifications

Widget:CartoFab

364 octets supprimés, 21 février 2017 à 11:05
aucun résumé de modification
<noinclude>
Proto de développement de[[widget:CarteFablabs]]
|longitude=51(optionnel)
$.each(data.items, function(i,item){ $("<img/>").attr("src", item.media.m).appendTo("#images"); if ( i == 3 ) return false; });
|latitude=3.56(optionnel)
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 labs/fin javaload function requete(url) {if (window.XMLHttpRequest) // Mozilla, Safari,... xhr var cartofab = new XMLHttpRequestL.map('<!--{$nom|escape:'quotes'|default:'carte'}-->');else if (window.ActiveXObject) xhr = new ActiveXObjectsetView("Microsoft[<!--{$longitude|escape:'quotes'|default:'47'}-->, <!--{$latitude|escape:'quotes'|default:'1.XMLHTTP");if (7'}-->], <!xhr) --{ alert("Abandon $zoom|escape:'quotes'|default: Impossible de créer une instance Ajax"'5'}-->); return false;}xhr.onreadystatechange = reponse;xhr// add an OpenStreetMap tile layerL.opentileLayer('http://{s}.tile.osm.org/{z}/{x}/{y}.png', { attribution: '&copy; <a href="GEThttp://osm.org/copyright", url, true>OpenStreetMap</a> contributors'});xhr.sendaddTo(nullcartofab);}
function reponse() {if (xhr.readyState == 4) { if (xhr.status == 200) {
//alertappel de la liste des labsdocument.getElementById(xhr"nombreLabos").innerHTML = "Recherche des labs..responseText).";
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/le fichier arrive en CSV (valeurs séparées par des virgules)var lignes=new RegExp("[\n]+"searchlabel%3D/format%3Djson', "g");//alert(responseText); data: {var tableau=xhr.responseText.split(lignes); format: 'json'var colones=new RegExp("[ },]+" dataType: 'json', "g");for success: function(var i=1;i<tableau.length-1;i++jsondata) {
console.log(jsondata.results);
var donnees=tableau[i].split(colones);
var coords=new Array(donnees[2],donnees[1]);
var nom=donnees[0];
var url=donnees[3];
var intitule=donnees[5];//type de lieu
var structure=donnees[6];//structure juridique
// alert $.each(coords[0]); Ljsondata.markerresults, function([coords[0]i, coords[1]]item).addTo(cartofab).bindPopup("<b><a href="+url+" target=\"_blank\">"+nom+"</a></b><br/>"+intitule+"<br/>"+structure);{ } document.getElementById("nombreLabos").innerHTML = "Il ya actuellement " numLabs+tableau.length+" laboratoires renseignés sur cette page";documentconsole.getElementByIdlog("nombreLabos"numLabs).innerHTML =responseText; } else { alert("La requête AJAX a rencontré un problème .."); } }}
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);
///////////fin javaload
var cartofab = L.map('<!--{$nom|escape:'quotes'|default:'carte' }-->'); document.setViewgetElementById([<!--{$longitude|escape:'quotes'|default:'47'}-->, <!--{$latitude|escape:'quotes'|default:'1"nombreLabos").7'}-->], <!--{$zoom|escape:'quotes'|default:'5'}-->)innerHTML = "Il ya actuellement "+numLabs+" Labos renseignés sur cette page";
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);
}
});
//appel de la liste des labs
requete("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/format%3Djson/sep%3D,/headers%3Dshow", function(json) {
$.each(json.items, function(i,item){
alert(item[0]);
});
});
</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>