mirror of
				https://github.com/commons-app/apps-android-commons.git
				synced 2025-10-26 12:23:58 +01:00 
			
		
		
		
	* Fixes #4595 - Updated nearby query * Removed logic to replace local language in nearby query - that might acccidentally replace other strings * Fetch property location in usual nearby query
This commit is contained in:
		
							parent
							
								
									174b4760ab
								
							
						
					
					
						commit
						74ec73ebd6
					
				
					 3 changed files with 106 additions and 180 deletions
				
			
		|  | @ -1,60 +0,0 @@ | ||||||
| SELECT |  | ||||||
|       (SAMPLE(?location) as ?location) |  | ||||||
|       ?item |  | ||||||
|       (SAMPLE(COALESCE(?itemLabelPreferredLanguage, ?itemLabelAnyLanguage)) as ?label) |  | ||||||
|       (SAMPLE(COALESCE(?itemDescriptionPreferredLanguage, ?itemDescriptionAnyLanguage, "?")) as ?description) |  | ||||||
|       (SAMPLE(?classId) as ?class) |  | ||||||
|       (SAMPLE(COALESCE(?classLabelPreferredLanguage, ?classLabelAnyLanguage, "?")) as ?classLabel) |  | ||||||
|       (SAMPLE(COALESCE(?icon0, ?icon1)) as ?icon) |  | ||||||
|       ?wikipediaArticle |  | ||||||
|       ?commonsArticle |  | ||||||
|       (SAMPLE(?commonsCategory) as ?commonsCategory) |  | ||||||
|       (SAMPLE(?pic) as ?pic) |  | ||||||
|     WHERE { |  | ||||||
|       # Around given location... |  | ||||||
|       SERVICE wikibase:around { |  | ||||||
|         ?item wdt:P625 ?location. |  | ||||||
|         bd:serviceParam wikibase:center "Point(${LONG} ${LAT})"^^geo:wktLiteral. |  | ||||||
|         bd:serviceParam wikibase:radius "${RAD}" . # Radius in kilometers. |  | ||||||
|       } |  | ||||||
| 
 |  | ||||||
|       { ?item p:P1435 ?monument } UNION { ?item p:P2186 ?monument } UNION { ?item p:P1459 ?monument } UNION { ?item p:P1460 ?monument } UNION { ?item p:P1216 ?monument } UNION { ?item p:P709 ?monument } UNION { ?item p:P718 ?monument } UNION { ?item p:P5694 ?monument } |  | ||||||
| 
 |  | ||||||
|       # Get Commons category (P373) |  | ||||||
|       OPTIONAL { ?item wdt:P373 ?commonsCategory. } |  | ||||||
| 
 |  | ||||||
|       # Get (P18) |  | ||||||
|       OPTIONAL { ?item wdt:P18 ?pic. } |  | ||||||
| 
 |  | ||||||
|       # Get the label in the preferred language of the user, or any other language if no label is available in that language. |  | ||||||
|       OPTIONAL {?item rdfs:label ?itemLabelPreferredLanguage. FILTER (lang(?itemLabelPreferredLanguage) = "${LANG}")} |  | ||||||
|       OPTIONAL {?item rdfs:label ?itemLabelAnyLanguage} |  | ||||||
| 
 |  | ||||||
|       # Get the description in the preferred language of the user, or any other language if no description is available in that language. |  | ||||||
|       OPTIONAL {?item schema:description ?itemDescriptionPreferredLanguage. FILTER (lang(?itemDescriptionPreferredLanguage) = "${LANG}")} |  | ||||||
|       OPTIONAL {?item schema:description ?itemDescriptionAnyLanguage } |  | ||||||
| 
 |  | ||||||
|       # Get the class label in the preferred language of the user, or any other language if no label is available in that language. |  | ||||||
|       OPTIONAL { |  | ||||||
|         ?item p:P31/ps:P31 ?classId. |  | ||||||
|         OPTIONAL {?classId rdfs:label ?classLabelPreferredLanguage. FILTER (lang(?classLabelPreferredLanguage) = "")} |  | ||||||
|         OPTIONAL {?classId rdfs:label ?classLabelAnyLanguage} |  | ||||||
| 
 |  | ||||||
|         OPTIONAL { |  | ||||||
|             ?wikipediaArticle   schema:about ?item ; |  | ||||||
|                                 schema:isPartOf <https://.wikipedia.org/> . |  | ||||||
|           } |  | ||||||
|         OPTIONAL { |  | ||||||
|             ?wikipediaArticle   schema:about ?item ; |  | ||||||
|                                 schema:isPartOf <https://en.wikipedia.org/> . |  | ||||||
|             SERVICE wikibase:label { bd:serviceParam wikibase:language "en" } |  | ||||||
|           } |  | ||||||
| 
 |  | ||||||
|           OPTIONAL { |  | ||||||
|             ?commonsArticle   schema:about ?item ; |  | ||||||
|                                 schema:isPartOf <https://commons.wikimedia.org/> . |  | ||||||
|             SERVICE wikibase:label { bd:serviceParam wikibase:language "en" } |  | ||||||
|           } |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|     GROUP BY ?item ?wikipediaArticle ?commonsArticle |  | ||||||
|  | @ -1,66 +1,56 @@ | ||||||
| SELECT | SELECT | ||||||
|      (SAMPLE(?location) as ?location) |   ?item | ||||||
|      ?item |   (SAMPLE(?location) as ?location) | ||||||
|      (SAMPLE(COALESCE(?itemLabelPreferredLanguage, ?itemLabelAnyLanguage)) as ?label) |   (SAMPLE(?label) AS ?label) | ||||||
|      (SAMPLE(COALESCE(?itemDescriptionPreferredLanguage, ?itemDescriptionAnyLanguage, "?")) as ?description) |   (SAMPLE(?description) AS ?description) | ||||||
|      (SAMPLE(?classId) as ?class) |   (SAMPLE(?class) AS ?class) | ||||||
|      (SAMPLE(COALESCE(?classLabelPreferredLanguage, ?classLabelAnyLanguage, "?")) as ?classLabel) |   (SAMPLE(?classLabel) AS ?classLabel) | ||||||
|      (SAMPLE(COALESCE(?icon0, ?icon1)) as ?icon) |   (SAMPLE(?pic) AS ?pic) | ||||||
|      ?wikipediaArticle |   (SAMPLE(?destroyed) AS ?destroyed) | ||||||
|      ?commonsArticle |   (SAMPLE(?endTime) AS ?endTime) | ||||||
|      (SAMPLE(?commonsCategory) as ?commonsCategory) |   (SAMPLE(?wikipediaArticle) AS ?wikipediaArticle) | ||||||
|      (SAMPLE(?pic) as ?pic) |   (SAMPLE(?commonsArticle) AS ?commonsArticle) | ||||||
|      (SAMPLE(?destroyed) as ?destroyed) |   (SAMPLE(?commonsCategory) AS ?commonsCategory) | ||||||
|      (SAMPLE(?endTime) as ?endTime) | WHERE { | ||||||
|    WHERE { |   # Around given location | ||||||
|      # Around given location... |   SERVICE wikibase:around { | ||||||
|      SERVICE wikibase:around { |     ?item wdt:P625 ?location. | ||||||
|        ?item wdt:P625 ?location. |     bd:serviceParam wikibase:center "Point(${LONG} ${LAT})"^^geo:wktLiteral. # Longitude latitude | ||||||
|        bd:serviceParam wikibase:center "Point(${LONG} ${LAT})"^^geo:wktLiteral. |     bd:serviceParam wikibase:radius "${RAD}". # Radius in kilometers. | ||||||
|        bd:serviceParam wikibase:radius "${RAD}" . # Radius in kilometers. |   } | ||||||
|      } |  | ||||||
| 
 | 
 | ||||||
|      # Get the label in the preferred language of the user, or any other language if no label is available in that language. |   OPTIONAL { | ||||||
|      OPTIONAL {?item rdfs:label ?itemLabelPreferredLanguage. FILTER (lang(?itemLabelPreferredLanguage) = "${LANG}")} |   ?item p:P31/ps:P31 ?class. | ||||||
|      OPTIONAL {?item rdfs:label ?itemLabelAnyLanguage} |   } | ||||||
| 
 | 
 | ||||||
|      # Get the description in the preferred language of the user, or any other language if no description is available in that language. |   # Get picture | ||||||
|      OPTIONAL {?item schema:description ?itemDescriptionPreferredLanguage. FILTER (lang(?itemDescriptionPreferredLanguage) = "${LANG}")} |   OPTIONAL {?item wdt:P18 ?pic} | ||||||
|      OPTIONAL {?item schema:description ?itemDescriptionAnyLanguage } |  | ||||||
| 
 | 
 | ||||||
|      # Get Commons category (P373) |   # Get existence | ||||||
|      OPTIONAL { ?item wdt:P373 ?commonsCategory. } |   OPTIONAL {?item wdt:P576 ?destroyed} | ||||||
|  |   OPTIONAL {?item wdt:P582 ?endTime} | ||||||
| 
 | 
 | ||||||
|      # Get (P18) |   # Get Commons category | ||||||
|      OPTIONAL { ?item wdt:P18 ?pic. } |   OPTIONAL {?item wdt:P373 ?commonsCategory} | ||||||
| 
 | 
 | ||||||
|      # Get (P576) |   # Get Wikipedia article | ||||||
|      OPTIONAL { ?item wdt:P576 ?destroyed. } |   OPTIONAL { | ||||||
|  |     ?wikipediaArticle schema:about ?item. | ||||||
|  |     ?wikipediaArticle schema:isPartOf <https://${LANG}.wikipedia.org/>. | ||||||
|  |   } | ||||||
| 
 | 
 | ||||||
|      # Get (P582) |   # Get Commons article | ||||||
|      OPTIONAL { ?item wdt:P582 ?endTime. } |   OPTIONAL { | ||||||
|  |     ?commonsArticle schema:about ?item. | ||||||
|  |     ?commonsArticle schema:isPartOf <https://commons.wikimedia.org/>. | ||||||
|  |   } | ||||||
| 
 | 
 | ||||||
|      # Get the class label in the preferred language of the user, or any other language if no label is available in that language. |   # Labels and descriptions | ||||||
|      OPTIONAL { |   SERVICE wikibase:label { | ||||||
|        ?item p:P31/ps:P31 ?classId. |     bd:serviceParam wikibase:language "${LANG},en,fr,de,es,ja,ru,it,zh,pt,ar,fa,pl,nl,id,uk,he,sv,cs,ko,vi,ca,no,fi,hu,tr,th,hi,bn,ceb,ro,sw,kk,da,eo,sr,lt,sk,bg,sl,eu,et,hr,ms,el,arz,ur,ta,te,nn,gl,az,af,bs,be,ml,ka,is,sq,uz,la,br,mk,lv,azb,mr,sh,tl,cy,ckb,ast,be-tarask,zh-yue,hy,pa,as,my,kn,ne,si,tt,ha,war,zh-min-nan,vo,min,lmo,ht,lb,gu,tg,sco,ku,new,bpy,nds,io,pms,su,oc,jv,nap,ba,scn,wa,bar,an,ksh,szl,fy,frr,als,ia,ga,yi,mg,gd,vec,ce,sa,mai,xmf,sd,wuu,mrj,mhr,km,roa-tara,am,roa-rup,map-bms,bh,mnw,shn,bcl,co,cv,dv,nds-nl,fo,hif,fur,gan,glk,hak,ilo,pam,csb,avk,lij,li,gv,mi,mt,nah,nrm,se,nov,qu,os,pi,pag,ps,pdc,rm,bat-smg,sc,to,tk,hsb,fiu-vro,vls,yo,diq,zh-classical,frp,lad,kw,mn,haw,ang,ln,ie,wo,tpi,ty,crh,nv,jbo,ay,pcd,zea,eml,ky,ig,or,cbk-zam,kg,arc,rmy,ab,gn,so,kab,ug,stq,udm,ext,mzn,pap,cu,sah,tet,sn,lo,pnb,iu,na,got,bo,dsb,chr,cdo,om,sm,ee,ti,av,bm,zu,pnt,cr,pih,ss,ve,bi,rw,ch,xh,kl,ik,bug,dz,ts,tn,kv,tum,xal,st,tw,bxr,ak,ny,fj,lbe,za,ks,ff,lg,sg,rn,chy,mwl,lez,bjn,gom,tyv,vep,nso,kbd,ltg,rue,pfl,gag,koi,krc,ace,olo,kaa,mdf,myv,srn,ady,jam,tcy,dty,atj,kbp,din,lfn,gor,inh,sat,hyw,nqo,ban,szy,awa,ary,lld,smn,skr,mad,dag,shi,nia,ki,gcr". | ||||||
|        OPTIONAL {?classId rdfs:label ?classLabelPreferredLanguage. FILTER (lang(?classLabelPreferredLanguage) = "${LANG}")} |     ?item rdfs:label ?label. | ||||||
|        OPTIONAL {?classId rdfs:label ?classLabelAnyLanguage} |     ?item schema:description ?description. | ||||||
| 
 |     ?class rdfs:label ?classLabel. | ||||||
|        OPTIONAL { |   } | ||||||
|            ?wikipediaArticle   schema:about ?item ; | } | ||||||
|                                schema:isPartOf <https://${LANG}.wikipedia.org/> . | GROUP BY ?item | ||||||
|          } |  | ||||||
|        OPTIONAL { |  | ||||||
|            ?wikipediaArticle   schema:about ?item ; |  | ||||||
|                                schema:isPartOf <https://en.wikipedia.org/> . |  | ||||||
|            SERVICE wikibase:label { bd:serviceParam wikibase:language "en" } |  | ||||||
|          } |  | ||||||
| 
 |  | ||||||
|          OPTIONAL { |  | ||||||
|            ?commonsArticle   schema:about ?item ; |  | ||||||
|                                schema:isPartOf <https://commons.wikimedia.org/> . |  | ||||||
|            SERVICE wikibase:label { bd:serviceParam wikibase:language "en" } |  | ||||||
|          } |  | ||||||
|      } |  | ||||||
|    } |  | ||||||
|    GROUP BY ?item ?wikipediaArticle ?commonsArticle |  | ||||||
|  | @ -1,71 +1,67 @@ | ||||||
| SELECT | SELECT | ||||||
|      (SAMPLE(?location) as ?location) |   ?item | ||||||
|      ?item |   (SAMPLE(?location) as ?location) | ||||||
|      (SAMPLE(COALESCE(?itemLabelPreferredLanguage, ?itemLabelAnyLanguage)) as ?label) |   (SAMPLE(?label) AS ?label) | ||||||
|      (SAMPLE(COALESCE(?itemDescriptionPreferredLanguage, ?itemDescriptionAnyLanguage, "?")) as ?description) |   (SAMPLE(?description) AS ?description) | ||||||
|      (SAMPLE(?classId) as ?class) |   (SAMPLE(?class) AS ?class) | ||||||
|      (SAMPLE(COALESCE(?classLabelPreferredLanguage, ?classLabelAnyLanguage, "?")) as ?classLabel) |   (SAMPLE(?classLabel) AS ?classLabel) | ||||||
|      (SAMPLE(COALESCE(?icon0, ?icon1)) as ?icon) |   (SAMPLE(?pic) AS ?pic) | ||||||
|      ?wikipediaArticle |   (SAMPLE(?destroyed) AS ?destroyed) | ||||||
|      ?commonsArticle |   (SAMPLE(?endTime) AS ?endTime) | ||||||
|      (SAMPLE(?commonsCategory) as ?commonsCategory) |   (SAMPLE(?wikipediaArticle) AS ?wikipediaArticle) | ||||||
|      (SAMPLE(?pic) as ?pic) |   (SAMPLE(?commonsArticle) AS ?commonsArticle) | ||||||
|      (SAMPLE(?destroyed) as ?destroyed) |   (SAMPLE(?commonsCategory) AS ?commonsCategory) | ||||||
|      (SAMPLE(?endTime) as ?endTime) |   (SAMPLE(?monument) AS ?monument) | ||||||
|      (SAMPLE(?monument) as ?monument) | WHERE { | ||||||
|    WHERE { |   # Around given location | ||||||
|      # Around given location... |   SERVICE wikibase:around { | ||||||
|      SERVICE wikibase:around { |     ?item wdt:P625 ?location. | ||||||
|        ?item wdt:P625 ?location. |     bd:serviceParam wikibase:center "Point(${LONG} ${LAT})"^^geo:wktLiteral. # Longitude latitude | ||||||
|        bd:serviceParam wikibase:center "Point(${LONG} ${LAT})"^^geo:wktLiteral. |     bd:serviceParam wikibase:radius "${RAD}". # Radius in kilometers. | ||||||
|        bd:serviceParam wikibase:radius "${RAD}" . # Radius in kilometers. |   } | ||||||
|      } |  | ||||||
| 
 | 
 | ||||||
|      OPTIONAL { |   OPTIONAL { | ||||||
|       { ?item p:P1435 ?monument } UNION { ?item p:P2186 ?monument } UNION { ?item p:P1459 ?monument } UNION { ?item p:P1460 ?monument } UNION { ?item p:P1216 ?monument } UNION { ?item p:P709 ?monument } UNION { ?item p:P718 ?monument } UNION { ?item p:P5694 ?monument } |   ?item p:P31/ps:P31 ?class. | ||||||
|      } |   } | ||||||
| 
 | 
 | ||||||
|      # Get the label in the preferred language of the user, or any other language if no label is available in that language. |   # Get picture | ||||||
|      OPTIONAL {?item rdfs:label ?itemLabelPreferredLanguage. FILTER (lang(?itemLabelPreferredLanguage) = "${LANG}")} |   OPTIONAL {?item wdt:P18 ?pic} | ||||||
|      OPTIONAL {?item rdfs:label ?itemLabelAnyLanguage} |  | ||||||
| 
 | 
 | ||||||
|      # Get the description in the preferred language of the user, or any other language if no description is available in that language. |   # Get existence | ||||||
|      OPTIONAL {?item schema:description ?itemDescriptionPreferredLanguage. FILTER (lang(?itemDescriptionPreferredLanguage) = "${LANG}")} |   OPTIONAL {?item wdt:P576 ?destroyed} | ||||||
|      OPTIONAL {?item schema:description ?itemDescriptionAnyLanguage } |   OPTIONAL {?item wdt:P582 ?endTime} | ||||||
| 
 | 
 | ||||||
|      # Get Commons category (P373) |   # Get Commons category | ||||||
|      OPTIONAL { ?item wdt:P373 ?commonsCategory. } |   OPTIONAL {?item wdt:P373 ?commonsCategory} | ||||||
| 
 | 
 | ||||||
|      # Get (P18) |   # Get Wikipedia article | ||||||
|      OPTIONAL { ?item wdt:P18 ?pic. } |   OPTIONAL { | ||||||
|  |     ?wikipediaArticle schema:about ?item. | ||||||
|  |     ?wikipediaArticle schema:isPartOf <https://${LANG}.wikipedia.org/>. | ||||||
|  |   } | ||||||
| 
 | 
 | ||||||
|      # Get (P576) |   # Get Commons article | ||||||
|      OPTIONAL { ?item wdt:P576 ?destroyed. } |   OPTIONAL { | ||||||
|  |     ?commonsArticle schema:about ?item. | ||||||
|  |     ?commonsArticle schema:isPartOf <https://commons.wikimedia.org/>. | ||||||
|  |   } | ||||||
| 
 | 
 | ||||||
|      # Get (P582) |   # Wiki Loves Monuments | ||||||
|      OPTIONAL { ?item wdt:P582 ?endTime. } |   OPTIONAL {?item p:P1435 ?monument} | ||||||
|  |   OPTIONAL {?item p:P2186 ?monument} | ||||||
|  |   OPTIONAL {?item p:P1459 ?monument} | ||||||
|  |   OPTIONAL {?item p:P1460 ?monument} | ||||||
|  |   OPTIONAL {?item p:P1216 ?monument} | ||||||
|  |   OPTIONAL {?item p:P709 ?monument} | ||||||
|  |   OPTIONAL {?item p:P718 ?monument} | ||||||
|  |   OPTIONAL {?item p:P5694 ?monument} | ||||||
| 
 | 
 | ||||||
|      # Get the class label in the preferred language of the user, or any other language if no label is available in that language. |   # Labels and descriptions | ||||||
|      OPTIONAL { |   SERVICE wikibase:label { | ||||||
|        ?item p:P31/ps:P31 ?classId. |     bd:serviceParam wikibase:language "${LANG},en,fr,de,es,ja,ru,it,zh,pt,ar,fa,pl,nl,id,uk,he,sv,cs,ko,vi,ca,no,fi,hu,tr,th,hi,bn,ceb,ro,sw,kk,da,eo,sr,lt,sk,bg,sl,eu,et,hr,ms,el,arz,ur,ta,te,nn,gl,az,af,bs,be,ml,ka,is,sq,uz,la,br,mk,lv,azb,mr,sh,tl,cy,ckb,ast,be-tarask,zh-yue,hy,pa,as,my,kn,ne,si,tt,ha,war,zh-min-nan,vo,min,lmo,ht,lb,gu,tg,sco,ku,new,bpy,nds,io,pms,su,oc,jv,nap,ba,scn,wa,bar,an,ksh,szl,fy,frr,als,ia,ga,yi,mg,gd,vec,ce,sa,mai,xmf,sd,wuu,mrj,mhr,km,roa-tara,am,roa-rup,map-bms,bh,mnw,shn,bcl,co,cv,dv,nds-nl,fo,hif,fur,gan,glk,hak,ilo,pam,csb,avk,lij,li,gv,mi,mt,nah,nrm,se,nov,qu,os,pi,pag,ps,pdc,rm,bat-smg,sc,to,tk,hsb,fiu-vro,vls,yo,diq,zh-classical,frp,lad,kw,mn,haw,ang,ln,ie,wo,tpi,ty,crh,nv,jbo,ay,pcd,zea,eml,ky,ig,or,cbk-zam,kg,arc,rmy,ab,gn,so,kab,ug,stq,udm,ext,mzn,pap,cu,sah,tet,sn,lo,pnb,iu,na,got,bo,dsb,chr,cdo,om,sm,ee,ti,av,bm,zu,pnt,cr,pih,ss,ve,bi,rw,ch,xh,kl,ik,bug,dz,ts,tn,kv,tum,xal,st,tw,bxr,ak,ny,fj,lbe,za,ks,ff,lg,sg,rn,chy,mwl,lez,bjn,gom,tyv,vep,nso,kbd,ltg,rue,pfl,gag,koi,krc,ace,olo,kaa,mdf,myv,srn,ady,jam,tcy,dty,atj,kbp,din,lfn,gor,inh,sat,hyw,nqo,ban,szy,awa,ary,lld,smn,skr,mad,dag,shi,nia,ki,gcr". | ||||||
|        OPTIONAL {?classId rdfs:label ?classLabelPreferredLanguage. FILTER (lang(?classLabelPreferredLanguage) = "${LANG}")} |     ?item rdfs:label ?label. | ||||||
|        OPTIONAL {?classId rdfs:label ?classLabelAnyLanguage} |     ?item schema:description ?description. | ||||||
| 
 |     ?class rdfs:label ?classLabel. | ||||||
|        OPTIONAL { |   } | ||||||
|            ?wikipediaArticle   schema:about ?item ; | } | ||||||
|                                schema:isPartOf <https://${LANG}.wikipedia.org/> . | GROUP BY ?item | ||||||
|          } |  | ||||||
|        OPTIONAL { |  | ||||||
|            ?wikipediaArticle   schema:about ?item ; |  | ||||||
|                                schema:isPartOf <https://en.wikipedia.org/> . |  | ||||||
|            SERVICE wikibase:label { bd:serviceParam wikibase:language "en" } |  | ||||||
|          } |  | ||||||
| 
 |  | ||||||
|          OPTIONAL { |  | ||||||
|            ?commonsArticle   schema:about ?item ; |  | ||||||
|                                schema:isPartOf <https://commons.wikimedia.org/> . |  | ||||||
|            SERVICE wikibase:label { bd:serviceParam wikibase:language "en" } |  | ||||||
|          } |  | ||||||
|      } |  | ||||||
|    } |  | ||||||
|    GROUP BY ?item ?wikipediaArticle ?commonsArticle |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Ashish
						Ashish