Module

WorldSwitch

From Dogcraft Wiki

m (added streamtown)
mNo edit summary
 
(6 intermediate revisions by the same user not shown)
Line 1: Line 1:
local p = {} --p stands for package
local p = {} --p stands for package
local worldTools = require('Module:World')


-- HELPERS
-- get world from a string
function world(input)
input = mw.ustring.lower(input)
worlds = {"survival 1", "survival 2", "survival 3", "survival 4", "survival 5", "survival 6", "creative", "patreon", "hub", "amplified", "MCMMO", "skyblock"}
for key,value in ipairs(worlds) do
if (mw.ustring.find(input, value, 1, true) ~= nil) then
return value
end
end
if (mw.ustring.find(input, 'survival', 1, true) ~= nil) then
return 'survival 1'
end
return ''--return 'not found'
end
-- get the subworld from a string
function subworld(input)
input = mw.ustring.lower(input)
subworlds = {"husky", "beagle", "akita", "corgi", "labrador", "shepherd", "sheltie", "retriever", "streamtown"}
for key,value in ipairs(subworlds) do
if (mw.ustring.find(input, value, 1, true) ~= nil) then
return value
end
end
return ''--return 'not found'
end
-- MODES


-- get the parent world for a specific subworld
-- @return the world or an empty string when it doesn't find anything
function p.parentWorld(frame)
function p.parentWorld(frame)
input = mw.ustring.lower(frame.args[1] .. frame.args[2])
input = mw.ustring.lower(frame.args[1] .. frame.args[2])
subworld = subworld(input)
return worldTools.getParentWorld(input)
subworlds = {}
subworlds["survival 4"] = {"husky", "beagle"}
subworlds["survival 5"] = {"akita", "corgi", "labrador", "shepherd"}
subworlds["survival 6"] = {"sheltie", "retriever", "streamtown"}
for key,value in ipairs(subworlds["survival 4"]) do
if (mw.ustring.find(subworld, value, 1, true) ~= nil) then
return "survival 4"
end
end
for key,value in ipairs(subworlds["survival 5"]) do
if (mw.ustring.find(subworld, value, 1, true) ~= nil) then
return "survival 5"
end
end
for key,value in ipairs(subworlds["survival 6"]) do
if (mw.ustring.find(subworld, value, 1, true) ~= nil) then
return "survival 6"
end
end
end
end
 
-- get the subworld
-- usually would expect a world + subworld combo as the first two #invoke args, but works with any setup as long as either the first or the second arg has a string
-- @return the subworld or an empty string when it doesn't find anything
function p.subworld(frame)
function p.subworld(frame)
input = mw.ustring.lower(frame.args[1] .. frame.args[2])
input = mw.ustring.lower(frame.args[1] .. frame.args[2])
subworlds = {"husky", "beagle", "akita", "corgi", "labrador", "shepherd", "sheltie", "retriever", "streamtown"}
return worldTools.extractSubworld(input)
for key,value in ipairs(subworlds) do
if (mw.ustring.find(input, value, 1, true) ~= nil) then
return value
end
end
return ''--return 'not found'
end
end


-- get the world
-- usually would expect a world + subworld combo as the first two #invoke args, but works with any setup as long as either the first or the second arg has a string
-- @return the world or an empty string when it doesn't find anything
function p.world(frame)
function p.world(frame)
input = mw.ustring.lower(frame.args[1] .. frame.args[2])
input = mw.ustring.lower(frame.args[1] .. frame.args[2])
worlds = {"survival 1", "survival 2", "survival 3", "survival 4", "survival 5", "survival 6", "creative", "patreon", "hub", "amplified", "MCMMO", "skyblock"}
return worldTools.extractWorld(input)
for key,value in ipairs(worlds) do  
end
if (mw.ustring.find(input, value, 1, true) ~= nil) then
 
return value
 
end
-- get all world-related categories
-- usually meant for pages with multiple worlds, like groups or projects
-- @return a custom string or an empty string when it doesn't find anything
function p.multicat(frame)
input = mw.ustring.lower(frame.args[1] .. frame.args[2])
worlds = worldTools.extractAllWorlds(input)
cats = ""
for i, world in pairs(worlds) do
cats = cats .. " [[Category:" ..  mw.getContentLanguage():ucfirst( world ) .. "]]"
end
end
if (mw.ustring.find(input, 'survival', 1, true) ~= nil) then
return 'survival 1'
return cats
end
return ''--return 'not found'
end
end


return p
return p

Latest revision as of 16:00, 29 July 2024

{{#invoke:WorldSwitch|subworld|Survial 4|Husky}} generates: husky

{{#invoke:WorldSwitch|world|Survial 4|Husky}} generates: survival 4


local p = {} --p stands for package
local worldTools = require('Module:World')


-- get the parent world for a specific subworld
-- @return the world or an empty string when it doesn't find anything
function p.parentWorld(frame)
	input = mw.ustring.lower(frame.args[1] .. frame.args[2])
	return worldTools.getParentWorld(input)
end
	
	
-- get the subworld 
-- usually would expect a world + subworld combo as the first two #invoke args, but works with any setup as long as either the first or the second arg has a string
-- @return the subworld or an empty string when it doesn't find anything
function p.subworld(frame)
	input = mw.ustring.lower(frame.args[1] .. frame.args[2])
	return worldTools.extractSubworld(input)
end


-- get the world 
-- usually would expect a world + subworld combo as the first two #invoke args, but works with any setup as long as either the first or the second arg has a string
-- @return the world or an empty string when it doesn't find anything
function p.world(frame)
	input = mw.ustring.lower(frame.args[1] .. frame.args[2])
	return worldTools.extractWorld(input)
end


-- get all world-related categories
-- usually meant for pages with multiple worlds, like groups or projects
-- @return a custom string or an empty string when it doesn't find anything
function p.multicat(frame)
	input = mw.ustring.lower(frame.args[1] .. frame.args[2])
	worlds = worldTools.extractAllWorlds(input)
	
	cats = ""
	for i, world in pairs(worlds) do
		cats = cats .. " [[Category:" ..  mw.getContentLanguage():ucfirst( world ) .. "]]"
	end
	
	return cats
end

return p
Background Dragon Slayer - Retriever by Ironboundred