diff options
-rw-r--r-- | app/controllers/pokeviewer/pokemon_controller.rb | 67 | ||||
-rw-r--r-- | app/views/pokeviewer/pokemon/index.html.haml | 12 |
2 files changed, 70 insertions, 9 deletions
diff --git a/app/controllers/pokeviewer/pokemon_controller.rb b/app/controllers/pokeviewer/pokemon_controller.rb index 17bd83d..f9f6c15 100644 --- a/app/controllers/pokeviewer/pokemon_controller.rb +++ b/app/controllers/pokeviewer/pokemon_controller.rb | |||
@@ -3,12 +3,73 @@ require_dependency "pokeviewer/application_controller" | |||
3 | module Pokeviewer | 3 | module Pokeviewer |
4 | class PokemonController < ApplicationController | 4 | class PokemonController < ApplicationController |
5 | def index | 5 | def index |
6 | @trainers = Trainer.all | 6 | pokemon = Pokemon.joins(:revisions). |
7 | @unaccounted = Pokemon.where(trainer: nil) | 7 | order("trainer_id IS NULL DESC"). |
8 | order(trainer_id: :asc). | ||
9 | order(box: :asc). | ||
10 | order(slot: :asc). | ||
11 | order("pokeviewer_revisions.sequential_id DESC"). | ||
12 | group("pokeviewer_pokemon.uuid"). | ||
13 | select(:box, :slot, :uuid, :trainer_id, :species_id). | ||
14 | select(:ot_gender, :ot_name, :unown_letter). | ||
15 | select("pokeviewer_revisions.nickname AS nickname"). | ||
16 | chunk do |p| | ||
17 | if p.trainer_id.nil? | ||
18 | -1 | ||
19 | else | ||
20 | p.trainer_id | ||
21 | end | ||
22 | end | ||
23 | |||
24 | if pokemon.peek.first == -1 | ||
25 | @unaccounted = pokemon.next.second | ||
26 | else | ||
27 | @unaccounted = [] | ||
28 | end | ||
29 | |||
30 | @trainers = Trainer.order(id: :asc).all.map do |trainer| | ||
31 | if trainer.id == pokemon.peek.first | ||
32 | party = [] | ||
33 | |||
34 | boxes = (1..14).map do |i| | ||
35 | { | ||
36 | name: trainer.box_name(i), | ||
37 | pokemon: [nil] * 30 | ||
38 | } | ||
39 | end | ||
40 | |||
41 | pokemon.next.second.chunk do |p| | ||
42 | if p.box.nil? | ||
43 | -1 | ||
44 | else | ||
45 | p.box | ||
46 | end | ||
47 | end.each do |box, pokes| | ||
48 | if box == -1 | ||
49 | party = pokes | ||
50 | else | ||
51 | boxes[box-1][:pokemon] = (0..29).map do |i| | ||
52 | if not pokes.empty? and (pokes.first.slot == i) | ||
53 | pokes.shift | ||
54 | else | ||
55 | nil | ||
56 | end | ||
57 | end | ||
58 | end | ||
59 | end | ||
60 | |||
61 | [trainer, party, boxes] | ||
62 | else | ||
63 | nil | ||
64 | end | ||
65 | end.compact | ||
8 | end | 66 | end |
9 | 67 | ||
10 | def show | 68 | def show |
11 | @pokemon = Pokemon.find_by_uuid! params[:id] | 69 | @pokemon = Pokemon.includes( |
70 | :trainer, :species, :location, | ||
71 | revisions: [:item, :move_1, :move_2, :move_3, :move_4] | ||
72 | ).find_by_uuid! params[:id] | ||
12 | end | 73 | end |
13 | end | 74 | end |
14 | end | 75 | end |
diff --git a/app/views/pokeviewer/pokemon/index.html.haml b/app/views/pokeviewer/pokemon/index.html.haml index 0be3edd..e1793dc 100644 --- a/app/views/pokeviewer/pokemon/index.html.haml +++ b/app/views/pokeviewer/pokemon/index.html.haml | |||
@@ -1,4 +1,4 @@ | |||
1 | - @trainers.each do |trainer| | 1 | - @trainers.each do |trainer, party, boxes| |
2 | .trainer | 2 | .trainer |
3 | .trainer-info{ class: trainer.game } | 3 | .trainer-info{ class: trainer.game } |
4 | %h2= trainer.name | 4 | %h2= trainer.name |
@@ -6,11 +6,11 @@ | |||
6 | .pc-boxes | 6 | .pc-boxes |
7 | %ul.party.pc-box | 7 | %ul.party.pc-box |
8 | %h3 Party | 8 | %h3 Party |
9 | - trainer.party.each do |p| | 9 | - party.each do |p| |
10 | %li | 10 | %li |
11 | %span.party-icon= image_tag p.icon_path | 11 | %span.party-icon= image_tag p.icon_path |
12 | %span.party-name= link_to p.revisions.last.nickname, p | 12 | %span.party-name= link_to p.nickname, p |
13 | - trainer.boxes.each do |box| | 13 | - boxes.each do |box| |
14 | .pc-box | 14 | .pc-box |
15 | %h3= box[:name] | 15 | %h3= box[:name] |
16 | %table.pc-contents | 16 | %table.pc-contents |
@@ -23,7 +23,7 @@ | |||
23 | - else | 23 | - else |
24 | = link_to image_tag(p.icon_path), p | 24 | = link_to image_tag(p.icon_path), p |
25 | .pc-data.pkv-hover | 25 | .pc-data.pkv-hover |
26 | .pc-data-name= p.revisions.last.nickname | 26 | .pc-data-name= p.nickname |
27 | .pc-data-ot | 27 | .pc-data-ot |
28 | OT/ | 28 | OT/ |
29 | %span{ class: p.ot_gender }>= p.ot_name | 29 | %span{ class: p.ot_gender }>= p.ot_name |
@@ -36,7 +36,7 @@ | |||
36 | %li.pc-pokemon.pkv-has-hover | 36 | %li.pc-pokemon.pkv-has-hover |
37 | = link_to image_tag(p.icon_path), p | 37 | = link_to image_tag(p.icon_path), p |
38 | .pc-data.pkv-hover | 38 | .pc-data.pkv-hover |
39 | .pc-data-name= p.revisions.last.nickname | 39 | .pc-data-name= p.nickname |
40 | .pc-data-ot | 40 | .pc-data-ot |
41 | OT/ | 41 | OT/ |
42 | %span{ class: p.ot_gender }>= p.ot_name | 42 | %span{ class: p.ot_gender }>= p.ot_name |