1
0

Measurement/readouts WIP

This commit is contained in:
cryptogopher 2019-11-16 18:39:46 +01:00
parent eb379c7835
commit 22aeda720d
8 changed files with 97 additions and 2 deletions

View File

@ -49,7 +49,7 @@ class IngredientsController < ApplicationController
end
def toggle
@ingredient.update(hidden: !@ingredient.hidden)
@ingredient.toggle_hidden!
prepare_ingredients
end

View File

@ -1,11 +1,68 @@
class MeasurementsController < ApplicationController
before_action :find_project_by_project_id, only: [:index, :create]
before_action :find_measurement, only: [:destroy, :toggle]
before_action :authorize
def index
@measurement = @project.measurements.new
@measurement.readouts.new
prepare_measurements
@measurements << @measurement
end
def create
@measurement = @project.measurements.new(measurement_params)
if @measurement.save
flash[:notice] = 'Created newmeasurement'
redirect_to :back
else
prepare_measurements
@measurement.readouts.new if @measurement.readouts.empty?
render :index
end
end
def destroy
# FIXME: don't destroy if there are any readout values
if @measurement.destroy
flash[:notice] = 'Deleted measurement'
end
prepare_measurements
render :toggle
end
def toggle
@measurement.toggle_hidden!
prepare_measurements
end
private
def ingredient_params
params.require(:measurement).permit(
:name,
:source_id,
readouts_attributes:
[
:id,
:quantity_id,
:unit_id,
:_destroy
]
)
end
# :find_* methods are called before :authorize,
# @project is required for :authorize to succeed
def find_measurement
@measurement = Measurement.find(params[:id])
@project = @measurement.project
rescue ActiveRecord::RecordNotFound
render_404
end
def prepare_measurements
@measurements = @project.measurements.includes(:source)
end
end

View File

@ -37,6 +37,10 @@ class Ingredient < ActiveRecord::Base
end
end
def toggle_hidden!
self.toggle!(:hidden)
end
def self.filter(project, filters = {}, requested_q = Quantity.none)
ingredients = all

View File

@ -1,2 +1,29 @@
class Measurement < ActiveRecord::Base
belongs_to :project, required: true
belongs_to :source, required: false
has_many :readouts, inverse_of: :measurement, dependent: :destroy, validate: true
validates :readouts, presence: true
accepts_nested_attributes_for :readouts, allow_destroy: true, reject_if: proc { |attrs|
attrs['quantity_id'].blank?
}
# Readout (quantity_id, unit_id) pair uniqueness check for nested attributes
validate do
quantities = self.readouts.map { |r| [r.quantity_id, r.unit_id] }
if quantities.length != quantities.uniq.length
errors.add(:readouts, :duplicated_quantity)
end
end
validates :name, presence: true, uniqueness: {scope: :project_id}
after_initialize do
if new_record?
self.hidden = false if self.hidden.nil?
end
end
def toggle_hidden!
self.toggle!(:hidden)
end
end

View File

@ -1,2 +1,7 @@
class Readout < ActiveRecord::Base
belongs_to :measurement, inverse_of: :readouts, required: true
belongs_to :quantity, required: true
belongs_to :unit, required: true
validates :quantity, uniqueness: {scope: [:ingredient_id, :unit_id]}
end

View File

@ -7,6 +7,7 @@ resources :projects do
post 'defaults', on: :collection
end
resources :measurements, :only => [:index, :create, :destroy] do
post 'toggle', on: :member
end
resources :ingredients, :only => [:index, :create, :destroy] do
get 'nutrients', on: :collection

View File

@ -24,7 +24,7 @@ Redmine::Plugin.register :body_tracking do
}, read: true
permission :manage_common, {
:body_trackers => [:defaults],
:measurements => [:create, :destroy],
:measurements => [:create, :destroy, :toggle],
:ingredients => [:create, :destroy, :toggle, :import, :toggle_nutrient_column],
:sources => [:create, :destroy],
:quantities => [:create, :destroy, :toggle, :up, :down, :left, :right],

View File

@ -1,6 +1,7 @@
module BodyTracking
module ProjectPatch
Project.class_eval do
has_many :measurements, -> { order "name" }, dependent: :destroy
has_many :ingredients, -> { order "name" }, dependent: :destroy
has_many :sources, dependent: :destroy