mirror of
				https://gitlab.com/Kwoth/nadekobot.git
				synced 2025-11-04 08:34:27 -05:00 
			
		
		
		
	Added .xpshopbuy and .xpshopuse convenience commands
This commit is contained in:
		@@ -334,14 +334,15 @@ public partial class Xp : NadekoModule<XpService>
 | 
			
		||||
 | 
			
		||||
    public enum XpShopInputType
 | 
			
		||||
    {
 | 
			
		||||
        F = 0,
 | 
			
		||||
        Frs = 0,
 | 
			
		||||
        Fs = 0,
 | 
			
		||||
        Frames = 0,
 | 
			
		||||
        Backgrounds = 1,
 | 
			
		||||
        B = 1,
 | 
			
		||||
        Bg = 1,
 | 
			
		||||
        Bgs = 1,
 | 
			
		||||
        Backgrounds = 1
 | 
			
		||||
        Frames = 0,
 | 
			
		||||
        F = 0,
 | 
			
		||||
        Fr = 0,
 | 
			
		||||
        Frs = 0,
 | 
			
		||||
        Fs = 0,
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    [Cmd]
 | 
			
		||||
@@ -352,9 +353,12 @@ public partial class Xp : NadekoModule<XpService>
 | 
			
		||||
            await ReplyErrorLocalizedAsync(strs.xp_shop_disabled);
 | 
			
		||||
            return;
 | 
			
		||||
        }
 | 
			
		||||
        
 | 
			
		||||
        await SendConfirmAsync(GetText(strs.available_commands), $@"`{prefix}xpshop bgs`
 | 
			
		||||
`{prefix}xpshop frames`");
 | 
			
		||||
 | 
			
		||||
        await SendConfirmAsync(GetText(strs.available_commands),
 | 
			
		||||
            $@"`{prefix}xpshop bgs`
 | 
			
		||||
`{prefix}xpshop frames`
 | 
			
		||||
 | 
			
		||||
*{GetText(strs.xpshop_website)}*");
 | 
			
		||||
    }
 | 
			
		||||
    
 | 
			
		||||
    [Cmd]
 | 
			
		||||
@@ -394,15 +398,18 @@ public partial class Xp : NadekoModule<XpService>
 | 
			
		||||
                    .WithOkColor()
 | 
			
		||||
                    .WithTitle(item.Name)
 | 
			
		||||
                    .AddField(GetText(strs.price), Gambling.Gambling.N(item.Price, culture), true)
 | 
			
		||||
                    // .AddField(GetText(strs.buy), $"{prefix}xpbuy {key}", true)
 | 
			
		||||
                    .WithImageUrl(string.IsNullOrWhiteSpace(item.Preview)
 | 
			
		||||
                        ? item.Url
 | 
			
		||||
                        : item.Preview);
 | 
			
		||||
 | 
			
		||||
                if (!string.IsNullOrWhiteSpace(item.Desc))
 | 
			
		||||
                    eb.WithDescription(item.Desc);
 | 
			
		||||
                    eb.AddField(GetText(strs.desc), item.Desc);
 | 
			
		||||
 | 
			
		||||
                var tier = _service.GetXpShopTierRequirement();
 | 
			
		||||
                if (key == "default")
 | 
			
		||||
                    eb.WithDescription(GetText(strs.xpshop_website));
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
                var tier = _service.GetXpShopTierRequirement(type);
 | 
			
		||||
                if (tier != PatronTier.None)
 | 
			
		||||
                {
 | 
			
		||||
                    eb.WithFooter(GetText(strs.xp_shop_buy_required_tier(tier.ToString())));
 | 
			
		||||
@@ -456,6 +463,42 @@ public partial class Xp : NadekoModule<XpService>
 | 
			
		||||
            1,
 | 
			
		||||
            addPaginatedFooter: false);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    [Cmd]
 | 
			
		||||
    public async Task XpShopBuy(XpShopInputType type, string key)
 | 
			
		||||
    {
 | 
			
		||||
        var result = await _service.BuyShopItemAsync(ctx.User.Id, (XpShopItemType)type, key);
 | 
			
		||||
 | 
			
		||||
        if (result != BuyResult.Success)
 | 
			
		||||
        {
 | 
			
		||||
            var _ = result switch
 | 
			
		||||
            {
 | 
			
		||||
                BuyResult.InsufficientFunds => await ReplyErrorLocalizedAsync(strs.not_enough(_gss.Data.Currency.Sign)),
 | 
			
		||||
                BuyResult.AlreadyOwned => await ReplyErrorLocalizedAsync(strs.xpshop_already_owned),
 | 
			
		||||
                BuyResult.UnknownItem => await ReplyErrorLocalizedAsync(strs.xpshop_item_not_found),
 | 
			
		||||
                BuyResult.InsufficientPatronTier => await ReplyErrorLocalizedAsync(strs.patron_insuff_tier),
 | 
			
		||||
                _ => throw new ArgumentOutOfRangeException()
 | 
			
		||||
            };
 | 
			
		||||
            return;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        await ReplyConfirmLocalizedAsync(strs.xpshop_buy_success(type.ToString().ToLowerInvariant(),
 | 
			
		||||
            key.ToLowerInvariant()));
 | 
			
		||||
    }
 | 
			
		||||
    
 | 
			
		||||
    [Cmd]
 | 
			
		||||
    public async Task XpShopUse(XpShopInputType type, string key)
 | 
			
		||||
    {
 | 
			
		||||
        var result = await _service.UseShopItemAsync(ctx.User.Id, (XpShopItemType)type, key);
 | 
			
		||||
 | 
			
		||||
        if (!result)
 | 
			
		||||
        {
 | 
			
		||||
            await ReplyConfirmLocalizedAsync(strs.xp_shop_item_cant_use);
 | 
			
		||||
            return;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        await ctx.OkAsync();
 | 
			
		||||
    }
 | 
			
		||||
    
 | 
			
		||||
    private async Task OnShopUse(SocketMessageComponent smc, (string? key, XpShopItemType type)? maybeState)
 | 
			
		||||
    {
 | 
			
		||||
 
 | 
			
		||||
@@ -10,7 +10,7 @@ namespace NadekoBot.Modules.Xp;
 | 
			
		||||
public sealed partial class XpConfig : ICloneable<XpConfig>
 | 
			
		||||
{
 | 
			
		||||
    [Comment(@"DO NOT CHANGE")]
 | 
			
		||||
    public int Version { get; set; } = 4;
 | 
			
		||||
    public int Version { get; set; } = 5;
 | 
			
		||||
 | 
			
		||||
    [Comment(@"How much XP will the users receive per message")]
 | 
			
		||||
    public int XpPerMessage { get; set; } = 3;
 | 
			
		||||
@@ -37,9 +37,13 @@ True -> Users can access the xp shop using .xpshop command
 | 
			
		||||
False -> Users can't access the xp shop")]
 | 
			
		||||
        public bool IsEnabled { get; set; } = false;
 | 
			
		||||
 | 
			
		||||
        [Comment(@"Which patron tier do users need in order to use the .xpshop command
 | 
			
		||||
        [Comment(@"Which patron tier do users need in order to use the .xpshop bgs command
 | 
			
		||||
Leave at 'None' if patron system is disabled or you don't want any restrictions")]
 | 
			
		||||
        public PatronTier TierRequirement { get; set; } = PatronTier.None;
 | 
			
		||||
        public PatronTier BgsTierRequirement { get; set; } = PatronTier.None;
 | 
			
		||||
        
 | 
			
		||||
        [Comment(@"Which patron tier do users need in order to use the .xpshop frames command
 | 
			
		||||
Leave at 'None' if patron system is disabled or you don't want any restrictions")]
 | 
			
		||||
        public PatronTier FramesTierRequirement { get; set; } = PatronTier.None;
 | 
			
		||||
        
 | 
			
		||||
        [Comment(@"Frames available for sale. Keys are unique IDs.
 | 
			
		||||
Do not change keys as they are not publicly visible. Only change properties (name, price, id)
 | 
			
		||||
 
 | 
			
		||||
@@ -52,11 +52,11 @@ public sealed class XpConfigService : ConfigServiceBase<XpConfig>
 | 
			
		||||
            });
 | 
			
		||||
        }
 | 
			
		||||
        
 | 
			
		||||
        if (data.Version < 4)
 | 
			
		||||
        if (data.Version < 5)
 | 
			
		||||
        {
 | 
			
		||||
            ModifyConfig(c =>
 | 
			
		||||
            {
 | 
			
		||||
                c.Version = 4;
 | 
			
		||||
                c.Version = 5;
 | 
			
		||||
            });
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 
 | 
			
		||||
@@ -1351,11 +1351,15 @@ public class XpService : INService, IReadyExecutor, IExecNoCommand
 | 
			
		||||
        if (!conf.Shop.IsEnabled)
 | 
			
		||||
            return BuyResult.UnknownItem;
 | 
			
		||||
 | 
			
		||||
        if (conf.Shop.TierRequirement != PatronTier.None && !_creds.IsOwner(userId))
 | 
			
		||||
        var req = type == XpShopItemType.Background
 | 
			
		||||
            ? conf.Shop.BgsTierRequirement
 | 
			
		||||
            : conf.Shop.FramesTierRequirement;
 | 
			
		||||
        
 | 
			
		||||
        if (req != PatronTier.None && !_creds.IsOwner(userId))
 | 
			
		||||
        {
 | 
			
		||||
            var patron = await _ps.GetPatronAsync(userId);
 | 
			
		||||
 | 
			
		||||
            if ((int)patron.Tier < (int)conf.Shop.TierRequirement)
 | 
			
		||||
            if ((int)patron.Tier < (int)req)
 | 
			
		||||
                return BuyResult.InsufficientPatronTier;
 | 
			
		||||
        }
 | 
			
		||||
        
 | 
			
		||||
@@ -1482,8 +1486,12 @@ public class XpService : INService, IReadyExecutor, IExecNoCommand
 | 
			
		||||
        return false;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public PatronTier GetXpShopTierRequirement()
 | 
			
		||||
        => _xpConfig.Data.Shop.TierRequirement;
 | 
			
		||||
    public PatronTier GetXpShopTierRequirement(Xp.XpShopInputType type)
 | 
			
		||||
        => type switch
 | 
			
		||||
        {
 | 
			
		||||
            Xp.XpShopInputType.F => _xpConfig.Data.Shop.FramesTierRequirement,
 | 
			
		||||
            _ => _xpConfig.Data.Shop.BgsTierRequirement,
 | 
			
		||||
        };
 | 
			
		||||
 | 
			
		||||
    public bool IsShopEnabled()
 | 
			
		||||
        => _xpConfig.Data.Shop.IsEnabled;
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user