Module:TA4TK:myTest: Difference between revisions
From MaRDI portal
No edit summary |
No edit summary |
||
Line 11: | Line 11: | ||
local propertyIdImage = "P1088" -- Property ID for the local image | local propertyIdImage = "P1088" -- Property ID for the local image | ||
local propertyIdLegend = "P648" -- Property ID for the media legend | local propertyIdLegend = "P648" -- Property ID for the media legend | ||
local entityId = "Q4610" | local entityId = "Q4610" -- The target entity | ||
-- Attempt to retrieve entity data | -- Attempt to retrieve entity data | ||
local entity = mw.wikibase.getEntity(entityId) | local entity = mw.wikibase.getEntity(entityId) | ||
if not entity or not entity.claims[ | if not entity or not entity.claims[propertyIdImage] then | ||
return "No image found" | return "No image found" | ||
end | end |
Revision as of 15:49, 6 February 2025
Documentation for this module may be created at Module:TA4TK:myTest/doc
-- Required modules for SPARQL queries and HTML table generation
local sparql = require('SPARQL')
local mwHtml = require('mw.html')
local p = {}
local p = {}
function p.getImageWithLegend(frame)
local propertyIdImage = "P1088" -- Property ID for the local image
local propertyIdLegend = "P648" -- Property ID for the media legend
local entityId = "Q4610" -- The target entity
-- Attempt to retrieve entity data
local entity = mw.wikibase.getEntity(entityId)
if not entity or not entity.claims[propertyIdImage] then
return "No image found"
end
-- Fetch the image filename from P1088
local imageClaims = entity.claims and entity.claims[propertyIdImage]
local imageFilename = imageClaims and imageClaims[1] and imageClaims[1].mainsnak.datavalue.value
-- Fetch the image legend from P648
local legendClaims = entity.claims and entity.claims[propertyIdLegend]
local imageLegend = legendClaims and legendClaims[1] and legendClaims[1].mainsnak.datavalue.value
-- Check if image exists
if not imageFilename then
return "No image available."
end
-- Use a default message if legend is missing
if not imageLegend then
imageLegend = "No legend available."
end
-- Return a formatted wikitext string
return string.format(
'[[File:%s|thumb|%s]]',
imageFilename,
imageLegend
)
end
function convertJsonToTable(jsonResults)
local resultsTable = {}
if jsonResults and jsonResults.results and jsonResults.results.bindings then
local bindings = jsonResults.results.bindings
for j=0, #bindings do
local row = {}
for key, value in pairs(bindings[j]) do
table.insert(row, value.value)
end
table.insert(resultsTable, row)
end
end
return resultsTable
end
-- Function to build the list
function p.buildList2(frame)
-- Retrieve target1 from frame arguments or return error message if not set
local target1 = frame.args[1]
if not target1 or target1 == '' then
return "No ID given"
end
-- Constructing the SPARQL query with dynamic entity target1
local sparqlQuery = [[
PREFIX target1: <https://portal.mardi4nfdi.de/entity/Q6534342>
SELECT ?Computational_Task WHERE {
target1: wdt:P147 ?URL.
?URL rdfs:label ?Label
BIND(CONCAT("<a href=", STR(?URL), ">", STR(?Label) ,"</a>") as ?Computational_Task)
}
]]
-- Executing the SPARQL query and retrieving results in JSON format
local jsonResults = sparql.runQuery(sparqlQuery)
return jsonResults['results']['bindings'][0]['Computational Task']['value']
--local dataTable = convertJsonToTable(jsonResults)
--return testTable
--return jsonResults
end
function p.hello()
local str = "Hello World!"
return str
end
function p.renderFormula()
return mw.getCurrentFrame():extensionTag{
name="math",
content= "\\sin x",
}
end
-- Function to convert JSON results into a comma-separated string
function p.convertJsonToCommaSeparatedList(jsonResults)
local resultsString = ""
if jsonResults and jsonResults.results and jsonResults.results.bindings then
local bindings = jsonResults.results.bindings
for i = 0, #bindings do
local binding = bindings[i]
if binding.valueLabel and binding.valueLabel.value then
if resultsString ~= "" then
resultsString = resultsString .. ", "
end
local name = binding.valueLabel.value
if string.find(name, "https://") then
name = "Unnamed task"
end
local link = binding.value.value
link = link:gsub("entity/Q", "wiki/Task:")
local nameAndLink = "[" .. link .. " " .. name .. "]"
resultsString = resultsString .. nameAndLink
end
end
end
return resultsString
end
-- Function to build the list
function p.buildList(frame)
-- Retrieve target1 from frame arguments or return error message if not set
local target1 = frame.args[1]
if not target1 or target1 == '' then
return "No ID given"
end
-- Constructing the SPARQL query with dynamic entity target1
local sparqlQuery = [[
PREFIX target1: <https://staging.mardi4nfdi.org/entity/]] .. target1 .. [[>
SELECT ?value ?valueLabel WHERE {
?value wdt:P715 target1:.
target1: rdfs:label ?valueLabel
}
]]
-- Executing the SPARQL query and retrieving results in JSON format
local jsonResults = sparql.runQuery(sparqlQuery)
-- Handle error in SPARQL query execution
if jsonResults and jsonResults.error then
mw.log("Error in SPARQL query: " .. tostring(jsonResults.error))
return nil
end
if not jsonResults then
return "Could not fetch data."
end
local testList = p.convertJsonToCommaSeparatedList(jsonResults)
return testList
end
-- Function to build the list in the real portal
function p.buildListPortal(frame)
-- Retrieve target1 from frame arguments or return error message if not set
local target1 = frame.args[1]
if not target1 or target1 == '' then
return "No ID given"
end
-- Constructing the SPARQL query with dynamic entity target1
local sparqlQuery = [[
PREFIX target1: <https://portal.mardi4nfdi.de/entity/]] .. target1 .. [[>
SELECT ?value ?valueLabel WHERE {
?value wdt:P715 target1:.
target1: rdfs:label ?valueLabel
}
]]
-- Executing the SPARQL query and retrieving results in JSON format
local jsonResults = sparql.runQuery(sparqlQuery)
-- Handle error in SPARQL query execution
if jsonResults and jsonResults.error then
mw.log("Error in SPARQL query: " .. tostring(jsonResults.error))
return nil
end
if not jsonResults then
return "Could not fetch data."
end
local testList = p.convertJsonToCommaSeparatedList(jsonResults)
return testList
end
-- Function to build the description
function p.buildDescription(frame)
-- Retrieve target1 from frame arguments or return error message if not set
local target1 = frame.args[1]
if not target1 or target1 == '' then
return "No ID given"
end
-- Constructing the SPARQL query with dynamic entity target1
local sparqlQuery = [[
SELECT ?Description
WHERE {
wd:Q4610 wdt:P896 ?Description.
}
]]
-- Executing the SPARQL query and retrieving results in JSON format
local jsonResults = sparql.runQuery(sparqlQuery)
return jsonResults['results']['bindings'][0]['Description']['value']
end
function p.getImage(frame)
local entityId = "Q4610" -- The target entity
local propertyId = "P1088" -- Property assumed to store the image
local width = "480px" -- Desired image width
-- Attempt to retrieve entity data
local entity = mw.wikibase.getEntity(entityId)
if not entity or not entity.claims[propertyId] then
return "No image found"
end
-- Extract the first image filename from P1088
local imageFilename1 = entity.claims[propertyId][1].mainsnak.datavalue.value
if not imageFilename1 then
return "No valid image found"
end
-- Extract the second image filename from P1088
local imageFilename2 = entity.claims[propertyId][2].mainsnak.datavalue.value
if not imageFilename2 then
--return one image
return string.format("[[File:%s|thumb|center|%s]]", imageFilename1, width)
else
--return two images
return string.format("[[File:%s|left|%s]] [[File:%s|center|%s]] \n \n \n ", imageFilename1, width, imageFilename2, width)
end
end
return p