diff --git a/app/controllers/items_controller.rb b/app/controllers/items_controller.rb index 179343e13..582ce5e91 100644 --- a/app/controllers/items_controller.rb +++ b/app/controllers/items_controller.rb @@ -99,8 +99,7 @@ class ItemsController < ApplicationController @all_appearances = @item.appearances @appearances_by_occupied_zone_label = - @item.appearances_by_occupied_zone. - transform_keys(&:label).sort_by { |l, a| l } + @item.appearances_by_occupied_zone_label.sort_by { |l, a| l } @selected_item_appearance = @preview_outfit.item_appearances.first @preview_pet_type_options = PetType.where(color: @preview_outfit.color). diff --git a/app/models/item.rb b/app/models/item.rb index 7fcce27ae..f6d553449 100644 --- a/app/models/item.rb +++ b/app/models/item.rb @@ -592,22 +592,19 @@ class Item < ApplicationRecord Item.appearances_for([self], target, ...)[id] end - def appearances_by_occupied_zone_id + def appearances_by_occupied_zone_label + zones_by_id = occupied_zones.to_h { |z| [z.id, z] } {}.tap do |h| appearances.each do |appearance| appearance.occupied_zone_ids.each do |zone_id| - h[zone_id] ||= [] - h[zone_id] << appearance + zone_label = zones_by_id[zone_id].label + h[zone_label] ||= [] + h[zone_label] << appearance end end end end - def appearances_by_occupied_zone - zones_by_id = occupied_zones.to_h { |z| [z.id, z] } - appearances_by_occupied_zone_id.transform_keys { |zid| zones_by_id[zid] } - end - # Given a list of items, return how they look on the given target (either a # pet type or an alt style). def self.appearances_for(items, target, swf_asset_includes: [])