diff options
-rw-r--r-- | app/jobs/pokeviewer/extract_save_data_job.rb | 6 | ||||
-rw-r--r-- | app/models/pokeviewer/box.rb | 29 | ||||
-rw-r--r-- | app/models/pokeviewer/trainer.rb | 20 | ||||
-rw-r--r-- | app/views/pokeviewer/pokemon/index.html.haml | 6 | ||||
-rw-r--r-- | db/migrate/20170924224550_create_pokeviewer_boxes.rb | 15 | ||||
-rw-r--r-- | test/dummy/db/schema.rb | 12 |
6 files changed, 65 insertions, 23 deletions
diff --git a/app/jobs/pokeviewer/extract_save_data_job.rb b/app/jobs/pokeviewer/extract_save_data_job.rb index 404716a..3409a5f 100644 --- a/app/jobs/pokeviewer/extract_save_data_job.rb +++ b/app/jobs/pokeviewer/extract_save_data_job.rb | |||
@@ -22,6 +22,12 @@ module Pokeviewer | |||
22 | end | 22 | end |
23 | end | 23 | end |
24 | 24 | ||
25 | args["boxes"].each_with_index do |box_name,index| | ||
26 | box = Box.find_or_initialize_by(trainer: game, number: index) | ||
27 | box.name = box_name | ||
28 | box.save! | ||
29 | end | ||
30 | |||
25 | game.pokemon.clear | 31 | game.pokemon.clear |
26 | 32 | ||
27 | args["pokemon"].each do |param| | 33 | args["pokemon"].each do |param| |
diff --git a/app/models/pokeviewer/box.rb b/app/models/pokeviewer/box.rb new file mode 100644 index 0000000..090175e --- /dev/null +++ b/app/models/pokeviewer/box.rb | |||
@@ -0,0 +1,29 @@ | |||
1 | module Pokeviewer | ||
2 | class Box < ApplicationRecord | ||
3 | belongs_to :trainer | ||
4 | |||
5 | validates :name, presence: true | ||
6 | |||
7 | validates :number, presence: true, | ||
8 | numericality: { | ||
9 | greater_than_or_equal_to: 0, | ||
10 | less_than: 14, | ||
11 | only_integer: true }, | ||
12 | uniqueness: { scope: :trainer_id } | ||
13 | |||
14 | def contents | ||
15 | pokes = trainer.pokemon.where(box: number).order("slot ASC").to_a | ||
16 | |||
17 | result = [] | ||
18 | (0..29).each do |i| | ||
19 | if pokes.empty? or (pokes.first.slot == i) | ||
20 | result << pokes.shift | ||
21 | else | ||
22 | result << nil | ||
23 | end | ||
24 | end | ||
25 | |||
26 | result | ||
27 | end | ||
28 | end | ||
29 | end | ||
diff --git a/app/models/pokeviewer/trainer.rb b/app/models/pokeviewer/trainer.rb index d3a5b91..f890d61 100644 --- a/app/models/pokeviewer/trainer.rb +++ b/app/models/pokeviewer/trainer.rb | |||
@@ -3,6 +3,7 @@ module Pokeviewer | |||
3 | extend Enumerize | 3 | extend Enumerize |
4 | 4 | ||
5 | has_many :pokemon, dependent: :nullify | 5 | has_many :pokemon, dependent: :nullify |
6 | has_many :boxes, -> { order("number ASC") }, dependent: :destroy | ||
6 | 7 | ||
7 | validates :number, presence: true, | 8 | validates :number, presence: true, |
8 | numericality: { greater_than_or_equal_to: 0, only_integer: true } | 9 | numericality: { greater_than_or_equal_to: 0, only_integer: true } |
@@ -22,24 +23,5 @@ module Pokeviewer | |||
22 | def party | 23 | def party |
23 | pokemon.where(box: nil).order("slot ASC") | 24 | pokemon.where(box: nil).order("slot ASC") |
24 | end | 25 | end |
25 | |||
26 | def boxes | ||
27 | (0..13).map { |i| box(i) } | ||
28 | end | ||
29 | |||
30 | def box(number) | ||
31 | pokes = pokemon.where(box: number).order("slot ASC").to_a | ||
32 | |||
33 | result = [] | ||
34 | (0..29).each do |i| | ||
35 | if pokes.empty? or (pokes.first.slot == i) | ||
36 | result << pokes.shift | ||
37 | else | ||
38 | result << nil | ||
39 | end | ||
40 | end | ||
41 | |||
42 | result | ||
43 | end | ||
44 | end | 26 | end |
45 | end | 27 | end |
diff --git a/app/views/pokeviewer/pokemon/index.html.haml b/app/views/pokeviewer/pokemon/index.html.haml index 69b6a68..e536080 100644 --- a/app/views/pokeviewer/pokemon/index.html.haml +++ b/app/views/pokeviewer/pokemon/index.html.haml | |||
@@ -10,11 +10,11 @@ | |||
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.revisions.last.nickname, p |
13 | - trainer.boxes.each_with_index do |box,bid| | 13 | - trainer.boxes.each do |box| |
14 | .pc-box | 14 | .pc-box |
15 | %h3= "Box #{bid+1}" | 15 | %h3= box.name |
16 | %table.pc-contents | 16 | %table.pc-contents |
17 | - box.each_slice(6) do |row| | 17 | - box.contents.each_slice(6) do |row| |
18 | %tr | 18 | %tr |
19 | - row.each do |p| | 19 | - row.each do |p| |
20 | %td.pc-pokemon | 20 | %td.pc-pokemon |
diff --git a/db/migrate/20170924224550_create_pokeviewer_boxes.rb b/db/migrate/20170924224550_create_pokeviewer_boxes.rb new file mode 100644 index 0000000..02f6fa9 --- /dev/null +++ b/db/migrate/20170924224550_create_pokeviewer_boxes.rb | |||
@@ -0,0 +1,15 @@ | |||
1 | class CreatePokeviewerBoxes < ActiveRecord::Migration[5.1] | ||
2 | def change | ||
3 | create_table :pokeviewer_boxes do |t| | ||
4 | t.references :trainer, null: false | ||
5 | t.integer :number, null: false | ||
6 | t.string :name, null: false | ||
7 | |||
8 | t.timestamps | ||
9 | end | ||
10 | |||
11 | add_foreign_key :pokeviewer_boxes, :pokeviewer_trainer, column: :trainer_id | ||
12 | |||
13 | add_index :pokeviewer_boxes, [:trainer_id, :number], unique: true | ||
14 | end | ||
15 | end | ||
diff --git a/test/dummy/db/schema.rb b/test/dummy/db/schema.rb index 9a13685..e7322e9 100644 --- a/test/dummy/db/schema.rb +++ b/test/dummy/db/schema.rb | |||
@@ -10,7 +10,17 @@ | |||
10 | # | 10 | # |
11 | # It's strongly recommended that you check this file into your version control system. | 11 | # It's strongly recommended that you check this file into your version control system. |
12 | 12 | ||
13 | ActiveRecord::Schema.define(version: 20170924160524) do | 13 | ActiveRecord::Schema.define(version: 20170924224550) do |
14 | |||
15 | create_table "pokeviewer_boxes", force: :cascade do |t| | ||
16 | t.integer "trainer_id", null: false | ||
17 | t.integer "number", null: false | ||
18 | t.string "name", null: false | ||
19 | t.datetime "created_at", null: false | ||
20 | t.datetime "updated_at", null: false | ||
21 | t.index ["trainer_id", "number"], name: "index_pokeviewer_boxes_on_trainer_id_and_number", unique: true | ||
22 | t.index ["trainer_id"], name: "index_pokeviewer_boxes_on_trainer_id" | ||
23 | end | ||
14 | 24 | ||
15 | create_table "pokeviewer_moves", force: :cascade do |t| | 25 | create_table "pokeviewer_moves", force: :cascade do |t| |
16 | t.string "name", limit: 191, null: false | 26 | t.string "name", limit: 191, null: false |