Module:PublicationCitesWork

From MaRDI portal

Documentation for this module may be created at Module:PublicationCitesWork/doc

-- Required module containing helper methods
local helper = require('Module:HelperMethods')

-- Required modules for SPARQL queries and HTML table generation
local sparql = require('SPARQL')
local mwHtml = require('mw.html')

-- Main table to hold all functions
local p = {}

-- 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 and binding.valueLabel and binding.valueLabel.value then
                if resultsString ~= "" then
                    resultsString = resultsString
                end
                
                local noTitle = false 
                local name = binding.valueLabel.value
                if string.find(name, "https://") then
                	name = helper.titleNotAvailableStr()
                	noTitle = true
                end
                
				-- Determine namespace prefix based on type
				local itemType = binding.type and binding.type.value or ""
				local itemTypeQID = itemType:match("Q%d+")				
				
				local prefix = "Item:Q"  -- default
				local displayPrefix = "" -- default
				
				if itemTypeQID == "Q56885" then
					prefix = "Dataset:"
					displayPrefix = "(DATASET) "
				elseif itemTypeQID == "Q56887" then
					prefix = "Publication:"
				elseif itemTypeQID == "Q57080" then
					prefix = "Software:"
					displayPrefix = "(SOFTWARE) "
				end                
				
				-- Rewrite the URL
                local link = binding.value.value
				link = link:gsub("entity/Q", "wiki/" .. prefix)				

				-- This condidtion is necessary to availd display mistakes with then
				-- "Title not available" links. Should be rewritten at some point.
				local nameAndLink
				if noTitle then
                	nameAndLink = "<li>[" .. link .. " " .. displayPrefix .. name .. "]</li>"
                else
                	nameAndLink = "<li>" .. helper.makeWikiLink(link, displayPrefix .. name) ..  "</li>"
                end

                resultsString = resultsString .. nameAndLink
            end
        end
    end

	return "<ul> " .. resultsString .. " </ul>"
end


-- Function to build the list
function p.getCitesWorkList(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 records found"
    end    
    
    -- Constructing the SPARQL query with dynamic entity target1
    local sparqlQuery = [[
PREFIX target: <https://portal.mardi4nfdi.de/entity/]] .. target1 .. [[>
PREFIX wdt: <https://portal.mardi4nfdi.de/prop/direct/>
PREFIX wd: <https://portal.mardi4nfdi.de/entity/>
PREFIX wikibase: <http://wikiba.se/ontology#>
PREFIX bd: <http://www.bigdata.com/rdf#>

SELECT ?property ?propertyLabel ?value ?valueLabel ?type ?typeLabel
WHERE {
  target: wdt:P223 ?value .
  OPTIONAL { ?value wdt:P31 ?type . }
  BIND(wdt:P223 AS ?property)
  SERVICE wikibase:label {
    bd:serviceParam wikibase:language "[AUTO_LANGUAGE],en".
  }
}
ORDER BY ?propertyLabel
]]
    
    -- mw.log( sparqlQuery )
    
	-- Executing the SPARQL query and retrieving results in JSON format
	local jsonResults = sparql.runQuery(sparqlQuery)
	
	mw.logObject(jsonResults)

	-- 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 nil
	end
	
	if helper.countElementsInBindings(jsonResults.results.bindings) == 0 then
        return nil
	end

	local linkList = p.convertJsonToCommaSeparatedList(jsonResults)
	-- mw.log(linkList) 

	local result = [[
<div class="keywords-header">
<span class="keywords-title">Cites Work</span>
<div class="keywords-line"></div>
</div>
<div class="keywords-list"> ]] .. linkList .. [[</div>
]]

	
    return result
end

-- Return the created html table
return p