1
0
mirror of https://gitlab.com/rubenwardy/awards.git synced 2025-06-28 22:26:17 +02:00

9 Commits

Author SHA1 Message Date
c27d527cfc Merge remote-tracking branch 'upstream/master' 2021-01-12 21:43:50 +01:00
37082d1186 Rename background to hud_background 2021-01-10 17:55:42 +00:00
6dc91cf893 Fix error due to unchecked JSON parsing 2021-01-10 17:17:57 +00:00
8702b6cdd8 Merge remote-tracking branch 'upstream/master' into nalc-1.2-dev 2020-06-16 20:49:49 +02:00
baf79bf9bf Merge branch 'master' of yunohost.local:mtcontrib/awards into nalc-1.2-dev 2019-12-21 13:09:58 +01:00
4f5260da5f Corrige la commande /awards.
Corrige l'affige des awards d'un joueur donné.
Empêche le retour de l'inventaire sfinv quand on active ou desactive
les awards d'un joueur.
2019-03-03 22:40:11 +01:00
89d4a93f3b Ajoute le privilège awards_admin
Modifie la commande /awards en conséquence
2019-03-03 13:24:28 +01:00
cae2c1ee3b Tente la correction d'un crash 2019-03-02 21:08:02 +01:00
54db6ce0c0 Suppression de minetest.register_on_craft
Cette fonction a été réécrite dans nalc_awards
2019-03-02 19:49:08 +01:00
7 changed files with 61 additions and 45 deletions

View File

