Module:PublicationKeywordList: Difference between revisions

From MaRDI portal
No edit summary
No edit summary
 
(16 intermediate revisions by the same user not shown)
Line 9: Line 9:
local p = {}
local p = {}


-- This function will replace spaces with + and encode other non-alphanumeric
-- Function to convert JSON results into a string containing the links
-- characters into their percent-encoded representations, making the string
function p.convertJsonToLinkList(jsonResults)
-- safe to use in a URL.
function urlencode(str)
    if str then
        str = string.gsub(str, "\n", "\r\n")
        str = string.gsub(str, "([^%w %-%_%.%~])",
            function (c) return string.format("%%%02X", string.byte(c)) end)
        str = string.gsub(str, " ", "+")
    end
    return str
end
 
-- Function to convert JSON results into a comma-separated string
function p.convertJsonToCommaSeparatedList(jsonResults)
local resultsString = ""
local resultsString = ""
Line 32: Line 19:
             if binding.valueLabel and binding.valueLabel.value then
             if binding.valueLabel and binding.valueLabel.value then
                 if resultsString ~= "" then
                 if resultsString ~= "" then
                     resultsString = resultsString .. ", "
                     resultsString = resultsString  
                 end
                 end
                  
                  
Line 40: Line 27:
                 end
                 end
                  
                  
                 local safeList = urlencode ( binding.value.value )
                -- Get the current URL
                 local link = "https://portal.mardi4nfdi.de/w/index.php?title=+Special%3ASearch&search=" + safeList + "&go=Go"
    local baseUrl = mw.site.server
 
                -- replace weird characters in key words
                 local safeList = helper.urlencode ( binding.value.value )
                 local link = baseUrl .. "/w/index.php?title=+Special%3ASearch&search=" .. safeList .. "&go=Go"
                  
                  
                 local nameAndLink = "[" .. link .. " " .. name .. "]"
                 local nameAndLink = "[" .. link .. " " .. name .. "]"
Line 94: Line 85:
if not jsonResults then
if not jsonResults then
         return "Could not fetch data."
         return "Could not fetch data."
    end
end


if not jsonResults.results or not jsonResults.results.bindings or #jsonResults.results.bindings == 0 then
if helper.countElementsInBindings(jsonResults.results.bindings) == 0 then
         return "No records found."
         return "No records found."
end
end


local keywordList = p.convertJsonToCommaSeparatedList(jsonResults)
local keywordList = p.convertJsonToLinkList(jsonResults)
-- mw.log(keywordList)  
-- mw.log(keywordList)  

Latest revision as of 20:19, 10 September 2024

Documentation for this module may be created at Module:PublicationKeywordList/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 string containing the links
function p.convertJsonToLinkList(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 = "Unknown"
                end
                
                -- Get the current URL
    			local baseUrl = mw.site.server

                -- replace weird characters in key words
                local safeList = helper.urlencode ( binding.value.value )
                local link = baseUrl .. "/w/index.php?title=+Special%3ASearch&search=" .. safeList .. "&go=Go"
                
                local nameAndLink = "[" .. link .. " " .. name .. "]"

                resultsString = resultsString .. nameAndLink
            end
        end
    end

    return resultsString
end


-- Function to build the list
function p.buildKeywordList(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 target1: <https://portal.mardi4nfdi.de/entity/]] .. target1 .. [[>
PREFIX wdt: <https://portal.mardi4nfdi.de/prop/direct/>
PREFIX wd: <https://portal.mardi4nfdi.de/entity/>

SELECT ?property ?propertyLabel ?value ?valueLabel
WHERE {
    target1: wdt:P1450 ?value .
    OPTIONAL {
        ?value rdfs:label ?valueLabel .
        FILTER(LANG(?valueLabel) = "en")
    }
    BIND(wdt:P16 AS ?property)
    SERVICE wikibase:label { bd:serviceParam wikibase:language "[AUTO_LANGUAGE],en". }
}
    ]]
    
	-- 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 "Could not fetch data."
	end

	if helper.countElementsInBindings(jsonResults.results.bindings) == 0 then
        return "No records found."
	end

	local keywordList = p.convertJsonToLinkList(jsonResults)
	
	-- mw.log(keywordList) 
	
    return keywordList
end

-- Return the created html table
return p