Add ability to change party tag colour

This commit is contained in:
fishyWET 2017-10-12 22:43:34 +08:00
parent 0c60e69052
commit dd3f79c199
3 changed files with 67 additions and 10 deletions

View File

@ -14,6 +14,7 @@ will support external mods.
=== mod_storage:<leadername>_leader -- <leader>'s party name === mod_storage:<leadername>_leader -- <leader>'s party name
=== mod_storage:<leadername>_lock -- join status of party <empty/active/request/private> === mod_storage:<leadername>_lock -- join status of party <empty/active/request/private>
=== mod_storage:<leadername>_home -- home of party <empty/active/request/private> === mod_storage:<leadername>_home -- home of party <empty/active/request/private>
=== mod_storage:<leadername>_colour -- colour of partytag, might return a nonsensical colour because there are no checks to ensure it is a real colour
----------------------------------------------------- -----------------------------------------------------
=== attribute:partyinvite -- if invited, value is inviter's name === attribute:partyinvite -- if invited, value is inviter's name
=== attribute:partypending -- for request mode parties only, if player sends request to join a party, value is party's leadername === attribute:partypending -- for request mode parties only, if player sends request to join a party, value is party's leadername

View File

@ -136,7 +136,11 @@ party.join = function(name, partyname)
mod_storage:set_string(name.."_party", partyname) mod_storage:set_string(name.."_party", partyname)
player:set_attribute("partyinvite", nil) player:set_attribute("partyinvite", nil)
player:set_attribute("partypending", nil) player:set_attribute("partypending", nil)
player:set_nametag_attributes({text = "["..cparty_l.."] "..name}) local tcolour = mod_storage:get_string(partyname.."_colour")
if tcolour == "" then
tcolour = "lightgrey"
end
player:set_nametag_attributes({text = minetest.colorize(tcolour, "["..cparty_l.."]").." "..name})
party.send_notice_all(name, name.." has joined "..partyname.."'s party ["..cparty_l.."].") party.send_notice_all(name, name.." has joined "..partyname.."'s party ["..cparty_l.."].")
player:set_attribute("partychat", "party") player:set_attribute("partychat", "party")
end end
@ -155,6 +159,7 @@ party.leave = function(name)
mod_storage:set_string(name.."_lock", nil) mod_storage:set_string(name.."_lock", nil)
mod_storage:set_string(name.."_title", nil) mod_storage:set_string(name.."_title", nil)
mod_storage:set_string(name.."_home", nil) mod_storage:set_string(name.."_home", nil)
mod_storage:set_string(name.."_colour", nil)
player:set_nametag_attributes({text = name}) player:set_nametag_attributes({text = name})
player:set_attribute("partychat", "main") player:set_attribute("partychat", "main")
end end
@ -206,6 +211,7 @@ minetest.register_chatcommand("p", {
party.send_notice(name, minetest.colorize("cyan", "/p rename <new_partyname>").." --- Rename your party.") party.send_notice(name, minetest.colorize("cyan", "/p rename <new_partyname>").." --- Rename your party.")
party.send_notice(name, minetest.colorize("cyan", "/p sethome").." --- Set your party home.") party.send_notice(name, minetest.colorize("cyan", "/p sethome").." --- Set your party home.")
party.send_notice(name, minetest.colorize("cyan", "/p sethome remove").." --- Remove your party home.") party.send_notice(name, minetest.colorize("cyan", "/p sethome remove").." --- Remove your party home.")
party.send_notice(name, minetest.colorize("cyan", "/p colour <colour>").." --- Set the colour of your party tag.")
party.send_notice(name, minetest.colorize("cyan", "/p officer <playername>").." --- Toogle a player's officer position. Officers can kick & invite.") party.send_notice(name, minetest.colorize("cyan", "/p officer <playername>").." --- Toogle a player's officer position. Officers can kick & invite.")
party.send_notice(name, minetest.colorize("cyan", "/p lock <open/active/request/private>").." --- Toggle joining method for your party.") party.send_notice(name, minetest.colorize("cyan", "/p lock <open/active/request/private>").." --- Toggle joining method for your party.")
party.send_notice(name, minetest.colorize("cyan", "/p title <playername> <title>").." --- Adds a title to a player in party chat.") party.send_notice(name, minetest.colorize("cyan", "/p title <playername> <title>").." --- Adds a title to a player in party chat.")
@ -217,8 +223,6 @@ minetest.register_chatcommand("p", {
-- TODO -- TODO
-- formspecs equivalents -- formspecs equivalents
-- party.send_notice(name, "/p colour <partycolour> --- Change colour of party tag")
-- party.send_notice(name, "/p customrank <player> <rank> --- Custom ranks -- for customizing certain party features later on.")
-- party.send_notice(name, "/p ally/enemy/neutral <partyname> --- Toggle diplomacy status with another party. Allied parties will have no friendly fire and there will be ally chat.") -- party.send_notice(name, "/p ally/enemy/neutral <partyname> --- Toggle diplomacy status with another party. Allied parties will have no friendly fire and there will be ally chat.")
-- party.send_notice(name, "/p ally list --- Ally list.") -- party.send_notice(name, "/p ally list --- Ally list.")
@ -343,7 +347,11 @@ minetest.register_chatcommand("p", {
mod_storage:set_string(name.."_leader", param2) mod_storage:set_string(name.."_leader", param2)
player:set_attribute("partyinvite", nil) player:set_attribute("partyinvite", nil)
player:set_attribute("partychat", "party") player:set_attribute("partychat", "party")
player:set_nametag_attributes({text = "["..param2.."] "..name}) local tcolour = mod_storage:get_string(name.."_colour")
if tcolour == "" then
tcolour = "lightgrey"
end
player:set_nametag_attributes({text = minetest.colorize(tcolour, "["..param2.."]").." "..name})
party.send_notice(name, "You created "..name.."'s party ["..param2.."].") party.send_notice(name, "You created "..name.."'s party ["..param2.."].")
else else
@ -489,6 +497,7 @@ minetest.register_chatcommand("p", {
mod_storage:set_string(playernames.."_officer", nil) mod_storage:set_string(playernames.."_officer", nil)
mod_storage:set_string(playernames.."_leader", nil) mod_storage:set_string(playernames.."_leader", nil)
mod_storage:set_string(playernames.."_lock", nil) mod_storage:set_string(playernames.."_lock", nil)
mod_storage:set_string(playernames.."_title", nil)
end end
end end
end end
@ -497,6 +506,9 @@ minetest.register_chatcommand("p", {
mod_storage:set_string(name.."_party", nil) mod_storage:set_string(name.."_party", nil)
mod_storage:set_string(name.."_leader", nil) mod_storage:set_string(name.."_leader", nil)
mod_storage:set_string(name.."_lock", nil) mod_storage:set_string(name.."_lock", nil)
mod_storage:set_string(name.."_colour", nil)
mod_storage:set_string(name.."_title", nil)
mod_storage:set_string(name.."_home", nil)
player:set_nametag_attributes({text = name}) player:set_nametag_attributes({text = name})
end end
@ -517,10 +529,40 @@ minetest.register_chatcommand("p", {
party.send_notice_all(name, name.." renamed the party tag to ["..param2.."].") party.send_notice_all(name, name.." renamed the party tag to ["..param2.."].")
-- update online player nametags -- update online player nametags
local tcolour = mod_storage:get_string(name.."_colour")
if tcolour == "" then
tcolour = "lightgrey"
end
for _,players in ipairs(minetest.get_connected_players()) do for _,players in ipairs(minetest.get_connected_players()) do
local names = players:get_player_name() local names = players:get_player_name()
if mod_storage:get_string(names.."_party") == cparty then local csquad = mod_storage:get_string(names.."_squad")
players:set_nametag_attributes({text = "["..param2.."] "..names}) if mod_storage:get_string(names.."_party") == cparty and csquad == "" then
players:set_nametag_attributes({text = minetest.colorize(tcolour, "["..param2.."]").." "..name})
elseif mod_storage:get_string(names.."_party") == cparty and csquad ~= "" then
players:set_nametag_attributes({text = minetest.colorize(tcolour, "["..param2.."-"..csquad.."]").." "..name})
end
end
elseif param1 == "colour" and param2 ~= nil then
if party.check(name, 3) == true then
return
end
party.send_notice(name, "Party tag colour is set to "..minetest.colorize(param2, param2)..".")
mod_storage:set_string(name.."_colour", param2)
-- update online player nametags
local cparty_l = mod_storage:get_string(cparty.."_leader")
local tcolour = mod_storage:get_string(cparty.."_colour")
if tcolour == "" then
tcolour = "lightgrey"
end
for _,players in ipairs(minetest.get_connected_players()) do
local names = players:get_player_name()
local csquad = mod_storage:get_string(names.."_squad")
if mod_storage:get_string(names.."_party") == cparty and csquad == "" then
players:set_nametag_attributes({text = minetest.colorize(tcolour, "["..cparty_l.."]").." "..name})
elseif mod_storage:get_string(names.."_party") == cparty and csquad ~= "" then
players:set_nametag_attributes({text = minetest.colorize(tcolour, "["..cparty_l.."-"..csquad.."]").." "..name})
end end
end end
@ -1000,7 +1042,11 @@ minetest.register_on_joinplayer(function(player)
party.leave(name) party.leave(name)
return return
else else
player:set_nametag_attributes({text = "["..cparty_l.."] "..name}) local tcolour = mod_storage:get_string(cparty.."_colour")
if tcolour == "" then
tcolour = "lightgrey"
end
player:set_nametag_attributes({text = minetest.colorize(tcolour, "["..cparty_l.."]").." "..name})
end end
end end
end) end)

View File

@ -167,7 +167,11 @@ squad.join = function(name, tag)
squad.update_hud_self(name) squad.update_hud_self(name)
squad.send_notice_all(name, name.." has joined the ["..tag.."] squad") squad.send_notice_all(name, name.." has joined the ["..tag.."] squad")
player:set_nametag_attributes({text = "["..cparty_l.."-"..tag.."] "..name}) local tcolour = mod_storage:get_string(cparty.."_colour")
if tcolour == "" then
tcolour = "lightgrey"
end
player:set_nametag_attributes({text = minetest.colorize(tcolour, "["..cparty_l.."-"..tag.."]").." "..name})
player:set_attribute("partychat", "squad") player:set_attribute("partychat", "squad")
end end
@ -221,7 +225,12 @@ squad.leave = function(name, tag)
mod_storage:set_string(name.."_squad_leader", nil) mod_storage:set_string(name.."_squad_leader", nil)
mod_storage:set_string(name.."_squad_lock", nil) mod_storage:set_string(name.."_squad_lock", nil)
mod_storage:set_string(name.."_squad_no", nil) mod_storage:set_string(name.."_squad_no", nil)
player:set_nametag_attributes({text = "["..cparty_l.."] "..name})
local tcolour = mod_storage:get_string(cparty.."_colour")
if tcolour == "" then
tcolour = "lightgrey"
end
player:set_nametag_attributes({text = minetest.colorize(tcolour, "["..cparty_l.."]").." "..name})
local squad_amt = squad.member_amt(name, csquad) local squad_amt = squad.member_amt(name, csquad)
@ -513,6 +522,7 @@ minetest.register_chatcommand("sq", {
squad.send_notice(name, param2.." has been sent an invitation to join ["..csquad.."] squad. Pending response") squad.send_notice(name, param2.." has been sent an invitation to join ["..csquad.."] squad. Pending response")
else squad.send_notice(name, "Player "..param2.." does not exist!") else squad.send_notice(name, "Player "..param2.." does not exist!")
end end
else squad.send_notice(name, "You are not in a squad!")
end end
else squad.send_notice(name, "ERROR: Command is invalid! For help, use the command '/sq help'.") else squad.send_notice(name, "ERROR: Command is invalid! For help, use the command '/sq help'.")