Module:TA4TK:myTest: Difference between revisions

From MaRDI portal
No edit summary
No edit summary
Line 1: Line 1:
-- Main table to hold all functions
-- Required modules for SPARQL queries and HTML table generation
 
local sparql = require('SPARQL')
local sparql = require('SPARQL') -- Load the SPARQL binding
local mwHtml = require('mw.html')


local p = {}
local p = {}
Line 17: Line 17:
end
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


function p.querySPARQL()
    return resultsString
-- Define the SPARQL endpoint
end
    local endpoint = "https://query.wikidata.org/bigdata/namespace/wdq/sparql"


     -- Define the SPARQL query
 
-- 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 = [[
     local sparqlQuery = [[
        SELECT ?item ?itemLabel WHERE {
PREFIX target1: <https://staging.mardi4nfdi.org/entity/]] .. target1 .. [[>
            ?item wdt:P31 wd:Q5;
SELECT ?value ?valueLabel WHERE {
                  rdfs:label "Albert Einstein"@en.
  ?value wdt:P715 target1:.
            SERVICE wikibase:label { bd:serviceParam wikibase:language "[AUTO_LANGUAGE],en". }
  target1: rdfs:label ?valueLabel
        } LIMIT 1
}
     ]]
     ]]
   
-- Executing the SPARQL query and retrieving results in JSON format
local jsonResults = sparql.runQuery(sparqlQuery)
local queryResults = sparql.runQuery(sparqlQuery) -- Use the runQuery method
-- Handle error in SPARQL query execution
if jsonResults and jsonResults.error then
    mw.log("Error in SPARQL query: " .. tostring(jsonResults.error))
    return nil
end


-- nil is returned if Blazegraph did not return a valid response
if not jsonResults then
if queryResults == nil then
        return "Could not fetch data."
return "No results found."
end
end
    -- Check if the input is a table
local testList = p.convertJsonToCommaSeparatedList(jsonResults)
    if type(queryResults) ~= "table" then
        return "Error: Input is not a table."
    end
 
    -- Start HTML table
    local results = {"<table border='1'>"}
    table.insert(results, "<tr><th>Key</th><th>Value</th></tr>")
 
    -- Add rows for each key-value pair
    for key, value in pairs(queryResults) do
        table.insert(results, string.format("<tr><td>%s</td><td>%s</td></tr>", tostring(key), tostring(value)))
    end


    -- End HTML table
     return testList
    table.insert(results, "</table>")
      
     return table.concat(results, "\n")
     --return queryResults['results']
end
end




return p
return p

Revision as of 09:57, 29 January 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 = {}

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


return p