@ -185,15 +185,16 @@ end
* `secret` - boolean if this award is secret (i.e. showed on awards list) * `secret` - boolean if this award is secret (i.e. showed on awards list)
* `sound` - `SimpleSoundSpec` table to play on unlock. * `sound` - `SimpleSoundSpec` table to play on unlock.
`false` to disable unlock sound. `false` to disable unlock sound.
* `icon` - the icon image, use default otherwise. * `icon` - the icon image. Defaults to `awards_unknown.png`.
* `background` - the background image, use default otherwise. * `hud_background` - the background image used in the HUD to contain the text and icon.
Defaults to `awards_bg_default.png`.
* `trigger` - trigger definition, see [Builtin Trigger Types](#builtin-trigger-types). * `trigger` - trigger definition, see [Builtin Trigger Types](#builtin-trigger-types).
* `on_unlock(name, def)` - callback on unlock. * `on_unlock(name, def)` - callback on unlock.
* `awards.registered_awards` - table of award name to definition. * `awards.registered_awards` - table of award name to definition.
* `awards.register_on_unlock(func(name, def))` * `awards.register_on_unlock(func(name, def))`
* `name` is the player name * `name` is the player name
* `def` is the award def. * `def` is the award def.
* return true to cancel HUD * return true to cancel HUD from appearing.
* `awards.unlock(player_name, award_name)` * `awards.unlock(player_name, award_name)`
* gives an award to a player * gives an award to a player
* `awards.get_award_states(player_name)` * `awards.get_award_states(player_name)`

View File

@ -95,7 +95,7 @@ function awards.unlock(name, award)
-- Get Notification Settings -- Get Notification Settings
local title = awdef.title or award local title = awdef.title or award
local desc = awdef.description or "" local desc = awdef.description or ""
local background = awdef.background or "awards_bg_default.png" local background = awdef.hud_background or awdef.background or "awards_bg_default.png"
local icon = (awdef.icon or "awards_unknown.png") .. "^[resize:32x32" local icon = (awdef.icon or "awards_unknown.png") .. "^[resize:32x32"
local sound = awdef.sound local sound = awdef.sound
if sound == nil then if sound == nil then
@ -127,6 +127,9 @@ function awards.unlock(name, award)
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",

View File

@ -251,7 +251,7 @@ if minetest.get_modpath("default") then
title = S("Lava and Water"), title = S("Lava and Water"),
description = S("Mine your first obsidian."), description = S("Mine your first obsidian."),
icon = "awards_lava_and_water.png^awards_level1.png", icon = "awards_lava_and_water.png^awards_level1.png",
background = "awards_bg_mining.png", hud_background = "awards_bg_mining.png",
difficulty = 1.5, difficulty = 1.5,
trigger = { trigger = {
type = "dig", type = "dig",
@ -265,7 +265,7 @@ if minetest.get_modpath("default") then
title = S("Obsessed with Obsidian"), title = S("Obsessed with Obsidian"),
description = S("Mine 50 obsidian."), description = S("Mine 50 obsidian."),
icon = "awards_obsessed_with_obsidian.png^awards_level2.png", icon = "awards_obsessed_with_obsidian.png^awards_level2.png",
background = "awards_bg_mining.png", hud_background = "awards_bg_mining.png",
difficulty = 1.5, difficulty = 1.5,
trigger = { trigger = {
type = "dig", type = "dig",
@ -279,7 +279,7 @@ if minetest.get_modpath("default") then
title = S("Lava Miner"), title = S("Lava Miner"),
description = S("Mine any block while being very close to lava."), description = S("Mine any block while being very close to lava."),
icon = "awards_lava_miner.png", icon = "awards_lava_miner.png",
background = "awards_bg_mining.png", hud_background = "awards_bg_mining.png",
difficulty = 1, difficulty = 1,
}) })
awards.register_on_dig(function(player,data) awards.register_on_dig(function(player,data)
@ -386,7 +386,7 @@ if minetest.get_modpath("default") then
title = S("First Mese Find"), title = S("First Mese Find"),
description = S("Mine your first mese ore."), description = S("Mine your first mese ore."),
icon = "awards_first_mese_find.png", icon = "awards_first_mese_find.png",
background = "awards_bg_mining.png", hud_background = "awards_bg_mining.png",
difficulty = 1, difficulty = 1,
trigger = { trigger = {
type = "dig", type = "dig",
@ -401,7 +401,7 @@ if minetest.get_modpath("default") then
title = S("Mese Mastery"), title = S("Mese Mastery"),
description = S("Mine a mese block."), description = S("Mine a mese block."),
icon = "awards_mese_mastery.png", icon = "awards_mese_mastery.png",
background = "awards_bg_mining.png", hud_background = "awards_bg_mining.png",
difficulty = 1.1, difficulty = 1.1,
trigger = { trigger = {
type = "dig", type = "dig",
@ -415,7 +415,7 @@ if minetest.get_modpath("default") then
title = S("Youre a copper"), title = S("Youre a copper"),
description = S("Dig 1,000 copper ores."), description = S("Dig 1,000 copper ores."),
icon = "awards_youre_a_copper.png", icon = "awards_youre_a_copper.png",
background = "awards_bg_mining.png", hud_background = "awards_bg_mining.png",
difficulty = 0.2, difficulty = 0.2,
trigger = { trigger = {
type = "dig", type = "dig",
@ -429,7 +429,7 @@ if minetest.get_modpath("default") then
title = S("Mini Miner"), title = S("Mini Miner"),
description = S("Dig 100 stone blocks."), description = S("Dig 100 stone blocks."),
icon = "awards_mini_miner.png^awards_level1.png", icon = "awards_mini_miner.png^awards_level1.png",
background = "awards_bg_mining.png", hud_background = "awards_bg_mining.png",
difficulty = 0.02, difficulty = 0.02,
trigger = { trigger = {
type = "dig", type = "dig",
@ -443,7 +443,7 @@ if minetest.get_modpath("default") then
title = S("Hardened Miner"), title = S("Hardened Miner"),
description = S("Dig 1,000 stone blocks."), description = S("Dig 1,000 stone blocks."),
icon = "awards_hardened_miner.png^awards_level2.png", icon = "awards_hardened_miner.png^awards_level2.png",
background = "awards_bg_mining.png", hud_background = "awards_bg_mining.png",
difficulty = 0.02, difficulty = 0.02,
trigger = { trigger = {
type = "dig", type = "dig",
@ -457,7 +457,7 @@ if minetest.get_modpath("default") then
title = S("Master Miner"), title = S("Master Miner"),
description = S("Dig 10,000 stone blocks."), description = S("Dig 10,000 stone blocks."),
icon = "awards_master_miner.png^awards_level3.png", icon = "awards_master_miner.png^awards_level3.png",
background = "awards_bg_mining.png", hud_background = "awards_bg_mining.png",
difficulty = 0.02, difficulty = 0.02,
trigger = { trigger = {
type = "dig", type = "dig",
@ -471,7 +471,7 @@ if minetest.get_modpath("default") then
title = S("Marchand De Sable"), title = S("Marchand De Sable"),
description = S("Dig 1,000 sand."), description = S("Dig 1,000 sand."),
icon = "awards_marchand_de_sable.png", icon = "awards_marchand_de_sable.png",
background = "awards_bg_mining.png", hud_background = "awards_bg_mining.png",
difficulty = 0.05, difficulty = 0.05,
trigger = { trigger = {
type = "dig", type = "dig",
@ -581,7 +581,7 @@ if minetest.get_modpath("default") then
title = S("First Gold Find"), title = S("First Gold Find"),
description = S("Mine your first gold ore."), description = S("Mine your first gold ore."),
icon = "awards_first_gold_find.png^awards_level1.png", icon = "awards_first_gold_find.png^awards_level1.png",
background = "awards_bg_mining.png", hud_background = "awards_bg_mining.png",
difficulty = 0.9, difficulty = 0.9,
trigger = { trigger = {
type = "dig", type = "dig",
@ -594,7 +594,7 @@ if minetest.get_modpath("default") then
title = S("Gold Rush"), title = S("Gold Rush"),
description = S("Mine 45 gold ores."), description = S("Mine 45 gold ores."),
icon = "awards_gold_rush.png^awards_level2.png", icon = "awards_gold_rush.png^awards_level2.png",
background = "awards_bg_mining.png", hud_background = "awards_bg_mining.png",
difficulty = 0.9, difficulty = 0.9,
trigger = { trigger = {
type = "dig", type = "dig",
@ -619,7 +619,7 @@ if minetest.get_modpath("default") then
title = S("Girl's Best Friend"), title = S("Girl's Best Friend"),
description = S("Mine 18 diamond ores."), description = S("Mine 18 diamond ores."),
icon = "awards_girls_best_friend.png^awards_level2.png", icon = "awards_girls_best_friend.png^awards_level2.png",
background = "awards_bg_mining.png", hud_background = "awards_bg_mining.png",
difficulty = 1, difficulty = 1,
trigger = { trigger = {
type = "dig", type = "dig",

View File

@ -2,28 +2,39 @@
local S = awards.gettext local S = awards.gettext
minetest.register_privilege("awards_admin", { description = "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 = "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, "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, "All awards and statistics of "..playern.." have been cleared.")
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, "Your awards are disabled.")
else minetest.chat_send_player(name, "You have disabled awards of "..playern..".")
elseif action == "enable" then
awards.enable(playern)
minetest.chat_send_player(playern, "Your awards are enabled.")
minetest.chat_send_player(name, "You have enabled awards of "..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

View File

@ -80,7 +80,8 @@ function awards.load()
os.rename(old_save_path, minetest.get_worldpath().."/awards.bk.txt") os.rename(old_save_path, minetest.get_worldpath().."/awards.bk.txt")
awards.save() awards.save()
else else
__player_data = minetest.parse_json(storage:get_string("player_data")) or {} local json = storage:get("player_data")
__player_data = json and minetest.parse_json(json) or {}
end end
end end

View File

@ -101,7 +101,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

View File

@ -113,15 +113,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", {