diff --git a/app/Console/Commands/ClearDeletedCharacterAttachments.php b/app/Console/Commands/ClearDeletedCharacterAttachments.php new file mode 100644 index 0000000000..daeb1f98d9 --- /dev/null +++ b/app/Console/Commands/ClearDeletedCharacterAttachments.php @@ -0,0 +1,62 @@ +whereNotNull('deleted_at')->pluck('id'); + + // Delete their held currencies + CharacterCurrency::whereIn('character_id', $deletedCharacterIds)->delete(); + + // Delete their character images + CharacterImage::whereIn('character_id', $deletedCharacterIds)->delete(); + + // Get all deleted character images + $deletedImageIds = DB::table('character_images')->whereNotNull('deleted_at')->pluck('id'); + + // Delete their features + CharacterFeature::whereIn('character_image_id', $deletedImageIds)->delete(); + } +} diff --git a/app/Services/CharacterManager.php b/app/Services/CharacterManager.php index 767d7c719b..cdace3ef3a 100644 --- a/app/Services/CharacterManager.php +++ b/app/Services/CharacterManager.php @@ -17,6 +17,7 @@ use App\Models\User\User; use App\Models\User\UserItem; use App\Models\Character\Character; +use App\Models\Character\CharacterCurrency; use App\Models\Character\CharacterCategory; use App\Models\Character\CharacterFeature; use App\Models\Character\CharacterImage; @@ -643,6 +644,8 @@ public function deleteImage($image, $user) try { if($image->character->character_image_id == $image->id) throw new \Exception("Cannot delete a character's active image."); + $image->features()->delete(); + $image->delete(); // Delete the image files @@ -1025,11 +1028,25 @@ public function deleteCharacter($character, $user) if($character->user_id) { $character->user->settings->{$character->is_myo_slot ? 'myo_slot_count' : 'character_count'}--; $character->user->settings->save(); - } + } // Delete associated bookmarks CharacterBookmark::where('character_id', $character->id)->delete(); + // Delete associated features and images + // Images use soft deletes + foreach($character->images as $image) { + $image->features()->delete(); + $image->delete(); + } + + // Delete associated currencies + CharacterCurrency::where('character_id', $character->id)->delete(); + + // Delete associated design updates + // Design updates use soft deletes + CharacterDesignUpdate::where('character_id', $character->id)->delete(); + // Delete character // This is a soft delete, so the character still kind of exists $character->delete(); diff --git a/app/Services/CurrencyManager.php b/app/Services/CurrencyManager.php index 25cdfa683e..c101ffb39a 100644 --- a/app/Services/CurrencyManager.php +++ b/app/Services/CurrencyManager.php @@ -95,7 +95,7 @@ public function grantCharacterCurrencies($data, $character, $staff) // Process currency $currency = Currency::find($data['currency_id']); if(!$currency) throw new \Exception("Invalid currency selected."); - if(!$currency->is_user_owned) throw new \Exception("This currency cannot be held by characters."); + if(!$currency->is_character_owned) throw new \Exception("This currency cannot be held by characters."); if($data['quantity'] < 0) { $this->debitCurrency($character, $staff, 'Staff Removal', $data['data'], $currency, -$data['quantity']); Notifications::create('CHARACTER_CURRENCY_REMOVAL', $character->user, [ diff --git a/database/migrations/2019_04_13_094613_add_owned_currencies.php b/database/migrations/2019_04_13_094613_add_owned_currencies.php index 7b974c84a2..7e1092b79c 100644 --- a/database/migrations/2019_04_13_094613_add_owned_currencies.php +++ b/database/migrations/2019_04_13_094613_add_owned_currencies.php @@ -20,7 +20,7 @@ public function up() $table->integer('currency_id')->unsigned(); $table->integer('quantity')->unsigned()->default(0); - $table->unique(['user_id', 'currency_id']); + //$table->unique(['user_id', 'currency_id']); $table->primary(['user_id', 'currency_id']); $table->foreign('user_id')->references('id')->on('users'); @@ -32,7 +32,7 @@ public function up() $table->integer('currency_id')->unsigned(); $table->integer('quantity')->unsigned()->default(0); - $table->unique(['character_id', 'currency_id']); + //$table->unique(['character_id', 'currency_id']); $table->primary(['character_id', 'currency_id']); $table->foreign('character_id')->references('id')->on('characters'); diff --git a/database/migrations/2020_04_25_114747_drop_log_foreign_keys.php b/database/migrations/2020_04_25_114747_drop_log_foreign_keys.php new file mode 100644 index 0000000000..44b5c5bf10 --- /dev/null +++ b/database/migrations/2020_04_25_114747_drop_log_foreign_keys.php @@ -0,0 +1,37 @@ +dropForeign('banks_log_currency_id_foreign'); + }); + } + + /** + * Reverse the migrations. + * + * @return void + */ + public function down() + { + // This is not actually a very accurate opposite of the above, + // as the old index was created when the table was called banks, + // and this will generate a different index name + Schema::table('currencies_log', function(Blueprint $table) { + $table->foreign('currency_id')->references('id')->on('currencies'); + }); + } +} diff --git a/public/css/lorekeeper.css b/public/css/lorekeeper.css index 11f60100fe..2239c95cad 100644 --- a/public/css/lorekeeper.css +++ b/public/css/lorekeeper.css @@ -58,7 +58,7 @@ body { **************************************************************************************************/ .hide { - display: none; + display: none !important; } /************************************************************************************************** diff --git a/resources/views/admin/shops/_stock.blade.php b/resources/views/admin/shops/_stock.blade.php index fb6e2839c9..2776534f4e 100644 --- a/resources/views/admin/shops/_stock.blade.php +++ b/resources/views/admin/shops/_stock.blade.php @@ -2,17 +2,17 @@