where('settlement_batch_id', $batch->id) ->with([ 'ticketItem:id,ticket_no,play_code,player_id', 'ticketItem.player:id,site_code,username,nickname,site_player_id', 'ticketItem.order:id,currency_code', ]) ->orderBy('id') ->paginate($p['perPage'], ['*'], 'page', $p['page']); return AdminApiList::jsonWith($paginator, function ($row) { /** @var TicketSettlementDetail $row */ $item = $row->ticketItem; $player = $item?->player; $order = $item?->order; return [ 'id' => (int) $row->id, 'ticket_item_id' => (int) $row->ticket_item_id, 'ticket_no' => $item?->ticket_no, 'play_code' => $item?->play_code, 'currency_code' => $order?->currency_code, 'player_id' => $item?->player_id, 'site_code' => $player?->site_code, 'site_player_id' => $player?->site_player_id, 'username' => $player?->username, 'nickname' => $player?->nickname, 'matched_prize_tier' => $row->matched_prize_tier, 'win_amount' => (int) $row->win_amount, 'jackpot_allocation_amount' => (int) $row->jackpot_allocation_amount, 'match_detail_json' => $row->match_detail_json, 'created_at' => $row->created_at?->toIso8601String(), ]; }, ['batch_id' => (int) $batch->id]); } }