|
10 | 10 |
|
11 | 11 | function PL_UTIL.add_booster_pack() |
12 | 12 | if not G.shop then return end |
13 | | - local pack_watch = {} |
14 | | - for k, v in pairs(G.P_CENTERS) do |
15 | | - if v.set == 'Booster' then |
16 | | - table.insert(pack_watch, k) |
17 | | - end |
18 | | - end |
19 | | - local pack_chosen = pseudorandom_element(pack_watch, pseudoseed('pl_pop_up')) |
20 | | - local pack = Card( |
21 | | - G.shop_booster.T.x + G.shop_booster.T.w / 2, |
22 | | - G.shop_booster.T.y, |
23 | | - G.CARD_W * 1.27, G.CARD_H * 1.27, |
24 | | - G.P_CARDS.empty, |
25 | | - G.P_CENTERS[pack_chosen], |
26 | | - { bypass_discovery_center = true, bypass_discovery_ui = true } |
27 | | - ) |
28 | | - if price then |
29 | | - pack.cost = price |
30 | | - end |
| 13 | + local pack = SMODS.create_card({ set = 'Booster', key_append = 'pl_popup'..G.GAME.round_resets.ante }) |
| 14 | + pack.T.w = G.CARD_W * 1.27 |
| 15 | + pack.T.h = G.CARD_H * 1.27 |
| 16 | + |
| 17 | + G.shop_booster:emplace(pack) |
| 18 | + |
31 | 19 | create_shop_card_ui(pack, 'Booster', G.shop_booster) |
32 | 20 | pack:start_materialize() |
33 | | - G.shop_booster:emplace(pack) |
| 21 | + pack:set_card_area(G.shop_booster) |
| 22 | + pack:juice_up() |
34 | 23 | end |
35 | 24 |
|
36 | | -function PL_UTIL.reroll_booster_pack(position) |
| 25 | +function PL_UTIL.reroll_booster_packs() |
37 | 26 | if not G.shop then return end |
38 | | - if #G.shop_booster.cards <= 0 then return end |
39 | | - |
40 | | - local booster_to_replace = G.shop_booster.cards[position] |
41 | 27 |
|
42 | | - local pack_watch = {} |
43 | | - for k, v in pairs(G.P_CENTERS) do |
44 | | - if v.set == 'Booster' then |
45 | | - table.insert(pack_watch, k) |
46 | | - end |
47 | | - end |
| 28 | + local pack_count = #G.shop_booster.cards |
48 | 29 |
|
49 | | - local pack_chosen = pseudorandom_element(pack_watch, pseudoseed(('pl_booster_reroll')..G.GAME.round_resets.ante)) |
| 30 | + if pack_count <= 0 then return end |
50 | 31 |
|
51 | | - local pack = Card( |
52 | | - G.shop_booster.T.x + G.shop_booster.T.w / 2, |
53 | | - G.shop_booster.T.y, |
54 | | - G.CARD_W * 1.27, G.CARD_H * 1.27, |
55 | | - G.P_CARDS.empty, |
56 | | - G.P_CENTERS[pack_chosen], |
57 | | - { bypass_discovery_center = true, bypass_discovery_ui = true } |
58 | | - ) |
| 32 | + for i=1, pack_count do |
| 33 | + |
| 34 | + local booster_to_replace = G.shop_booster.cards[i] |
59 | 35 |
|
60 | | - if price then |
61 | | - pack.cost = price |
62 | | - end |
| 36 | + local pack = SMODS.create_card({ set = 'Booster', key_append = 'pl_booster_reroll'..G.GAME.round_resets.ante }) |
| 37 | + pack.T.w = G.CARD_W * 1.27 |
| 38 | + pack.T.h = G.CARD_H * 1.27 |
63 | 39 |
|
64 | | - create_shop_card_ui(pack, 'Booster', G.shop_booster) |
65 | | - pack:start_materialize() |
| 40 | + table.insert(G.shop_booster.cards, i, pack) |
66 | 41 |
|
67 | | - local pack_pos = 1 |
68 | | - for k, v in ipairs(G.shop_booster.cards) do |
69 | | - if v == booster_to_replace then |
70 | | - pack_pos = k |
71 | | - end |
72 | | - end |
| 42 | + create_shop_card_ui(pack, 'Booster', G.shop_booster) |
| 43 | + pack:start_materialize() |
| 44 | + pack:set_card_area(G.shop_booster) |
| 45 | + pack:juice_up() |
73 | 46 |
|
74 | | - table.insert(G.shop_booster.cards, pack_pos, pack) |
75 | | - pack:set_card_area(G.shop_booster) |
76 | | - pack:juice_up() |
| 47 | + local c = G.shop_booster:remove_card(booster_to_replace) |
| 48 | + c:remove() |
| 49 | + c = nil |
77 | 50 |
|
78 | | - local c = G.shop_booster:remove_card(booster_to_replace) |
79 | | - c:remove() |
80 | | - c = nil |
| 51 | + end |
81 | 52 |
|
82 | 53 | end |
83 | 54 |
|
|
0 commit comments