diff --git a/pom.xml b/pom.xml
index b27c7ff..d797964 100644
--- a/pom.xml
+++ b/pom.xml
@@ -6,7 +6,7 @@
me.sat7
DynamicShop
- 3.6.1
+ 3.6.2
jar
DynamicShop
diff --git a/src/main/java/me/sat7/dynamicshop/commands/Shop.java b/src/main/java/me/sat7/dynamicshop/commands/Shop.java
index 7ac9128..d476aae 100644
--- a/src/main/java/me/sat7/dynamicshop/commands/Shop.java
+++ b/src/main/java/me/sat7/dynamicshop/commands/Shop.java
@@ -125,27 +125,14 @@ static void shopCommand(String[] args, CommandSender sender)
int curTime = (int) (player.getWorld().getTime()) / 1000 + 6;
if (curTime > 24) curTime -= 24;
- String[] temp = shopConf.getString("shophours").split("~");
-
- int open = Integer.parseInt(temp[0]);
- int close = Integer.parseInt(temp[1]);
-
- if (close > open)
- {
- if (!(open <= curTime && curTime < close))
- {
- player.sendMessage(DynamicShop.dsPrefix(player) + t(player, "TIME.SHOP_IS_CLOSED").
- replace("{time}", open + "").replace("{curTime}", curTime + ""));
- return;
- }
- } else
+ if (!ShopUtil.CheckShopHour(shopName, player))
{
- if (!(open <= curTime || curTime < close))
- {
- player.sendMessage(DynamicShop.dsPrefix(player) + t(player, "TIME.SHOP_IS_CLOSED").
- replace("{time}", open + "").replace("{curTime}", curTime + ""));
- return;
- }
+ String[] temp = shopConf.getString("shophours").split("~");
+ int open = Integer.parseInt(temp[0]);
+
+ player.sendMessage(DynamicShop.dsPrefix(player) + t(player, "TIME.SHOP_IS_CLOSED").
+ replace("{time}", open + "").replace("{curTime}", curTime + ""));
+ return;
}
}
diff --git a/src/main/java/me/sat7/dynamicshop/utilities/ShopUtil.java b/src/main/java/me/sat7/dynamicshop/utilities/ShopUtil.java
index 3fb5946..f803cd4 100644
--- a/src/main/java/me/sat7/dynamicshop/utilities/ShopUtil.java
+++ b/src/main/java/me/sat7/dynamicshop/utilities/ShopUtil.java
@@ -549,6 +549,7 @@ public static String[] FindTheBestShopToSell(Player player, ItemStack itemStack)
continue;
}
+ // 비활성화된 상점
boolean enable = data.get().getBoolean("Options.enable", true);
if (!enable)
continue;
@@ -557,6 +558,10 @@ public static String[] FindTheBestShopToSell(Player player, ItemStack itemStack)
if (data.get().contains("Options.flag.localshop") || data.get().contains("Options.flag.signshop") || data.get().contains("Options.flag.jobpoint"))
continue;
+ // 영업시간 확인
+ if (!CheckShopHour(entry.getKey(), player))
+ continue;
+
int sameItemIdx = ShopUtil.findItemFromShop(entry.getKey(), itemStack);
if (sameItemIdx != -1)
@@ -608,6 +613,7 @@ public static String[] FindTheBestShopToBuy(Player player, ItemStack itemStack)
continue;
}
+ // 비활성화된 상점
boolean enable = data.get().getBoolean("Options.enable", true);
if (!enable)
continue;
@@ -616,6 +622,10 @@ public static String[] FindTheBestShopToBuy(Player player, ItemStack itemStack)
if (data.get().contains("Options.flag.localshop") || data.get().contains("Options.flag.signshop") || data.get().contains("Options.flag.jobpoint"))
continue;
+ // 영업시간 확인
+ if (!CheckShopHour(entry.getKey(), player))
+ continue;
+
int sameItemIdx = ShopUtil.findItemFromShop(entry.getKey(), itemStack);
if (sameItemIdx != -1)
@@ -917,4 +927,33 @@ public static int StockStabilizing(Boolean isLegacyMode, Random generator,int st
return stock;
}
+
+ public static boolean CheckShopHour(String shopName, Player player)
+ {
+ CustomConfig shopData = ShopUtil.shopConfigFiles.get(shopName);
+ ConfigurationSection shopConf = shopData.get().getConfigurationSection("Options");
+
+ if (shopConf.contains("shophours"))
+ {
+ int curTimeHour = (int) (player.getWorld().getTime()) / 1000 + 6;
+ if (curTimeHour > 24) curTimeHour -= 24;
+
+ String[] temp = shopConf.getString("shophours").split("~");
+
+ int open = Integer.parseInt(temp[0]);
+ int close = Integer.parseInt(temp[1]);
+
+ if (close > open)
+ {
+ return open <= curTimeHour && curTimeHour < close;
+ } else
+ {
+ return open <= curTimeHour || curTimeHour < close;
+ }
+ }
+ else
+ {
+ return true;
+ }
+ }
}