mirror of
				https://gitlab.com/rubenwardy/awards.git
				synced 2025-11-04 06:35:29 +01:00 
			
		
		
		
	Compare commits
	
		
			16 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| a78db04f7e | |||
| 2d7a306dde | |||
| aceec98b09 | |||
| 24f4780ead | |||
| 4da55e06e8 | |||
| 978d57a301 | |||
| 70773359ad | |||
| 0a1a02b8c4 | |||
| c6151abbe9 | |||
| c27d527cfc | |||
| 8702b6cdd8 | |||
| baf79bf9bf | |||
| 4f5260da5f | |||
| 
						 | 
					89d4a93f3b | ||
| 
						 | 
					cae2c1ee3b | ||
| 
						 | 
					54db6ce0c0 | 
@@ -116,17 +116,20 @@ function awards.unlock(name, award)
 | 
				
			|||||||
	if awards.show_mode == "chat" then
 | 
						if awards.show_mode == "chat" then
 | 
				
			||||||
		local chat_announce
 | 
							local chat_announce
 | 
				
			||||||
		if awdef.secret then
 | 
							if awdef.secret then
 | 
				
			||||||
			chat_announce = S("Secret Award Unlocked: %s")
 | 
								chat_announce = S("Secret Award Unlocked: @1", title)
 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
			chat_announce = S("Award Unlocked: %s")
 | 
								chat_announce = S("Award Unlocked: @1", title)
 | 
				
			||||||
		end
 | 
							end
 | 
				
			||||||
		-- use the chat console to send it
 | 
							-- use the chat console to send it
 | 
				
			||||||
		minetest.chat_send_player(name, string.format(chat_announce, title))
 | 
							minetest.chat_send_player(name, chat_announce)
 | 
				
			||||||
		if desc~="" then
 | 
							if desc~="" then
 | 
				
			||||||
			minetest.chat_send_player(name, desc)
 | 
								minetest.chat_send_player(name, desc)
 | 
				
			||||||
		end
 | 
							end
 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
		local player = minetest.get_player_by_name(name)
 | 
							local player = minetest.get_player_by_name(name)
 | 
				
			||||||
 | 
							if not (player and player.is_player and player:is_player()) then
 | 
				
			||||||
 | 
								return
 | 
				
			||||||
 | 
							end
 | 
				
			||||||
		local one = player:hud_add({
 | 
							local one = player:hud_add({
 | 
				
			||||||
			hud_elem_type = "image",
 | 
								hud_elem_type = "image",
 | 
				
			||||||
			name = "award_bg",
 | 
								name = "award_bg",
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -455,7 +455,7 @@ if minetest.get_modpath("default") then
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	-- Marchand de sable
 | 
						-- Marchand de sable
 | 
				
			||||||
	awards.register_award("award_marchand_de_sable", {
 | 
						awards.register_award("award_marchand_de_sable", {
 | 
				
			||||||
		title = S("Marchand De Sable"),
 | 
							title = S("SandMan"),
 | 
				
			||||||
		description = S("Dig 1,000 sand."),
 | 
							description = S("Dig 1,000 sand."),
 | 
				
			||||||
		icon = "awards_marchand_de_sable.png",
 | 
							icon = "awards_marchand_de_sable.png",
 | 
				
			||||||
		hud_background = "awards_bg_mining.png",
 | 
							hud_background = "awards_bg_mining.png",
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -2,28 +2,39 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
local S = awards.translator
 | 
					local S = awards.translator
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					minetest.register_privilege("awards_admin", { description = S("Can manage awards of given player") })
 | 
				
			||||||
 | 
					
 | 
				
			||||||
minetest.register_chatcommand("awards", {
 | 
					minetest.register_chatcommand("awards", {
 | 
				
			||||||
	params = S("[c|clear|disable|enable]"),
 | 
						params = "[c|clear|disable|enable] [player_name]",
 | 
				
			||||||
	description = S("Show, clear, disable or enable your awards"),
 | 
						description = S("Show, clear, disable or enable player's awards"),
 | 
				
			||||||
	func = function(name, param)
 | 
						func = function(name, param)
 | 
				
			||||||
		if param == "clear" then
 | 
							if not minetest.check_player_privs(name, { awards_admin = true }) then
 | 
				
			||||||
			awards.clear_player(name)
 | 
								return false, S("You need awards_admin privilege!")
 | 
				
			||||||
			minetest.chat_send_player(name,
 | 
							end
 | 
				
			||||||
			S("All your awards and statistics have been cleared. You can now start again."))
 | 
							local action, playern = param:split(" ")[1], param:split(" ")[2] or name
 | 
				
			||||||
		elseif param == "disable" then
 | 
							if action == "clear" then
 | 
				
			||||||
			awards.disable(name)
 | 
								awards.clear_player(playern)
 | 
				
			||||||
			minetest.chat_send_player(name, S("You have disabled awards."))
 | 
								minetest.chat_send_player(playern,
 | 
				
			||||||
		elseif param == "enable" then
 | 
									S("All your awards and statistics have been cleared. You can now start again."))
 | 
				
			||||||
			awards.enable(name)
 | 
								minetest.chat_send_player(name, S("All awards and statistics of @1 have been cleared.", playern))
 | 
				
			||||||
			minetest.chat_send_player(name, S("You have enabled awards."))
 | 
							elseif action == "disable" then
 | 
				
			||||||
		elseif param == "c" then
 | 
								awards.disable(playern)
 | 
				
			||||||
			awards.show_to(name, name, nil, true)
 | 
								minetest.chat_send_player(playern, S("Your awards are disabled."))
 | 
				
			||||||
		else
 | 
								minetest.chat_send_player(name, S("You have disabled awards of @1.", playern))
 | 
				
			||||||
 | 
							elseif action == "enable" then
 | 
				
			||||||
 | 
								awards.enable(playern)
 | 
				
			||||||
 | 
								minetest.chat_send_player(playern, S("Your awards are enabled."))
 | 
				
			||||||
 | 
								minetest.chat_send_player(name, S("You have enabled awards of @1.", playern))
 | 
				
			||||||
 | 
							elseif action == "c" then
 | 
				
			||||||
 | 
								awards.show_to(playern, name, nil, true)
 | 
				
			||||||
 | 
							elseif not action then
 | 
				
			||||||
			awards.show_to(name, name, nil, false)
 | 
								awards.show_to(name, name, nil, false)
 | 
				
			||||||
 | 
							else
 | 
				
			||||||
 | 
								awards.show_to(action, name, nil, true)
 | 
				
			||||||
		end
 | 
							end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (param == "disable" or param == "enable") and minetest.global_exists("sfinv") then
 | 
							if (action == "disable" or action == "enable") and minetest.global_exists("sfinv") and not minetest.get_modpath("unified_inventory") then
 | 
				
			||||||
			local player = minetest.get_player_by_name(name)
 | 
								local player = minetest.get_player_by_name(playern)
 | 
				
			||||||
			if player then
 | 
								if player then
 | 
				
			||||||
				sfinv.set_player_inventory_formspec(player)
 | 
									sfinv.set_player_inventory_formspec(player)
 | 
				
			||||||
			end
 | 
								end
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -106,7 +106,7 @@ function awards.show_to(name, to, sid, text)
 | 
				
			|||||||
	if name == "" or name == nil then
 | 
						if name == "" or name == nil then
 | 
				
			||||||
		name = to
 | 
							name = to
 | 
				
			||||||
	end
 | 
						end
 | 
				
			||||||
	local data = awards.player(to)
 | 
						local data = awards.player(name)
 | 
				
			||||||
	if name == to and data.disabled then
 | 
						if name == to and data.disabled then
 | 
				
			||||||
		minetest.chat_send_player(name, S("You've disabled awards. Type /awards enable to reenable."))
 | 
							minetest.chat_send_player(name, S("You've disabled awards. Type /awards enable to reenable."))
 | 
				
			||||||
		return
 | 
							return
 | 
				
			||||||
@@ -120,7 +120,7 @@ function awards.show_to(name, to, sid, text)
 | 
				
			|||||||
			minetest.chat_send_player(to, S("You have not unlocked any awards."))
 | 
								minetest.chat_send_player(to, S("You have not unlocked any awards."))
 | 
				
			||||||
			return
 | 
								return
 | 
				
			||||||
		end
 | 
							end
 | 
				
			||||||
		minetest.chat_send_player(to, string.format(S("%s’s awards:"), name))
 | 
							minetest.chat_send_player(to, S("@1’s awards:", name))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		for str, _ in pairs(data.unlocked) do
 | 
							for str, _ in pairs(data.unlocked) do
 | 
				
			||||||
			local def = awards.registered_awards[str]
 | 
								local def = awards.registered_awards[str]
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -105,6 +105,10 @@ minetest.register_on_placenode(function(pos, node, player)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	local node_name = node.name
 | 
						local node_name = node.name
 | 
				
			||||||
	node_name = minetest.registered_aliases[node_name] or node_name
 | 
						node_name = minetest.registered_aliases[node_name] or node_name
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						if string.match(node_name, "default:torch_") then -- NALC: fix torch name change on wall place
 | 
				
			||||||
 | 
							node_name = "default:torch"
 | 
				
			||||||
 | 
						end
 | 
				
			||||||
	awards.notify_place(player, node_name)
 | 
						awards.notify_place(player, node_name)
 | 
				
			||||||
end)
 | 
					end)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -119,15 +123,15 @@ awards.register_trigger("craft", {
 | 
				
			|||||||
	end,
 | 
						end,
 | 
				
			||||||
	key_is_item = true,
 | 
						key_is_item = true,
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
minetest.register_on_craft(function(itemstack, player, old_craft_grid, craft_inv)
 | 
					--minetest.register_on_craft(function(itemstack, player, old_craft_grid, craft_inv)
 | 
				
			||||||
	if not player_ok(player) or itemstack:is_empty() then
 | 
					--	if not player_ok(player) or itemstack:is_empty() then
 | 
				
			||||||
		return
 | 
					--		return
 | 
				
			||||||
	end
 | 
					--	end
 | 
				
			||||||
 | 
					--
 | 
				
			||||||
	local itemname = itemstack:get_name()
 | 
					--	local itemname = itemstack:get_name()
 | 
				
			||||||
	itemname = minetest.registered_aliases[itemname] or itemname
 | 
					--	itemname = minetest.registered_aliases[itemname] or itemname
 | 
				
			||||||
	awards.notify_craft(player, itemname, itemstack:get_count())
 | 
					--	awards.notify_craft(player, itemname, itemstack:get_count())
 | 
				
			||||||
end)
 | 
					--end)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
awards.register_trigger("eat", {
 | 
					awards.register_trigger("eat", {
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user