From dd3f79c199e70aa1bdf0d754e5e769838549eb54 Mon Sep 17 00:00:00 2001 From: fishyWET Date: Thu, 12 Oct 2017 22:43:34 +0800 Subject: [PATCH] Add ability to change party tag colour --- doc.txt | 1 + init.lua | 62 ++++++++++++++++++++++++++++++++++++++++++++++++------- squad.lua | 14 +++++++++++-- 3 files changed, 67 insertions(+), 10 deletions(-) diff --git a/doc.txt b/doc.txt index 9049f74..b4ac743 100644 --- a/doc.txt +++ b/doc.txt @@ -14,6 +14,7 @@ will support external mods. === mod_storage:_leader -- 's party name === mod_storage:_lock -- join status of party === mod_storage:_home -- home of party +=== mod_storage:_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:partypending -- for request mode parties only, if player sends request to join a party, value is party's leadername diff --git a/init.lua b/init.lua index dacac7d..5493d24 100644 --- a/init.lua +++ b/init.lua @@ -136,7 +136,11 @@ party.join = function(name, partyname) mod_storage:set_string(name.."_party", partyname) player:set_attribute("partyinvite", 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.."].") player:set_attribute("partychat", "party") end @@ -155,6 +159,7 @@ party.leave = function(name) mod_storage:set_string(name.."_lock", nil) mod_storage:set_string(name.."_title", nil) mod_storage:set_string(name.."_home", nil) + mod_storage:set_string(name.."_colour", nil) player:set_nametag_attributes({text = name}) player:set_attribute("partychat", "main") end @@ -206,6 +211,7 @@ minetest.register_chatcommand("p", { party.send_notice(name, minetest.colorize("cyan", "/p rename ").." --- 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 remove").." --- Remove your party home.") + party.send_notice(name, minetest.colorize("cyan", "/p colour ").." --- Set the colour of your party tag.") party.send_notice(name, minetest.colorize("cyan", "/p officer ").." --- Toogle a player's officer position. Officers can kick & invite.") party.send_notice(name, minetest.colorize("cyan", "/p lock ").." --- Toggle joining method for your party.") party.send_notice(name, minetest.colorize("cyan", "/p title ").." --- Adds a title to a player in party chat.") @@ -217,8 +223,6 @@ minetest.register_chatcommand("p", { -- TODO -- 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 list --- Ally list.") @@ -343,7 +347,11 @@ minetest.register_chatcommand("p", { mod_storage:set_string(name.."_leader", param2) player:set_attribute("partyinvite", nil) 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.."].") else @@ -489,6 +497,7 @@ minetest.register_chatcommand("p", { mod_storage:set_string(playernames.."_officer", nil) mod_storage:set_string(playernames.."_leader", nil) mod_storage:set_string(playernames.."_lock", nil) + mod_storage:set_string(playernames.."_title", nil) end end end @@ -497,6 +506,9 @@ minetest.register_chatcommand("p", { mod_storage:set_string(name.."_party", nil) mod_storage:set_string(name.."_leader", 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}) end @@ -517,13 +529,43 @@ minetest.register_chatcommand("p", { party.send_notice_all(name, name.." renamed the party tag to ["..param2.."].") -- 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 local names = players:get_player_name() - if mod_storage:get_string(names.."_party") == cparty then - players:set_nametag_attributes({text = "["..param2.."] "..names}) + 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, "["..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 + elseif param1 == "lock" then if party.check(name, 3) == true then return @@ -607,7 +649,7 @@ minetest.register_chatcommand("p", { mod_storage:set_string(param2.."_title",param3) party.send_notice(name, "Player "..param2.."'s title has been set to "..param3) end - end + end -- /p kick elseif param1 == "kick" and param2 ~= nil then @@ -1000,7 +1042,11 @@ minetest.register_on_joinplayer(function(player) party.leave(name) return 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) diff --git a/squad.lua b/squad.lua index 3497c5a..ad28eb4 100644 --- a/squad.lua +++ b/squad.lua @@ -167,7 +167,11 @@ squad.join = function(name, tag) squad.update_hud_self(name) 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") end @@ -221,7 +225,12 @@ squad.leave = function(name, tag) mod_storage:set_string(name.."_squad_leader", nil) mod_storage:set_string(name.."_squad_lock", 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) @@ -513,6 +522,7 @@ minetest.register_chatcommand("sq", { 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!") end + else squad.send_notice(name, "You are not in a squad!") end else squad.send_notice(name, "ERROR: Command is invalid! For help, use the command '/sq help'.")