diff --git a/Gemfile b/Gemfile index 9a25d6ac8..feef7ff2b 100644 --- a/Gemfile +++ b/Gemfile @@ -68,6 +68,9 @@ gem "strong_migrations", "~> 1.7" # Soft Deletion gem "discard", "~> 1.2" +# JSON models +gem "store_model" + # ActiveModel extension to remove extra whitespace from attributes gem "strip_attributes", "~> 1.13" diff --git a/Gemfile.lock b/Gemfile.lock index cfd34871a..3522aae9a 100644 --- a/Gemfile.lock +++ b/Gemfile.lock @@ -494,6 +494,8 @@ GEM rubocop-performance (~> 1.20.2) stimulus-rails (1.3.3) railties (>= 6.0.0) + store_model (1.2.0) + activerecord (>= 5.2) stringio (3.1.0) strip_attributes (1.13.0) activemodel (>= 3.0, < 8.0) @@ -592,6 +594,7 @@ DEPENDENCIES square.rb standard (~> 1.34) stimulus-rails + store_model strip_attributes (~> 1.13) stripe strong_migrations (~> 1.7) diff --git a/app/furniture/slipvector.rb b/app/furniture/slipvector.rb index 3ef65cf5a..a50a9416f 100644 --- a/app/furniture/slipvector.rb +++ b/app/furniture/slipvector.rb @@ -1,2 +1,8 @@ class Slipvector + ELMOS = { + energy: "⚡️ Energy", + life: "🧬 Life", + matter: "⚛️ Matter", + oddities: "⁉️ Oddity" + } end diff --git a/app/furniture/slipvector/README.md b/app/furniture/slipvector/README.md index 2e144f0a2..a4fae1d06 100644 --- a/app/furniture/slipvector/README.md +++ b/app/furniture/slipvector/README.md @@ -59,14 +59,14 @@ Binds [Star Systems](#star-systems) together. By spending considerable [Energy]( Every [Star System](#star-systems) in Slipvector has Potential and Kinetic ELMO -- [Energy](#energy) -- [Matter](#matter) -- [Life](#life) -- [Oddity](#oddity) +- [⚡️ Energy](#energy) +- [⚛️ Matter](#matter) +- [🧬 Life](#life) +- [⁉️ Oddity](#oddity) -#### Energy -#### Matter +#### ⚡️ Energy +#### ⚛️ Matter -#### Life +#### 🧬 Life -#### Oddity +#### ⁉️ Oddity diff --git a/app/furniture/slipvector/data_level.rb b/app/furniture/slipvector/data_level.rb index 95bb9fe7e..6bd0a6cdf 100644 --- a/app/furniture/slipvector/data_level.rb +++ b/app/furniture/slipvector/data_level.rb @@ -4,7 +4,14 @@ class DataLevel include ActiveModel::Attributes include ActiveModel::Validations - attribute :observes, :string - validates :observes, inclusion: {in: [:energy, :life, :materials, :oddities]} + attribute :elmo, :string + validates :elmo, inclusion: {in: [:energy, :life, :materials, :oddities]} + + attribute :xp, :integer + validates :xp, numericality: true + + def label + ELMOS.fetch(elmo.to_sym) + end end end diff --git a/app/furniture/slipvector/star_system.rb b/app/furniture/slipvector/star_system.rb index 219fc98a1..d0858bb7d 100644 --- a/app/furniture/slipvector/star_system.rb +++ b/app/furniture/slipvector/star_system.rb @@ -5,7 +5,7 @@ class StarSystem < Record belongs_to :surveyors_guild, inverse_of: :star_systems location(parent: :surveyors_guild) - attribute :data_levels, DataLevelType.new + attribute :experience, Experience.to_type, default: -> { Experience.new } has_many :surveys, inverse_of: :star_system, dependent: :destroy has_many :active_surveys, -> { active }, class_name: :Survey diff --git a/app/furniture/slipvector/star_system/experience.rb b/app/furniture/slipvector/star_system/experience.rb new file mode 100644 index 000000000..a1a2dc4e2 --- /dev/null +++ b/app/furniture/slipvector/star_system/experience.rb @@ -0,0 +1,40 @@ +class Slipvector + class StarSystem::Experience + include StoreModel::Model + + attribute :energy, :integer, default: 0 + attribute :energy_level, :integer, default: 1 + attribute :life, :integer, default: 0 + attribute :life_level, :integer, default: 1 + attribute :matter, :integer, default: 0 + attribute :matter_level, :integer, default: 1 + attribute :oddities, :integer, default: 0 + attribute :oddities_level, :integer, default: 1 + + def bump(result) + assign_attributes({result.elmo => attribute(result.elmo) + result.xp}) + end + + def pools + @experience ||= [ + Level.new(elmo: :energy, xp: energy, level: energy_level), + Level.new(elmo: :life, xp: life, level: life_level), + Level.new(elmo: :matter, xp: matter, level: matter_level), + Level.new(elmo: :oddities, xp: oddities, level: oddities_level) + ] + end + + class Level < DataLevel + attribute :level, :integer, default: 0 + + def next_level_xp + level * 125 + end + + def ready_for_level_up? + xp > next_level_xp + end + + end + end +end diff --git a/app/furniture/slipvector/star_systems/_star_system.html.erb b/app/furniture/slipvector/star_systems/_star_system.html.erb index d43c62365..8684e9973 100644 --- a/app/furniture/slipvector/star_systems/_star_system.html.erb +++ b/app/furniture/slipvector/star_systems/_star_system.html.erb @@ -1,12 +1,29 @@ <%= render CardComponent.new do |card| %> <%- card.with_header do %>
Surveying <%= survey.star_system.name %>
<%- end %> +Gathered... +