forked from MapComplete/MapComplete
Improve script to fetch languages
This commit is contained in:
parent
97bf454d38
commit
657168e1f3
1 changed files with 40 additions and 11 deletions
|
@ -4,13 +4,25 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import * as wds from "wikidata-sdk"
|
import * as wds from "wikidata-sdk"
|
||||||
import { Utils } from "../Utils"
|
import {Utils} from "../Utils"
|
||||||
import ScriptUtils from "./ScriptUtils"
|
import ScriptUtils from "./ScriptUtils"
|
||||||
import { existsSync, readFileSync, writeFileSync } from "fs"
|
import {existsSync, readFileSync, writeFileSync} from "fs"
|
||||||
import { QuestionableTagRenderingConfigJson } from "../Models/ThemeConfig/Json/QuestionableTagRenderingConfigJson"
|
|
||||||
import { LayerConfigJson } from "../Models/ThemeConfig/Json/LayerConfigJson"
|
|
||||||
import WikidataUtils from "../Utils/WikidataUtils"
|
import WikidataUtils from "../Utils/WikidataUtils"
|
||||||
import LanguageUtils from "../Utils/LanguageUtils"
|
import LanguageUtils from "../Utils/LanguageUtils"
|
||||||
|
import Wikidata from "../Logic/Web/Wikidata";
|
||||||
|
|
||||||
|
interface value<T> {
|
||||||
|
value: T,
|
||||||
|
type: "uri" | "literal" | string
|
||||||
|
'xml:lang'?: string
|
||||||
|
}
|
||||||
|
|
||||||
|
interface LanguageSpecResult {
|
||||||
|
directionalityLabel: value<string | "right-to-left" | "left-to-right">
|
||||||
|
lang: value<string>
|
||||||
|
code: value<string>
|
||||||
|
label: value<string>
|
||||||
|
}
|
||||||
|
|
||||||
async function fetch(target: string) {
|
async function fetch(target: string) {
|
||||||
const regular = await fetchRegularLanguages()
|
const regular = await fetchRegularLanguages()
|
||||||
|
@ -36,33 +48,50 @@ async function fetchRegularLanguages() {
|
||||||
|
|
||||||
// request the generated URL with your favorite HTTP request library
|
// request the generated URL with your favorite HTTP request library
|
||||||
const result = await Utils.downloadJson(url, { "User-Agent": "MapComplete script" })
|
const result = await Utils.downloadJson(url, { "User-Agent": "MapComplete script" })
|
||||||
const bindings = result.results.bindings
|
const bindings = <LanguageSpecResult[]> result.results.bindings
|
||||||
|
|
||||||
const zh_hant = await fetchSpecial(18130932, "zh_Hant")
|
const zh_hant = await fetchSpecial(18130932, "zh_Hant")
|
||||||
const zh_hans = await fetchSpecial(13414913, "zh_Hant")
|
const zh_hans = await fetchSpecial(13414913, "zh_Hant")
|
||||||
const pt_br = await fetchSpecial(750553, "pt_BR")
|
const pt_br = await fetchSpecial(750553, "pt_BR")
|
||||||
|
const punjabi = await fetchSpecial(58635, "pa_PK")
|
||||||
|
const Shahmukhi = await Wikidata.LoadWikidataEntryAsync(133800)
|
||||||
|
|
||||||
|
punjabi.forEach(item => {
|
||||||
|
const native = Shahmukhi.find(item => item.label["xml:lang"] == item.label["xml:lang"]) ??"Shahmukhi";
|
||||||
|
return item.label.value = item.label + " (" +native+")";
|
||||||
|
})
|
||||||
|
|
||||||
const fil = await fetchSpecial(33298, "fil")
|
const fil = await fetchSpecial(33298, "fil")
|
||||||
|
|
||||||
bindings.push(...zh_hant)
|
bindings.push(...zh_hant)
|
||||||
bindings.push(...zh_hans)
|
bindings.push(...zh_hans)
|
||||||
bindings.push(...pt_br)
|
bindings.push(...pt_br)
|
||||||
bindings.push(...fil)
|
bindings.push(...fil)
|
||||||
|
bindings.push(...punjabi)
|
||||||
|
|
||||||
return result.results.bindings
|
return result.results.bindings
|
||||||
}
|
}
|
||||||
|
|
||||||
async function fetchSpecial(id: number, code: string) {
|
/**
|
||||||
|
* Fetches the object as is. Sets a 'code' binding as predifined value
|
||||||
|
* @param id
|
||||||
|
* @param code
|
||||||
|
*/
|
||||||
|
async function fetchSpecial(id: number, code: string) : Promise< LanguageSpecResult []> {
|
||||||
ScriptUtils.fixUtils()
|
ScriptUtils.fixUtils()
|
||||||
console.log("Fetching languages")
|
console.log("Fetching languages")
|
||||||
|
|
||||||
|
const lang = " wd:Q" + id;
|
||||||
const sparql =
|
const sparql =
|
||||||
"SELECT ?lang ?label ?code \n" +
|
"SELECT ?label ?directionalityLabel \n" +
|
||||||
"WHERE \n" +
|
"WHERE \n" +
|
||||||
"{ \n" +
|
"{ \n" +
|
||||||
" wd:Q" +
|
lang + " rdfs:label ?label." +
|
||||||
id +
|
lang+ " wdt:P282 ?writing_system. \n" +
|
||||||
" rdfs:label ?label. \n" +
|
" ?writing_system wdt:P1406 ?directionality. \n" +
|
||||||
|
' SERVICE wikibase:label { bd:serviceParam wikibase:language "en". } \n'+
|
||||||
"} "
|
"} "
|
||||||
|
console.log("Special sparql:", sparql)
|
||||||
const url = wds.sparqlQuery(sparql)
|
const url = wds.sparqlQuery(sparql)
|
||||||
|
|
||||||
const result = await Utils.downloadJson(url, { "User-Agent": "MapComplete script" })
|
const result = await Utils.downloadJson(url, { "User-Agent": "MapComplete script" })
|
||||||
|
@ -167,6 +196,6 @@ async function main(wipeCache = false) {
|
||||||
writeFileSync("./assets/language_translations.json", JSON.stringify(translations, null, " "))
|
writeFileSync("./assets/language_translations.json", JSON.stringify(translations, null, " "))
|
||||||
}
|
}
|
||||||
|
|
||||||
const forceRefresh = process.argv[2] === "--force-refresh"
|
const forceRefresh = true || process.argv[2] === "--force-refresh"
|
||||||
ScriptUtils.fixUtils()
|
ScriptUtils.fixUtils()
|
||||||
main(forceRefresh).then(() => console.log("Done!"))
|
main(forceRefresh).then(() => console.log("Done!"))
|
||||||
|
|
Loading…
Reference in a new issue