Модуль:TerritorialDivision

Материал из Википедии — свободной энциклопедии
Это старая версия этой страницы, сохранённая Игорь Темиров (обсуждение | вклад) в 20:33, 19 октября 2020. Она может серьёзно отличаться от текущей версии.
Перейти к навигации Перейти к поиску
Документация
local p = {}

local function Declension(collocation, case)
	local str = string.match(collocation, "([^\(]+)")
	if case == Genitive then
		if string.match(str, "ий район") then
			return string.gsub( str, "ий район", "ого района" )
		elseif string.match(str, "ая автономная область") then
			return string.gsub( str, "ая автономная область", "ой автономной области" )
		elseif string.match(str, "ское сельское поселение") then
			return string.gsub( str, "ское сельское поселение", "ского сельского поселения" )
		elseif string.match(str, "ородской округ") then
			return string.gsub( str, "ородской округ", "ородского округа" )
		end
	end
end

function p.MakeMunicipality(frame)
    local args = frame:getParent().args
	if args[1]==nil then 
    	CallSite = mw.wikibase.getEntityObject() 
    else
    	CallSite = mw.wikibase.getEntityObject(string.match( args[1], "Q%d+")) 
    end
    if CallSite==nil then do return "Не удалось получить свойства района из викидаты" end end
    local District

	if CallSite.claims.P31 and CallSite.claims.P31[1].mainsnak.datavalue.value['id'] == "Q2198484" then 
		District = CallSite
	elseif (CallSite.claims.P31 and CallSite.claims.P31[1].mainsnak.datavalue.value['id'] == "Q634099") or
		(CallSite.claims.P31 and CallSite.claims.P31[1].mainsnak.datavalue.value['id'] == "Q2661988") then 
		District = mw.wikibase.getEntityObject( CallSite.claims.P131 and CallSite.claims.P131[1].mainsnak.datavalue.value['id'] )
	else
		do return "Неизвестный тип поселения. Сообщите, пожалуйста, на страницу обсуждения шаблона" end
    end
    if District == nil then do return "Не удалось получить свойства района из викидаты" end end

    DistrictName = District:getSitelink() or District:getLabel()
	
	--local Colour   = args['цвет'] or "{{Цвет|Россия}}"
	local Titul    = args['заглавие'] or "Муниципальные образования [[" .. DistrictName .. "|" ..  Declension(DistrictName, Genitive) .. "]]"
	local State    = args['state'] or (#District.claims.P150 > 20 and "<includeonly>collapsed</includeonly>")
	local Picture  = args['изображение'] or (District.claims.P94 and "[[Файл:" .. District.claims.P94[1].mainsnak.datavalue['value'] .. "|x80px]]")
	local Picture2 = args['изображение2'] or (District.claims.P41 and "[[Файл:" .. District.claims.P41[1].mainsnak.datavalue['value'] .. "|x60px|border]]") 

	local frameTable={}
	table.insert( frameTable,  "{{навигационная полоса")
	table.insert( frameTable, "|имя = Муниципальные образования")
	--table.insert( frameTable,  "|цвет = " .. Colour)
	table.insert( frameTable, "|заглавие = " .. Titul)
	if State then table.insert( frameTable, "|state = " .. State) end
	if Picture then table.insert( frameTable, "|изображение = " .. Picture) end
	if Picture2 then table.insert( frameTable, "|изображение2 = " .. Picture2) end
	table.insert( frameTable, "|содержание = ")
	local GorodMO={}
	local SeloMO={}
	for c, claim in pairs( District.claims.P150 ) do
		if ( claim['rank'] ~= "deprecated" and claim.mainsnak.datavalue.value['id'] ) then
			local childQ = claim.mainsnak.datavalue.value['id']
		    local Child = mw.wikibase.getEntityObject( childQ )
			if Child.claims.P31 and Child.claims.P31[1].mainsnak.datavalue.value['id'] == "Q634099" then 
		    	table.insert (SeloMO, Child:getSitelink()  or Child:getLabel())
		    elseif Child.claims.P31 and Child.claims.P31[1].mainsnak.datavalue.value['id'] == "Q2661988" then 
		    	table.insert (GorodMO, Child:getSitelink()  or Child:getLabel())
		    else			
		    	do return "Неизвестный тип поселения" end
		    end
		end
	end

	table.sort(GorodMO)
	for key, val in pairs(GorodMO) do
   		table.insert( frameTable, "{{s|[[" .. val .. "|" .. string.match(val, "([^\(]+)") .. "]]}}{{•}}" )
	end	
	frameTable[#frameTable] = string.gsub( frameTable[#frameTable], "}}{{•}}$", "}}<br>") 

	table.sort(SeloMO)
	SeloStr=""
	for key, val in pairs(SeloMO) do
   		table.insert( frameTable, "{{s|[[" .. val)
   		if string.match(val, "%(") then table.insert( frameTable, "|" .. string.match(val, "([^\(]+) %(")) end
   		table.insert( frameTable, "]]}}{{•}}")
	end	
	frameTable[#frameTable] = string.gsub( frameTable[#frameTable], "}}{{•}}$", "}}") 
	table.insert( frameTable, "}}")
	frameStr=table.concat(frameTable)

	return frame:preprocess( frameStr ) 
end

-- ================================================================================================================================
function p.MakeSettlements (frame)
    local args = frame:getParent().args
	if args[1]==nil then 
    	CallSite = mw.wikibase.getEntityObject() 
    else
    	CallSite = mw.wikibase.getEntityObject(string.match( args[1], "Q%d+")) 
    end
    if CallSite==nil then do return "Не удалось получить свойства района из викидаты" end end
    local District

	if CallSite.claims.P31 and CallSite.claims.P31[1].mainsnak.datavalue.value['id'] == "Q2198484" then 
		District = CallSite
	else
		Parent = mw.wikibase.getEntityObject( CallSite.claims.P131 and CallSite.claims.P131[1].mainsnak.datavalue.value['id'] )
		District = mw.wikibase.getEntityObject( Parent.claims.P131 and Parent.claims.P131[1].mainsnak.datavalue.value['id'] )
		if District.claims.P31 and District.claims.P31[1].mainsnak.datavalue.value['id'] ~= "Q2198484" then District = nil end
    end
    if District == nill then do return "Не удалось получить свойства района из викидаты" end end

    DistrictName = District:getSitelink() or District:getLabel()
    AdmCenterQ = District.claims.P36 and District.claims.P36[1].mainsnak.datavalue.value['id']
	AdmCenter = mw.wikibase.getEntityObject( AdmCenterQ )
	AdmCenterName = AdmCenter:getSitelink() or AdmCenter:getLabel()
	
	--local Colour   = args['цвет'] or "{{Цвет|Россия}}"
	local Titul    = args['заглавие'] or "Населённые пункты [[" .. DistrictName .. "|" ..  Declension(DistrictName, Genitive) .. "]]"
	local State    = args['state'] or (#District.claims.P150 > 20 and "<includeonly>collapsed</includeonly>")
	local Picture  = args['изображение'] or (District.claims.P94 and "[[Файл:" .. District.claims.P94[1].mainsnak.datavalue['value'] .. "|x80px]]")
	local Picture2 = args['изображение2'] or (District.claims.P41 and "[[Файл:" .. District.claims.P41[1].mainsnak.datavalue['value'] .. "|x60px|border]]") 

	local frameTable={}
	table.insert( frameTable, "{{навигационная полоса")
	table.insert( frameTable, "|имя = Муниципальные образования")
	--table.insert( frameTable, "|цвет = " .. Colour)
	table.insert( frameTable, "|заглавие = " .. Titul)
	if State then table.insert( frameTable, "|state = " .. State) end
	if Picture then table.insert( frameTable, "|изображение = " .. Picture) end
	if Picture2 then table.insert( frameTable, "|изображение2 = " .. Picture2) end
	table.insert( frameTable, "|содержание = ")

	local AdmCenterExist = false
	local Settlements={}
	for d, DistrictClaim in pairs( District.claims.P150 ) do
		if ( DistrictClaim['rank'] ~= "deprecated" and DistrictClaim.mainsnak.datavalue.value['id'] ) then
			local MunicipalityQ = DistrictClaim.mainsnak.datavalue.value['id']
		    local Municipality = mw.wikibase.getEntityObject( MunicipalityQ )
			for m, MunicipalityClaim in pairs( Municipality.claims.P150 ) do
				if ( MunicipalityClaim['rank'] ~= "deprecated" and MunicipalityClaim.mainsnak.datavalue.value['id'] ) then
					local SettlementQ = MunicipalityClaim.mainsnak.datavalue.value['id']
				    local Settlement = mw.wikibase.getEntityObject( SettlementQ )
			    	table.insert (Settlements, Settlement:getSitelink()  or Settlement:getLabel())
			    	AdmCenterExist = AdmCenterExist or (AdmCenterQ == SettlementQ)
				end
			end
		end
	end
	table.insert( frameTable, 	"'''Районный центр:''' [[" .. AdmCenterName)
   	if string.match(AdmCenterName, "%(") then table.insert( frameTable, "|" .. string.match(AdmCenterName, "([^\(]+) %(")) end
   	table.insert( frameTable, "]]")
	if not AdmCenterExist then table.insert( frameTable, " (в состав района не входит)") end
	table.insert( frameTable, 	"<br>")

	table.sort(Settlements)
	for key, val in pairs(Settlements) do
		if val ~= AdmCenterName then
   			table.insert( frameTable, "{{s|[[" .. val)
   			if string.match(val, "%(") then table.insert( frameTable, "|" .. string.match(val, "([^\(]+) %(")) end
   			table.insert( frameTable, "]]}}{{•}}")
   		end
	end	
	frameTable[#frameTable] = string.gsub( frameTable[#frameTable], "}}{{•}}$", "}}") 

	table.insert( frameTable, "}}")
	frameStr=table.concat(frameTable)

	return frame:preprocess( frameStr ) 
end

-- ================================================================================================================================

function p.MakeMunicipalityDB(frame)
	local args = {}
	if #frame:getParent().args > 0 then
		args = frame:getParent().args
	else
		args = frame.args
	end
	if args==nil then do return "Не удалось получить код ОКТМО для данной страницы из викидаты" end end
    local CodePage = mw.text.trim(args[1])
	if string.sub(CodePage, 1, 2) ~= '79' then do return "Пока только Адыгея" end end
	local RegionSet = mw.loadData("Модуль:TerritorialDivision/79")
	local RayonSet = RegionSet[string.sub(CodePage, 1, 5)..'000']
    DistrictName = RayonSet[0][1]
	local DistrictQ = mw.wikibase.getEntityIdForTitle(DistrictName)
	local District = mw.wikibase.getEntity(DistrictQ)
	local GorodMO={}
	local SeloMO={}
	for k, var in pairs(RayonSet) do
		if k ~= 0 then
			if var[0][2] == 'сельское поселение' then
		    	table.insert (SeloMO, var[0][1])
		    elseif var[0][2] == 'сельское поселение' then
			    table.insert (SeloMO, var[0][1])
		    else			
		    	do return var[0][1] .. " -> Неизвестный тип поселения" end
		    end
		end
	end
	local Titul    = args['заглавие'] or "Муниципальные образования [[" .. DistrictName .. "|" ..  Declension(DistrictName, Genitive) .. "]]"
	local State = args['state'] or (#GorodMO + #SeloMO > 20 and "<includeonly>collapsed</includeonly>")
	local Picture  = args['изображение'] or (District.claims.P94 and "[[Файл:" .. District.claims.P94[1].mainsnak.datavalue['value'] .. "|x80px]]")
	local Picture2 = args['изображение2'] or (District.claims.P41 and "[[Файл:" .. District.claims.P41[1].mainsnak.datavalue['value'] .. "|x60px|border]]") 

	local frameTable={}
	table.insert( frameTable,  "{{навигационная полоса")
	table.insert( frameTable, "|имя = Муниципальные образования")
	--table.insert( frameTable,  "|цвет = " .. Colour)
	table.insert( frameTable, "|заглавие = " .. Titul)
	if State then table.insert( frameTable, "|state = " .. State) end
	if Picture then table.insert( frameTable, "|изображение = " .. Picture) end
	if Picture2 then table.insert( frameTable, "|изображение2 = " .. Picture2) end
	table.insert( frameTable, "|содержание = ")

	table.sort(GorodMO)
	for key, val in pairs(GorodMO) do
   		table.insert( frameTable, "{{s|[[" .. val .. "|" .. string.match(val, "([^\(]+)") .. "]]}}{{•}}" )
	end	
	frameTable[#frameTable] = string.gsub( frameTable[#frameTable], "}}{{•}}$", "}}<br>") 

	table.sort(SeloMO)
	SeloStr=""
	for key, val in pairs(SeloMO) do
   		table.insert( frameTable, "{{s|[[" .. val)
   		if string.match(val, "%(") then table.insert( frameTable, "|" .. string.match(val, "([^\(]+) %(")) end
   		table.insert( frameTable, "]]}}{{•}}")
	end	
	frameTable[#frameTable] = string.gsub( frameTable[#frameTable], "}}{{•}}$", "}}") 
	table.insert( frameTable, "}}")
	frameStr=table.concat(frameTable)

	return frame:preprocess( frameStr ) 
end


-- ================================================================================================================================
function p.MakeSettlementsDB (frame)
	local args = {}
	if #frame:getParent().args > 0 then
		args = frame:getParent().args
	else
		args = frame.args
	end
	if args==nil then do return "Не удалось получить код ОКТМО для данной страницы из викидаты" end end
    local CodePage = mw.text.trim(args[1])
	if string.sub(CodePage, 1, 2) ~= '79' then do return "Пока только Адыгея" end end
	local RegionSet = mw.loadData("Модуль:TerritorialDivision/79")
	local Poselenie = false
	if string.len(CodePage) == 8 and string.find(CodePage, "^(\d\d\d\d\d000)") ~= nil then Poselenie = true end
	local MOSet
	if Poselenie then
		MOSet = RegionSet[string.sub(CodePage, 1, 5)..'000'][CodePage]
	else 
		MOSet = RegionSet[string.sub(CodePage, 1, 5)..'000']
	end
    local DistrictName = MOSet[0][1]
    local AdmCenterName = MOSet[0][3] 
	local DistrictQ = mw.wikibase.getEntityIdForTitle(DistrictName)
	local District = mw.wikibase.getEntity(DistrictQ)
    if District == nill then do return "Не удалось получить свойства района из викидаты" end end

	local AdmCenterExist = false
	local Settlements={}
	for k, var in pairs(MOSet) do
		if k ~= 0 then
			if var[0] == nil then
				if var[1] == AdmCenterName then
					AdmCenterExist = true
				else
					table.insert (Settlements, var[1])
				end
			else
				for s, mo in pairs(var) do
					if s ~= 0 then 				
						if mo[1] == AdmCenterName then
							AdmCenterExist = true
						else
							table.insert (Settlements, mo[1])
						end
					end
				end
			end
		end
	end

	--local Colour   = args['цвет'] or "{{Цвет|Россия}}"
	--do return DistrictName end
	local Titul    = args['заглавие'] or "Населённые пункты [[" .. DistrictName .. "|" ..  Declension(DistrictName, Genitive) .. "]]"
	local State    = args['state'] or (#Settlements > 30 and "<includeonly>collapsed</includeonly>")
	local Picture  = args['изображение'] or (District.claims.P94 and "[[Файл:" .. District.claims.P94[1].mainsnak.datavalue['value'] .. "|x80px]]")
	local Picture2 = args['изображение2'] or (District.claims.P41 and "[[Файл:" .. District.claims.P41[1].mainsnak.datavalue['value'] .. "|x60px|border]]") 

	local frameTable={}
	table.insert( frameTable, "{{навигационная полоса")
	table.insert( frameTable, "|имя = Населённые пункты")
	--table.insert( frameTable, "|цвет = " .. Colour)
	table.insert( frameTable, "|заглавие = " .. Titul)
	if State then table.insert( frameTable, "|state = " .. State) end
	if Picture then table.insert( frameTable, "|изображение = " .. Picture) end
	if Picture2 then table.insert( frameTable, "|изображение2 = " .. Picture2) end
	table.insert( frameTable, "|содержание = ")

	table.insert( frameTable, 	"'''Административный центр:''' [[" .. AdmCenterName)
   	if string.match(AdmCenterName, "%(") then table.insert( frameTable, "|" .. string.match(AdmCenterName, "([^\(]+) %(")) end
   	table.insert( frameTable, "]]")
	if not AdmCenterExist then table.insert( frameTable, " (в состав муниципального образования не входит)") end
	table.insert( frameTable, 	"<br>")

	table.sort(Settlements)
	for key, val in pairs(Settlements) do
		if val ~= AdmCenterName then
   			table.insert( frameTable, "{{s|[[" .. val)
   			if string.match(val, "%(") then table.insert( frameTable, "|" .. string.match(val, "([^\(]+) %(")) end
   			table.insert( frameTable, "]]}}{{•}}")
   		end
	end	
	frameTable[#frameTable] = string.gsub( frameTable[#frameTable], "}}{{•}}$", "}}") 

	table.insert( frameTable, "}}")
	frameStr=table.concat(frameTable)

	return frame:preprocess( frameStr ) 
end

return p