diff --git a/src/Notifications/Corporations/Discord/CorpAppNewMsg.php b/src/Notifications/Corporations/Discord/CorpAppNewMsg.php index 4da39d4..539c7a4 100644 --- a/src/Notifications/Corporations/Discord/CorpAppNewMsg.php +++ b/src/Notifications/Corporations/Discord/CorpAppNewMsg.php @@ -73,7 +73,7 @@ public function populateMessage(DiscordMessage $message, $notifiable) $embed->field(function (DiscordEmbedField $field) { $field - ->name('Character Name') + ->name('Corporation Name') ->long(); $entity = UniverseName::find($this->notification->text['corpID']); diff --git a/src/Notifications/Structures/Discord/StructureFuelAlert.php b/src/Notifications/Structures/Discord/StructureFuelAlert.php index cfdf2d6..5a2c0f0 100644 --- a/src/Notifications/Structures/Discord/StructureFuelAlert.php +++ b/src/Notifications/Structures/Discord/StructureFuelAlert.php @@ -25,6 +25,7 @@ use Seat\Eveapi\Models\Character\CharacterNotification; use Seat\Eveapi\Models\Sde\InvType; use Seat\Eveapi\Models\Sde\MapDenormalize; +use Seat\Eveapi\Models\Universe\UniverseStructure; use Seat\Notifications\Notifications\AbstractDiscordNotification; use Seat\Notifications\Services\Discord\Messages\DiscordEmbed; use Seat\Notifications\Services\Discord\Messages\DiscordEmbedField; @@ -70,10 +71,26 @@ public function populateMessage(DiscordMessage $message, $notifiable): void }); $embed->field(function (DiscordEmbedField $field) { + // Find the structure by its ID from the notification data. + // If the structure ID exists in the notification, retrieve it from the UniverseStructure model. + $structure = UniverseStructure::find($this->notification->text['structureID']); + + // Retrieve the structure's type information using the structureShowInfoData from the notification. + // The second index ([1]) contains the type ID which is used to look up the structure type from the InvType model. $type = InvType::find($this->notification->text['structureShowInfoData'][1]); - $field->name('Structure') - ->value($type->typeName); + // Initialize a default title for the structure field as 'Structure'. + $title = 'Structure'; + + // If a structure is found (i.e., it's not null), set the title to the name of the structure. + if (! is_null($structure)) { + $title = $structure->name; + } + + // Set the field's name to the title (either 'Structure' or the structure's actual name). + // Set the field's value to a zKillboard link, formatted for Discord. This uses the structure's type ID and name. + $field->name($title) + ->value($this->zKillBoardToDiscordLink('ship', $type->typeID, $type->typeName)); }); }) ->embed(function (DiscordEmbed $embed) { diff --git a/src/Notifications/Structures/Discord/StructureWentHighPower.php b/src/Notifications/Structures/Discord/StructureWentHighPower.php index 1777366..8a59472 100644 --- a/src/Notifications/Structures/Discord/StructureWentHighPower.php +++ b/src/Notifications/Structures/Discord/StructureWentHighPower.php @@ -25,6 +25,7 @@ use Seat\Eveapi\Models\Character\CharacterNotification; use Seat\Eveapi\Models\Sde\InvType; use Seat\Eveapi\Models\Sde\MapDenormalize; +use Seat\Eveapi\Models\Universe\UniverseStructure; use Seat\Notifications\Notifications\AbstractDiscordNotification; use Seat\Notifications\Services\Discord\Messages\DiscordEmbed; use Seat\Notifications\Services\Discord\Messages\DiscordEmbedField; @@ -74,12 +75,25 @@ public function populateMessage(DiscordMessage $message, $notifiable): void }); $embed->field(function (DiscordEmbedField $field) { - $type = InvType::firstOrNew( - ['typeID' => $this->notification->text['structureTypeID']], - ['typeName' => trans('web::seat.unknown')] - ); + // Find the structure by its ID from the notification data. + // If the structure ID exists in the notification, retrieve it from the UniverseStructure model. + $structure = UniverseStructure::find($this->notification->text['structureID']); + + // Retrieve the structure's type information using the structureShowInfoData from the notification. + // The second index ([1]) contains the type ID which is used to look up the structure type from the InvType model. + $type = InvType::find($this->notification->text['structureShowInfoData'][1]); + + // Initialize a default title for the structure field as 'Structure'. + $title = 'Structure'; + + // If a structure is found (i.e., it's not null), set the title to the name of the structure. + if (! is_null($structure)) { + $title = $structure->name; + } - $field->name('Structure') + // Set the field's name to the title (either 'Structure' or the structure's actual name). + // Set the field's value to a zKillboard link, formatted for Discord. This uses the structure's type ID and name. + $field->name($title) ->value($this->zKillBoardToDiscordLink('ship', $type->typeID, $type->typeName)); }); });