This repository has been archived on 2021-11-24. You can view files and clone it, but cannot push or open issues or pull requests.
phone_app/app/models/p_article.rb
Philippe b32ddd37f5 Add front validations for p_article form, add p_article to stock_movement, add AJAX on price_line update method
TODO:
- AJAX for add_p_article and add_stock_movement_p_article in stock_movement views
- Fix select p_article with in stock_movement partial view
- Fix query to display available p_article in stock_movement partial
2021-11-23 20:20:41 +01:00

94 lines
3.0 KiB
Ruby

class PArticle < ApplicationRecord
belongs_to :p_grade
belongs_to :p_product_ref
belongs_to :tva_type
has_one :p_product, through: :p_product_ref
has_one :p_product_color, through: :p_product_ref
has_one :s_brand, through: :p_product_ref
# has_many :p_serial_num_values, through: :p_article_serial_nums
has_many :p_article_serial_nums, dependent: :destroy
accepts_nested_attributes_for :p_article_serial_nums
has_many :price_line_p_articles
has_many :price_lines, through: :price_line_p_articles
has_many :line_stock_p_articles
has_many :line_stocks, through: :line_stock_p_articles
has_many :stock_movement_line_p_articles
has_many :stock_movement_lines, through: :stock_movement_line_p_articles
validates_presence_of :p_product_ref
# has_many :p_product_ref_specs, through: :p_product_ref
# accepts_nested_attributes_for :p_product_ref_specs
if PGrade::ACTIVATED
acts_as_sorting :fields => {
:id => {:name => "id", :reorder => true},
:p_product_ref_ref => {:name => "Code ref", :reorder => true},
:p_product_ref => {:name => "Référence", :reorder => true},
:p_grade => {:name => "Grade", :reorder => true},
:color => {:name => "Couleur"},
:p_article_serial_nums => {:name => "N° identifiants"},
:actions => {:name => "Actions", :reorder => false},
}
else
acts_as_sorting :fields => {
:id => {:name => "id", :reorder => true},
:p_product_ref_ref => {:name => "Code ref", :reorder => true},
:p_product_ref => {:name => "Référence", :reorder => true},
:color => {:name => "Couleur"},
:p_article_serial_nums => {:name => "N° identifiants"},
:actions => {:name => "Actions", :reorder => false},
}
end
include PgSearch::Model
pg_search_scope :global_search,
associated_against: {
p_product_ref: [:cc_name, :ref],
s_brand: [ :code, :name ],
p_product_color: [:name, :color],
p_article_serial_nums: [:value]
},
using: {
tsearch: { prefix: true }
}
def member_label
"#{p_product_ref.cc_name}"
end
def serialized_name
"#{self.p_product_ref.cc_name} #{self.p_article_serial_nums.map{|x| "#{x.p_serial_num_type.name}: #{x.value}"}.join(' / ')}"
end
# def self.available_articles
# p_articles = PArticle.joins(:line_stocks).where("qte_available > ?", 0)
# p_articles.each do |p_article|
# if LineStockUsage.where(p_article_id: p_article.id).empty?
# p_articles.drop(p_article.id)
# end
# end
# return p_articles
# end
def self.available_articles
p_articles = PArticle.joins(:line_stocks).where("qte_available > ?", 0)
used_p_articles_ids = LineStockUsage.where.not(p_article_id: nil).pluck(:p_article_id)#.map{|ls| ls.p_article_id}
available_p_articles_ids =[]
p_articles.each do |p_article|
#puts used_p_articles_ids.include?(p_article.id)
if !used_p_articles_ids.include?(p_article.id)
available_p_articles_ids << p_article.id
end
end
return PArticle.where(id: available_p_articles_ids)
end
end