summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--bags.lua90
-rw-r--r--callbacks.lua2
-rw-r--r--depends.txt2
-rw-r--r--init.lua19
-rw-r--r--locale/de.txt5
-rw-r--r--locale/es.txt8
-rw-r--r--locale/fr.txt5
-rw-r--r--locale/pl.txt5
-rw-r--r--locale/ru.txt5
-rw-r--r--locale/template.txt5
-rw-r--r--locale/tr.txt5
-rw-r--r--register.lua8
-rw-r--r--textures/ui_bags_trash.pngbin0 -> 1790 bytes
13 files changed, 52 insertions, 107 deletions
diff --git a/bags.lua b/bags.lua
index 7e925db..4af4ff5 100644
--- a/bags.lua
+++ b/bags.lua
@@ -31,80 +31,18 @@ unified_inventory.register_button("bags", {
hide_lite=true
})
-
- unified_inventory.register_page("bag1", {
- get_formspec = function(player)
- local stack = player:get_inventory():get_stack("bag1", 1)
- local image = stack:get_definition().inventory_image
- local formspec = "image[7,0;1,1;"..image.."]"
- formspec = formspec.."label[0,0;"..F("Bag 1").."]"
- formspec = formspec.."listcolors[#00000000;#00000000]"
- formspec = formspec.."list[current_player;bag1contents;0,1;8,3;]"
- formspec = formspec.."listring[current_name;bag1contents]"
- formspec = formspec.."listring[current_player;main]"
- local slots = stack:get_definition().groups.bagslots
- if slots == 8 then
- formspec = formspec.."background[0.06,0.99;7.92,7.52;ui_bags_sm_form.png]"
- elseif slots == 16 then
- formspec = formspec.."background[0.06,0.99;7.92,7.52;ui_bags_med_form.png]"
- elseif slots == 24 then
- formspec = formspec.."background[0.06,0.99;7.92,7.52;ui_bags_lg_form.png]"
- end
- return {formspec=formspec}
- end,
- })
- unified_inventory.register_page("bag2", {
- get_formspec = function(player)
- local stack = player:get_inventory():get_stack("bag2", 1)
- local image = stack:get_definition().inventory_image
- local formspec = "image[7,0;1,1;"..image.."]"
- formspec = formspec.."label[0,0;"..F("Bag 2").."]"
- formspec = formspec.."listcolors[#00000000;#00000000]"
- formspec = formspec.."list[current_player;bag2contents;0,1;8,3;]"
- formspec = formspec.."listring[current_name;bag2contents]"
- formspec = formspec.."listring[current_player;main]"
- local slots = stack:get_definition().groups.bagslots
- if slots == 8 then
- formspec = formspec.."background[0.06,0.99;7.92,7.52;ui_bags_sm_form.png]"
- elseif slots == 16 then
- formspec = formspec.."background[0.06,0.99;7.92,7.52;ui_bags_med_form.png]"
- elseif slots == 24 then
- formspec = formspec.."background[0.06,0.99;7.92,7.52;ui_bags_lg_form.png]"
- end
- return {formspec=formspec}
- end,
- })
- unified_inventory.register_page("bag3", {
+for i = 1, 4 do
+ local bi = i
+ unified_inventory.register_page("bag"..bi, {
get_formspec = function(player)
- local stack = player:get_inventory():get_stack("bag3", 1)
+ local stack = player:get_inventory():get_stack("bag"..bi, 1)
local image = stack:get_definition().inventory_image
- local formspec = "image[7,0;1,1;"..image.."]"
- formspec = formspec.."label[0,0;"..F("Bag 3").."]"
- formspec = formspec.."listcolors[#00000000;#00000000]"
- formspec = formspec.."list[current_player;bag3contents;0,1;8,3;]"
- formspec = formspec.."listring[current_name;bag3contents]"
- formspec = formspec.."listring[current_player;main]"
- local slots = stack:get_definition().groups.bagslots
- if slots == 8 then
- formspec = formspec.."background[0.06,0.99;7.92,7.52;ui_bags_sm_form.png]"
- elseif slots == 16 then
- formspec = formspec.."background[0.06,0.99;7.92,7.52;ui_bags_med_form.png]"
- elseif slots == 24 then
- formspec = formspec.."background[0.06,0.99;7.92,7.52;ui_bags_lg_form.png]"
- end
- return {formspec=formspec}
- end,
- })
- unified_inventory.register_page("bag4", {
- get_formspec = function(player)
- local stack = player:get_inventory():get_stack("bag4", 1)
- local image = stack:get_definition().inventory_image
- local formspec = "image[7,0;1,1;"..image.."]"
- formspec = formspec.."label[0,0;"..F("Bag 4").."]"
- formspec = formspec.."listcolors[#00000000;#00000000]"
- formspec = formspec.."list[current_player;bag4contents;0,1;8,3;]"
- formspec = formspec.."listring[current_name;bag4contents]"
- formspec = formspec.."listring[current_player;main]"
+ local formspec = ("image[7,0;1,1;"..image.."]"
+ .."label[0,0;"..F("Bag @1", bi).."]"
+ .."listcolors[#00000000;#00000000]"
+ .."list[current_player;bag"..bi.."contents;0,1;8,3;]"
+ .."listring[current_name;bag"..bi.."contents]"
+ .."listring[current_player;main]")
local slots = stack:get_definition().groups.bagslots
if slots == 8 then
formspec = formspec.."background[0.06,0.99;7.92,7.52;ui_bags_sm_form.png]"
@@ -113,9 +51,12 @@ unified_inventory.register_button("bags", {
elseif slots == 24 then
formspec = formspec.."background[0.06,0.99;7.92,7.52;ui_bags_lg_form.png]"
end
+ formspec = (formspec.."background[6.06,0;0.92,0.92;ui_bags_trash.png]"
+ .."list[detached:trash;main;6,0.1;1,1;]")
return {formspec=formspec}
end,
})
+end
minetest.register_on_player_receive_fields(function(player, formname, fields)
if formname ~= "" then
@@ -135,7 +76,8 @@ end)
minetest.register_on_joinplayer(function(player)
local player_inv = player:get_inventory()
- local bags_inv = minetest.create_detached_inventory(player:get_player_name().."_bags",{
+ local player_name = player:get_player_name()
+ local bags_inv = minetest.create_detached_inventory(player_name.."_bags",{
on_put = function(inv, listname, index, stack, player)
player:get_inventory():set_stack(listname, index, stack)
player:get_inventory():set_size(listname.."contents",
@@ -186,7 +128,7 @@ minetest.register_on_joinplayer(function(player)
allow_move = function(inv, from_list, from_index, to_list, to_index, count, player)
return 0
end,
- })
+ }, player_name)
for i=1,4 do
local bag = "bag"..i
player_inv:set_size(bag, 1)
diff --git a/callbacks.lua b/callbacks.lua
index ad6de0a..7240814 100644
--- a/callbacks.lua
+++ b/callbacks.lua
@@ -43,7 +43,7 @@ minetest.register_on_joinplayer(function(player)
minetest.sound_play("electricity",
{to_player=player_name, gain = 1.0})
end,
- })
+ }, player_name)
refill:set_size("main", 1)
end)
diff --git a/depends.txt b/depends.txt
index 3879b2c..20eb8b0 100644
--- a/depends.txt
+++ b/depends.txt
@@ -1,4 +1,6 @@
+default
creative?
+sfinv?
intllib?
datastorage?
farming?
diff --git a/init.lua b/init.lua
index e24fff2..76bc3ea 100644
--- a/init.lua
+++ b/init.lua
@@ -2,7 +2,15 @@
local modpath = minetest.get_modpath(minetest.get_current_modname())
local worldpath = minetest.get_worldpath()
-local mygettext = rawget(_G, "intllib") and intllib.Getter() or function(s) return s end
+local mygettext
+if rawget(_G, "intllib") then
+ mygettext = intllib.Getter()
+else
+ function mygettext(s, ...)
+ local t = { ... }
+ return (s:gsub("@(%d+)", function(n) return t[tonumber(n)] end))
+ end
+end
-- Data tables definitions
unified_inventory = {
@@ -33,7 +41,7 @@ unified_inventory = {
-- intllib
gettext = mygettext,
- fgettext = function(s) return minetest.formspec_escape(mygettext(s)) end,
+ fgettext = function(...) return minetest.formspec_escape(mygettext(...)) end,
-- "Lite" mode
lite_mode = minetest.setting_getbool("unified_inventory_lite"),
@@ -57,6 +65,12 @@ if creative then
end
end
+-- Disable sfinv inventory
+local sfinv = rawget(_G, "sfinv")
+if sfinv then
+ sfinv.enabled = false
+end
+
dofile(modpath.."/group.lua")
dofile(modpath.."/api.lua")
dofile(modpath.."/internal.lua")
@@ -69,4 +83,3 @@ dofile(modpath.."/item_names.lua")
if minetest.get_modpath("datastorage") then
dofile(modpath.."/waypoints.lua")
end
-
diff --git a/locale/de.txt b/locale/de.txt
index a2f7c3d..ad8009d 100644
--- a/locale/de.txt
+++ b/locale/de.txt
@@ -5,10 +5,7 @@ Digging (by chance) = Graben (durch Zufall)
### bags.lua ###
Bags = Taschen
-Bag 1 = Tasche 1
-Bag 2 = Tasche 2
-Bag 3 = Tasche 3
-Bag 4 = Tasche 4
+Bag @1 = Tasche @1
Small Bag = Kleine Tasche
Medium Bag = Mittelgroße Tasche
Large Bag = Große Tasche
diff --git a/locale/es.txt b/locale/es.txt
index 26508fb..d8c0dd6 100644
--- a/locale/es.txt
+++ b/locale/es.txt
@@ -1,12 +1,12 @@
# Translation by Diego Martínez <kaeza>
+### api.lua ###
+Digging (by chance) = Excavado (por azar)
+
# Template
### bags.lua ###
Bags = Bolsas
-Bag 1 = Bolsa 1
-Bag 2 = Bolsa 2
-Bag 3 = Bolsa 3
-Bag 4 = Bolsa 4
+Bag @1 = Bolsa @1
Small Bag = Bolsa Pequeña
Medium Bag = Bolsa Mediana
Large Bag = Bolsa Grande
diff --git a/locale/fr.txt b/locale/fr.txt
index e4923a0..43c52f0 100644
--- a/locale/fr.txt
+++ b/locale/fr.txt
@@ -3,10 +3,7 @@
# Template
### bags.lua ###
Bags = Sacs
-Bag 1 = Sac 1
-Bag 2 = Sac 2
-Bag 3 = Sac 3
-Bag 4 = Sac 4
+Bag @1 = Sac @1
Small Bag = Petit sac
Medium Bag = Sac moyen
Large Bag = Grand sac
diff --git a/locale/pl.txt b/locale/pl.txt
index 6173a5f..ef3e821 100644
--- a/locale/pl.txt
+++ b/locale/pl.txt
@@ -2,10 +2,7 @@
### bags.lua ###
Bags = Plecaki
-Bag 1 = Plecak 1
-Bag 2 = Plecak 2
-Bag 3 = Plecak 3
-Bag 4 = Plecak 4
+Bag @1 = Plecak @1
Small Bag = Maly plecak
Medium Bag = Sredni plecak
Large Bag = Duzy plecak
diff --git a/locale/ru.txt b/locale/ru.txt
index 821f2b1..a7bbe54 100644
--- a/locale/ru.txt
+++ b/locale/ru.txt
@@ -3,10 +3,7 @@
# Template
### bags.lua ###
Bags = Сумки
-Bag 1 = Сумка 1
-Bag 2 = Сумка 2
-Bag 3 = Сумка 3
-Bag 4 = Сумка 4
+Bag @1 = Сумка @1
Small Bag = Малая сумка
Medium Bag = Средняя сумка
Large Bag = Большая сумка
diff --git a/locale/template.txt b/locale/template.txt
index bd27f2f..0ea805b 100644
--- a/locale/template.txt
+++ b/locale/template.txt
@@ -6,10 +6,7 @@ Digging (by chance) =
# Template
### bags.lua ###
Bags =
-Bag 1 =
-Bag 2 =
-Bag 3 =
-Bag 4 =
+Bag @1 =
Small Bag =
Medium Bag =
Large Bag =
diff --git a/locale/tr.txt b/locale/tr.txt
index 138e66c..e171fd6 100644
--- a/locale/tr.txt
+++ b/locale/tr.txt
@@ -3,10 +3,7 @@
# Template
### bags.lua ###
Bags = Çantalarım
-Bag 1 = 1. Çanta
-Bag 2 = 2. Çanta
-Bag 3 = 3. Çanta
-Bag 4 = 4. Çanta
+Bag @1 = @1. Çanta
Small Bag = Küçük Çanta
Medium Bag = Çanta
Large Bag = Büyük Çanta
diff --git a/register.lua b/register.lua
index 9731832..f0c045c 100644
--- a/register.lua
+++ b/register.lua
@@ -249,6 +249,12 @@ unified_inventory.register_page("craftguide", {
formspec = formspec.."listcolors[#00000000;#00000000]"
local item_name = unified_inventory.current_item[player_name]
if not item_name then return {formspec=formspec} end
+ local item_name_shown
+ if minetest.registered_items[item_name] and minetest.registered_items[item_name].description then
+ item_name_shown = string.format(S("%s (%s)"), minetest.registered_items[item_name].description, item_name)
+ else
+ item_name_shown = item_name
+ end
local dir = unified_inventory.current_craft_direction[player_name]
local rdir
@@ -264,7 +270,7 @@ unified_inventory.register_page("craftguide", {
formspec = formspec.."background[0.5,"..(formspecy + 0.2)..";8,3;ui_craftguide_form.png]"
formspec = formspec.."textarea["..craftresultx..","..craftresulty
- ..";10,1;;"..minetest.formspec_escape(F(role_text[dir])..": "..item_name)..";]"
+ ..";10,1;;"..minetest.formspec_escape(F(role_text[dir])..": "..item_name_shown)..";]"
formspec = formspec..stack_image_button(0, formspecy, 1.1, 1.1, "item_button_"
.. rdir .. "_", ItemStack(item_name))
diff --git a/textures/ui_bags_trash.png b/textures/ui_bags_trash.png
new file mode 100644
index 0000000..6338999
--- /dev/null
+++ b/textures/ui_bags_trash.png
Binary files differ