CINXE.COM
Module:WikidataIB/sandbox - Wikipedia
<!DOCTYPE html> <html class="client-nojs vector-feature-language-in-header-enabled vector-feature-language-in-main-page-header-disabled vector-feature-sticky-header-disabled vector-feature-page-tools-pinned-disabled vector-feature-toc-pinned-clientpref-1 vector-feature-main-menu-pinned-disabled vector-feature-limited-width-clientpref-1 vector-feature-limited-width-content-enabled vector-feature-custom-font-size-clientpref-1 vector-feature-appearance-pinned-clientpref-1 vector-feature-night-mode-enabled skin-theme-clientpref-day vector-toc-available" lang="en" dir="ltr"> <head> <meta charset="UTF-8"> <title>Module:WikidataIB/sandbox - Wikipedia</title> <script>(function(){var className="client-js vector-feature-language-in-header-enabled vector-feature-language-in-main-page-header-disabled vector-feature-sticky-header-disabled vector-feature-page-tools-pinned-disabled vector-feature-toc-pinned-clientpref-1 vector-feature-main-menu-pinned-disabled vector-feature-limited-width-clientpref-1 vector-feature-limited-width-content-enabled vector-feature-custom-font-size-clientpref-1 vector-feature-appearance-pinned-clientpref-1 vector-feature-night-mode-enabled skin-theme-clientpref-day vector-toc-available";var cookie=document.cookie.match(/(?:^|; )enwikimwclientpreferences=([^;]+)/);if(cookie){cookie[1].split('%2C').forEach(function(pref){className=className.replace(new RegExp('(^| )'+pref.replace(/-clientpref-\w+$|[^\w-]+/g,'')+'-clientpref-\\w+( |$)'),'$1'+pref+'$2');});}document.documentElement.className=className;}());RLCONF={"wgBreakFrames":false,"wgSeparatorTransformTable":["",""],"wgDigitTransformTable":["",""],"wgDefaultDateFormat":"dmy", "wgMonthNames":["","January","February","March","April","May","June","July","August","September","October","November","December"],"wgRequestId":"20ed87a8-a747-4118-8a41-7b925d6a602b","wgCanonicalNamespace":"Module","wgCanonicalSpecialPageName":false,"wgNamespaceNumber":828,"wgPageName":"Module:WikidataIB/sandbox","wgTitle":"WikidataIB/sandbox","wgCurRevisionId":1164674032,"wgRevisionId":1164674032,"wgArticleId":52889275,"wgIsArticle":true,"wgIsRedirect":false,"wgAction":"view","wgUserName":null,"wgUserGroups":["*"],"wgCategories":["Test cases using output parameter","Module sandboxes"],"wgPageViewLanguage":"en","wgPageContentLanguage":"en","wgPageContentModel":"Scribunto","wgRelevantPageName":"Module:WikidataIB/sandbox","wgRelevantArticleId":52889275,"wgIsProbablyEditable":true,"wgRelevantPageIsProbablyEditable":true,"wgRestrictionEdit":[],"wgRestrictionMove":[],"wgNoticeProject":"wikipedia","wgCiteReferencePreviewsActive":false,"wgFlaggedRevsParams":{"tags":{"status":{"levels":1}}}, "wgMediaViewerOnClick":true,"wgMediaViewerEnabledByDefault":true,"wgPopupsFlags":0,"wgVisualEditor":{"pageLanguageCode":"en","pageLanguageDir":"ltr","pageVariantFallbacks":"en"},"wgMFDisplayWikibaseDescriptions":{"search":true,"watchlist":true,"tagline":false,"nearby":true},"wgWMESchemaEditAttemptStepOversample":false,"wgWMEPageLength":100000,"wgRelatedArticlesCompat":[],"wgCentralAuthMobileDomain":false,"wgEditSubmitButtonLabelPublish":true,"wgULSPosition":"interlanguage","wgULSisCompactLinksEnabled":false,"wgVector2022LanguageInHeader":true,"wgULSisLanguageSelectorEmpty":false,"wgCheckUserClientHintsHeadersJsApi":["brands","architecture","bitness","fullVersionList","mobile","model","platform","platformVersion"],"GEHomepageSuggestedEditsEnableTopics":true,"wgGETopicsMatchModeEnabled":false,"wgGEStructuredTaskRejectionReasonTextInputEnabled":false,"wgGELevelingUpEnabledForUser":false};RLSTATE={"ext.globalCssJs.user.styles":"ready","site.styles":"ready","user.styles":"ready", "ext.globalCssJs.user":"ready","user":"ready","user.options":"loading","skins.vector.search.codex.styles":"ready","skins.vector.styles":"ready","skins.vector.icons":"ready","jquery.tablesorter.styles":"ready","jquery.makeCollapsible.styles":"ready","ext.wikimediamessages.styles":"ready","ext.visualEditor.desktopArticleTarget.noscript":"ready","ext.uls.interlanguage":"ready","wikibase.client.init":"ready","ext.wikimediaBadges":"ready"};RLPAGEMODULES=["ext.scribunto.logs","site","mediawiki.page.ready","jquery.tablesorter","jquery.makeCollapsible","mediawiki.toc","skins.vector.js","ext.centralNotice.geoIP","ext.centralNotice.startUp","ext.gadget.ReferenceTooltips","ext.gadget.switcher","ext.urlShortener.toolbar","ext.centralauth.centralautologin","mmv.bootstrap","ext.popups","ext.visualEditor.desktopArticleTarget.init","ext.visualEditor.targetLoader","ext.echo.centralauth","ext.eventLogging","ext.wikimediaEvents","ext.navigationTiming","ext.uls.interface","ext.cx.eventlogging.campaigns", "ext.checkUser.clientHints"];</script> <script>(RLQ=window.RLQ||[]).push(function(){mw.loader.impl(function(){return["user.options@12s5i",function($,jQuery,require,module){mw.user.tokens.set({"patrolToken":"+\\","watchToken":"+\\","csrfToken":"+\\"}); }];});});</script> <link rel="stylesheet" href="/w/load.php?lang=en&modules=ext.uls.interlanguage%7Cext.visualEditor.desktopArticleTarget.noscript%7Cext.wikimediaBadges%7Cext.wikimediamessages.styles%7Cjquery.makeCollapsible.styles%7Cjquery.tablesorter.styles%7Cskins.vector.icons%2Cstyles%7Cskins.vector.search.codex.styles%7Cwikibase.client.init&only=styles&skin=vector-2022"> <script async="" src="/w/load.php?lang=en&modules=startup&only=scripts&raw=1&skin=vector-2022"></script> <meta name="ResourceLoaderDynamicStyles" content=""> <link rel="stylesheet" href="/w/load.php?lang=en&modules=site.styles&only=styles&skin=vector-2022"> <meta name="generator" content="MediaWiki 1.44.0-wmf.4"> <meta name="referrer" content="origin"> <meta name="referrer" content="origin-when-cross-origin"> <meta name="robots" content="max-image-preview:standard"> <meta name="format-detection" content="telephone=no"> <meta name="viewport" content="width=1120"> <meta property="og:title" content="Module:WikidataIB/sandbox - Wikipedia"> <meta property="og:type" content="website"> <link rel="preconnect" href="//upload.wikimedia.org"> <link rel="alternate" media="only screen and (max-width: 640px)" href="//en.m.wikipedia.org/wiki/Module:WikidataIB/sandbox"> <link rel="alternate" type="application/x-wiki" title="Edit this page" href="/w/index.php?title=Module:WikidataIB/sandbox&action=edit"> <link rel="apple-touch-icon" href="/static/apple-touch/wikipedia.png"> <link rel="icon" href="/static/favicon/wikipedia.ico"> <link rel="search" type="application/opensearchdescription+xml" href="/w/rest.php/v1/search" title="Wikipedia (en)"> <link rel="EditURI" type="application/rsd+xml" href="//en.wikipedia.org/w/api.php?action=rsd"> <link rel="canonical" href="https://en.wikipedia.org/wiki/Module:WikidataIB/sandbox"> <link rel="license" href="https://creativecommons.org/licenses/by-sa/4.0/deed.en"> <link rel="alternate" type="application/atom+xml" title="Wikipedia Atom feed" href="/w/index.php?title=Special:RecentChanges&feed=atom"> <link rel="dns-prefetch" href="//meta.wikimedia.org" /> <link rel="dns-prefetch" href="//login.wikimedia.org"> </head> <body class="skin--responsive skin-vector skin-vector-search-vue mediawiki ltr sitedir-ltr mw-hide-empty-elt ns-828 ns-subject mw-editable page-Module_WikidataIB_sandbox rootpage-Module_WikidataIB skin-vector-2022 action-view"><a class="mw-jump-link" href="#bodyContent">Jump to content</a> <div class="vector-header-container"> <header class="vector-header mw-header"> <div class="vector-header-start"> <nav class="vector-main-menu-landmark" aria-label="Site"> <div id="vector-main-menu-dropdown" class="vector-dropdown vector-main-menu-dropdown vector-button-flush-left vector-button-flush-right" > <input type="checkbox" id="vector-main-menu-dropdown-checkbox" role="button" aria-haspopup="true" data-event-name="ui.dropdown-vector-main-menu-dropdown" class="vector-dropdown-checkbox " aria-label="Main menu" > <label id="vector-main-menu-dropdown-label" for="vector-main-menu-dropdown-checkbox" class="vector-dropdown-label cdx-button cdx-button--fake-button cdx-button--fake-button--enabled cdx-button--weight-quiet cdx-button--icon-only " aria-hidden="true" ><span class="vector-icon mw-ui-icon-menu mw-ui-icon-wikimedia-menu"></span> <span class="vector-dropdown-label-text">Main menu</span> </label> <div class="vector-dropdown-content"> <div id="vector-main-menu-unpinned-container" class="vector-unpinned-container"> <div id="vector-main-menu" class="vector-main-menu vector-pinnable-element"> <div class="vector-pinnable-header vector-main-menu-pinnable-header vector-pinnable-header-unpinned" data-feature-name="main-menu-pinned" data-pinnable-element-id="vector-main-menu" data-pinned-container-id="vector-main-menu-pinned-container" data-unpinned-container-id="vector-main-menu-unpinned-container" > <div class="vector-pinnable-header-label">Main menu</div> <button class="vector-pinnable-header-toggle-button vector-pinnable-header-pin-button" data-event-name="pinnable-header.vector-main-menu.pin">move to sidebar</button> <button class="vector-pinnable-header-toggle-button vector-pinnable-header-unpin-button" data-event-name="pinnable-header.vector-main-menu.unpin">hide</button> </div> <div id="p-navigation" class="vector-menu mw-portlet mw-portlet-navigation" > <div class="vector-menu-heading"> Navigation </div> <div class="vector-menu-content"> <ul class="vector-menu-content-list"> <li id="n-mainpage-description" class="mw-list-item"><a href="/wiki/Main_Page" title="Visit the main page [z]" accesskey="z"><span>Main page</span></a></li><li id="n-contents" class="mw-list-item"><a href="/wiki/Wikipedia:Contents" title="Guides to browsing Wikipedia"><span>Contents</span></a></li><li id="n-currentevents" class="mw-list-item"><a href="/wiki/Portal:Current_events" title="Articles related to current events"><span>Current events</span></a></li><li id="n-randompage" class="mw-list-item"><a href="/wiki/Special:Random" title="Visit a randomly selected article [x]" accesskey="x"><span>Random article</span></a></li><li id="n-aboutsite" class="mw-list-item"><a href="/wiki/Wikipedia:About" title="Learn about Wikipedia and how it works"><span>About Wikipedia</span></a></li><li id="n-contactpage" class="mw-list-item"><a href="//en.wikipedia.org/wiki/Wikipedia:Contact_us" title="How to contact Wikipedia"><span>Contact us</span></a></li> </ul> </div> </div> <div id="p-interaction" class="vector-menu mw-portlet mw-portlet-interaction" > <div class="vector-menu-heading"> Contribute </div> <div class="vector-menu-content"> <ul class="vector-menu-content-list"> <li id="n-help" class="mw-list-item"><a href="/wiki/Help:Contents" title="Guidance on how to use and edit Wikipedia"><span>Help</span></a></li><li id="n-introduction" class="mw-list-item"><a href="/wiki/Help:Introduction" title="Learn how to edit Wikipedia"><span>Learn to edit</span></a></li><li id="n-portal" class="mw-list-item"><a href="/wiki/Wikipedia:Community_portal" title="The hub for editors"><span>Community portal</span></a></li><li id="n-recentchanges" class="mw-list-item"><a href="/wiki/Special:RecentChanges" title="A list of recent changes to Wikipedia [r]" accesskey="r"><span>Recent changes</span></a></li><li id="n-upload" class="mw-list-item"><a href="/wiki/Wikipedia:File_upload_wizard" title="Add images or other media for use on Wikipedia"><span>Upload file</span></a></li> </ul> </div> </div> </div> </div> </div> </div> </nav> <a href="/wiki/Main_Page" class="mw-logo"> <img class="mw-logo-icon" src="/static/images/icons/wikipedia.png" alt="" aria-hidden="true" height="50" width="50"> <span class="mw-logo-container skin-invert"> <img class="mw-logo-wordmark" alt="Wikipedia" src="/static/images/mobile/copyright/wikipedia-wordmark-en.svg" style="width: 7.5em; height: 1.125em;"> <img class="mw-logo-tagline" alt="The Free Encyclopedia" src="/static/images/mobile/copyright/wikipedia-tagline-en.svg" width="117" height="13" style="width: 7.3125em; height: 0.8125em;"> </span> </a> </div> <div class="vector-header-end"> <div id="p-search" role="search" class="vector-search-box-vue vector-search-box-collapses vector-search-box-show-thumbnail vector-search-box-auto-expand-width vector-search-box"> <a href="/wiki/Special:Search" class="cdx-button cdx-button--fake-button cdx-button--fake-button--enabled cdx-button--weight-quiet cdx-button--icon-only search-toggle" title="Search Wikipedia [f]" accesskey="f"><span class="vector-icon mw-ui-icon-search mw-ui-icon-wikimedia-search"></span> <span>Search</span> </a> <div class="vector-typeahead-search-container"> <div class="cdx-typeahead-search cdx-typeahead-search--show-thumbnail cdx-typeahead-search--auto-expand-width"> <form action="/w/index.php" id="searchform" class="cdx-search-input cdx-search-input--has-end-button"> <div id="simpleSearch" class="cdx-search-input__input-wrapper" data-search-loc="header-moved"> <div class="cdx-text-input cdx-text-input--has-start-icon"> <input class="cdx-text-input__input" type="search" name="search" placeholder="Search Wikipedia" aria-label="Search Wikipedia" autocapitalize="sentences" title="Search Wikipedia [f]" accesskey="f" id="searchInput" > <span class="cdx-text-input__icon cdx-text-input__start-icon"></span> </div> <input type="hidden" name="title" value="Special:Search"> </div> <button class="cdx-button cdx-search-input__end-button">Search</button> </form> </div> </div> </div> <nav class="vector-user-links vector-user-links-wide" aria-label="Personal tools"> <div class="vector-user-links-main"> <div id="p-vector-user-menu-preferences" class="vector-menu mw-portlet emptyPortlet" > <div class="vector-menu-content"> <ul class="vector-menu-content-list"> </ul> </div> </div> <div id="p-vector-user-menu-userpage" class="vector-menu mw-portlet emptyPortlet" > <div class="vector-menu-content"> <ul class="vector-menu-content-list"> </ul> </div> </div> <nav class="vector-appearance-landmark" aria-label="Appearance"> <div id="vector-appearance-dropdown" class="vector-dropdown " title="Change the appearance of the page's font size, width, and color" > <input type="checkbox" id="vector-appearance-dropdown-checkbox" role="button" aria-haspopup="true" data-event-name="ui.dropdown-vector-appearance-dropdown" class="vector-dropdown-checkbox " aria-label="Appearance" > <label id="vector-appearance-dropdown-label" for="vector-appearance-dropdown-checkbox" class="vector-dropdown-label cdx-button cdx-button--fake-button cdx-button--fake-button--enabled cdx-button--weight-quiet cdx-button--icon-only " aria-hidden="true" ><span class="vector-icon mw-ui-icon-appearance mw-ui-icon-wikimedia-appearance"></span> <span class="vector-dropdown-label-text">Appearance</span> </label> <div class="vector-dropdown-content"> <div id="vector-appearance-unpinned-container" class="vector-unpinned-container"> </div> </div> </div> </nav> <div id="p-vector-user-menu-notifications" class="vector-menu mw-portlet emptyPortlet" > <div class="vector-menu-content"> <ul class="vector-menu-content-list"> </ul> </div> </div> <div id="p-vector-user-menu-overflow" class="vector-menu mw-portlet" > <div class="vector-menu-content"> <ul class="vector-menu-content-list"> <li id="pt-sitesupport-2" class="user-links-collapsible-item mw-list-item user-links-collapsible-item"><a data-mw="interface" href="https://donate.wikimedia.org/wiki/Special:FundraiserRedirector?utm_source=donate&utm_medium=sidebar&utm_campaign=C13_en.wikipedia.org&uselang=en" class=""><span>Donate</span></a> </li> <li id="pt-createaccount-2" class="user-links-collapsible-item mw-list-item user-links-collapsible-item"><a data-mw="interface" href="/w/index.php?title=Special:CreateAccount&returnto=Module%3AWikidataIB%2Fsandbox" title="You are encouraged to create an account and log in; however, it is not mandatory" class=""><span>Create account</span></a> </li> <li id="pt-login-2" class="user-links-collapsible-item mw-list-item user-links-collapsible-item"><a data-mw="interface" href="/w/index.php?title=Special:UserLogin&returnto=Module%3AWikidataIB%2Fsandbox" title="You're encouraged to log in; however, it's not mandatory. [o]" accesskey="o" class=""><span>Log in</span></a> </li> </ul> </div> </div> </div> <div id="vector-user-links-dropdown" class="vector-dropdown vector-user-menu vector-button-flush-right vector-user-menu-logged-out" title="Log in and more options" > <input type="checkbox" id="vector-user-links-dropdown-checkbox" role="button" aria-haspopup="true" data-event-name="ui.dropdown-vector-user-links-dropdown" class="vector-dropdown-checkbox " aria-label="Personal tools" > <label id="vector-user-links-dropdown-label" for="vector-user-links-dropdown-checkbox" class="vector-dropdown-label cdx-button cdx-button--fake-button cdx-button--fake-button--enabled cdx-button--weight-quiet cdx-button--icon-only " aria-hidden="true" ><span class="vector-icon mw-ui-icon-ellipsis mw-ui-icon-wikimedia-ellipsis"></span> <span class="vector-dropdown-label-text">Personal tools</span> </label> <div class="vector-dropdown-content"> <div id="p-personal" class="vector-menu mw-portlet mw-portlet-personal user-links-collapsible-item" title="User menu" > <div class="vector-menu-content"> <ul class="vector-menu-content-list"> <li id="pt-sitesupport" class="user-links-collapsible-item mw-list-item"><a href="https://donate.wikimedia.org/wiki/Special:FundraiserRedirector?utm_source=donate&utm_medium=sidebar&utm_campaign=C13_en.wikipedia.org&uselang=en"><span>Donate</span></a></li><li id="pt-createaccount" class="user-links-collapsible-item mw-list-item"><a href="/w/index.php?title=Special:CreateAccount&returnto=Module%3AWikidataIB%2Fsandbox" title="You are encouraged to create an account and log in; however, it is not mandatory"><span class="vector-icon mw-ui-icon-userAdd mw-ui-icon-wikimedia-userAdd"></span> <span>Create account</span></a></li><li id="pt-login" class="user-links-collapsible-item mw-list-item"><a href="/w/index.php?title=Special:UserLogin&returnto=Module%3AWikidataIB%2Fsandbox" title="You're encouraged to log in; however, it's not mandatory. [o]" accesskey="o"><span class="vector-icon mw-ui-icon-logIn mw-ui-icon-wikimedia-logIn"></span> <span>Log in</span></a></li> </ul> </div> </div> <div id="p-user-menu-anon-editor" class="vector-menu mw-portlet mw-portlet-user-menu-anon-editor" > <div class="vector-menu-heading"> Pages for logged out editors <a href="/wiki/Help:Introduction" aria-label="Learn more about editing"><span>learn more</span></a> </div> <div class="vector-menu-content"> <ul class="vector-menu-content-list"> <li id="pt-anoncontribs" class="mw-list-item"><a href="/wiki/Special:MyContributions" title="A list of edits made from this IP address [y]" accesskey="y"><span>Contributions</span></a></li><li id="pt-anontalk" class="mw-list-item"><a href="/wiki/Special:MyTalk" title="Discussion about edits from this IP address [n]" accesskey="n"><span>Talk</span></a></li> </ul> </div> </div> </div> </div> </nav> </div> </header> </div> <div class="mw-page-container"> <div class="mw-page-container-inner"> <div class="vector-sitenotice-container"> <div id="siteNotice"><!-- CentralNotice --></div> </div> <div class="vector-column-start"> <div class="vector-main-menu-container"> <div id="mw-navigation"> <nav id="mw-panel" class="vector-main-menu-landmark" aria-label="Site"> <div id="vector-main-menu-pinned-container" class="vector-pinned-container"> </div> </nav> </div> </div> <div class="vector-sticky-pinned-container"> <nav id="mw-panel-toc" aria-label="Contents" data-event-name="ui.sidebar-toc" class="mw-table-of-contents-container vector-toc-landmark"> <div id="vector-toc-pinned-container" class="vector-pinned-container"> <div id="vector-toc" class="vector-toc vector-pinnable-element"> <div class="vector-pinnable-header vector-toc-pinnable-header vector-pinnable-header-pinned" data-feature-name="toc-pinned" data-pinnable-element-id="vector-toc" > <h2 class="vector-pinnable-header-label">Contents</h2> <button class="vector-pinnable-header-toggle-button vector-pinnable-header-pin-button" data-event-name="pinnable-header.vector-toc.pin">move to sidebar</button> <button class="vector-pinnable-header-toggle-button vector-pinnable-header-unpin-button" data-event-name="pinnable-header.vector-toc.unpin">hide</button> </div> <ul class="vector-toc-contents" id="mw-panel-toc-list"> <li id="toc-mw-content-text" class="vector-toc-list-item vector-toc-level-1"> <a href="#" class="vector-toc-link"> <div class="vector-toc-text">(Top)</div> </a> </li> <li id="toc-Overview" class="vector-toc-list-item vector-toc-level-1"> <a class="vector-toc-link" href="#Overview"> <div class="vector-toc-text"> <span class="vector-toc-numb">1</span> <span>Overview</span> </div> </a> <button aria-controls="toc-Overview-sublist" class="cdx-button cdx-button--weight-quiet cdx-button--icon-only vector-toc-toggle"> <span class="vector-icon mw-ui-icon-wikimedia-expand"></span> <span>Toggle Overview subsection</span> </button> <ul id="toc-Overview-sublist" class="vector-toc-list"> <li id="toc-Utilities_functions" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Utilities_functions"> <div class="vector-toc-text"> <span class="vector-toc-numb">1.1</span> <span>Utilities functions</span> </div> </a> <ul id="toc-Utilities_functions-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Examples_of_calls" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Examples_of_calls"> <div class="vector-toc-text"> <span class="vector-toc-numb">1.2</span> <span>Examples of calls</span> </div> </a> <ul id="toc-Examples_of_calls-sublist" class="vector-toc-list"> </ul> </li> </ul> </li> <li id="toc-Function_getValue" class="vector-toc-list-item vector-toc-level-1"> <a class="vector-toc-link" href="#Function_getValue"> <div class="vector-toc-text"> <span class="vector-toc-numb">2</span> <span>Function getValue</span> </div> </a> <button aria-controls="toc-Function_getValue-sublist" class="cdx-button cdx-button--weight-quiet cdx-button--icon-only vector-toc-toggle"> <span class="vector-icon mw-ui-icon-wikimedia-expand"></span> <span>Toggle Function getValue subsection</span> </button> <ul id="toc-Function_getValue-sublist" class="vector-toc-list"> <li id="toc-Parameters_to_getValue" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Parameters_to_getValue"> <div class="vector-toc-text"> <span class="vector-toc-numb">2.1</span> <span>Parameters to getValue</span> </div> </a> <ul id="toc-Parameters_to_getValue-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Base_parameters" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Base_parameters"> <div class="vector-toc-text"> <span class="vector-toc-numb">2.2</span> <span>Base parameters</span> </div> </a> <ul id="toc-Base_parameters-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Whitelist_and_blacklist" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Whitelist_and_blacklist"> <div class="vector-toc-text"> <span class="vector-toc-numb">2.3</span> <span>Whitelist and blacklist</span> </div> </a> <ul id="toc-Whitelist_and_blacklist-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Sourcing" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Sourcing"> <div class="vector-toc-text"> <span class="vector-toc-numb">2.4</span> <span>Sourcing</span> </div> </a> <ul id="toc-Sourcing-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Link_to_Wikidata" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Link_to_Wikidata"> <div class="vector-toc-text"> <span class="vector-toc-numb">2.5</span> <span>Link to Wikidata</span> </div> </a> <ul id="toc-Link_to_Wikidata-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Dates" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Dates"> <div class="vector-toc-text"> <span class="vector-toc-numb">2.6</span> <span>Dates</span> </div> </a> <ul id="toc-Dates-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Ranks" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Ranks"> <div class="vector-toc-text"> <span class="vector-toc-numb">2.7</span> <span>Ranks</span> </div> </a> <ul id="toc-Ranks-sublist" class="vector-toc-list"> <li id="toc-Specific_value-type_handlers" class="vector-toc-list-item vector-toc-level-3"> <a class="vector-toc-link" href="#Specific_value-type_handlers"> <div class="vector-toc-text"> <span class="vector-toc-numb">2.7.1</span> <span>Specific value-type handlers</span> </div> </a> <ul id="toc-Specific_value-type_handlers-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Formatting_multiple_returned_values" class="vector-toc-list-item vector-toc-level-3"> <a class="vector-toc-link" href="#Formatting_multiple_returned_values"> <div class="vector-toc-text"> <span class="vector-toc-numb">2.7.2</span> <span>Formatting multiple returned values</span> </div> </a> <ul id="toc-Formatting_multiple_returned_values-sublist" class="vector-toc-list"> </ul> </li> </ul> </li> <li id="toc-Limiting_the_returned_values" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Limiting_the_returned_values"> <div class="vector-toc-text"> <span class="vector-toc-numb">2.8</span> <span>Limiting the returned values</span> </div> </a> <ul id="toc-Limiting_the_returned_values-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Unlinking" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Unlinking"> <div class="vector-toc-text"> <span class="vector-toc-numb">2.9</span> <span>Unlinking</span> </div> </a> <ul id="toc-Unlinking-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Unit_abbreviations" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Unit_abbreviations"> <div class="vector-toc-text"> <span class="vector-toc-numb">2.10</span> <span>Unit abbreviations</span> </div> </a> <ul id="toc-Unit_abbreviations-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Qualifiers" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Qualifiers"> <div class="vector-toc-text"> <span class="vector-toc-numb">2.11</span> <span>Qualifiers</span> </div> </a> <ul id="toc-Qualifiers-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Short_form_of_parameters" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Short_form_of_parameters"> <div class="vector-toc-text"> <span class="vector-toc-numb">2.12</span> <span>Short form of parameters</span> </div> </a> <ul id="toc-Short_form_of_parameters-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Parameter_sets" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Parameter_sets"> <div class="vector-toc-text"> <span class="vector-toc-numb">2.13</span> <span>Parameter sets</span> </div> </a> <ul id="toc-Parameter_sets-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Wrapper_template" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Wrapper_template"> <div class="vector-toc-text"> <span class="vector-toc-numb">2.14</span> <span>Wrapper template</span> </div> </a> <ul id="toc-Wrapper_template-sublist" class="vector-toc-list"> </ul> </li> </ul> </li> <li id="toc-Other_main_functions" class="vector-toc-list-item vector-toc-level-1"> <a class="vector-toc-link" href="#Other_main_functions"> <div class="vector-toc-text"> <span class="vector-toc-numb">3</span> <span>Other main functions</span> </div> </a> <button aria-controls="toc-Other_main_functions-sublist" class="cdx-button cdx-button--weight-quiet cdx-button--icon-only vector-toc-toggle"> <span class="vector-icon mw-ui-icon-wikimedia-expand"></span> <span>Toggle Other main functions subsection</span> </button> <ul id="toc-Other_main_functions-sublist" class="vector-toc-list"> <li id="toc-Function_getPreferredValue" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Function_getPreferredValue"> <div class="vector-toc-text"> <span class="vector-toc-numb">3.1</span> <span>Function getPreferredValue</span> </div> </a> <ul id="toc-Function_getPreferredValue-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Function_getCoords" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Function_getCoords"> <div class="vector-toc-text"> <span class="vector-toc-numb">3.2</span> <span>Function getCoords</span> </div> </a> <ul id="toc-Function_getCoords-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Function_getQualifierValue" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Function_getQualifierValue"> <div class="vector-toc-text"> <span class="vector-toc-numb">3.3</span> <span>Function getQualifierValue</span> </div> </a> <ul id="toc-Function_getQualifierValue-sublist" class="vector-toc-list"> <li id="toc-Example_of_getQualifierValue" class="vector-toc-list-item vector-toc-level-3"> <a class="vector-toc-link" href="#Example_of_getQualifierValue"> <div class="vector-toc-text"> <span class="vector-toc-numb">3.3.1</span> <span>Example of getQualifierValue</span> </div> </a> <ul id="toc-Example_of_getQualifierValue-sublist" class="vector-toc-list"> </ul> </li> </ul> </li> <li id="toc-Function_getValueByQual" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Function_getValueByQual"> <div class="vector-toc-text"> <span class="vector-toc-numb">3.4</span> <span>Function getValueByQual</span> </div> </a> <ul id="toc-Function_getValueByQual-sublist" class="vector-toc-list"> <li id="toc-Example_of_getValueByQual" class="vector-toc-list-item vector-toc-level-3"> <a class="vector-toc-link" href="#Example_of_getValueByQual"> <div class="vector-toc-text"> <span class="vector-toc-numb">3.4.1</span> <span>Example of getValueByQual</span> </div> </a> <ul id="toc-Example_of_getValueByQual-sublist" class="vector-toc-list"> </ul> </li> </ul> </li> <li id="toc-Function_getValueByLang" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Function_getValueByLang"> <div class="vector-toc-text"> <span class="vector-toc-numb">3.5</span> <span>Function getValueByLang</span> </div> </a> <ul id="toc-Function_getValueByLang-sublist" class="vector-toc-list"> <li id="toc-Example_of_getValueByLang" class="vector-toc-list-item vector-toc-level-3"> <a class="vector-toc-link" href="#Example_of_getValueByLang"> <div class="vector-toc-text"> <span class="vector-toc-numb">3.5.1</span> <span>Example of getValueByLang</span> </div> </a> <ul id="toc-Example_of_getValueByLang-sublist" class="vector-toc-list"> </ul> </li> </ul> </li> </ul> </li> <li id="toc-Utility_functions" class="vector-toc-list-item vector-toc-level-1"> <a class="vector-toc-link" href="#Utility_functions"> <div class="vector-toc-text"> <span class="vector-toc-numb">4</span> <span>Utility functions</span> </div> </a> <button aria-controls="toc-Utility_functions-sublist" class="cdx-button cdx-button--weight-quiet cdx-button--icon-only vector-toc-toggle"> <span class="vector-icon mw-ui-icon-wikimedia-expand"></span> <span>Toggle Utility functions subsection</span> </button> <ul id="toc-Utility_functions-sublist" class="vector-toc-list"> <li id="toc-Function_getLink" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Function_getLink"> <div class="vector-toc-text"> <span class="vector-toc-numb">4.1</span> <span>Function getLink</span> </div> </a> <ul id="toc-Function_getLink-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Function_getLabel" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Function_getLabel"> <div class="vector-toc-text"> <span class="vector-toc-numb">4.2</span> <span>Function getLabel</span> </div> </a> <ul id="toc-Function_getLabel-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Function_label" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Function_label"> <div class="vector-toc-text"> <span class="vector-toc-numb">4.3</span> <span>Function label</span> </div> </a> <ul id="toc-Function_label-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Function_getAT" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Function_getAT"> <div class="vector-toc-text"> <span class="vector-toc-numb">4.4</span> <span>Function getAT</span> </div> </a> <ul id="toc-Function_getAT-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Function_getDescription" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Function_getDescription"> <div class="vector-toc-text"> <span class="vector-toc-numb">4.5</span> <span>Function getDescription</span> </div> </a> <ul id="toc-Function_getDescription-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Function_formatDate" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Function_formatDate"> <div class="vector-toc-text"> <span class="vector-toc-numb">4.6</span> <span>Function formatDate</span> </div> </a> <ul id="toc-Function_formatDate-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Function_checkBlacklist" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Function_checkBlacklist"> <div class="vector-toc-text"> <span class="vector-toc-numb">4.7</span> <span>Function checkBlacklist</span> </div> </a> <ul id="toc-Function_checkBlacklist-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Function_emptyor" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Function_emptyor"> <div class="vector-toc-text"> <span class="vector-toc-numb">4.8</span> <span>Function emptyor</span> </div> </a> <ul id="toc-Function_emptyor-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Function_labelorid" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Function_labelorid"> <div class="vector-toc-text"> <span class="vector-toc-numb">4.9</span> <span>Function labelorid</span> </div> </a> <ul id="toc-Function_labelorid-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Function_getQid" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Function_getQid"> <div class="vector-toc-text"> <span class="vector-toc-numb">4.10</span> <span>Function getQid</span> </div> </a> <ul id="toc-Function_getQid-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Function_examine" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Function_examine"> <div class="vector-toc-text"> <span class="vector-toc-numb">4.11</span> <span>Function examine</span> </div> </a> <ul id="toc-Function_examine-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Function_url2" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Function_url2"> <div class="vector-toc-text"> <span class="vector-toc-numb">4.12</span> <span>Function url2</span> </div> </a> <ul id="toc-Function_url2-sublist" class="vector-toc-list"> <li id="toc-See_also" class="vector-toc-list-item vector-toc-level-3"> <a class="vector-toc-link" href="#See_also"> <div class="vector-toc-text"> <span class="vector-toc-numb">4.12.1</span> <span>See also</span> </div> </a> <ul id="toc-See_also-sublist" class="vector-toc-list"> </ul> </li> </ul> </li> </ul> </li> <li id="toc-Coding_into_an_infobox" class="vector-toc-list-item vector-toc-level-1"> <a class="vector-toc-link" href="#Coding_into_an_infobox"> <div class="vector-toc-text"> <span class="vector-toc-numb">5</span> <span>Coding into an infobox</span> </div> </a> <button aria-controls="toc-Coding_into_an_infobox-sublist" class="cdx-button cdx-button--weight-quiet cdx-button--icon-only vector-toc-toggle"> <span class="vector-icon mw-ui-icon-wikimedia-expand"></span> <span>Toggle Coding into an infobox subsection</span> </button> <ul id="toc-Coding_into_an_infobox-sublist" class="vector-toc-list"> <li id="toc-Example_of_calls_in_an_infobox" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Example_of_calls_in_an_infobox"> <div class="vector-toc-text"> <span class="vector-toc-numb">5.1</span> <span>Example of calls in an infobox</span> </div> </a> <ul id="toc-Example_of_calls_in_an_infobox-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Coordinates" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Coordinates"> <div class="vector-toc-text"> <span class="vector-toc-numb">5.2</span> <span>Coordinates</span> </div> </a> <ul id="toc-Coordinates-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Upgrading_existing_infoboxes" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Upgrading_existing_infoboxes"> <div class="vector-toc-text"> <span class="vector-toc-numb">5.3</span> <span>Upgrading existing infoboxes</span> </div> </a> <ul id="toc-Upgrading_existing_infoboxes-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Verifiability" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Verifiability"> <div class="vector-toc-text"> <span class="vector-toc-numb">5.4</span> <span>Verifiability</span> </div> </a> <ul id="toc-Verifiability-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Helper_templates" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Helper_templates"> <div class="vector-toc-text"> <span class="vector-toc-numb">5.5</span> <span>Helper templates</span> </div> </a> <ul id="toc-Helper_templates-sublist" class="vector-toc-list"> </ul> </li> </ul> </li> <li id="toc-Example_of_use:_Infobox_book" class="vector-toc-list-item vector-toc-level-1"> <a class="vector-toc-link" href="#Example_of_use:_Infobox_book"> <div class="vector-toc-text"> <span class="vector-toc-numb">6</span> <span>Example of use: Infobox book</span> </div> </a> <button aria-controls="toc-Example_of_use:_Infobox_book-sublist" class="cdx-button cdx-button--weight-quiet cdx-button--icon-only vector-toc-toggle"> <span class="vector-icon mw-ui-icon-wikimedia-expand"></span> <span>Toggle Example of use: Infobox book subsection</span> </button> <ul id="toc-Example_of_use:_Infobox_book-sublist" class="vector-toc-list"> <li id="toc-No_Wikidata" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#No_Wikidata"> <div class="vector-toc-text"> <span class="vector-toc-numb">6.1</span> <span>No Wikidata</span> </div> </a> <ul id="toc-No_Wikidata-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-All_Wikidata" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#All_Wikidata"> <div class="vector-toc-text"> <span class="vector-toc-numb">6.2</span> <span>All Wikidata</span> </div> </a> <ul id="toc-All_Wikidata-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Never_display_genre" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Never_display_genre"> <div class="vector-toc-text"> <span class="vector-toc-numb">6.3</span> <span>Never display genre</span> </div> </a> <ul id="toc-Never_display_genre-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Local_override" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Local_override"> <div class="vector-toc-text"> <span class="vector-toc-numb">6.4</span> <span>Local override</span> </div> </a> <ul id="toc-Local_override-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Don't_fetch_genre" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Don't_fetch_genre"> <div class="vector-toc-text"> <span class="vector-toc-numb">6.5</span> <span>Don't fetch genre</span> </div> </a> <ul id="toc-Don't_fetch_genre-sublist" class="vector-toc-list"> </ul> </li> </ul> </li> <li id="toc-Exporting_the_module" class="vector-toc-list-item vector-toc-level-1"> <a class="vector-toc-link" href="#Exporting_the_module"> <div class="vector-toc-text"> <span class="vector-toc-numb">7</span> <span>Exporting the module</span> </div> </a> <button aria-controls="toc-Exporting_the_module-sublist" class="cdx-button cdx-button--weight-quiet cdx-button--icon-only vector-toc-toggle"> <span class="vector-icon mw-ui-icon-wikimedia-expand"></span> <span>Toggle Exporting the module subsection</span> </button> <ul id="toc-Exporting_the_module-sublist" class="vector-toc-list"> <li id="toc-Linked_items" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Linked_items"> <div class="vector-toc-text"> <span class="vector-toc-numb">7.1</span> <span>Linked items</span> </div> </a> <ul id="toc-Linked_items-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Italic_titles" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Italic_titles"> <div class="vector-toc-text"> <span class="vector-toc-numb">7.2</span> <span>Italic titles</span> </div> </a> <ul id="toc-Italic_titles-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Complex_date" class="vector-toc-list-item vector-toc-level-2"> <a class="vector-toc-link" href="#Complex_date"> <div class="vector-toc-text"> <span class="vector-toc-numb">7.3</span> <span>Complex date</span> </div> </a> <ul id="toc-Complex_date-sublist" class="vector-toc-list"> <li id="toc-Complex_date_dependencies" class="vector-toc-list-item vector-toc-level-3"> <a class="vector-toc-link" href="#Complex_date_dependencies"> <div class="vector-toc-text"> <span class="vector-toc-numb">7.3.1</span> <span>Complex date dependencies</span> </div> </a> <ul id="toc-Complex_date_dependencies-sublist" class="vector-toc-list"> </ul> </li> </ul> </li> </ul> </li> <li id="toc-See_also_2" class="vector-toc-list-item vector-toc-level-1"> <a class="vector-toc-link" href="#See_also_2"> <div class="vector-toc-text"> <span class="vector-toc-numb">8</span> <span>See also</span> </div> </a> <ul id="toc-See_also_2-sublist" class="vector-toc-list"> </ul> </li> <li id="toc-Tracking_categories" class="vector-toc-list-item vector-toc-level-1"> <a class="vector-toc-link" href="#Tracking_categories"> <div class="vector-toc-text"> <span class="vector-toc-numb">9</span> <span>Tracking categories</span> </div> </a> <ul id="toc-Tracking_categories-sublist" class="vector-toc-list"> </ul> </li> </ul> </div> </div> </nav> </div> </div> <div class="mw-content-container"> <main id="content" class="mw-body"> <header class="mw-body-header vector-page-titlebar"> <nav aria-label="Contents" class="vector-toc-landmark"> <div id="vector-page-titlebar-toc" class="vector-dropdown vector-page-titlebar-toc vector-button-flush-left" > <input type="checkbox" id="vector-page-titlebar-toc-checkbox" role="button" aria-haspopup="true" data-event-name="ui.dropdown-vector-page-titlebar-toc" class="vector-dropdown-checkbox " aria-label="Toggle the table of contents" > <label id="vector-page-titlebar-toc-label" for="vector-page-titlebar-toc-checkbox" class="vector-dropdown-label cdx-button cdx-button--fake-button cdx-button--fake-button--enabled cdx-button--weight-quiet cdx-button--icon-only " aria-hidden="true" ><span class="vector-icon mw-ui-icon-listBullet mw-ui-icon-wikimedia-listBullet"></span> <span class="vector-dropdown-label-text">Toggle the table of contents</span> </label> <div class="vector-dropdown-content"> <div id="vector-page-titlebar-toc-unpinned-container" class="vector-unpinned-container"> </div> </div> </div> </nav> <h1 id="firstHeading" class="firstHeading mw-first-heading"><span class="mw-page-title-namespace">Module</span><span class="mw-page-title-separator">:</span><span class="mw-page-title-main">WikidataIB/sandbox</span></h1> <div id="p-lang-btn" class="vector-dropdown mw-portlet mw-portlet-lang" > <input type="checkbox" id="p-lang-btn-checkbox" role="button" aria-haspopup="true" data-event-name="ui.dropdown-p-lang-btn" class="vector-dropdown-checkbox mw-interlanguage-selector" aria-label="This article exist only in this language. Add the article for other languages" > <label id="p-lang-btn-label" for="p-lang-btn-checkbox" class="vector-dropdown-label cdx-button cdx-button--fake-button cdx-button--fake-button--enabled cdx-button--weight-quiet cdx-button--action-progressive mw-portlet-lang-heading-0" aria-hidden="true" ><span class="vector-icon mw-ui-icon-language-progressive mw-ui-icon-wikimedia-language-progressive"></span> <span class="vector-dropdown-label-text">Add languages</span> </label> <div class="vector-dropdown-content"> <div class="vector-menu-content"> <ul class="vector-menu-content-list"> </ul> <div class="after-portlet after-portlet-lang"><span class="uls-after-portlet-link"></span><span class="wb-langlinks-add wb-langlinks-link"><a href="https://www.wikidata.org/wiki/Special:NewItem?site=enwiki&page=Module%3AWikidataIB%2Fsandbox" title="Add interlanguage links" class="wbc-editpage">Add links</a></span></div> </div> </div> </div> </header> <div class="vector-page-toolbar"> <div class="vector-page-toolbar-container"> <div id="left-navigation"> <nav aria-label="Namespaces"> <div id="p-associated-pages" class="vector-menu vector-menu-tabs mw-portlet mw-portlet-associated-pages" > <div class="vector-menu-content"> <ul class="vector-menu-content-list"> <li id="ca-nstab-module" class="selected vector-tab-noicon mw-list-item"><a href="/wiki/Module:WikidataIB/sandbox" title="View the module page [c]" accesskey="c"><span>Module</span></a></li><li id="ca-talk" class="vector-tab-noicon mw-list-item"><a href="/wiki/Module_talk:WikidataIB/sandbox" rel="discussion" title="Discuss improvements to the content page [t]" accesskey="t"><span>Talk</span></a></li> </ul> </div> </div> <div id="vector-variants-dropdown" class="vector-dropdown emptyPortlet" > <input type="checkbox" id="vector-variants-dropdown-checkbox" role="button" aria-haspopup="true" data-event-name="ui.dropdown-vector-variants-dropdown" class="vector-dropdown-checkbox " aria-label="Change language variant" > <label id="vector-variants-dropdown-label" for="vector-variants-dropdown-checkbox" class="vector-dropdown-label cdx-button cdx-button--fake-button cdx-button--fake-button--enabled cdx-button--weight-quiet" aria-hidden="true" ><span class="vector-dropdown-label-text">English</span> </label> <div class="vector-dropdown-content"> <div id="p-variants" class="vector-menu mw-portlet mw-portlet-variants emptyPortlet" > <div class="vector-menu-content"> <ul class="vector-menu-content-list"> </ul> </div> </div> </div> </div> </nav> </div> <div id="right-navigation" class="vector-collapsible"> <nav aria-label="Views"> <div id="p-views" class="vector-menu vector-menu-tabs mw-portlet mw-portlet-views" > <div class="vector-menu-content"> <ul class="vector-menu-content-list"> <li id="ca-view" class="selected vector-tab-noicon mw-list-item"><a href="/wiki/Module:WikidataIB/sandbox"><span>Read</span></a></li><li id="ca-edit" class="vector-tab-noicon mw-list-item"><a href="/w/index.php?title=Module:WikidataIB/sandbox&action=edit" title="Edit this page [e]" accesskey="e"><span>Edit</span></a></li><li id="ca-history" class="vector-tab-noicon mw-list-item"><a href="/w/index.php?title=Module:WikidataIB/sandbox&action=history" title="Past revisions of this page [h]" accesskey="h"><span>View history</span></a></li> </ul> </div> </div> </nav> <nav class="vector-page-tools-landmark" aria-label="Page tools"> <div id="vector-page-tools-dropdown" class="vector-dropdown vector-page-tools-dropdown" > <input type="checkbox" id="vector-page-tools-dropdown-checkbox" role="button" aria-haspopup="true" data-event-name="ui.dropdown-vector-page-tools-dropdown" class="vector-dropdown-checkbox " aria-label="Tools" > <label id="vector-page-tools-dropdown-label" for="vector-page-tools-dropdown-checkbox" class="vector-dropdown-label cdx-button cdx-button--fake-button cdx-button--fake-button--enabled cdx-button--weight-quiet" aria-hidden="true" ><span class="vector-dropdown-label-text">Tools</span> </label> <div class="vector-dropdown-content"> <div id="vector-page-tools-unpinned-container" class="vector-unpinned-container"> <div id="vector-page-tools" class="vector-page-tools vector-pinnable-element"> <div class="vector-pinnable-header vector-page-tools-pinnable-header vector-pinnable-header-unpinned" data-feature-name="page-tools-pinned" data-pinnable-element-id="vector-page-tools" data-pinned-container-id="vector-page-tools-pinned-container" data-unpinned-container-id="vector-page-tools-unpinned-container" > <div class="vector-pinnable-header-label">Tools</div> <button class="vector-pinnable-header-toggle-button vector-pinnable-header-pin-button" data-event-name="pinnable-header.vector-page-tools.pin">move to sidebar</button> <button class="vector-pinnable-header-toggle-button vector-pinnable-header-unpin-button" data-event-name="pinnable-header.vector-page-tools.unpin">hide</button> </div> <div id="p-cactions" class="vector-menu mw-portlet mw-portlet-cactions emptyPortlet vector-has-collapsible-items" title="More options" > <div class="vector-menu-heading"> Actions </div> <div class="vector-menu-content"> <ul class="vector-menu-content-list"> <li id="ca-more-view" class="selected vector-more-collapsible-item mw-list-item"><a href="/wiki/Module:WikidataIB/sandbox"><span>Read</span></a></li><li id="ca-more-edit" class="vector-more-collapsible-item mw-list-item"><a href="/w/index.php?title=Module:WikidataIB/sandbox&action=edit" title="Edit this page [e]" accesskey="e"><span>Edit</span></a></li><li id="ca-more-history" class="vector-more-collapsible-item mw-list-item"><a href="/w/index.php?title=Module:WikidataIB/sandbox&action=history"><span>View history</span></a></li> </ul> </div> </div> <div id="p-tb" class="vector-menu mw-portlet mw-portlet-tb" > <div class="vector-menu-heading"> General </div> <div class="vector-menu-content"> <ul class="vector-menu-content-list"> <li id="t-whatlinkshere" class="mw-list-item"><a href="/wiki/Special:WhatLinksHere/Module:WikidataIB/sandbox" title="List of all English Wikipedia pages containing links to this page [j]" accesskey="j"><span>What links here</span></a></li><li id="t-recentchangeslinked" class="mw-list-item"><a href="/wiki/Special:RecentChangesLinked/Module:WikidataIB/sandbox" rel="nofollow" title="Recent changes in pages linked from this page [k]" accesskey="k"><span>Related changes</span></a></li><li id="t-upload" class="mw-list-item"><a href="/wiki/Wikipedia:File_Upload_Wizard" title="Upload files [u]" accesskey="u"><span>Upload file</span></a></li><li id="t-specialpages" class="mw-list-item"><a href="/wiki/Special:SpecialPages" title="A list of all special pages [q]" accesskey="q"><span>Special pages</span></a></li><li id="t-permalink" class="mw-list-item"><a href="/w/index.php?title=Module:WikidataIB/sandbox&oldid=1164674032" title="Permanent link to this revision of this page"><span>Permanent link</span></a></li><li id="t-info" class="mw-list-item"><a href="/w/index.php?title=Module:WikidataIB/sandbox&action=info" title="More information about this page"><span>Page information</span></a></li><li id="t-urlshortener" class="mw-list-item"><a href="/w/index.php?title=Special:UrlShortener&url=https%3A%2F%2Fen.wikipedia.org%2Fwiki%2FModule%3AWikidataIB%2Fsandbox"><span>Get shortened URL</span></a></li><li id="t-urlshortener-qrcode" class="mw-list-item"><a href="/w/index.php?title=Special:QrCode&url=https%3A%2F%2Fen.wikipedia.org%2Fwiki%2FModule%3AWikidataIB%2Fsandbox"><span>Download QR code</span></a></li> </ul> </div> </div> <div id="p-electronpdfservice-sidebar-portlet-heading" class="vector-menu mw-portlet mw-portlet-electronpdfservice-sidebar-portlet-heading" > <div class="vector-menu-heading"> Print/export </div> <div class="vector-menu-content"> <ul class="vector-menu-content-list"> <li id="electron-print_pdf" class="mw-list-item"><a href="/w/index.php?title=Special:DownloadAsPdf&page=Module%3AWikidataIB%2Fsandbox&action=show-download-screen"><span>Download as PDF</span></a></li><li id="t-print" class="mw-list-item"><a href="javascript:print();" rel="alternate" title="Printable version of this page [p]" accesskey="p"><span>Printable version</span></a></li> </ul> </div> </div> <div id="p-wikibase-otherprojects" class="vector-menu mw-portlet mw-portlet-wikibase-otherprojects emptyPortlet" > <div class="vector-menu-heading"> In other projects </div> <div class="vector-menu-content"> <ul class="vector-menu-content-list"> </ul> </div> </div> </div> </div> </div> </div> </nav> </div> </div> </div> <div class="vector-column-end"> <div class="vector-sticky-pinned-container"> <nav class="vector-page-tools-landmark" aria-label="Page tools"> <div id="vector-page-tools-pinned-container" class="vector-pinned-container"> </div> </nav> <nav class="vector-appearance-landmark" aria-label="Appearance"> <div id="vector-appearance-pinned-container" class="vector-pinned-container"> <div id="vector-appearance" class="vector-appearance vector-pinnable-element"> <div class="vector-pinnable-header vector-appearance-pinnable-header vector-pinnable-header-pinned" data-feature-name="appearance-pinned" data-pinnable-element-id="vector-appearance" data-pinned-container-id="vector-appearance-pinned-container" data-unpinned-container-id="vector-appearance-unpinned-container" > <div class="vector-pinnable-header-label">Appearance</div> <button class="vector-pinnable-header-toggle-button vector-pinnable-header-pin-button" data-event-name="pinnable-header.vector-appearance.pin">move to sidebar</button> <button class="vector-pinnable-header-toggle-button vector-pinnable-header-unpin-button" data-event-name="pinnable-header.vector-appearance.unpin">hide</button> </div> </div> </div> </nav> </div> </div> <div id="bodyContent" class="vector-body" aria-labelledby="firstHeading" data-mw-ve-target-container> <div class="vector-body-before-content"> <div class="mw-indicators"> </div> <div id="siteSub" class="noprint">From Wikipedia, the free encyclopedia</div> </div> <div id="contentSub"><div id="mw-content-subtitle"><div class="subpages">< <bdi dir="ltr"><a href="/wiki/Module:WikidataIB" title="Module:WikidataIB">Module:WikidataIB</a></bdi></div></div></div> <div id="mw-content-text" class="mw-body-content"><div class="mw-content-ltr mw-parser-output" lang="en" dir="ltr"><style data-mw-deduplicate="TemplateStyles:r1237875617">.mw-parser-output .documentation,.mw-parser-output .documentation-metadata{border:1px solid #a2a9b1;background-color:#ecfcf4;clear:both}.mw-parser-output .documentation{margin:1em 0 0 0;padding:1em}.mw-parser-output .documentation-metadata{margin:0.2em 0;font-style:italic;padding:0.4em 1em}.mw-parser-output .documentation-startbox{padding-bottom:3px;border-bottom:1px solid #aaa;margin-bottom:1ex}.mw-parser-output .documentation-heading{font-weight:bold;font-size:125%}.mw-parser-output .documentation-clear{clear:both}.mw-parser-output .documentation-toolbar{font-style:normal;font-size:85%}@media screen{html.skin-theme-clientpref-night .mw-parser-output .documentation,html.skin-theme-clientpref-night .mw-parser-output .documentation-metadata{background-color:#0b1e1c}}@media screen and (prefers-color-scheme:dark){html.skin-theme-clientpref-os .mw-parser-output .documentation,html.skin-theme-clientpref-os .mw-parser-output .documentation-metadata{background-color:#0b1e1c}}</style><div class="documentation-clear"></div><style data-mw-deduplicate="TemplateStyles:r1238436933">.mw-parser-output .ombox{margin:4px 0;border-collapse:collapse;border:1px solid #a2a9b1;background-color:var(--background-color-neutral-subtle,#f8f9fa);box-sizing:border-box;color:var(--color-base,#202122)}.mw-parser-output .ombox.mbox-small{font-size:88%;line-height:1.25em}.mw-parser-output .ombox-speedy{border:2px solid #b32424;background-color:#fee7e6}.mw-parser-output .ombox-delete{border:2px solid #b32424}.mw-parser-output .ombox-content{border:1px solid #f28500}.mw-parser-output .ombox-style{border:1px solid #fc3}.mw-parser-output .ombox-move{border:1px solid #9932cc}.mw-parser-output .ombox-protection{border:2px solid #a2a9b1}.mw-parser-output .ombox .mbox-text{border:none;padding:0.25em 0.9em;width:100%}.mw-parser-output .ombox .mbox-image{border:none;padding:2px 0 2px 0.9em;text-align:center}.mw-parser-output .ombox .mbox-imageright{border:none;padding:2px 0.9em 2px 0;text-align:center}.mw-parser-output .ombox .mbox-empty-cell{border:none;padding:0;width:1px}.mw-parser-output .ombox .mbox-invalid-type{text-align:center}@media(min-width:720px){.mw-parser-output .ombox{margin:4px 10%}.mw-parser-output .ombox.mbox-small{clear:right;float:right;margin:4px 0 4px 1em;width:238px}}body.skin--responsive .mw-parser-output table.ombox img{max-width:none!important}@media screen{html.skin-theme-clientpref-night .mw-parser-output .ombox-speedy{background-color:#310402}}@media screen and (prefers-color-scheme:dark){html.skin-theme-clientpref-os .mw-parser-output .ombox-speedy{background-color:#310402}}</style><table class="plainlinks ombox ombox-notice" role="presentation"><tbody><tr><td class="mbox-image"><span typeof="mw:File"><span><img alt="" src="//upload.wikimedia.org/wikipedia/commons/thumb/8/88/Sandbox.svg/50px-Sandbox.svg.png" decoding="async" width="50" height="33" class="mw-file-element" srcset="//upload.wikimedia.org/wikipedia/commons/thumb/8/88/Sandbox.svg/75px-Sandbox.svg.png 1.5x, //upload.wikimedia.org/wikipedia/commons/thumb/8/88/Sandbox.svg/100px-Sandbox.svg.png 2x" data-file-width="650" data-file-height="424" /></span></span></td><td class="mbox-text">This is the <a href="/wiki/Wikipedia:Template_test_cases" class="mw-redirect" title="Wikipedia:Template test cases">module sandbox</a> page for <a href="/wiki/Module:WikidataIB" title="Module:WikidataIB">Module:WikidataIB</a> (<a class="external text" href="https://en.wikipedia.org/w/index.php?title=Special%3AComparePages&page1=Module%3AWikidataIB&page2=Module%3AWikidataIB%2Fsandbox">diff</a>).<br />See also the companion subpage for <a href="/wiki/Module:WikidataIB/testcases" class="mw-redirect" title="Module:WikidataIB/testcases">test cases</a>.</td></tr></tbody></table><div class="documentation-container" role="complementary" aria-labelledby="documentation-heading"> <div class="documentation"> <div class="documentation-startbox"> <span class="documentation-heading" id="documentation-heading"><span typeof="mw:File"><span><img alt="" src="//upload.wikimedia.org/wikipedia/commons/thumb/4/43/Test_Template_Info-Icon_-_Version_%282%29.svg/50px-Test_Template_Info-Icon_-_Version_%282%29.svg.png" decoding="async" width="50" height="22" class="mw-file-element" srcset="//upload.wikimedia.org/wikipedia/commons/thumb/4/43/Test_Template_Info-Icon_-_Version_%282%29.svg/75px-Test_Template_Info-Icon_-_Version_%282%29.svg.png 1.5x, //upload.wikimedia.org/wikipedia/commons/thumb/4/43/Test_Template_Info-Icon_-_Version_%282%29.svg/100px-Test_Template_Info-Icon_-_Version_%282%29.svg.png 2x" data-file-width="1792" data-file-height="800" /></span></span> Module documentation</span><span class="mw-editsection-like plainlinks">[<a href="/wiki/Module:WikidataIB/doc" title="Module:WikidataIB/doc">view</a>] [<a href="/wiki/Special:EditPage/Module:WikidataIB/doc" title="Special:EditPage/Module:WikidataIB/doc">edit</a>] [<a href="/wiki/Special:PageHistory/Module:WikidataIB/doc" title="Special:PageHistory/Module:WikidataIB/doc">history</a>] [<a href="/wiki/Special:Purge/Module:WikidataIB/sandbox" title="Special:Purge/Module:WikidataIB/sandbox">purge</a>]</span></div> <link rel="mw-deduplicated-inline-style" href="mw-data:TemplateStyles:r1238436933"><table class="plainlinks ombox ombox-notice" role="presentation"><tbody><tr><td class="mbox-image"><span typeof="mw:File"><span><img alt="Protected" src="//upload.wikimedia.org/wikipedia/en/thumb/5/53/Template-protection-shackle.svg/40px-Template-protection-shackle.svg.png" decoding="async" width="40" height="40" class="mw-file-element" srcset="//upload.wikimedia.org/wikipedia/en/thumb/5/53/Template-protection-shackle.svg/60px-Template-protection-shackle.svg.png 1.5x, //upload.wikimedia.org/wikipedia/en/thumb/5/53/Template-protection-shackle.svg/80px-Template-protection-shackle.svg.png 2x" data-file-width="512" data-file-height="512" /></span></span></td><td class="mbox-text">This module is <a href="/wiki/Category:Modules_subject_to_page_protection" title="Category:Modules subject to page protection">subject to page protection</a>. It is a <a href="/wiki/Wikipedia:High-risk_templates" title="Wikipedia:High-risk templates">highly visible module</a> in use by a very large number of pages, or is <a href="/wiki/Wikipedia:Substitution" title="Wikipedia:Substitution">substituted</a> very frequently. Because vandalism or mistakes would affect many pages, and even trivial editing might cause substantial load on the servers, it is <a href="/wiki/Wikipedia:Protection_policy" title="Wikipedia:Protection policy">protected</a> from editing.</td></tr></tbody></table> <link rel="mw-deduplicated-inline-style" href="mw-data:TemplateStyles:r1238436933"><table class="plainlinks ombox ombox-notice" role="presentation"><tbody><tr><td class="mbox-image"><span typeof="mw:File"><span><img alt="" src="//upload.wikimedia.org/wikipedia/en/thumb/1/1d/Information_icon4.svg/40px-Information_icon4.svg.png" decoding="async" width="40" height="40" class="mw-file-element" srcset="//upload.wikimedia.org/wikipedia/en/thumb/1/1d/Information_icon4.svg/60px-Information_icon4.svg.png 1.5x, //upload.wikimedia.org/wikipedia/en/thumb/1/1d/Information_icon4.svg/80px-Information_icon4.svg.png 2x" data-file-width="620" data-file-height="620" /></span></span></td><td class="mbox-text">For a more user-friendly wrapper of this module see <span class="nowrap">{{</span><a href="/wiki/Template:Wdib" title="Template:Wdib">wdib</a><span class="nowrap">}}</span>.</td></tr></tbody></table> <p>This module is intended to be used inside <span class="nowrap">{{</span><a href="/wiki/Template:Infobox" title="Template:Infobox">infobox</a><span class="nowrap">}}</span> (letters Wikidata<b>IB</b> stand for <i>Info Box</i>, hence the name) or other templates and designed specifically to allow editors of an article (as opposed to editors of the infobox the article uses) to control whether Wikidata values are displayed. </p><p>One of the two sandboxes should be used for testing anything other than trivial amendments. </p><p>Test examples for the main module and the two sandboxes are available. </p> <table class="wikitable plainrowheaders"> <caption>Modules and test cases </caption> <tbody><tr> <th> </th> <th scope="col">Module </th> <th scope="col">Test cases </th></tr> <tr> <th scope="row">Main </th> <td><a href="/wiki/Module:WikidataIB" title="Module:WikidataIB">Module:WikidataIB</a> </td> <td><a href="/wiki/Module_talk:WikidataIB/testing" title="Module talk:WikidataIB/testing">Module talk:WikidataIB/testing</a> </td></tr> <tr> <th scope="row">sandbox </th> <td><a class="mw-selflink selflink">Module:WikidataIB/sandbox</a> (<span class="plainlinks"><a class="external text" href="https://en.wikipedia.org/w/index.php?title=Special:ComparePages&page1=Module%3AWikidataIB&page2=Module%3AWikidataIB%2Fsandbox">diff</a></span>) </td> <td><a href="/wiki/Module_talk:WikidataIB/sandbox/testing" title="Module talk:WikidataIB/sandbox/testing">Module talk:WikidataIB/sandbox/testing</a> (<span class="plainlinks"><a class="external text" href="https://en.wikipedia.org/w/index.php?title=Special:ComparePages&page1=Module+talk%3AWikidataIB%2Ftesting&page2=Module+talk%3AWikidataIB%2Fsandbox%2Ftesting">diff</a></span>) </td></tr> <tr> <th scope="row">sandbox1 </th> <td><a href="/wiki/Module:WikidataIB/sandbox1" title="Module:WikidataIB/sandbox1">Module:WikidataIB/sandbox1</a> (<span class="plainlinks"><a class="external text" href="https://en.wikipedia.org/w/index.php?title=Special:ComparePages&page1=Module%3AWikidataIB&page2=Module%3AWikidataIB%2Fsandbox1">diff</a></span>) </td> <td><a href="/wiki/Module_talk:WikidataIB/sandbox1/testing" title="Module talk:WikidataIB/sandbox1/testing">Module talk:WikidataIB/sandbox1/testing</a> (<span class="plainlinks"><a class="external text" href="https://en.wikipedia.org/w/index.php?title=Special:ComparePages&page1=Module+talk%3AWikidataIB%2Ftesting&page2=Module+talk%3AWikidataIB%2Fsandbox1%2Ftesting">diff</a></span>) </td></tr></tbody></table> <meta property="mw:PageProp/toc" /> <div class="mw-heading mw-heading2"><h2 id="Overview">Overview</h2><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-1" title="Edit section: Overview"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>The module provides these calls specifically for use in infoboxes at present: </p> <ol><li><code>getValue</code> - main call, used to get the value(s) of a given property</li> <li><code>getQualifierValue</code> - given: (1) a property; (2) its value; (3) a qualifier's propertyID, returns values which match</li> <li><code>getValueByQual</code> gets the value of a property which has a qualifier with a given entity value</li> <li><code>getValueByLang</code> gets the value of a property which has a qualifier P407("language of work or name") whose value has the given language code</li> <li><code>getValueByRefSource</code> gets the value of a property which has a reference "stated in" (P248) whose value has the given entity-ID</li> <li><code>getPropOfProp</code> if the value(s) of prop1 are of type "wikibase-item" then it returns the value(s) of prop2 of each of those wikibase-items</li> <li><code>getAwardCat</code> if the item has values of P166 (award received), then it examines each of those awards for P2517 (category for recipients of this award) and it returns the corresponding category, with the item's P734 (family name) as sort key, or no sort key if there is no family name</li> <li><code>getIntersectCat</code> for each value of the prop1 it fetches the value's main category and then each value of prop2, then it returns all of the categories representing the intersection of those properties</li> <li><code>getSumOfParts</code> scans the property 'has part' (P527) for values matching a list. If the matched values have a qualifier 'quantity' (P1114), those quantities are summed and returned (but zero returns nil)</li> <li><code>getCoords</code> gets coordinates and passes them through <span class="nowrap">{{</span><a href="/wiki/Template:Coord" title="Template:Coord">Coord</a><span class="nowrap">}}</span></li> <li><code>getPreferredValue</code> - <style data-mw-deduplicate="TemplateStyles:r1239334494">@media screen{html.skin-theme-clientpref-night .mw-parser-output div:not(.notheme)>.tmp-color,html.skin-theme-clientpref-night .mw-parser-output p>.tmp-color,html.skin-theme-clientpref-night .mw-parser-output table:not(.notheme) .tmp-color{color:inherit!important}}@media screen and (prefers-color-scheme:dark){html.skin-theme-clientpref-os .mw-parser-output div:not(.notheme)>.tmp-color,html.skin-theme-clientpref-os .mw-parser-output p>.tmp-color,html.skin-theme-clientpref-os .mw-parser-output table:not(.notheme) .tmp-color{color:inherit!important}}</style><span class="tmp-color" style="color:red"><b>Deprecated</b></span> but retained for backward compatibility. Use the <code>|getValue|rank=best</code> parameters instead</li></ol> <p>The obsolete call getSourcedValue has now been removed as it is redundant to getValue which can do the same job using the <code class="tpl-para" style="word-break:break-word;">|onlysourced=true</code> parameter (which is set by default). </p> <div class="mw-heading mw-heading3"><h3 id="Utilities_functions">Utilities functions</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-2" title="Edit section: Utilities functions"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <ol><li><code>getLink</code> if there is a sitelink to an article on the local Wiki, it returns a link to the article with the Wikidata label as the displayed text. If there is no sitelink, it returns the label as plain text. If there is no label in the local language, it returns the entity-ID</li> <li><code>getAT</code> (Article Title) If there is a sitelink to an article on the local Wiki, it returns the sitelink as plain text, otherwise nothing</li> <li><code>getSiteLink</code> gets the plain text link to an article on a given wiki</li> <li><code>getLabel</code> returns the Wikidata label for the local language as plain text. If there is no label in the local language, it returns the entity-ID</li> <li><code>getAllLabels</code> fetches the set of labels and formats it for display as wikitext</li> <li><code>labelorid</code> returns the label with all wikitext removed, or the entity-ID if no label</li> <li><code>getDescription</code> returns the article description for the Wikidata entity if the local parameter is "Wikidata"</li> <li><code>getAllDescriptions</code> fetches the set of descriptions and formats it for display as wikitext</li> <li><code>getAliases</code> returns the aliases for the entity in the current or given language</li> <li><code>getAllAliases</code> fetches the set of aliases and formats it for display as wikitext</li> <li><code>pageId</code> returns the connected Wikidata page id (entity-ID, Q-number) of the current page</li> <li><code>formatDate</code> takes a datetime of the usual format from mw.wikibase.entity:formatPropertyValues and formats it according to the df (date format) and bc parameters</li> <li><code>formatNumber</code> formats a number according to the supplied language code</li> <li><code>checkBlacklist</code> returns true if the field is <i>not</i> blacklisted (i.e. allowed)</li> <li><code>emptyor</code> returns nil if the parameter is just punctuation, whitespace or html tags, otherwise returns the argument unchanged</li> <li><code>getLang</code> returns the MediaWiki language code or the full language name of the current content</li> <li><code>getItemLangCode</code> looks for country (P17), then for that country's official language (P37), and returns its language code (P424)</li> <li><code>findLanguage</code> returns (1) supplied language if valid; or (2) the user's set language; or (3) the language of the current wiki</li> <li><code>getQid</code> returns (1) the entity-ID, if supplied; or (2) the entity ID of the "category's main topic (P301)"; or (3) the entity ID associated with the current page; or (4) nothing</li> <li><code>followQid</code> given a list of properties, looks for each property in turn and returns the entity-ID of the first value that matches (optionally, returns all entity-IDs that match)</li> <li><code>getGlobe</code> returns the entity-ID of the globe used in P625 (coordinate location), or nil if there isn't one</li> <li><code>getCommonsLink</code> returns one of the following in order of preference: the Commons sitelink of the linked Wikidata item; the Commons sitelink of the topic's main category of the linked Wikidata item</li> <li><code>siteID</code> returns the root of the globalSiteID, e.g. "en" for "enwiki", "enwikisource", "en-gb", etc.</li> <li><code>projID</code> same as siteID</li> <li><code>location</code> scans from the current location upwards along the chain of higher-level locations, returning each one until it reaches a country</li> <li><code>examine</code> returns a formatted dump of the given property</li> <li><code>url2</code> takes a parameter that is a proper url and formats it for use in an infobox; it accepts its own output as input</li> <li><code>getWebsite</code> fetches the Official website (P856) and formats it for use in an infobox</li> <li><code>checkvalue</code> looks through a property for a given entity-ID as its value and returns that entity-ID if found; otherwise nil</li> <li><code>checkValidity</code> returns whether the first unnamed parameter represents a valid entity-id</li> <li><code>showNoLinks</code> displays the article titles that should not be linked</li></ol> <div class="mw-heading mw-heading3"><h3 id="Examples_of_calls">Examples of calls</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-3" title="Edit section: Examples of calls"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <pre>{{#invoke:WikidataIB |getValue |<PropertyID> |name=<fieldname> |suppressfields=<list of fields which will never display> |fetchwikidata=<list of fields to fetch values from Wikidata> |onlysourced=<yes/no> |noicon=<yes/no> |df=<dmy/mdy/y> |bc=<BC/BCE> |qual=<ALL/DATES/P999> |list=<ubl/hlist/prose> |linked=<yes/no> |<local parameter>}} </pre> <pre>{{#invoke:WikidataIB |getCoords |name=<fieldname> |suppressfields=<list of fields which will never display> |fetchwikidata=<list of fields to fetch values from Wikidata> |<local parameter>}} </pre> <pre>{{#invoke:WikidataIB |getQualifierValue |<PropertyID> |pval=<ID of target value for the property> |qual=<qualifier ID for that target value> |name=<fieldname> |suppressfields=<list of fields which will never display> |fetchwikidata=<list of fields to fetch values from Wikidata> |onlysourced=<yes/no>}} </pre> <pre>{{#invoke:WikidataIB |getValueByQual |<PropertyID> |qualID=<qualifier property ID to match> |qvalue=<QID of target value for the qualifier property> |name=<fieldname> |suppressfields=<list of fields which will never display> |fetchwikidata=<list of fields to fetch values from Wikidata> |onlysourced=<yes/no>}} </pre> <pre>{{#invoke:WikidataIB |getValueByLang |<PropertyID> |lang=<language code to match> |name=<fieldname> |suppressfields=<list of fields which will never display> |fetchwikidata=<list of fields to fetch values from Wikidata> |onlysourced=<yes/no>}} </pre> <div class="mw-heading mw-heading2"><h2 id="Function_getValue">Function getValue</h2><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-4" title="Edit section: Function getValue"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <div class="mw-heading mw-heading3"><h3 id="Parameters_to_getValue">Parameters to getValue</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-5" title="Edit section: Parameters to getValue"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <table class="wikitable sortable"> <tbody><tr> <th scope="col">Name </th> <th scope="col">Alias </th> <th scope="col">Function </th> <th scope="col">Default </th></tr> <tr> <td>(first unnamed) </td> <td>1 </td> <td>The property-ID whose values are returned. Required. </td> <td> </td></tr> <tr> <td>(second unnamed) </td> <td>2 </td> <td>A locally supplied value that, if it is not empty, will be returned in preference to the value on Wikidata. </td> <td>empty </td></tr> <tr> <td>qid </td> <td> </td> <td>The Q-number (entity-ID) of the entity that the property belongs to. If not supplied or empty, defaults to the associated Wikidata entry of the current page – uses <a href="https://www.mediawiki.org/wiki/Extension:Wikibase_Client/Lua#mw.wikibase.getEntityIdForCurrentPage" class="extiw" title="mw:Extension:Wikibase Client/Lua">mw.wikibase.getEntityIdForCurrentPage()</a>. </td> <td>Item id for current page </td></tr> <tr> <td>eid </td> <td> </td> <td>An alternative to qid. Except for <code>eid</code>, all parameters to getValue treat nil and the empty string the same. So, setting <code class="tpl-para" style="word-break:break-word;">|x=</code> gives the same result as omitting the parameter. However, to provide some compatibility with other modules, using <code class="tpl-para" style="word-break:break-word;">|eid=</code> always returns an empty string, while omitting <code>eid</code> allows <code>qid</code> to work as normal. </td> <td>Item id for current page </td></tr> <tr> <td>rank </td> <td> </td> <td>[Case insensitive] When set to <code>best</code>, returns preferred values if present, otherwise returns normal values. When set to <code>preferred</code> returns preferred values. When set to <code>normal</code>, returns normal values. When set to <code>deprecated</code> returns deprecated values. Any parameter value beginning with "b" is "best"; beginning with "p" is "preferred"; beginning with "n" is "normal"; beginning with "d" is deprecated. Multiple values are allowed: "p n d" would return all ranks. "Best" overrides the other flags. Other values are ignored and if no ranks are requested, preferred and normal are returned. </td> <td>preferred and normal </td></tr> <tr> <td>qual </td> <td> </td> <td>A punctuation-separated list of property-IDs of qualifiers that are to be returned in parentheses after the property. Setting <code>qual=ALL</code> returns all qualifiers. Setting <code>qual=DATES</code> returns <a href="https://www.wikidata.org/wiki/Special:EntityPage/P580" class="extiw" title="d:Special:EntityPage/P580">start time <small>(P580)</small></a> and <a href="https://www.wikidata.org/wiki/Special:EntityPage/P582" class="extiw" title="d:Special:EntityPage/P582">end time <small>(P582)</small></a> with a date separator. </td> <td>none </td></tr> <tr> <td>qualsonly </td> <td>qo </td> <td>A boolean which enables the display of just the qualifier(s), without the property value or parentheses. Values <code>no</code>, <code>false</code> and <code>0</code> are all false; anything else is true. </td> <td>false </td></tr> <tr> <td>fetchwikidata </td> <td>fwd </td> <td>List of fields to fetch values from. <code>ALL</code> fetches all fields. A value of <code>NONE</code> or blank or omitting the parameter fetches no fields. </td> <td>none </td></tr> <tr> <td>suppressfields </td> <td>spf </td> <td>List of fields which will never display. This will even force a local value in the field not to display. </td> <td>none </td></tr> <tr> <td>name </td> <td> </td> <td>Name of the field. When encoding an infobox, this is the name that fetchwikidata and suppressfields will recognise. Required if fetchwikidata or suppressfields is specified (except when <code>fetchwikidata=ALL</code>). </td> <td>nil </td></tr> <tr> <td>onlysourced </td> <td>osd </td> <td>A boolean which will filter out Wikidata values that are unsourced or only sourced to Wikipedia. <a href="/wiki/Wikipedia:Wikidata/2018_Infobox_RfC#Discussion" title="Wikipedia:Wikidata/2018 Infobox RfC">This 2018 RFC</a> requires that Wikidata values displayed in article infoboxes must be sourced. Values <code>no</code>, <code>false</code> and <code>0</code> are all false; anything else is true. </td> <td>true </td></tr> <tr> <td>df </td> <td> </td> <td>Date format: may be <code>dmy</code> (day before month) or <code>mdy</code> (month before day) or <code>y</code> (year alone). </td> <td>dmy </td></tr> <tr> <td>qdf </td> <td> </td> <td>Date format of qualifiers. If omitted, defaults to parameter <code>df</code>, or "y" if <code>df</code> is also omitted. </td> <td>value of df or "y" </td></tr> <tr> <td>bc </td> <td> </td> <td>Format of the BC/BCE suffix for dates. </td> <td>BCE </td></tr> <tr> <td>plaindate </td> <td>pd </td> <td>String to modify formatting of dates. Setting "true"/"yes"/"1" disables adding "sourcing cirumstances" (P1480) and any links. Setting "adj" does the same but uses the adjectival form of the date. </td> <td>false </td></tr> <tr> <td>linked </td> <td> </td> <td>A boolean that enables the link to a local page via its sitelink on Wikidata. Values <code>no</code>, <code>false</code> and <code>0</code> are all false; anything else is true. </td> <td>true </td></tr> <tr> <td>displaytext </td> <td>dt </td> <td>A string that overrides the displayed text of a linked item if it is non-empty. </td> <td>empty </td></tr> <tr> <td>shortname </td> <td>sn </td> <td>A boolean that enables the use of shortname (P1813) instead of label for a linked item. Values <code>no</code>, <code>false</code> and <code>0</code> are all false; anything else is true. </td> <td>false </td></tr> <tr> <td>uselabel </td> <td>uselbl </td> <td>A boolean that forces the display of the label instead of the disambiguated sitelink for a linked item. Labels are much more prone to vandalism that sitelinks. Values <code>no</code>, <code>false</code> and <code>0</code> are all false; anything else is true. </td> <td>false </td></tr> <tr> <td>wdlinks </td> <td>wdl </td> <td>A boolean that enables the display of links to Wikidata when no local article exists. Values <code>no</code>, <code>false</code> and <code>0</code> are all false; anything else is true. </td> <td>false </td></tr> <tr> <td>unitabbr </td> <td>uabbr </td> <td>A boolean that enables unit abbreviations for common units. Values <code>no</code>, <code>false</code> and <code>0</code> are all false; anything else is true. </td> <td>false </td></tr> <tr> <td>convert </td> <td>conv </td> <td>A boolean that enables passing of quantities to Template:Cvt. Values <code>no</code>, <code>false</code> and <code>0</code> are all false; anything else is true. </td> <td>false </td></tr> <tr> <td>showunits </td> <td>su </td> <td>A boolean that enables showing units for quantities. Values <code>no</code>, <code>false</code> and <code>0</code> are all false; anything else is true. </td> <td>true </td></tr> <tr> <td>scale </td> <td> </td> <td>A string that sets scaling for format of quantities. Values are: "a"=automatic; "0"=no scaling; "3"=thousand; "6"=million; "9"=billion; "12"=trillion. </td> <td>0 </td></tr> <tr> <td>maxvals </td> <td> </td> <td>Sets the maximum number of values to be returned when multiple values are available. Setting it to 1 is useful where the returned string is used within another call, e.g. image. Values <code>0</code> and empty return all values. </td> <td>0 (all) </td></tr> <tr> <td>collapse </td> <td> </td> <td>Sets the maximum number of values to be returned before the content is auto-collapsed. Values <code>0</code> and empty allow all content to be displayed uncollapsed. </td> <td>0 (all) </td></tr> <tr> <td>linkprefix </td> <td>lp </td> <td>A link prefix that is prepended to the linked value when linked. Applies only to items that have articles and to strings (e.g. url). It triggers linking of strings. Any double-quotes " are stripped out, so that spaces may be passed. </td> <td>empty </td></tr> <tr> <td>linkpostfix </td> <td> </td> <td>A link postfix that is appended to the linked value when linked. Applies only to items that have articles and to strings (e.g. url). It triggers linking of strings. Any double-quotes " are stripped out, so that spaces may be passed. </td> <td>empty </td></tr> <tr> <td>prefix </td> <td> </td> <td>A prefix that is prepended to the displayed value of strings (e.g. url). Any double-quotes " are stripped out, so that spaces may be passed. </td> <td>empty </td></tr> <tr> <td>postfix </td> <td> </td> <td>A postfix that is appended to the displayed value of strings (e.g. url). Any double-quotes " are stripped out, so that spaces may be passed. </td> <td>empty </td></tr> <tr> <td>qlinkprefix </td> <td>qlp </td> <td>Qualifier link prefix (see linkprefix). </td> <td>empty </td></tr> <tr> <td>qlinkpostfix </td> <td> </td> <td>Qualifier link postfix (see linkpostfix). </td> <td>empty </td></tr> <tr> <td>qprefix </td> <td> </td> <td>Qualifier prefix (see prefix). </td> <td>empty </td></tr> <tr> <td>qpostfix </td> <td> </td> <td>Qualifier postfix (see postfix). </td> <td>empty </td></tr> <tr> <td>sorted </td> <td> </td> <td>A boolean which enables sorting of the values returned. Values <code>no</code>, <code>false</code> and <code>0</code> are all false; anything else is true. </td> <td>false </td></tr> <tr> <td>qsorted </td> <td> </td> <td>A boolean which enables sorting of the qualifier values within each item returned. Values <code>no</code>, <code>false</code> and <code>0</code> are all false; anything else is true. </td> <td>false </td></tr> <tr> <td>noicon </td> <td> </td> <td>A boolean which will suppress the trailing "edit at Wikidata" pen-icon. Useful for when the returned value is to be further processed. Values <code>no</code>, <code>false</code> and <code>0</code> are all false (i.e. shows the icon); anything else is true (i.e. suppresses the icon). </td> <td>false </td></tr> <tr> <td>list </td> <td> </td> <td>The name of a template that the list of multiple values is then passed through. Examples include "cslist", "hlist", "ubl", "blist", "olist", "p-1". A special value, <code>prose</code>, produces "1, 2, 3 and 4". </td> <td>none </td></tr> <tr> <td>sep </td> <td> </td> <td>Customises the string that is used to separate multiple returned values. Any double-quotes " are stripped out, so that spaces may be passed. If nothing or an empty string is passed it is set to the default list separator (", " in English). </td> <td>", " </td></tr> <tr> <td>qsep </td> <td> </td> <td>Customises the string that is used to separate multiple returned qualifier values. Any double-quotes " are stripped out, so that spaces may be passed. If nothing or an empty string is passed it is set to the default list separator (", " in English). </td> <td>", " </td></tr> <tr> <td>format </td> <td> </td> <td>Determines whether global coordinates should be rendered as degree/minute/second or as decimal degrees. Any value beginning "dec" (case insensitive) will render as decimal. Anything else will render as DMS. </td> <td>dms </td></tr> <tr> <td>show </td> <td> </td> <td>Determines how global coordinates should be returned. The value "longlat" will return <code>longitude, latitude</code>. Any other value beginning "lon" (case insensitive) will return just longitude. Any value beginning "lat" (case insensitive) will return just latitude. When used with <code class="tpl-para" style="word-break:break-word;">|noicon=true</code>, all of these will be pure numbers in decimal degrees (signed: N and E as positive), which are intended for use in mapping templates, etc. Anything other value (or nothing) will render the usual coordinate values as DMS or decimal with "NSEW" qualifiers, etc. </td> <td>empty </td></tr> <tr> <td>lang </td> <td> </td> <td>Allows an unlinked value to be returned in the chosen language. Takes a standard ISO language code recognised by MediaWiki. If not supplied or blank, the local language (or set language for multi-lingual wikis) is used as normal. </td> <td>local language </td></tr> <tr> <td>parameterset </td> <td>ps </td> <td>Convenience parameter to allow commonly used sets of parameters to be specified with a single parameter: ps=1 gets a simple linked value wherever possible; ps=2 represents a plain text value. See <a href="#Parameter_sets">Parameter sets</a>. </td> <td> </td></tr> <tr> <td>linkredir </td> <td> </td> <td>Boolean to switch on or off the check for a redirect with the same name as the label when there is no sitelink on Wikidata for the value. Values <code>no</code>, <code>false</code> and <code>0</code> are all false; anything else is true. </td> <td>false </td></tr></tbody></table> <div class="mw-heading mw-heading3"><h3 id="Base_parameters">Base parameters</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-6" title="Edit section: Base parameters"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <ul><li>getValue can also take a named parameter <code class="tpl-para" style="word-break:break-word;">|qid=</code> which is the Wikidata ID for an article. This will not normally be used as omitting it defaults to the current article.</li> <li>The property whose value is to be returned is passed in the first unnamed property and is required.</li> <li>The second unnamed parameter, if supplied, will become the returned value and no call to Wikidata will be made.</li></ul> <div class="mw-heading mw-heading3"><h3 id="Whitelist_and_blacklist">Whitelist and blacklist</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-7" title="Edit section: Whitelist and blacklist"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <ul><li>The name of the field that this function is called from is passed in the named parameter <code class="tpl-para" style="word-break:break-word;">|name=</code>, which is first checked against a blacklist of fields that are never to be displayed, (i.e. the call must return nil in all circumstances). If the field is not on the blacklist, it is then checked against a whitelist. If the name of the field matches, the call will return any locally supplied value if it is supplied as the second unnamed parameter, or the Wikidata value otherwise.</li> <li>Specifying <code class="tpl-para" style="word-break:break-word;">|fetchwikidata=ALL</code> is a shortcut to return all fields that are not blacklisted.</li> <li>The name is compulsory when the blacklist or whitelist is used, so the module returns nil if it is not supplied, other than when <code class="tpl-para" style="word-break:break-word;">|fetchwikidata=ALL</code>.</li> <li>The blacklist is passed in the named parameter <code class="tpl-para" style="word-break:break-word;">|suppressfields=</code></li> <li>The whitelist is passed in the named parameter <code class="tpl-para" style="word-break:break-word;">|fetchwikidata=</code></li></ul> <div class="mw-heading mw-heading3"><h3 id="Sourcing">Sourcing</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-8" title="Edit section: Sourcing"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>The getValue function will accept a boolean parameter <code>onlysourced</code> which will suppress return of Wikidata values that are unsourced or only sourced to a Wikimedia project. The absence of the parameter, an empty parameter (<code class="tpl-para" style="word-break:break-word;">|onlysourced=</code>) and the empty string (<code>""</code>) all default to true (i.e. only referenced values are returned). The values <code>no</code>, <code>false</code> and <code>0</code> are treated as false (i.e. all values are returned); any other value is true (although <code class="tpl-para" style="word-break:break-word;">|onlysourced=yes/no</code> is recommended for readability). </p> <div class="mw-heading mw-heading3"><h3 id="Link_to_Wikidata">Link to Wikidata</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-9" title="Edit section: Link to Wikidata"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>The getValue function will accept a boolean parameter <code>noicon</code> which will suppress the trailing "edit at Wikidata" icon and link for cases when the returned value is to be further processed by the infobox (e.g. a url). The absence of the parameter or an empty parameter (<code class="tpl-para" style="word-break:break-word;">|noicon=</code>) default to false (i.e. the icon is added). The empty string (<code>""</code>) and the values <code>no</code>, <code>false</code> and <code>0</code> are treated as false; any other value is true (although <code class="tpl-para" style="word-break:break-word;">|noicon=true</code> is recommended for readability). </p><p>Following a discussion at <a href="/wiki/Module_talk:WikidataIB#Visibility_of_pen_icon" title="Module talk:WikidataIB">Module talk:WikidataIB #Visibility of pen icon</a>, the pen icon is hidden from users who are not autoconfirmed. This means that most readers don't see the pen icon, and represents a balance between aesthetics and vandalism at Wikidata on the one hand, and the desire to encourage editing Wikidata on the other. </p> <div class="mw-heading mw-heading3"><h3 id="Dates">Dates</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-10" title="Edit section: Dates"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>In order to handle the requirement for dates in mdy, dmy or just year formats, getValue accepts a named parameter <code class="tpl-para" style="word-break:break-word;">|df=</code> that may take the values "dmy", "mdy", or "y" - default is "dmy". </p><p>As an article may require either of suffixes BC and BCE, getValue accepts a named parameter <code class="tpl-para" style="word-break:break-word;">|bc=</code> that may take the values "BC", or "BCE" - default is "BCE". Some test cases are shown at <a href="/wiki/Module_talk:WikidataIB/testing#Calls_to_getValue_for_dates" title="Module talk:WikidataIB/testing">Module talk:WikidataIB/testing #Calls to getValue for dates</a>. </p> <div class="mw-heading mw-heading3"><h3 id="Ranks">Ranks</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-11" title="Edit section: Ranks"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>The <code class="tpl-para" style="word-break:break-word;">|rank=</code> parameter, when set to preferred, returns only preferred values; when set to normal, returns only normal values; when set to deprecated, returns only deprecated values. If the parameter is set to best, it returns preferred values if present, otherwise normal values. Any parameter value beginning with "p" is "preferred"; any parameter value beginning with "n" is "normal"; any parameter value beginning with "d" is "deprecated"; any parameter value beginning with "b" is "best". Combinations of values are allowed, e.g. <code class="tpl-para" style="word-break:break-word;">|rank=p n</code> returns all the preferred and normal values (which is the default), although "best" overrides any other parameters. </p> <div class="mw-heading mw-heading4"><h4 id="Specific_value-type_handlers">Specific value-type handlers</h4><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-12" title="Edit section: Specific value-type handlers"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>The module has specific handlers for the following data types: </p> <ol><li>Items that correspond to an article in some Wikipedia, called "wikibase-items". These will be linked to the corresponding (and disambiguated) article on English Wikipedia where possible.</li> <li>Items that represent dates. These may be centuries, years, years and months, or years, months and days.</li> <li>Items that represent Commons media, urls, external ids, or other sorts of plain text.</li> <li>Items that represent quantities. All of these may have an associated unit, or be dimensionless, and may have a range.</li> <li>Items that represent global coordinates. These will be in degrees of latitude and longitude and will have an associated precision.</li></ol> <p>Items that represent other types of data are not handled at present. </p><p>The third class of data types may be used with the parameters: </p> <ul><li><code class="tpl-para" style="word-break:break-word;">|prefix=</code>, <code class="tpl-para" style="word-break:break-word;">|postfix=</code>, <code class="tpl-para" style="word-break:break-word;">|linkprefix=</code>, <code class="tpl-para" style="word-break:break-word;">|linkpostfix=</code></li></ul> <p>If you don't supply at least one of <code class="tpl-para" style="word-break:break-word;">|linkprefix=</code> or <code class="tpl-para" style="word-break:break-word;">|linkpostfix=</code>, then just <code class="tpl-para" style="word-break:break-word;">|prefix=</code> and <code class="tpl-para" style="word-break:break-word;">|postfix=</code> are used. For example, when getting the <a href="https://www.wikidata.org/wiki/Special:EntityPage/P717" class="extiw" title="d:Special:EntityPage/P717">Minor Planet Center observatory code <small>(P717)</small></a> in <a href="https://www.wikidata.org/wiki/Special:EntityPage/Q532127" class="extiw" title="d:Special:EntityPage/Q532127">Vienna Observatory <small>(Q532127)</small></a>: </p> <ul><li><code>{{#invoke:WikidataIB/sandbox|getValue|P717|fetchwikidata=ALL|onlysourced=no |prefix="before " |postfix=" after" |qid=Q532127}}</code> → before 045 after <span class="penicon autoconfirmed-show"><span class="mw-valign-text-top" typeof="mw:File/Frameless"><a href="https://www.wikidata.org/wiki/Q532127?uselang=en#P717" title="Edit this on Wikidata"><img alt="Edit this on Wikidata" src="//upload.wikimedia.org/wikipedia/en/thumb/8/8a/OOjs_UI_icon_edit-ltr-progressive.svg/10px-OOjs_UI_icon_edit-ltr-progressive.svg.png" decoding="async" width="10" height="10" class="mw-file-element" srcset="//upload.wikimedia.org/wikipedia/en/thumb/8/8a/OOjs_UI_icon_edit-ltr-progressive.svg/15px-OOjs_UI_icon_edit-ltr-progressive.svg.png 1.5x, //upload.wikimedia.org/wikipedia/en/thumb/8/8a/OOjs_UI_icon_edit-ltr-progressive.svg/20px-OOjs_UI_icon_edit-ltr-progressive.svg.png 2x" data-file-width="20" data-file-height="20" /></a></span></span></li></ul> <p>Use double-quotes to enclose the parameter value if it has leading or trailing spaces (otherwise they are stripped out). If you supply <code class="tpl-para" style="word-break:break-word;">|linkprefix=</code> or <code class="tpl-para" style="word-break:break-word;">|linkpostfix=</code>, then all four parameters are used and a link is made for each value like this: </p> <ul><li><code>[[ linkprefix WikidataValue1 linkpostfix | prefix WikidataValue1 postfix]], [[ linkprefix WikidataValue2 linkpostfix | prefix WikidataValue2 postfix]], etc.</code></li></ul> <p>That allows multiple links to be made to different sections of a list article, such as <a href="/wiki/List_of_observatory_codes" title="List of observatory codes">List of observatory codes</a>. For example, when getting the <a href="https://www.wikidata.org/wiki/Special:EntityPage/P717" class="extiw" title="d:Special:EntityPage/P717">Minor Planet Center observatory code <small>(P717)</small></a> in <a href="https://www.wikidata.org/wiki/Special:EntityPage/Q532127" class="extiw" title="d:Special:EntityPage/Q532127">Vienna Observatory <small>(Q532127)</small></a> we can make the links: </p> <ul><li><code>{{#invoke:WikidataIB/sandbox|getValue|P717|fetchwikidata=ALL|onlysourced=no |prefix= |postfix= |linkprefix="List of observatory codes#" |linkpostfix= |qid=Q532127}}</code> → [List of observatory codes#045 045] <span class="penicon autoconfirmed-show"><span class="mw-valign-text-top" typeof="mw:File/Frameless"><a href="https://www.wikidata.org/wiki/Q532127?uselang=en#P717" title="Edit this on Wikidata"><img alt="Edit this on Wikidata" src="//upload.wikimedia.org/wikipedia/en/thumb/8/8a/OOjs_UI_icon_edit-ltr-progressive.svg/10px-OOjs_UI_icon_edit-ltr-progressive.svg.png" decoding="async" width="10" height="10" class="mw-file-element" srcset="//upload.wikimedia.org/wikipedia/en/thumb/8/8a/OOjs_UI_icon_edit-ltr-progressive.svg/15px-OOjs_UI_icon_edit-ltr-progressive.svg.png 1.5x, //upload.wikimedia.org/wikipedia/en/thumb/8/8a/OOjs_UI_icon_edit-ltr-progressive.svg/20px-OOjs_UI_icon_edit-ltr-progressive.svg.png 2x" data-file-width="20" data-file-height="20" /></a></span></span></li></ul> <p>The parameters <code class="tpl-para" style="word-break:break-word;">|prefix=</code>, <code class="tpl-para" style="word-break:break-word;">|postfix=</code>, <code class="tpl-para" style="word-break:break-word;">|linkprefix=</code>, <code class="tpl-para" style="word-break:break-word;">|linkpostfix=</code> are also applied to wikibase-items if they are linked. </p> <div class="mw-heading mw-heading4"><h4 id="Formatting_multiple_returned_values">Formatting multiple returned values</h4><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-13" title="Edit section: Formatting multiple returned values"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <ul><li><code class="tpl-para" style="word-break:break-word;">|sorted=<yes|no></code> is a boolean passed to enable sorting of the values returned. No parameter, or an empty string, or "false", or "no", or "0" disables sorting. It's only a very dumb alphabetical sort and sorts linked values as "[[ ..."</li> <li><code class="tpl-para" style="word-break:break-word;">|sep=<separator characters></code> allows the separator between multiple returned values to be defined. The default is <code>", "</code> (comma plus normal space). If the separator has leading or trailing spaces, enclose it in double quotes (e.g. <code class="tpl-para" style="word-break:break-word;">|sep=" - "</code>). Any double quotes are stripped from the separator. The pipe character (<code>|</code>) must be escaped as <code>{{!}}</code>. For reasons of accessibility (see <a href="/wiki/MOS:PLIST" class="mw-redirect" title="MOS:PLIST">MOS:PLIST</a>), do not use <code class="tpl-para" style="word-break:break-word;">|sep=<br></code> for vertical unbulleted lists; use <code class="tpl-para" style="word-break:break-word;">|list=ubl</code> instead.</li> <li><code class="tpl-para" style="word-break:break-word;">|list=<prose|cslist|hlist|ubl|blist|olist></code> allows multiple returned values to be displayed as a sentence with last two values separated by "and" (<code class="tpl-para" style="word-break:break-word;">|list=prose</code>), a horizontal comma-separated list (<code class="tpl-para" style="word-break:break-word;">|list=cslist</code>, not to be used in prose), a horizontal list (<code class="tpl-para" style="word-break:break-word;">|list=hlist</code>), a vertical unbulleted list (<code class="tpl-para" style="word-break:break-word;">|list=ubl</code>), a vertical bulleted list (<code class="tpl-para" style="word-break:break-word;">|list=blist</code>), or a vertical ordered list (<code class="tpl-para" style="word-break:break-word;">|list=olist</code>). These override the separator and do not display the 'pen icon' linked to "Edit at Wikidata".</li> <li><code class="tpl-para" style="word-break:break-word;">|list=p-1</code> displays the last value. Combine with <code class="tpl-para" style="word-break:break-word;">|maxvals=<i>n</i></code> to display the <i>n</i>th value.</li></ul> <div class="mw-heading mw-heading3"><h3 id="Limiting_the_returned_values">Limiting the returned values</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-14" title="Edit section: Limiting the returned values"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>Sometimes a property is expected to have a single value, such as <a href="https://www.wikidata.org/wiki/Special:EntityPage/P18" class="extiw" title="d:Special:EntityPage/P18">image <small>(P18)</small></a>, but may have multiple values on Wikidata. Setting <code class="tpl-para" style="word-break:break-word;">|maxvals=1</code> will limit the number of values returned to 1. Any other value is possible and functions as expected, but zero is treated as "no limit". </p> <div class="mw-heading mw-heading3"><h3 id="Unlinking">Unlinking</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-15" title="Edit section: Unlinking"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>A returned value that represents an article on the local wiki will be linked by default. This includes redirects, but not dab pages. Sometimes there is a need not to link that returned values and this may be accomplished by setting <code class="tpl-para" style="word-break:break-word;">|linked=no</code>. </p> <div class="mw-heading mw-heading3"><h3 id="Unit_abbreviations">Unit abbreviations</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-16" title="Edit section: Unit abbreviations"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>When the returned value is a quantity, the name of the units in which it is expressed is appended. Infoboxes may wish to use abbreviations instead for common units. This can be done by setting <code class="tpl-para" style="word-break:break-word;">|unitabbr=true</code>. </p> <div class="mw-heading mw-heading3"><h3 id="Qualifiers">Qualifiers</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-17" title="Edit section: Qualifiers"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>A parameter <code class="tpl-para" style="word-break:break-word;">|qual=</code> may be supplied, which will return qualifiers of the required property, if they exist. If the value is set to a punctuation-separated list of property-IDs (e.g. P123, P456), then only the values of qualifiers with that property will be returned. If the value is set to <code class="tpl-para" style="word-break:break-word;">|qual=ALL</code>, then all of the qualifier values are returned. If the value is set to <code class="tpl-para" style="word-break:break-word;">|qual=DATES</code> then the <a href="https://www.wikidata.org/wiki/Special:EntityPage/P580" class="extiw" title="d:Special:EntityPage/P580">start time <small>(P580)</small></a> and the <a href="https://www.wikidata.org/wiki/Special:EntityPage/P582" class="extiw" title="d:Special:EntityPage/P582">end time <small>(P582)</small></a> of the property are returned with a date separator. In each case, any qualifier values returned follow the property value, and are enclosed in parentheses. If multiple qualifier values are returned, they will be separated by commas by default, although the separator can be changed by specifying <code class="tpl-para" style="word-break:break-word;">|qsep=</code> (which may be enclosed in double-quotes, which are stripped out, so that spaces can be included). Setting the parameter <code class="tpl-para" style="word-break:break-word;">|qsorted=yes</code> will sort the returned qualifier values alphanumerically. </p> <div class="mw-heading mw-heading3"><h3 id="Short_form_of_parameters">Short form of parameters</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-18" title="Edit section: Short form of parameters"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>Some of the longer parameters may be abbreviated to make infobox designs more compact: </p> <ul><li><code>fwd → fetchwikidata</code></li> <li><code>osd → onlysourced</code></li> <li><code>spf → suppressfields</code></li> <li><code>wdl → wdlinks</code></li></ul> <div class="mw-heading mw-heading3"><h3 id="Parameter_sets">Parameter sets</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-19" title="Edit section: Parameter sets"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>Generally, <code>getValue</code> has a set of defaults for its parameters that represent consensus decisions by editors. For example, <code class="tpl-para" style="word-break:break-word;">|onlysourced=</code> defaults to <code>true</code> so only Wikidata values that are sourced to something better than "Wikipedia" will be returned, and <code class="tpl-para" style="word-break:break-word;">|fetchwikidata=</code> defaults to <code>none</code> so nothing is returned until it is enabled by setting some field names or "ALL". This represents the fail-safe condition and allows infoboxes to be made Wikidata-capable without changing any article until enabled <i>for that article</i>. </p><p>To simplify the use of <code>getValue</code> in other circumstances, common combinations of parameters can be specified with <code class="tpl-para" style="word-break:break-word;">|parameterset=</code> or its alias <code class="tpl-para" style="word-break:break-word;">|ps=</code> for convenience. Two combinations are implemented at present and these are: </p> <dl><dt>ps=1</dt> <dd>a common set of overrides to get a simple value, linked where possible:</dd></dl> <pre>|rank ="best" |fetchwikidata="ALL" |onlysourced ="no" |noicon ="true" </pre> <dl><dt>ps=2</dt> <dd>a sort of raw value in plain text:</dd></dl> <pre>|rank = "best" |fetchwikidata = "ALL" |onlysourced = "no" |noicon = "true" |linked = "no" |plaindate = "true" </pre> <p>Other sets could be created if there is a demand. </p> <div class="mw-heading mw-heading3"><h3 id="Wrapper_template">Wrapper template</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-20" title="Edit section: Wrapper template"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>The template <span class="nowrap">{{</span><a href="/wiki/Template:Wdib" title="Template:Wdib">wdib</a><span class="nowrap">}}</span> can be used as a convenient wrapper for <code>{{#invoke:WikidataIB |getValue}}</code>. </p> <div class="mw-heading mw-heading2"><h2 id="Other_main_functions">Other main functions</h2><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-21" title="Edit section: Other main functions"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <div class="mw-heading mw-heading3"><h3 id="Function_getPreferredValue">Function getPreferredValue</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-22" title="Edit section: Function getPreferredValue"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>The getPreferredValue function works exactly like getValue, taking the same parameters, but if any values for a property have the preferred rank set, it will only return those values. This is now deprecated in favour of <code>getValue|rank=best</code>. </p> <div class="mw-heading mw-heading3"><h3 id="Function_getCoords">Function getCoords</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-23" title="Edit section: Function getCoords"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <ul><li>getCoords can also take a named parameter <code class="tpl-para" style="word-break:break-word;">|qid=</code> which is the Wikidata ID for an article. This will not normally be used as omitting it defaults to the current article.</li> <li>The first unnamed parameter, if supplied, will become the returned value and no call to Wikidata will be made.</li> <li>The coordinates from Wikidata are parsed and passed to <a href="/wiki/Template:Coord" title="Template:Coord">Template:Coord</a> which returns the display as if it were called manually.</li> <li>The blacklist of fields that are never to be displayed, and the whitelist are implemented in the same way as for getValue using <code class="tpl-para" style="word-break:break-word;">|suppressfields=</code> and <code class="tpl-para" style="word-break:break-word;">|fetchwikidata=</code></li> <li>The <code>format</code> parameter sets the display format to decimal or dms. Any value beginning with "dec" sets decimal; anything else sets dms.</li> <li>The <code>display</code> parameter sets the display position to "inline", "title" or "inline, title". Default is nothing (so uses default for <span class="nowrap">{{</span><a href="/wiki/Template:Coord" title="Template:Coord">Coord</a><span class="nowrap">}}</span>, currently "inline").</li></ul> <div class="mw-heading mw-heading3"><h3 id="Function_getQualifierValue">Function getQualifierValue</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-24" title="Edit section: Function getQualifierValue"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>The getQualifierValue function is for use when we want to fetch the value of a qualifier. We need to know the property and the value of the property that the qualifier relates to. The parameters are: </p> <ul><li>The property ID passed in the unnamed parameter (or <code class="tpl-para" style="word-break:break-word;">|1=</code>)</li> <li>The target value for that property in <code class="tpl-para" style="word-break:break-word;">|pval=</code></li> <li>The qualifier ID for that target value in <code class="tpl-para" style="word-break:break-word;">|qual=</code></li> <li>The same parameters to implement whitelisting and blacklisting of the property as in getValue</li> <li>Optional boolean to specify whether only sourced values of the property are returned (defaults to "no") in <code class="tpl-para" style="word-break:break-word;">|onlysourced=</code></li> <li>Optional item ID for arbitrary access in <code class="tpl-para" style="word-break:break-word;">|qid=</code></li> <li>The same parameters to format output as in getValue</li></ul> <div class="mw-heading mw-heading4"><h4 id="Example_of_getQualifierValue">Example of getQualifierValue</h4><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-25" title="Edit section: Example of getQualifierValue"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>In <a href="https://www.wikidata.org/wiki/Special:EntityPage/Q1513315" class="extiw" title="d:Special:EntityPage/Q1513315">South Pole Telescope <small>(Q1513315)</small></a> there is a property <a href="https://www.wikidata.org/wiki/Special:EntityPage/P793" class="extiw" title="d:Special:EntityPage/P793">significant event <small>(P793)</small></a>, which has a value <a href="https://www.wikidata.org/wiki/Special:EntityPage/Q385378" class="extiw" title="d:Special:EntityPage/Q385378">construction <small>(Q385378)</small></a>. That has two qualifiers, <a href="https://www.wikidata.org/wiki/Special:EntityPage/P580" class="extiw" title="d:Special:EntityPage/P580">start time <small>(P580)</small></a> and <a href="https://www.wikidata.org/wiki/Special:EntityPage/P582" class="extiw" title="d:Special:EntityPage/P582">end time <small>(P582)</small></a>. To get the start date: </p> <ul><li><code>{{#invoke:WikidataIB |getQualifierValue |qid=Q1513315 |P793 |pval=Q385378 |qual=P580 |name=xyz |fetchwikidata=ALL }}</code></li></ul> <p>In <a href="/wiki/South_Pole_Telescope" title="South Pole Telescope">South Pole Telescope</a> it returns: </p> <ul><li>November 2006 <span class="penicon autoconfirmed-show"><span class="mw-valign-text-top" typeof="mw:File/Frameless"><a href="https://www.wikidata.org/wiki/Q1513315?uselang=en#P793" title="Edit this on Wikidata"><img alt="Edit this on Wikidata" src="//upload.wikimedia.org/wikipedia/en/thumb/8/8a/OOjs_UI_icon_edit-ltr-progressive.svg/10px-OOjs_UI_icon_edit-ltr-progressive.svg.png" decoding="async" width="10" height="10" class="mw-file-element" srcset="//upload.wikimedia.org/wikipedia/en/thumb/8/8a/OOjs_UI_icon_edit-ltr-progressive.svg/15px-OOjs_UI_icon_edit-ltr-progressive.svg.png 1.5x, //upload.wikimedia.org/wikipedia/en/thumb/8/8a/OOjs_UI_icon_edit-ltr-progressive.svg/20px-OOjs_UI_icon_edit-ltr-progressive.svg.png 2x" data-file-width="20" data-file-height="20" /></a></span></span></li></ul> <div class="mw-heading mw-heading3"><h3 id="Function_getValueByQual">Function getValueByQual</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-26" title="Edit section: Function getValueByQual"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>The getValueByQual function returns the value of a property which has a qualifier with a given entity value. The parameters are: </p> <ul><li>The property ID passed in the unnamed parameter (or <code class="tpl-para" style="word-break:break-word;">|1=</code>)</li> <li>The property ID for a qualifier (or "ALL" or "DATES") in <code class="tpl-para" style="word-break:break-word;">|qualID=</code></li> <li>The Wikibase-entity ID of a value for that qualifier in <code class="tpl-para" style="word-break:break-word;">|qvalue=</code></li> <li>The same parameters to implement whitelisting and blacklisting of the property as in getValue</li> <li>Optional boolean to specify whether only sourced values of the property are returned (defaults to "no") in <code class="tpl-para" style="word-break:break-word;">|onlysourced=</code></li> <li>Optional item ID for arbitrary access in <code class="tpl-para" style="word-break:break-word;">|qid=</code></li> <li>The same parameters to format output as in getValue</li></ul> <div class="mw-heading mw-heading4"><h4 id="Example_of_getValueByQual">Example of getValueByQual</h4><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-27" title="Edit section: Example of getValueByQual"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>In <a href="https://www.wikidata.org/wiki/Special:EntityPage/Q10990" class="extiw" title="d:Special:EntityPage/Q10990">meat <small>(Q10990)</small></a> there is a property <a href="https://www.wikidata.org/wiki/Special:EntityPage/P443" class="extiw" title="d:Special:EntityPage/P443">pronunciation audio <small>(P443)</small></a> that has multiple values, each of which has a qualifier <a href="https://www.wikidata.org/wiki/Special:EntityPage/P407" class="extiw" title="d:Special:EntityPage/P407">language of work or name <small>(P407)</small></a>. We can return the property value whose qualifier has the value <a href="https://www.wikidata.org/wiki/Special:EntityPage/Q13955" class="extiw" title="d:Special:EntityPage/Q13955">Arabic <small>(Q13955)</small></a> </p> <ul><li><code>{{#invoke:WikidataIB |getValueByQual |qid=Q10990 |P443 |qualID=P407 |qvalue=Q13955 |fwd=ALL |osd=no |noicon=true}}</code> → Ar-لحم.ogg</li></ul> <div class="mw-heading mw-heading3"><h3 id="Function_getValueByLang">Function getValueByLang</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-28" title="Edit section: Function getValueByLang"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>The getValueByLang function returns the value of a property which has a qualifier <a href="https://www.wikidata.org/wiki/Special:EntityPage/P407" class="extiw" title="d:Special:EntityPage/P407">language of work or name <small>(P407)</small></a> whose value has the given language code. The parameters are: </p> <ul><li>The property ID passed in the unnamed parameter (or <code class="tpl-para" style="word-break:break-word;">|1=</code>)</li> <li>The <a href="https://www.wikidata.org/wiki/Special:EntityPage/P424" class="extiw" title="d:Special:EntityPage/P424">Wikimedia language code <small>(P424)</small></a> to match the language whose code is given by <code class="tpl-para" style="word-break:break-word;">|lang=xx[-yy]</code>. If no code is supplied, it uses the default language.</li> <li>The same parameters to implement whitelisting and blacklisting of the property as in getValue</li> <li>Optional boolean to specify whether only sourced values of the property are returned (defaults to "no") in <code class="tpl-para" style="word-break:break-word;">|onlysourced=</code></li> <li>Optional item ID for arbitrary access in <code class="tpl-para" style="word-break:break-word;">|qid=</code></li> <li>The same parameters to format output as in getValue</li></ul> <div class="mw-heading mw-heading4"><h4 id="Example_of_getValueByLang">Example of getValueByLang</h4><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-29" title="Edit section: Example of getValueByLang"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>In <a href="https://www.wikidata.org/wiki/Special:EntityPage/Q7565108" class="extiw" title="d:Special:EntityPage/Q7565108">OSDN <small>(Q7565108)</small></a> there is a property <a href="https://www.wikidata.org/wiki/Special:EntityPage/P856" class="extiw" title="d:Special:EntityPage/P856">official website <small>(P856)</small></a> that has multiple values, each of which has a qualifier <a href="https://www.wikidata.org/wiki/Special:EntityPage/P407" class="extiw" title="d:Special:EntityPage/P407">language of work or name <small>(P407)</small></a>. We can return the property value whose <a href="https://www.wikidata.org/wiki/Special:EntityPage/P407" class="extiw" title="d:Special:EntityPage/P407">language of work or name <small>(P407)</small></a> qualifier value (a WD item) itself has the <a href="https://www.wikidata.org/wiki/Special:EntityPage/P424" class="extiw" title="d:Special:EntityPage/P424">Wikimedia language code <small>(P424)</small></a> property that is "ja", i.e, <a href="https://www.wikidata.org/wiki/Special:EntityPage/Q5287" class="extiw" title="d:Special:EntityPage/Q5287">Japanese <small>(Q5287)</small></a> </p> <ul><li><code>{{#invoke:WikidataIB |getValueByLang |qid=Q7565108 |P856 |lang=ja |fwd=ALL |osd=no |noicon=true}}</code> → <a rel="nofollow" class="external free" href="https://ja.osdn.net/">https://ja.osdn.net/</a></li></ul> <p>If <code class="tpl-para" style="word-break:break-word;">|lang=</code> is unspecified, we can obtain the same value with the default language (here that is the <a href="https://www.wikidata.org/wiki/Special:EntityPage/Q1860" class="extiw" title="d:Special:EntityPage/Q1860">English <small>(Q1860)</small></a> and its <a href="https://www.wikidata.org/wiki/Special:EntityPage/P424" class="extiw" title="d:Special:EntityPage/P424">Wikimedia language code <small>(P424)</small></a> is "en") </p> <ul><li><code>{{#invoke:WikidataIB |getValueByLang |qid=Q7565108 |P856 |fwd=ALL |osd=no |noicon=true}}</code> → <a rel="nofollow" class="external free" href="https://osdn.net/">https://osdn.net/</a></li></ul> <div class="mw-heading mw-heading2"><h2 id="Utility_functions">Utility functions</h2><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-30" title="Edit section: Utility functions"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <div class="mw-heading mw-heading3"><h3 id="Function_getLink">Function getLink</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-31" title="Edit section: Function getLink"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>getLink has the qid of a Wikidata entity passed as the first unnamed parameter or as |qid= </p><p>If there is a sitelink to an article on the local Wiki, it returns a link to the article with the Wikidata label as the displayed text. If there is no sitelink, it returns the label as plain text. If there is no label in the local language, it displays the qid instead. </p> <dl><dd>Wikidata: <a href="https://www.wikidata.org/wiki/Special:EntityPage/Q29016906" class="extiw" title="d:Special:EntityPage/Q29016906">Corisca and the Satyr <small>(Q29016906)</small></a> and <a href="https://www.wikidata.org/wiki/Special:EntityPage/Q3621491" class="extiw" title="d:Special:EntityPage/Q3621491">archaeologist <small>(Q3621491)</small></a></dd></dl> <ul><li><code>{{#invoke:WikidataIB |getLink |Q29016906}}</code> → <a href="/wiki/Corisca_and_the_Satyr" title="Corisca and the Satyr">Corisca and the Satyr</a></li> <li><code>{{#invoke:WikidataIB |getLink |Q3621491}}</code> → <a href="/wiki/Archaeologist" class="mw-redirect" title="Archaeologist">archaeologist</a></li></ul> <div class="mw-heading mw-heading3"><h3 id="Function_getLabel">Function getLabel</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-32" title="Edit section: Function getLabel"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>getLabel has the qid of a Wikidata entity passed as the first unnamed parameter or as <code class="tpl-para" style="word-break:break-word;">|qid=</code> </p><p>It returns the Wikidata label in the local language for an item by the given qid. If there is no label in the local language, it returns the qid instead. Note that this is the label given to the Wikidata entry in the same language as the current Wiki, if the label exists. </p> <dl><dd>Wikidata: <a href="https://www.wikidata.org/wiki/Special:EntityPage/Q29016906" class="extiw" title="d:Special:EntityPage/Q29016906">Corisca and the Satyr <small>(Q29016906)</small></a> and <a href="https://www.wikidata.org/wiki/Special:EntityPage/Q3621491" class="extiw" title="d:Special:EntityPage/Q3621491">archaeologist <small>(Q3621491)</small></a></dd></dl> <ul><li><code>{{#invoke:WikidataIB |getLabel |Q29016906}}</code> → Corisca and the Satyr</li> <li><code>{{#invoke:WikidataIB |getLabel |Q3621491}}</code> → archaeologist</li> <li><code>{{#invoke:WikidataIB |getLabel |Q19805408}}</code> → Module:Biblio/Ouvrage</li></ul> <div class="mw-heading mw-heading3"><h3 id="Function_label">Function label</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-33" title="Edit section: Function label"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>label has the qid of a Wikidata entity passed as the first unnamed parameter or as <code class="tpl-para" style="word-break:break-word;">|qid=</code> </p><p>It returns the Wikidata label in the local language for an item by the given qid or linked to the current page. If there is no label in the local language, it returns an empty string. Note that this is the label given to the Wikidata entry in the same language as the current Wiki, if the label exists. </p> <dl><dd>Wikidata: <a href="https://www.wikidata.org/wiki/Special:EntityPage/Q29016906" class="extiw" title="d:Special:EntityPage/Q29016906">Corisca and the Satyr <small>(Q29016906)</small></a> and <a href="https://www.wikidata.org/wiki/Special:EntityPage/Q3621491" class="extiw" title="d:Special:EntityPage/Q3621491">archaeologist <small>(Q3621491)</small></a></dd></dl> <ul><li><code>{{#invoke:WikidataIB |label |Q29016906}}</code> → Corisca and the Satyr</li> <li><code>{{#invoke:WikidataIB |label |Q3621491}}</code> → archaeologist</li> <li><code>{{#invoke:WikidataIB |label |Q19805408}}</code> → Module:Biblio/Ouvrage</li></ul> <div class="mw-heading mw-heading3"><h3 id="Function_getAT">Function getAT</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-34" title="Edit section: Function getAT"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>getAT has the qid of a Wikidata entity passed as the first unnamed parameter or as |qid= </p><p>If there is a sitelink to an article on the local Wiki, it returns the sitelink as plain text, i.e. the article title. If there is no sitelink, it returns nothing. Note that this is the title of the article in the current Wikipedia, if the interlanguage link exists in the Wikidata entry. </p> <dl><dd>Wikidata: <a href="https://www.wikidata.org/wiki/Special:EntityPage/Q29016906" class="extiw" title="d:Special:EntityPage/Q29016906">Corisca and the Satyr <small>(Q29016906)</small></a> and <a href="https://www.wikidata.org/wiki/Special:EntityPage/Q3621491" class="extiw" title="d:Special:EntityPage/Q3621491">archaeologist <small>(Q3621491)</small></a></dd></dl> <ul><li><code>{{#invoke:WikidataIB |getAT |Q29016906}}</code> → Corisca and the Satyr</li> <li><code>{{#invoke:WikidataIB |getAT |Q3621491}}</code> → Archaeologist</li></ul> <div class="mw-heading mw-heading3"><h3 id="Function_getDescription">Function getDescription</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-35" title="Edit section: Function getDescription"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>getDescription has the qid of a Wikidata entity passed as |qid= (it defaults to the associated qid of the current article if omitted). It has a local parameter passed as the first unnamed parameter. Any local parameter passed (other than "Wikidata" or "none") becomes the return value. It returns the article description for the Wikidata entity in plain text if the local parameter is "Wikidata". Nothing is returned if the description doesn't exist or "none" is passed as the local parameter. </p> <dl><dd>Wikidata: <a href="https://www.wikidata.org/wiki/Special:EntityPage/Q29016906" class="extiw" title="d:Special:EntityPage/Q29016906">Corisca and the Satyr <small>(Q29016906)</small></a> and <a href="https://www.wikidata.org/wiki/Special:EntityPage/Q3621491" class="extiw" title="d:Special:EntityPage/Q3621491">archaeologist <small>(Q3621491)</small></a></dd></dl> <ul><li><code>{{#invoke:WikidataIB |getDescription |qid=Q29016906 |wikidata}}</code> → painting by Artemisia Gentileschi</li> <li><code>{{#invoke:WikidataIB |getDescription |qid=Q29016906 |A painting}}</code> → A painting</li> <li><code>{{#invoke:WikidataIB |getDescription |qid=Q29016906 |none}}</code> →</li> <li><code>{{#invoke:WikidataIB |getDescription |qid=Q3621491 |wikidata}}</code> → person studying human activity in the past</li> <li><code>{{#invoke:WikidataIB |getDescription |qid=Q3621491 |A profession}}</code> → A profession</li> <li><code>{{#invoke:WikidataIB |getDescription |qid=Q3621491 |none}}</code> →</li></ul> <div class="mw-heading mw-heading3"><h3 id="Function_formatDate">Function formatDate</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-36" title="Edit section: Function formatDate"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>formatDate accepts a datetime of the usual format from mw.wikibase.entity:formatPropertyValues, like "1 August 30 BCE" as parameter 1 and formats it according to the df (date format) and bc parameters. </p> <ul><li><code>{{#invoke:WikidataIB |formatDate | 1 August 30 BCE |bc=BCE |df=dmy}}</code> → 1 August 30 BCE</li> <li><code>{{#invoke:WikidataIB |formatDate | 1 August 30 BCE |bc=BC |df=mdy}}</code> → August 1, 30 BC</li> <li>df = "dmy" / "mdy" / "y" - default is "dmy"</li> <li>bc = "BC" / "BCE" - default is "BCE"</li></ul> <div class="mw-heading mw-heading3"><h3 id="Function_checkBlacklist">Function checkBlacklist</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-37" title="Edit section: Function checkBlacklist"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>checkBlacklist allows a test to check whether a named field is allowed. It returns true if the field is not blacklisted (i.e. allowed) It returns false if the field is blacklisted (i.e. disallowed) </p><p>Example: </p> <ul><li><code>{{#if:{{#invoke:WikidataIB |checkBlacklist |name=nationality |suppressfields=residence; nationality; citizenship}} | not blacklisted | blacklisted}}</code> → not blacklisted</li> <li><code>{{#if:{{#invoke:WikidataIB |checkBlacklist |name=birth_place |suppressfields=residence; nationality; citizenship}} | not blacklisted | blacklisted}}</code> → not blacklisted</li></ul> <div class="mw-heading mw-heading3"><h3 id="Function_emptyor">Function emptyor</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-38" title="Edit section: Function emptyor"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>emptyor returns nil if its first unnamed argument is just punctuation, whitespace or html tags otherwise it returns the argument unchanged (including leading/trailing space). </p><p>If the argument could contain "=", then it must be called explicitly: </p> <ul><li><code>| 1 = whatever-the-argument-is</code></li></ul> <p>In that case, leading and trailing spaces are trimmed. </p><p>It finds use in infoboxes where it can replace tests like: </p> <ul><li><code>{{#if: {{#invoke:WikidataIB |getvalue |P99 |fwd=ALL}} | <span class="xxx">{{#invoke:WikidataIB |getvalue |P99 |fwd=ALL}}</span> | }}</code></li></ul> <p>with a form that uses just a single call to Wikidata: </p> <ul><li><code>{{#invoke |WikidataIB |emptyor |1= <span class="xxx">{{#invoke:WikidataIB |getvalue |P99 |fwd=ALL}}</span> }}</code></li></ul> <div class="mw-heading mw-heading3"><h3 id="Function_labelorid">Function labelorid</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-39" title="Edit section: Function labelorid"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>labelorid is a public function to expose the output of labelOrId(). </p><p>The Q-number (entity ID) is passed as |qid= or as an unnamed parameter. </p><p>It returns the Wikidata label for that entity or the qid if no label exists. </p> <div class="mw-heading mw-heading3"><h3 id="Function_getQid">Function getQid</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-40" title="Edit section: Function getQid"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <ul><li>getQid works with the current page and its associated Wikidata entry.</li> <li>It returns qid, if supplied as the first unnamed parameter or as <code class="tpl-para" style="word-break:break-word;">|qid=</code>;</li> <li>failing that, the Wikidata entity ID of the "category's main topic (P301)", if it exists;</li> <li>failing that, the Wikidata entity ID associated with the current page, if it exists;</li> <li>otherwise, nothing</li></ul> <div class="mw-heading mw-heading3"><h3 id="Function_examine">Function examine</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-41" title="Edit section: Function examine"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>examine provides a dump of the entire property given in the first unnamed parameter (or in <code class="tpl-para" style="word-break:break-word;">|pid=</code> as a named alias) from the item given by the parameter 'qid', or from the item corresponding to the current page if qid is not supplied. Both parameters may be unnamed and given in any order. </p><p>It works in a similar manner to the <a href="/wiki/Module:Wikidata" title="Module:Wikidata">Dump</a> function, but only loads a single claim, rather than the whole Wikidata entry. </p> <ul><li>Example: <code>{{#invoke:WikidataIB |examine |qid=Q1396889 |P50}}</code></li></ul> <p>There is a <a href="/wiki/Template:Examine" class="mw-redirect" title="Template:Examine">Template:Examine</a> which acts as a wrapper for the call. </p> <ul><li>Example: <code>{{examine |Q4048254 |P31}}</code> →</li></ul> <pre>table#1 { table#2 { ["id"] = "Q4048254$9af461b4-a1d0-4c67-a7f0-f668944a17d6", ["mainsnak"] = table#3 { ["datatype"] = "wikibase-item", ["datavalue"] = table#4 { ["type"] = "wikibase-entityid", ["value"] = table#5 { ["entity-type"] = "item", ["id"] = "Q4656150", ["numeric-id"] = 4656150, }, }, ["property"] = "P31", ["snaktype"] = "value", }, ["rank"] = "normal", ["references"] = table#6 { table#7 { ["hash"] = "3bf39867b037e8e494a8389ae8a03bad6825a7fc", ["snaks"] = table#8 { ["P143"] = table#9 { table#10 { ["datatype"] = "wikibase-item", ["datavalue"] = table#11 { ["type"] = "wikibase-entityid", ["value"] = table#12 { ["entity-type"] = "item", ["id"] = "Q191168", ["numeric-id"] = 191168, }, }, ["property"] = "P143", ["snaktype"] = "value", }, }, }, ["snaks-order"] = table#13 { "P143", }, }, }, ["type"] = "statement", }, table#14 { ["id"] = "q4048254$d1f08825-499b-8d4a-d1ee-304b2498a7fd", ["mainsnak"] = table#15 { ["datatype"] = "wikibase-item", ["datavalue"] = table#16 { ["type"] = "wikibase-entityid", ["value"] = table#17 { ["entity-type"] = "item", ["id"] = "Q14204246", ["numeric-id"] = 14204246, }, }, ["property"] = "P31", ["snaktype"] = "value", }, ["rank"] = "normal", ["type"] = "statement", }, }</pre> <div class="mw-heading mw-heading3"><h3 id="Function_url2">Function url2</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-42" title="Edit section: Function url2"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>url2 takes a parameter url= that is a proper url and formats it for use in an infobox. </p><p>Examples: </p> <ol><li><code>{{#invoke:WikidataIB |url2 |url= http://www.example.com/ }}</code> → <span class="url"><a rel="nofollow" class="external text" href="http://www.example.com/">www<wbr />.example<wbr />.com</a></span> <pre style="white-space: pre-wrap;"><span class="url">[http://www.example.com/ www<wbr/>.example<wbr/>.com]</span>&nbsp;</pre></li> <li><code>{{#invoke:WikidataIB |url2 |url= http://www.example.com/path/ }}</code> → <span class="url"><a rel="nofollow" class="external text" href="http://www.example.com/path/">www<wbr />.example<wbr />.com<wbr />/path<wbr />/</a></span> <pre style="white-space: pre-wrap;"><span class="url">[http://www.example.com/path/ www<wbr/>.example<wbr/>.com<wbr/>/path<wbr/>/]</span>&nbsp;</pre></li> <li><code>{{#invoke:WikidataIB |url2 |url= {{wdib |P856 |qid=Q23317 |fwd=ALL |osd=no}} }}</code> → <span class="url"><a rel="nofollow" class="external text" href="https://www.audi.com,">https://www.audi.co.za/, https://www.audi.de/, https://www.audi.fr/ www<wbr />.audi<wbr />.com, https:<wbr />/<wbr />/www<wbr />.audi<wbr />.co<wbr />.za<wbr />/, https:<wbr />/<wbr />/www<wbr />.audi<wbr />.de<wbr />/, https:<wbr />/<wbr />/www<wbr />.audi<wbr />.fr<wbr />/</a></span> <span class="penicon autoconfirmed-show"><span class="mw-valign-text-top" typeof="mw:File/Frameless"><a href="https://www.wikidata.org/wiki/Q23317?uselang=en#P856" title="Edit this on Wikidata"><img alt="Edit this on Wikidata" src="//upload.wikimedia.org/wikipedia/en/thumb/8/8a/OOjs_UI_icon_edit-ltr-progressive.svg/10px-OOjs_UI_icon_edit-ltr-progressive.svg.png" decoding="async" width="10" height="10" class="mw-file-element" srcset="//upload.wikimedia.org/wikipedia/en/thumb/8/8a/OOjs_UI_icon_edit-ltr-progressive.svg/15px-OOjs_UI_icon_edit-ltr-progressive.svg.png 1.5x, //upload.wikimedia.org/wikipedia/en/thumb/8/8a/OOjs_UI_icon_edit-ltr-progressive.svg/20px-OOjs_UI_icon_edit-ltr-progressive.svg.png 2x" data-file-width="20" data-file-height="20" /></a></span></span><pre style="white-space: pre-wrap;"><span class="url">[https://www.audi.com, https://www.audi.co.za/, https://www.audi.de/, https://www.audi.fr/ www<wbr/>.audi<wbr/>.com, https:<wbr/>/<wbr/>/www<wbr/>.audi<wbr/>.co<wbr/>.za<wbr/>/, https:<wbr/>/<wbr/>/www<wbr/>.audi<wbr/>.de<wbr/>/, https:<wbr/>/<wbr/>/www<wbr/>.audi<wbr/>.fr<wbr/>/]</span>&nbsp;<span class='penicon autoconfirmed-show'>[[File:OOjs UI icon edit-ltr-progressive.svg |frameless |text-top |10px |alt=Edit this on Wikidata|link=https://www.wikidata.org/wiki/Q23317?uselang=en#P856|Edit this on Wikidata]]</span></pre> <dl><dd><code>{{wdib |P856 |qid=Q23317 |fwd=ALL |osd=no}}</code> → <a rel="nofollow" class="external free" href="https://www.audi.com">https://www.audi.com</a>, <a rel="nofollow" class="external free" href="https://www.audi.co.za/">https://www.audi.co.za/</a>, <a rel="nofollow" class="external free" href="https://www.audi.de/">https://www.audi.de/</a>, <a rel="nofollow" class="external free" href="https://www.audi.fr/">https://www.audi.fr/</a> <span class="penicon autoconfirmed-show"><span class="mw-valign-text-top" typeof="mw:File/Frameless"><a href="https://www.wikidata.org/wiki/Q23317?uselang=en#P856" title="Edit this on Wikidata"><img alt="Edit this on Wikidata" src="//upload.wikimedia.org/wikipedia/en/thumb/8/8a/OOjs_UI_icon_edit-ltr-progressive.svg/10px-OOjs_UI_icon_edit-ltr-progressive.svg.png" decoding="async" width="10" height="10" class="mw-file-element" srcset="//upload.wikimedia.org/wikipedia/en/thumb/8/8a/OOjs_UI_icon_edit-ltr-progressive.svg/15px-OOjs_UI_icon_edit-ltr-progressive.svg.png 1.5x, //upload.wikimedia.org/wikipedia/en/thumb/8/8a/OOjs_UI_icon_edit-ltr-progressive.svg/20px-OOjs_UI_icon_edit-ltr-progressive.svg.png 2x" data-file-width="20" data-file-height="20" /></a></span></span><pre style="white-space: pre-wrap;">https://www.audi.com, https://www.audi.co.za/, https://www.audi.de/, https://www.audi.fr/&nbsp;<span class='penicon autoconfirmed-show'>[[File:OOjs UI icon edit-ltr-progressive.svg |frameless |text-top |10px |alt=Edit this on Wikidata|link=https://www.wikidata.org/wiki/Q23317?uselang=en#P856|Edit this on Wikidata]]</span></pre></dd></dl></li> <li><code>{{#invoke:WikidataIB |url2 |url= {{url|http://www.example.com/}} }}</code> → <span class="url"><a rel="nofollow" class="external text" href="http://www.example.com/">www<wbr />.example<wbr />.com</a></span> www<wbr />.example<wbr />.com<wbr />/ www<wbr<wbr />/><wbr />.example<wbr<wbr />/><wbr />.com]<<wbr />/span>] <pre style="white-space: pre-wrap;"><span class="url">[http://www.example.com/ www<wbr/>.example<wbr/>.com]</span> www<wbr/>.example<wbr/>.com<wbr/>/ www<wbr<wbr/>/><wbr/>.example<wbr<wbr/>/><wbr/>.com]<<wbr/>/span>]</span>&nbsp;</pre></li></ol> <p>Comparison with output of <span class="nowrap">{{</span><a href="/wiki/Template:URL" title="Template:URL">URL</a><span class="nowrap">}}</span>: </p> <ol><li><code>{{URL | http://www.example.com/ }}</code> → <span class="url"><a rel="nofollow" class="external text" href="http://www.example.com/">www<wbr />.example<wbr />.com</a></span><pre style="white-space: pre-wrap;"><span class="url">[http://www.example.com/ www<wbr/>.example<wbr/>.com]</span></pre></li> <li><code>{{URL | http://www.example.com/path/ }}</code> → <span class="url"><a rel="nofollow" class="external text" href="http://www.example.com/path/">www<wbr />.example<wbr />.com<wbr />/path<wbr />/</a></span><pre style="white-space: pre-wrap;"><span class="url">[http://www.example.com/path/ www<wbr/>.example<wbr/>.com<wbr/>/path<wbr/>/]</span></pre></li> <li><code>{{URL | {{wikidata|property|Q23317|P856}} }}</code> → <span class="url"><a rel="nofollow" class="external text" href="https://www.audi.com">www<wbr />.audi<wbr />.com</a></span><pre style="white-space: pre-wrap;"><span class="url">[https://www.audi.com www<wbr/>.audi<wbr/>.com]</span></pre> <dl><dd><code>{{wikidata|property|Q23317|P856}}</code> → <a rel="nofollow" class="external free" href="https://www.audi.com">https://www.audi.com</a><pre style="white-space: pre-wrap;">https://www.audi.com</pre></dd></dl></li></ol> <div class="mw-heading mw-heading4"><h4 id="See_also">See also</h4><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-43" title="Edit section: See also"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <ul><li>{{<a href="/wiki/Module:URL" title="Module:URL">#invoke:URL</a>|url}} & {{<a href="/wiki/Module:URL" title="Module:URL">#invoke:URL</a>|url2}}</li></ul> <div class="mw-heading mw-heading2"><h2 id="Coding_into_an_infobox">Coding into an infobox</h2><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-44" title="Edit section: Coding into an infobox"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>Typically, the getValue call will be invoked in an infobox definition, using appropriate template parameters. One simple implementation is given as an example in <a href="/wiki/Template:Infobox_book/Wikidata/Sandbox" title="Template:Infobox book/Wikidata/Sandbox">Template:Infobox book/Wikidata/Sandbox</a>. As an illustration, the 'author' field in the infobox is coded like this: </p> <pre style="line-height:1.2em;">| label2 = Author{{#if:{{{authors|}}}|s}} | data2 = {{#invoke:WikidataIB |getValue |P50 |name=author |fetchwikidata={{{fetchwikidata|}}} |suppressfields={{{suppressfields|}}} |{{{authors|{{{author|}}}}}} }} </pre> <p>The property to be fetched is the first unnamed parameter. In this case it is <a href="https://www.wikidata.org/wiki/Special:EntityPage/P50" class="extiw" title="d:Special:EntityPage/P50">author <small>(P50)</small></a>. </p><p>The name of the field is passed in <code class="tpl-para" style="word-break:break-word;">|name=</code> and that name is checked against the blacklist and the whitelist. To always suppress the author field in a particular article, an editor will set <code class="tpl-para" style="word-break:break-word;">|suppressfields=author</code> in the infobox. The author field will then never be displayed. </p><p>If the field is not blacklisted, then the infobox can be set to display a locally supplied value for author simply by setting <code class="tpl-para" style="word-break:break-word;">|author=<a href="/wiki/George_Orwell" title="George Orwell">George Orwell</a></code>, for example, in the infobox. It also accepts <code class="tpl-para" style="word-break:break-word;">|authors=</code>. If the name of the field is on the whitelist, e.g. <code class="tpl-para" style="word-break:break-word;">|fetchwikidata=author; genre; pub_date; pages; dewey; congress</code>, <i>and</i> the local value is not supplied, then the infobox will display the value retrieved from Wikidata. Any separators can be used, except | and {}. </p><p>As a shorthand, <code class="tpl-para" style="word-break:break-word;">|fetchwikidata=ALL</code> will fetch all of the fields that are not blacklisted, as long as no local value is already provided in the article for a given field. </p><p>Since Wikidata labels are normally lower case, the ucfirst function from <a href="/wiki/Module:String2" title="Module:String2">Module:String2</a> can be used to capitalise the first letter of the returned text, e.g. </p> <ul><li><code>{{#invoke:String2 | ucfirst | {{#invoke:WikidataIB |getValue |P136 |name=genre |fetchwikidata=ALL |onlysourced=false}} }}</code> in <a href="https://www.wikidata.org/wiki/Special:EntityPage/Q1396889" class="extiw" title="d:Special:EntityPage/Q1396889">Animal Farm <small>(Q1396889)</small></a> produces:</li> <li><a href="/wiki/Roman_%C3%A0_clef" title="Roman à clef">Roman à clef</a>, satirical fiction, <a href="/wiki/Fable" title="Fable">fable</a>, dystopian fiction <span class="penicon autoconfirmed-show"><span class="mw-valign-text-top" typeof="mw:File/Frameless"><a href="https://www.wikidata.org/wiki/Q1396889?uselang=en#P136" title="Edit this on Wikidata"><img alt="Edit this on Wikidata" src="//upload.wikimedia.org/wikipedia/en/thumb/8/8a/OOjs_UI_icon_edit-ltr-progressive.svg/10px-OOjs_UI_icon_edit-ltr-progressive.svg.png" decoding="async" width="10" height="10" class="mw-file-element" srcset="//upload.wikimedia.org/wikipedia/en/thumb/8/8a/OOjs_UI_icon_edit-ltr-progressive.svg/15px-OOjs_UI_icon_edit-ltr-progressive.svg.png 1.5x, //upload.wikimedia.org/wikipedia/en/thumb/8/8a/OOjs_UI_icon_edit-ltr-progressive.svg/20px-OOjs_UI_icon_edit-ltr-progressive.svg.png 2x" data-file-width="20" data-file-height="20" /></a></span></span></li></ul> <div class="mw-heading mw-heading3"><h3 id="Example_of_calls_in_an_infobox">Example of calls in an infobox</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-45" title="Edit section: Example of calls in an infobox"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>Basic use of getValue: </p> <ul><li><code>{{#invoke:WikidataIB |getValue |P000 |name=fieldname |qid={{{qid|}}} |fetchwikidata={{{fetchwikidata|}}} |onlysourced={{{onlysourced|}}} |{{{localparameter|}}} }}</code></li></ul> <p>Full collection of parameters: </p> <ul><li><code>{{#invoke:WikidataIB |getValue |P000 |name=fieldname |qid={{{qid|}}} |suppressfields={{{suppressfields|}}} |fetchwikidata={{{fetchwikidata|}}} |onlysourced={{{onlysourced|}}} |noicon={{{noicon|}}} |wdl={{{wikidatalink|}}} |df={{dateformat|}} |bc={{{bc|}}} |prefix= |postfix= |linkprefix= |linkpostfix= |sorted={{{sorted|}}} |sep={{{separator|}}} |list={{listtype|}}} |{{{localparameter|}}} }}</code></li></ul> <p>Any of the parameters can, of course, be fixed for a given field in an infobox, rather than taking the parameter supplied to the infobox, which will affect all fields. For example, one field may set <code class="tpl-para" style="word-break:break-word;">|list=hlist</code> where a series of short words is expected; whereas another field could use <code class="tpl-para" style="word-break:break-word;">|list=ubl</code> where an unbulleted vertical list of several words on each line is required. </p> <div class="mw-heading mw-heading3"><h3 id="Coordinates">Coordinates</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-46" title="Edit section: Coordinates"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>The getCoords call will display the output of <a href="/wiki/Template:Coord" title="Template:Coord">Template:Coord</a> when supplied with the coordinates returned from Wikidata. It can be coded like this: </p> <pre style="line-height:1.2em;">|label20 = Coordinates | data20 = {{#invoke:WikidataIB |getCoords |name=coordinates |suppressfields={{{suppressfields|}}} |fetchwikidata={{{fetchwikidata|}}} |{{{coordinates|}}} }} </pre> <p>An example is <a href="/w/index.php?title=Template:Infobox_biosphere_reserve&action=edit&redlink=1" class="new" title="Template:Infobox biosphere reserve (page does not exist)">Template:Infobox biosphere reserve</a> </p> <pre style="line-height:1.2em;">{{Infobox biosphere reserve | fetchwikidata = ALL }} </pre> <p>Displays coordinates in the usual positions when used in an article where Wikidata has coordinates. </p> <div class="mw-heading mw-heading3"><h3 id="Upgrading_existing_infoboxes">Upgrading existing infoboxes</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-47" title="Edit section: Upgrading existing infoboxes"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>Since the parameter <code class="tpl-para" style="word-break:break-word;">|fetchwikidata=</code> is needed for any Wikidata functionality, an existing infobox may be replaced by an infobox incorporating these calls without any change whatsoever to any article. Each article using the new infobox can later be enabled by supplying <code class="tpl-para" style="word-break:break-word;">|fetchwikidata=ALL</code>, or a list of required fields for that article. At that point, the onus is on the editor enabling the functionality to check that no unwanted fields are now being displayed. If so, they can be added to a blacklist for the article by setting <code class="tpl-para" style="word-break:break-word;">|suppressfields=</code> to the list of unwanted fields. </p> <div class="mw-heading mw-heading3"><h3 id="Verifiability">Verifiability</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-48" title="Edit section: Verifiability"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>Where it will always be essential for a particular field to only contain values that are referenced, use <code>getValue</code>, making sure that <code class="tpl-para" style="word-break:break-word;">|onlysourced=</code> is <i>not</i> set to 'false', '0' or 'no'. By default it will exclude values that are unsourced or only sourced to a Wikipedia, thus making the job of checking easier at the article level. If unsourced data is acceptable (!), set <code class="tpl-para" style="word-break:break-word;">|onlysourced=no</code>. As it is beyond my wit to produce an automated mechanism that knows whether an existing source is reliable or not in a given context, that job must still be performed at the article level by an editor familiar with the subject. It should always be done when first enabling Wikidata for that article. </p> <div class="mw-heading mw-heading3"><h3 id="Helper_templates">Helper templates</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-49" title="Edit section: Helper templates"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <dl><dt><a href="/wiki/Template:If_then_show" title="Template:If then show">Template:If then show</a></dt> <dd>tests whether the first unnamed parameter is not an empty string and returns it if it isn't. Otherwise it returns the second unnamed parameter. Optional third and fourth unnamed parameters provide a prefix and a suffix for the first parameter when returned. Useful when the first parameter is a call to Wikidata.</dd> <dt><a href="/wiki/Template:Ifnoteq_then_show" title="Template:Ifnoteq then show">Template:Ifnoteq then show</a></dt> <dd>tests whether the first unnamed parameter is equal to the second unnamed parameter and returns the third unnamed parameter if it does. Otherwise it returns the first unnamed parameter. This is useful when the first parameter is a <code>{{#invoke:</code> of a Lua module that returns a value for which a specific exception is required.</dd> <dt><a href="/wiki/Template:If_then_wikilink" title="Template:If then wikilink">Template:If then wikilink</a></dt> <dd>tests whether the first unnamed parameter is not an empty string and if it isn't, it returns the parameter formatted as piped wiki-link using an optional namespace prefix.</dd> <dt><a href="/wiki/Template:Formatter_link" title="Template:Formatter link">Template:Formatter link</a></dt> <dd>takes an external identifier code as <code class="tpl-para" style="word-break:break-word;">|code=</code> and uses a formatter url as <code class="tpl-para" style="word-break:break-word;">|url=</code> to construct a link to the external resource, which uses the code as display.</dd> <dt><a href="/wiki/Template:Emptyor" title="Template:Emptyor">Template:Emptyor</a></dt> <dd>tests a piece of text to ascertain whether it's effectively empty or contains some text. If the unnamed parameter consists only of html tags, punctuation (e.g. wiki markup) and whitespace, then Emptyor returns nothing; otherwise it returns the parameter unchanged. Wrapper for p.emptyor function.</dd></dl> <div class="mw-heading mw-heading2"><h2 id="Example_of_use:_Infobox_book">Example of use: Infobox book</h2><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-50" title="Edit section: Example of use: Infobox book"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>This section is taken from <a href="/wiki/Template:Infobox_book/Wikidata/Sandbox/doc" title="Template:Infobox book/Wikidata/Sandbox/doc">Template:Infobox book/Wikidata/Sandbox/doc</a>. </p> <div class="mw-heading mw-heading3"><h3 id="No_Wikidata">No Wikidata</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-51" title="Edit section: No Wikidata"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <pre style="line-height:1.2em;">{{Infobox book/Wikidata/Sandbox | suppressfields = | fetchwikidata = | name = Animal Farm | title_orig = Animal Farm: A Fairy Story | image = Animal Farm - 1st edition.jpg | image_size = 200px | caption = First edition cover | author = [[George Orwell]] | country = United Kingdom | language = English | genre = Political satire }} </pre> <p>Works as a non-aware infobox: only locally supplied parameters are displayed. </p> <pre style="line-height:1.2em;">{{Infobox book/Wikidata/Sandbox | name = Animal Farm | title_orig = Animal Farm: A Fairy Story | image = Animal Farm - 1st edition.jpg | image_size = 200px | caption = First edition cover | author = [[George Orwell]] | country = United Kingdom | language = English | genre = Political satire }} </pre> <p>The blacklist and whitelist can be omitted if unused </p> <div class="mw-heading mw-heading3"><h3 id="All_Wikidata">All Wikidata</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-52" title="Edit section: All Wikidata"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <pre style="line-height:1.2em;">{{Infobox book/Wikidata/Sandbox | fetchwikidata = author; genre; pub_date; pages; dewey; congress }} </pre> <p>Fetches the author, publication date, number of pages, Dewey index, and Library of Congress catalogue number values from Wikidata. </p> <pre style="line-height:1.2em;">{{Infobox book/Wikidata/Sandbox | fetchwikidata = ALL }} </pre> <p>As shorthand, the <code class="tpl-para" style="word-break:break-word;">|fetchwikidata=</code> parameter can be set to ALL to fetch all available fields. Any field can be suppressed by naming it in <code class="tpl-para" style="word-break:break-word;">|suppressfields=</code>, or overridden by supplying a local value. </p> <div class="mw-heading mw-heading3"><h3 id="Never_display_genre">Never display genre</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-53" title="Edit section: Never display genre"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <pre style="line-height:1.2em;">{{Infobox book/Wikidata/Sandbox | suppressfields = genre | fetchwikidata = author; genre; pub_date; pages; dewey; congress }} </pre> <p>The genre field will always be suppressed, even if a local value is supplied. </p> <pre style="line-height:1.2em;">{{Infobox book/Wikidata/Sandbox | suppressfields = genre | fetchwikidata = author; genre; pub_date; pages; dewey; congress | genre = Political satire }} </pre> <div class="mw-heading mw-heading3"><h3 id="Local_override">Local override</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-54" title="Edit section: Local override"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <pre style="line-height:1.2em;">{{Infobox book/Wikidata/Sandbox | fetchwikidata = author; genre; pub_date; pages; dewey; congress | genre = Political satire }} </pre> <p>The genre field is set to display "Political satire", no matter what is stored in Wikidata. </p> <pre style="line-height:1.2em;">{{Infobox book/Wikidata/Sandbox | fetchwikidata = ALL | genre = Novel }} </pre> <p>The genre field is set to display "Novel", no matter what is stored in Wikidata. </p> <div class="mw-heading mw-heading3"><h3 id="Don't_fetch_genre"><span id="Don.27t_fetch_genre"></span>Don't fetch genre</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-55" title="Edit section: Don't fetch genre"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <pre style="line-height:1.2em;">{{Infobox book/Wikidata/Sandbox | suppressfields = | fetchwikidata = author; pub_date; pages; dewey; congress }} </pre> <p>The genre field will not be fetched from Wikidata. Only the author, publication date, number of pages, Dewey index, and Library of Congress catalogue number are imported. A local value for genre will display. </p> <div class="mw-heading mw-heading2"><h2 id="Exporting_the_module">Exporting the module</h2><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-56" title="Edit section: Exporting the module"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>WikidataIB has been developed to run on any language wiki (or Wikimedia project) with a minimum of modification. An optional sub-module <a href="/w/index.php?title=Module:WikidataIB/i18n&action=edit&redlink=1" class="new" title="Module:WikidataIB/i18n (page does not exist)">Module:WikidataIB/i18n</a> may be created to replace the values for error messages, ordinal suffixes etc. as shown in the local i18n definitions in the module. Although the same result can be arrived at by directly editing those values in WikidataIB, using the sub-module will allow an updated version of WikidataIB to directly replace the older module without having to re-edit the i18n definitions. </p> <div class="mw-heading mw-heading3"><h3 id="Linked_items">Linked items</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-57" title="Edit section: Linked items"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>If the target Wiki has a convention that certain items are not normally linked (see <a href="/wiki/Wikipedia:Manual_of_Style/Linking#What_generally_should_not_be_linked" title="Wikipedia:Manual of Style/Linking">en:Wikipedia:Manual of Style/Linking #What generally should not be linked</a> for an example), then a sub-module <a href="/wiki/Module:WikidataIB/nolinks" title="Module:WikidataIB/nolinks">Module:WikidataIB/nolinks</a> can be created to list items that should not be linked, using the English Wikipedia sub-module as an exemplar. </p> <div class="mw-heading mw-heading3"><h3 id="Italic_titles">Italic titles</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-58" title="Edit section: Italic titles"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>If the target Wiki has a convention that certain works should be italicised or quoted (see <a href="/wiki/Wikipedia:Manual_of_Style/Text_formatting#Names_and_titles" title="Wikipedia:Manual of Style/Text formatting">en:Wikipedia:Manual of Style/Text formatting #Names and titles</a> for an example), then a sub-module <a href="/wiki/Module:WikidataIB/titleformats" title="Module:WikidataIB/titleformats">Module:WikidataIB/titleformats</a> can be created to list items that should be italicised or quoted, using the English Wikipedia sub-module as an exemplar. </p> <div class="mw-heading mw-heading3"><h3 id="Complex_date">Complex date</h3><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-59" title="Edit section: Complex date"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p>Most of the output from the module will use the local language (or any user-specified one on multi-lingual wikis) where the sitelink or label exists on Wikidata. However, dates are more complicated and not handled perfectly in all languages. To solve this, WikidataIB uses <a href="/wiki/Module:Complex_date" title="Module:Complex date">Module:Complex date</a> – developed on Commons by <a href="/wiki/User:Jarekt" title="User:Jarekt">Jarekt</a> – which allows expansion to support a wider variety of languages. As a result, it is necessary to install Complex date and its dependencies alongside WikidataIB when installing on another Wikimedia project. </p> <div class="mw-heading mw-heading4"><h4 id="Complex_date_dependencies">Complex date dependencies</h4><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-60" title="Edit section: Complex date dependencies"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <p><a href="/wiki/Module:Complex_date" title="Module:Complex date">Module:Complex_date</a> relies on the following modules: </p> <ul><li><a href="/wiki/Module:ISOdate" title="Module:ISOdate">Module:ISOdate</a> <ul><li><a href="/wiki/Module:DateI18n" title="Module:DateI18n">Module:DateI18n</a> (no dependencies)</li></ul></li> <li><a href="/wiki/Module:I18n/complex_date" title="Module:I18n/complex date">Module:i18n/complex date</a> <ul><li><a href="/wiki/Module:Ordinal" title="Module:Ordinal">Module:Ordinal</a> (lazy loading) <ul><li><a href="/wiki/Module:I18n/ordinal" title="Module:I18n/ordinal">Module:I18n/ordinal</a> (no dependencies)</li> <li><a href="/wiki/Module:Yesno" title="Module:Yesno">Module:Yesno</a> (from en.wikipedia) (no dependencies)</li> <li><a href="/wiki/Module:Formatnum" title="Module:Formatnum">Module:Formatnum</a> (no dependencies)</li></ul></li> <li><a href="/wiki/Module:Roman" title="Module:Roman">Module:Roman</a> (lazy loading with no dependencies)</li></ul></li></ul> <p>Unless otherwise noted, the authoritative version of each module can be found on <a class="external text" href="https://commons.wikimedia.org/">Commons</a> although the versions on English Wikipedia are usually kept in sync. </p> <div class="mw-heading mw-heading2"><h2 id="See_also_2">See also</h2><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-61" title="Edit section: See also"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <ul><li><a href="/wiki/Module:Wikidata" title="Module:Wikidata">Module:Wikidata</a>, handling Wikidata more basically</li> <li><a href="/wiki/Template:WikidataOI" title="Template:WikidataOI">Template:WikidataOI</a>, a template that uses <a href="/wiki/Module:Wd" title="Module:Wd">Module:Wd</a> but also has and "opt-in" options <code class="tpl-para" style="word-break:break-word;">|fetch=</code> and <code class="tpl-para" style="word-break:break-word;">|ifeq=</code> similar to this module's <code class="tpl-para" style="word-break:break-word;">|fetchwikidata=</code> or <code class="tpl-para" style="word-break:break-word;">|fwd=</code></li></ul> <div class="mw-heading mw-heading2"><h2 id="Tracking_categories">Tracking categories</h2><span class="mw-editsection"><span class="mw-editsection-bracket">[</span><a href="/w/index.php?title=Module:WikidataIB/doc&action=edit&section=T-62" title="Edit section: Tracking categories"><span>edit</span></a><span class="mw-editsection-bracket">]</span></span></div> <ul><li><a href="/wiki/Category:Articles_with_missing_Wikidata_information" title="Category:Articles with missing Wikidata information">Category:Articles with missing Wikidata information</a> (179)</li></ul> <div class="navbox-styles"><style data-mw-deduplicate="TemplateStyles:r1129693374">.mw-parser-output .hlist dl,.mw-parser-output .hlist ol,.mw-parser-output .hlist ul{margin:0;padding:0}.mw-parser-output .hlist dd,.mw-parser-output .hlist dt,.mw-parser-output .hlist li{margin:0;display:inline}.mw-parser-output .hlist.inline,.mw-parser-output .hlist.inline dl,.mw-parser-output .hlist.inline ol,.mw-parser-output .hlist.inline ul,.mw-parser-output .hlist dl dl,.mw-parser-output .hlist dl ol,.mw-parser-output .hlist dl ul,.mw-parser-output .hlist ol dl,.mw-parser-output .hlist ol ol,.mw-parser-output .hlist ol ul,.mw-parser-output .hlist ul dl,.mw-parser-output .hlist ul ol,.mw-parser-output .hlist ul ul{display:inline}.mw-parser-output .hlist .mw-empty-li{display:none}.mw-parser-output .hlist dt::after{content:": "}.mw-parser-output .hlist dd::after,.mw-parser-output .hlist li::after{content:" · ";font-weight:bold}.mw-parser-output .hlist dd:last-child::after,.mw-parser-output .hlist dt:last-child::after,.mw-parser-output .hlist li:last-child::after{content:none}.mw-parser-output .hlist dd dd:first-child::before,.mw-parser-output .hlist dd dt:first-child::before,.mw-parser-output .hlist dd li:first-child::before,.mw-parser-output .hlist dt dd:first-child::before,.mw-parser-output .hlist dt dt:first-child::before,.mw-parser-output .hlist dt li:first-child::before,.mw-parser-output .hlist li dd:first-child::before,.mw-parser-output .hlist li dt:first-child::before,.mw-parser-output .hlist li li:first-child::before{content:" (";font-weight:normal}.mw-parser-output .hlist dd dd:last-child::after,.mw-parser-output .hlist dd dt:last-child::after,.mw-parser-output .hlist dd li:last-child::after,.mw-parser-output .hlist dt dd:last-child::after,.mw-parser-output .hlist dt dt:last-child::after,.mw-parser-output .hlist dt li:last-child::after,.mw-parser-output .hlist li dd:last-child::after,.mw-parser-output .hlist li dt:last-child::after,.mw-parser-output .hlist li li:last-child::after{content:")";font-weight:normal}.mw-parser-output .hlist ol{counter-reset:listitem}.mw-parser-output .hlist ol>li{counter-increment:listitem}.mw-parser-output .hlist ol>li::before{content:" "counter(listitem)"\a0 "}.mw-parser-output .hlist dd ol>li:first-child::before,.mw-parser-output .hlist dt ol>li:first-child::before,.mw-parser-output .hlist li ol>li:first-child::before{content:" ("counter(listitem)"\a0 "}</style><style data-mw-deduplicate="TemplateStyles:r1236075235">.mw-parser-output .navbox{box-sizing:border-box;border:1px solid #a2a9b1;width:100%;clear:both;font-size:88%;text-align:center;padding:1px;margin:1em auto 0}.mw-parser-output .navbox .navbox{margin-top:0}.mw-parser-output .navbox+.navbox,.mw-parser-output .navbox+.navbox-styles+.navbox{margin-top:-1px}.mw-parser-output .navbox-inner,.mw-parser-output .navbox-subgroup{width:100%}.mw-parser-output .navbox-group,.mw-parser-output .navbox-title,.mw-parser-output .navbox-abovebelow{padding:0.25em 1em;line-height:1.5em;text-align:center}.mw-parser-output .navbox-group{white-space:nowrap;text-align:right}.mw-parser-output .navbox,.mw-parser-output .navbox-subgroup{background-color:#fdfdfd}.mw-parser-output .navbox-list{line-height:1.5em;border-color:#fdfdfd}.mw-parser-output .navbox-list-with-group{text-align:left;border-left-width:2px;border-left-style:solid}.mw-parser-output tr+tr>.navbox-abovebelow,.mw-parser-output tr+tr>.navbox-group,.mw-parser-output tr+tr>.navbox-image,.mw-parser-output tr+tr>.navbox-list{border-top:2px solid #fdfdfd}.mw-parser-output .navbox-title{background-color:#ccf}.mw-parser-output .navbox-abovebelow,.mw-parser-output .navbox-group,.mw-parser-output .navbox-subgroup .navbox-title{background-color:#ddf}.mw-parser-output .navbox-subgroup .navbox-group,.mw-parser-output .navbox-subgroup .navbox-abovebelow{background-color:#e6e6ff}.mw-parser-output .navbox-even{background-color:#f7f7f7}.mw-parser-output .navbox-odd{background-color:transparent}.mw-parser-output .navbox .hlist td dl,.mw-parser-output .navbox .hlist td ol,.mw-parser-output .navbox .hlist td ul,.mw-parser-output .navbox td.hlist dl,.mw-parser-output .navbox td.hlist ol,.mw-parser-output .navbox td.hlist ul{padding:0.125em 0}.mw-parser-output .navbox .navbar{display:block;font-size:100%}.mw-parser-output .navbox-title .navbar{float:left;text-align:left;margin-right:0.5em}body.skin--responsive .mw-parser-output .navbox-image img{max-width:none!important}@media print{body.ns-0 .mw-parser-output .navbox{display:none!important}}</style></div><div role="navigation" class="navbox" aria-labelledby="Infoboxes_using_Wikidata" style="padding:3px"><table class="nowraplinks mw-collapsible autocollapse navbox-inner" style="border-spacing:0;background:transparent;color:inherit"><tbody><tr><th scope="col" class="navbox-title" colspan="2"><link rel="mw-deduplicated-inline-style" href="mw-data:TemplateStyles:r1129693374"><style data-mw-deduplicate="TemplateStyles:r1239400231">.mw-parser-output .navbar{display:inline;font-size:88%;font-weight:normal}.mw-parser-output .navbar-collapse{float:left;text-align:left}.mw-parser-output .navbar-boxtext{word-spacing:0}.mw-parser-output .navbar ul{display:inline-block;white-space:nowrap;line-height:inherit}.mw-parser-output .navbar-brackets::before{margin-right:-0.125em;content:"[ "}.mw-parser-output .navbar-brackets::after{margin-left:-0.125em;content:" ]"}.mw-parser-output .navbar li{word-spacing:-0.125em}.mw-parser-output .navbar a>span,.mw-parser-output .navbar a>abbr{text-decoration:inherit}.mw-parser-output .navbar-mini abbr{font-variant:small-caps;border-bottom:none;text-decoration:none;cursor:inherit}.mw-parser-output .navbar-ct-full{font-size:114%;margin:0 7em}.mw-parser-output .navbar-ct-mini{font-size:114%;margin:0 4em}html.skin-theme-clientpref-night .mw-parser-output .navbar li a abbr{color:var(--color-base)!important}@media(prefers-color-scheme:dark){html.skin-theme-clientpref-os .mw-parser-output .navbar li a abbr{color:var(--color-base)!important}}@media print{.mw-parser-output .navbar{display:none!important}}</style><div class="navbar plainlinks hlist navbar-mini"><ul><li class="nv-view"><a href="/wiki/Template:Wikidata_infoboxes" title="Template:Wikidata infoboxes"><abbr title="View this template">v</abbr></a></li><li class="nv-talk"><a href="/wiki/Template_talk:Wikidata_infoboxes" title="Template talk:Wikidata infoboxes"><abbr title="Discuss this template">t</abbr></a></li><li class="nv-edit"><a href="/wiki/Special:EditPage/Template:Wikidata_infoboxes" title="Special:EditPage/Template:Wikidata infoboxes"><abbr title="Edit this template">e</abbr></a></li></ul></div><div id="Infoboxes_using_Wikidata" style="font-size:114%;margin:0 4em">Infoboxes using Wikidata</div></th></tr><tr><td colspan="2" class="navbox-list navbox-odd hlist" style="width:100%;padding:0"><div style="padding:0 0.25em"> <ul><li><span class="nowrap">{{</span><a href="/wiki/Template:Biota_infobox/Wikidata" title="Template:Biota infobox/Wikidata">Biota infobox/Wikidata</a><span class="nowrap">}}</span></li> <li><span class="nowrap">{{</span><a href="/wiki/Template:Infobox_archive/wikidata" title="Template:Infobox archive/wikidata">Infobox archive/wikidata</a><span class="nowrap">}}</span></li> <li><span class="nowrap">{{</span><a href="/wiki/Template:Infobox_artwork/wikidata" title="Template:Infobox artwork/wikidata">Infobox artwork/wikidata</a><span class="nowrap">}}</span></li> <li><span class="nowrap">{{</span><a href="/wiki/Template:Infobox_book/wikidata" title="Template:Infobox book/wikidata">Infobox book/wikidata</a><span class="nowrap">}}</span></li> <li><span class="nowrap">{{</span><a href="/wiki/Template:Infobox_expedition/Wikidata" title="Template:Infobox expedition/Wikidata">Infobox expedition/Wikidata</a><span class="nowrap">}}</span></li> <li><span class="nowrap">{{</span><a href="/wiki/Template:Infobox_journal/wikidata" title="Template:Infobox journal/wikidata">Infobox journal/wikidata</a><span class="nowrap">}}</span></li> <li><span class="nowrap">{{</span><a href="/wiki/Template:Infobox_library/wikidata" title="Template:Infobox library/wikidata">Infobox library/wikidata</a><span class="nowrap">}}</span></li> <li><span class="nowrap">{{</span><a href="/wiki/Template:Infobox_museum/wikidata" title="Template:Infobox museum/wikidata">Infobox museum/wikidata</a><span class="nowrap">}}</span></li> <li><span class="nowrap">{{</span><a href="/wiki/Template:Infobox_noble/Wikidata" title="Template:Infobox noble/Wikidata">Infobox noble/Wikidata</a><span class="nowrap">}}</span></li> <li><span class="nowrap">{{</span><a href="/wiki/Template:Infobox_organization/Wikidata" title="Template:Infobox organization/Wikidata">Infobox organization/Wikidata</a><span class="nowrap">}}</span></li> <li><span class="nowrap">{{</span><a href="/wiki/Template:Infobox_person/Wikidata" title="Template:Infobox person/Wikidata">Infobox person/Wikidata</a><span class="nowrap">}}</span></li> <li><span class="nowrap">{{</span><a href="/wiki/Template:Infobox_power_station" title="Template:Infobox power station">Infobox power station</a><span class="nowrap">}}</span></li> <li><span class="nowrap">{{</span><a href="/wiki/Template:Infobox_product" title="Template:Infobox product">Infobox product</a><span class="nowrap">}}</span></li> <li><span class="nowrap">{{</span><a href="/wiki/Template:Infobox_religious_biography/Wikidata" title="Template:Infobox religious biography/Wikidata">Infobox religious biography/Wikidata</a><span class="nowrap">}}</span></li> <li><span class="nowrap">{{</span><a href="/wiki/Template:Infobox_scientist/Wikidata" title="Template:Infobox scientist/Wikidata">Infobox scientist/Wikidata</a><span class="nowrap">}}</span></li> <li><span class="nowrap">{{</span><a href="/wiki/Template:Infobox_settlement/Wikidata" title="Template:Infobox settlement/Wikidata">Infobox settlement/Wikidata</a><span class="nowrap">}}</span></li> <li><span class="nowrap">{{</span><a href="/wiki/Template:Infobox_sportsperson/Wikidata" title="Template:Infobox sportsperson/Wikidata">Infobox sportsperson/Wikidata</a><span class="nowrap">}}</span></li> <li><span class="nowrap">{{</span><a href="/wiki/Template:Infobox_telescope" title="Template:Infobox telescope">Infobox telescope</a><span class="nowrap">}}</span></li> <li><span class="nowrap">{{</span><a href="/wiki/Template:Infobox_theatre/wikidata" title="Template:Infobox theatre/wikidata">Infobox theatre/wikidata</a><span class="nowrap">}}</span></li> <li><span class="nowrap">{{</span><a href="/wiki/Template:Infobox_university/wikidata" title="Template:Infobox university/wikidata">Infobox university/wikidata</a><span class="nowrap">}}</span></li> <li><span class="nowrap">{{</span><a href="/wiki/Template:Infobox_writer/Wikidata" title="Template:Infobox writer/Wikidata">Infobox writer/Wikidata</a><span class="nowrap">}}</span></li> <li><span class="nowrap">{{</span><a href="/wiki/Template:Ordination" title="Template:Ordination">Ordination</a><span class="nowrap">}}</span></li></ul> </div></td></tr></tbody></table></div> <div class="documentation-clear"></div> </div> <div role="note" class="documentation-metadata plainlinks">The above <a href="/wiki/Wikipedia:Template_documentation" title="Wikipedia:Template documentation">documentation</a> is <a href="/wiki/Help:Transclusion" title="Help:Transclusion">transcluded</a> from <a href="/wiki/Module:WikidataIB/doc" title="Module:WikidataIB/doc">Module:WikidataIB/doc</a>. <span class="documentation-toolbar">(<a href="/wiki/Special:EditPage/Module:WikidataIB/doc" title="Special:EditPage/Module:WikidataIB/doc">edit</a> | <a href="/wiki/Special:PageHistory/Module:WikidataIB/doc" title="Special:PageHistory/Module:WikidataIB/doc">history</a>)</span><br />Editors can experiment in this module's <a class="mw-selflink selflink">sandbox</a> <span class="documentation-toolbar">(<a href="/wiki/Special:EditPage/Module:WikidataIB/sandbox" title="Special:EditPage/Module:WikidataIB/sandbox">edit</a> | <a class="external text" href="https://en.wikipedia.org/w/index.php?title=Special%3AComparePages&page1=Module%3AWikidataIB&page2=Module%3AWikidataIB%2Fsandbox">diff</a>)</span> and <a href="/wiki/Module:WikidataIB/testcases" class="mw-redirect" title="Module:WikidataIB/testcases">testcases</a> <span class="documentation-toolbar">(<a href="/wiki/Special:EditPage/Module:WikidataIB/testcases" title="Special:EditPage/Module:WikidataIB/testcases">edit</a>)</span> pages.<br />Add categories to the <a href="/wiki/Module:WikidataIB/doc" title="Module:WikidataIB/doc">/doc</a> subpage. <a href="/wiki/Special:PrefixIndex/Module:WikidataIB/" title="Special:PrefixIndex/Module:WikidataIB/">Subpages of this module</a>.</div></div><pre lang="en" dir="ltr" class="mw-code mw-script"> -- Version: 2023-07-10 -- Module to implement use of a blacklist and whitelist for infobox fields -- Can take a named parameter |qid which is the Wikidata ID for the article -- if not supplied, it will use the Wikidata ID associated with the current page. -- Fields in blacklist are never to be displayed, i.e. module must return nil in all circumstances -- Fields in whitelist return local value if it exists or the Wikidata value otherwise -- The name of the field that this function is called from is passed in named parameter |name -- The name is compulsory when blacklist or whitelist is used, -- so the module returns nil if it is not supplied. -- blacklist is passed in named parameter |suppressfields (or |spf) -- whitelist is passed in named parameter |fetchwikidata (or |fwd) require("strict") local p = {} local cdate -- initialise as nil and only load _complex_date function if needed -- Module:Complex date is loaded lazily and has the following dependencies: -- Module:Calendar -- Module:ISOdate -- Module:DateI18n -- Module:I18n/complex date -- Module:Ordinal -- Module:I18n/ordinal -- Module:Yesno -- Module:Formatnum -- Module:Linguistic -- -- The following, taken from https://www.mediawiki.org/wiki/Wikibase/DataModel#Dates_and_times, -- is needed to use Module:Complex date which seemingly requires date precision as a string. -- It would work better if only the authors of the mediawiki page could spell 'millennium'. local dp = { [6] = "millennium", [7] = "century", [8] = "decade", [9] = "year", [10] = "month", [11] = "day", } local i18n = { ["errors"] = { ["property-not-found"] = "Property not found.", ["No property supplied"] = "No property supplied", ["entity-not-found"] = "Wikidata entity not found.", ["unknown-claim-type"] = "Unknown claim type.", ["unknown-entity-type"] = "Unknown entity type.", ["qualifier-not-found"] = "Qualifier not found.", ["site-not-found"] = "Wikimedia project not found.", ["labels-not-found"] = "No labels found.", ["descriptions-not-found"] = "No descriptions found.", ["aliases-not-found"] = "No aliases found.", ["unknown-datetime-format"] = "Unknown datetime format.", ["local-article-not-found"] = "Article is available on Wikidata, but not on Wikipedia", ["dab-page"] = " (dab)", }, ["months"] = { "January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December" }, ["century"] = "century", ["BC"] = "BC", ["BCE"] = "BCE", ["ordinal"] = { [1] = "st", [2] = "nd", [3] = "rd", ["default"] = "th" }, ["filespace"] = "File", ["Unknown"] = "Unknown", ["NaN"] = "Not a number", -- set the following to the name of a tracking category, -- e.g. "[[Category:Articles with missing Wikidata information]]", or "" to disable: ["missinginfocat"] = "[[Category:Articles with missing Wikidata information]]", ["editonwikidata"] = "Edit this on Wikidata", ["latestdatequalifier"] = function (date) return "before " .. date end, -- some languages, e.g. Bosnian use a period as a suffix after each number in a date ["datenumbersuffix"] = "", ["list separator"] = ", ", ["multipliers"] = { [0] = "", [3] = " thousand", [6] = " million", [9] = " billion", [12] = " trillion", } } -- This allows an internationisation module to override the above table if 'en' ~= mw.getContentLanguage():getCode() then require("Module:i18n").loadI18n("Module:WikidataIB/i18n", i18n) end -- This piece of html implements a collapsible container. Check the classes exist on your wiki. local collapsediv = '<div class="mw-collapsible mw-collapsed" style="width:100%; overflow:auto;" data-expandtext="{{int:show}}" data-collapsetext="{{int:hide}}">' -- Some items should not be linked. -- Each wiki can create a list of those in Module:WikidataIB/nolinks -- It should return a table called itemsindex, containing true for each item not to be linked local donotlink = {} local nolinks_exists, nolinks = pcall(mw.loadData, "Module:WikidataIB/nolinks") if nolinks_exists then donotlink = nolinks.itemsindex end -- To satisfy Wikipedia:Manual of Style/Titles, certain types of items are italicised, and others are quoted. -- The submodule [[Module:WikidataIB/titleformats]] lists the entity-ids used in 'instance of' (P31), -- which allows this module to identify the values that should be formatted. -- WikidataIB/titleformats exports a table p.formats, which is indexed by entity-id, and contains the value " or '' local formats = {} local titleformats_exists, titleformats = pcall(mw.loadData, "Module:WikidataIB/titleformats") if titleformats_exists then formats = titleformats.formats end ------------------------------------------------------------------------------- -- Private functions ------------------------------------------------------------------------------- -- ------------------------------------------------------------------------------- -- makeOrdinal needs to be internationalised along with the above: -- takes cardinal number as a numeric and returns the ordinal as a string -- we need three exceptions in English for 1st, 2nd, 3rd, 21st, .. 31st, etc. ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- local makeOrdinal = function(cardinal) local ordsuffix = i18n.ordinal.default if cardinal % 10 == 1 then ordsuffix = i18n.ordinal[1] elseif cardinal % 10 == 2 then ordsuffix = i18n.ordinal[2] elseif cardinal % 10 == 3 then ordsuffix = i18n.ordinal[3] end -- In English, 1, 21, 31, etc. use 'st', but 11, 111, etc. use 'th' -- similarly for 12 and 13, etc. if (cardinal % 100 == 11) or (cardinal % 100 == 12) or (cardinal % 100 == 13) then ordsuffix = i18n.ordinal.default end return tostring(cardinal) .. ordsuffix end ------------------------------------------------------------------------------- -- findLang takes a "langcode" parameter if supplied and valid -- otherwise it tries to create it from the user's set language ({{int:lang}}) -- failing that it uses the wiki's content language. -- It returns a language object ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- local findLang = function(langcode) local langobj langcode = mw.text.trim(langcode or "") if mw.language.isKnownLanguageTag(langcode) then langobj = mw.language.new( langcode ) else langcode = mw.getCurrentFrame():callParserFunction('int', {'lang'}) if mw.language.isKnownLanguageTag(langcode) then langobj = mw.language.new( langcode ) else langobj = mw.language.getContentLanguage() end end return langobj end ------------------------------------------------------------------------------- -- _getItemLangCode takes a qid parameter (using the current page's qid if blank) -- If the item for that qid has property country (P17) it looks at the first preferred value -- If the country has an official language (P37), it looks at the first preferred value -- If that official language has a language code (P424), it returns the first preferred value -- Otherwise it returns nothing. ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- local _getItemLangCode = function(qid) qid = mw.text.trim(qid or ""):upper() if qid == "" then qid = mw.wikibase.getEntityIdForCurrentPage() end if not qid then return end local prop17 = mw.wikibase.getBestStatements(qid, "P17")[1] if not prop17 or prop17.mainsnak.snaktype ~= "value" then return end local qid17 = prop17.mainsnak.datavalue.value.id local prop37 = mw.wikibase.getBestStatements(qid17, "P37")[1] if not prop37 or prop37.mainsnak.snaktype ~= "value" then return end local qid37 = prop37.mainsnak.datavalue.value.id local prop424 = mw.wikibase.getBestStatements(qid37, "P424")[1] if not prop424 or prop424.mainsnak.snaktype ~= "value" then return end return prop424.mainsnak.datavalue.value end ------------------------------------------------------------------------------- -- roundto takes a number (x) -- and returns it rounded to (sf) significant figures ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- local roundto = function(x, sf) if x == 0 then return 0 end local s = 1 if x < 0 then x = -x s = -1 end if sf < 1 then sf = 1 end local p = 10 ^ (math.floor(math.log10(x)) - sf + 1) x = math.floor(x / p + 0.5) * p * s -- if it's integral, cast to an integer: if x == math.floor(x) then x = math.floor(x) end return x end ------------------------------------------------------------------------------- -- decimalToDMS takes a decimal degrees (x) with precision (p) -- and returns degrees/minutes/seconds according to the precision ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- local decimalToDMS = function(x, p) -- if p is not supplied, use a precision around 0.1 seconds if not tonumber(p) then p = 1e-4 end local d = math.floor(x) local ms = (x - d) * 60 if p > 0.5 then -- precision is > 1/2 a degree if ms > 30 then d = d + 1 end ms = 0 end local m = math.floor(ms) local s = (ms - m) * 60 if p > 0.008 then -- precision is > 1/2 a minute if s > 30 then m = m +1 end s = 0 elseif p > 0.00014 then -- precision is > 1/2 a second s = math.floor(s + 0.5) elseif p > 0.000014 then -- precision is > 1/20 second s = math.floor(10 * s + 0.5) / 10 elseif p > 0.0000014 then -- precision is > 1/200 second s = math.floor(100 * s + 0.5) / 100 else -- cap it at 3 dec places for now s = math.floor(1000 * s + 0.5) / 1000 end return d, m, s end ------------------------------------------------------------------------------- -- decimalPrecision takes a decimal (x) with precision (p) -- and returns x rounded approximately to the given precision -- precision should be between 1 and 1e-6, preferably a power of 10. ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- local decimalPrecision = function(x, p) local s = 1 if x < 0 then x = -x s = -1 end -- if p is not supplied, pick an arbitrary precision if not tonumber(p) then p = 1e-4 elseif p > 1 then p = 1 elseif p < 1e-6 then p = 1e-6 else p = 10 ^ math.floor(math.log10(p)) end x = math.floor(x / p + 0.5) * p * s -- if it's integral, cast to an integer: if x == math.floor(x) then x = math.floor(x) end -- if it's less than 1e-4, it will be in exponent form, so return a string with 6dp -- 9e-5 becomes 0.000090 if math.abs(x) < 1e-4 then x = string.format("%f", x) end return x end ------------------------------------------------------------------------------- -- formatDate takes a datetime of the usual format from mw.wikibase.entity:formatPropertyValues -- like "1 August 30 BCE" as parameter 1 -- and formats it according to the df (date format) and bc parameters -- df = ["dmy" / "mdy" / "y"] default will be "dmy" -- bc = ["BC" / "BCE"] default will be "BCE" ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- local format_Date = function(datetime, dateformat, bc) local datetime = datetime or "1 August 30 BCE" -- in case of nil value -- chop off multiple vales and/or any hours, mins, etc. -- keep anything before punctuation - we just want a single date: local dateval = string.match( datetime, "[%w ]+") local dateformat = string.lower(dateformat or "dmy") -- default to dmy local bc = string.upper(bc or "") -- can't use nil for bc -- we only want to accept two possibilities: BC or default to BCE if bc == "BC" then bc = "&nbsp;" .. i18n["BC"] -- prepend a non-breaking space. else bc = "&nbsp;" .. i18n["BCE"] end local postchrist = true -- start by assuming no BCE local dateparts = {} for word in string.gmatch(dateval, "%w+") do if word == "BCE" or word == "BC" then -- *** internationalise later *** postchrist = false else -- we'll keep the parts that are not 'BCE' in a table dateparts[#dateparts + 1] = word end end if postchrist then bc = "" end -- set AD dates to no suffix *** internationalise later *** local sep = "&nbsp;" -- separator is nbsp local fdate = table.concat(dateparts, sep) -- set formatted date to same order as input -- if we have day month year, check dateformat if #dateparts == 3 then if dateformat == "y" then fdate = dateparts[3] elseif dateformat == "mdy" then fdate = dateparts[2] .. sep .. dateparts[1] .. "," .. sep .. dateparts[3] end elseif #dateparts == 2 and dateformat == "y" then fdate = dateparts[2] end return fdate .. bc end ------------------------------------------------------------------------------- -- dateFormat is the handler for properties that are of type "time" -- It takes timestamp, precision (6 to 11 per mediawiki), dateformat (y/dmy/mdy), BC format (BC/BCE), -- a plaindate switch (yes/no/adj) to en/disable "sourcing circumstances"/use adjectival form, -- any qualifiers for the property, the language, and any adjective to use like 'before'. -- It passes the date through the "complex date" function -- and returns a string with the internatonalised date formatted according to preferences. ------------------------------------------------------------------------------- -- Dependencies: findLang(); cdate(); dp[] ------------------------------------------------------------------------------- local dateFormat = function(timestamp, dprec, df, bcf, pd, qualifiers, lang, adj, model) -- output formatting according to preferences (y/dmy/mdy/ymd) df = (df or ""):lower() -- if ymd is required, return the part of the timestamp in YYYY-MM-DD form -- but apply Year zero#Astronomers fix: 1 BC = 0000; 2 BC = -0001; etc. if df == "ymd" then if timestamp:sub(1,1) == "+" then return timestamp:sub(2,11) else local yr = tonumber(timestamp:sub(2,5)) - 1 yr = ("000" .. yr):sub(-4) if yr ~= "0000" then yr = "-" .. yr end return yr .. timestamp:sub(6,11) end end -- A year can be stored like this: "+1872-00-00T00:00:00Z", -- which is processed here as if it were the day before "+1872-01-01T00:00:00Z", -- and that's the last day of 1871, so the year is wrong. -- So fix the month 0, day 0 timestamp to become 1 January instead: timestamp = timestamp:gsub("%-00%-00T", "-01-01T") -- just in case date precision is missing dprec = dprec or 11 -- override more precise dates if required dateformat is year alone: if df == "y" and dprec > 9 then dprec = 9 end -- complex date only deals with precisions from 6 to 11, so clip range dprec = dprec>11 and 11 or dprec dprec = dprec<6 and 6 or dprec -- BC format is "BC" or "BCE" bcf = (bcf or ""):upper() -- plaindate only needs the first letter (y/n/a) pd = (pd or ""):sub(1,1):lower() if pd == "" or pd == "n" or pd == "f" or pd == "0" then pd = false end -- in case language isn't passed lang = lang or findLang().code -- set adj as empty if nil adj = adj or "" -- extract the day, month, year from the timestamp local bc = timestamp:sub(1, 1)=="-" and "BC" or "" local year, month, day = timestamp:match("[+-](%d*)-(%d*)-(%d*)T") local iso = tonumber(year) -- if year is missing, let it throw an error -- this will adjust the date format to be compatible with cdate -- possible formats are Y, YY, YYY0, YYYY, YYYY-MM, YYYY-MM-DD if dprec == 6 then iso = math.floor( (iso - 1) / 1000 ) + 1 end if dprec == 7 then iso = math.floor( (iso - 1) / 100 ) + 1 end if dprec == 8 then iso = math.floor( iso / 10 ) .. "0" end if dprec == 10 then iso = year .. "-" .. month end if dprec == 11 then iso = year .. "-" .. month .. "-" .. day end -- add "circa" (Q5727902) from "sourcing circumstances" (P1480) local sc = not pd and qualifiers and qualifiers.P1480 if sc then for k1, v1 in pairs(sc) do if v1.datavalue and v1.datavalue.value.id == "Q5727902" then adj = "circa" break end end end -- deal with Julian dates: -- no point in saying that dates before 1582 are Julian - they are by default -- doesn't make sense for dates less precise than year -- we can suppress it by setting |plaindate, e.g. for use in constructing categories. local calendarmodel = "" if tonumber(year) > 1582 and dprec > 8 and not pd and model == "http://www.wikidata.org/entity/Q1985786" then calendarmodel = "julian" end if not cdate then cdate = require("Module:Complex date")._complex_date end local fdate = cdate(calendarmodel, adj, tostring(iso), dp[dprec], bc, "", "", "", "", lang, 1) -- this may have QuickStatements info appended to it in a div, so remove that fdate = fdate:gsub(' <div style="display: none;">[^<]*</div>', '') -- it may also be returned wrapped in a microformat, so remove that fdate = fdate:gsub("<[^>]*>", "") -- there may be leading zeros that we should remove fdate = fdate:gsub("^0*", "") -- if a plain date is required, then remove any links (like BC linked) if pd then fdate = fdate:gsub("%[%[.*|", ""):gsub("]]", "") end -- if 'circa', use the abbreviated form *** internationalise later *** fdate = fdate:gsub('circa ', '<abbr title="circa">c.</abbr>&nbsp;') -- deal with BC/BCE if bcf == "BCE" then fdate = fdate:gsub('BC', 'BCE') end -- deal with mdy format if df == "mdy" then fdate = fdate:gsub("(%d+) (%w+) (%d+)", "%2 %1, %3") end -- deal with adjectival form *** internationalise later *** if pd == "a" then fdate = fdate:gsub(' century', '-century') end return fdate end ------------------------------------------------------------------------------- -- parseParam takes a (string) parameter, e.g. from the list of frame arguments, -- and makes "false", "no", and "0" into the (boolean) false -- it makes the empty string and nil into the (boolean) value passed as default -- allowing the parameter to be true or false by default. -- It returns a boolean. ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- local parseParam = function(param, default) if type(param) == "boolean" then param = tostring(param) end if param and param ~= "" then param = param:lower() if (param == "false") or (param:sub(1,1) == "n") or (param == "0") then return false else return true end else return default end end ------------------------------------------------------------------------------- -- _getSitelink takes the qid of a Wikidata entity passed as |qid= -- It takes an optional parameter |wiki= to determine which wiki is to be checked for a sitelink -- If the parameter is blank, then it uses the local wiki. -- If there is a sitelink to an article available, it returns the plain text link to the article -- If there is no sitelink, it returns nil. ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- local _getSitelink = function(qid, wiki) qid = (qid or ""):upper() if qid == "" then qid = mw.wikibase.getEntityIdForCurrentPage() end if not qid then return nil end wiki = wiki or "" local sitelink if wiki == "" then sitelink = mw.wikibase.getSitelink(qid) else sitelink = mw.wikibase.getSitelink(qid, wiki) end return sitelink end ------------------------------------------------------------------------------- -- _getCommonslink takes an optional qid of a Wikidata entity passed as |qid= -- It returns one of the following in order of preference: -- the Commons sitelink of the Wikidata entity - but not if onlycat=true and it's not a category; -- the Commons sitelink of the topic's main category of the Wikidata entity; -- the Commons category of the Wikidata entity - unless fallback=false. ------------------------------------------------------------------------------- -- Dependencies: _getSitelink(); parseParam() ------------------------------------------------------------------------------- local _getCommonslink = function(qid, onlycat, fallback) qid = (qid or ""):upper() if qid == "" then qid = mw.wikibase.getEntityIdForCurrentPage() end if not qid then return nil end onlycat = parseParam(onlycat, false) if fallback == "" then fallback = nil end local sitelink = _getSitelink(qid, "commonswiki") if onlycat and sitelink and sitelink:sub(1,9) ~= "Category:" then sitelink = nil end if not sitelink then -- check for topic's main category local prop910 = mw.wikibase.getBestStatements(qid, "P910")[1] if prop910 then local tmcid = prop910.mainsnak.datavalue and prop910.mainsnak.datavalue.value.id sitelink = _getSitelink(tmcid, "commonswiki") end if not sitelink then -- check for list's main category local prop1754 = mw.wikibase.getBestStatements(qid, "P1754")[1] if prop1754 then local tmcid = prop1754.mainsnak.datavalue and prop1754.mainsnak.datavalue.value.id sitelink = _getSitelink(tmcid, "commonswiki") end end end if not sitelink and fallback then -- check for Commons category (string value) local prop373 = mw.wikibase.getBestStatements(qid, "P373")[1] if prop373 then sitelink = prop373.mainsnak.datavalue and prop373.mainsnak.datavalue.value if sitelink then sitelink = "Category:" .. sitelink end end end return sitelink end ------------------------------------------------------------------------------- -- The label in a Wikidata item is subject to vulnerabilities -- that an attacker might try to exploit. -- It needs to be 'sanitised' by removing any wikitext before use. -- If it doesn't exist, return the id for the item -- a second (boolean) value is also returned, value is true when the label exists ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- local labelOrId = function(id, lang) if lang == "default" then lang = findLang().code end local label if lang then label = mw.wikibase.getLabelByLang(id, lang) else label = mw.wikibase.getLabel(id) end if label then return mw.text.nowiki(label), true else return id, false end end ------------------------------------------------------------------------------- -- linkedItem takes an entity-id and returns a string, linked if possible. -- This is the handler for "wikibase-item". Preferences: -- 1. Display linked disambiguated sitelink if it exists -- 2. Display linked label if it is a redirect -- 3. TBA: Display an inter-language link for the label if it exists other than in default language -- 4. Display unlinked label if it exists -- 5. Display entity-id for now to indicate a label could be provided -- dtxt is text to be used instead of label, or nil. -- shortname is boolean switch to use P1813 (short name) instead of label if true. -- lang is the current language code. -- uselbl is boolean switch to force display of the label instead of the sitelink (default: false) -- linkredir is boolean switch to allow linking to a redirect (default: false) -- formatvalue is boolean switch to allow formatting as italics or quoted (default: false) ------------------------------------------------------------------------------- -- Dependencies: labelOrId(); donotlink[] ------------------------------------------------------------------------------- local linkedItem = function(id, args) local lprefix = (args.lp or args.lprefix or args.linkprefix or ""):gsub('"', '') -- toughen against nil values passed local lpostfix = (args.lpostfix or ""):gsub('"', '') local prefix = (args.prefix or ""):gsub('"', '') local postfix = (args.postfix or ""):gsub('"', '') local dtxt = args.dtxt local shortname = args.shortname or args.sn local lang = args.lang or "en" -- fallback to default if missing local uselbl = args.uselabel or args.uselbl uselbl = parseParam(uselbl, false) local linkredir = args.linkredir linkredir = parseParam(linkredir, false) local formatvalue = args.formatvalue or args.fv formatvalue = parseParam(formatvalue, false) -- see if item might need italics or quotes local fmt = "" if next(formats) and formatvalue then for k, v in ipairs( mw.wikibase.getBestStatements(id, "P31") ) do if v.mainsnak.datavalue and formats[v.mainsnak.datavalue.value.id] then fmt = formats[v.mainsnak.datavalue.value.id] break -- pick the first match end end end local disp local sitelink = mw.wikibase.getSitelink(id) local label, islabel if dtxt then label, islabel = dtxt, true elseif shortname then -- see if there is a shortname in our language, and set label to it for k, v in ipairs( mw.wikibase.getBestStatements(id, "P1813") ) do if v.mainsnak.datavalue.value.language == lang then label, islabel = v.mainsnak.datavalue.value.text, true break end -- test for language match end -- loop through values of short name -- if we have no label set, then there was no shortname available if not islabel then label, islabel = labelOrId(id) shortname = false end else label, islabel = labelOrId(id) end if mw.site.siteName ~= "Wikimedia Commons" then if sitelink then if not (dtxt or shortname) then -- if sitelink and label are the same except for case, no need to process further if sitelink:lower() ~= label:lower() then -- strip any namespace or dab from the sitelink local pos = sitelink:find(":") or 0 local slink = sitelink if pos > 0 then local pfx = sitelink:sub(1,pos-1) if mw.site.namespaces[pfx] then -- that prefix is a valid namespace, so remove it slink = sitelink:sub(pos+1) end end -- remove stuff after commas or inside parentheses - ie. dabs slink = slink:gsub("%s%(.+%)$", ""):gsub(",.+$", "") -- if uselbl is false, use sitelink instead of label if not uselbl then -- use slink as display, preserving label case - find("^%u") is true for 1st char uppercase if label:find("^%u") then label = slink:gsub("^(%l)", string.upper) else label = slink:gsub("^(%u)", string.lower) end end end end if donotlink[label] then disp = prefix .. fmt .. label .. fmt .. postfix else disp = "[[" .. lprefix .. sitelink .. lpostfix .. "|" .. prefix .. fmt .. label .. fmt .. postfix .. "]]" end elseif islabel then -- no sitelink, label exists, so check if a redirect with that title exists, if linkredir is true -- display plain label by default disp = prefix .. fmt .. label .. fmt .. postfix if linkredir then local artitle = mw.title.new(label, 0) -- only nil if label has invalid chars if not donotlink[label] and artitle and artitle.redirectTarget then -- there's a redirect with the same title as the label, so let's link to that disp = "[[".. lprefix .. label .. lpostfix .. "|" .. prefix .. fmt .. label .. fmt .. postfix .. "]]" end end -- test if article title exists as redirect on current Wiki else -- no sitelink and no label, so return whatever was returned from labelOrId for now -- add tracking category [[Category:Articles with missing Wikidata information]] -- for enwiki, just return the tracking category if mw.wikibase.getGlobalSiteId() == "enwiki" then disp = i18n.missinginfocat else disp = prefix .. label .. postfix .. i18n.missinginfocat end end else local ccat = mw.wikibase.getBestStatements(id, "P373")[1] if ccat and ccat.mainsnak.datavalue then ccat = ccat.mainsnak.datavalue.value disp = "[[" .. lprefix .. "Category:" .. ccat .. lpostfix .. "|" .. prefix .. label .. postfix .. "]]" elseif sitelink then -- this asumes that if a sitelink exists, then a label also exists disp = "[[" .. lprefix .. sitelink .. lpostfix .. "|" .. prefix .. label .. postfix .. "]]" else -- no sitelink and no Commons cat, so return label from labelOrId for now disp = prefix .. label .. postfix end end return disp end ------------------------------------------------------------------------------- -- sourced takes a table representing a statement that may or may not have references -- it looks for a reference sourced to something not containing the word "wikipedia" -- it returns a boolean = true if it finds a sourced reference. ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- local sourced = function(claim) if claim.references then for kr, vr in pairs(claim.references) do local ref = mw.wikibase.renderSnaks(vr.snaks) if not ref:find("Wiki") then return true end end end end ------------------------------------------------------------------------------- -- setRanks takes a flag (parameter passed) that requests the values to return -- "b[est]" returns preferred if available, otherwise normal -- "p[referred]" returns preferred -- "n[ormal]" returns normal -- "d[eprecated]" returns deprecated -- multiple values are allowed, e.g. "preferred normal" (which is the default) -- "best" will override the other flags, and set p and n ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- local setRanks = function(rank) rank = (rank or ""):lower() -- if nothing passed, return preferred and normal -- if rank == "" then rank = "p n" end local ranks = {} for w in string.gmatch(rank, "%a+") do w = w:sub(1,1) if w == "b" or w == "p" or w == "n" or w == "d" then ranks[w] = true end end -- check if "best" is requested or no ranks requested; and if so, set preferred and normal if ranks.b or not next(ranks) then ranks.p = true ranks.n = true end return ranks end ------------------------------------------------------------------------------- -- parseInput processes the Q-id , the blacklist and the whitelist -- if an input parameter is supplied, it returns that and ends the call. -- it returns (1) either the qid or nil indicating whether or not the call should continue -- and (2) a table containing all of the statements for the propertyID and relevant Qid -- if "best" ranks are requested, it returns those instead of all non-deprecated ranks ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- local parseInput = function(frame, input_parm, property_id) -- There may be a local parameter supplied, if it's blank, set it to nil input_parm = mw.text.trim(input_parm or "") if input_parm == "" then input_parm = nil end -- return nil if Wikidata is not available if not mw.wikibase then return false, input_parm end local args = frame.args -- can take a named parameter |qid which is the Wikidata ID for the article. -- if it's not supplied, use the id for the current page local qid = args.qid or "" if qid == "" then qid = mw.wikibase.getEntityIdForCurrentPage() end -- if there's no Wikidata item for the current page return nil if not qid then return false, input_parm end -- The blacklist is passed in named parameter |suppressfields local blacklist = args.suppressfields or args.spf or "" -- The whitelist is passed in named parameter |fetchwikidata local whitelist = args.fetchwikidata or args.fwd or "" if whitelist == "" then whitelist = "NONE" end -- The name of the field that this function is called from is passed in named parameter |name local fieldname = args.name or "" if blacklist ~= "" then -- The name is compulsory when blacklist is used, so return nil if it is not supplied if fieldname == "" then return false, nil end -- If this field is on the blacklist, then return nil if blacklist:find(fieldname) then return false, nil end end -- If we got this far then we're not on the blacklist -- The blacklist overrides any locally supplied parameter as well -- If a non-blank input parameter was supplied return it if input_parm then return false, input_parm end -- We can filter out non-valid properties if property_id:sub(1,1):upper() ~="P" or property_id == "P0" then return false, nil end -- Otherwise see if this field is on the whitelist: -- needs a bit more logic because find will return its second value = 0 if fieldname is "" -- but nil if fieldname not found on whitelist local _, found = whitelist:find(fieldname) found = ((found or 0) > 0) if whitelist ~= 'ALL' and (whitelist:upper() == "NONE" or not found) then return false, nil end -- See what's on Wikidata (the call always returns a table, but it may be empty): local props = {} if args.reqranks.b then props = mw.wikibase.getBestStatements(qid, property_id) else props = mw.wikibase.getAllStatements(qid, property_id) end if props[1] then return qid, props end -- no property on Wikidata return false, nil end ------------------------------------------------------------------------------- -- createicon assembles the "Edit at Wikidata" pen icon. -- It returns a wikitext string inside a span class="penicon" -- if entityID is nil or empty, the ID associated with current page is used -- langcode and propertyID may be nil or empty ------------------------------------------------------------------------------- -- Dependencies: i18n[]; ------------------------------------------------------------------------------- local createicon = function(langcode, entityID, propertyID) langcode = langcode or "" if not entityID or entityID == "" then entityID= mw.wikibase.getEntityIdForCurrentPage() end propertyID = propertyID or "" local icon = "&nbsp;<span class='penicon autoconfirmed-show'>[[" -- "&nbsp;<span data-bridge-edit-flow='overwrite' class='penicon'>[[" -> enable Wikidata Bridge .. i18n["filespace"] .. ":OOjs UI icon edit-ltr-progressive.svg |frameless |text-top |10px |alt=" .. i18n["editonwikidata"] .. "|link=https://www.wikidata.org/wiki/" .. entityID if langcode ~= "" then icon = icon .. "?uselang=" .. langcode end if propertyID ~= "" then icon = icon .. "#" .. propertyID end icon = icon .. "|" .. i18n["editonwikidata"] .. "]]</span>" return icon end ------------------------------------------------------------------------------- -- assembleoutput takes the sequence table containing the property values -- and formats it according to switches given. It returns a string or nil. -- It uses the entityID (and optionally propertyID) to create a link in the pen icon. ------------------------------------------------------------------------------- -- Dependencies: parseParam(); ------------------------------------------------------------------------------- local assembleoutput = function(out, args, entityID, propertyID) -- sorted is a boolean passed to enable sorting of the values returned -- if nothing or an empty string is passed set it false -- if "false" or "no" or "0" is passed set it false local sorted = parseParam(args.sorted, false) -- noicon is a boolean passed to suppress the trailing "edit at Wikidata" icon -- for use when the value is processed further by the infobox -- if nothing or an empty string is passed set it false -- if "false" or "no" or "0" is passed set it false local noic = parseParam(args.noicon, false) -- list is the name of a template that a list of multiple values is passed through -- examples include "hlist" and "ubl" -- setting it to "prose" produces something like "1, 2, 3, and 4" local list = args.list or "" -- sep is a string that is used to separate multiple returned values -- if nothing or an empty string is passed set it to the default -- any double-quotes " are stripped out, so that spaces may be passed -- e.g. |sep=" - " local sepdefault = i18n["list separator"] local separator = args.sep or "" separator = string.gsub(separator, '"', '') if separator == "" then separator = sepdefault end -- collapse is a number that determines the maximum number of returned values -- before the output is collapsed. -- Zero or not a number result in no collapsing (default becomes 0). local collapse = tonumber(args.collapse) or 0 -- replacetext (rt) is a string that is returned instead of any non-empty Wikidata value -- this is useful for tracking and debugging local replacetext = mw.text.trim(args.rt or args.replacetext or "") -- if there's anything to return, then return a list -- comma-separated by default, but may be specified by the sep parameter -- optionally specify a hlist or ubl or a prose list, etc. local strout if #out > 0 then if sorted then table.sort(out) end -- if there's something to display and a pen icon is wanted, add it the end of the last value local hasdisplay = false for i, v in ipairs(out) do if v ~= i18n.missinginfocat then hasdisplay = true break end end if not noic and hasdisplay then out[#out] = out[#out] .. createicon(args.langobj.code, entityID, propertyID) end if list == "" then strout = table.concat(out, separator) elseif list:lower() == "prose" then strout = mw.text.listToText( out ) else strout = mw.getCurrentFrame():expandTemplate{title = list, args = out} end if collapse >0 and #out > collapse then strout = collapsediv .. strout .. "</div>" end else strout = nil -- no items had valid reference end if replacetext ~= "" and strout then strout = replacetext end return strout end ------------------------------------------------------------------------------- -- rendersnak takes a table (propval) containing the information stored on one property value -- and returns the value as a string and its language if monolingual text. -- It handles data of type: -- wikibase-item -- time -- string, url, commonsMedia, external-id -- quantity -- globe-coordinate -- monolingualtext -- It also requires linked, the link/pre/postfixes, uabbr, and the arguments passed from frame. -- The optional filter parameter allows quantities to be be filtered by unit Qid. ------------------------------------------------------------------------------- -- Dependencies: parseParam(); labelOrId(); i18n[]; dateFormat(); -- roundto(); decimalPrecision(); decimalToDMS(); linkedItem(); ------------------------------------------------------------------------------- local rendersnak = function(propval, args, linked, lpre, lpost, pre, post, uabbr, filter) lpre = lpre or "" lpost = lpost or "" pre = pre or "" post = post or "" args.lang = args.lang or findLang().code -- allow values to display a fixed text instead of label local dtxt = args.displaytext or args.dt if dtxt == "" then dtxt = nil end -- switch to use display of short name (P1813) instead of label local shortname = args.shortname or args.sn shortname = parseParam(shortname, false) local snak = propval.mainsnak or propval local dtype = snak.datatype local dv = snak.datavalue dv = dv and dv.value -- value and monolingual text language code returned local val, mlt if propval.rank and not args.reqranks[propval.rank:sub(1, 1)] then -- val is nil: value has a rank that isn't requested ------------------------------------ elseif snak.snaktype == "somevalue" then -- value is unknown val = i18n["Unknown"] ------------------------------------ elseif snak.snaktype == "novalue" then -- value is none -- val = "No value" -- don't return anything ------------------------------------ elseif dtype == "wikibase-item" then -- data type is a wikibase item: -- it's wiki-linked value, so output as link if enabled and possible local qnumber = dv.id if linked then val = linkedItem(qnumber, args) else -- no link wanted so check for display-text, otherwise test for lang code local label, islabel if dtxt then label = dtxt else label, islabel = labelOrId(qnumber) local langlabel = mw.wikibase.getLabelByLang(qnumber, args.lang) if langlabel then label = mw.text.nowiki( langlabel ) end end val = pre .. label .. post end -- test for link required ------------------------------------ elseif dtype == "time" then -- data type is time: -- time is in timestamp format -- date precision is integer per mediawiki -- output formatting according to preferences (y/dmy/mdy) -- BC format as BC or BCE -- plaindate is passed to disable looking for "sourcing cirumstances" -- or to set the adjectival form -- qualifiers (if any) is a nested table or nil -- lang is given, or user language, or site language -- -- Here we can check whether args.df has a value -- If not, use code from Module:Sandbox/RexxS/Getdateformat to set it from templates like {{Use mdy dates}} val = dateFormat(dv.time, dv.precision, args.df, args.bc, args.pd, propval.qualifiers, args.lang, "", dv.calendarmodel) ------------------------------------ -- data types which are strings: elseif dtype == "commonsMedia" or dtype == "external-id" or dtype == "string" or dtype == "url" then -- commonsMedia or external-id or string or url -- all have mainsnak.datavalue.value as string if (lpre == "" or lpre == ":") and lpost == "" then -- don't link if no linkpre/postfix or linkprefix is just ":" val = pre .. dv .. post elseif dtype == "external-id" then val = "[" .. lpre .. dv .. lpost .. " " .. pre .. dv .. post .. "]" else val = "[[" .. lpre .. dv .. lpost .. "|" .. pre .. dv .. post .. "]]" end -- check for link requested (i.e. either linkprefix or linkpostfix exists) ------------------------------------ -- data types which are quantities: elseif dtype == "quantity" then -- quantities have mainsnak.datavalue.value.amount and mainsnak.datavalue.value.unit -- the unit is of the form http://www.wikidata.org/entity/Q829073 -- -- implement a switch to turn on/off numerical formatting later local fnum = true -- -- a switch to turn on/off conversions - only for en-wiki local conv = parseParam(args.conv or args.convert, false) -- if we have conversions, we won't have formatted numbers or scales if conv then uabbr = true fnum = false args.scale = "0" end -- -- a switch to turn on/off showing units, default is true local showunits = parseParam(args.su or args.showunits, true) -- -- convert amount to a number local amount = tonumber(dv.amount) or i18n["NaN"] -- -- scale factor for millions, billions, etc. local sc = tostring(args.scale or ""):sub(1,1):lower() local scale if sc == "a" then -- automatic scaling if amount > 1e15 then scale = 12 elseif amount > 1e12 then scale = 9 elseif amount > 1e9 then scale = 6 elseif amount > 1e6 then scale = 3 else scale = 0 end else scale = tonumber(args.scale) or 0 if scale < 0 or scale > 12 then scale = 0 end scale = math.floor(scale/3) * 3 end local factor = 10^scale amount = amount / factor -- ranges: local range = "" -- check if upper and/or lower bounds are given and significant local upb = tonumber(dv.upperBound) local lowb = tonumber(dv.lowerBound) if upb and lowb then -- differences rounded to 2 sig fig: local posdif = roundto(upb - amount, 2) / factor local negdif = roundto(amount - lowb, 2) / factor upb, lowb = amount + posdif, amount - negdif -- round scaled numbers to integers or 4 sig fig if (scale > 0 or sc == "a") then if amount < 1e4 then amount = roundto(amount, 4) else amount = math.floor(amount + 0.5) end end if fnum then amount = args.langobj:formatNum( amount ) end if posdif ~= negdif then -- non-symmetrical range = " +" .. posdif .. " -" .. negdif elseif posdif ~= 0 then -- symmetrical and non-zero range = " ±" .. posdif else -- otherwise range is zero, so leave it as "" end else -- round scaled numbers to integers or 4 sig fig if (scale > 0 or sc == "a") then if amount < 1e4 then amount = roundto(amount, 4) else amount = math.floor(amount + 0.5) end end if fnum then amount = args.langobj:formatNum( amount ) end end -- unit names and symbols: -- extract the qid in the form 'Qnnn' from the value.unit url -- and then fetch the label from that - or symbol if unitabbr is true local unit = "" local usep = "" local usym = "" local unitqid = string.match( dv.unit, "(Q%d+)" ) if filter and unitqid ~= filter then return nil end if unitqid and showunits then local uname = mw.wikibase.getLabelByLang(unitqid, args.lang) or "" if uname ~= "" then usep, unit = " ", uname end if uabbr then -- see if there's a unit symbol (P5061) local unitsymbols = mw.wikibase.getBestStatements(unitqid, "P5061") -- construct fallback table, add local lang and multiple languages local fbtbl = mw.language.getFallbacksFor( args.lang ) table.insert( fbtbl, 1, args.lang ) table.insert( fbtbl, 1, "mul" ) local found = false for idx1, us in ipairs(unitsymbols) do for idx2, fblang in ipairs(fbtbl) do if us.mainsnak.datavalue.value.language == fblang then usym = us.mainsnak.datavalue.value.text found = true break end if found then break end end -- loop through fallback table end -- loop through values of P5061 if found then usep, unit = "&nbsp;", usym end end end -- format display: if conv then if range == "" then val = mw.getCurrentFrame():expandTemplate{title = "cvt", args = {amount, unit}} else val = mw.getCurrentFrame():expandTemplate{title = "cvt", args = {lowb, "to", upb, unit}} end elseif unit == "$" or unit == "£" then val = unit .. amount .. range .. i18n.multipliers[scale] else val = amount .. range .. i18n.multipliers[scale] .. usep .. unit end ------------------------------------ -- datatypes which are global coordinates: elseif dtype == "globe-coordinate" then -- 'display' parameter defaults to "inline, title" *** unused for now *** -- local disp = args.display or "" -- if disp == "" then disp = "inline, title" end -- -- format parameter switches from deg/min/sec to decimal degrees -- default is deg/min/sec -- decimal degrees needs |format = dec local form = (args.format or ""):lower():sub(1,3) if form ~= "dec" then form = "dms" end -- not needed for now -- -- show parameter allows just the latitude, or just the longitude, or both -- to be returned as a signed decimal, ignoring the format parameter. local show = (args.show or ""):lower() if show ~= "longlat" then show = show:sub(1,3) end -- local lat, long, prec = dv.latitude, dv.longitude, dv.precision if show == "lat" then val = decimalPrecision(lat, prec) elseif show == "lon" then val = decimalPrecision(long, prec) elseif show == "longlat" then val = decimalPrecision(long, prec) .. ", " .. decimalPrecision(lat, prec) else local ns = "N" local ew = "E" if lat < 0 then ns = "S" lat = - lat end if long < 0 then ew = "W" long = - long end if form == "dec" then lat = decimalPrecision(lat, prec) long = decimalPrecision(long, prec) val = lat .. "°" .. ns .. " " .. long .. "°" .. ew else local latdeg, latmin, latsec = decimalToDMS(lat, prec) local longdeg, longmin, longsec = decimalToDMS(long, prec) if latsec == 0 and longsec == 0 then if latmin == 0 and longmin == 0 then val = latdeg .. "°" .. ns .. " " .. longdeg .. "°" .. ew else val = latdeg .. "°" .. latmin .. "′" .. ns .. " " val = val .. longdeg .. "°".. longmin .. "′" .. ew end else val = latdeg .. "°" .. latmin .. "′" .. latsec .. "″" .. ns .. " " val = val .. longdeg .. "°" .. longmin .. "′" .. longsec .. "″" .. ew end end end ------------------------------------ elseif dtype == "monolingualtext" then -- data type is Monolingual text: -- has mainsnak.datavalue.value as a table containing language/text pairs -- collect all the values in 'out' and languages in 'mlt' and process them later val = pre .. dv.text .. post mlt = dv.language ------------------------------------ else -- some other data type so write a specific handler val = "unknown data type: " .. dtype end -- of datatype/unknown value/sourced check return val, mlt end ------------------------------------------------------------------------------- -- propertyvalueandquals takes a property object, the arguments passed from frame, -- and a qualifier propertyID. -- It returns a sequence (table) of values representing the values of that property -- and qualifiers that match the qualifierID if supplied. ------------------------------------------------------------------------------- -- Dependencies: parseParam(); sourced(); labelOrId(); i18n.latestdatequalifier(); format_Date(); -- makeOrdinal(); roundto(); decimalPrecision(); decimalToDMS(); assembleoutput(); ------------------------------------------------------------------------------- local function propertyvalueandquals(objproperty, args, qualID) -- needs this style of declaration because it's re-entrant -- onlysourced is a boolean passed to return only values sourced to other than Wikipedia -- if nothing or an empty string is passed set it true local onlysrc = parseParam(args.onlysourced or args.osd, true) -- linked is a a boolean that enables the link to a local page via sitelink -- if nothing or an empty string is passed set it true local linked = parseParam(args.linked, true) -- prefix is a string that may be nil, empty (""), or a string of characters -- this is prefixed to each value -- useful when when multiple values are returned -- any double-quotes " are stripped out, so that spaces may be passed local prefix = (args.prefix or ""):gsub('"', '') -- postfix is a string that may be nil, empty (""), or a string of characters -- this is postfixed to each value -- useful when when multiple values are returned -- any double-quotes " are stripped out, so that spaces may be passed local postfix = (args.postfix or ""):gsub('"', '') -- linkprefix is a string that may be nil, empty (""), or a string of characters -- this creates a link and is then prefixed to each value -- useful when when multiple values are returned and indirect links are needed -- any double-quotes " are stripped out, so that spaces may be passed local lprefix = (args.linkprefix or args.lp or ""):gsub('"', '') -- linkpostfix is a string that may be nil, empty (""), or a string of characters -- this is postfixed to each value when linking is enabled with lprefix -- useful when when multiple values are returned -- any double-quotes " are stripped out, so that spaces may be passed local lpostfix = (args.linkpostfix or ""):gsub('"', '') -- wdlinks is a boolean passed to enable links to Wikidata when no article exists -- if nothing or an empty string is passed set it false local wdl = parseParam(args.wdlinks or args.wdl, false) -- unitabbr is a boolean passed to enable unit abbreviations for common units -- if nothing or an empty string is passed set it false local uabbr = parseParam(args.unitabbr or args.uabbr, false) -- qualsonly is a boolean passed to return just the qualifiers -- if nothing or an empty string is passed set it false local qualsonly = parseParam(args.qualsonly or args.qo, false) -- maxvals is a string that may be nil, empty (""), or a number -- this determines how many items may be returned when multiple values are available -- setting it = 1 is useful where the returned string is used within another call, e.g. image local maxvals = tonumber(args.maxvals) or 0 -- pd (plain date) is a string: yes/true/1 | no/false/0 | adj -- to disable/enable "sourcing cirumstances" or use adjectival form for the plain date local pd = args.plaindate or args.pd or "no" args.pd = pd -- allow qualifiers to have a different date format; default to year unless qualsonly is set args.qdf = args.qdf or args.qualifierdateformat or args.df or (not qualsonly and "y") local lang = args.lang or findLang().code -- qualID is a string list of wanted qualifiers or "ALL" qualID = qualID or "" -- capitalise list of wanted qualifiers and substitute "DATES" qualID = qualID:upper():gsub("DATES", "P580, P582") local allflag = (qualID == "ALL") -- create table of wanted qualifiers as key local qwanted = {} -- create sequence of wanted qualifiers local qorder = {} for q in mw.text.gsplit(qualID, "%p") do -- split at punctuation and iterate local qtrim = mw.text.trim(q) if qtrim ~= "" then qwanted[mw.text.trim(q)] = true qorder[#qorder+1] = qtrim end end -- qsep is the output separator for rendering qualifier list local qsep = (args.qsep or ""):gsub('"', '') -- qargs are the arguments to supply to assembleoutput() local qargs = { ["osd"] = "false", ["linked"] = tostring(linked), ["prefix"] = args.qprefix, ["postfix"] = args.qpostfix, ["linkprefix"] = args.qlinkprefix or args.qlp, ["linkpostfix"] = args.qlinkpostfix, ["wdl"] = "false", ["unitabbr"] = tostring(uabbr), ["maxvals"] = 0, ["sorted"] = tostring(args.qsorted), ["noicon"] = "true", ["list"] = args.qlist, ["sep"] = qsep, ["langobj"] = args.langobj, ["lang"] = args.langobj.code, ["df"] = args.qdf, ["sn"] = parseParam(args.qsn or args.qshortname, false), } -- all proper values of a Wikidata property will be the same type as the first -- qualifiers don't have a mainsnak, properties do local datatype = objproperty[1].datatype or objproperty[1].mainsnak.datatype -- out[] holds the a list of returned values for this property -- mlt[] holds the language code if the datatype is monolingual text local out = {} local mlt = {} for k, v in ipairs(objproperty) do local hasvalue = true if (onlysrc and not sourced(v)) then -- no value: it isn't sourced when onlysourced=true hasvalue = false else local val, lcode = rendersnak(v, args, linked, lprefix, lpostfix, prefix, postfix, uabbr) if not val then hasvalue = false -- rank doesn't match elseif qualsonly and qualID then -- suppress value returned: only qualifiers are requested else out[#out+1], mlt[#out+1] = val, lcode end end -- See if qualifiers are to be returned: local snak = v.mainsnak or v if hasvalue and v.qualifiers and qualID ~= "" and snak.snaktype~="novalue" then -- collect all wanted qualifier values returned in qlist, indexed by propertyID local qlist = {} local timestart, timeend = "", "" -- loop through qualifiers for k1, v1 in pairs(v.qualifiers) do if allflag or qwanted[k1] then if k1 == "P1326" then local ts = v1[1].datavalue.value.time local dp = v1[1].datavalue.value.precision qlist[k1] = dateFormat(ts, dp, args.qdf, args.bc, pd, "", lang, "before") elseif k1 == "P1319" then local ts = v1[1].datavalue.value.time local dp = v1[1].datavalue.value.precision qlist[k1] = dateFormat(ts, dp, args.qdf, args.bc, pd, "", lang, "after") elseif k1 == "P580" then timestart = propertyvalueandquals(v1, qargs)[1] or "" -- treat only one start time as valid elseif k1 == "P582" then timeend = propertyvalueandquals(v1, qargs)[1] or "" -- treat only one end time as valid else local q = assembleoutput(propertyvalueandquals(v1, qargs), qargs) -- we already deal with circa via 'sourcing circumstances' if the datatype was time -- circa may be either linked or unlinked *** internationalise later *** if datatype ~= "time" or q ~= "circa" and not (type(q) == "string" and q:find("circa]]")) then qlist[k1] = q end end end -- of test for wanted end -- of loop through qualifiers -- set date separator local t = timestart .. timeend -- *** internationalise date separators later *** local dsep = "&ndash;" if t:find("%s") or t:find("&nbsp;") then dsep = " &ndash; " end -- set the order for the list of qualifiers returned; start time and end time go last if next(qlist) then local qlistout = {} if allflag then for k2, v2 in pairs(qlist) do qlistout[#qlistout+1] = v2 end else for i2, v2 in ipairs(qorder) do qlistout[#qlistout+1] = qlist[v2] end end if t ~= "" then qlistout[#qlistout+1] = timestart .. dsep .. timeend end local qstr = assembleoutput(qlistout, qargs) if qualsonly then out[#out+1] = qstr else out[#out] = out[#out] .. " (" .. qstr .. ")" end elseif t ~= "" then if qualsonly then if timestart == "" then out[#out+1] = timeend elseif timeend == "" then out[#out+1] = timestart else out[#out+1] = timestart .. dsep .. timeend end else out[#out] = out[#out] .. " (" .. timestart .. dsep .. timeend .. ")" end end end -- of test for qualifiers wanted if maxvals > 0 and #out >= maxvals then break end end -- of for each value loop -- we need to pick one value to return if the datatype was "monolingualtext" -- if there's only one value, use that -- otherwise look through the fallback languages for a match if datatype == "monolingualtext" and #out >1 then lang = mw.text.split( lang, '-', true )[1] local fbtbl = mw.language.getFallbacksFor( lang ) table.insert( fbtbl, 1, lang ) local bestval = "" local found = false for idx1, lang1 in ipairs(fbtbl) do for idx2, lang2 in ipairs(mlt) do if (lang1 == lang2) and not found then bestval = out[idx2] found = true break end end -- loop through values of property end -- loop through fallback languages if found then -- replace output table with a table containing the best value out = { bestval } else -- more than one value and none of them on the list of fallback languages -- sod it, just give them the first one out = { out[1] } end end return out end ------------------------------------------------------------------------------- -- Common code for p.getValueByQual and p.getValueByLang ------------------------------------------------------------------------------- -- Dependencies: parseParam; setRanks; parseInput; sourced; assembleoutput; ------------------------------------------------------------------------------- local _getvaluebyqual = function(frame, qualID, checkvalue) -- The property ID that will have a qualifier is the first unnamed parameter local propertyID = mw.text.trim(frame.args[1] or "") if propertyID == "" then return "no property supplied" end if qualID == "" then return "no qualifier supplied" end -- onlysourced is a boolean passed to return property values -- only when property values are sourced to something other than Wikipedia -- if nothing or an empty string is passed set it true -- if "false" or "no" or 0 is passed set it false local onlysrc = parseParam(frame.args.onlysourced or frame.args.osd, true) -- set the requested ranks flags frame.args.reqranks = setRanks(frame.args.rank) -- set a language object and code in the frame.args table frame.args.langobj = findLang(frame.args.lang) frame.args.lang = frame.args.langobj.code local args = frame.args -- check for locally supplied parameter in second unnamed parameter -- success means no local parameter and the property exists local qid, props = parseInput(frame, args[2], propertyID) local linked = parseParam(args.linked, true) local lpre = (args.linkprefix or args.lp or ""):gsub('"', '') local lpost = (args.linkpostfix or ""):gsub('"', '') local pre = (args.prefix or ""):gsub('"', '') local post = (args.postfix or ""):gsub('"', '') local uabbr = parseParam(args.unitabbr or args.uabbr, false) local filter = (args.unit or ""):upper() local maxvals = tonumber(args.maxvals) or 0 if filter == "" then filter = nil end if qid then local out = {} -- Scan through the values of the property -- we want something like property is "pronunciation audio (P443)" in propertyID -- with a qualifier like "language of work or name (P407)" in qualID -- whose value has the required ID, like "British English (Q7979)", in qval for k1, v1 in ipairs(props) do if v1.mainsnak.snaktype == "value" then -- check if it has the right qualifier local v1q = v1.qualifiers if v1q and v1q[qualID] then if onlysrc == false or sourced(v1) then -- if we've got this far, we have a (sourced) claim with qualifiers -- so see if matches the required value -- We'll only deal with wikibase-items and strings for now if v1q[qualID][1].datatype == "wikibase-item" then if checkvalue(v1q[qualID][1].datavalue.value.id) then out[#out + 1] = rendersnak(v1, args, linked, lpre, lpost, pre, post, uabbr, filter) end elseif v1q[qualID][1].datatype == "string" then if checkvalue(v1q[qualID][1].datavalue.value) then out[#out + 1] = rendersnak(v1, args, linked, lpre, lpost, pre, post, uabbr, filter) end end end -- of check for sourced end -- of check for matching required value and has qualifiers else return nil end -- of check for string if maxvals > 0 and #out >= maxvals then break end end -- of loop through values of propertyID return assembleoutput(out, frame.args, qid, propertyID) else return props -- either local parameter or nothing end -- of test for success return nil end ------------------------------------------------------------------------------- -- _location takes Q-id and follows P276 (location) -- or P131 (located in the administrative territorial entity) or P706 (located on terrain feature) -- from the initial item to higher level territories/locations until it reaches the highest. -- An optional boolean, 'first', determines whether the first item is returned (default: false). -- An optional boolean 'skip' toggles the display to skip to the last item (default: false). -- It returns a table containing the locations - linked where possible, except for the highest. ------------------------------------------------------------------------------- -- Dependencies: findLang(); labelOrId(); linkedItem ------------------------------------------------------------------------------- local _location = function(qid, first, skip) first = parseParam(first, false) skip = parseParam(skip, false) local locs = {"P276", "P131", "P706"} local out = {} local langcode = findLang():getCode() local finished = false local count = 0 local prevqid = "Q0" repeat local prop for i1, v1 in ipairs(locs) do local proptbl = mw.wikibase.getBestStatements(qid, v1) if #proptbl > 1 then -- there is more than one higher location local prevP131, prevP131id if prevqid ~= "Q0" then prevP131 = mw.wikibase.getBestStatements(prevqid, "P131")[1] prevP131id = prevP131 and prevP131.mainsnak.datavalue and prevP131.mainsnak.datavalue.value.id end for i2, v2 in ipairs(proptbl) do local parttbl = v2.qualifiers and v2.qualifiers.P518 if parttbl then -- this higher location has qualifier 'applies to part' (P518) for i3, v3 in ipairs(parttbl) do if v3.snaktype == "value" and v3.datavalue.value.id == prevqid then -- it has a value equal to the previous location prop = proptbl[i2] break end -- of test for matching last location end -- of loop through values of 'applies to part' else -- there's no qualifier 'applies to part' (P518) -- so check if the previous location had a P131 that matches this alternate if qid == prevP131id then prop = proptbl[i2] break end -- of test for matching previous P131 end end -- of loop through parent locations -- fallback to second value if match not found prop = prop or proptbl[2] elseif #proptbl > 0 then prop = proptbl[1] end if prop then break end end -- check if it's an instance of (P31) a country (Q6256) or sovereign state (Q3624078) -- and terminate the chain if it is local inst = mw.wikibase.getAllStatements(qid, "P31") if #inst > 0 then for k, v in ipairs(inst) do local instid = v.mainsnak.datavalue and v.mainsnak.datavalue.value.id -- stop if it's a country (or a country within the United Kingdom if skip is true) if instid == "Q6256" or instid == "Q3624078" or (skip and instid == "Q3336843") then prop = nil -- this will ensure this is treated as top-level location break end end end -- get the name of this location and update qid to point to the parent location if prop and prop.mainsnak.datavalue then if not skip or count == 0 then local args = { lprefix = ":" } out[#out+1] = linkedItem(qid, args) -- get a linked value if we can end qid, prevqid = prop.mainsnak.datavalue.value.id, qid else -- This is top-level location, so get short name except when this is the first item -- Use full label if there's no short name or this is the first item local prop1813 = mw.wikibase.getAllStatements(qid, "P1813") -- if there's a short name and this isn't the only item if prop1813[1] and (#out > 0)then local shortname -- short name is monolingual text, so look for match to the local language -- choose the shortest 'short name' in that language for k, v in pairs(prop1813) do if v.mainsnak.datavalue.value.language == langcode then local name = v.mainsnak.datavalue.value.text if (not shortname) or (#name < #shortname) then shortname = name end end end -- add the shortname if one is found, fallback to the label -- but skip it if it's "USA" if shortname ~= "USA" then out[#out+1] = shortname or labelOrId(qid) else if skip then out[#out+1] = "US" end end else -- no shortname, so just add the label local loc = labelOrId(qid) -- exceptions go here: if loc == "United States of America" then out[#out+1] = "United States" else out[#out+1] = loc end end finished = true end count = count + 1 until finished or count >= 10 -- limit to 10 levels to avoid infinite loops -- remove the first location if not required if not first then table.remove(out, 1) end -- we might have duplicate text for consecutive locations, so remove them if #out > 2 then local plain = {} for i, v in ipairs(out) do -- strip any links plain[i] = v:gsub("^%[%[[^|]*|", ""):gsub("]]$", "") end local idx = 2 repeat if plain[idx] == plain[idx-1] then -- duplicate found local removeidx = 0 if (plain[idx] ~= out[idx]) and (plain[idx-1] == out[idx-1]) then -- only second one is linked, so drop the first removeidx = idx - 1 elseif (plain[idx] == out[idx]) and (plain[idx-1] ~= out[idx-1]) then -- only first one is linked, so drop the second removeidx = idx else -- pick one removeidx = idx - (os.time()%2) end table.remove(out, removeidx) table.remove(plain, removeidx) else idx = idx +1 end until idx >= #out end return out end ------------------------------------------------------------------------------- -- _getsumofparts scans the property 'has part' (P527) for values matching a list. -- The list (args.vlist) consists of a string of Qids separated by spaces or any usual punctuation. -- If the matched values have a qualifer 'quantity' (P1114), those quantites are summed. -- The sum is returned as a number (i.e. 0 if none) -- a table of arguments is supplied implementing the usual parameters. ------------------------------------------------------------------------------- -- Dependencies: setRanks; parseParam; parseInput; sourced; assembleoutput; ------------------------------------------------------------------------------- local _getsumofparts = function(args) local vallist = (args.vlist or ""):upper() if vallist == "" then return end args.reqranks = setRanks(args.rank) local f = {} f.args = args local qid, props = parseInput(f, "", "P527") if not qid then return 0 end local onlysrc = parseParam(args.onlysourced or args.osd, true) local sum = 0 for k1, v1 in ipairs(props) do if (onlysrc == false or sourced(v1)) and v1.mainsnak.snaktype == "value" and v1.mainsnak.datavalue.type == "wikibase-entityid" and vallist:match( v1.mainsnak.datavalue.value.id ) and v1.qualifiers then local quals = v1.qualifiers["P1114"] if quals then for k2, v2 in ipairs(quals) do sum = sum + v2.datavalue.value.amount end end end end return sum end ------------------------------------------------------------------------------- ------------------------------------------------------------------------------- -- Public functions ------------------------------------------------------------------------------- ------------------------------------------------------------------------------- -- _getValue makes the functionality of getValue available to other modules ------------------------------------------------------------------------------- -- Dependencies: setRanks; parseInput; propertyvalueandquals; assembleoutput; parseParam; sourced; -- labelOrId; i18n.latestdatequalifier; format_Date; makeOrdinal; roundto; decimalPrecision; decimalToDMS; ------------------------------------------------------------------------------- p._getValue = function(args) -- parameter sets for commonly used groups of parameters local paraset = tonumber(args.ps or args.parameterset or 0) if paraset == 1 then -- a common setting args.rank = "best" args.fetchwikidata = "ALL" args.onlysourced = "no" args.noicon = "true" elseif paraset == 2 then -- equivalent to raw args.rank = "best" args.fetchwikidata = "ALL" args.onlysourced = "no" args.noicon = "true" args.linked = "no" args.pd = "true" elseif paraset == 3 then -- third set goes here end -- implement eid parameter local eid = args.eid if eid == "" then return nil elseif eid then args.qid = eid end local propertyID = mw.text.trim(args[1] or "") args.reqranks = setRanks(args.rank) -- replacetext (rt) is a string that is returned instead of any non-empty Wikidata value -- this is useful for tracking and debugging, so we set fetchwikidata=ALL to fill the whitelist local replacetext = mw.text.trim(args.rt or args.replacetext or "") if replacetext ~= "" then args.fetchwikidata = "ALL" end local f = {} f.args = args local entityid, props = parseInput(f, f.args[2], propertyID) if not entityid then return props -- either the input parameter or nothing end -- qual is a string containing the property ID of the qualifier(s) to be returned -- if qual == "ALL" then all qualifiers returned -- if qual == "DATES" then qualifiers P580 (start time) and P582 (end time) returned -- if nothing or an empty string is passed set it nil -> no qualifiers returned local qualID = mw.text.trim(args.qual or ""):upper() if qualID == "" then qualID = nil end -- set a language object and code in the args table args.langobj = findLang(args.lang) args.lang = args.langobj.code -- table 'out' stores the return value(s): local out = propertyvalueandquals(props, args, qualID) -- format the table of values and return it as a string: return assembleoutput(out, args, entityid, propertyID) end ------------------------------------------------------------------------------- -- getValue is used to get the value(s) of a property -- The property ID is passed as the first unnamed parameter and is required. -- A locally supplied parameter may optionaly be supplied as the second unnamed parameter. -- The function will now also return qualifiers if parameter qual is supplied ------------------------------------------------------------------------------- -- Dependencies: _getValue; setRanks; parseInput; propertyvalueandquals; assembleoutput; parseParam; sourced; -- labelOrId; i18n.latestdatequalifier; format_Date; makeOrdinal; roundto; decimalPrecision; decimalToDMS; ------------------------------------------------------------------------------- p.getValue = function(frame) local args= frame.args if not args[1] then args = frame:getParent().args if not args[1] then return i18n.errors["No property supplied"] end end return p._getValue(args) end ------------------------------------------------------------------------------- -- getPreferredValue is used to get a value, -- (or a comma separated list of them if multiple values exist). -- If preferred ranks are set, it will return those values, otherwise values with normal ranks -- now redundant to getValue with |rank=best ------------------------------------------------------------------------------- -- Dependencies: p.getValue; setRanks; parseInput; propertyvalueandquals; assembleoutput; -- parseParam; sourced; labelOrId; i18n.latestdatequalifier; format_Date; -- makeOrdinal; roundto; decimalPrecision; decimalToDMS; ------------------------------------------------------------------------------- p.getPreferredValue = function(frame) frame.args.rank = "best" return p.getValue(frame) end ------------------------------------------------------------------------------- -- getCoords is used to get coordinates for display in an infobox -- whitelist and blacklist are implemented -- optional 'display' parameter is allowed, defaults to nil - was "inline, title" ------------------------------------------------------------------------------- -- Dependencies: setRanks(); parseInput(); decimalPrecision(); ------------------------------------------------------------------------------- p.getCoords = function(frame) local propertyID = "P625" -- if there is a 'display' parameter supplied, use it -- otherwise default to nothing local disp = frame.args.display or "" if disp == "" then disp = nil -- default to not supplying display parameter, was "inline, title" end -- there may be a format parameter to switch from deg/min/sec to decimal degrees -- default is deg/min/sec -- decimal degrees needs |format = dec local form = (frame.args.format or ""):lower():sub(1,3) if form ~= "dec" then form = "dms" end -- just deal with best values frame.args.reqranks = setRanks("best") local qid, props = parseInput(frame, frame.args[1], propertyID) if not qid then return props -- either local parameter or nothing else local dv = props[1].mainsnak.datavalue.value local lat, long, prec = dv.latitude, dv.longitude, dv.precision lat = decimalPrecision(lat, prec) long = decimalPrecision(long, prec) local lat_long = { lat, long } lat_long["display"] = disp lat_long["format"] = form -- invoke template Coord with the values stored in the table return frame:expandTemplate{title = 'coord', args = lat_long} end end ------------------------------------------------------------------------------- -- getQualifierValue is used to get a formatted value of a qualifier -- -- The call needs: a property (the unnamed parameter or 1=) -- a target value for that property (pval=) -- a qualifier for that target value (qual=) -- The usual whitelisting and blacklisting of the property is implemented -- The boolean onlysourced= parameter can be set to return nothing -- when the property is unsourced (or only sourced to Wikipedia) ------------------------------------------------------------------------------- -- Dependencies: parseParam(); setRanks(); parseInput(); sourced(); -- propertyvalueandquals(); assembleoutput(); -- labelOrId(); i18n.latestdatequalifier(); format_Date(); -- findLang(); makeOrdinal(); roundto(); decimalPrecision(); decimalToDMS(); ------------------------------------------------------------------------------- p.getQualifierValue = function(frame) -- The property ID that will have a qualifier is the first unnamed parameter local propertyID = mw.text.trim(frame.args[1] or "") -- The value of the property we want to match whose qualifier value is to be returned -- is passed in named parameter |pval= local propvalue = frame.args.pval -- The property ID of the qualifier -- whose value is to be returned is passed in named parameter |qual= local qualifierID = frame.args.qual -- A filter can be set like this: filter=P642==Q22674854 local filter, fprop, fval local ftable = mw.text.split(frame.args.filter or "", "==") if ftable[2] then fprop = mw.text.trim(ftable[1]) fval = mw.text.trim(ftable[2]) filter = true end -- onlysourced is a boolean passed to return qualifiers -- only when property values are sourced to something other than Wikipedia -- if nothing or an empty string is passed set it true -- if "false" or "no" or 0 is passed set it false local onlysrc = parseParam(frame.args.onlysourced or frame.args.osd, true) -- set a language object and language code in the frame.args table frame.args.langobj = findLang(frame.args.lang) frame.args.lang = frame.args.langobj.code -- set the requested ranks flags frame.args.reqranks = setRanks(frame.args.rank) -- check for locally supplied parameter in second unnamed parameter -- success means no local parameter and the property exists local qid, props = parseInput(frame, frame.args[2], propertyID) if qid then local out = {} -- Scan through the values of the property -- we want something like property is P793, significant event (in propertyID) -- whose value is something like Q385378, construction (in propvalue) -- then we can return the value(s) of a qualifier such as P580, start time (in qualifierID) for k1, v1 in pairs(props) do if v1.mainsnak.snaktype == "value" and v1.mainsnak.datavalue.type == "wikibase-entityid" then -- It's a wiki-linked value, so check if it's the target (in propvalue) and if it has qualifiers if v1.mainsnak.datavalue.value.id == propvalue and v1.qualifiers then if onlysrc == false or sourced(v1) then -- if we've got this far, we have a (sourced) claim with qualifiers -- which matches the target, so apply the filter and find the value(s) of the qualifier we want if not filter or (v1.qualifiers[fprop] and v1.qualifiers[fprop][1].datavalue.value.id == fval) then local quals = v1.qualifiers[qualifierID] if quals then -- can't reference qualifer, so set onlysourced = "no" (args are strings, not boolean) local qargs = frame.args qargs.onlysourced = "no" local vals = propertyvalueandquals(quals, qargs, qid) for k, v in ipairs(vals) do out[#out + 1] = v end end end end -- of check for sourced end -- of check for matching required value and has qualifiers end -- of check for wikibase entity end -- of loop through values of propertyID return assembleoutput(out, frame.args, qid, propertyID) else return props -- either local parameter or nothing end -- of test for success return nil end ------------------------------------------------------------------------------- -- getSumOfParts scans the property 'has part' (P527) for values matching a list. -- The list is passed in parameter vlist. -- It consists of a string of Qids separated by spaces or any usual punctuation. -- If the matched values have a qualifier 'quantity' (P1114), those quantities are summed. -- The sum is returned as a number or nothing if zero. ------------------------------------------------------------------------------- -- Dependencies: _getsumofparts; ------------------------------------------------------------------------------- p.getSumOfParts = function(frame) local sum = _getsumofparts(frame.args) if sum == 0 then return end return sum end ------------------------------------------------------------------------------- -- getValueByQual gets the value of a property which has a qualifier with a given entity value -- The call needs: -- a property ID (the unnamed parameter or 1=Pxxx) -- the ID of a qualifier for that property (qualID=Pyyy) -- either the Wikibase-entity ID of a value for that qualifier (qvalue=Qzzz) -- or a string value for that qualifier (qvalue=abc123) -- The usual whitelisting, blacklisting, onlysourced, etc. are implemented ------------------------------------------------------------------------------- -- Dependencies: _getvaluebyqual; parseParam; setRanks; parseInput; sourced; -- assembleoutput; ------------------------------------------------------------------------------- p.getValueByQual = function(frame) local qualID = frame.args.qualID -- The Q-id of the value for the qualifier we want to match is in named parameter |qvalue= local qval = frame.args.qvalue or "" if qval == "" then return "no qualifier value supplied" end local function checkQID(id) return id == qval end return _getvaluebyqual(frame, qualID, checkQID) end ------------------------------------------------------------------------------- -- getValueByLang gets the value of a property which has a qualifier P407 -- ("language of work or name") whose value has the given language code -- The call needs: -- a property ID (the unnamed parameter or 1=Pxxx) -- the MediaWiki language code to match the language (lang=xx[-yy]) -- (if no code is supplied, it uses the default language) -- The usual whitelisting, blacklisting, onlysourced, etc. are implemented ------------------------------------------------------------------------------- -- Dependencies: _getvaluebyqual; parseParam; setRanks; parseInput; sourced; assembleoutput; ------------------------------------------------------------------------------- p.getValueByLang = function(frame) -- The language code for the qualifier we want to match is in named parameter |lang= local langcode = findLang(frame.args.lang).code local function checkLanguage(id) -- id should represent a language like "British English (Q7979)" -- it should have string property "Wikimedia language code (P424)" -- qlcode will be a table: local qlcode = mw.wikibase.getBestStatements(id, "P424") if (#qlcode > 0) and (qlcode[1].mainsnak.datavalue.value == langcode) then return true end end return _getvaluebyqual(frame, "P407", checkLanguage) end ------------------------------------------------------------------------------- -- getValueByRefSource gets the value of a property which has a reference "stated in" (P248) -- whose value has the given entity-ID. -- The call needs: -- a property ID (the unnamed parameter or 1=Pxxx) -- the entity ID of a value to match where the reference is stated in (match=Qzzz) -- The usual whitelisting, blacklisting, onlysourced, etc. are implemented ------------------------------------------------------------------------------- -- Dependencies: parseParam; setRanks; parseInput; sourced; propertyvalueandquals assembleoutput; ------------------------------------------------------------------------------- p.getValueByRefSource = function(frame) -- The property ID that we want to check is the first unnamed parameter local propertyID = mw.text.trim(frame.args[1] or ""):upper() if propertyID == "" then return "no property supplied" end -- The Q-id of the value we want to match is in named parameter |qvalue= local qval = (frame.args.match or ""):upper() if qval == "" then qval = "Q21540096" end local unit = (frame.args.unit or ""):upper() if unit == "" then unit = "Q4917" end local onlysrc = parseParam(frame.args.onlysourced or frame.args.osd, true) -- set the requested ranks flags frame.args.reqranks = setRanks(frame.args.rank) -- set a language object and code in the frame.args table frame.args.langobj = findLang(frame.args.lang) frame.args.lang = frame.args.langobj.code local linked = parseParam(frame.args.linked, true) local uabbr = parseParam(frame.args.uabbr or frame.args.unitabbr, false) -- qid not nil means no local parameter and the property exists local qid, props = parseInput(frame, frame.args[2], propertyID) if qid then local out = {} local mlt= {} for k1, v1 in ipairs(props) do if onlysrc == false or sourced(v1) then if v1.references then for k2, v2 in ipairs(v1.references) do if v2.snaks.P248 then for k3, v3 in ipairs(v2.snaks.P248) do if v3.datavalue.value.id == qval then out[#out+1], mlt[#out+1] = rendersnak(v1, frame.args, linked, "", "", "", "", uabbr, unit) if not mlt[#out] then -- we only need one match per property value -- unless datatype was monolingual text break end end -- of test for match end -- of loop through values "stated in" end -- of test that "stated in" exists end -- of loop through references end -- of test that references exist end -- of test for sourced end -- of loop through values of propertyID if #mlt > 0 then local langcode = frame.args.lang langcode = mw.text.split( langcode, '-', true )[1] local fbtbl = mw.language.getFallbacksFor( langcode ) table.insert( fbtbl, 1, langcode ) local bestval = "" local found = false for idx1, lang1 in ipairs(fbtbl) do for idx2, lang2 in ipairs(mlt) do if (lang1 == lang2) and not found then bestval = out[idx2] found = true break end end -- loop through values of property end -- loop through fallback languages if found then -- replace output table with a table containing the best value out = { bestval } else -- more than one value and none of them on the list of fallback languages -- sod it, just give them the first one out = { out[1] } end end return assembleoutput(out, frame.args, qid, propertyID) else return props -- no property or local parameter supplied end -- of test for success end ------------------------------------------------------------------------------- -- getPropertyIDs takes most of the usual parameters. -- The usual whitelisting, blacklisting, onlysourced, etc. are implemented. -- It returns the Entity-IDs (Qids) of the values of a property if it is a Wikibase-Entity. -- Otherwise it returns nothing. ------------------------------------------------------------------------------- -- Dependencies: parseParam; setRanks; parseInput; sourced; propertyvalueandquals assembleoutput; ------------------------------------------------------------------------------- p._getPropertyIDs = function(args) args.reqranks = setRanks(args.rank) args.langobj = findLang(args.lang) args.lang = args.langobj.code -- change default for noicon to true args.noicon = tostring(parseParam(args.noicon or "", true)) local f = {} f.args = args local pid = mw.text.trim(args[1] or ""):upper() -- get the qid and table of claims for the property, or nothing and the local value passed local qid, props = parseInput(f, args[2], pid) if not qid then return props end if not props[1] then return nil end local onlysrc = parseParam(args.onlysourced or args.osd, true) local maxvals = tonumber(args.maxvals) or 0 local out = {} for i, v in ipairs(props) do local snak = v.mainsnak if ( snak.datatype == "wikibase-item" ) and ( v.rank and args.reqranks[v.rank:sub(1, 1)] ) and ( snak.snaktype == "value" ) and ( sourced(v) or not onlysrc ) then out[#out+1] = snak.datavalue.value.id end if maxvals > 0 and #out >= maxvals then break end end return assembleoutput(out, args, qid, pid) end p.getPropertyIDs = function(frame) local args = frame.args return p._getPropertyIDs(args) end ------------------------------------------------------------------------------- -- getQualifierIDs takes most of the usual parameters. -- The usual whitelisting, blacklisting, onlysourced, etc. are implemented. -- It takes a property-id as the first unnamed parameter, and an optional parameter qlist -- which is a list of qualifier property-ids to search for (default is "ALL") -- It returns the Entity-IDs (Qids) of the values of a property if it is a Wikibase-Entity. -- Otherwise it returns nothing. ------------------------------------------------------------------------------- -- Dependencies: parseParam; setRanks; parseInput; sourced; propertyvalueandquals assembleoutput; ------------------------------------------------------------------------------- p.getQualifierIDs = function(frame) local args = frame.args args.reqranks = setRanks(args.rank) args.langobj = findLang(args.lang) args.lang = args.langobj.code -- change default for noicon to true args.noicon = tostring(parseParam(args.noicon or "", true)) local f = {} f.args = args local pid = mw.text.trim(args[1] or ""):upper() -- get the qid and table of claims for the property, or nothing and the local value passed local qid, props = parseInput(f, args[2], pid) if not qid then return props end if not props[1] then return nil end -- get the other parameters local onlysrc = parseParam(args.onlysourced or args.osd, true) local maxvals = tonumber(args.maxvals) or 0 local qlist = args.qlist or "" if qlist == "" then qlist = "ALL" end qlist = qlist:gsub("[%p%s]+", " ") .. " " local out = {} for i, v in ipairs(props) do local snak = v.mainsnak if ( v.rank and args.reqranks[v.rank:sub(1, 1)] ) and ( snak.snaktype == "value" ) and ( sourced(v) or not onlysrc ) then if v.qualifiers then for k1, v1 in pairs(v.qualifiers) do if qlist == "ALL " or qlist:match(k1 .. " ") then for i2, v2 in ipairs(v1) do if v2.datatype == "wikibase-item" and v2.snaktype == "value" then out[#out+1] = v2.datavalue.value.id end -- of test that id exists end -- of loop through qualifier values end -- of test for kq in qlist end -- of loop through qualifiers end -- of test for qualifiers end -- of test for rank value, sourced, and value exists if maxvals > 0 and #out >= maxvals then break end end -- of loop through property values return assembleoutput(out, args, qid, pid) end ------------------------------------------------------------------------------- -- getPropOfProp takes two propertyIDs: prop1 and prop2 (as well as the usual parameters) -- If the value(s) of prop1 are of type "wikibase-item" then it returns the value(s) of prop2 -- of each of those wikibase-items. -- The usual whitelisting, blacklisting, onlysourced, etc. are implemented ------------------------------------------------------------------------------- -- Dependencies: parseParam; setRanks; parseInput; sourced; propertyvalueandquals assembleoutput; ------------------------------------------------------------------------------- p._getPropOfProp = function(args) -- parameter sets for commonly used groups of parameters local paraset = tonumber(args.ps or args.parameterset or 0) if paraset == 1 then -- a common setting args.rank = "best" args.fetchwikidata = "ALL" args.onlysourced = "no" args.noicon = "true" elseif paraset == 2 then -- equivalent to raw args.rank = "best" args.fetchwikidata = "ALL" args.onlysourced = "no" args.noicon = "true" args.linked = "no" args.pd = "true" elseif paraset == 3 then -- third set goes here end args.reqranks = setRanks(args.rank) args.langobj = findLang(args.lang) args.lang = args.langobj.code local pid1 = args.prop1 or args.pid1 or "" local pid2 = args.prop2 or args.pid2 or "" if pid1 == "" or pid2 == "" then return nil end local f = {} f.args = args local qid1, statements1 = parseInput(f, args[1], pid1) -- parseInput nulls empty args[1] and returns args[1] if nothing on Wikidata if not qid1 then return statements1 end -- otherwise it returns the qid and a table for the statement local onlysrc = parseParam(args.onlysourced or args.osd, true) local maxvals = tonumber(args.maxvals) or 0 local qualID = mw.text.trim(args.qual or ""):upper() if qualID == "" then qualID = nil end local out = {} for k, v in ipairs(statements1) do if not onlysrc or sourced(v) then local snak = v.mainsnak if snak.datatype == "wikibase-item" and snak.snaktype == "value" then local qid2 = snak.datavalue.value.id local statements2 = {} if args.reqranks.b then statements2 = mw.wikibase.getBestStatements(qid2, pid2) else statements2 = mw.wikibase.getAllStatements(qid2, pid2) end if statements2[1] then local out2 = propertyvalueandquals(statements2, args, qualID) out[#out+1] = assembleoutput(out2, args, qid2, pid2) end end -- of test for valid property1 value end -- of test for sourced if maxvals > 0 and #out >= maxvals then break end end -- of loop through values of property1 return assembleoutput(out, args, qid1, pid1) end p.getPropOfProp = function(frame) local args= frame.args if not args.prop1 and not args.pid1 then args = frame:getParent().args if not args.prop1 and not args.pid1 then return i18n.errors["No property supplied"] end end return p._getPropOfProp(args) end ------------------------------------------------------------------------------- -- getAwardCat takes most of the usual parameters. If the item has values of P166 (award received), -- then it examines each of those awards for P2517 (category for recipients of this award). -- If it exists, it returns the corresponding category, -- with the item's P734 (family name) as sort key, or no sort key if there is no family name. -- The sort key may be overridden by the parameter |sortkey (alias |sk). -- The usual whitelisting, blacklisting, onlysourced, etc. are implemented ------------------------------------------------------------------------------- -- Dependencies: parseParam; setRanks; parseInput; sourced; propertyvalueandquals assembleoutput; ------------------------------------------------------------------------------- p.getAwardCat = function(frame) frame.args.reqranks = setRanks(frame.args.rank) frame.args.langobj = findLang(frame.args.lang) frame.args.lang = frame.args.langobj.code local args = frame.args args.sep = " " local pid1 = args.prop1 or "P166" local pid2 = args.prop2 or "P2517" if pid1 == "" or pid2 == "" then return nil end -- locally supplied value: local localval = mw.text.trim(args[1] or "") local qid1, statements1 = parseInput(frame, localval, pid1) if not qid1 then return localval end -- linkprefix (strip quotes) local lp = (args.linkprefix or args.lp or ""):gsub('"', '') -- sort key (strip quotes, hyphens and periods): local sk = (args.sortkey or args.sk or ""):gsub('["-.]', '') -- family name: local famname = "" if sk == "" then local p734 = mw.wikibase.getBestStatements(qid1, "P734")[1] local p734id = p734 and p734.mainsnak.snaktype == "value" and p734.mainsnak.datavalue.value.id or "" famname = mw.wikibase.getSitelink(p734id) or "" -- strip namespace and disambigation local pos = famname:find(":") or 0 famname = famname:sub(pos+1):gsub("%s%(.+%)$", "") if famname == "" then local lbl = mw.wikibase.getLabel(p734id) famname = lbl and mw.text.nowiki(lbl) or "" end end local onlysrc = parseParam(args.onlysourced or args.osd, true) local maxvals = tonumber(args.maxvals) or 0 local qualID = mw.text.trim(args.qual or ""):upper() if qualID == "" then qualID = nil end local out = {} for k, v in ipairs(statements1) do if not onlysrc or sourced(v) then local snak = v.mainsnak if snak.datatype == "wikibase-item" and snak.snaktype == "value" then local qid2 = snak.datavalue.value.id local statements2 = {} if args.reqranks.b then statements2 = mw.wikibase.getBestStatements(qid2, pid2) else statements2 = mw.wikibase.getAllStatements(qid2, pid2) end if statements2[1] and statements2[1].mainsnak.snaktype == "value" then local qid3 = statements2[1].mainsnak.datavalue.value.id local sitelink = mw.wikibase.getSitelink(qid3) -- if there's no local sitelink, create the sitelink from English label if not sitelink then local lbl = mw.wikibase.getLabelByLang(qid3, "en") if lbl then if lbl:sub(1,9) == "Category:" then sitelink = mw.text.nowiki(lbl) else sitelink = "Category:" .. mw.text.nowiki(lbl) end end end if sitelink then if sk ~= "" then out[#out+1] = "[[" .. lp .. sitelink .. "|" .. sk .. "]]" elseif famname ~= "" then out[#out+1] = "[[" .. lp .. sitelink .. "|" .. famname .. "]]" else out[#out+1] = "[[" .. lp .. sitelink .. "]]" end -- of check for sort keys end -- of test for sitelink end -- of test for category end -- of test for wikibase item has a value end -- of test for sourced if maxvals > 0 and #out >= maxvals then break end end -- of loop through values of property1 return assembleoutput(out, args, qid1, pid1) end ------------------------------------------------------------------------------- -- getIntersectCat takes most of the usual parameters. -- The usual whitelisting, blacklisting, onlysourced, etc. are implemented -- It takes two properties, |prop1 and |prop2 (e.g. occupation and country of citizenship) -- Each property's value is a wiki-base entity -- For each value of the first parameter (ranks implemented) it fetches the value's main category -- and then each value of the second parameter (possibly substituting a simpler description) -- then it returns all of the categories representing the intersection of those properties, -- (e.g. Category:Actors from Canada). A joining term may be supplied (e.g. |join=from). -- The item's P734 (family name) is the sort key, or no sort key if there is no family name. -- The sort key may be overridden by the parameter |sortkey (alias |sk). ------------------------------------------------------------------------------- -- Dependencies: parseParam; setRanks; parseInput; sourced; propertyvalueandquals assembleoutput; ------------------------------------------------------------------------------- p.getIntersectCat = function(frame) frame.args.reqranks = setRanks(frame.args.rank) frame.args.langobj = findLang(frame.args.lang) frame.args.lang = frame.args.langobj.code local args = frame.args args.sep = " " args.linked = "no" local pid1 = args.prop1 or "P106" local pid2 = args.prop2 or "P27" if pid1 == "" or pid2 == "" then return nil end local qid, statements1 = parseInput(frame, "", pid1) if not qid then return nil end local qid, statements2 = parseInput(frame, "", pid2) if not qid then return nil end -- topics like countries may have different names in categories from their label in Wikidata local subs_exists, subs = pcall(mw.loadData, "Module:WikidataIB/subs") local join = args.join or "" local onlysrc = parseParam(args.onlysourced or args.osd, true) local maxvals = tonumber(args.maxvals) or 0 -- linkprefix (strip quotes) local lp = (args.linkprefix or args.lp or ""):gsub('"', '') -- sort key (strip quotes, hyphens and periods): local sk = (args.sortkey or args.sk or ""):gsub('["-.]', '') -- family name: local famname = "" if sk == "" then local p734 = mw.wikibase.getBestStatements(qid, "P734")[1] local p734id = p734 and p734.mainsnak.snaktype == "value" and p734.mainsnak.datavalue.value.id or "" famname = mw.wikibase.getSitelink(p734id) or "" -- strip namespace and disambigation local pos = famname:find(":") or 0 famname = famname:sub(pos+1):gsub("%s%(.+%)$", "") if famname == "" then local lbl = mw.wikibase.getLabel(p734id) famname = lbl and mw.text.nowiki(lbl) or "" end end local cat1 = {} for k, v in ipairs(statements1) do if not onlysrc or sourced(v) then -- get the ID representing the value of the property local pvalID = (v.mainsnak.snaktype == "value") and v.mainsnak.datavalue.value.id if pvalID then -- get the topic's main category (P910) for that entity local p910 = mw.wikibase.getBestStatements(pvalID, "P910")[1] if p910 and p910.mainsnak.snaktype == "value" then local tmcID = p910.mainsnak.datavalue.value.id -- use sitelink or the English label for the cat local cat = mw.wikibase.getSitelink(tmcID) if not cat then local lbl = mw.wikibase.getLabelByLang(tmcID, "en") if lbl then if lbl:sub(1,9) == "Category:" then cat = mw.text.nowiki(lbl) else cat = "Category:" .. mw.text.nowiki(lbl) end end end cat1[#cat1+1] = cat end -- of test for topic's main category exists end -- of test for property has vaild value end -- of test for sourced if maxvals > 0 and #cat1 >= maxvals then break end end local cat2 = {} for k, v in ipairs(statements2) do if not onlysrc or sourced(v) then local cat = rendersnak(v, args) if subs[cat] then cat = subs[cat] end cat2[#cat2+1] = cat end if maxvals > 0 and #cat2 >= maxvals then break end end local out = {} for k1, v1 in ipairs(cat1) do for k2, v2 in ipairs(cat2) do if sk ~= "" then out[#out+1] = "[[" .. lp .. v1 .. " " .. join .. " " .. v2 .. "|" .. sk .. "]]" elseif famname ~= "" then out[#out+1] = "[[" .. lp .. v1 .. " " .. join .. " " .. v2 .. "|" .. famname .. "]]" else out[#out+1] = "[[" .. lp .. v1 .. " " .. join .. " " .. v2 .. "]]" end -- of check for sort keys end end args.noicon = "true" return assembleoutput(out, args, qid, pid1) end ------------------------------------------------------------------------------- -- qualsToTable takes most of the usual parameters. -- The usual whitelisting, blacklisting, onlysourced, etc. are implemented. -- A qid may be given, and the first unnamed parameter is the property ID, which is of type wikibase item. -- It takes a list of qualifier property IDs as |quals= -- For a given qid and property, it creates the rows of an html table, -- each row being a value of the property (optionally only if the property matches the value in |pval= ) -- each cell being the first value of the qualifier corresponding to the list in |quals ------------------------------------------------------------------------------- -- Dependencies: parseParam; setRanks; parseInput; sourced; ------------------------------------------------------------------------------- p.qualsToTable = function(frame) local args = frame.args local quals = args.quals or "" if quals == "" then return "" end args.reqranks = setRanks(args.rank) local propertyID = mw.text.trim(args[1] or "") local f = {} f.args = args local entityid, props = parseInput(f, "", propertyID) if not entityid then return "" end args.langobj = findLang(args.lang) args.lang = args.langobj.code local pval = args.pval or "" local qplist = mw.text.split(quals, "%p") -- split at punctuation and make a sequential table for i, v in ipairs(qplist) do qplist[i] = mw.text.trim(v):upper() -- remove whitespace and capitalise end local col1 = args.firstcol or "" if col1 ~= "" then col1 = col1 .. "</td><td>" end local emptycell = args.emptycell or "&nbsp;" -- construct a 2-D array of qualifier values in qvals local qvals = {} for i, v in ipairs(props) do local skip = false if pval ~= "" then local pid = v.mainsnak.datavalue and v.mainsnak.datavalue.value.id if pid ~= pval then skip = true end end if not skip then local qval = {} local vqualifiers = v.qualifiers or {} -- go through list of wanted qualifier properties for i1, v1 in ipairs(qplist) do -- check for that property ID in the statement's qualifiers local qv, qtype if vqualifiers[v1] then qtype = vqualifiers[v1][1].datatype if qtype == "time" then if vqualifiers[v1][1].snaktype == "value" then qv = mw.wikibase.renderSnak(vqualifiers[v1][1]) qv = frame:expandTemplate{title="dts", args={qv}} else qv = "?" end elseif qtype == "url" then if vqualifiers[v1][1].snaktype == "value" then qv = mw.wikibase.renderSnak(vqualifiers[v1][1]) local display = mw.ustring.match( mw.uri.decode(qv, "WIKI"), "([%w ]+)$" ) if display then qv = "[" .. qv .. " " .. display .. "]" end end else qv = mw.wikibase.formatValue(vqualifiers[v1][1]) end end -- record either the value or a placeholder qval[i1] = qv or emptycell end -- of loop through list of qualifiers -- add the list of qualifier values as a "row" in the main list qvals[#qvals+1] = qval end end -- of for each value loop local out = {} for i, v in ipairs(qvals) do out[i] = "<tr><td>" .. col1 .. table.concat(qvals[i], "</td><td>") .. "</td></tr>" end return table.concat(out, "\n") end ------------------------------------------------------------------------------- -- getGlobe takes an optional qid of a Wikidata entity passed as |qid= -- otherwise it uses the linked item for the current page. -- If returns the Qid of the globe used in P625 (coordinate location), -- or nil if there isn't one. ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- p.getGlobe = function(frame) local qid = frame.args.qid or frame.args[1] or "" if qid == "" then qid = mw.wikibase.getEntityIdForCurrentPage() end local coords = mw.wikibase.getBestStatements(qid, "P625")[1] local globeid if coords and coords.mainsnak.snaktype == "value" then globeid = coords.mainsnak.datavalue.value.globe:match("(Q%d+)") end return globeid end ------------------------------------------------------------------------------- -- getCommonsLink takes an optional qid of a Wikidata entity passed as |qid= -- It returns one of the following in order of preference: -- the Commons sitelink of the linked Wikidata item; -- the Commons sitelink of the topic's main category of the linked Wikidata item; ------------------------------------------------------------------------------- -- Dependencies: _getCommonslink(); _getSitelink(); parseParam() ------------------------------------------------------------------------------- p.getCommonsLink = function(frame) local oc = frame.args.onlycat or frame.args.onlycategories local fb = parseParam(frame.args.fallback or frame.args.fb, true) return _getCommonslink(frame.args.qid, oc, fb) end ------------------------------------------------------------------------------- -- getSitelink takes the qid of a Wikidata entity passed as |qid= -- It takes an optional parameter |wiki= to determine which wiki is to be checked for a sitelink -- If the parameter is blank, then it uses the local wiki. -- If there is a sitelink to an article available, it returns the plain text link to the article -- If there is no sitelink, it returns nil. ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- p.getSiteLink = function(frame) return _getSitelink(frame.args.qid, frame.args.wiki or mw.text.trim(frame.args[1] or "")) end ------------------------------------------------------------------------------- -- getLink has the qid of a Wikidata entity passed as the first unnamed parameter or as |qid= -- If there is a sitelink to an article on the local Wiki, it returns a link to the article -- with the Wikidata label as the displayed text. -- If there is no sitelink, it returns the label as plain text. -- If there is no label in the local language, it displays the qid instead. ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- p.getLink = function(frame) local itemID = mw.text.trim(frame.args[1] or frame.args.qid or "") if itemID == "" then return end local sitelink = mw.wikibase.getSitelink(itemID) local label = labelOrId(itemID) if sitelink then return "[[:" .. sitelink .. "|" .. label .. "]]" else return label end end ------------------------------------------------------------------------------- -- getLabel has the qid of a Wikidata entity passed as the first unnamed parameter or as |qid= -- It returns the Wikidata label for the local language as plain text. -- If there is no label in the local language, it displays the qid instead. ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- p.getLabel = function(frame) local itemID = mw.text.trim(frame.args[1] or frame.args.qid or "") if itemID == "" then return end local lang = frame.args.lang or "" if lang == "" then lang = nil end local label = labelOrId(itemID, lang) return label end ------------------------------------------------------------------------------- -- label has the qid of a Wikidata entity passed as the first unnamed parameter or as |qid= -- if no qid is supplied, it uses the qid associated with the current page. -- It returns the Wikidata label for the local language as plain text. -- If there is no label in the local language, it returns nil. ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- p.label = function(frame) local qid = mw.text.trim(frame.args[1] or frame.args.qid or "") if qid == "" then qid = mw.wikibase.getEntityIdForCurrentPage() end if not qid then return end local lang = frame.args.lang or "" if lang == "" then lang = nil end local label, success = labelOrId(qid, lang) if success then return label end end ------------------------------------------------------------------------------- -- getAT (Article Title) -- has the qid of a Wikidata entity passed as the first unnamed parameter or as |qid= -- If there is a sitelink to an article on the local Wiki, it returns the sitelink as plain text. -- If there is no sitelink or qid supplied, it returns nothing. ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- p.getAT = function(frame) local itemID = mw.text.trim(frame.args[1] or frame.args.qid or "") if itemID == "" then return end return mw.wikibase.getSitelink(itemID) end ------------------------------------------------------------------------------- -- getDescription has the qid of a Wikidata entity passed as |qid= -- (it defaults to the associated qid of the current article if omitted) -- and a local parameter passed as the first unnamed parameter. -- Any local parameter passed (other than "Wikidata" or "none") becomes the return value. -- It returns the article description for the Wikidata entity if the local parameter is "Wikidata". -- Nothing is returned if the description doesn't exist or "none" is passed as the local parameter. ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- p.getDescription = function(frame) local desc = mw.text.trim(frame.args[1] or "") local itemID = mw.text.trim(frame.args.qid or "") if itemID == "" then itemID = nil end if desc:lower() == 'wikidata' then return mw.wikibase.getDescription(itemID) elseif desc:lower() == 'none' then return nil else return desc end end ------------------------------------------------------------------------------- -- getAliases has the qid of a Wikidata entity passed as |qid= -- (it defaults to the associated qid of the current article if omitted) -- and a local parameter passed as the first unnamed parameter. -- It implements blacklisting and whitelisting with a field name of "alias" by default. -- Any local parameter passed becomes the return value. -- Otherwise it returns the aliases for the Wikidata entity with the usual list options. -- Nothing is returned if the aliases do not exist. ------------------------------------------------------------------------------- -- Dependencies: findLang(); assembleoutput() ------------------------------------------------------------------------------- p.getAliases = function(frame) local args = frame.args local fieldname = args.name or "" if fieldname == "" then fieldname = "alias" end local blacklist = args.suppressfields or args.spf or "" if blacklist:find(fieldname) then return nil end local localval = mw.text.trim(args[1] or "") if localval ~= "" then return localval end local whitelist = args.fetchwikidata or args.fwd or "" if whitelist == "" then whitelist = "NONE" end if not (whitelist == 'ALL' or whitelist:find(fieldname)) then return nil end local qid = args.qid or "" if qid == "" then qid = mw.wikibase.getEntityIdForCurrentPage() end if not qid or not mw.wikibase.entityExists(qid) then return nil end local aliases = mw.wikibase.getEntity(qid).aliases if not aliases then return nil end args.langobj = findLang(args.lang) local langcode = args.langobj.code args.lang = langcode local out = {} for k1, v1 in pairs(aliases) do if v1[1].language == langcode then for k1, v2 in ipairs(v1) do out[#out+1] = v2.value end break end end return assembleoutput(out, args, qid) end ------------------------------------------------------------------------------- -- pageId returns the page id (entity ID, Qnnn) of the current page -- returns nothing if the page is not connected to Wikidata ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- p.pageId = function(frame) return mw.wikibase.getEntityIdForCurrentPage() end ------------------------------------------------------------------------------- -- formatDate is a wrapper to export the private function format_Date ------------------------------------------------------------------------------- -- Dependencies: format_Date(); ------------------------------------------------------------------------------- p.formatDate = function(frame) return format_Date(frame.args[1], frame.args.df, frame.args.bc) end ------------------------------------------------------------------------------- -- location is a wrapper to export the private function _location -- it takes the entity-id as qid or the first unnamed parameter -- optional boolean parameter first toggles the display of the first item -- optional boolean parameter skip toggles the display to skip to the last item -- parameter debug=<y/n> (default 'n') adds error msg if not a location ------------------------------------------------------------------------------- -- Dependencies: _location(); ------------------------------------------------------------------------------- p.location = function(frame) local debug = (frame.args.debug or ""):sub(1, 1):lower() if debug == "" then debug = "n" end local qid = mw.text.trim(frame.args.qid or frame.args[1] or ""):upper() if qid == "" then qid=mw.wikibase.getEntityIdForCurrentPage() end if not qid then if debug ~= "n" then return i18n.errors["entity-not-found"] else return nil end end local first = mw.text.trim(frame.args.first or "") local skip = mw.text.trim(frame.args.skip or "") return table.concat( _location(qid, first, skip), ", " ) end ------------------------------------------------------------------------------- -- checkBlacklist implements a test to check whether a named field is allowed -- returns true if the field is not blacklisted (i.e. allowed) -- returns false if the field is blacklisted (i.e. disallowed) -- {{#if:{{#invoke:WikidataIB |checkBlacklist |name=Joe |suppressfields=Dave; Joe; Fred}} | not blacklisted | blacklisted}} -- displays "blacklisted" -- {{#if:{{#invoke:WikidataIB |checkBlacklist |name=Jim |suppressfields=Dave; Joe; Fred}} | not blacklisted | blacklisted}} -- displays "not blacklisted" ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- p.checkBlacklist = function(frame) local blacklist = frame.args.suppressfields or frame.args.spf or "" local fieldname = frame.args.name or "" if blacklist ~= "" and fieldname ~= "" then if blacklist:find(fieldname) then return false else return true end else -- one of the fields is missing: let's call that "not on the list" return true end end ------------------------------------------------------------------------------- -- emptyor returns nil if its first unnamed argument is just punctuation, whitespace or html tags -- otherwise it returns the argument unchanged (including leading/trailing space). -- If the argument may contain "=", then it must be called explicitly: -- |1=arg -- (In that case, leading and trailing spaces are trimmed) -- It finds use in infoboxes where it can replace tests like: -- {{#if: {{#invoke:WikidatIB |getvalue |P99 |fwd=ALL}} | <span class="xxx">{{#invoke:WikidatIB |getvalue |P99 |fwd=ALL}}</span> | }} -- with a form that uses just a single call to Wikidata: -- {{#invoke |WikidataIB |emptyor |1= <span class="xxx">{{#invoke:WikidataIB |getvalue |P99 |fwd=ALL}}</span> }} ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- p.emptyor = function(frame) local s = frame.args[1] or "" if s == "" then return nil end local sx = s:gsub("%s", ""):gsub("<[^>]*>", ""):gsub("%p", "") if sx == "" then return nil else return s end end ------------------------------------------------------------------------------- -- labelorid is a public function to expose the output of labelOrId() -- Pass the Q-number as |qid= or as an unnamed parameter. -- It returns the Wikidata label for that entity or the qid if no label exists. ------------------------------------------------------------------------------- -- Dependencies: labelOrId ------------------------------------------------------------------------------- p.labelorid = function(frame) return (labelOrId(frame.args.qid or frame.args[1])) end ------------------------------------------------------------------------------- -- getLang returns the MediaWiki language code of the current content. -- If optional parameter |style=full, it returns the language name. ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- p.getLang = function(frame) local style = (frame.args.style or ""):lower() local langcode = mw.language.getContentLanguage().code if style == "full" then return mw.language.fetchLanguageName( langcode ) end return langcode end ------------------------------------------------------------------------------- -- getItemLangCode takes a qid parameter (using the current page's qid if blank) -- If the item for that qid has property country (P17) it looks at the first preferred value -- If the country has an official language (P37), it looks at the first preferred value -- If that official language has a language code (P424), it returns the first preferred value -- Otherwise it returns nothing. ------------------------------------------------------------------------------- -- Dependencies: _getItemLangCode() ------------------------------------------------------------------------------- p.getItemLangCode = function(frame) return _getItemLangCode(frame.args.qid or frame.args[1]) end ------------------------------------------------------------------------------- -- findLanguage exports the local findLang() function -- It takes an optional language code and returns, in order of preference: -- the code if a known language; -- the user's language, if set; -- the server's content language. ------------------------------------------------------------------------------- -- Dependencies: findLang ------------------------------------------------------------------------------- p.findLanguage = function(frame) return findLang(frame.args.lang or frame.args[1]).code end ------------------------------------------------------------------------------- -- getQid returns the qid, if supplied -- failing that, the Wikidata entity ID of the "category's main topic (P301)", if it exists -- failing that, the Wikidata entity ID associated with the current page, if it exists -- otherwise, nothing ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- p.getQid = function(frame) local qid = (frame.args.qid or ""):upper() -- check if a qid was passed; if so, return it: if qid ~= "" then return qid end -- check if there's a "category's main topic (P301)": qid = mw.wikibase.getEntityIdForCurrentPage() if qid then local prop301 = mw.wikibase.getBestStatements(qid, "P301") if prop301[1] then local mctid = prop301[1].mainsnak.datavalue.value.id if mctid then return mctid end end end -- otherwise return the page qid (if any) return qid end ------------------------------------------------------------------------------- -- followQid takes four optional parameters: qid, props, list and all. -- If qid is not given, it uses the qid for the connected page -- or returns nil if there isn't one. -- props is a list of properties, separated by punctuation. -- If props is given, the Wikidata item for the qid is examined for each property in turn. -- If that property contains a value that is another Wikibase-item, that item's qid is returned, -- and the search terminates, unless |all=y when all of the qids are returned, separated by spaces. -- If |list= is set to a template, the qids are passed as arguments to the template. -- If props is not given, the qid is returned. ------------------------------------------------------------------------------- -- Dependencies: parseParam() ------------------------------------------------------------------------------- p._followQid = function(args) local qid = (args.qid or ""):upper() local all = parseParam(args.all, false) local list = args.list or "" if list == "" then list = nil end if qid == "" then qid = mw.wikibase.getEntityIdForCurrentPage() end if not qid then return nil end local out = {} local props = (args.props or ""):upper() if props ~= "" then for p in mw.text.gsplit(props, "%p") do -- split at punctuation and iterate p = mw.text.trim(p) for i, v in ipairs( mw.wikibase.getBestStatements(qid, p) ) do local linkedid = v.mainsnak.datavalue and v.mainsnak.datavalue.value.id if linkedid then if all then out[#out+1] = linkedid else return linkedid end -- test for all or just the first one found end -- test for value exists for that property end -- loop through values of property to follow end -- loop through list of properties to follow end if #out > 0 then local ret = "" if list then ret = mw.getCurrentFrame():expandTemplate{title = list, args = out} else ret = table.concat(out, " ") end return ret else return qid end end p.followQid = function(frame) return p._followQid(frame.args) end ------------------------------------------------------------------------------- -- globalSiteID returns the globalSiteID for the current wiki -- e.g. returns "enwiki" for the English Wikipedia, "enwikisource" for English Wikisource, etc. ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- p.globalSiteID = function(frame) return mw.wikibase.getGlobalSiteId() end ------------------------------------------------------------------------------- -- siteID returns the root of the globalSiteID -- e.g. "en" for "enwiki", "enwikisource", etc. -- treats "en-gb" as "en", etc. ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- p.siteID = function(frame) local txtlang = frame:callParserFunction('int', {'lang'}) or "" -- This deals with specific exceptions: be-tarask -> be-x-old if txtlang == "be-tarask" then return "be_x_old" end local pos = txtlang:find("-") local ret = "" if pos then ret = txtlang:sub(1, pos-1) else ret = txtlang end return ret end ------------------------------------------------------------------------------- -- projID returns the code used to link to the reader's language's project -- e.g "en" for [[:en:WikidataIB]] -- treats "en-gb" as "en", etc. ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- p.projID = function(frame) local txtlang = frame:callParserFunction('int', {'lang'}) or "" -- This deals with specific exceptions: be-tarask -> be-x-old if txtlang == "be-tarask" then return "be-x-old" end local pos = txtlang:find("-") local ret = "" if pos then ret = txtlang:sub(1, pos-1) else ret = txtlang end return ret end ------------------------------------------------------------------------------- -- formatNumber formats a number according to the the supplied language code ("|lang=") -- or the default language if not supplied. -- The number is the first unnamed parameter or "|num=" ------------------------------------------------------------------------------- -- Dependencies: findLang() ------------------------------------------------------------------------------- p.formatNumber = function(frame) local lang local num = tonumber(frame.args[1] or frame.args.num) or 0 lang = findLang(frame.args.lang) return lang:formatNum( num ) end ------------------------------------------------------------------------------- -- examine dumps the property (the unnamed parameter or pid) -- from the item given by the parameter 'qid' (or the other unnamed parameter) -- or from the item corresponding to the current page if qid is not supplied. -- e.g. {{#invoke:WikidataIB |examine |pid=P26 |qid=Q42}} -- or {{#invoke:WikidataIB |examine |P26 |Q42}} or any combination of these -- or {{#invoke:WikidataIB |examine |P26}} for the current page. ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- p.examine = function( frame ) local args if frame.args[1] or frame.args.pid or frame.args.qid then args = frame.args else args = frame:getParent().args end local par = {} local pid = (args.pid or ""):upper() local qid = (args.qid or ""):upper() par[1] = mw.text.trim( args[1] or "" ):upper() par[2] = mw.text.trim( args[2] or "" ):upper() table.sort(par) if par[2]:sub(1,1) == "P" then par[1], par[2] = par[2], par[1] end if pid == "" then pid = par[1] end if qid == "" then qid = par[2] end local q1 = qid:sub(1,1) if pid:sub(1,1) ~= "P" then return "No property supplied" end if q1 ~= "Q" and q1 ~= "M" then qid = mw.wikibase.getEntityIdForCurrentPage() end if not qid then return "No item for this page" end return "<pre>" .. mw.dumpObject( mw.wikibase.getAllStatements( qid, pid ) ) .. "</pre>" end ------------------------------------------------------------------------------- -- checkvalue looks for 'val' as a wikibase-item value of a property (the unnamed parameter or pid) -- from the item given by the parameter 'qid' -- or from the Wikidata item associated with the current page if qid is not supplied. -- It only checks ranks that are requested (preferred and normal by default) -- If property is not supplied, then P31 (instance of) is assumed. -- It returns val if found or nothing if not found. -- e.g. {{#invoke:WikidataIB |checkvalue |val=Q5 |pid=P31 |qid=Q42}} -- or {{#invoke:WikidataIB |checkvalue |val=Q5 |P31 |qid=Q42}} -- or {{#invoke:WikidataIB |checkvalue |val=Q5 |qid=Q42}} -- or {{#invoke:WikidataIB |checkvalue |val=Q5 |P31}} for the current page. ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- p.checkvalue = function( frame ) local args if frame.args.val then args = frame.args else args = frame:getParent().args end local val = args.val if not val then return nil end local pid = mw.text.trim(args.pid or args[1] or "P31"):upper() local qid = (args.qid or ""):upper() if pid:sub(1,1) ~= "P" then return nil end if qid:sub(1,1) ~= "Q" then qid = mw.wikibase.getEntityIdForCurrentPage() end if not qid then return nil end local ranks = setRanks(args.rank) local stats = {} if ranks.b then stats = mw.wikibase.getBestStatements(qid, pid) else stats = mw.wikibase.getAllStatements( qid, pid ) end if not stats[1] then return nil end if stats[1].mainsnak.datatype == "wikibase-item" then for k, v in pairs( stats ) do local ms = v.mainsnak if ranks[v.rank:sub(1,1)] and ms.snaktype == "value" and ms.datavalue.value.id == val then return val end end end return nil end ------------------------------------------------------------------------------- -- url2 takes a parameter url= that is a proper url and formats it for use in an infobox. -- If no parameter is supplied, it returns nothing. -- This is the equivalent of Template:URL -- but it keeps the "edit at Wikidata" pen icon out of the microformat. -- Usually it will take its url parameter directly from a Wikidata call: -- e.g. {{#invoke:WikidataIB |url2 |url={{wdib |P856 |qid=Q23317 |fwd=ALL |osd=no}} }} ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- p.url2 = function(frame) local txt = frame.args.url or "" if txt == "" then return nil end -- extract any icon local url, icon = txt:match("(.+)&nbsp;(.+)") -- make sure there's at least a space at the end url = (url or txt) .. " " icon = icon or "" -- extract any protocol like https:// local prot = url:match("(https*://).+[ \"\']") -- extract address local addr = "" if prot then addr = url:match("https*://(.+)[ \"\']") or " " else prot = "//" addr = url:match("[^%p%s]+%.(.+)[ \"\']") or " " end -- strip trailing / from end of domain-only url and add <wbr/> before . and / local disp, n = addr:gsub( "^([^/]+)/$", "%1" ):gsub("%/", "<wbr/>/"):gsub("%.", "<wbr/>.") return '<span class="url">[' .. prot .. addr .. " " .. disp .. "]</span>&nbsp;" .. icon end ------------------------------------------------------------------------------- -- getWebsite fetches the Official website (P856) and formats it for use in an infobox. -- This is similar to Template:Official website but with a url displayed, -- and it adds the "edit at Wikidata" pen icon beyond the microformat if enabled. -- A local value will override the Wikidata value. "NONE" returns nothing. -- e.g. {{#invoke:WikidataIB |getWebsite |qid= |noicon= |lang= |url= }} ------------------------------------------------------------------------------- -- Dependencies: findLang(); parseParam(); ------------------------------------------------------------------------------- p.getWebsite = function(frame) local url = frame.args.url or "" if url:upper() == "NONE" then return nil end local urls = {} local quals = {} local qid = frame.args.qid or "" if url and url ~= "" then urls[1] = url else if qid == "" then qid = mw.wikibase.getEntityIdForCurrentPage() end if not qid then return nil end local prop856 = mw.wikibase.getBestStatements(qid, "P856") for k, v in pairs(prop856) do if v.mainsnak.snaktype == "value" then urls[#urls+1] = v.mainsnak.datavalue.value if v.qualifiers and v.qualifiers["P1065"] then -- just take the first archive url (P1065) local au = v.qualifiers["P1065"][1] if au.snaktype == "value" then quals[#urls] = au.datavalue.value end -- test for archive url having a value end -- test for qualifers end -- test for website having a value end -- loop through website(s) end if #urls == 0 then return nil end local out = {} for i, u in ipairs(urls) do local link = quals[i] or u local prot, addr = u:match("(http[s]*://)(.+)") addr = addr or u local disp, n = addr:gsub("%.", "<wbr/>%.") out[#out+1] = '<span class="url">[' .. link .. " " .. disp .. "]</span>" end local langcode = findLang(frame.args.lang).code local noicon = parseParam(frame.args.noicon, false) if url == "" and not noicon then out[#out] = out[#out] .. createicon(langcode, qid, "P856") end local ret = "" if #out > 1 then ret = mw.getCurrentFrame():expandTemplate{title = "ubl", args = out} else ret = out[1] end return ret end ------------------------------------------------------------------------------- -- getAllLabels fetches the set of labels and formats it for display as wikitext. -- It takes a parameter 'qid' for arbitrary access, otherwise it uses the current page. ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- p.getAllLabels = function(frame) local args = frame.args or frame:getParent().args or {} local qid = args.qid or "" if qid == "" then qid = mw.wikibase.getEntityIdForCurrentPage() end if not qid or not mw.wikibase.entityExists(qid) then return i18n["entity-not-found"] end local labels = mw.wikibase.getEntity(qid).labels if not labels then return i18n["labels-not-found"] end local out = {} for k, v in pairs(labels) do out[#out+1] = v.value .. " (" .. v.language .. ")" end return table.concat(out, "; ") end ------------------------------------------------------------------------------- -- getAllDescriptions fetches the set of descriptions and formats it for display as wikitext. -- It takes a parameter 'qid' for arbitrary access, otherwise it uses the current page. ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- p.getAllDescriptions = function(frame) local args = frame.args or frame:getParent().args or {} local qid = args.qid or "" if qid == "" then qid = mw.wikibase.getEntityIdForCurrentPage() end if not qid or not mw.wikibase.entityExists(qid) then return i18n["entity-not-found"] end local descriptions = mw.wikibase.getEntity(qid).descriptions if not descriptions then return i18n["descriptions-not-found"] end local out = {} for k, v in pairs(descriptions) do out[#out+1] = v.value .. " (" .. v.language .. ")" end return table.concat(out, "; ") end ------------------------------------------------------------------------------- -- getAllAliases fetches the set of aliases and formats it for display as wikitext. -- It takes a parameter 'qid' for arbitrary access, otherwise it uses the current page. ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- p.getAllAliases = function(frame) local args = frame.args or frame:getParent().args or {} local qid = args.qid or "" if qid == "" then qid = mw.wikibase.getEntityIdForCurrentPage() end if not qid or not mw.wikibase.entityExists(qid) then return i18n["entity-not-found"] end local aliases = mw.wikibase.getEntity(qid).aliases if not aliases then return i18n["aliases-not-found"] end local out = {} for k1, v1 in pairs(aliases) do local lang = v1[1].language local val = {} for k1, v2 in ipairs(v1) do val[#val+1] = v2.value end out[#out+1] = table.concat(val, ", ") .. " (" .. lang .. ")" end return table.concat(out, "; ") end ------------------------------------------------------------------------------- -- showNoLinks displays the article titles that should not be linked. ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- p.showNoLinks = function(frame) local out = {} for k, v in pairs(donotlink) do out[#out+1] = k end table.sort( out ) return table.concat(out, "; ") end ------------------------------------------------------------------------------- -- checkValidity checks whether the first unnamed parameter represents a valid entity-id, -- that is, something like Q1235 or P123. -- It returns the strings "true" or "false". -- Change false to nil to return "true" or "" (easier to test with #if:). ------------------------------------------------------------------------------- -- Dependencies: none ------------------------------------------------------------------------------- function p.checkValidity(frame) local id = mw.text.trim(frame.args[1] or "") if mw.wikibase.isValidEntityId(id) then return true else return false end end ------------------------------------------------------------------------------- -- getEntityFromTitle returns the Entity-ID (Q-number) for a given title. -- Modification of Module:ResolveEntityId -- The title is the first unnamed parameter. -- The site parameter determines the site/language for the title. Defaults to current wiki. -- The showdab parameter determines whether dab pages should return the Q-number or nil. Defaults to true. -- Returns the Q-number or nil if it does not exist. ------------------------------------------------------------------------------- -- Dependencies: parseParam ------------------------------------------------------------------------------- function p.getEntityFromTitle(frame) local args=frame.args if not args[1] then args=frame:getParent().args end if not args[1] then return nil end local title = mw.text.trim(args[1]) local site = args.site or "" local showdab = parseParam(args.showdab, true) local qid = mw.wikibase.getEntityIdForTitle(title, site) if qid then local prop31 = mw.wikibase.getBestStatements(qid, "P31")[1] if not showdab and prop31 and prop31.mainsnak.datavalue.value.id == "Q4167410" then return nil else return qid end end end ------------------------------------------------------------------------------- -- getDatePrecision returns the number representing the precision of the first best date value -- for the given property. -- It takes the qid and property ID -- The meanings are given at https://www.mediawiki.org/wiki/Wikibase/DataModel#Dates_and_times -- 0 = 1 billion years .. 6 = millennium, 7 = century, 8 = decade, 9 = year, 10 = month, 11 = day -- Returns 0 (or the second unnamed parameter) if the Wikidata does not exist. ------------------------------------------------------------------------------- -- Dependencies: parseParam; sourced; ------------------------------------------------------------------------------- function p.getDatePrecision(frame) local args=frame.args if not args[1] then args=frame:getParent().args end local default = tonumber(args[2] or args.default) or 0 local prop = mw.text.trim(args[1] or "") if prop == "" then return default end local qid = args.qid or "" if qid == "" then qid = mw.wikibase.getEntityIdForCurrentPage() end if not qid then return default end local onlysrc = parseParam(args.onlysourced or args.osd, true) local stat = mw.wikibase.getBestStatements(qid, prop) for i, v in ipairs(stat) do local prec = (onlysrc == false or sourced(v)) and v.mainsnak.datavalue and v.mainsnak.datavalue.value and v.mainsnak.datavalue.value.precision if prec then return prec end end return default end return p ------------------------------------------------------------------------------- -- List of exported functions ------------------------------------------------------------------------------- --[[ _getValue getValue getPreferredValue getCoords getQualifierValue getSumOfParts getValueByQual getValueByLang getValueByRefSource getPropertyIDs getQualifierIDs getPropOfProp getAwardCat getIntersectCat getGlobe getCommonsLink getSiteLink getLink getLabel label getAT getDescription getAliases pageId formatDate location checkBlacklist emptyor labelorid getLang getItemLangCode findLanguage getQID followQid globalSiteID siteID projID formatNumber examine checkvalue url2 getWebsite getAllLabels getAllDescriptions getAllAliases showNoLinks checkValidity getEntityFromTitle getDatePrecision --]] ------------------------------------------------------------------------------- </pre> <!-- NewPP limit report Parsed by mw‐web.codfw.main‐f69cdc8f6‐v45bm Cached time: 20241124044149 Cache expiry: 2592000 Reduced expiry: false Complications: [vary‐revision‐sha1, show‐toc] CPU time usage: 0.570 seconds Real time usage: 0.803 seconds Preprocessor visited node count: 4609/1000000 Post‐expand include size: 223669/2097152 bytes Template argument size: 6749/2097152 bytes Highest expansion depth: 20/100 Expensive parser function count: 8/500 Unstrip recursion depth: 0/20 Unstrip post‐expand size: 22811/5000000 bytes Lua time usage: 0.374/10.000 seconds Lua memory usage: 5336596/52428800 bytes Number of Wikibase entities loaded: 16/400 --> <!-- Transclusion expansion time report (%,ms,calls,template) 100.00% 643.173 1 -total 100.00% 643.173 1 Module:WikidataIB/doc 22.11% 142.176 40 Template:Q 12.80% 82.355 9 Template:Nowiki_template_demo 11.95% 76.836 1 Template:Wikidata_infoboxes 11.40% 73.340 1 Template:Navbox 3.77% 24.271 1 Template:Module_rating 3.55% 22.810 2 Template:Ombox 3.39% 21.805 3 Template:URL 3.15% 20.251 2 Template:Wikidata --> </div><!--esi <esi:include src="/esitest-fa8a495983347898/content" /> --><noscript><img src="https://login.wikimedia.org/wiki/Special:CentralAutoLogin/start?type=1x1" alt="" width="1" height="1" style="border: none; position: absolute;"></noscript> <div class="printfooter" data-nosnippet="">Retrieved from "<a dir="ltr" href="https://en.wikipedia.org/w/index.php?title=Module:WikidataIB/sandbox&oldid=1164674032">https://en.wikipedia.org/w/index.php?title=Module:WikidataIB/sandbox&oldid=1164674032</a>"</div></div> <div id="catlinks" class="catlinks" data-mw="interface"><div id="mw-normal-catlinks" class="mw-normal-catlinks"><a href="/wiki/Help:Category" title="Help:Category">Category</a>: <ul><li><a href="/wiki/Category:Module_sandboxes" title="Category:Module sandboxes">Module sandboxes</a></li></ul></div><div id="mw-hidden-catlinks" class="mw-hidden-catlinks mw-hidden-cats-hidden">Hidden category: <ul><li><a href="/wiki/Category:Test_cases_using_output_parameter" title="Category:Test cases using output parameter">Test cases using output parameter</a></li></ul></div></div> </div> </main> </div> <div class="mw-footer-container"> <footer id="footer" class="mw-footer" > <ul id="footer-info"> <li id="footer-info-lastmod"> This page was last edited on 10 July 2023, at 11:53<span class="anonymous-show"> (UTC)</span>.</li> <li id="footer-info-copyright">Text is available under the <a href="/wiki/Wikipedia:Text_of_the_Creative_Commons_Attribution-ShareAlike_4.0_International_License" title="Wikipedia:Text of the Creative Commons Attribution-ShareAlike 4.0 International License">Creative Commons Attribution-ShareAlike 4.0 License</a>; additional terms may apply. By using this site, you agree to the <a href="https://foundation.wikimedia.org/wiki/Special:MyLanguage/Policy:Terms_of_Use" class="extiw" title="foundation:Special:MyLanguage/Policy:Terms of Use">Terms of Use</a> and <a href="https://foundation.wikimedia.org/wiki/Special:MyLanguage/Policy:Privacy_policy" class="extiw" title="foundation:Special:MyLanguage/Policy:Privacy policy">Privacy Policy</a>. Wikipedia® is a registered trademark of the <a rel="nofollow" class="external text" href="https://wikimediafoundation.org/">Wikimedia Foundation, Inc.</a>, a non-profit organization.</li> </ul> <ul id="footer-places"> <li id="footer-places-privacy"><a href="https://foundation.wikimedia.org/wiki/Special:MyLanguage/Policy:Privacy_policy">Privacy policy</a></li> <li id="footer-places-about"><a href="/wiki/Wikipedia:About">About Wikipedia</a></li> <li id="footer-places-disclaimers"><a href="/wiki/Wikipedia:General_disclaimer">Disclaimers</a></li> <li id="footer-places-contact"><a href="//en.wikipedia.org/wiki/Wikipedia:Contact_us">Contact Wikipedia</a></li> <li id="footer-places-wm-codeofconduct"><a href="https://foundation.wikimedia.org/wiki/Special:MyLanguage/Policy:Universal_Code_of_Conduct">Code of Conduct</a></li> <li id="footer-places-developers"><a href="https://developer.wikimedia.org">Developers</a></li> <li id="footer-places-statslink"><a href="https://stats.wikimedia.org/#/en.wikipedia.org">Statistics</a></li> <li id="footer-places-cookiestatement"><a href="https://foundation.wikimedia.org/wiki/Special:MyLanguage/Policy:Cookie_statement">Cookie statement</a></li> <li id="footer-places-mobileview"><a href="//en.m.wikipedia.org/w/index.php?title=Module:WikidataIB/sandbox&mobileaction=toggle_view_mobile" class="noprint stopMobileRedirectToggle">Mobile view</a></li> </ul> <ul id="footer-icons" class="noprint"> <li id="footer-copyrightico"><a href="https://wikimediafoundation.org/" class="cdx-button cdx-button--fake-button cdx-button--size-large cdx-button--fake-button--enabled"><img src="/static/images/footer/wikimedia-button.svg" width="84" height="29" alt="Wikimedia Foundation" loading="lazy"></a></li> <li id="footer-poweredbyico"><a href="https://www.mediawiki.org/" class="cdx-button cdx-button--fake-button cdx-button--size-large cdx-button--fake-button--enabled"><img src="/w/resources/assets/poweredby_mediawiki.svg" alt="Powered by MediaWiki" width="88" height="31" loading="lazy"></a></li> </ul> </footer> </div> </div> </div> <div class="vector-settings" id="p-dock-bottom"> <ul></ul> </div><script>(RLQ=window.RLQ||[]).push(function(){mw.config.set({"wgHostname":"mw-web.codfw.main-f69cdc8f6-v45bm","wgBackendResponseTime":953,"wgPageParseReport":{"limitreport":{"cputime":"0.570","walltime":"0.803","ppvisitednodes":{"value":4609,"limit":1000000},"postexpandincludesize":{"value":223669,"limit":2097152},"templateargumentsize":{"value":6749,"limit":2097152},"expansiondepth":{"value":20,"limit":100},"expensivefunctioncount":{"value":8,"limit":500},"unstrip-depth":{"value":0,"limit":20},"unstrip-size":{"value":22811,"limit":5000000},"entityaccesscount":{"value":16,"limit":400},"timingprofile":["100.00% 643.173 1 -total","100.00% 643.173 1 Module:WikidataIB/doc"," 22.11% 142.176 40 Template:Q"," 12.80% 82.355 9 Template:Nowiki_template_demo"," 11.95% 76.836 1 Template:Wikidata_infoboxes"," 11.40% 73.340 1 Template:Navbox"," 3.77% 24.271 1 Template:Module_rating"," 3.55% 22.810 2 Template:Ombox"," 3.39% 21.805 3 Template:URL"," 3.15% 20.251 2 Template:Wikidata"]},"scribunto":{"limitreport-timeusage":{"value":"0.374","limit":"10.000"},"limitreport-memusage":{"value":5336596,"limit":52428800},"limitreport-logs":"table#1 {\n table#2 {\n [\"requireMagicWord\"] = false,\n [\"title\"] = Module:WikidataIB,\n },\n}\ntable#1 {\n table#2 {\n [\"requireMagicWord\"] = false,\n [\"title\"] = Module:WikidataIB,\n },\n}\ntable#1 {\n table#2 {\n [\"requireMagicWord\"] = false,\n [\"title\"] = Module:WikidataIB,\n },\n}\ntable#1 {\n table#2 {\n [\"requireMagicWord\"] = false,\n [\"title\"] = Module:WikidataIB,\n },\n}\ntable#1 {\n table#2 {\n [\"requireMagicWord\"] = false,\n [\"title\"] = Module:WikidataIB,\n },\n}\ntable#1 {\n table#2 {\n [\"requireMagicWord\"] = false,\n [\"title\"] = Module:WikidataIB,\n },\n}\ntable#1 {\n table#2 {\n [\"requireMagicWord\"] = false,\n [\"title\"] = Module:WikidataIB,\n },\n}\ntable#1 {\n table#2 {\n [\"requireMagicWord\"] = false,\n [\"title\"] = Module:WikidataIB,\n },\n}\ntable#1 {\n table#2 {\n [\"requireMagicWord\"] = false,\n [\"title\"] = Module:WikidataIB,\n },\n}\n"},"cachereport":{"origin":"mw-web.codfw.main-f69cdc8f6-v45bm","timestamp":"20241124044149","ttl":2592000,"transientcontent":false}}});});</script> </body> </html>