בדוקי עריכות אוטומטית, אינטערפעיס רעדאקטארן, אינטערפעיס אדמיניסטראַטאָרן, סיסאפן, מייבאים, מעדכנים, מייבא, אספקלריה רעדאקטארן
46,726
רעדאגירונגען
ק (rv) |
(אפדעיט) |
||
| (28 מיטלסטע ווערסיעס פון 6 באַניצער נישט געוויזן.) | |||
| שורה 1: | שורה 1: | ||
local propertyLink = require('Module:PropertyLink') | local propertyLink = require('Module:PropertyLink') | ||
local WikidataCrossValidation = require('Module:WikidataCrossValidation') | |||
local Infobox = {} | local Infobox = {} | ||
function Infobox:new() | function Infobox:new() | ||
| שורה 22: | שורה 22: | ||
for k,v in pairs(self.templateParams) do | for k,v in pairs(self.templateParams) do | ||
if mw.ustring.match( k, '-ויקינתונים') then | if mw.ustring.match( k, '-ויקינתונים') then | ||
templateDocumentation = templateDocumentation .. '[[קאַטעגאָריע: | templateDocumentation = templateDocumentation .. '[[קאַטעגאָריע:תבניות מידע שמשתמשות בוויקינתונים]]' | ||
break | break | ||
end | end | ||
| שורה 63: | שורה 63: | ||
local titleCaption = self.root | local titleCaption = self.root | ||
:tag('caption') | :tag('caption') | ||
:attr('dir', 'auto') | |||
:addClass(self.args.titleclass) | :addClass(self.args.titleclass) | ||
:cssText(self.args.titlestyle) | :cssText(self.args.titlestyle) | ||
| שורה 101: | שורה 102: | ||
row:tag('table') | row:tag('table') | ||
:css('width','100%') | :css('width','100%') | ||
:css('display','table') | |||
:tag('tr') | :tag('tr') | ||
:tag('td') | :tag('td') | ||
| שורה 138: | שורה 140: | ||
--[[ | --[[ | ||
Adds edit links for easier editing of the template. If the template | Adds edit links for easier editing of the template. If the template use data from wikidata it also adds edit link in Wikidata | ||
]] | ]] | ||
function Infobox:renderEditLinks() | function Infobox:renderEditLinks() | ||
end | end | ||
| שורה 188: | שורה 178: | ||
:tag('th') | :tag('th') | ||
:attr('scope', 'row') | :attr('scope', 'row') | ||
:addClass('infobox-label') | |||
:attr('id', rowArgs.labelid) | :attr('id', rowArgs.labelid) | ||
:cssText(self.args.labelstyle) | :cssText(self.args.labelstyle) | ||
:cssText(rowArgs.labelstyle) | :cssText(rowArgs.labelstyle) | ||
| שורה 217: | שורה 207: | ||
--[[ | --[[ | ||
This function removes | This function removes redundent keys from templateStructure: nil entries and header entries with no data | ||
]] | ]] | ||
function Infobox:removeEmptyHeaders() | function Infobox:removeEmptyHeaders() | ||
local lastHeaderIndex=nil | local lastHeaderIndex=nil | ||
local | |||
local hasImage = (self.args.image~=nil and #self.args.image>0) | |||
hasImage = hasImage or (self.args.rightImage~=nil and #self.args.rightImage>0) | |||
hasImage = hasImage or (self.args.leftImage~=nil and #self.args.leftImage>0) | |||
local removeFirstHeader = nil | |||
if self.args.removeFirstHeader~=nil then | |||
removeFirstHeader = (not hasImage) and self.args.removeFirstHeader -- remove the first header if there are no images & the first header is generic | |||
else | |||
removeFirstHeader = (not hasImage)-- default, remove the first header if there are no images | |||
end | |||
local tempTemplateStructure = {} | local tempTemplateStructure = {} | ||
for i,v in pairs(self.templateStructure) do | for i,v in pairs(self.templateStructure) do | ||
| שורה 231: | שורה 231: | ||
if lastHeaderIndex then | if lastHeaderIndex then | ||
if not removeFirstHeader then | if not removeFirstHeader then | ||
table.insert(tempTemplateStructure, self.templateStructure[lastHeaderIndex]) | -- skip headers that are only spaces/nowiki - marking structure seperation | ||
local headerData =mw.text.unstripNoWiki( self.templateStructure[lastHeaderIndex].data ) | |||
local headerDataNoSpace = mw.ustring.gsub(headerData, "%s", "") | |||
if #headerDataNoSpace >0 then | |||
table.insert(tempTemplateStructure, self.templateStructure[lastHeaderIndex]) | |||
end | |||
end | end | ||
lastHeaderIndex = nil | lastHeaderIndex = nil | ||
| שורה 248: | שורה 253: | ||
function Infobox:renderInfobox() | function Infobox:renderInfobox() | ||
self:removeEmptyHeaders() | self:removeEmptyHeaders() | ||
-- sub infobox | -- sub infobox | ||
| שורה 297: | שורה 285: | ||
This function adds image using valueArg, or if not specified by the user tries to get image from wikidata using property | This function adds image using valueArg, or if not specified by the user tries to get image from wikidata using property | ||
]] | ]] | ||
function getValueOrWikidataImage(valueArg | function getValueOrWikidataImage(args) | ||
valueArg = args.valueArg | |||
if valueArg and #valueArg>0 then | if valueArg and #valueArg>0 then | ||
if valueArg == '-' then | if valueArg == '-' then | ||
return nil | return nil | ||
else | else | ||
if | -- wrap with wikisyntax if only filename provided. avoid that in case of tags or wikisyntaxed files | ||
not mw.ustring.match(valueArg, ' | if not mw.ustring.match(valueArg, '%[%[') and | ||
not mw.ustring.match(valueArg, '<') then | |||
local imgSuffix = '| | local imgSuffix = '|'..args.width .. 'px' | ||
if imgDesc~=nil and #imgDesc>0 then | if args.imgDesc~=nil and #args.imgDesc>0 then | ||
imgSuffix = imgSuffix .. '|' .. imgDesc | imgSuffix = imgSuffix .. '|' .. args.imgDesc | ||
end | end | ||
imgSuffix = imgSuffix .. ']]' | imgSuffix = imgSuffix .. ']]' | ||
if mw.ustring.match(valueArg, '^[Ff]ile:') or | if mw.ustring.match(valueArg, '^[Ff]ile:') or | ||
mw.ustring.match(valueArg, '^[Ii]mage:') or | mw.ustring.match(valueArg, '^[Ii]mage:') or | ||
mw.ustring.match(valueArg, '^קובץ:') or | |||
mw.ustring.match(valueArg, '^טעקע:') or | mw.ustring.match(valueArg, '^טעקע:') or | ||
mw.ustring.match(valueArg, '^תמונה:') then | mw.ustring.match(valueArg, '^תמונה:') then | ||
valueArg = '[[' .. valueArg .. imgSuffix | valueArg = '[[' .. valueArg .. imgSuffix | ||
else | else | ||
valueArg = '[[File:' .. valueArg .. imgSuffix | valueArg = '[[File:' .. valueArg .. imgSuffix | ||
end | |||
elseif args.imgDesc~=nil and #args.imgDesc>0 and not mw.ustring.match(args.imgDesc, '%[%[קאַטעגאָריע:ערכים להחלפת תמונה בחופשית%]%]$') then | |||
if mw.ustring.match(valueArg, '^ *%[%[[Ff]ile:') or | |||
mw.ustring.match(valueArg, '^ *%[%[[Ii]mage:') or | |||
mw.ustring.match(valueArg, '^ *%[%[קובץ:') or | |||
mw.ustring.match(valueArg, '^ *%[%[טעקע:') or | |||
mw.ustring.match(valueArg, '^ *%[%[תמונה:') then | |||
valueArg = mw.ustring.gsub(valueArg, "%]%]$", "") | |||
local imgSuffix = '|' .. args.imgDesc .. ']]' | |||
valueArg = valueArg .. imgSuffix | |||
end | end | ||
end | end | ||
return valueArg | return valueArg, args.imgDesc | ||
end | end | ||
end | end | ||
if wikidataArg then | if args.wikidataArg and args.args.entityId~=nil then | ||
return propertyLink.getImageLink(wikidataArg, width) | args.args.usingWikidata = true | ||
return propertyLink.getImageLink(args.wikidataArg, args.width, nil, nil,nil, args.args.entityId) | |||
end | end | ||
return '' | return '' | ||
| שורה 330: | שורה 330: | ||
end | end | ||
--[[ | |||
Split category links from value, return tuple of whether data exists and maitainance cats in case no data exists | |||
]] | |||
function splitMaintainceCategory(value) | function splitMaintainceCategory(value) | ||
local maintainceCats = nil | local maintainceCats = nil | ||
local hasData = #(mw.ustring.gsub(value, '%[%[ | local hasData = #(mw.ustring.gsub(value, '%[%[קאַטעגאָריע:.-%]%]', ''))>0 | ||
if not hasData then | if not hasData then | ||
maintainceCats = value | maintainceCats = value | ||
| שורה 343: | שורה 346: | ||
return nil | return nil | ||
end | end | ||
local res = propertyLink.getPropertyByOptions(propertyName, entityId, options) | local res = propertyLink.getPropertyByOptions(propertyName, entityId, options) | ||
if res then | if (res==nil) or (#res == 0) then | ||
local | return nil | ||
end | |||
res = | local hasData, maintainceCats = splitMaintainceCategory(res) | ||
if hasData then | |||
if options['formatter'] then | |||
res = options['formatter'](res) | |||
end | end | ||
local link = mw.title.makeTitle( 0, entityId, propertyName, 'wikidata' ):fullUrl('uselang=he') | |||
res = res .. mw.ustring.format(' [[File:Blue pencil RTL.svg|15px|link=%s|עריכת הנתון בוויקינתונים]]', link) | |||
end | end | ||
return res | return res | ||
end | |||
--[[ | |||
Filters statements to statements with existing links only | |||
]] | |||
function filterExists( propertyVals ) | |||
local tempVals = {} | |||
for i, property in ipairs(propertyVals) do | |||
local propValue = property.mainsnak and property.mainsnak.datavalue | |||
if propValue and propValue.value then | |||
local linkTarget = mw.wikibase.sitelink( propValue.value['id'] ) | |||
if linkTarget then | |||
table.insert(tempVals, property) | |||
end | |||
end | |||
end | |||
return tempVals | |||
end | end | ||
| שורה 363: | שורה 389: | ||
local hasData=false | local hasData=false | ||
local maintainceCats = nil | local maintainceCats = nil | ||
local includeWikidataRef = frame and frame:getParent() | local includeWikidataRef = frame and frame:getParent() | ||
if entityId == nil then return inWikidata, maintainceCats end -- early terminate | |||
includeWikidataRef = includeWikidataRef and includeWikidataRef.args and includeWikidataRef.args['ויקינתונים-מקורות'] == 'כן' | includeWikidataRef = includeWikidataRef and includeWikidataRef.args and includeWikidataRef.args['ויקינתונים-מקורות'] == 'כן' | ||
local wikidataOptions = { | local wikidataOptions = { | ||
['entity-gender-aware'] = templateParams[missingParam..'-ויקינתונים-מגדר'] == 'כן', | ['entity-gender-aware'] = templateParams[missingParam..'-ויקינתונים-מגדר'] == 'כן', | ||
['source'] = includeWikidataRef | ['source'] = includeWikidataRef | ||
} | } | ||
if templateParams[missingParam..'-ויקינתונים-סינון'] == 'קיים' then | |||
wikidataOptions['filter'] = filterExists | |||
elseif templateParams[missingParam..'-ויקינתונים-סינון'] and mw.ustring.match(templateParams[missingParam..'-ויקינתונים-סינון'], 'filter[a-zA-Z]+') then | |||
local moduleTitle = mw.ustring.match( frame:getParent():getTitle(), 'מוסטער:(.+)' ) | |||
moduleTitle = mw.ustring.format('יחידה:%s', moduleTitle) | |||
local filterFunc = mw.ustring.match(templateParams[missingParam..'-ויקינתונים-סינון'],'filter[a-zA-Z]+') | |||
wikidataOptions['filter'] = require(moduleTitle)[filterFunc] | |||
end | |||
if templateParams[missingParam..'-ויקינתונים-עיצוב'] and mw.ustring.match(templateParams[missingParam..'-ויקינתונים-עיצוב'], '[a-zA-Z]+') then | |||
local moduleTitle = mw.ustring.match( frame:getParent():getTitle(), 'מוסטער:(.+)' ) | |||
moduleTitle = mw.ustring.format('יחידה:%s', moduleTitle) | |||
local formatFunc = templateParams[missingParam..'-ויקינתונים-עיצוב'] | |||
wikidataOptions['formatter'] = require(moduleTitle)[formatFunc] | |||
end | |||
if templateParams[missingParam..'-ויקינתונים-פרטים']~=nil then | |||
wikidataOptions['qualifiers'] = {} | |||
wikidataOptions['qualifiers-sep'] = templateParams[missingParam..'-ויקינתונים-פרטים-הפרדה'] or nil | |||
for v in string.gmatch(templateParams[missingParam..'-ויקינתונים-פרטים'], "[^,%s]+") do | |||
table.insert(wikidataOptions['qualifiers'], v) | |||
end | |||
wikidataOptions['default-value'] = templateParams[missingParam..'-ויקינתונים-פרטים-ברירת מחדל'] or nil | |||
end | |||
if templateParams[missingParam..'-ויקינתונים-תמונה-גודל']~=nil then | if templateParams[missingParam..'-ויקינתונים-תמונה-גודל']~=nil then | ||
wikidataOptions['img-width'] = templateParams[missingParam..'-ויקינתונים-תמונה-גודל'] | wikidataOptions['img-width'] = templateParams[missingParam..'-ויקינתונים-תמונה-גודל'] | ||
end | end | ||
if templateParams[missingParam..'-ויקינתונים'] then | if templateParams[missingParam..'-ויקינתונים'] then | ||
templateArg.data = getPropertyByOptions(templateParams[missingParam..'-ויקינתונים'], entityId, wikidataOptions) or nil | if templateParams[missingParam..'-ויקינתונים-יחידה'] then | ||
templateArg.data = require('Module:Convert').convert(mw.getCurrentFrame():newChild{ args = { | |||
['input'] = templateParams[missingParam..'-ויקינתונים'], | |||
[2] = templateParams[missingParam..'-ויקינתונים-יחידה'], | |||
['disp'] = 'out', | |||
['qid'] = entityId, | |||
['abbr']='off' | |||
} }:newChild{}) | |||
else | |||
templateArg.data = getPropertyByOptions(templateParams[missingParam..'-ויקינתונים'], entityId, wikidataOptions) or nil | |||
end | |||
inWikidata = templateArg.data and #(templateArg.data)>0 | inWikidata = templateArg.data and #(templateArg.data)>0 | ||
elseif templateParams[missingParam..'-ויקינתונים-מרובה'] then | elseif templateParams[missingParam..'-ויקינתונים-מרובה'] then | ||
wikidataOptions['allowMulti'] = true | wikidataOptions['allowMulti'] = true | ||
wikidataOptions['seperator'] = templateParams[missingParam..'-ויקינתונים-מרובה-הפרדה'] | wikidataOptions['seperator'] = templateParams[missingParam..'-ויקינתונים-מרובה-הפרדה'] | ||
wikidataOptions['sort'] = { templateParams[missingParam..'-ויקינתונים-מרובה-מיון'] } or nil | |||
if templateParams[missingParam..'-ויקינתונים-מרובה-מיון-יורד'] then | |||
wikidataOptions['sort-order'] = 'desc' | |||
end | |||
paramsData = {} | |||
-- split multiple params to include all of them (e.g: "P1,P2") | |||
for paramToFetch in string.gmatch(templateParams[missingParam..'-ויקינתונים-מרובה'], '([^,]+)') do | |||
-- split optional params to include ONLY the first one of them (e.g: "P1/P2") | |||
for optionalParam in string.gmatch(paramToFetch, '([^/]+)') do | |||
if (string.sub(optionalParam, 1, 1) == 'P' or string.sub(optionalParam, 1, 1) == 'Q') then | |||
if getPropertyByOptions(optionalParam, entityId, wikidataOptions) then | |||
table.insert(paramsData, getPropertyByOptions(optionalParam, entityId, wikidataOptions) or nil) | |||
-- found one of the optionals - stop the loop | |||
break | |||
end | |||
else | |||
-- one of the optionals is static data - take it and stop the loop | |||
table.insert(paramsData, optionalParam) | |||
break | |||
end | |||
end | |||
end | |||
if wikidataOptions['seperator'] == '*' and #paramsData>1 then | |||
templateArg.data = '*' .. table.concat( paramsData, '\n*' ) | |||
else | |||
templateArg.data = table.concat(paramsData, wikidataOptions['seperator']) | |||
end | |||
inWikidata = templateArg.data and #(templateArg.data)>0 | inWikidata = templateArg.data and #(templateArg.data)>0 | ||
elseif templateParams[missingParam..'-ויקינתונים-פשוט'] then | elseif templateParams[missingParam..'-ויקינתונים-פשוט'] then | ||
| שורה 387: | שורה 473: | ||
local wikidataParamValue = propertyLink.getLabel(templateParams[missingParam..'-ויקינתונים-פשוט'], entityId) | local wikidataParamValue = propertyLink.getLabel(templateParams[missingParam..'-ויקינתונים-פשוט'], entityId) | ||
if wikidataParamValue and #wikidataParamValue>0 then | if wikidataParamValue and #wikidataParamValue>0 then | ||
templateArg.data = frame:preprocess(mw.ustring.gsub(templateArg.data, ' | templateArg.data = frame:preprocess(mw.ustring.gsub(templateArg.data, '{{{('..missingParam..')}}}', wikidataParamValue)) | ||
inWikidata = true | inWikidata = true | ||
end | end | ||
-- special cases | -- special cases | ||
elseif missingParam == 'קואורדינטות' then | elseif missingParam == 'קואורדינטות' then | ||
templateArg.data = propertyLink.getPropertyByOptions('P625', entityId, {['coord-display'] = 'title,inline' }) | |||
templateArg.data = propertyLink.getPropertyByOptions('P625', entityId, {['coord-display'] = templateParams['קואורדינטות-תצוגה'] or 'title,inline' }) | |||
inWikidata = templateArg.data and #(templateArg.data)>0 | inWikidata = templateArg.data and #(templateArg.data)>0 | ||
elseif missingParam == 'מפה' and templateParams['מפה-זום'] then | elseif missingParam == 'מפה' and templateParams['מפה-זום'] then | ||
| שורה 398: | שורה 485: | ||
if inWikidata then | if inWikidata then | ||
local defaultZoom = templateParams['מפה-זום'] | local defaultZoom = templateParams['מפה-זום'] | ||
templateArg.data = frame:expandTemplate{ title = 'מפה דינמית', args = { | templateArg.data = frame:expandTemplate{ title = 'מפה דינמית', args = { | ||
['יישור'] = 'center', | ['יישור'] = 'center', | ||
['זום ברירת מחדל'] = defaultZoom | ['זום ברירת מחדל'] = defaultZoom, | ||
['פריטים'] = entityId | |||
} } | } } | ||
end | end | ||
| שורה 415: | שורה 502: | ||
return inWikidata, maintainceCats | return inWikidata, maintainceCats | ||
end | end | ||
--[[ | --[[ | ||
This function fills missing parameter using wikidata | This function fills missing parameter using wikidata | ||
]] | ]] | ||
function crossValidateWikidata(missingParam, templateParams, templateArg, frame | function crossValidateWikidata(missingParam, templateParams, templateArg, frame, entityId) | ||
local matching = nil | local matching = nil | ||
local propertyName | local propertyName | ||
if missingParam==nil then | |||
if entityId == nil or missingParam==nil then | |||
return nil | return nil | ||
end | end | ||
if templateParams[missingParam..'-ויקינתונים'] then | if templateParams[missingParam..'-ויקינתונים'] then | ||
propertyName = templateParams[missingParam..'-ויקינתונים'] | propertyName = templateParams[missingParam..'-ויקינתונים'] | ||
matching = WikidataCrossValidation.crossValidate(templateArg, propertyName) | matching = WikidataCrossValidation.crossValidate(templateArg, propertyName, entityId) | ||
elseif templateParams[missingParam..'-ויקינתונים-פשוט'] then | elseif templateParams[missingParam..'-ויקינתונים-פשוט'] then | ||
propertyName = templateParams[missingParam..'-ויקינתונים-פשוט'] | propertyName = templateParams[missingParam..'-ויקינתונים-פשוט'] | ||
matching = WikidataCrossValidation.crossValidate(templateArg, propertyName) | matching = WikidataCrossValidation.crossValidate(templateArg, propertyName, entityId) | ||
elseif templateParams[missingParam..'-ויקינתונים-מרובה'] then | elseif templateParams[missingParam..'-ויקינתונים-מרובה'] then | ||
local genderAware = templateParams[missingParam..'-ויקינתונים-מגדר'] == 'כן' | local genderAware = templateParams[missingParam..'-ויקינתונים-מגדר'] == 'כן' | ||
propertyName = templateParams[missingParam..'-ויקינתונים-מרובה'] | propertyName = templateParams[missingParam..'-ויקינתונים-מרובה'] | ||
matching = WikidataCrossValidation.crossValidate(templateArg, propertyName) | matching = WikidataCrossValidation.crossValidate(templateArg, propertyName, entityId) | ||
end | end | ||
| שורה 449: | שורה 534: | ||
]] | ]] | ||
function standardTitle(templateArgs, isSubTemplate, entityId) | function standardTitle(templateArgs, isSubTemplate, entityId) | ||
local name = templateArgs['נאמען'] | local name = templateArgs['שם'] or templateArgs['נאמען'] | ||
if name=='-' then return name end -- | if name=='-' then return name end -- | ||
if isSubTemplate then return name or '' end | if isSubTemplate then return name or '' end | ||
| שורה 458: | שורה 543: | ||
end | end | ||
local originName = templateArgs[' | local originName = templateArgs['שם בשפת המקור'] | ||
if originName == '-' then | if originName == '-' then | ||
originName = '' | originName = '' | ||
| שורה 468: | שורה 553: | ||
if #propertyVals == 0 then propertyVals = mw.wikibase.getBestStatements(entityId, 'P1559') end | if #propertyVals == 0 then propertyVals = mw.wikibase.getBestStatements(entityId, 'P1559') end | ||
if #propertyVals > 0 then | if #propertyVals > 0 then | ||
local propValue = | for _,propertyVal in pairs(propertyVals) do | ||
local propValue = propertyVal.mainsnak and propertyVal.mainsnak.datavalue | |||
-- by convention we pick single origin name | |||
if propValue and propValue.value and propValue.value.text and propValue.value.text~=name and not originName then | |||
originName = mw.ustring.format('<span lang="%s" title="%s">%s</span>', propValue.value.language, | |||
mw.language.fetchLanguageName( propValue.value.language , 'he'), propValue.value.text) | |||
end | |||
end | |||
end | end | ||
end | end | ||
if originName and #originName and originName~=name then | if originName and #originName and originName~=name then | ||
name = name..'<br>'..originName | name = name..'<br>'..originName | ||
| שורה 491: | שורה 577: | ||
local templateStructure = {} | local templateStructure = {} | ||
args.subtemplate = frame.args['תת-תבנית'] | args.subtemplate = frame.args['תת-תבנית'] | ||
args.entityId = templateArgs['qid'] or | if (templateArgs['qid'] ~= nil and templateArgs['qid'] ~= '') then | ||
args.entityId = templateArgs['qid'] | |||
else | |||
args.entityId = templateParams['qid'] | |||
end | |||
-- disable wikidata fetching | |||
if args.entityId == '' or args.entityId == '-' then args.entityId = nil end | |||
args.title = frame.args['כותרת תבנית'] or standardTitle(templateArgs, args.subtemplate, args.entityId) | args.title = frame.args['כותרת תבנית'] or standardTitle(templateArgs, args.subtemplate, args.entityId) | ||
if args.title=='-' then args.subtemplate = true end | if args.title=='-' then args.subtemplate = true end | ||
args.titlestyle = | args.titlestyle = templateParams['כותרת תבנית-עיצוב'] | ||
args.titleclass = | args.titleclass = templateParams['כותרת תבנית-מחלקה'] | ||
args.subtitle = | args.subtitle = templateParams['תת-כותרת תבנית'] | ||
args.subtitlestyle = | args.subtitlestyle = templateParams['תת-כותרת תבנית-עיצוב'] | ||
args.subtitleclass = | args.subtitleclass = templateParams['תת-כותרת תבנית-מחלקה'] | ||
args.rightImage = getValueOrWikidataImage | |||
args.rightImageDesc = templateParams['כיתוב ימין'] | |||
args.leftImage = getValueOrWikidataImage | args.rightImage, args.rightImageDesc = getValueOrWikidataImage{ | ||
valueArg=templateParams['תמונה ימין'], | |||
args.imageDesc = | wikidataArg=templateParams['תמונה ימין-ויקינתונים'], | ||
args.image = getValueOrWikidataImage | width=templateParams['תמונה ימין-גודל'] or '100x80', | ||
args. | imgDesc=args.rightImageDesc, | ||
args.headerstyle = | args=args | ||
args.rowsstyle = | } | ||
args.labelstyle = | |||
args.datastyle = | args.leftImageDesc = templateParams['כיתוב שמאל'] | ||
args.tablestyle = | args.leftImage, args.leftImageDesc = getValueOrWikidataImage{ | ||
args.tableclass = | valueArg=templateParams['תמונה שמאל'], | ||
local | wikidataArg=templateParams['תמונה שמאל-ויקינתונים'], | ||
self.autoDocumentation = | width=templateParams['תמונה שמאל-גודל'] or '100x80', | ||
imgDesc=args.leftImageDesc, | |||
args=args | |||
} | |||
args.imageDesc = templateParams['קעפל'] or templateParams['כיתוב'] | |||
if templateParams['תמונה ללא שאיבה אוטומטית'] == 'כן' then | |||
args.image, args.imageDesc = getValueOrWikidataImage{ | |||
valueArg=templateParams['תמונה'] or templateParams['בילד'], | |||
wikidataArg=templateParams['תמונה-ויקינתונים'], | |||
width=templateParams['תמונה-גודל'] or '220', | |||
imgDesc=args.imageDesc, | |||
args=args | |||
} | |||
else | |||
args.image, args.imageDesc = getValueOrWikidataImage{ | |||
valueArg=templateParams['בילד'] or templateParams['תמונה'], | |||
wikidataArg=templateParams['תמונה-ויקינתונים'] or 'P18', | |||
width=templateParams['תמונה-גודל'] or '220', | |||
imgDesc=args.imageDesc, | |||
args=args | |||
} | |||
end | |||
args.removeFirstHeader = false-- default based on vote on 18/7/21 | |||
-- explictly override the default | |||
if templateParams['כותרת כללית'] == 'כן' then | |||
args.removeFirstHeader = true | |||
elseif templateParams['כותרת כללית'] == 'לא' then | |||
args.removeFirstHeader = false | |||
end | |||
args.headerclass = templateParams['כותרת-מחלקה'] | |||
args.headerstyle = templateParams['כותרת-עיצוב'] | |||
args.rowsstyle = templateParams['שורה-עיצוב'] | |||
args.labelstyle = templateParams['תווית-עיצוב'] | |||
args.datastyle = templateParams['מידע-עיצוב'] | |||
args.tablestyle = templateArgs['טבלה-עיצוב'] or templateParams['טבלה-עיצוב'] | |||
args.tableclass = templateArgs['טבלה-מחלקה'] or templateParams['טבלה-מחלקה'] | |||
local pageNs = mw.title.getCurrentTitle().namespace | |||
local subpageText = mw.title.getCurrentTitle().subpageText | |||
local isSelfUse = (pageNs==10 and subpageText ~= "תיעוד") | |||
self.autoDocumentation = templateParams['תיעוד-אוטומטי'] | |||
local labelPrefix = 'תווית' | local labelPrefix = 'תווית' | ||
local dataPrefix = 'מידע' | local dataPrefix = 'מידע' | ||
local parameterDataPrefix = 'מידע-פרמטרי' | |||
local subheader = 'כותרת' | local subheader = 'כותרת' | ||
local labelDataPrefix = 'תווית-מידע' | local labelDataPrefix = 'תווית-מידע' | ||
| שורה 522: | שורה 657: | ||
local rowStyleClassPrefix = 'מחלקה-שורה' | local rowStyleClassPrefix = 'מחלקה-שורה' | ||
local styleSuffix = '-עיצוב' | local styleSuffix = '-עיצוב' | ||
local explicitWikidata = '-ויקינתונים-מפורש' | |||
local k=0 | local k=0 | ||
local processedParams = {['0']=1} -- param0 may be used by Lua, not be template | local processedParams = {['0']=1} -- param0 may be used by Lua, not be template | ||
| שורה 536: | שורה 672: | ||
else | else | ||
local labelName = templateParams[labelPrefix..i] | local labelName = templateParams[labelPrefix..i] | ||
local dataTemplate = templateParams[dataPrefix..i] | local dataTemplate = templateParams[dataPrefix..i] or templateParams[parameterDataPrefix..i] | ||
if dataTemplate then | if dataTemplate then | ||
-- if parameter contains only category with no value, replace with with nil and add | -- if parameter contains only category with no value, replace with with nil and add the value to maintaince category | ||
local hasData, maintainceCats = splitMaintainceCategory(dataTemplate) | local hasData, maintainceCats = splitMaintainceCategory(dataTemplate) | ||
if maintainceCats and not hasData then | if maintainceCats and not hasData then | ||
| שורה 546: | שורה 682: | ||
end | end | ||
if labelName and dataTemplate then | if labelName and dataTemplate then | ||
--label | if dataTemplate == templateParams[parameterDataPrefix..i] then | ||
local hasContent = templateArgs[dataTemplate] and #templateArgs[dataTemplate]>0 | |||
-- + and use explicit wikidata replace the content with such if available from wikidata | |||
local isExplicitWikidataParam = templateParams[dataTemplate..explicitWikidata] | |||
local isExplicitWikidataEnabled = false | |||
if isExplicitWikidataParam then | |||
isExplicitWikidataEnabled = templateArgs[dataTemplate]~=nil and mw.ustring.match(templateArgs[dataTemplate], '^ *+$') | |||
end | |||
local skipContent = false | |||
if hasContent and not isExplicitWikidataEnabled then | |||
dataTemplate = templateArgs[dataTemplate] | |||
else | |||
if isExplicitWikidataParam and not isExplicitWikidataEnabled then | |||
skipContent = true | |||
end | |||
dataTemplate = '{{{' ..dataTemplate.. '}}}' | |||
end | |||
if not skipContent then | |||
table.insert(templateStructure, {label=labelName, data=dataTemplate, rowstyle=templateParams[rowStylePrefix..i], rowclass=templateParams[rowStyleClassPrefix..i], datastyle=templateParams[dataPrefix..i..styleSuffix], | |||
labelstyle=templateParams[labelPrefix..i..styleSuffix], indic=indic}) | |||
end | |||
else | |||
table.insert(templateStructure, {label=labelName, data=dataTemplate, rowstyle=templateParams[rowStylePrefix..i], rowclass=templateParams[rowStyleClassPrefix..i], datastyle=templateParams[dataPrefix..i..styleSuffix], | |||
labelstyle=templateParams[labelPrefix..i..styleSuffix], indic=indic}) | labelstyle=templateParams[labelPrefix..i..styleSuffix], indic=indic}) | ||
end | |||
elseif labelName and not dataTemplate then | elseif labelName and not dataTemplate then | ||
--skip it. no only label [use subheader] | --skip it. no only label [use subheader] | ||
elseif not labelName and dataTemplate then | elseif not labelName and dataTemplate then | ||
-- | if dataTemplate == templateParams[parameterDataPrefix..i] then | ||
local hasContent = templateArgs[dataTemplate] and #templateArgs[dataTemplate]>0 | |||
-- + and use explicit wikidata replace the content with such if available from wikidata | |||
local isExplicitWikidataParam = templateParams[dataTemplate..explicitWikidata] | |||
local isExplicitWikidataEnabled = false | |||
if isExplicitWikidataParam then | |||
isExplicitWikidataEnabled = templateArgs[dataTemplate]~=nil and mw.ustring.match(templateArgs[dataTemplate], '^ *+$') | |||
end | |||
local skipContent = false | |||
if hasContent and not isExplicitWikidataEnabled then | |||
dataTemplate = templateArgs[dataTemplate] | |||
else | |||
if isExplicitWikidataParam and not isExplicitWikidataEnabled then | |||
skipContent = true | |||
end | |||
dataTemplate = '{{{' ..dataTemplate.. '}}}' | |||
end | |||
if not skipContent then | |||
table.insert(templateStructure, {data=dataTemplate, rowstyle=templateParams[rowStylePrefix..i], rowclass=templateParams[rowStyleClassPrefix..i], datastyle=templateParams[dataPrefix..i..styleSuffix], indic=indic}) | |||
end | |||
else | |||
table.insert(templateStructure, {data=dataTemplate, rowstyle=templateParams[rowStylePrefix..i], rowclass=templateParams[rowStyleClassPrefix..i], datastyle=templateParams[dataPrefix..i..styleSuffix], indic=indic}) | |||
end | |||
else | else | ||
local label_data_names = templateParams[labelDataPrefix..i] | local label_data_names = templateParams[labelDataPrefix..i] | ||
| שורה 559: | שורה 738: | ||
labelName = label_data_names | labelName = label_data_names | ||
label_data_names = mw.text.trim(label_data_names, '%[%]') | label_data_names = mw.text.trim(label_data_names, '%[%]') | ||
local hasContent = templateArgs[label_data_names] and #templateArgs[label_data_names]>0 | |||
-- + and use explicit wikidata replace the content with such if available from wikidata | |||
local isExplicitWikidataParam = templateParams[label_data_names..explicitWikidata] | |||
local isExplicitWikidataEnabled = false | |||
if isExplicitWikidataParam then | |||
isExplicitWikidataEnabled = templateArgs[label_data_names]~=nil and mw.ustring.match(templateArgs[label_data_names], '^ *+$') | |||
end | |||
local skipContent = false | |||
if hasContent and not isExplicitWikidataEnabled then | |||
dataTemplate = templateArgs[label_data_names] | dataTemplate = templateArgs[label_data_names] | ||
else | else | ||
if isExplicitWikidataParam and not isExplicitWikidataEnabled then | |||
skipContent = true | |||
end | |||
dataTemplate = '{{{' ..label_data_names.. '}}}' | dataTemplate = '{{{' ..label_data_names.. '}}}' | ||
end | end | ||
table.insert(templateStructure, {label=labelName, data=dataTemplate, rowstyle=templateParams[rowStylePrefix..i], rowclass=templateParams[rowStyleClassPrefix..i], datastyle=templateParams[dataPrefix..i..styleSuffix], | if not skipContent then | ||
table.insert(templateStructure, {label=labelName, data=dataTemplate, rowstyle=templateParams[rowStylePrefix..i], rowclass=templateParams[rowStyleClassPrefix..i], datastyle=templateParams[dataPrefix..i..styleSuffix], | |||
labelstyle=templateParams[labelPrefix..i..styleSuffix], indic=indic}) | labelstyle=templateParams[labelPrefix..i..styleSuffix], indic=indic}) | ||
end | |||
end | end | ||
end | end | ||
| שורה 585: | שורה 778: | ||
table.insert(entriesToRemove, 1, k) | table.insert(entriesToRemove, 1, k) | ||
else | else | ||
-- otherwise if the template isn't full - try to use wikidata to fill it | -- otherwise if the template isn't full or if there is a Wikidata-beats tag - them try to use wikidata to fill it | ||
local m = mw.ustring.match(v.data, ' | local m = mw.ustring.match(v.data, '{{{(.-)}}}') | ||
if v.label and templateParams[v.label..'-ויקינתונים-גובר'] then | |||
m = templateParams[v.label..'-ויקינתונים-גובר'] | |||
end | |||
if m then | if m then | ||
m = mw.uri.decode( m ) -- some templates may add encoding and are preprocessed before | m = mw.uri.decode( m ) -- some templates may add encoding and are preprocessed before | ||
local before = v.data | |||
local inWikidata, maintainceCats = fillMissingParamFromWikidata(m, templateParams, v, args.entityId, frame) | local inWikidata, maintainceCats = fillMissingParamFromWikidata(m, templateParams, v, args.entityId, frame) | ||
if (v.data==nil or v.data=="") and v.label and templateParams[v.label..'-ויקינתונים-גובר'] then | |||
v.data = before | |||
inWikidata = true | |||
end | |||
if maintainceCats then | if maintainceCats then | ||
table.insert(wikidataCats, maintainceCats) | table.insert(wikidataCats, maintainceCats) | ||
| שורה 600: | שורה 802: | ||
-- if data isn't available remove it | -- if data isn't available remove it | ||
table.insert(entriesToRemove, 1, k) | table.insert(entriesToRemove, 1, k) | ||
-- no need to cross validate it | |||
crossValidatedFields[m] = 1 | |||
end | end | ||
end | |||
end | |||
end | end | ||
end | end | ||
end | end | ||
for k,v in pairs(templateArgs) do | |||
if crossValidatedFields[k]==nil and v and #v>0 and k~= 'תמונה' then | if crossValidatedFields[k]==nil and v and #v>0 and pageNs==0 and k~= 'בילד' and k~= 'תמונה' then | ||
local maintainceCats = crossValidateWikidata(k,templateParams, v, frame) | local maintainceCats = crossValidateWikidata(k,templateParams, v, frame, args.entityId) | ||
if maintainceCats and #maintainceCats>0 then | if maintainceCats and #maintainceCats>0 then | ||
table.insert(wikidataCats, maintainceCats) | table.insert(wikidataCats, maintainceCats) | ||
end | end | ||
end | end | ||
end | end | ||
for k,v in pairs(entriesToRemove) do table.remove(templateStructure, v) end | for k,v in pairs(entriesToRemove) do table.remove(templateStructure, v) end | ||
| שורה 627: | שורה 824: | ||
-- use wikidata in title | -- use wikidata in title | ||
if args.title then | if args.title then | ||
local m = mw.ustring.match(args.title, ' | local m = mw.ustring.match(args.title, '{{{(.-)|(?)}}}') | ||
if m then | if m then | ||
local inWikidata = false | local inWikidata = false | ||
| שורה 639: | שורה 836: | ||
local wikidataParamValue = propertyLink.getLabel(templateParams[m..'-ויקינתונים-פשוט']) | local wikidataParamValue = propertyLink.getLabel(templateParams[m..'-ויקינתונים-פשוט']) | ||
if wikidataParamValue then | if wikidataParamValue then | ||
args.title = frame:preprocess(mw.ustring.gsub(args.title, ' | args.title = frame:preprocess(mw.ustring.gsub(args.title, '{{{('..m..')|?}}}', wikidataParamValue)) | ||
end | end | ||
end | end | ||
רעדאגירונגען