Those helpers help you figure-out if an id format looks right, not that the associated entity really exists. Typically to be used in conditions:
import { isItemId, isPropertyId } from 'wikibase-sdk'
if (isItemId(someId)) doThis()
else if (isPropertyId(someId)) doThat()
Note that those helpers are independant from the Wikibase instance you are working with, so they can either be imported directly — import { isEntityId } from 'wikibase-sdk'
— or found on the wbk object — wbk.isEntityId
.
Accepts Q
(item), P
(property), and L
(lexeme) ids.
import { isEntityId } from 'wikibase-sdk'
isEntityId('Q1') // true
isEntityId('P1') // true
isEntityId('L1') // true
isEntityId('L1-F1') // false
isEntityId('L1-S1') // false
item ids a.k.a. Q
ids
import { isItemId } from 'wikibase-sdk'
isItemId('Q1') // true
isItemId('P1') // false
Property ids a.k.a. P
ids
import { isPropertyId } from 'wikibase-sdk'
isPropertyId('P1') // true
isPropertyId('Q1') // false
Property ids a.k.a. L
ids
import { isLexemeId } from 'wikibase-sdk'
isLexemeId('L1') // true
isLexemeId('L1-F1') // false
isLexemeId('L1-S1') // false
Property ids a.k.a. L
ids
import { isFormId } from 'wikibase-sdk'
isFormId('L1-F1') // true
isFormId('L1') // false
isFormId('L1-S1') // false
Property ids a.k.a. L
ids
import { isSenseId } from 'wikibase-sdk'
isSenseId('L1-S1') // true
isSenseId('L1') // false
isSenseId('L1-F1') // false
The global unique id
of a claim
import { isGuid } from 'wikibase-sdk'
isGuid('q520$7f95c04f-4cb6-b018-80eb-fefe0e0bf377') // true
isGuid('Q520$4a0b85a0-4a47-3254-0379-52680370fec6') // true
The hash of a claim, qualifier, or reference
import { isHash } from 'wikibase-sdk'
isHash('14ddd544b82e2f811669d2bb4c939c4997536ce3') // true
Property claims id is a non-official term to refer to a group of claims an entity has for a given property
import { isPropertyClaimsId } from 'wikibase-sdk'
isPropertyClaimsId('Q1#P1') // true
isPropertyClaimsId('P12#P12') // true
isPropertyClaimsId('L123#P123') // true
import { isEntitySchemaId } from 'wikibase-sdk'
isEntitySchemaId('E123') // true
Filter-out non-truthy claims from an entity.claims
object
import { truthyClaims } from 'wikibase-sdk'
const entityTruthyClaims = truthyClaims(entity.claims)
Filter-out non-truthy claims from an entity.claims[prop]
array
import { truthyPropertyClaims } from 'wikibase-sdk'
const entityP135TruthyClaims = truthyPropertyClaims(entity.claims.P135)
import { getSitelinkUrl } from 'wikibase-sdk'
getSitelinkUrl({ site: 'frwiki', title: 'Septembre' })
// => 'https://fr.wikipedia.org/wiki/Septembre'
getSitelinkUrl({ site: 'eswikiquote', title: 'Gilles Deleuze' })
// => 'https://es.wikiquote.org/wiki/Gilles_Deleuze'
getSitelinkUrl({ site: 'commons', title: 'Lyon' })
// => 'https://commons.wikimedia.org/wiki/Lyon'
getSitelinkUrl({ site: 'wikidata', title: 'Q1' })
// => 'https://wikidata.org/wiki/Q1'
getSitelinkUrl({ site: 'zhwikiquote', title: '維克多·雨果' })
// => 'https://zh.wikiquote.org/wiki/%E7%B6%AD%E5%85%8B%E5%A4%9A%C2%B7%E9%9B%A8%E6%9E%9C'
import { getSitelinkData } from 'wikibase-sdk'
getSitelinkData('https://de.wikipedia.org/wiki/Kernfusion')
// => {
// lang: 'de',
// project: 'wikipedia',
// key: 'dewiki',
// title: 'Kernfusion',
// url: 'https://de.wikipedia.org/wiki/Kernfusion'
// }
getSitelinkData('https://www.wikidata.org/wiki/Q13082')
// => {
// lang: 'en', // Using 'en' as placeholder lang for commons and wikidata
// project: 'wikidata',
// key: 'wikidata',
// title: 'Q13082',
// url: 'https://www.wikidata.org/wiki/Q13082'
// }
// Can also be used to get basic data from a sitelink key
getSitelinkData('frwiki')
// => { lang: 'fr', project: 'wikipedia', key: 'frwiki' }
getSitelinkData('dewikiquote')
// => { lang: 'de', project: 'wikiquote', key: 'dewikiquote' }
getSitelinkData('commonswiki')
// => { lang: 'en', project: 'commons', key: 'commonswiki' }
getSitelinkData('wikidatawiki')
// => { lang: 'en', project: 'wikidata', key: 'wikidatawiki' }
import { isSite } from 'wikibase-sdk'
isSite('frwiki')
// => true
isSite('dewikiquote')
// => true
isSite('commons')
// => true
// Accepting wikidata as a valid sitelink for convenience
isSite('wikidata')
// => true
isSite('frwikilinpinpin')
// => false
// /!\ langs are loosly validated
isSite('imaginarylangwiki')
// => true
Uses extended years following ECMAScript standard
import { wikibaseTimeToISOString } from 'wikibase-sdk'
var wikibaseTime = '+1885-05-22T00:00:00Z'
wikibaseTimeToISOString(wikibaseTime)
// => '1885-05-22T00:00:00.000Z'
wikibaseTime = '+0180-03-17T00:00:00Z'
wikibaseTimeToISOString(wikibaseTime)
// => '0180-03-17T00:00:00.000Z'
wikibaseTime = '-0398-00-00T00:00:00Z'
wikibaseTimeToISOString(wikibaseTime)
// => '-000398-01-01T00:00:00.000Z'
that should also work for dates far in the past or the future:
import { wikibaseTimeToISOString } from 'wikibase-sdk'
wikibaseTime = '-13798000000-00-00T00:00:00Z'
wikibaseTimeToISOString(wikibaseTime)
// => '-13798000000-01-01T00:00:00Z'
This is the time normalizer used by simplify.claims
functions
Returns dates on the format 'yyyy-mm-dd', 'yyyy-mm', 'yyyy' depending on the date precision. The benefit over the iso or the epoch format is that it preserves the precision.
It is thus possible, and prefered, to pass it the full datavalue value object to let it take the precision in account:
import { wikibaseTimeToSimpleDay } from 'wikibase-sdk'
const claims = {
"P569": [
{
"mainsnak": {
"snaktype": "value",
"property": "P569",
"hash": "4a6b80ab71c1ba78cb3a14aacd4e2f68690ab2e8",
"datavalue": {
"value": {
"time": "+1869-11-01T00:00:00Z",
"timezone": 0,
"before": 0,
"after": 0,
"precision": 10,
"calendarmodel": "http://www.wikidata.org/entity/Q1985727"
},
"type": "time"
},
"datatype": "time"
},
"type": "statement",
"id": "Q970917$D52C5A12-C810-4B5E-A3C1-0FAB8808F902",
"rank": "normal"
}
]
}
// Passing only the time string: the result misses the month precision
// and thus wrongly returns the day set to '01'
wikibaseTimeToSimpleDay(claims.P569[0].mainsnak.datavalue.value.time)
// => '1869-11-01'
// Passing the whole value object, the function can
wikibaseTimeToSimpleDay(claims.P569[0].mainsnak.datavalue.value)
// => '1869-11'
Get an image URL from a Wikimedia Commons filename:
import { getImageUrl } from 'wikibase-sdk'
getImageUrl('Peredot.jpg')
// => https://commons.wikimedia.org/wiki/Special:FilePath/Peredot.jpg
getImageUrl('Peredot.jpg', 250)
// => https://commons.wikimedia.org/wiki/Special:FilePath/Peredot.jpg?width=250
You would think it's trivial, but actually GUIDs' case is inconsistent, so we need to take care of that once for all
import { getEntityIdFromGuid } from 'wikibase-sdk'
getEntityIdFromGuid('Q520$91F0CCEA-19E4-4CEB-97D9-74B014C14686')
// => 'Q520'
getEntityIdFromGuid('q520$BCA8D9DE-B467-473B-943C-6FD0C5B3D02C')
// => 'Q520'
getEntityIdFromGuid('L525$faeae005-4b75-1319-5516-e08a8bdd0e9c')
// => 'L525'
getEntityIdFromGuid('L525-F2$52c9b382-02f5-4413-9923-26ade74f5a0d')
// => 'L525-F2'
getEntityIdFromGuid('L525-S1$66D20252-8CEC-4DB1-8B00-D713CFF42E48')
// => 'L525-S1'
getEntityIdFromGuid('P6216$a7fd6230-496e-6b47-ca4a-dcec5dbd7f95')
// => 'P6216'
Hyphenated GUIDs, such as returned by the Query Service, can also be passed:
import { getEntityIdFromGuid } from 'wikibase-sdk'
getEntityIdFromGuid('q520-BCA8D9DE-B467-473B-943C-6FD0C5B3D02C')
// => Q520
getEntityIdFromGuid('Q520-91F0CCEA-19E4-4CEB-97D9-74B014C14686')
// => Q520
getEntityIdFromGuid('q520-7f95c04f-4cb6-b018-80eb-fefe0e0bf377')
// => Q520
getEntityIdFromGuid('Q520-4a0b85a0-4a47-3254-0379-52680370fec6')
// => Q520
getEntityIdFromGuid('L525-faeae005-4b75-1319-5516-e08a8bdd0e9c')
// => L525
getEntityIdFromGuid('L525-F2-52c9b382-02f5-4413-9923-26ade74f5a0d')
// => L525-F2
getEntityIdFromGuid('L525-S1-66D20252-8CEC-4DB1-8B00-D713CFF42E48')
// => L525-S1
getEntityIdFromGuid('P6216-a7fd6230-496e-6b47-ca4a-dcec5dbd7f95')
// => P6216
getEntityIdFromGuid('Q520-4a0b85a0-4a47-3254-0379-52680370fec')
// => Q520