From 118116ab706186f8cb0f4c3e24c740ff673d61b7 Mon Sep 17 00:00:00 2001
From: Philippe
Date: Thu, 28 Oct 2021 12:25:19 +0200
Subject: [PATCH 01/12] Adding tva_type to price_documents and package_number
to price_line_blocks
---
app/models/price_document.rb | 45 ++++++++++---------
app/models/tva_type.rb | 3 ++
.../admin/price_documents/_form.html.haml | 7 ++-
.../_form_facture_achat.html.haml | 21 ++++-----
app/views/admin/price_lines/_form.html.haml | 1 +
db/migrate/20211028091122_create_tva_types.rb | 17 +++++++
db/schema.rb | 13 +++++-
test/fixtures/tva_types.yml | 11 +++++
test/models/tva_type_test.rb | 7 +++
9 files changed, 91 insertions(+), 34 deletions(-)
create mode 100644 app/models/tva_type.rb
create mode 100644 db/migrate/20211028091122_create_tva_types.rb
create mode 100644 test/fixtures/tva_types.yml
create mode 100644 test/models/tva_type_test.rb
diff --git a/app/models/price_document.rb b/app/models/price_document.rb
index e941947..d81a403 100644
--- a/app/models/price_document.rb
+++ b/app/models/price_document.rb
@@ -5,6 +5,7 @@ class PriceDocument < ApplicationRecord
belongs_to :p_commercial
belongs_to :p_devise
belongs_to :p_payment_type
+ belongs_to :tva_type
has_one :p_compta_element, :dependent => :destroy, :as => :element
@@ -26,7 +27,7 @@ class PriceDocument < ApplicationRecord
accepts_nested_attributes_for :avoir_p_payment_documents, allow_destroy: true
#PURCHASES = ["Demande prix", "Réponse fournisseur", "Commande achat", "Facture achat", "Consultation fournisseur"]
- PURCHASES = ["Commande achat"]
+ PURCHASES = ["Facture achat"]
SALES = ["Bon de commande", "Devis", "Bon de livraison", "Facture", "Avoir"]
# AVANCEMENT = ["0%", "10%", "20%", "30%", "40%", "50%", "60%", "70%", "80%", "90%", "100%"]
AVANCEMENT = ["0%", "25%", "50%", "75%", "100"]
@@ -265,23 +266,24 @@ class PriceDocument < ApplicationRecord
def self.qi_table_order
{
- :p_customer_code => {:name => "Code client", :reorder => false},
-
-
- :avancement => {:name => "Avancement (%)", :reorder => true},
- :list_designaton => {:name => "Designation liste", :reorder => true},
- :end_date => {:name => "Fin de consultation", :reorder => true},
- :dp_comment => {:name => "Commentaire", :reorder => true},
- :acheteur_text => {:name => "Envoyé à", :reorder => true},
+ :id => {:name => "ID", :reorder => false},
+ :p_customer_code => {:name => "Code client", :reorder => false},
+ #:avancement => {:name => "Avancement (%)", :reorder => true},
+ #:list_designaton => {:name => "Designation liste", :reorder => true},
+ #:end_date => {:name => "Fin de consultation", :reorder => true},
+ #:dp_comment => {:name => "Commentaire", :reorder => true},
+ #:acheteur_text => {:name => "Envoyé à", :reorder => true},
:customer_ref => {:name => "Ref cotation", :reorder => false},
-
- :p_commercial => {:name => "Commercial", :reorder => false},
+ #:p_commercial => {:name => "Commercial", :reorder => false},
:p_customer => {:name => "Client", :reorder => false},
:public_fournisseur_name => {:name => "Nom fournisseur saisi", :reorder => false},
:p_fournisseur => {:name => "Fournisseur", :reorder => false},
:com_counter => {:name => "N° Offre", :reorder => false},
:label => {:name => "Type", :reorder => false},
+ :stock_ok => {:name => "Stock mis à jour ?", :reorder => true},
+ :tva_type_name => {:name => "ID Type de TVA", :reorder => true},
+ :package_number => {:name => "Nombre de colis", :reorder => true},
:d_number => {:name => "Numéro", :reorder => true},
:date => {:name => "Date", :reorder => true},
:cc_payment_end_at => {:name => "Date d'échance", :reorder => true},
@@ -296,21 +298,20 @@ class PriceDocument < ApplicationRecord
:cc_cost_ht => {:name => "Coût HT", :reorder => true, :as => :currency},
:cc_marge_ht => {:name => "Marge HT", :reorder => true, :as => :currency},
:cost_ok => {:name => "Marge calculée", :reorder => true, :as => :boolean},
- :f_token => {:name => "Liens consultation"},
-
-
-
-
-
-
- :stock_ok => {:name => "Stock mis à jour ?", :reorder => true},
+ #:f_token => {:name => "Liens consultation"},
:actions => {:name => "Actions", :reorder => false}
-
-
}
#, :sort_name => "code"
end
+ def ca_tva_type_name
+ self.tva_type.name
+ end
+
+ def package_number
+ self.price_line_block.package_number
+ end
+
def self.valid_sort
r = []
self.qi_table_order.each do |key, value|
@@ -343,7 +344,7 @@ class PriceDocument < ApplicationRecord
include Rails.application.routes.url_helpers
- QI_DYNAMICS = %w(solded_nbr_days solded_at cost_ht marge_ht weight_tot accounting_zone_id accounting_zone_name tot_amount_ht tot_amount_ttc tot_amount_tva label header footer payment_days payment_delais payment_month_end payment_end_at to_paid_ht to_paid_ttc to_paid_tva solded)
+ QI_DYNAMICS = %w(solded_nbr_days solded_at cost_ht marge_ht weight_tot accounting_zone_id accounting_zone_name tot_amount_ht tot_amount_ttc tot_amount_tva label header footer payment_days payment_delais payment_month_end payment_end_at to_paid_ht to_paid_ttc to_paid_tva solded tva_type_name)
def reset_for_update
diff --git a/app/models/tva_type.rb b/app/models/tva_type.rb
new file mode 100644
index 0000000..27bc3ab
--- /dev/null
+++ b/app/models/tva_type.rb
@@ -0,0 +1,3 @@
+class TvaType < ApplicationRecord
+ has_many :price_documents
+end
diff --git a/app/views/admin/price_documents/_form.html.haml b/app/views/admin/price_documents/_form.html.haml
index 60a7314..ea84db3 100644
--- a/app/views/admin/price_documents/_form.html.haml
+++ b/app/views/admin/price_documents/_form.html.haml
@@ -1,3 +1,4 @@
+PRICE_DOCUMENTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTT
=semantic_form_for [:admin, @price_document], :html => {:class => "qi_price_form"}, :remote => false do |f|
-@p_customer = @price_document.p_customer
=diag do
@@ -42,7 +43,11 @@
-if @price_document.price_document_type_id == 6 or @price_document.price_document_type_id == 7
- = f.input :date, :label => "Date du document :", :as => :date
+ .row
+ .col-6
+ = f.input :date, :label => "Date du document :", :as => :date
+ .col-6
+ = f.input :tva_type_id, :label => "Type de TVA :", as: :select, collection: TvaType.pluck(:name, :id)
.price_line_block_form
=f.semantic_fields_for :price_line_block do |f|
=render :partial => "admin/price_line_blocks/form_#{f.object.block_type_slug}", :locals => {:f => f}
diff --git a/app/views/admin/price_line_blocks/_form_facture_achat.html.haml b/app/views/admin/price_line_blocks/_form_facture_achat.html.haml
index dca9aea..88536e2 100644
--- a/app/views/admin/price_line_blocks/_form_facture_achat.html.haml
+++ b/app/views/admin/price_line_blocks/_form_facture_achat.html.haml
@@ -1,4 +1,4 @@
-
+PRICE LINE BLOCKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKK
=f.inputs do
@@ -34,22 +34,23 @@
= f.input :particular_send_id, :collection => f.object.p_customer.particulars.all, :as => :select, :member_label => :address_line, :include_blank => false, :label => "Adresse de livraison"
-else
=f.inputs do
- = f.input :particular_send_id, :collection => [], :as => :select, :include_blank => false, :label => "Adresse de facturation"
+ = f.input :particular_send_id, :collection => [], :as => :select, :include_blank => false, :label => "Adresse de livraison"
.clear
%table{:style => "width:100%;"}
%tr
- %td{:style => "width:50%;"}
- = f.input :wish_date, :label => "Date de livraison souhaitée :", :as => :date
-
- %td{:style => "width:50%;"}
- = f.input :ct_creation_date, :label => "Date de commande (si différente de la date de création) :", :as => :date
+ %td
+ =# f.input :wish_date, :label => "Date de livraison souhaitée :", :as => :date
+ %td
+ =# f.input :ct_creation_date, :label => "Date de commande (si différente de la date de création) :", :as => :date
+ .row
+ .col-6
+ = f.input :customer_ref, :label => "Référence commande fournisseur :"
+ .col-6
+ = f.input :package_number, :label => "Nombre de colis :"
-
-
- = f.input :customer_ref, :label => "Référence commande client :"
-if current_admin.has_permission?("customer-sheets-bl")
= f.input :bl_comment, :label => "Commentaire à mettre sur le BL :", :input_html => {:style => "min-height:50px;height:50px;"}
diff --git a/app/views/admin/price_lines/_form.html.haml b/app/views/admin/price_lines/_form.html.haml
index 6861e44..4d21fda 100644
--- a/app/views/admin/price_lines/_form.html.haml
+++ b/app/views/admin/price_lines/_form.html.haml
@@ -3,6 +3,7 @@
%td{:style => "padding-left:10px;", :class => ("error has-error" if form.object.errors[:p_product_ref_id].size > 0 )}
.take.mr-1
+ ="PRICE_LINEEEEEEEE"
=ic :arrows
%td{:style => "white-space: nowrap;"}
diff --git a/db/migrate/20211028091122_create_tva_types.rb b/db/migrate/20211028091122_create_tva_types.rb
new file mode 100644
index 0000000..1d54a38
--- /dev/null
+++ b/db/migrate/20211028091122_create_tva_types.rb
@@ -0,0 +1,17 @@
+class CreateTvaTypes < ActiveRecord::Migration[6.0]
+ def change
+ create_table :tva_types do |t|
+ t.string :name
+
+ t.timestamps
+ end
+
+ TvaType.create(name: "basique")
+ TvaType.create(name: "Sur Marge")
+
+ add_reference :price_documents, :tva_type, index: true
+ add_column :price_documents, :ac_tva_type_name, :string
+ add_column :price_documents, :cc_tva_type_name, :string
+ add_column :price_line_blocks, :package_number, :integer
+ end
+end
diff --git a/db/schema.rb b/db/schema.rb
index 6662bd6..bb88940 100644
--- a/db/schema.rb
+++ b/db/schema.rb
@@ -10,7 +10,7 @@
#
# It's strongly recommended that you check this file into your version control system.
-ActiveRecord::Schema.define(version: 2021_10_18_142636) do
+ActiveRecord::Schema.define(version: 2021_10_28_091122) do
# These are extensions that must be enabled in order to support this database
enable_extension "plpgsql"
@@ -2304,7 +2304,11 @@ ActiveRecord::Schema.define(version: 2021_10_18_142636) do
t.integer "demande_de_prix_id"
t.integer "avoir_achat_id"
t.integer "facture_achat_id"
+ t.bigint "tva_type_id"
+ t.string "ac_tva_type_name"
+ t.string "cc_tva_type_name"
t.index ["p_customer_id"], name: "index_price_documents_on_p_customer_id"
+ t.index ["tva_type_id"], name: "index_price_documents_on_tva_type_id"
end
create_table "price_line_blocks", force: :cascade do |t|
@@ -2453,6 +2457,7 @@ ActiveRecord::Schema.define(version: 2021_10_18_142636) do
t.boolean "imported", default: false
t.date "validation_date"
t.string "cc_state"
+ t.integer "package_number"
t.index ["p_customer_id"], name: "index_price_line_blocks_on_p_customer_id"
end
@@ -3007,6 +3012,12 @@ ActiveRecord::Schema.define(version: 2021_10_18_142636) do
t.index ["accounting_zone_id"], name: "index_tva_rates_on_accounting_zone_id"
end
+ create_table "tva_types", force: :cascade do |t|
+ t.string "name"
+ t.datetime "created_at", precision: 6, null: false
+ t.datetime "updated_at", precision: 6, null: false
+ end
+
create_table "tvable_tva_rates", force: :cascade do |t|
t.integer "tvable_id"
t.string "tvable_type"
diff --git a/test/fixtures/tva_types.yml b/test/fixtures/tva_types.yml
new file mode 100644
index 0000000..5181636
--- /dev/null
+++ b/test/fixtures/tva_types.yml
@@ -0,0 +1,11 @@
+# Read about fixtures at https://api.rubyonrails.org/classes/ActiveRecord/FixtureSet.html
+
+# This model initially had no columns defined. If you add columns to the
+# model remove the '{}' from the fixture names and add the columns immediately
+# below each fixture, per the syntax in the comments below
+#
+one: {}
+# column: value
+#
+two: {}
+# column: value
diff --git a/test/models/tva_type_test.rb b/test/models/tva_type_test.rb
new file mode 100644
index 0000000..18c29eb
--- /dev/null
+++ b/test/models/tva_type_test.rb
@@ -0,0 +1,7 @@
+require 'test_helper'
+
+class TvaTypeTest < ActiveSupport::TestCase
+ # test "the truth" do
+ # assert true
+ # end
+end
From 05007c569bb557a19655dfa37b653e528c06124c Mon Sep 17 00:00:00 2001
From: Philippe
Date: Thu, 28 Oct 2021 12:45:37 +0200
Subject: [PATCH 02/12] Adding stock entrace date to price_line_block form
---
.../(__TEMPLATE__)c | Bin 5965 -> 1374 bytes
app/models/price_document.rb | 6 +--
.../_form_facture_achat.html.haml | 38 ++++++++++--------
3 files changed, 24 insertions(+), 20 deletions(-)
diff --git a/.sass-cache/f6b9a0b1905a68d5dbb2139e95d49cba92f6fa93/(__TEMPLATE__)c b/.sass-cache/f6b9a0b1905a68d5dbb2139e95d49cba92f6fa93/(__TEMPLATE__)c
index f14f6942a4eff9a4b9af0c9026e5b8e2e708b671..e1c3ae14c64ffb6b86d264611307231a215c18c3 100644
GIT binary patch
delta 389
zcmX@BcaKZYSkGL~gv-Ft$jCf3HQB=4I4#v6HPtxPBq=#1&D_W+H6It+*WW5_3~Mm3W{MlU*3sGxAOT!WauA
zgP5*QUc@3R#*>m+T#%Dk$!5(NV#V!HmY7qT8qGFYo>zSGdlp?8&b<7*RInVcLw-R?
zW`16AH3QJ(lFEYA$(F48%IwzS`PLGg){^!FD8Pv&LQl7O1)pl>bfAZ0D*AZ;yVV6Ew(F}aIP8t9#DHaRm5D?W#k
v)Lfu%N`SsrfrUpkmx2P+lU5+#SaWgJa&d8iJOy+U+vJbjiacy^Qw>7^kL+bZ
literal 5965
zcmbVQUvt~W5f?Qbii9jtbo9@ZEVHzu*orOEk{sE0Gwmg=JYgnrG#1krJz$RHi9!S7
zPym#pdi>UWh4f?eOSNC2eQb9Re~w2&ij*hfh}*s2?(P0|7yG-1y9d_c!NDQ#?RC4a
z&iLMo?w)8J?Dt;r=l$Nx7hJsT9f~iyqPyR+epiy@-U$ywLOOvEguIh7dMo?l4q0Tq
zbI0um!aFTbZW_4)H&uwm0(d?xwi{~?yRv_2hY^pQFmnDn5@C@Pk2>To^LY@8zKuIW
zNgDBSC&CrINCt$wmct=G5g_69M2Rf0p%`{W5S|t#xj(r%-8V;QNPD@13FViged}
zylZW8SG!*V=pG-6c4KuKH!XMIwd;7oDS{u)99Q7p7GMiU-M;{C^(aR{4=pO4h^Pnx
z=R7?BIP(T94%I6=;NCz;vYs5T{sb4}zhzQk;Hx0AeF-Wy%q_<Nw?l5_F
z7K#WS7ntz+N`%(bOS<8#!_f$_1yI3y8AKvzp&-2*|HO}EgN2FDZ37=&FVlNc>nqaD
zvDG@g-)?;J*tR=I-yMJZW#`DYpA^ACbW4(YjJlm13PJP+aDwKJ%Sg~6E^pK)C+zI1b6Mr)MRR}EnL|f^(xS`RQFKjS@6{!GzeTt3dXzB!B##da$vL>+Qg$D>x=Zh~8r@|8sY@TY!Y6Q!}IKdyCapKFPl4E-urP7$dT74kGjsl?nze$M#k2E9|sWk
zB3j>Rs`~)1UHXE|hnNKs_-+Qwg+P=(Mrin929TE~3@!msD}#+IlER*#lH)-7NF_^j
z2`^(sV|=FIsVmvWR8NBKq!&1Tl+x9=4g@=QOLTi`!=KS|LQbLpqM%H-k)pnM{o<>`
zug0uY>YuPz^fOX%`e2`P=7@kaSYP;o=OhIEWMQ_gNoolT>(b;xX;eu+AHx{ie#?w+
zWEqcV!HqBccAROo$Z#HqV$_%OWSOY|1CRA=m9=q*Z9XNlh7>GW0KecT)8ePxB^Lo#7dHWdWS-qw;QL;9hLYup(v|9#%VEMkot6z
zr&LBiqmRw3TTBBqNrOeers=i(Oq=(
z(!`ldaLQulS6pqSXDW(s(v}H2Pk{z)DtI1O6IS@Ual%4&!k$rX5-hCnbGkvBUG2)C
zFM?-*GdPb_9w03n)~_D;Kh;C&I{ow()IPyK
z^M5f;Sk6u`%}=nf!auSN84WI^xLKI#GDCTs%WAo7rM&U0{l#@WwS1E-)wzabyOCw7
z60SPS5QOT{%+h7pt0i#-l2>Kv{w=aJX(XnzZzXkUl6@<1roKsB?WYKI7*1p#d6aPW
zL|YI>No#Ll=OhJ6`QE2sXD6@-dY9!EN7vJt9z-p=v`Jzflk<)0DU{c5zC_6XQkHe3#{~H
zg?XbPG*d8>*(1*ZZ_Plb0X>m~?%4Qukx3u{_|t7SP#gfhftbnzxM2X)#0CJt*FTEO
z_dqHz|7^wX{2_8&Lf*$X(}eqW>ND=b&|heb5tN9|!Fwl&>N8;dh>ezRO`0gALH^
z5A1k(1(J$^w38A6pX>PYmMm7xYc
z(Uk#Lx`9uJ(5ySUdV(`rg==TAv{%?jothMg4LG`%c^6ktvzy2bhCBs27)%9eFwAZh
zj3czIX0wohVY3ekDTwKexTaOSkq0&>Jg^BiuV(OY^*B8|pAqsDXb+eQG7q%02XMz#
z`H+BNv(GaR=!B@H$k}W~t22XVKb;k!7QiPXWOMi+H~VgO`di`$t6tY1YH(GrH=Fuv
z!Og}65Yi&o3=E+Dqh)=xa=W;jOr!{~*}TOdV;FNivRLcnph4lp@eZA6!c8V33I^p{
zbbGWhhB~%Kj}?-qb!Y^hj14~5;2A3b3ez+fBA}aIRAO|3C};XZv#q3w%DzY>jDiia
NrnY#MHog0u{{w}+6Mp~z
diff --git a/app/models/price_document.rb b/app/models/price_document.rb
index d81a403..0f019c2 100644
--- a/app/models/price_document.rb
+++ b/app/models/price_document.rb
@@ -266,7 +266,8 @@ class PriceDocument < ApplicationRecord
def self.qi_table_order
{
- :id => {:name => "ID", :reorder => false},
+ :id => {:name => "ID", :reorder => false},
+ :actions => {:name => "Actions", :reorder => false},
:p_customer_code => {:name => "Code client", :reorder => false},
#:avancement => {:name => "Avancement (%)", :reorder => true},
#:list_designaton => {:name => "Designation liste", :reorder => true},
@@ -297,9 +298,8 @@ class PriceDocument < ApplicationRecord
:cc_to_paid_ttc => {:name => "Restant dû", :reorder => true, :as => :currency},
:cc_cost_ht => {:name => "Coût HT", :reorder => true, :as => :currency},
:cc_marge_ht => {:name => "Marge HT", :reorder => true, :as => :currency},
- :cost_ok => {:name => "Marge calculée", :reorder => true, :as => :boolean},
+ :cost_ok => {:name => "Marge calculée", :reorder => true, :as => :boolean}
#:f_token => {:name => "Liens consultation"},
- :actions => {:name => "Actions", :reorder => false}
}
#, :sort_name => "code"
end
diff --git a/app/views/admin/price_line_blocks/_form_facture_achat.html.haml b/app/views/admin/price_line_blocks/_form_facture_achat.html.haml
index 88536e2..5113806 100644
--- a/app/views/admin/price_line_blocks/_form_facture_achat.html.haml
+++ b/app/views/admin/price_line_blocks/_form_facture_achat.html.haml
@@ -15,26 +15,26 @@ PRICE LINE BLOCKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKK
-if f.object.p_customer and f.object.p_customer.particular
=render :partial => "admin/p_customers/apercu", :locals => {:particular => f.object.p_customer.particular}
- .addresses.row
- .columns.span_6
- %h3 Adresse de facturation
+ -# .addresses.row
+ -# .columns.span_6
+ -# %h3 Adresse de facturation
- -if f.object.p_customer
- =f.inputs do
- = f.input :particular_bill_id, :collection => f.object.p_customer.particulars.all, :as => :select, :member_label => :address_line, :include_blank => false, :label => "Adresse de facturation"
- -else
- =f.inputs do
- = f.input :particular_bill_id, :collection => [], :as => :select, :include_blank => false, :label => "Adresse de facturation"
+ -# -if f.object.p_customer
+ -# =f.inputs do
+ -# = f.input :particular_bill_id, :collection => f.object.p_customer.particulars.all, :as => :select, :member_label => :address_line, :include_blank => false, :label => "Adresse de facturation"
+ -# -else
+ -# =f.inputs do
+ -# = f.input :particular_bill_id, :collection => [], :as => :select, :include_blank => false, :label => "Adresse de facturation"
- .columns.span_6
- %h3 Adresse de livraison
+ -# .columns.span_6
+ -# %h3 Adresse de livraison
- -if f.object.p_customer
- =f.inputs do
- = f.input :particular_send_id, :collection => f.object.p_customer.particulars.all, :as => :select, :member_label => :address_line, :include_blank => false, :label => "Adresse de livraison"
- -else
- =f.inputs do
- = f.input :particular_send_id, :collection => [], :as => :select, :include_blank => false, :label => "Adresse de livraison"
+ -# -if f.object.p_customer
+ -# =f.inputs do
+ -# = f.input :particular_send_id, :collection => f.object.p_customer.particulars.all, :as => :select, :member_label => :address_line, :include_blank => false, :label => "Adresse de livraison"
+ -# -else
+ -# =f.inputs do
+ -# = f.input :particular_send_id, :collection => [], :as => :select, :include_blank => false, :label => "Adresse de livraison"
.clear
@@ -45,6 +45,10 @@ PRICE LINE BLOCKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKK
=# f.input :wish_date, :label => "Date de livraison souhaitée :", :as => :date
%td
=# f.input :ct_creation_date, :label => "Date de commande (si différente de la date de création) :", :as => :date
+ .row
+ .col-6
+ = f.input :validation_date, :label => "Date d'entrée en stock :", :as => :date
+
.row
.col-6
= f.input :customer_ref, :label => "Référence commande fournisseur :"
From ee52fca31eb1cd2bba56c995a61d49bef7ef984c Mon Sep 17 00:00:00 2001
From: Philippe
Date: Fri, 29 Oct 2021 18:40:30 +0200
Subject: [PATCH 03/12] PArtciel from OK with device infos, adding coumn to
price line block ct_tot_amount ht and ttc
---
.../(__TEMPLATE__)c | Bin 1374 -> 5965 bytes
app/models/line_stock.rb | 21 ++----
app/models/price_line.rb | 16 -----
app/models/price_line_block.rb | 6 +-
.../p_article_serial_nums/_form.html.haml | 1 -
app/views/admin/p_articles/_form.html.haml | 10 ++-
.../admin/p_product_refs/_form.html.haml | 8 +--
app/views/admin/p_products/_form.html.haml | 2 +-
.../admin/price_documents/_form.html.haml | 4 +-
.../admin/price_documents/show.html.haml | 2 +-
.../_form_facture_achat.html.haml | 18 +++--
app/views/admin/price_lines/_form.html.haml | 66 ++++++------------
.../_form_bon_de_reception_achat.html.haml | 50 +++++++------
db/migrate/20211028091122_create_tva_types.rb | 8 +--
...mns_to_price_docs_adn_price_line_blocks.rb | 10 +++
db/schema.rb | 6 +-
16 files changed, 99 insertions(+), 129 deletions(-)
create mode 100644 db/migrate/20211029111104_add_columns_to_price_docs_adn_price_line_blocks.rb
diff --git a/.sass-cache/f6b9a0b1905a68d5dbb2139e95d49cba92f6fa93/(__TEMPLATE__)c b/.sass-cache/f6b9a0b1905a68d5dbb2139e95d49cba92f6fa93/(__TEMPLATE__)c
index e1c3ae14c64ffb6b86d264611307231a215c18c3..f14f6942a4eff9a4b9af0c9026e5b8e2e708b671 100644
GIT binary patch
literal 5965
zcmbVQUvt~W5f?Qbii9jtbo9@ZEVHzu*orOEk{sE0Gwmg=JYgnrG#1krJz$RHi9!S7
zPym#pdi>UWh4f?eOSNC2eQb9Re~w2&ij*hfh}*s2?(P0|7yG-1y9d_c!NDQ#?RC4a
z&iLMo?w)8J?Dt;r=l$Nx7hJsT9f~iyqPyR+epiy@-U$ywLOOvEguIh7dMo?l4q0Tq
zbI0um!aFTbZW_4)H&uwm0(d?xwi{~?yRv_2hY^pQFmnDn5@C@Pk2>To^LY@8zKuIW
zNgDBSC&CrINCt$wmct=G5g_69M2Rf0p%`{W5S|t#xj(r%-8V;QNPD@13FViged}
zylZW8SG!*V=pG-6c4KuKH!XMIwd;7oDS{u)99Q7p7GMiU-M;{C^(aR{4=pO4h^Pnx
z=R7?BIP(T94%I6=;NCz;vYs5T{sb4}zhzQk;Hx0AeF-Wy%q_<Nw?l5_F
z7K#WS7ntz+N`%(bOS<8#!_f$_1yI3y8AKvzp&-2*|HO}EgN2FDZ37=&FVlNc>nqaD
zvDG@g-)?;J*tR=I-yMJZW#`DYpA^ACbW4(YjJlm13PJP+aDwKJ%Sg~6E^pK)C+zI1b6Mr)MRR}EnL|f^(xS`RQFKjS@6{!GzeTt3dXzB!B##da$vL>+Qg$D>x=Zh~8r@|8sY@TY!Y6Q!}IKdyCapKFPl4E-urP7$dT74kGjsl?nze$M#k2E9|sWk
zB3j>Rs`~)1UHXE|hnNKs_-+Qwg+P=(Mrin929TE~3@!msD}#+IlER*#lH)-7NF_^j
z2`^(sV|=FIsVmvWR8NBKq!&1Tl+x9=4g@=QOLTi`!=KS|LQbLpqM%H-k)pnM{o<>`
zug0uY>YuPz^fOX%`e2`P=7@kaSYP;o=OhIEWMQ_gNoolT>(b;xX;eu+AHx{ie#?w+
zWEqcV!HqBccAROo$Z#HqV$_%OWSOY|1CRA=m9=q*Z9XNlh7>GW0KecT)8ePxB^Lo#7dHWdWS-qw;QL;9hLYup(v|9#%VEMkot6z
zr&LBiqmRw3TTBBqNrOeers=i(Oq=(
z(!`ldaLQulS6pqSXDW(s(v}H2Pk{z)DtI1O6IS@Ual%4&!k$rX5-hCnbGkvBUG2)C
zFM?-*GdPb_9w03n)~_D;Kh;C&I{ow()IPyK
z^M5f;Sk6u`%}=nf!auSN84WI^xLKI#GDCTs%WAo7rM&U0{l#@WwS1E-)wzabyOCw7
z60SPS5QOT{%+h7pt0i#-l2>Kv{w=aJX(XnzZzXkUl6@<1roKsB?WYKI7*1p#d6aPW
zL|YI>No#Ll=OhJ6`QE2sXD6@-dY9!EN7vJt9z-p=v`Jzflk<)0DU{c5zC_6XQkHe3#{~H
zg?XbPG*d8>*(1*ZZ_Plb0X>m~?%4Qukx3u{_|t7SP#gfhftbnzxM2X)#0CJt*FTEO
z_dqHz|7^wX{2_8&Lf*$X(}eqW>ND=b&|heb5tN9|!Fwl&>N8;dh>ezRO`0gALH^
z5A1k(1(J$^w38A6pX>PYmMm7xYc
z(Uk#Lx`9uJ(5ySUdV(`rg==TAv{%?jothMg4LG`%c^6ktvzy2bhCBs27)%9eFwAZh
zj3czIX0wohVY3ekDTwKexTaOSkq0&>Jg^BiuV(OY^*B8|pAqsDXb+eQG7q%02XMz#
z`H+BNv(GaR=!B@H$k}W~t22XVKb;k!7QiPXWOMi+H~VgO`di`$t6tY1YH(GrH=Fuv
z!Og}65Yi&o3=E+Dqh)=xa=W;jOr!{~*}TOdV;FNivRLcnph4lp@eZA6!c8V33I^p{
zbbGWhhB~%Kj}?-qb!Y^hj14~5;2A3b3ez+fBA}aIRAO|3C};XZv#q3w%DzY>jDiia
NrnY#MHog0u{{w}+6Mp~z
delta 389
zcmX@BcaKZYSkGL~gv-Ft$jCf3HQB=4I4#v6HPtxPBq=#1&D_W+H6It+*WW5_3~Mm3W{MlU*3sGxAOT!WauA
zgP5*QUc@3R#*>m+T#%Dk$!5(NV#V!HmY7qT8qGFYo>zSGdlp?8&b<7*RInVcLw-R?
zW`16AH3QJ(lFEYA$(F48%IwzS`PLGg){^!FD8Pv&LQl7O1)pl>bfAZ0D*AZ;yVV6Ew(F}aIP8t9#DHaRm5D?W#k
v)Lfu%N`SsrfrUpkmx2P+lU5+#SaWgJa&d8iJOy+U+vJbjiacy^Qw>7^kL+bZ
diff --git a/app/models/line_stock.rb b/app/models/line_stock.rb
index ab34132..a8886b9 100644
--- a/app/models/line_stock.rb
+++ b/app/models/line_stock.rb
@@ -1,4 +1,4 @@
-class LineStock < ApplicationRecord
+ class LineStock < ApplicationRecord
belongs_to :p_product_ref
belongs_to :stockable, :polymorphic => true
@@ -12,26 +12,17 @@ class LineStock < ApplicationRecord
:stockable => {:name => "Origine", :reorder => false},
:p_product_ref => {:name => "Produit", :reorder => false},
:description => {:name => "Description", :reorder => true, :sort_name => "p_customer_sheets.created_at"},
- :dluo => {:name => "DLUO", :reorder => true},
-
- :qte => {:name => "Quantité", :reorder => true},
+ #:dluo => {:name => "DLUO", :reorder => true},
+ :qte => {:name => "Quantité", :reorder => true },
:qte_available => {:name => "Quantité restante", :reorder => true},
:qte_used => {:name => "Quantité utilisée", :reorder => true},
:price_ht => {:name => "Valeur totale d'origine", :reorder => true, :as => :currency},
-
:price_ht_available => {:name => "Valeur disponnible", :reorder => true, :as => :currency},
-
:price_ht_used => {:name => "Valeur utilisée", :reorder => true, :as => :currency},
-
:price_u_ht => {:name => "Prix Unitaire", :reorder => true, :as => :currency},
-
- :price_u_kg_ht => {:name => "Prix U [Kg]", :reorder => true, :as => :currency},
-
- :qte_kg_per_unit => {:name => "Poids par unité", :reorder => true},
-
- :qte_kg => {:name => "Poids total", :reorder => true},
-
-
+ #:price_u_kg_ht => {:name => "Prix U [Kg]", :reorder => true, :as => :currency},
+ #:qte_kg_per_unit => {:name => "Poids par unité", :reorder => true},
+ #:qte_kg => {:name => "Poids total", :reorder => true},
:actions => {:name => "Actions", :reorder => false},
}
diff --git a/app/models/price_line.rb b/app/models/price_line.rb
index 897399c..dc50cd1 100644
--- a/app/models/price_line.rb
+++ b/app/models/price_line.rb
@@ -540,22 +540,6 @@ class PriceLine < ApplicationRecord
self.ca_discount_ecole_ht
end
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
def ca_tot_amount_ht
if self.ct_tot_amount_ht
self.ct_tot_amount_ht
diff --git a/app/models/price_line_block.rb b/app/models/price_line_block.rb
index b6b2b38..0bdb058 100644
--- a/app/models/price_line_block.rb
+++ b/app/models/price_line_block.rb
@@ -681,7 +681,11 @@ class PriceLineBlock < ApplicationRecord
end
def ca_tot_amount_ht
- self.tot_amount_af_discount_ht + self.tot_gen_discount_ht
+ if self.ct_tot_amount_ht
+ return self.ct_tot_amount_ht
+ else
+ self.tot_amount_af_discount_ht + self.tot_gen_discount_ht
+ end
end
def ca_tot_amount_tva
diff --git a/app/views/admin/p_article_serial_nums/_form.html.haml b/app/views/admin/p_article_serial_nums/_form.html.haml
index 545dbdf..d3ec238 100644
--- a/app/views/admin/p_article_serial_nums/_form.html.haml
+++ b/app/views/admin/p_article_serial_nums/_form.html.haml
@@ -16,4 +16,3 @@
=form.inputs do
= form.input :p_serial_num_type_id, :label => "type", as: :select, collection: PSerialNumType.pluck(:name, :id)
= form.input :value
-
diff --git a/app/views/admin/p_articles/_form.html.haml b/app/views/admin/p_articles/_form.html.haml
index f2fbe48..4da53fd 100644
--- a/app/views/admin/p_articles/_form.html.haml
+++ b/app/views/admin/p_articles/_form.html.haml
@@ -2,7 +2,10 @@
.content
=f.inputs do
- = f.input :p_product_ref, as: :select, collection: PProductRef.all.distinct.pluck(:cc_name, :id), :label => f.object.label_for(:p_product_ref)
+ -if params[:p_product_ref_id]
+ = f.input :p_product_ref, as: :select, collection: PProductRef.all.distinct.pluck(:cc_name, :id), :selected => f.object.p_product_ref , :label => f.object.label_for(:p_product_ref)
+ -else
+ = f.input :p_product_ref, as: :select, collection: PProductRef.all.distinct.pluck(:cc_name, :id), :label => f.object.label_for(:p_product_ref)
-if PGrade::ACTIVATED
= f.input :p_grade, as: :select, collection: PGrade.pluck(:grade, :id), :label => "Grade"
%h4 Numero de série :
@@ -11,9 +14,4 @@
=render :partial => "admin/p_article_serial_nums/form", :locals => {:form => form}
%p= link_to_add_fields "Ajouter un numéro de série", f, :p_article_serial_nums, {:class => "btn btn-primary"}
-
-
-
-
-
.actions=f.submit "sauvegarder", :class => "btn btn-primary"
diff --git a/app/views/admin/p_product_refs/_form.html.haml b/app/views/admin/p_product_refs/_form.html.haml
index aa46f8e..a857132 100644
--- a/app/views/admin/p_product_refs/_form.html.haml
+++ b/app/views/admin/p_product_refs/_form.html.haml
@@ -25,10 +25,10 @@
%td
=form.input :ean
%tr
- %td
- =form.input :ct_sorecop, :label => "Sorecop personalisée :"
- %td
- =form.input :sorecop_comment, :label => "Commentaire de Sorecop :"
+ -# %td
+ -# =form.input :ct_sorecop, :label => "Sorecop personalisée :"
+ -# %td
+ -# =form.input :sorecop_comment, :label => "Commentaire de Sorecop :"
%td
=form.input :ct_deee, :label => "DEEE personalisée :"
diff --git a/app/views/admin/p_products/_form.html.haml b/app/views/admin/p_products/_form.html.haml
index d298195..0b0953c 100755
--- a/app/views/admin/p_products/_form.html.haml
+++ b/app/views/admin/p_products/_form.html.haml
@@ -20,7 +20,7 @@
=# f.input :stocked, :label => "Suivi de stock ?"
.col-sm-2
- =f.input :sorecop_cat, label: "Catgorie Sorecop :", :collection => SorecopCat.all, :as => :select, :include_blank => true
+ =#f.input :sorecop_cat, label: "Catgorie Sorecop :", :collection => SorecopCat.all, :as => :select, :include_blank => true
diff --git a/app/views/admin/price_documents/_form.html.haml b/app/views/admin/price_documents/_form.html.haml
index ea84db3..3062be9 100644
--- a/app/views/admin/price_documents/_form.html.haml
+++ b/app/views/admin/price_documents/_form.html.haml
@@ -45,7 +45,9 @@ PRICE_DOCUMENTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTT
-if @price_document.price_document_type_id == 6 or @price_document.price_document_type_id == 7
.row
.col-6
- = f.input :date, :label => "Date du document :", :as => :date
+ = f.input :date, :label => "Date de la facture achat :", :as => :date
+ .col-6
+ = f.input :supplier_document_date, :label => "Date du document fournisseur :", :as => :date
.col-6
= f.input :tva_type_id, :label => "Type de TVA :", as: :select, collection: TvaType.pluck(:name, :id)
.price_line_block_form
diff --git a/app/views/admin/price_documents/show.html.haml b/app/views/admin/price_documents/show.html.haml
index 19a9616..87f7ba9 100644
--- a/app/views/admin/price_documents/show.html.haml
+++ b/app/views/admin/price_documents/show.html.haml
@@ -243,7 +243,7 @@
= link_to i(:"trash-o"), admin_price_line_path(price_line), method: :delete, data: { confirm: 'Voulez-vous vraiment supprimer cet enregistrement ? ' } , :remote => true
= link_to i(:pencil), edit_admin_price_line_path(price_line), :remote => true
= link_to i(:eye), admin_price_line_path(price_line), :remote => true
- = link_to i(:"mobile-alt"), new_admin_p_article_path, :remote => true
+ = link_to i(:"mobile-alt"), new_admin_p_article_path(p_product_ref_id: price_line.p_product_ref.id), :remote => true
/ %td=# price_line.line_stocks.sum(:price_ht)
diff --git a/app/views/admin/price_line_blocks/_form_facture_achat.html.haml b/app/views/admin/price_line_blocks/_form_facture_achat.html.haml
index 5113806..82c3485 100644
--- a/app/views/admin/price_line_blocks/_form_facture_achat.html.haml
+++ b/app/views/admin/price_line_blocks/_form_facture_achat.html.haml
@@ -1,17 +1,12 @@
PRICE LINE BLOCKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKK
=f.inputs do
-
-if !@p_customer_sheet or (@p_customer_sheet and @p_customer_sheet.state != "commande")
.qi_pannel.qi_plain.padding{:style => "margin:20px 0;"}
- = f.input :p_commercial_id, :label => "Commercial :", :collection => PCommercial.order(:name).all, :as => :select, :member_label => :long_name if f.object.id
-
-
+ =# f.input :p_commercial_id, :label => "Commercial :", :collection => PCommercial.order(:name).all, :as => :select, :member_label => :long_name if f.object.id
= f.hidden_field :p_customer_id, :class => "p_customer_id"
.p_customer_sheet_customer
-
-
-if f.object.p_customer and f.object.p_customer.particular
=render :partial => "admin/p_customers/apercu", :locals => {:particular => f.object.p_customer.particular}
@@ -47,13 +42,11 @@ PRICE LINE BLOCKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKK
=# f.input :ct_creation_date, :label => "Date de commande (si différente de la date de création) :", :as => :date
.row
.col-6
- = f.input :validation_date, :label => "Date d'entrée en stock :", :as => :date
+ = f.input :stock_entrance_date, :label => "Date d'entrée en stock :", :as => :date
.row
.col-6
= f.input :customer_ref, :label => "Référence commande fournisseur :"
- .col-6
- = f.input :package_number, :label => "Nombre de colis :"
-if current_admin.has_permission?("customer-sheets-bl")
= f.input :bl_comment, :label => "Commentaire à mettre sur le BL :", :input_html => {:style => "min-height:50px;height:50px;"}
@@ -80,11 +73,16 @@ PRICE LINE BLOCKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKK
-if !@p_customer_sheet or (@p_customer_sheet and @p_customer_sheet.state != "commande")
-if !@avoir
= f.input :ct_tot_discount_percent, :label => "Réduction pied de page (%) :", :input_html => {:class => "input_price_line_block_ct_tot_discount_percent"}
- = f.input :ct_tot_fdp_ht, :label => "Frais de port personnalisés :"
+ = f.input :ct_tot_fdp_ht, :label => "Montant des frais de port HT (€) :"
-if !@avoir
-if current_admin.has_permission?("customer-sheets-bl")
= f.input :ct_nbr_ship, :label => "Nombre de colis :"
+
+ = f.input :cc_tot_amount_ttc, label: "Montant TTC à payer", :input_html => {disabled: true}
+ = f.input :cc_tot_amount_ht, label: "Montant HT à payer", input_html: {disabled: true}
+ = f.input :ct_tot_amount_ht, label: "Montant HT personnalisé"
+
-if current_admin.has_permission?("payments")
-if !@p_customer_sheet or (@p_customer_sheet and @p_customer_sheet.state != "commande")
diff --git a/app/views/admin/price_lines/_form.html.haml b/app/views/admin/price_lines/_form.html.haml
index 4d21fda..013f1d6 100644
--- a/app/views/admin/price_lines/_form.html.haml
+++ b/app/views/admin/price_lines/_form.html.haml
@@ -3,69 +3,47 @@
%td{:style => "padding-left:10px;", :class => ("error has-error" if form.object.errors[:p_product_ref_id].size > 0 )}
.take.mr-1
- ="PRICE_LINEEEEEEEE"
=ic :arrows
+ = "PRICE_LINEEEEEEEE"
%td{:style => "white-space: nowrap;"}
-
-
-
.input-group
+ %label Référence
%input.p_product_ref_autocomplete_input.form-control{:type => "text", :style => "", tabindex: 1, autofocus: true, :value => ("#{form.object.p_product_ref.member_label}" if form.object.p_product_ref), :class => "p_product_ref_name"}
= form.hidden_field :p_product_ref_id, :class => "p_product_ref_id"
-
-
-
-
.input-group-append
=link_to "#", class: "btn btn-dark",:onclick => "key=genRanHex(12);select_product_from_manager(key);$(this).closest('tr').find('.p_product_ref_id').attr('id', 'p_product_ref_id_'+key);$(this).closest('tr').find('.p_product_ref_name').attr('id', 'p_product_ref_name_'+key);$(this).closest('tr').find('.p_product_ref_qte').attr('id', 'p_product_ref_qte_'+key);return false;" do
=ic(:search)
-
-
-
-
-
-
-
-
-
-form.object.forced_price = true if form.object.ct_u_price_ht
- -if form.object.forced_price and form.object.p_product_ref
- %td
- .mx-2
- .form-inline
- =qi_js_field_price_line_form(form, :price_line, :price_u_ht, :label => false, label_class: "mr-1", :value => form.object.th_price_u_ht)
- -else
- %td
- .mx-2
- .form-inline
- =qi_js_field_price_line_form(form, :price_line, :price_u_ht, :label =>false, label_class: "mr-1")
+ -# -if form.object.forced_price and form.object.p_product_ref
+ -# %td
+ -# .mx-2
+ -# .form-inline
+ -# =qi_js_field_price_line_form(form, :price_line, :price_u_ht, :label => false, label_class: "mr-1", :value => form.object.th_price_u_ht)
+ -# -else
+ -# %td
+ -# .mx-2
+ -# .form-inline
+ -# =qi_js_field_price_line_form(form, :price_line, :price_u_ht, :label =>false, label_class: "mr-1")
+ -# %td
+ -# .form-inline.mr-2{:style => ("display:none;" if !current_admin or !current_admin.has_permission?("customer-sheets-personalised-price"))}
+ -# = form.input :forced_price, :label => "Prix personnalisé ?", :as => :boolean, :input_html => {:class => "form-inline input_price_line_forced_price"}
+ -# .forced_price_wrapper.mx-2{:style => ("display:none;" if !form.object.forced_price)}= form.input :ct_u_price_ht, :label => false, :input_html => {:class => "input_price_line_ct_u_price_ht"}
%td
- .form-inline.mr-2{:style => ("display:none;" if !current_admin or !current_admin.has_permission?("customer-sheets-personalised-price"))}
- = form.input :forced_price, :label => "Prix personnalisé ?", :as => :boolean, :input_html => {:class => "form-inline input_price_line_forced_price"}
- .forced_price_wrapper.mx-2{:style => ("display:none;" if !form.object.forced_price)}= form.input :ct_u_price_ht, :label => false, :input_html => {:class => "input_price_line_ct_u_price_ht"}
- %td{:style => "width:100px;"}
-
- = form.input :qte, :label => false, :input_html => {:class => "input_price_line_qte form-control p_product_ref_qte", tabindex: 1}
+ = form.input :qte, :label => "Quantité", :input_html => {:class => "input_price_line_qte form-control p_product_ref_qte", tabindex: 1}
+ %td
+ = form.input :ct_u_price_ht, :label => "Prix Unitaire HT :", :input_html => { class: "mx-2"}
+ -# %td
+ -# =form.input :ct_tva_account_id, :collection => options_from_collection_for_select(TvaRate.where(:accounting_zone_id => (@p_customer ? @p_customer.accounting_zone_id : nil)).all, "id", "member_label", form.object.tva_account_id), :as => :select ,:label => false, :include_blank => false , :input_html => {:class => "input_price_line_tva_account_id form-control custom-select"}
%td
-
-
- =form.input :ct_tva_account_id, :collection => options_from_collection_for_select(TvaRate.where(:accounting_zone_id => (@p_customer ? @p_customer.accounting_zone_id : nil)).all, "id", "member_label", form.object.tva_account_id), :as => :select ,:label => false, :include_blank => false , :input_html => {:class => "input_price_line_tva_account_id form-control custom-select"}
-
- %td
-
%span.destroy=link_to_remove_fields ic(:"trash-o"), form
-
-
-
=qi_js_field(form, :price_line, :tva_account_value, :hidden => true)
-
= form.hidden_field :position, :class => "price_line_position_input"
-:javascript
+:javascript
$('.p_product_ref_autocomplete_input').focus()
$( function() {
$('.p_product_ref_autocomplete_input').autocomplete({
diff --git a/app/views/admin/price_lines/_form_bon_de_reception_achat.html.haml b/app/views/admin/price_lines/_form_bon_de_reception_achat.html.haml
index a8d7aa0..8013222 100644
--- a/app/views/admin/price_lines/_form_bon_de_reception_achat.html.haml
+++ b/app/views/admin/price_lines/_form_bon_de_reception_achat.html.haml
@@ -1,27 +1,35 @@
.qi_pannel.qi_plain.padding.price_line_form.col-12.field{:style =>"border-left:4px solid gray;margin-bottom:10px;padding-left:5px;"}
- price_line = form.object
.row
- .col-6.row
- .col-2.d-flex
- .take.mx-3
- =ic :arrows
- %label
- ref :
- %input.p_product_ref_autocomplete_input.form-control.col{:type => "text", :value => ("#{form.object.p_product_ref.ref} #{form.object.p_product_ref.cc_name}" if form.object.p_product_ref)}
+ .col-11
+ .row
+ .col-5.row
+ .col-2.d-flex
+ .take.mx-3
+ =ic :arrows
+ %label
+ Référence :
+ %input.p_product_ref_autocomplete_input.form-control.col{:type => "text", :value => ("#{form.object.p_product_ref.ref} #{form.object.p_product_ref.cc_name}" if form.object.p_product_ref)}
- .col-3.ml-2
- .form-inline
- = form.input :qte, :label => "qte :", :input_html => { class: "mx-2", autofocus: true, tabindex: 1}
- .col-2
- .form-inline
- = form.input :ct_u_price_ht, :label => "PU :", :input_html => { class: "mx-2"}
- .col-1.ml-2
- %span.destroy=link_to_remove_fields ic(:"trash-o"), form
- = form.hidden_field :p_product_ref_id, :class => "p_product_ref_id"
+ .col-3.ml-2
+ .form-inline
+ = form.input :qte, :label => "Quantité :", :input_html => { class: "mx-2", autofocus: true, tabindex: 1}
+ .col-2
+ .form-inline
+ = form.input :ct_u_price_ht, :label => "Prix unitaire HT :", :input_html => { class: "mx-2"}
+ .row
+ .col-5.row
+ .col-2.d-flex
+ .take.mx-3
-
-
- =qi_js_field(form, :price_line, :tva_account_value, :hidden => true)
-
- = form.hidden_field :position, :class => "price_line_position_input"
+ .form-inline
+ =# form.input :ac_tot_amount_ht, :label => "Prix total HT :", :input_html => { class: "mx-2", disabled: true}
+ %label Montant HT :
+ =price_line.tot_amount_ht
+ .col-1
+ .col-1.ml-2
+ %span.destroy=link_to_remove_fields ic(:"trash-o"), form
+ = form.hidden_field :p_product_ref_id, :class => "p_product_ref_id"
+ = qi_js_field(form, :price_line, :tva_account_value, :hidden => true)
+ = form.hidden_field :position, :class => "price_line_position_input"
diff --git a/db/migrate/20211028091122_create_tva_types.rb b/db/migrate/20211028091122_create_tva_types.rb
index 1d54a38..c877bca 100644
--- a/db/migrate/20211028091122_create_tva_types.rb
+++ b/db/migrate/20211028091122_create_tva_types.rb
@@ -6,12 +6,8 @@ class CreateTvaTypes < ActiveRecord::Migration[6.0]
t.timestamps
end
- TvaType.create(name: "basique")
+ TvaType.create(name: "Standard")
TvaType.create(name: "Sur Marge")
-
- add_reference :price_documents, :tva_type, index: true
- add_column :price_documents, :ac_tva_type_name, :string
- add_column :price_documents, :cc_tva_type_name, :string
- add_column :price_line_blocks, :package_number, :integer
+
end
end
diff --git a/db/migrate/20211029111104_add_columns_to_price_docs_adn_price_line_blocks.rb b/db/migrate/20211029111104_add_columns_to_price_docs_adn_price_line_blocks.rb
new file mode 100644
index 0000000..eafc48e
--- /dev/null
+++ b/db/migrate/20211029111104_add_columns_to_price_docs_adn_price_line_blocks.rb
@@ -0,0 +1,10 @@
+class AddColumnsToPriceDocsAdnPriceLineBlocks < ActiveRecord::Migration[6.0]
+ def change
+ add_reference :price_documents, :tva_type, index: true
+ add_column :price_documents, :ac_tva_type_name, :string
+ add_column :price_documents, :cc_tva_type_name, :string
+ add_column :price_documents, :supplier_document_date, :date
+ add_column :price_line_blocks, :stock_entrance_date, :date
+ add_column :price_line_blocks, :ct_tot_amount_ht, :decimal, :precision => 14, :scale => 2
+ end
+end
diff --git a/db/schema.rb b/db/schema.rb
index bb88940..1a08c45 100644
--- a/db/schema.rb
+++ b/db/schema.rb
@@ -10,7 +10,7 @@
#
# It's strongly recommended that you check this file into your version control system.
-ActiveRecord::Schema.define(version: 2021_10_28_091122) do
+ActiveRecord::Schema.define(version: 2021_10_29_111104) do
# These are extensions that must be enabled in order to support this database
enable_extension "plpgsql"
@@ -2307,6 +2307,7 @@ ActiveRecord::Schema.define(version: 2021_10_28_091122) do
t.bigint "tva_type_id"
t.string "ac_tva_type_name"
t.string "cc_tva_type_name"
+ t.date "supplier_document_date"
t.index ["p_customer_id"], name: "index_price_documents_on_p_customer_id"
t.index ["tva_type_id"], name: "index_price_documents_on_tva_type_id"
end
@@ -2457,7 +2458,8 @@ ActiveRecord::Schema.define(version: 2021_10_28_091122) do
t.boolean "imported", default: false
t.date "validation_date"
t.string "cc_state"
- t.integer "package_number"
+ t.date "stock_entrance_date"
+ t.decimal "ct_tot_amount_ht", precision: 14, scale: 2
t.index ["p_customer_id"], name: "index_price_line_blocks_on_p_customer_id"
end
From f1bad61fd2722ae319293df1754d5bb0b8ff613b Mon Sep 17 00:00:00 2001
From: Philippe
Date: Tue, 2 Nov 2021 19:36:31 +0100
Subject: [PATCH 04/12] adding nested p articles and SN
---
app/assets/stylesheets/pane_hover.scss | 2 +-
.../admin/price_lines_controller.rb | 15 +++++-
app/helpers/application_helper.rb | 3 +-
app/helpers/document_line_helper.rb | 12 +++++
app/models/line_stock.rb | 2 +
app/models/p_article.rb | 4 ++
app/models/p_customer.rb | 9 +++-
app/models/p_customer_sheet.rb | 3 +-
app/models/price_document.rb | 8 ++--
app/models/price_line.rb | 3 ++
app/models/price_line_block.rb | 2 +-
app/models/price_line_p_article.rb | 4 ++
.../p_article_serial_nums/_form.html.haml | 9 ++--
app/views/admin/p_articles/_form.html.haml | 47 ++++++++++++-------
.../admin/p_customer_sheets/_form.html.haml | 30 ++++++++----
app/views/admin/p_products/_form.html.haml | 24 ++++------
.../admin/price_documents/_form.html.haml | 2 +-
.../admin/price_documents/show.html.haml | 47 +++++++++----------
.../admin/price_line_blocks/_form.html.haml | 2 +-
.../_form_facture_achat.html.haml | 19 ++++----
.../price_lines/_add_p_article_form.html.haml | 9 ++++
.../_reponse_pane_hover_form.html.haml | 2 -
...p_articles.js.erb => add_p_article.js.erb} | 2 +-
config/routes.rb | 1 +
...211102094225_add_stockable_to_p_product.rb | 6 +++
...1102105934_create_price_line_p_articles.rb | 12 +++++
db/schema.rb | 13 ++++-
test/fixtures/price_line_p_articles.yml | 11 +++++
test/models/price_line_p_article_test.rb | 7 +++
29 files changed, 212 insertions(+), 98 deletions(-)
create mode 100644 app/models/price_line_p_article.rb
create mode 100644 app/views/admin/price_lines/_add_p_article_form.html.haml
rename app/views/admin/price_lines/{add_p_articles.js.erb => add_p_article.js.erb} (68%)
create mode 100644 db/migrate/20211102094225_add_stockable_to_p_product.rb
create mode 100644 db/migrate/20211102105934_create_price_line_p_articles.rb
create mode 100644 test/fixtures/price_line_p_articles.yml
create mode 100644 test/models/price_line_p_article_test.rb
diff --git a/app/assets/stylesheets/pane_hover.scss b/app/assets/stylesheets/pane_hover.scss
index 31ad878..e94bb43 100644
--- a/app/assets/stylesheets/pane_hover.scss
+++ b/app/assets/stylesheets/pane_hover.scss
@@ -10,7 +10,7 @@
.actions{
- position:absolute;
+ position: static;
bottom:0px;
left:0px;
right:0px;
diff --git a/app/controllers/admin/price_lines_controller.rb b/app/controllers/admin/price_lines_controller.rb
index 0874893..be13d20 100644
--- a/app/controllers/admin/price_lines_controller.rb
+++ b/app/controllers/admin/price_lines_controller.rb
@@ -1,5 +1,5 @@
# -*- encoding : utf-8 -*-
-
+require "awesome_print"
class Admin::PriceLinesController < ApplicationController
layout "admin"
before_action :auth_admin, :except => [:edit, :update]
@@ -44,12 +44,17 @@ class Admin::PriceLinesController < ApplicationController
def update
+ puts "PAAMSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSS"
+ puts params
+ puts "PAAMSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSS"
@price_line = PriceLine.find(params[:id])
-
if @price_line.update_attributes(params.require(:price_line).permit!)
else
+ puts "ERRORSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSS"
+ puts @price_line.errors.messages
+ puts "ERRORSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSS"
render action: "edit"
end
@@ -62,4 +67,10 @@ class Admin::PriceLinesController < ApplicationController
@price_line.destroy
end
+
+ def add_p_article
+ @price_line = PriceLine.find(params[:price_line_id])
+ # @p_article = PArticle.new#@price_line.p_articles.build
+ # @p_article_serial_nums = @p_article.p_article_serial_nums.build
+ end
end
diff --git a/app/helpers/application_helper.rb b/app/helpers/application_helper.rb
index 31e8de0..43aa011 100644
--- a/app/helpers/application_helper.rb
+++ b/app/helpers/application_helper.rb
@@ -78,7 +78,6 @@ module ApplicationHelper
icon = sort_direction == "asc" ? "chevron-up" : "chevron-down"
icon = column == sort_column ? icon : ""
link_to raw("#{title} "+ic(icon).html_safe), request.query_parameters.merge({column: column, direction: direction})
- end
-
+ end
end
diff --git a/app/helpers/document_line_helper.rb b/app/helpers/document_line_helper.rb
index 0e54205..88a9a6e 100644
--- a/app/helpers/document_line_helper.rb
+++ b/app/helpers/document_line_helper.rb
@@ -20,6 +20,18 @@ module DocumentLineHelper
end
+
+ if association == :p_articles
+
+
+
+ new_object.p_product_ref_id = f.object.p_product_ref_id
+
+
+
+
+ end
+
if options[:partial]
fields = f.fields_for(association, new_object, :child_index => "new_#{association}") do |builder|
render(options[:partial], :form => builder)
diff --git a/app/models/line_stock.rb b/app/models/line_stock.rb
index a8886b9..9847dfb 100644
--- a/app/models/line_stock.rb
+++ b/app/models/line_stock.rb
@@ -6,6 +6,8 @@
belongs_to :price_line_block
belongs_to :stock_movement_line
belongs_to :partition_lines
+
+
acts_as_sorting :fields => {
:id => {:name => "ID", :reorder => false},
:date => {:name => "Date", :reorder => true, :as => :date},
diff --git a/app/models/p_article.rb b/app/models/p_article.rb
index ca44f4f..bd9cbdc 100644
--- a/app/models/p_article.rb
+++ b/app/models/p_article.rb
@@ -7,8 +7,12 @@ class PArticle < ApplicationRecord
has_many :p_article_serial_nums, dependent: :destroy
# has_many :p_serial_num_values, through: :p_article_serial_nums
+ has_many :price_line_p_articles
+ has_many :price_lines, through: :price_line_p_articles
accepts_nested_attributes_for :p_article_serial_nums
+
+
validates_presence_of :p_product_ref
# has_many :p_product_ref_specs, through: :p_product_ref
# accepts_nested_attributes_for :p_product_ref_specs
diff --git a/app/models/p_customer.rb b/app/models/p_customer.rb
index 372e15b..0d11ced 100644
--- a/app/models/p_customer.rb
+++ b/app/models/p_customer.rb
@@ -73,8 +73,13 @@ class PCustomer < ApplicationRecord
def generate_code
if !self.code
- last_used_code = self.class.all.order(code: :desc).limit(1)[0].code
- last_number = last_used_code.match(/\d+/).to_s.to_i + 1
+ if self.class.all.order(code: :desc).limit(1)[0]
+ last_used_code = self.class.all.order(code: :desc).limit(1)[0].code
+ last_number = last_used_code.match(/\d+/).to_s.to_i + 1
+ else
+ last_used_code = 1
+ last_number = 1
+ end
code = "CLI%04d" % [last_number]
diff --git a/app/models/p_customer_sheet.rb b/app/models/p_customer_sheet.rb
index cada486..45d7409 100644
--- a/app/models/p_customer_sheet.rb
+++ b/app/models/p_customer_sheet.rb
@@ -12,8 +12,9 @@ class PCustomerSheet < ApplicationRecord
belongs_to :p_customer
belongs_to :particular_bill, :class_name => "Particular"#, :dependent => :destroy
+ accepts_nested_attributes_for :particular_bill
belongs_to :particular_send, :class_name => "Particular"#, :dependent => :destroy
-
+ accepts_nested_attributes_for :particular_send
has_one :price_line_block, :as => :price_lineable
diff --git a/app/models/price_document.rb b/app/models/price_document.rb
index 0f019c2..de113f8 100644
--- a/app/models/price_document.rb
+++ b/app/models/price_document.rb
@@ -284,7 +284,7 @@ class PriceDocument < ApplicationRecord
:label => {:name => "Type", :reorder => false},
:stock_ok => {:name => "Stock mis à jour ?", :reorder => true},
:tva_type_name => {:name => "ID Type de TVA", :reorder => true},
- :package_number => {:name => "Nombre de colis", :reorder => true},
+ #:package_number => {:name => "Nombre de colis", :reorder => true},
:d_number => {:name => "Numéro", :reorder => true},
:date => {:name => "Date", :reorder => true},
:cc_payment_end_at => {:name => "Date d'échance", :reorder => true},
@@ -308,9 +308,9 @@ class PriceDocument < ApplicationRecord
self.tva_type.name
end
- def package_number
- self.price_line_block.package_number
- end
+ # def package_number
+ # self.price_line_block.package_number
+ # end
def self.valid_sort
r = []
diff --git a/app/models/price_line.rb b/app/models/price_line.rb
index dc50cd1..3eb2621 100644
--- a/app/models/price_line.rb
+++ b/app/models/price_line.rb
@@ -10,6 +10,9 @@ class PriceLine < ApplicationRecord
has_one :p_fournisseur, :through => :price_line_block
#has_many :price_line_demands, through: :price_line_resp_selects
+ has_many :price_line_p_articles
+ has_many :p_articles, through: :price_line_p_articles
+ accepts_nested_attributes_for :p_articles
default_scope { order('position ASC') }
diff --git a/app/models/price_line_block.rb b/app/models/price_line_block.rb
index 0bdb058..8e4ee2c 100644
--- a/app/models/price_line_block.rb
+++ b/app/models/price_line_block.rb
@@ -543,7 +543,7 @@ class PriceLineBlock < ApplicationRecord
def ca_tot_lines_tva
r = 0.0
self.price_lines.each do |pl|
- r+= pl.tot_amount_tva
+ r+= pl.tot_amount_tva if pl
end
return r
end
diff --git a/app/models/price_line_p_article.rb b/app/models/price_line_p_article.rb
new file mode 100644
index 0000000..2edaf5e
--- /dev/null
+++ b/app/models/price_line_p_article.rb
@@ -0,0 +1,4 @@
+class PriceLinePArticle < ApplicationRecord
+ belongs_to :price_line
+ belongs_to :p_article
+end
diff --git a/app/views/admin/p_article_serial_nums/_form.html.haml b/app/views/admin/p_article_serial_nums/_form.html.haml
index d3ec238..88de8b6 100644
--- a/app/views/admin/p_article_serial_nums/_form.html.haml
+++ b/app/views/admin/p_article_serial_nums/_form.html.haml
@@ -12,7 +12,8 @@
.actions=f.submit "sauvegarder", :class => "btn btn-primary"
- else
- .p_article_serial_nums_form.field
- =form.inputs do
- = form.input :p_serial_num_type_id, :label => "type", as: :select, collection: PSerialNumType.pluck(:name, :id)
- = form.input :value
+ .ml-5
+ .p_article_serial_nums_form.field
+ =form.inputs do
+ = form.input :p_serial_num_type_id, :label => "type", as: :select, collection: PSerialNumType.pluck(:name, :id)
+ = form.input :value
diff --git a/app/views/admin/p_articles/_form.html.haml b/app/views/admin/p_articles/_form.html.haml
index 4da53fd..3a2568b 100644
--- a/app/views/admin/p_articles/_form.html.haml
+++ b/app/views/admin/p_articles/_form.html.haml
@@ -1,17 +1,32 @@
-=semantic_form_for [:admin, @p_article], :remote => true do |f|
+- if params[:controller] == "admin/p_articles"
+ =semantic_form_for [:admin, @p_article], :remote => true do |f|
+ .content
+ =f.inputs do
+ -if params[:p_product_ref_id]
+ = f.input :p_product_ref, as: :select, collection: PProductRef.all.distinct.pluck(:cc_name, :id), :selected => f.object.p_product_ref , :label => f.object.label_for(:p_product_ref)
+ -else
+ = f.input :p_product_ref, as: :select, collection: PProductRef.all.distinct.pluck(:cc_name, :id), :label => f.object.label_for(:p_product_ref)
+ -if PGrade::ACTIVATED
+ = f.input :p_grade, as: :select, collection: PGrade.pluck(:grade, :id), :label => "Grade"
+ %h4 Numero de série :
+ .p_article_serial_nums_form
+ = f.semantic_fields_for :p_article_serial_nums do |form|
+ =render :partial => "admin/p_article_serial_nums/form", :locals => {:form => form}
+ %p= link_to_add_fields "Ajouter un numéro de série", f, :p_article_serial_nums, {:class => "btn btn-primary"}
- .content
- =f.inputs do
- -if params[:p_product_ref_id]
- = f.input :p_product_ref, as: :select, collection: PProductRef.all.distinct.pluck(:cc_name, :id), :selected => f.object.p_product_ref , :label => f.object.label_for(:p_product_ref)
- -else
- = f.input :p_product_ref, as: :select, collection: PProductRef.all.distinct.pluck(:cc_name, :id), :label => f.object.label_for(:p_product_ref)
- -if PGrade::ACTIVATED
- = f.input :p_grade, as: :select, collection: PGrade.pluck(:grade, :id), :label => "Grade"
- %h4 Numero de série :
- .p_article_serial_nums_form
- = f.semantic_fields_for :p_article_serial_nums do |form|
- =render :partial => "admin/p_article_serial_nums/form", :locals => {:form => form}
- %p= link_to_add_fields "Ajouter un numéro de série", f, :p_article_serial_nums, {:class => "btn btn-primary"}
-
- .actions=f.submit "sauvegarder", :class => "btn btn-primary"
+ .actions=f.submit "sauvegarder", :class => "btn btn-primary"
+- else
+ = form.inputs do
+ -if params[:p_product_ref_id]
+ = form.input :p_product_ref_id, as: :select, collection: PProductRef.all.distinct.pluck(:cc_name, :id), :label => form.object.label_for(:p_product_ref), input_html: {disabled: true}
+ = form.hidden_field :p_product_ref_id, value: form.object.p_product_ref_id
+ -else
+ = form.input :p_product_ref_id, as: :select, collection: PProductRef.all.distinct.pluck(:cc_name, :id), :label => form.object.label_for(:p_product_ref), input_html: {disabled: true}
+ = form.hidden_field :p_product_ref_id, value: form.object.p_product_ref_id
+ -if PGrade::ACTIVATED
+ = form.input :p_grade, as: :select, collection: PGrade.pluck(:grade, :id), :label => "Grade"
+ %h4 Numero de série :
+ .p_article_serial_nums_form
+ = form.semantic_fields_for :p_article_serial_nums do |form|
+ =render :partial => "admin/p_article_serial_nums/form", :locals => {:form => form}
+ %p= link_to_add_fields "Ajouter un numéro de série", form, :p_article_serial_nums, {:class => "btn btn-primary"}
diff --git a/app/views/admin/p_customer_sheets/_form.html.haml b/app/views/admin/p_customer_sheets/_form.html.haml
index 2c1194a..f38a269 100755
--- a/app/views/admin/p_customer_sheets/_form.html.haml
+++ b/app/views/admin/p_customer_sheets/_form.html.haml
@@ -5,21 +5,31 @@
.content
.qi_row
.qi_pannel.qi_plain.padding.row
- .col-2
+ .col-8
+ =@p_customer_sheet.p_customer.particular.organisation
-if @p_customer_sheet and @p_customer_sheet.state != "commande"
=#form.input :demande_type, :collection => ["Brouillon", "Demande de bon de commande","Demande de devis"], :as => :select, :include_blank => false, :label => "Type de demande :"
-
- =form.input :state, :collection => ["AV BPA", "PAS BPA","BPA", "Traitée"], :as => :select, :include_blank => false, :label => "Statut :"
-
- =form.input :past_id, :label => "N° système actuel"
- =yield :discount
- .col-2
+ =#form.input :state, :collection => ["AV BPA", "PAS BPA","BPA", "Traitée"], :as => :select, :include_blank => false, :label => "Statut :"
+ =#form.input :past_id, :label => "N° système actuel"
=yield :shipping_date
- .col-8
- =yield :particular
+
+ .qi_row
+ .qi_pannel.qi_plain.padding.row
+ nested form for particular send et bill qui crée à chaque fois un particular
+ ajouter accept nested attributed for particular dans pcustomer sheet
+
- =yield :price_lines
+ .qi_row
+ .qi_pannel.qi_plain.padding.row
+ =yield :price_lines
+ .qi_row
+ .qi_pannel.qi_plain.padding.row
+ =yield :discount
+
+
+
+
.large_actions
.actions
=link_to "Annuler", admin_p_customer_sheets_path(), :class => "btn"
diff --git a/app/views/admin/p_products/_form.html.haml b/app/views/admin/p_products/_form.html.haml
index 0b0953c..d8f02c4 100755
--- a/app/views/admin/p_products/_form.html.haml
+++ b/app/views/admin/p_products/_form.html.haml
@@ -4,26 +4,24 @@
.qi_pannel.qi_plain.padding
=f.inputs do
.row.qi_cancel_margins
-
.col-sm-2
= f.input :p_product_cat_id, :label => "Catégorie produit :", :collection => PProductCat.all, :as => :select, :include_blank => false
-
-
.col-sm-2
%br
= f.input :enabled, :label => "Produit actif ?"
-
.col-sm-2
-
+ %br
+ = f.input :stockable, :label => "Produit stockable ?", :input_html => {:onclick => "$('#with_serial').toggle('slow');"}
+ .col-sm-2
+ %br
+ #with_serial
+ = f.input :with_serial_number, :label => "Avec n° de série ?"
+ .col-sm-2
=f.input :s_brand_id, :label => "Marque :", :collection => SBrand.all, :as => :select, :include_blank => true
-
=# f.input :stocked, :label => "Suivi de stock ?"
-
.col-sm-2
=#f.input :sorecop_cat, label: "Catgorie Sorecop :", :collection => SorecopCat.all, :as => :select, :include_blank => true
-
-
-
+
-if false
%table{:style => "width:100%"}
%tr
@@ -108,9 +106,3 @@
}
-
-
-
-
-
-
diff --git a/app/views/admin/price_documents/_form.html.haml b/app/views/admin/price_documents/_form.html.haml
index 3062be9..0f516cc 100644
--- a/app/views/admin/price_documents/_form.html.haml
+++ b/app/views/admin/price_documents/_form.html.haml
@@ -45,7 +45,7 @@ PRICE_DOCUMENTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTT
-if @price_document.price_document_type_id == 6 or @price_document.price_document_type_id == 7
.row
.col-6
- = f.input :date, :label => "Date de la facture achat :", :as => :date
+ = f.input :date, :label => "Date de la facture achat :", :as => :date, input_html: {value: Date.today}
.col-6
= f.input :supplier_document_date, :label => "Date du document fournisseur :", :as => :date
.col-6
diff --git a/app/views/admin/price_documents/show.html.haml b/app/views/admin/price_documents/show.html.haml
index 87f7ba9..59cf845 100644
--- a/app/views/admin/price_documents/show.html.haml
+++ b/app/views/admin/price_documents/show.html.haml
@@ -18,7 +18,7 @@
.qi_row
-
+ =debug @price_document.price_line_block.price_lines.count
%table.table.table-striped
-if @price_document.label == "Réponse fournisseur"
@@ -196,7 +196,7 @@
%table.table
%thead
%tr
- %th
+ %th ID
%th Référence
%th Marque
%th Désignation
@@ -205,47 +205,46 @@
%th TVA
%th Montant HT
%th Actions
-
- %tbody
- -price_line_block.price_lines.each do |price_line|
+
+ -price_line_block.price_lines.each do |price_line|
+ %tbody
%tr
- %td
- ="##{price_line.id}"
+ -if price_line.p_articles.count == 0
+ %td{style: "background-color: red;"}
+ ="##{price_line.id}"
+ - elsif price_line.p_articles.count < price_line.qte
+ %td{style: "background-color: orange"}
+ ="##{price_line.id}"
+ - else
+ %td{style: "background-color: green"}
+ ="##{price_line.id}"
%td
=price_line.ref
-
-
-
-
%td
=price_line.p_product_ref.p_product.s_brand.name
-
%td{class: "p_product_ref_cc_name_#{@price_document.id}"}
=link_to price_line.p_product_ref.cc_name, edit_admin_p_product_path(price_line.p_product_ref.p_product) if price_line.p_product_ref and price_line.p_product_ref.p_product
-
%td.numeraire{class: "price_line_qte_#{@price_document.id}"}
=price_line.qte
-
%td.numeraire{class: "price_line_price_u_ht_#{@price_document.id}"}
=number_to_currency price_line.price_u_ht
-
-
%td.numeraire
=price_line.tva_account_value.to_s+"%"
-
-
-
-
%td.numeraire
=number_to_currency price_line.tot_amount_ht
-
%td.actions
= link_to i(:"trash-o"), admin_price_line_path(price_line), method: :delete, data: { confirm: 'Voulez-vous vraiment supprimer cet enregistrement ? ' } , :remote => true
= link_to i(:pencil), edit_admin_price_line_path(price_line), :remote => true
= link_to i(:eye), admin_price_line_path(price_line), :remote => true
- = link_to i(:"mobile-alt"), new_admin_p_article_path(p_product_ref_id: price_line.p_product_ref.id), :remote => true
-
- / %td=# price_line.line_stocks.sum(:price_ht)
+ = link_to i(:"mobile-alt"), add_p_article_admin_price_lines_path(p_product_ref_id: price_line.p_product_ref.id, price_line_id: price_line.id), :remote => true
+ -price_line.p_articles.each do |p_article|
+ %tr
+ %td
+ %td="##{p_article.id}"
+ %td=p_article.p_product_ref.name
+ %td
+ - p_article.p_article_serial_nums.each do |sn|
+ ="#{sn.p_serial_num_type.name} - #{sn.value} /"
.qi_row
-if current_admin.has_permission?("show-costs")
diff --git a/app/views/admin/price_line_blocks/_form.html.haml b/app/views/admin/price_line_blocks/_form.html.haml
index f01c327..8f441a3 100644
--- a/app/views/admin/price_line_blocks/_form.html.haml
+++ b/app/views/admin/price_line_blocks/_form.html.haml
@@ -80,7 +80,7 @@
=content_for :discount do
-if !@p_customer_sheet or (@p_customer_sheet and @p_customer_sheet.state != "commande")
-if !@avoir
- = f.input :ct_tot_discount_percent, :label => "Réduction pied de page (%) :", :input_html => {:class => "input_price_line_block_ct_tot_discount_percent"}
+ = f.input :ct_tot_discount_percent, :label => "Réduction pied de page (%) :"#, :input_html => {:class => "input_price_line_block_ct_tot_discount_percent"}
= f.input :ct_tot_fdp_ht, :label => "Frais de port personnalisés :"
diff --git a/app/views/admin/price_line_blocks/_form_facture_achat.html.haml b/app/views/admin/price_line_blocks/_form_facture_achat.html.haml
index 82c3485..db81fc0 100644
--- a/app/views/admin/price_line_blocks/_form_facture_achat.html.haml
+++ b/app/views/admin/price_line_blocks/_form_facture_achat.html.haml
@@ -42,14 +42,14 @@ PRICE LINE BLOCKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKK
=# f.input :ct_creation_date, :label => "Date de commande (si différente de la date de création) :", :as => :date
.row
.col-6
- = f.input :stock_entrance_date, :label => "Date d'entrée en stock :", :as => :date
+ = f.input :stock_entrance_date, :label => "Date d'entrée en stock :", :as => :date, input_html: {value: Date.today}
.row
.col-6
= f.input :customer_ref, :label => "Référence commande fournisseur :"
-if current_admin.has_permission?("customer-sheets-bl")
- = f.input :bl_comment, :label => "Commentaire à mettre sur le BL :", :input_html => {:style => "min-height:50px;height:50px;"}
+ =# f.input :bl_comment, :label => "Commentaire à mettre sur le BL :", :input_html => {:style => "min-height:50px;height:50px;"}
-if @p_customer_sheet and @p_customer_sheet.p_customer and @p_customer_sheet.p_customer.p_customer_sheet_note?
%div
@@ -71,17 +71,18 @@ PRICE LINE BLOCKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKK
.qi_pannel.qi_plain.padding.price_line_block_footer{:style => "margin:20px 0;"}
-if !@p_customer_sheet or (@p_customer_sheet and @p_customer_sheet.state != "commande")
+ = f.input :cc_tot_amount_ht, label: "Somme HT des produits", input_html: {disabled: true}
-if !@avoir
- = f.input :ct_tot_discount_percent, :label => "Réduction pied de page (%) :", :input_html => {:class => "input_price_line_block_ct_tot_discount_percent"}
- = f.input :ct_tot_fdp_ht, :label => "Montant des frais de port HT (€) :"
+ =# f.input :ct_tot_discount_percent, :label => "Réduction pied de page (%) :", :input_html => {:class => "input_price_line_block_ct_tot_discount_percent"}
+ =# f.input :ct_tot_fdp_ht, :label => "Montant des frais de port HT (€) :"
-if !@avoir
-if current_admin.has_permission?("customer-sheets-bl")
- = f.input :ct_nbr_ship, :label => "Nombre de colis :"
-
- = f.input :cc_tot_amount_ttc, label: "Montant TTC à payer", :input_html => {disabled: true}
- = f.input :cc_tot_amount_ht, label: "Montant HT à payer", input_html: {disabled: true}
- = f.input :ct_tot_amount_ht, label: "Montant HT personnalisé"
+ =# f.input :ct_nbr_ship, :label => "Nombre de colis :"
+ = f.input :ct_tot_amount_ht, label: "Montant HT à payer"
+ = f.input :cc_tot_amount_ttc, label: "Montant TTC à payer", :input_html => {disabled: false}
+
+
-if current_admin.has_permission?("payments")
diff --git a/app/views/admin/price_lines/_add_p_article_form.html.haml b/app/views/admin/price_lines/_add_p_article_form.html.haml
new file mode 100644
index 0000000..6367aa5
--- /dev/null
+++ b/app/views/admin/price_lines/_add_p_article_form.html.haml
@@ -0,0 +1,9 @@
+.mx-2.my-2
+ =semantic_form_for [:admin, @price_line], :remote => true do |f|
+ .content
+ =f.inputs do
+ .p_articles_form
+ = f.semantic_fields_for :p_articles do |form|
+ =render :partial => "admin/p_articles/form", :locals => {:form => form, @price_line => f.object}
+ %p= link_to_add_fields "Ajouter un article", f, :p_articles, {:class => "btn btn-primary"} if f.object.p_articles.count < f.object.qte
+ .actions=f.submit "Sauvegarder", :class => "btn btn-primary"
diff --git a/app/views/admin/price_lines/_reponse_pane_hover_form.html.haml b/app/views/admin/price_lines/_reponse_pane_hover_form.html.haml
index 4444417..7bf404a 100644
--- a/app/views/admin/price_lines/_reponse_pane_hover_form.html.haml
+++ b/app/views/admin/price_lines/_reponse_pane_hover_form.html.haml
@@ -1,5 +1,3 @@
-
-
=semantic_form_for [:admin, @price_line], :remote => true do |form|
.content
diff --git a/app/views/admin/price_lines/add_p_articles.js.erb b/app/views/admin/price_lines/add_p_article.js.erb
similarity index 68%
rename from app/views/admin/price_lines/add_p_articles.js.erb
rename to app/views/admin/price_lines/add_p_article.js.erb
index dc68c39..b669ed6 100644
--- a/app/views/admin/price_lines/add_p_articles.js.erb
+++ b/app/views/admin/price_lines/add_p_article.js.erb
@@ -1 +1 @@
-show_pane_hover("<%= escape_javascript(render(:partial => "add_p_articles_form"))%>",700,900);
\ No newline at end of file
+show_pane_hover("<%= escape_javascript(render(:partial => "add_p_article_form"))%>",700,900);
\ No newline at end of file
diff --git a/config/routes.rb b/config/routes.rb
index a385f22..6c3c724 100644
--- a/config/routes.rb
+++ b/config/routes.rb
@@ -697,6 +697,7 @@ Rails.application.routes.draw do
end
collection do
+ get :add_p_article
end
end
diff --git a/db/migrate/20211102094225_add_stockable_to_p_product.rb b/db/migrate/20211102094225_add_stockable_to_p_product.rb
new file mode 100644
index 0000000..db26f91
--- /dev/null
+++ b/db/migrate/20211102094225_add_stockable_to_p_product.rb
@@ -0,0 +1,6 @@
+class AddStockableToPProduct < ActiveRecord::Migration[6.0]
+ def change
+ add_column :p_products, :stockable, :boolean
+ add_column :p_products, :with_serial_number, :boolean
+ end
+end
diff --git a/db/migrate/20211102105934_create_price_line_p_articles.rb b/db/migrate/20211102105934_create_price_line_p_articles.rb
new file mode 100644
index 0000000..b505378
--- /dev/null
+++ b/db/migrate/20211102105934_create_price_line_p_articles.rb
@@ -0,0 +1,12 @@
+class CreatePriceLinePArticles < ActiveRecord::Migration[6.0]
+ def change
+ create_table :price_line_p_articles do |t|
+ t.belongs_to :p_article
+ t.belongs_to :price_line
+
+ t.timestamps
+ end
+ #add_reference :price_lines, :price_line_p_article, index: true
+ #add_reference :p_articles, :price_line_p_article, index: true
+ end
+end
diff --git a/db/schema.rb b/db/schema.rb
index 1a08c45..3fe7b90 100644
--- a/db/schema.rb
+++ b/db/schema.rb
@@ -10,7 +10,7 @@
#
# It's strongly recommended that you check this file into your version control system.
-ActiveRecord::Schema.define(version: 2021_10_29_111104) do
+ActiveRecord::Schema.define(version: 2021_11_02_105934) do
# These are extensions that must be enabled in order to support this database
enable_extension "plpgsql"
@@ -1930,6 +1930,8 @@ ActiveRecord::Schema.define(version: 2021_10_29_111104) do
t.boolean "conserve_proportion", default: false
t.boolean "frontpage", default: true
t.integer "sorecop_cat_id"
+ t.boolean "stockable"
+ t.boolean "with_serial_number"
t.index ["p_product_cat_id"], name: "index_p_products_on_p_product_cat_id"
t.index ["s_brand_id"], name: "index_p_products_on_s_brand_id"
end
@@ -2463,6 +2465,15 @@ ActiveRecord::Schema.define(version: 2021_10_29_111104) do
t.index ["p_customer_id"], name: "index_price_line_blocks_on_p_customer_id"
end
+ create_table "price_line_p_articles", force: :cascade do |t|
+ t.bigint "p_article_id"
+ t.bigint "price_line_id"
+ t.datetime "created_at", precision: 6, null: false
+ t.datetime "updated_at", precision: 6, null: false
+ t.index ["p_article_id"], name: "index_price_line_p_articles_on_p_article_id"
+ t.index ["price_line_id"], name: "index_price_line_p_articles_on_price_line_id"
+ end
+
create_table "price_line_resp_selects", force: :cascade do |t|
t.integer "price_line_demand_id"
t.integer "price_line_resp_id"
diff --git a/test/fixtures/price_line_p_articles.yml b/test/fixtures/price_line_p_articles.yml
new file mode 100644
index 0000000..5181636
--- /dev/null
+++ b/test/fixtures/price_line_p_articles.yml
@@ -0,0 +1,11 @@
+# Read about fixtures at https://api.rubyonrails.org/classes/ActiveRecord/FixtureSet.html
+
+# This model initially had no columns defined. If you add columns to the
+# model remove the '{}' from the fixture names and add the columns immediately
+# below each fixture, per the syntax in the comments below
+#
+one: {}
+# column: value
+#
+two: {}
+# column: value
diff --git a/test/models/price_line_p_article_test.rb b/test/models/price_line_p_article_test.rb
new file mode 100644
index 0000000..8c4666d
--- /dev/null
+++ b/test/models/price_line_p_article_test.rb
@@ -0,0 +1,7 @@
+require 'test_helper'
+
+class PriceLinePArticleTest < ActiveSupport::TestCase
+ # test "the truth" do
+ # assert true
+ # end
+end
From d0646650c75176c0814b123bd90c9e14c00200c3 Mon Sep 17 00:00:00 2001
From: Philippe
Date: Wed, 3 Nov 2021 16:37:41 +0100
Subject: [PATCH 05/12] adding SN to sell price_line
---
.../(__TEMPLATE__)c | Bin 5965 -> 1374 bytes
.../admin/line_stocks_controller.rb | 4 +
.../admin/p_customer_sheets_controller.rb | 21 ++--
.../admin/price_lines_controller.rb | 13 +--
app/helpers/application_helper.rb | 12 ++-
app/models/line_stock.rb | 3 +
app/models/line_stock_p_article.rb | 4 +
app/models/p_article.rb | 3 +
app/models/p_customer_sheet.rb | 3 +-
app/models/particular.rb | 1 +
app/models/price_document.rb | 5 +
app/models/price_line.rb | 1 +
app/models/price_line_block.rb | 21 +++-
.../admin/line_stocks/_line_stock.html.haml | 1 +
.../_show_p_article_form.html.haml | 13 +++
app/views/admin/line_stocks/index.html.haml | 1 +
.../admin/line_stocks/show_p_article.js.erb | 1 +
app/views/admin/p_articles/_form.html.haml | 3 +-
.../admin/p_customer_sheets/_form.html.haml | 20 +---
app/views/admin/particulars/_form.html.haml | 14 ++-
.../admin/price_documents/show.html.haml | 14 +--
.../admin/price_line_blocks/_form.html.haml | 100 ++++++++----------
.../_price_line_block.html.haml | 3 +
.../price_line_p_articles/_form.html.haml | 1 +
.../_add_price_line_p_article_form.html.haml | 9 ++
.../add_price_line_p_article.js.erb | 1 +
config/routes.rb | 2 +
...1103085623_create_line_stock_p_articles.rb | 10 ++
db/schema.rb | 11 +-
test/fixtures/line_stock_p_articles.yml | 11 ++
test/models/line_stock_p_article_test.rb | 7 ++
31 files changed, 196 insertions(+), 117 deletions(-)
create mode 100644 app/models/line_stock_p_article.rb
create mode 100644 app/views/admin/line_stocks/_show_p_article_form.html.haml
create mode 100644 app/views/admin/line_stocks/show_p_article.js.erb
create mode 100644 app/views/admin/price_line_p_articles/_form.html.haml
create mode 100644 app/views/admin/price_lines/_add_price_line_p_article_form.html.haml
create mode 100644 app/views/admin/price_lines/add_price_line_p_article.js.erb
create mode 100644 db/migrate/20211103085623_create_line_stock_p_articles.rb
create mode 100644 test/fixtures/line_stock_p_articles.yml
create mode 100644 test/models/line_stock_p_article_test.rb
diff --git a/.sass-cache/f6b9a0b1905a68d5dbb2139e95d49cba92f6fa93/(__TEMPLATE__)c b/.sass-cache/f6b9a0b1905a68d5dbb2139e95d49cba92f6fa93/(__TEMPLATE__)c
index f14f6942a4eff9a4b9af0c9026e5b8e2e708b671..e1c3ae14c64ffb6b86d264611307231a215c18c3 100644
GIT binary patch
delta 389
zcmX@BcaKZYSkGL~gv-Ft$jCf3HQB=4I4#v6HPtxPBq=#1&D_W+H6It+*WW5_3~Mm3W{MlU*3sGxAOT!WauA
zgP5*QUc@3R#*>m+T#%Dk$!5(NV#V!HmY7qT8qGFYo>zSGdlp?8&b<7*RInVcLw-R?
zW`16AH3QJ(lFEYA$(F48%IwzS`PLGg){^!FD8Pv&LQl7O1)pl>bfAZ0D*AZ;yVV6Ew(F}aIP8t9#DHaRm5D?W#k
v)Lfu%N`SsrfrUpkmx2P+lU5+#SaWgJa&d8iJOy+U+vJbjiacy^Qw>7^kL+bZ
literal 5965
zcmbVQUvt~W5f?Qbii9jtbo9@ZEVHzu*orOEk{sE0Gwmg=JYgnrG#1krJz$RHi9!S7
zPym#pdi>UWh4f?eOSNC2eQb9Re~w2&ij*hfh}*s2?(P0|7yG-1y9d_c!NDQ#?RC4a
z&iLMo?w)8J?Dt;r=l$Nx7hJsT9f~iyqPyR+epiy@-U$ywLOOvEguIh7dMo?l4q0Tq
zbI0um!aFTbZW_4)H&uwm0(d?xwi{~?yRv_2hY^pQFmnDn5@C@Pk2>To^LY@8zKuIW
zNgDBSC&CrINCt$wmct=G5g_69M2Rf0p%`{W5S|t#xj(r%-8V;QNPD@13FViged}
zylZW8SG!*V=pG-6c4KuKH!XMIwd;7oDS{u)99Q7p7GMiU-M;{C^(aR{4=pO4h^Pnx
z=R7?BIP(T94%I6=;NCz;vYs5T{sb4}zhzQk;Hx0AeF-Wy%q_<Nw?l5_F
z7K#WS7ntz+N`%(bOS<8#!_f$_1yI3y8AKvzp&-2*|HO}EgN2FDZ37=&FVlNc>nqaD
zvDG@g-)?;J*tR=I-yMJZW#`DYpA^ACbW4(YjJlm13PJP+aDwKJ%Sg~6E^pK)C+zI1b6Mr)MRR}EnL|f^(xS`RQFKjS@6{!GzeTt3dXzB!B##da$vL>+Qg$D>x=Zh~8r@|8sY@TY!Y6Q!}IKdyCapKFPl4E-urP7$dT74kGjsl?nze$M#k2E9|sWk
zB3j>Rs`~)1UHXE|hnNKs_-+Qwg+P=(Mrin929TE~3@!msD}#+IlER*#lH)-7NF_^j
z2`^(sV|=FIsVmvWR8NBKq!&1Tl+x9=4g@=QOLTi`!=KS|LQbLpqM%H-k)pnM{o<>`
zug0uY>YuPz^fOX%`e2`P=7@kaSYP;o=OhIEWMQ_gNoolT>(b;xX;eu+AHx{ie#?w+
zWEqcV!HqBccAROo$Z#HqV$_%OWSOY|1CRA=m9=q*Z9XNlh7>GW0KecT)8ePxB^Lo#7dHWdWS-qw;QL;9hLYup(v|9#%VEMkot6z
zr&LBiqmRw3TTBBqNrOeers=i(Oq=(
z(!`ldaLQulS6pqSXDW(s(v}H2Pk{z)DtI1O6IS@Ual%4&!k$rX5-hCnbGkvBUG2)C
zFM?-*GdPb_9w03n)~_D;Kh;C&I{ow()IPyK
z^M5f;Sk6u`%}=nf!auSN84WI^xLKI#GDCTs%WAo7rM&U0{l#@WwS1E-)wzabyOCw7
z60SPS5QOT{%+h7pt0i#-l2>Kv{w=aJX(XnzZzXkUl6@<1roKsB?WYKI7*1p#d6aPW
zL|YI>No#Ll=OhJ6`QE2sXD6@-dY9!EN7vJt9z-p=v`Jzflk<)0DU{c5zC_6XQkHe3#{~H
zg?XbPG*d8>*(1*ZZ_Plb0X>m~?%4Qukx3u{_|t7SP#gfhftbnzxM2X)#0CJt*FTEO
z_dqHz|7^wX{2_8&Lf*$X(}eqW>ND=b&|heb5tN9|!Fwl&>N8;dh>ezRO`0gALH^
z5A1k(1(J$^w38A6pX>PYmMm7xYc
z(Uk#Lx`9uJ(5ySUdV(`rg==TAv{%?jothMg4LG`%c^6ktvzy2bhCBs27)%9eFwAZh
zj3czIX0wohVY3ekDTwKexTaOSkq0&>Jg^BiuV(OY^*B8|pAqsDXb+eQG7q%02XMz#
z`H+BNv(GaR=!B@H$k}W~t22XVKb;k!7QiPXWOMi+H~VgO`di`$t6tY1YH(GrH=Fuv
z!Og}65Yi&o3=E+Dqh)=xa=W;jOr!{~*}TOdV;FNivRLcnph4lp@eZA6!c8V33I^p{
zbbGWhhB~%Kj}?-qb!Y^hj14~5;2A3b3ez+fBA}aIRAO|3C};XZv#q3w%DzY>jDiia
NrnY#MHog0u{{w}+6Mp~z
diff --git a/app/controllers/admin/line_stocks_controller.rb b/app/controllers/admin/line_stocks_controller.rb
index 81131f2..caab464 100644
--- a/app/controllers/admin/line_stocks_controller.rb
+++ b/app/controllers/admin/line_stocks_controller.rb
@@ -133,4 +133,8 @@ class Admin::LineStocksController < ApplicationController
def empty_stock
@price_document = PriceDocument.where(:price_document_type_id => 4, :cost_ok => false)
end
+
+ def show_p_article
+ @line_stock = LineStock.find(params[:line_stock_id])
+ end
end
diff --git a/app/controllers/admin/p_customer_sheets_controller.rb b/app/controllers/admin/p_customer_sheets_controller.rb
index 8905ef1..806e13f 100644
--- a/app/controllers/admin/p_customer_sheets_controller.rb
+++ b/app/controllers/admin/p_customer_sheets_controller.rb
@@ -146,17 +146,20 @@ class Admin::PCustomerSheetsController < ApplicationController
def new
-
-
@p_customer_sheet = PCustomerSheet.new()
-
@p_customer = PCustomer.find(params[:p_customer_id]) if params[:p_customer_id]
-
+
+
@p_customer_sheet.p_customer = @p_customer
- @p_customer_sheet.price_line_block = PriceLineBlock.new(:particular_bill_id => @p_customer.particular_bill_id, :particular_send_id => @p_customer.particular_send_id)
+ @p_customer_sheet.price_line_block = PriceLineBlock.new
@p_customer_sheet.price_line_block.price_lines.build
@p_customer_sheet.price_line_block.p_customer = @p_customer
+
+ @p_customer_sheet.price_line_block.build_particular_send(owner: @p_customer)
+ @p_customer_sheet.price_line_block.build_particular_bill(owner: @p_customer)
+
+
end
@@ -171,15 +174,15 @@ class Admin::PCustomerSheetsController < ApplicationController
def create
@p_customer_sheet = PCustomerSheet.new(params.require(:p_customer_sheet).permit!)
-
@p_customer_sheet.admin = current_admin
-
-
-
if @p_customer_sheet.save
redirect_to admin_p_customer_sheet_path(@p_customer_sheet)
else
+ puts "ERRORSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSS"
+ puts params
+ puts @p_customer_sheet.errors.messages
+ puts "ERRORSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSS"
@p_customer = @p_customer_sheet.price_line_block.p_customer
render action: "new"
diff --git a/app/controllers/admin/price_lines_controller.rb b/app/controllers/admin/price_lines_controller.rb
index be13d20..12df066 100644
--- a/app/controllers/admin/price_lines_controller.rb
+++ b/app/controllers/admin/price_lines_controller.rb
@@ -44,19 +44,12 @@ class Admin::PriceLinesController < ApplicationController
def update
- puts "PAAMSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSS"
- puts params
- puts "PAAMSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSS"
@price_line = PriceLine.find(params[:id])
if @price_line.update_attributes(params.require(:price_line).permit!)
-
+
else
- puts "ERRORSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSS"
- puts @price_line.errors.messages
- puts "ERRORSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSS"
render action: "edit"
-
end
end
@@ -73,4 +66,8 @@ class Admin::PriceLinesController < ApplicationController
# @p_article = PArticle.new#@price_line.p_articles.build
# @p_article_serial_nums = @p_article.p_article_serial_nums.build
end
+
+ def add_price_line_p_article
+ @price_line = PriceLine.find(params[:price_line_id])
+ end
end
diff --git a/app/helpers/application_helper.rb b/app/helpers/application_helper.rb
index 43aa011..d0e29b3 100644
--- a/app/helpers/application_helper.rb
+++ b/app/helpers/application_helper.rb
@@ -78,6 +78,16 @@ module ApplicationHelper
icon = sort_direction == "asc" ? "chevron-up" : "chevron-down"
icon = column == sort_column ? icon : ""
link_to raw("#{title} "+ic(icon).html_safe), request.query_parameters.merge({column: column, direction: direction})
- end
+ end
+
+ def id_color(price_line)
+ if price_line.p_articles.count == 0
+ return "background-color: red"
+ elsif price_line.p_articles.count < price_line.qte
+ return "background-color: orange"
+ else
+ return "background-color: #70ff29"
+ end
+ end
end
diff --git a/app/models/line_stock.rb b/app/models/line_stock.rb
index 9847dfb..21da23b 100644
--- a/app/models/line_stock.rb
+++ b/app/models/line_stock.rb
@@ -7,6 +7,9 @@
belongs_to :stock_movement_line
belongs_to :partition_lines
+ has_many :line_stock_p_articles
+ has_many :p_articles, through: :line_stock_p_articles
+
acts_as_sorting :fields => {
:id => {:name => "ID", :reorder => false},
diff --git a/app/models/line_stock_p_article.rb b/app/models/line_stock_p_article.rb
new file mode 100644
index 0000000..54c2762
--- /dev/null
+++ b/app/models/line_stock_p_article.rb
@@ -0,0 +1,4 @@
+class LineStockPArticle < ApplicationRecord
+ belongs_to :line_stock
+ belongs_to :p_article
+end
diff --git a/app/models/p_article.rb b/app/models/p_article.rb
index bd9cbdc..6f695d4 100644
--- a/app/models/p_article.rb
+++ b/app/models/p_article.rb
@@ -10,6 +10,9 @@ class PArticle < ApplicationRecord
has_many :price_line_p_articles
has_many :price_lines, through: :price_line_p_articles
accepts_nested_attributes_for :p_article_serial_nums
+
+ has_many :line_stock_p_articles
+ has_many :line_stocks, through: :line_stock_p_articles
diff --git a/app/models/p_customer_sheet.rb b/app/models/p_customer_sheet.rb
index 45d7409..a16ac3a 100644
--- a/app/models/p_customer_sheet.rb
+++ b/app/models/p_customer_sheet.rb
@@ -13,12 +13,13 @@ class PCustomerSheet < ApplicationRecord
belongs_to :particular_bill, :class_name => "Particular"#, :dependent => :destroy
accepts_nested_attributes_for :particular_bill
+
belongs_to :particular_send, :class_name => "Particular"#, :dependent => :destroy
accepts_nested_attributes_for :particular_send
has_one :price_line_block, :as => :price_lineable
- accepts_nested_attributes_for :price_line_block
+ accepts_nested_attributes_for :price_line_block
has_many :price_lines, :through => :price_line_block
diff --git a/app/models/particular.rb b/app/models/particular.rb
index 9458945..9fbe2bd 100644
--- a/app/models/particular.rb
+++ b/app/models/particular.rb
@@ -7,6 +7,7 @@ class Particular < ApplicationRecord
has_many :open_ranges, :through => :open_range_elements
belongs_to :owner, :polymorphic => true
+ #has_many :p_customer_sheets
#validates :civilite, :presence => true, :if => :force_validation
#validates :name, :presence => true, :if => :force_validation
#validates :firstname, :presence => true, :if => :force_validation
diff --git a/app/models/price_document.rb b/app/models/price_document.rb
index de113f8..ae3a1f6 100644
--- a/app/models/price_document.rb
+++ b/app/models/price_document.rb
@@ -764,4 +764,9 @@ class PriceDocument < ApplicationRecord
end
end
+ def stock_generable
+ return self.price_line_block.price_lines.joins(:p_articles).count < self.price_line_block.price_lines.sum(:qte) ? false : true
+ #exclure les produit non stockable et sans SN
+ end
+
end
diff --git a/app/models/price_line.rb b/app/models/price_line.rb
index 3eb2621..faa5f6d 100644
--- a/app/models/price_line.rb
+++ b/app/models/price_line.rb
@@ -13,6 +13,7 @@ class PriceLine < ApplicationRecord
has_many :price_line_p_articles
has_many :p_articles, through: :price_line_p_articles
accepts_nested_attributes_for :p_articles
+ accepts_nested_attributes_for :price_line_p_articles
default_scope { order('position ASC') }
diff --git a/app/models/price_line_block.rb b/app/models/price_line_block.rb
index 8e4ee2c..744e069 100644
--- a/app/models/price_line_block.rb
+++ b/app/models/price_line_block.rb
@@ -7,8 +7,8 @@ class PriceLineBlock < ApplicationRecord
validates :p_customer_id, :presence => true, :if => :p_customer_needed?
#validates :p_fournisseur_id, :presence => true, :if => :p_fournisseur_needed?
- validates :particular_bill_id, :presence => true, :if => :particular_bill_needed?
- validates :particular_send_id, :presence => true, :if => :particular_send_needed?
+ #validates :particular_bill_id, :presence => true, :if => :particular_bill_needed?
+ #validates :particular_send_id, :presence => true, :if => :particular_send_needed?
belongs_to :particular_bill, :class_name => "Particular"#, :dependent => :destroy
@@ -208,8 +208,18 @@ class PriceLineBlock < ApplicationRecord
def generate_stock
self.price_lines.each do |pl|
if pl.p_product_ref
- LineStock.create(:dluo => pl.dluo, :date => self.price_lineable.date, :p_product_ref => pl.p_product_ref, :description => "Entrée en stock par facture d'achat", :qte => pl.qte, :price_ht => pl.local_tot_amount_ht, :price_line => pl, :price_line_block => self, :stockable => self.price_lineable)
-
+ ls = LineStock.new(
+ :dluo => pl.dluo,
+ :date => self.price_lineable.date,
+ :p_product_ref => pl.p_product_ref,
+ :description => "Entrée en stock par facture d'achat",
+ :qte => pl.qte,
+ :price_ht => pl.local_tot_amount_ht,
+ :price_line => pl,
+ :price_line_block => self,
+ :stockable => self.price_lineable)
+ ls.p_articles = pl.p_articles
+ ls.save
end
@@ -441,6 +451,9 @@ class PriceLineBlock < ApplicationRecord
end
if self.particular_bill_needed? and (!self.p_customer or !self.particular_bill or !self.particular_bill.owner or self.particular_bill.owner != self.p_customer)
+ puts "PARTICULEARRRRRRRRRRRRRRRRRRRRRRRRRRRRRR"
+ puts self.particular_bill
+ puts "PARTICULEARRRRRRRRRRRRRRRRRRRRRRRRRRRRRR"
errors.add(:particular_bill_id, 'doit être une adresse du client')
end
diff --git a/app/views/admin/line_stocks/_line_stock.html.haml b/app/views/admin/line_stocks/_line_stock.html.haml
index 0dae2d5..fb479c4 100644
--- a/app/views/admin/line_stocks/_line_stock.html.haml
+++ b/app/views/admin/line_stocks/_line_stock.html.haml
@@ -25,6 +25,7 @@
= link_to i(:"trash-o"), [:admin, line_stock], method: :delete, data: { confirm: 'Voulez-vous vraiment supprimer cet enregistrement ? ' } , :remote => true
= link_to i(:pencil), edit_admin_line_stock_path(line_stock), :remote => true
= link_to i(:eye), admin_line_stock_path(line_stock), :remote => true
+ = link_to i(:"mobile-alt"), show_p_article_admin_line_stocks_path(line_stock_id: line_stock.id), :remote => true
diff --git a/app/views/admin/line_stocks/_show_p_article_form.html.haml b/app/views/admin/line_stocks/_show_p_article_form.html.haml
new file mode 100644
index 0000000..4d014a9
--- /dev/null
+++ b/app/views/admin/line_stocks/_show_p_article_form.html.haml
@@ -0,0 +1,13 @@
+.mx-2.my-2
+ %table.table-bordered
+ %tbody
+ -@line_stock.p_articles.each do |p_article|
+ %tr
+ %td="##{p_article.id}"
+ %td=p_article.p_product_ref.name
+ - p_article.p_article_serial_nums.each do |sn|
+ %tr
+ %td
+ %td
+ ="#{sn.p_serial_num_type.name} - #{sn.value}"
+.actions
\ No newline at end of file
diff --git a/app/views/admin/line_stocks/index.html.haml b/app/views/admin/line_stocks/index.html.haml
index 7360c8e..f7d8347 100644
--- a/app/views/admin/line_stocks/index.html.haml
+++ b/app/views/admin/line_stocks/index.html.haml
@@ -140,3 +140,4 @@
+
\ No newline at end of file
diff --git a/app/views/admin/line_stocks/show_p_article.js.erb b/app/views/admin/line_stocks/show_p_article.js.erb
new file mode 100644
index 0000000..9f660b6
--- /dev/null
+++ b/app/views/admin/line_stocks/show_p_article.js.erb
@@ -0,0 +1 @@
+show_pane_hover("<%= escape_javascript(render(:partial => "show_p_article_form"))%>",700,900);
\ No newline at end of file
diff --git a/app/views/admin/p_articles/_form.html.haml b/app/views/admin/p_articles/_form.html.haml
index 3a2568b..6b380c1 100644
--- a/app/views/admin/p_articles/_form.html.haml
+++ b/app/views/admin/p_articles/_form.html.haml
@@ -15,7 +15,7 @@
%p= link_to_add_fields "Ajouter un numéro de série", f, :p_article_serial_nums, {:class => "btn btn-primary"}
.actions=f.submit "sauvegarder", :class => "btn btn-primary"
-- else
+- elsif params[:controller] == "admin/price_lines"
= form.inputs do
-if params[:p_product_ref_id]
= form.input :p_product_ref_id, as: :select, collection: PProductRef.all.distinct.pluck(:cc_name, :id), :label => form.object.label_for(:p_product_ref), input_html: {disabled: true}
@@ -30,3 +30,4 @@
= form.semantic_fields_for :p_article_serial_nums do |form|
=render :partial => "admin/p_article_serial_nums/form", :locals => {:form => form}
%p= link_to_add_fields "Ajouter un numéro de série", form, :p_article_serial_nums, {:class => "btn btn-primary"}
+
diff --git a/app/views/admin/p_customer_sheets/_form.html.haml b/app/views/admin/p_customer_sheets/_form.html.haml
index f38a269..5c93951 100755
--- a/app/views/admin/p_customer_sheets/_form.html.haml
+++ b/app/views/admin/p_customer_sheets/_form.html.haml
@@ -1,7 +1,8 @@
=semantic_form_for [:admin, @p_customer_sheet], :html => {:class => "qi_price_form"}, :remote => false do |form|
+ =#debug form.object.errors.messages if current_admin.id == 1
=form.semantic_fields_for :price_line_block do |f|
=render :partial => "admin/price_line_blocks/form", :locals => {:f => f}
-
+
.content
.qi_row
.qi_pannel.qi_plain.padding.row
@@ -11,23 +12,6 @@
=#form.input :demande_type, :collection => ["Brouillon", "Demande de bon de commande","Demande de devis"], :as => :select, :include_blank => false, :label => "Type de demande :"
=#form.input :state, :collection => ["AV BPA", "PAS BPA","BPA", "Traitée"], :as => :select, :include_blank => false, :label => "Statut :"
=#form.input :past_id, :label => "N° système actuel"
- =yield :shipping_date
-
- .qi_row
- .qi_pannel.qi_plain.padding.row
- nested form for particular send et bill qui crée à chaque fois un particular
- ajouter accept nested attributed for particular dans pcustomer sheet
-
-
-
- .qi_row
- .qi_pannel.qi_plain.padding.row
- =yield :price_lines
- .qi_row
- .qi_pannel.qi_plain.padding.row
- =yield :discount
-
-
.large_actions
diff --git a/app/views/admin/particulars/_form.html.haml b/app/views/admin/particulars/_form.html.haml
index 55bd784..03eb796 100644
--- a/app/views/admin/particulars/_form.html.haml
+++ b/app/views/admin/particulars/_form.html.haml
@@ -1,4 +1,3 @@
-
=form.hidden_field :particular_type
=form.hidden_field :skip_validation, :class => "skip_validation"
=form.hidden_field :pro
@@ -31,15 +30,14 @@
=#form.input :email, :label => false, :placeholder => qit("don-particular-email","Email")
=#form.input :tel, :label => false, :placeholder => qit("don-particular-phone","Téléphone")
-Contacts de l'adresse :
+-if !params[:controller] == "p_customer_sheets"
+ Contacts de l'adresse :
+ .p_contacts_form
+ =form.semantic_fields_for :p_contacts do |form|
+ =render :partial => "admin/p_contacts/form", :locals => {:form => form}
-.p_contacts_form
- =form.semantic_fields_for :p_contacts do |form|
- =render :partial => "admin/p_contacts/form", :locals => {:form => form}
-
-
-%p= link_to_add_fields ic(:plus)+" Ajouter un contact à l'adresse", form, :p_contacts
+ %p= link_to_add_fields ic(:plus)+" Ajouter un contact à l'adresse", form, :p_contacts
=#form.input :open_ranges, :label => "Horaires d'ouvertures :", :collection => OpenRange.all, :as => :check_boxes
diff --git a/app/views/admin/price_documents/show.html.haml b/app/views/admin/price_documents/show.html.haml
index 59cf845..a66ebcd 100644
--- a/app/views/admin/price_documents/show.html.haml
+++ b/app/views/admin/price_documents/show.html.haml
@@ -209,15 +209,8 @@
-price_line_block.price_lines.each do |price_line|
%tbody
%tr
- -if price_line.p_articles.count == 0
- %td{style: "background-color: red;"}
- ="##{price_line.id}"
- - elsif price_line.p_articles.count < price_line.qte
- %td{style: "background-color: orange"}
- ="##{price_line.id}"
- - else
- %td{style: "background-color: green"}
- ="##{price_line.id}"
+ %td{style: id_color(price_line)}
+ ="##{price_line.id}"
%td
=price_line.ref
%td
@@ -250,7 +243,8 @@
-if current_admin.has_permission?("show-costs")
%p
-if @price_document.price_document_type_id == 6
- =link_to "Générer les stocks", generate_stocks_admin_price_document_path(@price_document), :class => "btn btn-primary" if !@price_document.stock_ok
+ =link_to "Générer les stocks", generate_stocks_admin_price_document_path(@price_document), :class => "btn btn-primary" if !@price_document.stock_ok and @price_document.stock_generable
+ =link_to "Générer les stocks", generate_stocks_admin_price_document_path(@price_document), :class => "btn btn-primary disabled" if !@price_document.stock_ok and !@price_document.stock_generable
-elsif @price_document.price_document_type_id == 4 or @price_document.price_document_type_id == 5
%p
Coût :
diff --git a/app/views/admin/price_line_blocks/_form.html.haml b/app/views/admin/price_line_blocks/_form.html.haml
index 8f441a3..9adc306 100644
--- a/app/views/admin/price_line_blocks/_form.html.haml
+++ b/app/views/admin/price_line_blocks/_form.html.haml
@@ -4,47 +4,42 @@
-if !@p_customer_sheet or (@p_customer_sheet and @p_customer_sheet.state != "commande")
- = f.hidden_field :p_customer_id, :class => "p_customer_id"
- =content_for :particular do
- .row
- .p_customer_sheet_customer.col-12.mb-4
+ = f.text_field :p_customer_id, :class => "p_customer_id"
+ .row
+ .p_customer_sheet_customer.col-12.mb-4
+ -if f.object.p_customer and f.object.p_customer.particular
+ =render :partial => "admin/p_customers/apercu", :locals => {:particular => f.object.p_customer.particular}
- -if f.object.p_customer and f.object.p_customer.particular
- =render :partial => "admin/p_customers/apercu", :locals => {:particular => f.object.p_customer.particular}
+ .qi_row
+ .qi_pannel.qi_plain.padding.row
.col-6
- .addresses.row
- .columns.span_6
- %h4 Adresse de facturation
+ Adresse de livraison :
+ =f.semantic_fields_for :particular_send do |form_particular_send|
+ =render :partial => "admin/particulars/form", :locals => {:form => form_particular_send}
+ =form_particular_send.text_field :owner_id
+ =form_particular_send.text_field :owner_type
- -if f.object.p_customer
- =f.inputs do
- = f.input :particular_bill_id, :collection => f.object.p_customer.particulars.all, :as => :select, :member_label => :address_line, :include_blank => false, :label => "Adresse de facturation"
- -else
- =f.inputs do
- = f.input :particular_bill_id, :collection => [], :as => :select, :include_blank => false, :label => "Adresse de facturation"
.col-6
- .addresses.row
- .columns.span_6
- %h4 Adresse de livraison
+ Adresse de facturation :
+ =f.semantic_fields_for :particular_bill do |form_particular_bill|
+ =render :partial => "admin/particulars/form", :locals => {:form => form_particular_bill}
+ =form_particular_bill.text_field :owner_id
+ =form_particular_bill.text_field :owner_type
+
+
+
- -if f.object.p_customer
- =f.inputs do
- = f.input :particular_send_id, :collection => f.object.p_customer.particulars.all, :as => :select, :member_label => :address_line, :include_blank => false, :label => "Adresse de livraison"
- -else
- =f.inputs do
- = f.input :particular_send_id, :collection => [], :as => :select, :include_blank => false, :label => "Adresse de facturation"
.clear
- =content_for :shipping_date do
- = f.input :wish_date, :label => "Date de livraison souhaitée :", :as => :date
- = f.input :ct_creation_date, :label => "Date de commande (si différente de la date de création) :", :as => :date
- = f.input :validation_date, :label => "Date de validation :", :as => :date
+ = f.input :wish_date, :label => "Date de livraison souhaitée :", :as => :date
+ = f.input :ct_creation_date, :label => "Date de commande (si différente de la date de création) :", :as => :date
+ = f.input :validation_date, :label => "Date de validation :", :as => :date
- = f.input :customer_ref, :label => "Référence commande client :"
+ = f.input :customer_ref, :label => "Référence commande clientttt :"
-if current_admin.has_permission?("customer-sheets-bl")
=# f.input :bl_comment, :label => "Commentaire à mettre sur le BL :", :input_html => {:style => "min-height:50px;height:50px;"}
@@ -55,33 +50,30 @@
%br
+ %div{:style=>"padding:0 30px;"}
+ .row.qi_field_wrapper
+ %table{:style => "width:100%;border-collapse:separate;"}
+ %thead
+ %tr
+ %th
+ %th Produit
+ %th{:style => "width:200px;"} Prix
+ %th
+ %th{:style => "width:100px;"} Qté
+ %th TVA
+ %th
+ %tbody.price_lines_form
+ =f.semantic_fields_for :price_lines do |f|
+ =render :partial => "admin/price_lines/form", :locals => {:form => f}
- =content_for :price_lines do
- %div{:style=>"padding:0 30px;"}
- .row.qi_field_wrapper
- %table{:style => "width:100%;border-collapse:separate;"}
- %thead
- %tr
- %th
- %th Produit
- %th{:style => "width:200px;"} Prix
- %th
- %th{:style => "width:100px;"} Qté
- %th TVA
- %th
- %tbody.price_lines_form
- =f.semantic_fields_for :price_lines do |f|
- =render :partial => "admin/price_lines/form", :locals => {:form => f}
-
- %p{:style=>"padding-top:10px;"}= link_to_add_fields ic("plus-circle") + " ligne", f, :price_lines, {:class => "btn btn-primary p-2", tabindex: 10, style: "position: sticky; top: 100px"}
+ %p{:style=>"padding-top:10px;"}= link_to_add_fields ic("plus-circle") + " ligne", f, :price_lines, {:class => "btn btn-primary p-2", tabindex: 10, style: "position: sticky; top: 100px"}
-if current_admin.has_permission?("payments")
- =content_for :discount do
- -if !@p_customer_sheet or (@p_customer_sheet and @p_customer_sheet.state != "commande")
- -if !@avoir
- = f.input :ct_tot_discount_percent, :label => "Réduction pied de page (%) :"#, :input_html => {:class => "input_price_line_block_ct_tot_discount_percent"}
- = f.input :ct_tot_fdp_ht, :label => "Frais de port personnalisés :"
+ -if !@p_customer_sheet or (@p_customer_sheet and @p_customer_sheet.state != "commande")
+ -if !@avoir
+ = f.input :ct_tot_discount_percent, :label => "Réduction pied de page (%) :"#, :input_html => {:class => "input_price_line_block_ct_tot_discount_percent"}
+ = f.input :ct_tot_fdp_ht, :label => "Frais de port personnalisés :"
-if current_admin.has_permission?("payments")
@@ -103,7 +95,3 @@
-if false
= f.input :ct_payment_month_end, :label => "Fin de mois ?"
-
-
-
-
diff --git a/app/views/admin/price_line_blocks/_price_line_block.html.haml b/app/views/admin/price_line_blocks/_price_line_block.html.haml
index 390aec3..961c8ae 100644
--- a/app/views/admin/price_line_blocks/_price_line_block.html.haml
+++ b/app/views/admin/price_line_blocks/_price_line_block.html.haml
@@ -96,6 +96,9 @@
%td.numeraire
=price_line.qte
+ %td
+ = price_line.p_articles.count
+ = link_to i(:"mobile-alt"), add_price_line_p_article_admin_price_lines_path(p_product_ref_id: price_line.p_product_ref.id, price_line_id: price_line.id), :remote => true
-if @price_document and @price_document.label != "Demande prix" and @price_document.label != "Réponse fournisseur"
%td.numeraire
diff --git a/app/views/admin/price_line_p_articles/_form.html.haml b/app/views/admin/price_line_p_articles/_form.html.haml
new file mode 100644
index 0000000..b7c9644
--- /dev/null
+++ b/app/views/admin/price_line_p_articles/_form.html.haml
@@ -0,0 +1 @@
+=form.input :p_article_id, as: :select, collection: PArticle.all, member_label: :id
\ No newline at end of file
diff --git a/app/views/admin/price_lines/_add_price_line_p_article_form.html.haml b/app/views/admin/price_lines/_add_price_line_p_article_form.html.haml
new file mode 100644
index 0000000..8575343
--- /dev/null
+++ b/app/views/admin/price_lines/_add_price_line_p_article_form.html.haml
@@ -0,0 +1,9 @@
+.mx-2.my-2
+ =semantic_form_for [:admin, @price_line], :remote => true do |f|
+ .content
+ =f.inputs do
+ .price_line_p_articles_form
+ = f.semantic_fields_for :price_line_p_articles do |form|
+ =render :partial => "admin/price_line_p_articles/form", :locals => {:form => form}
+ %p= link_to_add_fields "Ajouter un article", f, :price_line_p_articles, {:class => "btn btn-primary"}
+ .actions=f.submit "Sauvegarder", :class => "btn btn-primary"
\ No newline at end of file
diff --git a/app/views/admin/price_lines/add_price_line_p_article.js.erb b/app/views/admin/price_lines/add_price_line_p_article.js.erb
new file mode 100644
index 0000000..d64a968
--- /dev/null
+++ b/app/views/admin/price_lines/add_price_line_p_article.js.erb
@@ -0,0 +1 @@
+show_pane_hover("<%= escape_javascript(render(:partial => "add_price_line_p_article_form"))%>",700,900);
\ No newline at end of file
diff --git a/config/routes.rb b/config/routes.rb
index 6c3c724..e0a0032 100644
--- a/config/routes.rb
+++ b/config/routes.rb
@@ -447,6 +447,7 @@ Rails.application.routes.draw do
collection do
get "stock_resume"
get "empty_stock"
+ get :show_p_article
end
end
end
@@ -698,6 +699,7 @@ Rails.application.routes.draw do
end
collection do
get :add_p_article
+ get :add_price_line_p_article
end
end
diff --git a/db/migrate/20211103085623_create_line_stock_p_articles.rb b/db/migrate/20211103085623_create_line_stock_p_articles.rb
new file mode 100644
index 0000000..0ec4e0e
--- /dev/null
+++ b/db/migrate/20211103085623_create_line_stock_p_articles.rb
@@ -0,0 +1,10 @@
+class CreateLineStockPArticles < ActiveRecord::Migration[6.0]
+ def change
+ create_table :line_stock_p_articles do |t|
+ t.belongs_to :p_article
+ t.belongs_to :line_stock
+
+ t.timestamps
+ end
+ end
+end
diff --git a/db/schema.rb b/db/schema.rb
index 3fe7b90..c6cfc94 100644
--- a/db/schema.rb
+++ b/db/schema.rb
@@ -10,7 +10,7 @@
#
# It's strongly recommended that you check this file into your version control system.
-ActiveRecord::Schema.define(version: 2021_11_02_105934) do
+ActiveRecord::Schema.define(version: 2021_11_03_085623) do
# These are extensions that must be enabled in order to support this database
enable_extension "plpgsql"
@@ -549,6 +549,15 @@ ActiveRecord::Schema.define(version: 2021_11_02_105934) do
t.datetime "updated_at", precision: 6, null: false
end
+ create_table "line_stock_p_articles", force: :cascade do |t|
+ t.bigint "p_article_id"
+ t.bigint "line_stock_id"
+ t.datetime "created_at", precision: 6, null: false
+ t.datetime "updated_at", precision: 6, null: false
+ t.index ["line_stock_id"], name: "index_line_stock_p_articles_on_line_stock_id"
+ t.index ["p_article_id"], name: "index_line_stock_p_articles_on_p_article_id"
+ end
+
create_table "line_stock_usages", force: :cascade do |t|
t.bigint "line_stock_id"
t.decimal "qte", precision: 14, scale: 2
diff --git a/test/fixtures/line_stock_p_articles.yml b/test/fixtures/line_stock_p_articles.yml
new file mode 100644
index 0000000..5181636
--- /dev/null
+++ b/test/fixtures/line_stock_p_articles.yml
@@ -0,0 +1,11 @@
+# Read about fixtures at https://api.rubyonrails.org/classes/ActiveRecord/FixtureSet.html
+
+# This model initially had no columns defined. If you add columns to the
+# model remove the '{}' from the fixture names and add the columns immediately
+# below each fixture, per the syntax in the comments below
+#
+one: {}
+# column: value
+#
+two: {}
+# column: value
diff --git a/test/models/line_stock_p_article_test.rb b/test/models/line_stock_p_article_test.rb
new file mode 100644
index 0000000..c5688f1
--- /dev/null
+++ b/test/models/line_stock_p_article_test.rb
@@ -0,0 +1,7 @@
+require 'test_helper'
+
+class LineStockPArticleTest < ActiveSupport::TestCase
+ # test "the truth" do
+ # assert true
+ # end
+end
From 721c98e20d8b714273c81a9d4f02b25417c829e5 Mon Sep 17 00:00:00 2001
From: Philippe
Date: Fri, 5 Nov 2021 11:24:58 +0100
Subject: [PATCH 06/12] add p_fournisseur_id in price_document achat form,
autocomplete for p_article_ids in price_line_block form
---
.../(__TEMPLATE__)c | Bin 1374 -> 5965 bytes
app/models/p_article.rb | 4 +
app/models/p_customer_sheet.rb | 3 +-
app/models/price_document.rb | 1 -
app/models/price_line.rb | 3 -
.../admin/p_customer_sheets/_form.html.haml | 18 ++--
.../admin/p_customer_sheets/show.html.haml | 37 ++++----
.../admin/p_fournisseurs/_form.html.haml | 4 +-
app/views/admin/p_products/_form.html.haml | 2 +-
.../admin/price_documents/_form.html.haml | 5 +-
.../admin/price_documents/show.html.haml | 13 ++-
.../admin/price_line_blocks/_form.html.haml | 85 ++++++++++--------
.../_form_facture_achat.html.haml | 1 -
.../_price_line_block.html.haml | 37 ++++----
.../price_line_p_articles/_form.html.haml | 6 +-
.../_add_price_line_p_article_form.html.haml | 15 ++--
app/views/admin/price_lines/_form.html.haml | 1 -
17 files changed, 124 insertions(+), 111 deletions(-)
diff --git a/.sass-cache/f6b9a0b1905a68d5dbb2139e95d49cba92f6fa93/(__TEMPLATE__)c b/.sass-cache/f6b9a0b1905a68d5dbb2139e95d49cba92f6fa93/(__TEMPLATE__)c
index e1c3ae14c64ffb6b86d264611307231a215c18c3..f14f6942a4eff9a4b9af0c9026e5b8e2e708b671 100644
GIT binary patch
literal 5965
zcmbVQUvt~W5f?Qbii9jtbo9@ZEVHzu*orOEk{sE0Gwmg=JYgnrG#1krJz$RHi9!S7
zPym#pdi>UWh4f?eOSNC2eQb9Re~w2&ij*hfh}*s2?(P0|7yG-1y9d_c!NDQ#?RC4a
z&iLMo?w)8J?Dt;r=l$Nx7hJsT9f~iyqPyR+epiy@-U$ywLOOvEguIh7dMo?l4q0Tq
zbI0um!aFTbZW_4)H&uwm0(d?xwi{~?yRv_2hY^pQFmnDn5@C@Pk2>To^LY@8zKuIW
zNgDBSC&CrINCt$wmct=G5g_69M2Rf0p%`{W5S|t#xj(r%-8V;QNPD@13FViged}
zylZW8SG!*V=pG-6c4KuKH!XMIwd;7oDS{u)99Q7p7GMiU-M;{C^(aR{4=pO4h^Pnx
z=R7?BIP(T94%I6=;NCz;vYs5T{sb4}zhzQk;Hx0AeF-Wy%q_<Nw?l5_F
z7K#WS7ntz+N`%(bOS<8#!_f$_1yI3y8AKvzp&-2*|HO}EgN2FDZ37=&FVlNc>nqaD
zvDG@g-)?;J*tR=I-yMJZW#`DYpA^ACbW4(YjJlm13PJP+aDwKJ%Sg~6E^pK)C+zI1b6Mr)MRR}EnL|f^(xS`RQFKjS@6{!GzeTt3dXzB!B##da$vL>+Qg$D>x=Zh~8r@|8sY@TY!Y6Q!}IKdyCapKFPl4E-urP7$dT74kGjsl?nze$M#k2E9|sWk
zB3j>Rs`~)1UHXE|hnNKs_-+Qwg+P=(Mrin929TE~3@!msD}#+IlER*#lH)-7NF_^j
z2`^(sV|=FIsVmvWR8NBKq!&1Tl+x9=4g@=QOLTi`!=KS|LQbLpqM%H-k)pnM{o<>`
zug0uY>YuPz^fOX%`e2`P=7@kaSYP;o=OhIEWMQ_gNoolT>(b;xX;eu+AHx{ie#?w+
zWEqcV!HqBccAROo$Z#HqV$_%OWSOY|1CRA=m9=q*Z9XNlh7>GW0KecT)8ePxB^Lo#7dHWdWS-qw;QL;9hLYup(v|9#%VEMkot6z
zr&LBiqmRw3TTBBqNrOeers=i(Oq=(
z(!`ldaLQulS6pqSXDW(s(v}H2Pk{z)DtI1O6IS@Ual%4&!k$rX5-hCnbGkvBUG2)C
zFM?-*GdPb_9w03n)~_D;Kh;C&I{ow()IPyK
z^M5f;Sk6u`%}=nf!auSN84WI^xLKI#GDCTs%WAo7rM&U0{l#@WwS1E-)wzabyOCw7
z60SPS5QOT{%+h7pt0i#-l2>Kv{w=aJX(XnzZzXkUl6@<1roKsB?WYKI7*1p#d6aPW
zL|YI>No#Ll=OhJ6`QE2sXD6@-dY9!EN7vJt9z-p=v`Jzflk<)0DU{c5zC_6XQkHe3#{~H
zg?XbPG*d8>*(1*ZZ_Plb0X>m~?%4Qukx3u{_|t7SP#gfhftbnzxM2X)#0CJt*FTEO
z_dqHz|7^wX{2_8&Lf*$X(}eqW>ND=b&|heb5tN9|!Fwl&>N8;dh>ezRO`0gALH^
z5A1k(1(J$^w38A6pX>PYmMm7xYc
z(Uk#Lx`9uJ(5ySUdV(`rg==TAv{%?jothMg4LG`%c^6ktvzy2bhCBs27)%9eFwAZh
zj3czIX0wohVY3ekDTwKexTaOSkq0&>Jg^BiuV(OY^*B8|pAqsDXb+eQG7q%02XMz#
z`H+BNv(GaR=!B@H$k}W~t22XVKb;k!7QiPXWOMi+H~VgO`di`$t6tY1YH(GrH=Fuv
z!Og}65Yi&o3=E+Dqh)=xa=W;jOr!{~*}TOdV;FNivRLcnph4lp@eZA6!c8V33I^p{
zbbGWhhB~%Kj}?-qb!Y^hj14~5;2A3b3ez+fBA}aIRAO|3C};XZv#q3w%DzY>jDiia
NrnY#MHog0u{{w}+6Mp~z
delta 389
zcmX@BcaKZYSkGL~gv-Ft$jCf3HQB=4I4#v6HPtxPBq=#1&D_W+H6It+*WW5_3~Mm3W{MlU*3sGxAOT!WauA
zgP5*QUc@3R#*>m+T#%Dk$!5(NV#V!HmY7qT8qGFYo>zSGdlp?8&b<7*RInVcLw-R?
zW`16AH3QJ(lFEYA$(F48%IwzS`PLGg){^!FD8Pv&LQl7O1)pl>bfAZ0D*AZ;yVV6Ew(F}aIP8t9#DHaRm5D?W#k
v)Lfu%N`SsrfrUpkmx2P+lU5+#SaWgJa&d8iJOy+U+vJbjiacy^Qw>7^kL+bZ
diff --git a/app/models/p_article.rb b/app/models/p_article.rb
index 6f695d4..4d69fd9 100644
--- a/app/models/p_article.rb
+++ b/app/models/p_article.rb
@@ -56,4 +56,8 @@ class PArticle < ApplicationRecord
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.value}.join(' / ')}"
+ end
end
diff --git a/app/models/p_customer_sheet.rb b/app/models/p_customer_sheet.rb
index a16ac3a..c477f8c 100644
--- a/app/models/p_customer_sheet.rb
+++ b/app/models/p_customer_sheet.rb
@@ -18,7 +18,6 @@ class PCustomerSheet < ApplicationRecord
accepts_nested_attributes_for :particular_send
has_one :price_line_block, :as => :price_lineable
-
accepts_nested_attributes_for :price_line_block
has_many :price_lines, :through => :price_line_block
@@ -32,7 +31,7 @@ class PCustomerSheet < ApplicationRecord
#:cc_com_counter => {:name => "ID", :reorder => true},
- :past_id => {:name => "N° ancien système", :reorder => true},
+ :id => {:name => "ID", :reorder => true},
:d_number => {:name => "N° BC", :reorder => false},
:created_at => {:name => "Date", :reorder => true, :sort_name => "p_customer_sheets.created_at"},
:admin_id => {:name => "Déposée par", :reorder => true},
diff --git a/app/models/price_document.rb b/app/models/price_document.rb
index ae3a1f6..9629fe2 100644
--- a/app/models/price_document.rb
+++ b/app/models/price_document.rb
@@ -13,7 +13,6 @@ class PriceDocument < ApplicationRecord
belongs_to :p_fournisseur
has_one :price_line_block, :as => :price_lineable
-
accepts_nested_attributes_for :price_line_block
belongs_to :ref_element, :polymorphic => true
diff --git a/app/models/price_line.rb b/app/models/price_line.rb
index faa5f6d..534aaf5 100644
--- a/app/models/price_line.rb
+++ b/app/models/price_line.rb
@@ -32,9 +32,7 @@ class PriceLine < ApplicationRecord
:ref => {:name => "Ref", :reorder => true},
:title => {:name => "Désignation", :reorder => true},
:qte => {:name => "Qté", :reorder => true},
-
:qte_available => {:name => "Qté dispo.", :reorder => true},
-
:ct_u_price_ht => {:name => "Prix de vente", :reorder => true},
:ref_fournisseur => {:name => "Réf. fournisseur", :reorder => true},
:p_product_power_id => {:name => "Chargeur", :reorder => true},
@@ -47,7 +45,6 @@ class PriceLine < ApplicationRecord
:lang_start => {:name => "Démarrage écran langue ?", :reorder => true},
:actions => {:name => "Actions"}
-
}
diff --git a/app/views/admin/p_customer_sheets/_form.html.haml b/app/views/admin/p_customer_sheets/_form.html.haml
index 5c93951..9f1576e 100755
--- a/app/views/admin/p_customer_sheets/_form.html.haml
+++ b/app/views/admin/p_customer_sheets/_form.html.haml
@@ -3,15 +3,15 @@
=form.semantic_fields_for :price_line_block do |f|
=render :partial => "admin/price_line_blocks/form", :locals => {:f => f}
- .content
- .qi_row
- .qi_pannel.qi_plain.padding.row
- .col-8
- =@p_customer_sheet.p_customer.particular.organisation
- -if @p_customer_sheet and @p_customer_sheet.state != "commande"
- =#form.input :demande_type, :collection => ["Brouillon", "Demande de bon de commande","Demande de devis"], :as => :select, :include_blank => false, :label => "Type de demande :"
- =#form.input :state, :collection => ["AV BPA", "PAS BPA","BPA", "Traitée"], :as => :select, :include_blank => false, :label => "Statut :"
- =#form.input :past_id, :label => "N° système actuel"
+ -# .content
+ -# .qi_row
+ -# .qi_pannel.qi_plain.padding.row
+ -# .col-8
+ -# =@p_customer_sheet.p_customer.particular.organisation
+ -# -if @p_customer_sheet and @p_customer_sheet.state != "commande"
+ -# =#form.input :demande_type, :collection => ["Brouillon", "Demande de bon de commande","Demande de devis"], :as => :select, :include_blank => false, :label => "Type de demande :"
+ -# =#form.input :state, :collection => ["AV BPA", "PAS BPA","BPA", "Traitée"], :as => :select, :include_blank => false, :label => "Statut :"
+ -# =#form.input :past_id, :label => "N° système actuel"
.large_actions
diff --git a/app/views/admin/p_customer_sheets/show.html.haml b/app/views/admin/p_customer_sheets/show.html.haml
index 1b37292..8bab240 100644
--- a/app/views/admin/p_customer_sheets/show.html.haml
+++ b/app/views/admin/p_customer_sheets/show.html.haml
@@ -88,25 +88,24 @@
.clear
- %h3 Documents liés à l'offre
- #bills
- -params[:search][:per_page] = params[:search][:per_page] || 50
- -per_page = params[:search][:per_page]
- -page = (params[:page] and params[:page] != "") ? params[:page] : 1
-
- -@price_documents = @p_customer_sheet.price_documents.order("date DESC, created_at DESC")
- -if params[:price_document_ids]
- -@price_documents = @price_documents.where(:id => params[:price_document_ids])
-
- -@price_documents = sort_by_sorting(@price_documents, "created_at DESC")
- -@price_documents = @price_documents.page(page).per(per_page)
- %br
-
-
-
- .clear
- =render :partial => "qi/qi_ordered_table", :locals => {:qi_ordered_table_collection => @price_documents}
-
+ -params[:search][:per_page] = params[:search][:per_page] || 50
+ -per_page = params[:search][:per_page]
+ -page = (params[:page] and params[:page] != "") ? params[:page] : 1
+ -@price_documents = @p_customer_sheet.price_documents.order("date DESC, created_at DESC")
+ -if params[:price_document_ids]
+ -@price_documents = @price_documents.where(:id => params[:price_document_ids])
+ -@price_documents = sort_by_sorting(@price_documents, "created_at DESC")
+ -@price_documents = @price_documents.page(page).per(per_page)
+
+ - if @price_documents.exists?
+ %h3 Documents liés à l'offre
+ #bills
+ %br
+ .clear
+ =render :partial => "qi/qi_ordered_table", :locals => {:qi_ordered_table_collection => @price_documents}
+
+:javascript
+ $('.p_articles_lines').hide();
\ No newline at end of file
diff --git a/app/views/admin/p_fournisseurs/_form.html.haml b/app/views/admin/p_fournisseurs/_form.html.haml
index 082c082..33ff79e 100755
--- a/app/views/admin/p_fournisseurs/_form.html.haml
+++ b/app/views/admin/p_fournisseurs/_form.html.haml
@@ -19,6 +19,6 @@
-
- .actions=f.submit "sauvegarder", :class => "btn btn-primary"
+ =link_to "Annuler", "#", class:"btn btn-default", onclick:"close_pane_hover();return false;"
+ =f.submit "sauvegarder", :class => "btn btn-primary"
\ No newline at end of file
diff --git a/app/views/admin/p_products/_form.html.haml b/app/views/admin/p_products/_form.html.haml
index d8f02c4..6a02656 100755
--- a/app/views/admin/p_products/_form.html.haml
+++ b/app/views/admin/p_products/_form.html.haml
@@ -11,7 +11,7 @@
= f.input :enabled, :label => "Produit actif ?"
.col-sm-2
%br
- = f.input :stockable, :label => "Produit stockable ?", :input_html => {:onclick => "$('#with_serial').toggle('slow');"}
+ = f.input :stockable, :label => "Produit stockable ?"#, :input_html => {:onclick => "$('#with_serial').toggle('slow');"}
.col-sm-2
%br
#with_serial
diff --git a/app/views/admin/price_documents/_form.html.haml b/app/views/admin/price_documents/_form.html.haml
index 0f516cc..9b21234 100644
--- a/app/views/admin/price_documents/_form.html.haml
+++ b/app/views/admin/price_documents/_form.html.haml
@@ -1,4 +1,3 @@
-PRICE_DOCUMENTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTT
=semantic_form_for [:admin, @price_document], :html => {:class => "qi_price_form"}, :remote => false do |f|
-@p_customer = @price_document.p_customer
=diag do
@@ -11,7 +10,7 @@ PRICE_DOCUMENTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTT
=f.inputs do
=f.hidden_field :price_document_type_id
- = f.hidden_field :p_customer_id
+ =f.hidden_field :p_customer_id
=f.hidden_field :ref_element_type
=f.hidden_field :ref_element_id
=f.hidden_field :doc_ref_id
@@ -50,6 +49,8 @@ PRICE_DOCUMENTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTTT
= f.input :supplier_document_date, :label => "Date du document fournisseur :", :as => :date
.col-6
= f.input :tva_type_id, :label => "Type de TVA :", as: :select, collection: TvaType.pluck(:name, :id)
+ .col-6
+ = f.input :p_fournisseur, :label => "Fournisseur :", as: :select, collection: PFournisseur.pluck(:name, :id)
.price_line_block_form
=f.semantic_fields_for :price_line_block do |f|
=render :partial => "admin/price_line_blocks/form_#{f.object.block_type_slug}", :locals => {:f => f}
diff --git a/app/views/admin/price_documents/show.html.haml b/app/views/admin/price_documents/show.html.haml
index a66ebcd..9b78bee 100644
--- a/app/views/admin/price_documents/show.html.haml
+++ b/app/views/admin/price_documents/show.html.haml
@@ -18,7 +18,7 @@
.qi_row
- =debug @price_document.price_line_block.price_lines.count
+ =#debug @price_document.price_line_block.price_lines.count
%table.table.table-striped
-if @price_document.label == "Réponse fournisseur"
@@ -201,6 +201,7 @@
%th Marque
%th Désignation
%th Qté
+ %th Qté saisie
%th P.U. HT
%th TVA
%th Montant HT
@@ -209,7 +210,7 @@
-price_line_block.price_lines.each do |price_line|
%tbody
%tr
- %td{style: id_color(price_line)}
+ %td{style: id_color(price_line), id: "price_line_#{price_line.id}", onclick: "$('.p_articles_#{price_line.id}').toggle('800','swing');"}
="##{price_line.id}"
%td
=price_line.ref
@@ -219,6 +220,8 @@
=link_to price_line.p_product_ref.cc_name, edit_admin_p_product_path(price_line.p_product_ref.p_product) if price_line.p_product_ref and price_line.p_product_ref.p_product
%td.numeraire{class: "price_line_qte_#{@price_document.id}"}
=price_line.qte
+ %td.numeraire{class: "price_line_qte_#{@price_document.id}"}
+ =price_line.p_articles.count
%td.numeraire{class: "price_line_price_u_ht_#{@price_document.id}"}
=number_to_currency price_line.price_u_ht
%td.numeraire
@@ -229,9 +232,9 @@
= link_to i(:"trash-o"), admin_price_line_path(price_line), method: :delete, data: { confirm: 'Voulez-vous vraiment supprimer cet enregistrement ? ' } , :remote => true
= link_to i(:pencil), edit_admin_price_line_path(price_line), :remote => true
= link_to i(:eye), admin_price_line_path(price_line), :remote => true
- = link_to i(:"mobile-alt"), add_p_article_admin_price_lines_path(p_product_ref_id: price_line.p_product_ref.id, price_line_id: price_line.id), :remote => true
+ = link_to i(:"mobile-alt"), add_p_article_admin_price_lines_path(p_product_ref_id: price_line.p_product_ref.id, price_line_id: price_line.id), :remote => true if price_line.p_product_ref.p_product.stockable and price_line.p_product_ref.p_product.with_serial_number
-price_line.p_articles.each do |p_article|
- %tr
+ %tr{class: "p_articles_lines p_articles_#{price_line.id}"}
%td
%td="##{p_article.id}"
%td=p_article.p_product_ref.name
@@ -427,6 +430,8 @@
:javascript
+ $('.p_articles_lines').hide();
+
const copyPriceLines = (event) => {
event.preventDefault()
let priceDocumentId = event.target.dataset.document
diff --git a/app/views/admin/price_line_blocks/_form.html.haml b/app/views/admin/price_line_blocks/_form.html.haml
index 9adc306..861d505 100644
--- a/app/views/admin/price_line_blocks/_form.html.haml
+++ b/app/views/admin/price_line_blocks/_form.html.haml
@@ -4,42 +4,43 @@
-if !@p_customer_sheet or (@p_customer_sheet and @p_customer_sheet.state != "commande")
- = f.text_field :p_customer_id, :class => "p_customer_id"
- .row
- .p_customer_sheet_customer.col-12.mb-4
- -if f.object.p_customer and f.object.p_customer.particular
- =render :partial => "admin/p_customers/apercu", :locals => {:particular => f.object.p_customer.particular}
+ .qi_row
+ .qi_pannel.qi_plain.padding.row
+ .col-6
+ = f.input :customer_ref, :label => "Référence commande client :"
+ .col-6
+ = f.input :wish_date, :label => "Date de livraison souhaitée :", :as => :date
+ = f.input :ct_creation_date, :label => "Date de commande (si différente de la date de création) :", :as => :date
+ = f.input :validation_date, :label => "Date de validation :", :as => :date
+ = f.hidden_field :p_customer_id, :class => "p_customer_id"
.qi_row
+ .qi_pannel.qi_plain.padding.row
+ -if f.object.p_customer and f.object.p_customer.particular
+ =render :partial => "admin/p_customers/apercu", :locals => {:particular => f.object.p_customer.particular}
.qi_pannel.qi_plain.padding.row
.col-6
Adresse de livraison :
=f.semantic_fields_for :particular_send do |form_particular_send|
=render :partial => "admin/particulars/form", :locals => {:form => form_particular_send}
- =form_particular_send.text_field :owner_id
- =form_particular_send.text_field :owner_type
-
+ =form_particular_send.hidden_field :owner_id
+ =form_particular_send.hidden_field :owner_type
.col-6
Adresse de facturation :
=f.semantic_fields_for :particular_bill do |form_particular_bill|
=render :partial => "admin/particulars/form", :locals => {:form => form_particular_bill}
- =form_particular_bill.text_field :owner_id
- =form_particular_bill.text_field :owner_type
+ =form_particular_bill.hidden_field :owner_id
+ =form_particular_bill.hidden_field :owner_type
- .clear
-
- = f.input :wish_date, :label => "Date de livraison souhaitée :", :as => :date
- = f.input :ct_creation_date, :label => "Date de commande (si différente de la date de création) :", :as => :date
- = f.input :validation_date, :label => "Date de validation :", :as => :date
+
-
- = f.input :customer_ref, :label => "Référence commande clientttt :"
+
-if current_admin.has_permission?("customer-sheets-bl")
=# f.input :bl_comment, :label => "Commentaire à mettre sur le BL :", :input_html => {:style => "min-height:50px;height:50px;"}
@@ -69,29 +70,41 @@
%p{:style=>"padding-top:10px;"}= link_to_add_fields ic("plus-circle") + " ligne", f, :price_lines, {:class => "btn btn-primary p-2", tabindex: 10, style: "position: sticky; top: 100px"}
+
+
+
+
+
+
+
+
+
+
-if current_admin.has_permission?("payments")
-if !@p_customer_sheet or (@p_customer_sheet and @p_customer_sheet.state != "commande")
- -if !@avoir
- = f.input :ct_tot_discount_percent, :label => "Réduction pied de page (%) :"#, :input_html => {:class => "input_price_line_block_ct_tot_discount_percent"}
- = f.input :ct_tot_fdp_ht, :label => "Frais de port personnalisés :"
+ .qi_row
+ .qi_pannel.qi_plain.padding.row
+ -if !@avoir
+ = f.input :ct_tot_discount_percent, :label => "Réduction pied de page (%) :"#, :input_html => {:class => "input_price_line_block_ct_tot_discount_percent"}
+ = f.input :ct_tot_fdp_ht, :label => "Frais de port personnalisés :"
-if current_admin.has_permission?("payments")
-if !@p_customer_sheet or (@p_customer_sheet and @p_customer_sheet.state != "commande")
- if f.object.id
- .qi_pannel.qi_plain.padding{:style => "margin:20px 0;"}
- %h4 Paiements
-
- = f.input :p_payment_type_id, :label => "Type de paiement :", :include_blank => false, :collection => PPaymentType.order(:name).all, :as => :select, :input_html => {:id => "payment_type_id_select"}
-
-
- = f.input :ct_payment_comptant, :label => "Paiement comptant nécessaire ?"
-
- -if false
- = f.input :ct_acompte, :label => "Acompte nécessaire ?"
- = f.input :ct_acompte_percent, :label => "Pourcentage d'acompte :"
-
- = f.input :ct_payment_delais, :label => "Délais jour de paiement :"
-
- -if false
- = f.input :ct_payment_month_end, :label => "Fin de mois ?"
+ .qi_row
+ .qi_pannel.qi_plain.padding.row
+ .col-6
+ %h4 Paiements
+ = f.input :p_payment_type_id, :label => "Type de paiement :", :include_blank => false, :collection => PPaymentType.order(:name).all, :as => :select, :input_html => {:id => "payment_type_id_select"}
+ = f.input :ct_payment_comptant, :label => "Paiement comptant nécessaire ?"
+ -if false
+ .col-6
+ = f.input :ct_acompte, :label => "Acompte nécessaire ?"
+ = f.input :ct_acompte_percent, :label => "Pourcentage d'acompte :"
+ .col-6
+ %h4{style: "color: transparent;"} Paiements
+ = f.input :ct_payment_delais, :label => "Délais jour de paiement :"
+ -if false
+ .col-6
+ = f.input :ct_payment_month_end, :label => "Fin de mois ?"
diff --git a/app/views/admin/price_line_blocks/_form_facture_achat.html.haml b/app/views/admin/price_line_blocks/_form_facture_achat.html.haml
index db81fc0..001336e 100644
--- a/app/views/admin/price_line_blocks/_form_facture_achat.html.haml
+++ b/app/views/admin/price_line_blocks/_form_facture_achat.html.haml
@@ -1,4 +1,3 @@
-PRICE LINE BLOCKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKK
=f.inputs do
-if !@p_customer_sheet or (@p_customer_sheet and @p_customer_sheet.state != "commande")
diff --git a/app/views/admin/price_line_blocks/_price_line_block.html.haml b/app/views/admin/price_line_blocks/_price_line_block.html.haml
index 961c8ae..54da1fc 100644
--- a/app/views/admin/price_line_blocks/_price_line_block.html.haml
+++ b/app/views/admin/price_line_blocks/_price_line_block.html.haml
@@ -1,7 +1,3 @@
-
-
-
-
-if price_line_block.p_customer
%h3 Client
-if price_line_block.p_customer and price_line_block.p_customer.particular
@@ -66,60 +62,57 @@
%table.table
%thead
%tr
+ %th IDddd
%th Référence
-
%th Désignation
-
-
-
%th Qté
+ %th Qté saisie
+ %th Actions
-if @price_document and @price_document.label != "Demande prix" and @price_document.label != "Réponse fournisseur"
%th P.U. HT
%th TVA
%th
Montant HT
-
-if price_line_block.purchase?
%th Montant équivalent
%tbody
-price_line_block.price_lines.each do |price_line|
%tr
+ %td{style: id_color(price_line), id: "price_line_#{price_line.id}", onclick: "$('.p_articles_#{price_line.id}').toggle('800','swing');"}
+ ="##{price_line.id}"
%td
=price_line.ref
-
%td
-if price_line.p_product_ref
=price_line.p_product_ref.member_label
-else
=price_line.title
-
-
%td.numeraire
=price_line.qte
- %td
+ %td.numeraire
= price_line.p_articles.count
= link_to i(:"mobile-alt"), add_price_line_p_article_admin_price_lines_path(p_product_ref_id: price_line.p_product_ref.id, price_line_id: price_line.id), :remote => true
-
-if @price_document and @price_document.label != "Demande prix" and @price_document.label != "Réponse fournisseur"
%td.numeraire
=number_to_currency price_line.price_u_ht, :unit => price_line_block.devise_symbol
-
-
%td.numeraire
=price_line.tva_account_value.to_s+"%"
-
-
-
-
%td.numeraire
=number_to_currency price_line.tot_amount_ht, :unit => price_line_block.devise_symbol
-
-
-if price_line_block.purchase?
%td.numeraire
=number_to_currency price_line.local_tot_amount_ht, :unit => price_line_block.devise_symbol
+ -price_line.p_articles.each do |p_article|
+ %tr{class: "p_articles_lines p_articles_#{price_line.id}"}
+ %td
+ %td="##{p_article.id}"
+ %td=p_article.p_product_ref.name
+ %td
+ - p_article.p_article_serial_nums.each do |sn|
+ ="#{sn.p_serial_num_type.name} - #{sn.value} /"
+
-if @price_document and @price_document.label != "Demande prix" and @price_document.label != "Réponse fournisseur"
%table.table{:style => "width:auto;float:right;"}
%tr
diff --git a/app/views/admin/price_line_p_articles/_form.html.haml b/app/views/admin/price_line_p_articles/_form.html.haml
index b7c9644..ce107a0 100644
--- a/app/views/admin/price_line_p_articles/_form.html.haml
+++ b/app/views/admin/price_line_p_articles/_form.html.haml
@@ -1 +1,5 @@
-=form.input :p_article_id, as: :select, collection: PArticle.all, member_label: :id
\ No newline at end of file
+=form.input :p_article_id, as: :select, collection: PArticle.all.map{|p_article| [p_article.serialized_name, p_article.id]}, label: "Article(s) associé(s)", input_html: {class:"p_article_select"}
+
+:javascript
+ $('.p_article_select').select2();
+ $('.p_article_select').removeClass('form-control');
\ No newline at end of file
diff --git a/app/views/admin/price_lines/_add_price_line_p_article_form.html.haml b/app/views/admin/price_lines/_add_price_line_p_article_form.html.haml
index 8575343..7aa687c 100644
--- a/app/views/admin/price_lines/_add_price_line_p_article_form.html.haml
+++ b/app/views/admin/price_lines/_add_price_line_p_article_form.html.haml
@@ -1,9 +1,10 @@
.mx-2.my-2
=semantic_form_for [:admin, @price_line], :remote => true do |f|
- .content
- =f.inputs do
- .price_line_p_articles_form
- = f.semantic_fields_for :price_line_p_articles do |form|
- =render :partial => "admin/price_line_p_articles/form", :locals => {:form => form}
- %p= link_to_add_fields "Ajouter un article", f, :price_line_p_articles, {:class => "btn btn-primary"}
- .actions=f.submit "Sauvegarder", :class => "btn btn-primary"
\ No newline at end of file
+ =f.inputs do
+ .price_line_p_articles_form
+ = f.semantic_fields_for :price_line_p_articles do |form|
+ =render :partial => "admin/price_line_p_articles/form", :locals => {:form => form}
+ %p= link_to_add_fields "Ajouter un article", f, :price_line_p_articles, {:class => "btn btn-primary"} if @price_line.p_articles.count < @price_line.qte
+ =link_to "Annuler", "#", class:"btn btn-default", onclick:"close_pane_hover();return false;"
+ =f.submit "sauvegarder", :class => "btn btn-primary"
+
\ No newline at end of file
diff --git a/app/views/admin/price_lines/_form.html.haml b/app/views/admin/price_lines/_form.html.haml
index 013f1d6..839313b 100644
--- a/app/views/admin/price_lines/_form.html.haml
+++ b/app/views/admin/price_lines/_form.html.haml
@@ -4,7 +4,6 @@
%td{:style => "padding-left:10px;", :class => ("error has-error" if form.object.errors[:p_product_ref_id].size > 0 )}
.take.mr-1
=ic :arrows
- = "PRICE_LINEEEEEEEE"
%td{:style => "white-space: nowrap;"}
.input-group
%label Référence
From 877824fba4a850ab71760391412e7e8ddb9bc386 Mon Sep 17 00:00:00 2001
From: Philippe
Date: Fri, 5 Nov 2021 18:46:32 +0100
Subject: [PATCH 07/12] adding select2 on price_line_block in
price_document_new
---
app/assets/javascripts/pane_hover.js | 7 +++
.../_form_facture_achat.html.haml | 11 +++--
.../price_line_p_articles/_form.html.haml | 2 +-
.../_add_price_line_p_article_form.html.haml | 4 +-
app/views/admin/price_lines/_form.html.haml | 44 ++++++++++---------
app/views/qi/_actions.html.haml | 4 ++
6 files changed, 43 insertions(+), 29 deletions(-)
create mode 100644 app/views/qi/_actions.html.haml
diff --git a/app/assets/javascripts/pane_hover.js b/app/assets/javascripts/pane_hover.js
index 3bb1844..8960543 100644
--- a/app/assets/javascripts/pane_hover.js
+++ b/app/assets/javascripts/pane_hover.js
@@ -25,6 +25,13 @@ function show_pane_hover(content, width, height, zindex){
$(".datepicker").attr("autocomplete", "off");
+ $(document).keyup(function(e) {
+ if (e.keyCode == 27) {
+ close_pane_hover();
+ return false;
+ }
+ });
+
}
diff --git a/app/views/admin/price_line_blocks/_form_facture_achat.html.haml b/app/views/admin/price_line_blocks/_form_facture_achat.html.haml
index 001336e..ca2fae3 100644
--- a/app/views/admin/price_line_blocks/_form_facture_achat.html.haml
+++ b/app/views/admin/price_line_blocks/_form_facture_achat.html.haml
@@ -63,7 +63,7 @@
=f.semantic_fields_for :price_lines do |f|
=render :partial => "admin/price_lines/form_bon_de_reception_achat", :locals => {:form => f}
- %p= link_to_add_fields "Ajouter une ligne", f, :price_lines, {:class => "btn btn-primary"}
+ %p= link_to_add_fields "Ajouter une ligneeeeeee", f, :price_lines, {:class => "btn btn-primary add_lines"}
-if current_admin.has_permission?("payments")
@@ -104,6 +104,9 @@
-if false
= f.input :ct_payment_month_end, :label => "Fin de mois ?"
-
-
-
+:javascript
+ $('.add_lines').click(function() {
+ console.log('LENGTH ' + $('.p_product_ref_select').length)
+ $('.p_product_ref_select').last().select2();
+ $('.p_product_ref_select').last().removeClass('form-control');
+ })
diff --git a/app/views/admin/price_line_p_articles/_form.html.haml b/app/views/admin/price_line_p_articles/_form.html.haml
index ce107a0..adf36d2 100644
--- a/app/views/admin/price_line_p_articles/_form.html.haml
+++ b/app/views/admin/price_line_p_articles/_form.html.haml
@@ -2,4 +2,4 @@
:javascript
$('.p_article_select').select2();
- $('.p_article_select').removeClass('form-control');
\ No newline at end of file
+ $('.p_article_select').removeClass('form-control');
diff --git a/app/views/admin/price_lines/_add_price_line_p_article_form.html.haml b/app/views/admin/price_lines/_add_price_line_p_article_form.html.haml
index 7aa687c..b601611 100644
--- a/app/views/admin/price_lines/_add_price_line_p_article_form.html.haml
+++ b/app/views/admin/price_lines/_add_price_line_p_article_form.html.haml
@@ -5,6 +5,4 @@
= f.semantic_fields_for :price_line_p_articles do |form|
=render :partial => "admin/price_line_p_articles/form", :locals => {:form => form}
%p= link_to_add_fields "Ajouter un article", f, :price_line_p_articles, {:class => "btn btn-primary"} if @price_line.p_articles.count < @price_line.qte
- =link_to "Annuler", "#", class:"btn btn-default", onclick:"close_pane_hover();return false;"
- =f.submit "sauvegarder", :class => "btn btn-primary"
-
\ No newline at end of file
+ =render :partial => "qi/actions", :locals => {:f => f}
diff --git a/app/views/admin/price_lines/_form.html.haml b/app/views/admin/price_lines/_form.html.haml
index 839313b..5e3ba63 100644
--- a/app/views/admin/price_lines/_form.html.haml
+++ b/app/views/admin/price_lines/_form.html.haml
@@ -1,48 +1,50 @@
-%tr.qi_pannel.qi_plain.padding.price_line_form.col-12.field{:style =>"border-left:4px solid gray;margin-bottom:10px;padding-left:5px;"}
+.row.qi_pannel.qi_plain.padding.price_line_form.col-12.field{:style =>"border-left:4px solid gray;margin-bottom:10px;padding-left:5px;"}
- %td{:style => "padding-left:10px;", :class => ("error has-error" if form.object.errors[:p_product_ref_id].size > 0 )}
- .take.mr-1
- =ic :arrows
- %td{:style => "white-space: nowrap;"}
+
+ .take.mr-1{:style => "padding-left:10px;", :class => ("error has-error" if form.object.errors[:p_product_ref_id].size > 0 )}
+ =ic :arrows
+ .col-3{:style => "white-space: nowrap;"}
+ =form.input :p_product_ref, as: :select, collection: PProductRef.all.map{ |p_product_ref| [p_product_ref.member_label, p_product_ref.id] }, label: "Référence", input_html: {class:"p_product_ref_select"}
.input-group
- %label Référence
- %input.p_product_ref_autocomplete_input.form-control{:type => "text", :style => "", tabindex: 1, autofocus: true, :value => ("#{form.object.p_product_ref.member_label}" if form.object.p_product_ref), :class => "p_product_ref_name"}
- = form.hidden_field :p_product_ref_id, :class => "p_product_ref_id"
- .input-group-append
- =link_to "#", class: "btn btn-dark",:onclick => "key=genRanHex(12);select_product_from_manager(key);$(this).closest('tr').find('.p_product_ref_id').attr('id', 'p_product_ref_id_'+key);$(this).closest('tr').find('.p_product_ref_name').attr('id', 'p_product_ref_name_'+key);$(this).closest('tr').find('.p_product_ref_qte').attr('id', 'p_product_ref_qte_'+key);return false;" do
- =ic(:search)
+ -# %label Référence
+ -# %input.p_product_ref_autocomplete_input.form-control{:type => "text", :style => "", tabindex: 1, autofocus: true, :value => ("#{form.object.p_product_ref.member_label}" if form.object.p_product_ref), :class => "p_product_ref_name"}
+ -# = form.hidden_field :p_product_ref_id, :class => "p_product_ref_id"
+
+ -# .input-group-append
+ -# =link_to "#", class: "btn btn-dark",:onclick => "key=genRanHex(12);select_product_from_manager(key);$(this).closest('tr').find('.p_product_ref_id').attr('id', 'p_product_ref_id_'+key);$(this).closest('tr').find('.p_product_ref_name').attr('id', 'p_product_ref_name_'+key);$(this).closest('tr').find('.p_product_ref_qte').attr('id', 'p_product_ref_qte_'+key);return false;" do
+ -# =ic(:search)
-form.object.forced_price = true if form.object.ct_u_price_ht
-# -if form.object.forced_price and form.object.p_product_ref
- -# %td
+ -# .col-3
-# .mx-2
-# .form-inline
-# =qi_js_field_price_line_form(form, :price_line, :price_u_ht, :label => false, label_class: "mr-1", :value => form.object.th_price_u_ht)
-# -else
- -# %td
+ -# .col-3
-# .mx-2
-# .form-inline
-# =qi_js_field_price_line_form(form, :price_line, :price_u_ht, :label =>false, label_class: "mr-1")
- -# %td
+ -# .col-3
-# .form-inline.mr-2{:style => ("display:none;" if !current_admin or !current_admin.has_permission?("customer-sheets-personalised-price"))}
-# = form.input :forced_price, :label => "Prix personnalisé ?", :as => :boolean, :input_html => {:class => "form-inline input_price_line_forced_price"}
-# .forced_price_wrapper.mx-2{:style => ("display:none;" if !form.object.forced_price)}= form.input :ct_u_price_ht, :label => false, :input_html => {:class => "input_price_line_ct_u_price_ht"}
- %td
+ .col-3
= form.input :qte, :label => "Quantité", :input_html => {:class => "input_price_line_qte form-control p_product_ref_qte", tabindex: 1}
- %td
+ .col-3
= form.input :ct_u_price_ht, :label => "Prix Unitaire HT :", :input_html => { class: "mx-2"}
- -# %td
+ -# .col-3
-# =form.input :ct_tva_account_id, :collection => options_from_collection_for_select(TvaRate.where(:accounting_zone_id => (@p_customer ? @p_customer.accounting_zone_id : nil)).all, "id", "member_label", form.object.tva_account_id), :as => :select ,:label => false, :include_blank => false , :input_html => {:class => "input_price_line_tva_account_id form-control custom-select"}
- %td
- %span.destroy=link_to_remove_fields ic(:"trash-o"), form
- =qi_js_field(form, :price_line, :tva_account_value, :hidden => true)
+ .col-1.text-center.my-auto
+ %span.destroy{style: "font-size: 2rem;"}=link_to_remove_fields ic(:"trash-o"), form
+ = qi_js_field(form, :price_line, :tva_account_value, :hidden => true)
= form.hidden_field :position, :class => "price_line_position_input"
-:javascript
+:javascript
$('.p_product_ref_autocomplete_input').focus()
$( function() {
$('.p_product_ref_autocomplete_input').autocomplete({
diff --git a/app/views/qi/_actions.html.haml b/app/views/qi/_actions.html.haml
new file mode 100644
index 0000000..cf5d322
--- /dev/null
+++ b/app/views/qi/_actions.html.haml
@@ -0,0 +1,4 @@
+%hr
+=link_to "Annuler", "#", class:"btn btn-default", onclick:"close_pane_hover();return false;"
+=f.submit "sauvegarder", :class => "btn btn-primary"
+
\ No newline at end of file
From e2ed7e5f22a3482f0c1f344b11da40a935929a5a Mon Sep 17 00:00:00 2001
From: Philippe
Date: Mon, 8 Nov 2021 18:43:44 +0100
Subject: [PATCH 08/12] addin good select2 instead of autocomplete. adding bon
de commande client to p custommer sheet
---
.../(__TEMPLATE__)c | Bin 5965 -> 1374 bytes
Gemfile | 8 +-
Gemfile.lock | 8 +-
app/assets/javascripts/admin.coffee | 2 +-
app/assets/stylesheets/admin.scss | 3 +
.../admin/price_documents_controller.rb | 5 +-
app/models/p_customer_sheet.rb | 6 +-
app/models/price_line_block.rb | 8 +-
.../admin/price_documents/index.html.haml | 4 +-
.../_form_facture_achat.html.haml | 9 +-
.../price_line_p_articles/_form.html.haml | 8 +-
.../_add_price_line_p_article_form.html.haml | 4 +-
app/views/admin/price_lines/_form.html.haml | 107 ++++++++----------
...mns_to_price_docs_adn_price_line_blocks.rb | 3 +
db/schema.rb | 2 +
15 files changed, 87 insertions(+), 90 deletions(-)
diff --git a/.sass-cache/f6b9a0b1905a68d5dbb2139e95d49cba92f6fa93/(__TEMPLATE__)c b/.sass-cache/f6b9a0b1905a68d5dbb2139e95d49cba92f6fa93/(__TEMPLATE__)c
index f14f6942a4eff9a4b9af0c9026e5b8e2e708b671..e1c3ae14c64ffb6b86d264611307231a215c18c3 100644
GIT binary patch
delta 389
zcmX@BcaKZYSkGL~gv-Ft$jCf3HQB=4I4#v6HPtxPBq=#1&D_W+H6It+*WW5_3~Mm3W{MlU*3sGxAOT!WauA
zgP5*QUc@3R#*>m+T#%Dk$!5(NV#V!HmY7qT8qGFYo>zSGdlp?8&b<7*RInVcLw-R?
zW`16AH3QJ(lFEYA$(F48%IwzS`PLGg){^!FD8Pv&LQl7O1)pl>bfAZ0D*AZ;yVV6Ew(F}aIP8t9#DHaRm5D?W#k
v)Lfu%N`SsrfrUpkmx2P+lU5+#SaWgJa&d8iJOy+U+vJbjiacy^Qw>7^kL+bZ
literal 5965
zcmbVQUvt~W5f?Qbii9jtbo9@ZEVHzu*orOEk{sE0Gwmg=JYgnrG#1krJz$RHi9!S7
zPym#pdi>UWh4f?eOSNC2eQb9Re~w2&ij*hfh}*s2?(P0|7yG-1y9d_c!NDQ#?RC4a
z&iLMo?w)8J?Dt;r=l$Nx7hJsT9f~iyqPyR+epiy@-U$ywLOOvEguIh7dMo?l4q0Tq
zbI0um!aFTbZW_4)H&uwm0(d?xwi{~?yRv_2hY^pQFmnDn5@C@Pk2>To^LY@8zKuIW
zNgDBSC&CrINCt$wmct=G5g_69M2Rf0p%`{W5S|t#xj(r%-8V;QNPD@13FViged}
zylZW8SG!*V=pG-6c4KuKH!XMIwd;7oDS{u)99Q7p7GMiU-M;{C^(aR{4=pO4h^Pnx
z=R7?BIP(T94%I6=;NCz;vYs5T{sb4}zhzQk;Hx0AeF-Wy%q_<Nw?l5_F
z7K#WS7ntz+N`%(bOS<8#!_f$_1yI3y8AKvzp&-2*|HO}EgN2FDZ37=&FVlNc>nqaD
zvDG@g-)?;J*tR=I-yMJZW#`DYpA^ACbW4(YjJlm13PJP+aDwKJ%Sg~6E^pK)C+zI1b6Mr)MRR}EnL|f^(xS`RQFKjS@6{!GzeTt3dXzB!B##da$vL>+Qg$D>x=Zh~8r@|8sY@TY!Y6Q!}IKdyCapKFPl4E-urP7$dT74kGjsl?nze$M#k2E9|sWk
zB3j>Rs`~)1UHXE|hnNKs_-+Qwg+P=(Mrin929TE~3@!msD}#+IlER*#lH)-7NF_^j
z2`^(sV|=FIsVmvWR8NBKq!&1Tl+x9=4g@=QOLTi`!=KS|LQbLpqM%H-k)pnM{o<>`
zug0uY>YuPz^fOX%`e2`P=7@kaSYP;o=OhIEWMQ_gNoolT>(b;xX;eu+AHx{ie#?w+
zWEqcV!HqBccAROo$Z#HqV$_%OWSOY|1CRA=m9=q*Z9XNlh7>GW0KecT)8ePxB^Lo#7dHWdWS-qw;QL;9hLYup(v|9#%VEMkot6z
zr&LBiqmRw3TTBBqNrOeers=i(Oq=(
z(!`ldaLQulS6pqSXDW(s(v}H2Pk{z)DtI1O6IS@Ual%4&!k$rX5-hCnbGkvBUG2)C
zFM?-*GdPb_9w03n)~_D;Kh;C&I{ow()IPyK
z^M5f;Sk6u`%}=nf!auSN84WI^xLKI#GDCTs%WAo7rM&U0{l#@WwS1E-)wzabyOCw7
z60SPS5QOT{%+h7pt0i#-l2>Kv{w=aJX(XnzZzXkUl6@<1roKsB?WYKI7*1p#d6aPW
zL|YI>No#Ll=OhJ6`QE2sXD6@-dY9!EN7vJt9z-p=v`Jzflk<)0DU{c5zC_6XQkHe3#{~H
zg?XbPG*d8>*(1*ZZ_Plb0X>m~?%4Qukx3u{_|t7SP#gfhftbnzxM2X)#0CJt*FTEO
z_dqHz|7^wX{2_8&Lf*$X(}eqW>ND=b&|heb5tN9|!Fwl&>N8;dh>ezRO`0gALH^
z5A1k(1(J$^w38A6pX>PYmMm7xYc
z(Uk#Lx`9uJ(5ySUdV(`rg==TAv{%?jothMg4LG`%c^6ktvzy2bhCBs27)%9eFwAZh
zj3czIX0wohVY3ekDTwKexTaOSkq0&>Jg^BiuV(OY^*B8|pAqsDXb+eQG7q%02XMz#
z`H+BNv(GaR=!B@H$k}W~t22XVKb;k!7QiPXWOMi+H~VgO`di`$t6tY1YH(GrH=Fuv
z!Og}65Yi&o3=E+Dqh)=xa=W;jOr!{~*}TOdV;FNivRLcnph4lp@eZA6!c8V33I^p{
zbbGWhhB~%Kj}?-qb!Y^hj14~5;2A3b3ez+fBA}aIRAO|3C};XZv#q3w%DzY>jDiia
NrnY#MHog0u{{w}+6Mp~z
diff --git a/Gemfile b/Gemfile
index bab2ceb..3806597 100644
--- a/Gemfile
+++ b/Gemfile
@@ -54,9 +54,9 @@ group :development do
# Access an interactive console on exception pages or by calling 'console' anywhere in the code.
gem 'web-console', '>= 3.3.0'
gem 'listen', '>= 3.0.5', '< 3.2'
- # Spring speeds up development by keeping your application running in the background. Read more: https://github.com/rails/spring
- gem 'spring'
- gem 'spring-watcher-listen', '~> 2.0.0'
+ # # Spring speeds up development by keeping your application running in the background. Read more: https://github.com/rails/spring
+ # gem 'spring'
+ # gem 'spring-watcher-listen', '~> 2.0.0'
end
group :test do
@@ -118,3 +118,5 @@ gem 'axlsx_rails'
gem 'mimemagic', "0.3.10"
gem "roo"
+gem "select2-rails"
+
diff --git a/Gemfile.lock b/Gemfile.lock
index 93c6cac..d374180 100644
--- a/Gemfile.lock
+++ b/Gemfile.lock
@@ -301,6 +301,7 @@ GEM
activemodel (>= 5)
elasticsearch (>= 6)
hashie
+ select2-rails (4.0.13)
selenium-webdriver (3.142.3)
childprocess (>= 0.5, < 2.0)
rubyzip (~> 1.2, >= 1.2.2)
@@ -308,10 +309,6 @@ GEM
sixarm_ruby_unaccent (1.2.0)
sort_alphabetical (1.1.0)
unicode_utils (>= 1.2.2)
- spring (2.1.0)
- spring-watcher-listen (2.0.1)
- listen (>= 2.7, < 4.0)
- spring (>= 1.2, < 3.0)
sprockets (3.7.2)
concurrent-ruby (~> 1.0)
rack (> 1, < 3)
@@ -406,9 +403,8 @@ DEPENDENCIES
roo
sass-rails (~> 5)
searchkick
+ select2-rails
selenium-webdriver
- spring
- spring-watcher-listen (~> 2.0.0)
sprockets
tiny_tds (= 1.3.0)
truncate_html
diff --git a/app/assets/javascripts/admin.coffee b/app/assets/javascripts/admin.coffee
index ea98f59..b0b76cb 100644
--- a/app/assets/javascripts/admin.coffee
+++ b/app/assets/javascripts/admin.coffee
@@ -15,7 +15,7 @@
#= require vendor/jquery.fileupload
#= require vendor/jquery.fileupload-ui
#= require vendor/jquery.fileupload-process
-#= require vendor/select2.min
+#= require select2
#= require vendor/accounting
#= require vendor/jquery.mask
#= require vendor/datatables.min
diff --git a/app/assets/stylesheets/admin.scss b/app/assets/stylesheets/admin.scss
index cb1ee54..af45036 100644
--- a/app/assets/stylesheets/admin.scss
+++ b/app/assets/stylesheets/admin.scss
@@ -1,3 +1,6 @@
+/*
+*= require select2
+*/
// Variables
@import "1-variables/app";
diff --git a/app/controllers/admin/price_documents_controller.rb b/app/controllers/admin/price_documents_controller.rb
index a58c531..0446561 100644
--- a/app/controllers/admin/price_documents_controller.rb
+++ b/app/controllers/admin/price_documents_controller.rb
@@ -98,7 +98,7 @@ class Admin::PriceDocumentsController < ApplicationController
if true
- @price_documents = @price_documents.where(:price_document_type_id => params[:price_document_type_ids]) if params[:price_document_type_ids].size > 0
+ @price_documents = @price_documents.where(:price_document_type_id => params[:price_document_type_ids]).order(:id) if params[:price_document_type_ids].size > 0
if current_admin.p_commercial
@@ -234,7 +234,6 @@ class Admin::PriceDocumentsController < ApplicationController
redirect_to admin_p_fournisseurs_path(:create_document => "Commande achat" )
else
-
@price_document = PriceDocument.new(:p_customer_id => params[:p_customer_id], :p_fournisseur_id => params[:p_fournisseur_id])
@price_document.price_document_type = PriceDocumentType.where(:label => params[:document_type]).first
@price_document.price_line_block = PriceLineBlock.new(:p_customer_id => params[:p_customer_id], :p_fournisseur_id => params[:p_fournisseur_id])
@@ -332,7 +331,7 @@ class Admin::PriceDocumentsController < ApplicationController
if @price_document.save
#if @price_document.cc_label == "Demande prix"
if @price_document.cc_label == "Facture achat"
- render action: :show
+ redirect_to admin_price_document_path(@price_document)
else
redirect_to admin_price_documents_path(:price_document_type_id => @price_document.price_document_type_id)
end
diff --git a/app/models/p_customer_sheet.rb b/app/models/p_customer_sheet.rb
index c477f8c..414af69 100644
--- a/app/models/p_customer_sheet.rb
+++ b/app/models/p_customer_sheet.rb
@@ -268,9 +268,11 @@ class PCustomerSheet < ApplicationRecord
self.archive_now if !self.archived
self.block_price if !self.price_blocked
price_document = self.price_documents.new(:price_document_type => PriceDocumentType.find_by_label(label), :date => Date.today)
+ #raise
price_document.p_customer = self.p_customer
price_document.price_line_block = self.price_line_block.dup
+ price_document.tva_type = self.price_line_block.price_document.tva_type
price_document.price_line_block.ac_block_type = nil
@@ -278,7 +280,7 @@ class PCustomerSheet < ApplicationRecord
new_pl = pl.dup
new_pl.ac_block_type = nil
price_document.price_line_block.price_lines << new_pl
- end
+ end
if price_document.save
@@ -306,7 +308,7 @@ class PCustomerSheet < ApplicationRecord
def generate_bc
- generate_doc("Bon de commande", "commande")
+ generate_doc("Bon de commande client", "commande")
end
diff --git a/app/models/price_line_block.rb b/app/models/price_line_block.rb
index 744e069..abee8ee 100644
--- a/app/models/price_line_block.rb
+++ b/app/models/price_line_block.rb
@@ -29,6 +29,8 @@ class PriceLineBlock < ApplicationRecord
belongs_to :p_fournisseur
accepts_nested_attributes_for :p_fournisseur
+
+ belongs_to :price_document
def to_no_archive
if self.imported
@@ -827,10 +829,6 @@ class PriceLineBlock < ApplicationRecord
AVOIR_TO_RESET = %w(weight_tot tot_lines_ht tot_lines_tva tot_lines_ttc tot_fdp_ht tot_fdp_tva tot_fdp_ttc tot_discount_ht tot_discount_tva tot_discount_ttc tot_amount_af_discount_ht tot_amount_af_discount_tva tot_amount_af_discount_ttc gen_discount_percent tot_gen_discount_ht tot_gen_discount_tva tot_gen_discount_ttc tot_amount_ht tot_amount_tva tot_amount_ttc nbr_ship)
-
-
-
-
-
+
end
diff --git a/app/views/admin/price_documents/index.html.haml b/app/views/admin/price_documents/index.html.haml
index 9b37cf8..6ad976f 100644
--- a/app/views/admin/price_documents/index.html.haml
+++ b/app/views/admin/price_documents/index.html.haml
@@ -11,8 +11,6 @@
-if params[:price_document_type_id]
=breadcrumb second_title: PriceDocumentType.find(params[:price_document_type_id]).label
-
-
.qi_search_row
=form_tag "", :method => "get", :onsubmit => "" do
@@ -137,7 +135,7 @@
=render :partial => "qi/qi_ordered_table_search_footer", :locals => {:collection_object => @price_documents}
-if true #if params[:price_document_type_id].to_i != 0
- =render :partial => "qi/qi_ordered_table", :locals => {:qi_ordered_table_collection => @price_documents, :key => params[:price_document_type_id].to_s}
+ = render :partial => "qi/qi_ordered_table", :locals => {:qi_ordered_table_collection => @price_documents, :key => params[:price_document_type_id].to_s}
:scss
diff --git a/app/views/admin/price_line_blocks/_form_facture_achat.html.haml b/app/views/admin/price_line_blocks/_form_facture_achat.html.haml
index ca2fae3..d71d68c 100644
--- a/app/views/admin/price_line_blocks/_form_facture_achat.html.haml
+++ b/app/views/admin/price_line_blocks/_form_facture_achat.html.haml
@@ -63,7 +63,7 @@
=f.semantic_fields_for :price_lines do |f|
=render :partial => "admin/price_lines/form_bon_de_reception_achat", :locals => {:form => f}
- %p= link_to_add_fields "Ajouter une ligneeeeeee", f, :price_lines, {:class => "btn btn-primary add_lines"}
+ %p= link_to_add_fields "Ajouter une ligne", f, :price_lines, {:class => "btn btn-primary add_lines"}
-if current_admin.has_permission?("payments")
@@ -106,7 +106,8 @@
:javascript
$('.add_lines').click(function() {
- console.log('LENGTH ' + $('.p_product_ref_select').length)
- $('.p_product_ref_select').last().select2();
- $('.p_product_ref_select').last().removeClass('form-control');
+ $('.p_product_ref_select').last().select2({
+ //theme: "bootstrap"
+ });
+ //$('.p_product_ref_select').last().removeClass('form-control');
})
diff --git a/app/views/admin/price_line_p_articles/_form.html.haml b/app/views/admin/price_line_p_articles/_form.html.haml
index adf36d2..ea396e6 100644
--- a/app/views/admin/price_line_p_articles/_form.html.haml
+++ b/app/views/admin/price_line_p_articles/_form.html.haml
@@ -1,5 +1,7 @@
-=form.input :p_article_id, as: :select, collection: PArticle.all.map{|p_article| [p_article.serialized_name, p_article.id]}, label: "Article(s) associé(s)", input_html: {class:"p_article_select"}
+= form.input :p_article_id, as: :select, collection: PArticle.joins(:p_product_ref).where(p_product_ref: price_line.p_product_ref).map{|p_article| [p_article.serialized_name, p_article.id]}, label: "Article(s) associé(s)", input_html: {class:"p_article_select"}
:javascript
- $('.p_article_select').select2();
- $('.p_article_select').removeClass('form-control');
+ $('.p_article_select').select2({
+ //theme: "bootstrap"
+ });
+ //$('.p_article_select').removeClass('form-control');
diff --git a/app/views/admin/price_lines/_add_price_line_p_article_form.html.haml b/app/views/admin/price_lines/_add_price_line_p_article_form.html.haml
index b601611..8071164 100644
--- a/app/views/admin/price_lines/_add_price_line_p_article_form.html.haml
+++ b/app/views/admin/price_lines/_add_price_line_p_article_form.html.haml
@@ -1,8 +1,8 @@
.mx-2.my-2
=semantic_form_for [:admin, @price_line], :remote => true do |f|
=f.inputs do
- .price_line_p_articles_form
+ .price_line_p_articles_form.col-3
= f.semantic_fields_for :price_line_p_articles do |form|
- =render :partial => "admin/price_line_p_articles/form", :locals => {:form => form}
+ =render :partial => "admin/price_line_p_articles/form", :locals => {:form => form, price_line: @price_line}
%p= link_to_add_fields "Ajouter un article", f, :price_line_p_articles, {:class => "btn btn-primary"} if @price_line.p_articles.count < @price_line.qte
=render :partial => "qi/actions", :locals => {:f => f}
diff --git a/app/views/admin/price_lines/_form.html.haml b/app/views/admin/price_lines/_form.html.haml
index 5e3ba63..ffc3c7a 100644
--- a/app/views/admin/price_lines/_form.html.haml
+++ b/app/views/admin/price_lines/_form.html.haml
@@ -4,8 +4,8 @@
.take.mr-1{:style => "padding-left:10px;", :class => ("error has-error" if form.object.errors[:p_product_ref_id].size > 0 )}
=ic :arrows
- .col-3{:style => "white-space: nowrap;"}
- =form.input :p_product_ref, as: :select, collection: PProductRef.all.map{ |p_product_ref| [p_product_ref.member_label, p_product_ref.id] }, label: "Référence", input_html: {class:"p_product_ref_select"}
+ .col-3
+ = form.input :p_product_ref, as: :select, collection: PProductRef.all.map{ |p_product_ref| [p_product_ref.member_label, p_product_ref.id] }, label: "Référence :", input_html: {class:"p_product_ref_select"}
.input-group
-# %label Référence
-# %input.p_product_ref_autocomplete_input.form-control{:type => "text", :style => "", tabindex: 1, autofocus: true, :value => ("#{form.object.p_product_ref.member_label}" if form.object.p_product_ref), :class => "p_product_ref_name"}
@@ -32,7 +32,7 @@
-# = form.input :forced_price, :label => "Prix personnalisé ?", :as => :boolean, :input_html => {:class => "form-inline input_price_line_forced_price"}
-# .forced_price_wrapper.mx-2{:style => ("display:none;" if !form.object.forced_price)}= form.input :ct_u_price_ht, :label => false, :input_html => {:class => "input_price_line_ct_u_price_ht"}
.col-3
- = form.input :qte, :label => "Quantité", :input_html => {:class => "input_price_line_qte form-control p_product_ref_qte", tabindex: 1}
+ = form.input :qte, :label => "Quantité :", :input_html => {:class => "input_price_line_qte form-control p_product_ref_qte", tabindex: 1}
.col-3
= form.input :ct_u_price_ht, :label => "Prix Unitaire HT :", :input_html => { class: "mx-2"}
@@ -43,59 +43,50 @@
= qi_js_field(form, :price_line, :tva_account_value, :hidden => true)
= form.hidden_field :position, :class => "price_line_position_input"
-
:javascript
- $('.p_product_ref_autocomplete_input').focus()
- $( function() {
- $('.p_product_ref_autocomplete_input').autocomplete({
- source: function( request, response ) {
- $.ajax( {
- url: "/admin/p_product_refs/autocomplete.json",
- dataType: "json",
- data: {
- search: request.term,
- p_customer_id: $(".p_customer_id").val()
- },
- success: function(data){
- arr = jQuery.map( data, function( item ) {
- return {
- label: item.member_label,
- value: item.member_label,
- id: item.id
- }
- });
- response(arr)
- }
- });
- },
- minLength: 2,
- select: function( event, ui ) {
- $(this).next(".p_product_ref_id").val(ui.item.id)
- form = $(this).closest(".price_line_form")
- $.ajax( {
- url: "/admin/p_product_refs/"+ui.item.id+"/get_infos.json",
- dataType: "json",
- data: {
- type: "price",
- qte: form.find(".input_price_line_qte").val(),
- p_customer_id: $(".p_customer_id").val()
- },
- success: function (data) {
- form.find(".input_price_line_price_u_ht").val(data.price);
- form.find(".input_price_line_tva_account_id").val(data.tva_account_id);
- form.find(".input_price_line_tva_account_value").val(data.tva_account_value);
- form.find(".input_price_line_weight_u").val(data.weight);
- }
- });
- //return false
- }
- });
- });
-
-
-:scss
- .price_line_form{
- .form-group{
- margin-bottom:0;}
-
- }
+-# $('.p_product_ref_autocomplete_input').focus()
+-# $( function() {
+-# $('.p_product_ref_autocomplete_input').autocomplete({
+-# source: function( request, response ) {
+-# $.ajax( {
+-# url: "/admin/p_product_refs/autocomplete.json",
+-# dataType: "json",
+-# data: {
+-# search: request.term,
+-# p_customer_id: $(".p_customer_id").val()
+-# },
+-# success: function(data){
+-# arr = jQuery.map( data, function( item ) {
+-# return {
+-# label: item.member_label,
+-# value: item.member_label,
+-# id: item.id
+-# }
+-# });
+-# response(arr)
+-# }
+-# });
+-# },
+-# minLength: 2,
+-# select: function( event, ui ) {
+-# $(this).next(".p_product_ref_id").val(ui.item.id)
+-# form = $(this).closest(".price_line_form")
+-# $.ajax( {
+-# url: "/admin/p_product_refs/"+ui.item.id+"/get_infos.json",
+-# dataType: "json",
+-# data: {
+-# type: "price",
+-# qte: form.find(".input_price_line_qte").val(),
+-# p_customer_id: $(".p_customer_id").val()
+-# },
+-# success: function (data) {
+-# form.find(".input_price_line_price_u_ht").val(data.price);
+-# form.find(".input_price_line_tva_account_id").val(data.tva_account_id);
+-# form.find(".input_price_line_tva_account_value").val(data.tva_account_value);
+-# form.find(".input_price_line_weight_u").val(data.weight);
+-# }
+-# });
+-# //return false
+-# }
+-# });
+-# });
\ No newline at end of file
diff --git a/db/migrate/20211029111104_add_columns_to_price_docs_adn_price_line_blocks.rb b/db/migrate/20211029111104_add_columns_to_price_docs_adn_price_line_blocks.rb
index eafc48e..d94c68b 100644
--- a/db/migrate/20211029111104_add_columns_to_price_docs_adn_price_line_blocks.rb
+++ b/db/migrate/20211029111104_add_columns_to_price_docs_adn_price_line_blocks.rb
@@ -6,5 +6,8 @@ class AddColumnsToPriceDocsAdnPriceLineBlocks < ActiveRecord::Migration[6.0]
add_column :price_documents, :supplier_document_date, :date
add_column :price_line_blocks, :stock_entrance_date, :date
add_column :price_line_blocks, :ct_tot_amount_ht, :decimal, :precision => 14, :scale => 2
+ change_table :price_line_blocks do |t|
+ t.belongs_to :price_document
+ end
end
end
diff --git a/db/schema.rb b/db/schema.rb
index c6cfc94..4128f51 100644
--- a/db/schema.rb
+++ b/db/schema.rb
@@ -2471,7 +2471,9 @@ ActiveRecord::Schema.define(version: 2021_11_03_085623) do
t.string "cc_state"
t.date "stock_entrance_date"
t.decimal "ct_tot_amount_ht", precision: 14, scale: 2
+ t.bigint "price_document_id"
t.index ["p_customer_id"], name: "index_price_line_blocks_on_p_customer_id"
+ t.index ["price_document_id"], name: "index_price_line_blocks_on_price_document_id"
end
create_table "price_line_p_articles", force: :cascade do |t|
From 820bd0364076487cdb4ec57c1621cfe39e741d91 Mon Sep 17 00:00:00 2001
From: Philippe
Date: Tue, 9 Nov 2021 12:13:52 +0100
Subject: [PATCH 09/12] fixing p_article_price_line mannel bug
---
.../(__TEMPLATE__)c | Bin 1374 -> 5965 bytes
app/models/p_customer_sheet.rb | 10 +---
.../admin/p_customer_sheets/_form.html.haml | 1 -
.../admin/price_line_blocks/_form.html.haml | 53 +++++++++---------
.../price_line_p_articles/_form.html.haml | 2 +-
.../_add_price_line_p_article_form.html.haml | 2 +-
app/views/admin/price_lines/_form.html.haml | 51 -----------------
7 files changed, 31 insertions(+), 88 deletions(-)
diff --git a/.sass-cache/f6b9a0b1905a68d5dbb2139e95d49cba92f6fa93/(__TEMPLATE__)c b/.sass-cache/f6b9a0b1905a68d5dbb2139e95d49cba92f6fa93/(__TEMPLATE__)c
index e1c3ae14c64ffb6b86d264611307231a215c18c3..f14f6942a4eff9a4b9af0c9026e5b8e2e708b671 100644
GIT binary patch
literal 5965
zcmbVQUvt~W5f?Qbii9jtbo9@ZEVHzu*orOEk{sE0Gwmg=JYgnrG#1krJz$RHi9!S7
zPym#pdi>UWh4f?eOSNC2eQb9Re~w2&ij*hfh}*s2?(P0|7yG-1y9d_c!NDQ#?RC4a
z&iLMo?w)8J?Dt;r=l$Nx7hJsT9f~iyqPyR+epiy@-U$ywLOOvEguIh7dMo?l4q0Tq
zbI0um!aFTbZW_4)H&uwm0(d?xwi{~?yRv_2hY^pQFmnDn5@C@Pk2>To^LY@8zKuIW
zNgDBSC&CrINCt$wmct=G5g_69M2Rf0p%`{W5S|t#xj(r%-8V;QNPD@13FViged}
zylZW8SG!*V=pG-6c4KuKH!XMIwd;7oDS{u)99Q7p7GMiU-M;{C^(aR{4=pO4h^Pnx
z=R7?BIP(T94%I6=;NCz;vYs5T{sb4}zhzQk;Hx0AeF-Wy%q_<Nw?l5_F
z7K#WS7ntz+N`%(bOS<8#!_f$_1yI3y8AKvzp&-2*|HO}EgN2FDZ37=&FVlNc>nqaD
zvDG@g-)?;J*tR=I-yMJZW#`DYpA^ACbW4(YjJlm13PJP+aDwKJ%Sg~6E^pK)C+zI1b6Mr)MRR}EnL|f^(xS`RQFKjS@6{!GzeTt3dXzB!B##da$vL>+Qg$D>x=Zh~8r@|8sY@TY!Y6Q!}IKdyCapKFPl4E-urP7$dT74kGjsl?nze$M#k2E9|sWk
zB3j>Rs`~)1UHXE|hnNKs_-+Qwg+P=(Mrin929TE~3@!msD}#+IlER*#lH)-7NF_^j
z2`^(sV|=FIsVmvWR8NBKq!&1Tl+x9=4g@=QOLTi`!=KS|LQbLpqM%H-k)pnM{o<>`
zug0uY>YuPz^fOX%`e2`P=7@kaSYP;o=OhIEWMQ_gNoolT>(b;xX;eu+AHx{ie#?w+
zWEqcV!HqBccAROo$Z#HqV$_%OWSOY|1CRA=m9=q*Z9XNlh7>GW0KecT)8ePxB^Lo#7dHWdWS-qw;QL;9hLYup(v|9#%VEMkot6z
zr&LBiqmRw3TTBBqNrOeers=i(Oq=(
z(!`ldaLQulS6pqSXDW(s(v}H2Pk{z)DtI1O6IS@Ual%4&!k$rX5-hCnbGkvBUG2)C
zFM?-*GdPb_9w03n)~_D;Kh;C&I{ow()IPyK
z^M5f;Sk6u`%}=nf!auSN84WI^xLKI#GDCTs%WAo7rM&U0{l#@WwS1E-)wzabyOCw7
z60SPS5QOT{%+h7pt0i#-l2>Kv{w=aJX(XnzZzXkUl6@<1roKsB?WYKI7*1p#d6aPW
zL|YI>No#Ll=OhJ6`QE2sXD6@-dY9!EN7vJt9z-p=v`Jzflk<)0DU{c5zC_6XQkHe3#{~H
zg?XbPG*d8>*(1*ZZ_Plb0X>m~?%4Qukx3u{_|t7SP#gfhftbnzxM2X)#0CJt*FTEO
z_dqHz|7^wX{2_8&Lf*$X(}eqW>ND=b&|heb5tN9|!Fwl&>N8;dh>ezRO`0gALH^
z5A1k(1(J$^w38A6pX>PYmMm7xYc
z(Uk#Lx`9uJ(5ySUdV(`rg==TAv{%?jothMg4LG`%c^6ktvzy2bhCBs27)%9eFwAZh
zj3czIX0wohVY3ekDTwKexTaOSkq0&>Jg^BiuV(OY^*B8|pAqsDXb+eQG7q%02XMz#
z`H+BNv(GaR=!B@H$k}W~t22XVKb;k!7QiPXWOMi+H~VgO`di`$t6tY1YH(GrH=Fuv
z!Og}65Yi&o3=E+Dqh)=xa=W;jOr!{~*}TOdV;FNivRLcnph4lp@eZA6!c8V33I^p{
zbbGWhhB~%Kj}?-qb!Y^hj14~5;2A3b3ez+fBA}aIRAO|3C};XZv#q3w%DzY>jDiia
NrnY#MHog0u{{w}+6Mp~z
delta 389
zcmX@BcaKZYSkGL~gv-Ft$jCf3HQB=4I4#v6HPtxPBq=#1&D_W+H6It+*WW5_3~Mm3W{MlU*3sGxAOT!WauA
zgP5*QUc@3R#*>m+T#%Dk$!5(NV#V!HmY7qT8qGFYo>zSGdlp?8&b<7*RInVcLw-R?
zW`16AH3QJ(lFEYA$(F48%IwzS`PLGg){^!FD8Pv&LQl7O1)pl>bfAZ0D*AZ;yVV6Ew(F}aIP8t9#DHaRm5D?W#k
v)Lfu%N`SsrfrUpkmx2P+lU5+#SaWgJa&d8iJOy+U+vJbjiacy^Qw>7^kL+bZ
diff --git a/app/models/p_customer_sheet.rb b/app/models/p_customer_sheet.rb
index 414af69..76b4e3d 100644
--- a/app/models/p_customer_sheet.rb
+++ b/app/models/p_customer_sheet.rb
@@ -267,29 +267,25 @@ class PCustomerSheet < ApplicationRecord
def generate_doc(label, state)
self.archive_now if !self.archived
self.block_price if !self.price_blocked
- price_document = self.price_documents.new(:price_document_type => PriceDocumentType.find_by_label(label), :date => Date.today)
- #raise
- price_document.p_customer = self.p_customer
+ price_document = self.price_documents.new(:price_document_type => PriceDocumentType.find_by_label(label), :date => Date.today)
+ price_document.p_customer = self.p_customer
price_document.price_line_block = self.price_line_block.dup
price_document.tva_type = self.price_line_block.price_document.tva_type
-
price_document.price_line_block.ac_block_type = nil
self.price_line_block.price_lines.each do |pl|
new_pl = pl.dup
new_pl.ac_block_type = nil
+ pl.p_articles.each { |p_article| new_pl.p_articles << p_article }
price_document.price_line_block.price_lines << new_pl
end
if price_document.save
-
price_document.archive_now
self.state = state
self.save
-
end
-
end
def generate_d
diff --git a/app/views/admin/p_customer_sheets/_form.html.haml b/app/views/admin/p_customer_sheets/_form.html.haml
index 9f1576e..5df9e97 100755
--- a/app/views/admin/p_customer_sheets/_form.html.haml
+++ b/app/views/admin/p_customer_sheets/_form.html.haml
@@ -19,4 +19,3 @@
=link_to "Annuler", admin_p_customer_sheets_path(), :class => "btn"
=form.submit "sauvegarder", :class => "btn btn-primary btn-ap-add"
.clear
-
diff --git a/app/views/admin/price_line_blocks/_form.html.haml b/app/views/admin/price_line_blocks/_form.html.haml
index 861d505..d069561 100644
--- a/app/views/admin/price_line_blocks/_form.html.haml
+++ b/app/views/admin/price_line_blocks/_form.html.haml
@@ -51,34 +51,24 @@
%br
- %div{:style=>"padding:0 30px;"}
- .row.qi_field_wrapper
- %table{:style => "width:100%;border-collapse:separate;"}
- %thead
- %tr
- %th
- %th Produit
- %th{:style => "width:200px;"} Prix
- %th
- %th{:style => "width:100px;"} Qté
- %th TVA
- %th
- %tbody.price_lines_form
- =f.semantic_fields_for :price_lines do |f|
- =render :partial => "admin/price_lines/form", :locals => {:form => f}
-
- %p{:style=>"padding-top:10px;"}= link_to_add_fields ic("plus-circle") + " ligne", f, :price_lines, {:class => "btn btn-primary p-2", tabindex: 10, style: "position: sticky; top: 100px"}
-
-
-
-
-
-
-
-
-
-
+ -# %div{:style=>"padding:0 30px;"}
+ -# .row.qi_field_wrapper
+ -# %table{:style => "width:100%;border-collapse:separate;"}
+ -# %thead
+ -# %tr
+ -# %th
+ -# %th Produit
+ -# %th{:style => "width:200px;"} Prix
+ -# %th
+ -# %th{:style => "width:100px;"} Qté
+ -# %th TVA
+ -# %th
+ -# %tbody.price_lines_form
+ .qi_row.price_lines_form
+ =f.semantic_fields_for :price_lines do |f|
+ =render :partial => "admin/price_lines/form", :locals => {:form => f}
+ %p{:style=>"padding-left:10px;"}= link_to_add_fields ic("plus-circle") + " Ajouter une ligne", f, :price_lines, {:class => "btn btn-primary p-2 add_lines", tabindex: 10}
-if current_admin.has_permission?("payments")
-if !@p_customer_sheet or (@p_customer_sheet and @p_customer_sheet.state != "commande")
@@ -108,3 +98,12 @@
-if false
.col-6
= f.input :ct_payment_month_end, :label => "Fin de mois ?"
+
+:javascript
+ $('.p_product_ref_select').select2();
+ $('.add_lines').click(function() {
+ $('.p_product_ref_select').last().select2({
+ //theme: "bootstrap"
+ });
+ //$('.p_product_ref_select').last().removeClass('form-control');
+ })
\ No newline at end of file
diff --git a/app/views/admin/price_line_p_articles/_form.html.haml b/app/views/admin/price_line_p_articles/_form.html.haml
index ea396e6..b58b1ec 100644
--- a/app/views/admin/price_line_p_articles/_form.html.haml
+++ b/app/views/admin/price_line_p_articles/_form.html.haml
@@ -1,4 +1,4 @@
-= form.input :p_article_id, as: :select, collection: PArticle.joins(:p_product_ref).where(p_product_ref: price_line.p_product_ref).map{|p_article| [p_article.serialized_name, p_article.id]}, label: "Article(s) associé(s)", input_html: {class:"p_article_select"}
+= form.input :p_article_id, as: :select, collection: PArticle.joins(:p_product_ref).where(p_product_ref: @price_line.p_product_ref).map{|p_article| [p_article.serialized_name, p_article.id]}, label: "Article(s) associé(s)", input_html: {class:"p_article_select"}
:javascript
$('.p_article_select').select2({
diff --git a/app/views/admin/price_lines/_add_price_line_p_article_form.html.haml b/app/views/admin/price_lines/_add_price_line_p_article_form.html.haml
index 8071164..d410809 100644
--- a/app/views/admin/price_lines/_add_price_line_p_article_form.html.haml
+++ b/app/views/admin/price_lines/_add_price_line_p_article_form.html.haml
@@ -3,6 +3,6 @@
=f.inputs do
.price_line_p_articles_form.col-3
= f.semantic_fields_for :price_line_p_articles do |form|
- =render :partial => "admin/price_line_p_articles/form", :locals => {:form => form, price_line: @price_line}
+ = render "admin/price_line_p_articles/form", form: form, price_line: @price_line
%p= link_to_add_fields "Ajouter un article", f, :price_line_p_articles, {:class => "btn btn-primary"} if @price_line.p_articles.count < @price_line.qte
=render :partial => "qi/actions", :locals => {:f => f}
diff --git a/app/views/admin/price_lines/_form.html.haml b/app/views/admin/price_lines/_form.html.haml
index ffc3c7a..e1c9540 100644
--- a/app/views/admin/price_lines/_form.html.haml
+++ b/app/views/admin/price_lines/_form.html.haml
@@ -1,7 +1,4 @@
.row.qi_pannel.qi_plain.padding.price_line_form.col-12.field{:style =>"border-left:4px solid gray;margin-bottom:10px;padding-left:5px;"}
-
-
-
.take.mr-1{:style => "padding-left:10px;", :class => ("error has-error" if form.object.errors[:p_product_ref_id].size > 0 )}
=ic :arrows
.col-3
@@ -42,51 +39,3 @@
%span.destroy{style: "font-size: 2rem;"}=link_to_remove_fields ic(:"trash-o"), form
= qi_js_field(form, :price_line, :tva_account_value, :hidden => true)
= form.hidden_field :position, :class => "price_line_position_input"
-
-:javascript
--# $('.p_product_ref_autocomplete_input').focus()
--# $( function() {
--# $('.p_product_ref_autocomplete_input').autocomplete({
--# source: function( request, response ) {
--# $.ajax( {
--# url: "/admin/p_product_refs/autocomplete.json",
--# dataType: "json",
--# data: {
--# search: request.term,
--# p_customer_id: $(".p_customer_id").val()
--# },
--# success: function(data){
--# arr = jQuery.map( data, function( item ) {
--# return {
--# label: item.member_label,
--# value: item.member_label,
--# id: item.id
--# }
--# });
--# response(arr)
--# }
--# });
--# },
--# minLength: 2,
--# select: function( event, ui ) {
--# $(this).next(".p_product_ref_id").val(ui.item.id)
--# form = $(this).closest(".price_line_form")
--# $.ajax( {
--# url: "/admin/p_product_refs/"+ui.item.id+"/get_infos.json",
--# dataType: "json",
--# data: {
--# type: "price",
--# qte: form.find(".input_price_line_qte").val(),
--# p_customer_id: $(".p_customer_id").val()
--# },
--# success: function (data) {
--# form.find(".input_price_line_price_u_ht").val(data.price);
--# form.find(".input_price_line_tva_account_id").val(data.tva_account_id);
--# form.find(".input_price_line_tva_account_value").val(data.tva_account_value);
--# form.find(".input_price_line_weight_u").val(data.weight);
--# }
--# });
--# //return false
--# }
--# });
--# });
\ No newline at end of file
From 159085c55d24a208824c127999bae67876e50eb6 Mon Sep 17 00:00:00 2001
From: Philippe
Date: Wed, 10 Nov 2021 17:28:49 +0100
Subject: [PATCH 10/12] adding PDF invoice
---
.../(__TEMPLATE__)c | Bin 5965 -> 1374 bytes
.../admin/price_documents_controller.rb | 35 +--
app/models/price_document.rb | 73 +++--
app/views/admin/p_articles/_form.html.haml | 27 +-
.../admin/p_customer_sheets/show.html.haml | 10 +-
.../admin/price_documents/print.html.haml | 270 +++++++++++++-----
.../admin/price_line_blocks/_form.html.haml | 15 +-
.../_form_facture_achat.html.haml | 13 +-
.../price_line_p_articles/_form.html.haml | 6 -
.../price_lines/_add_p_article_form.html.haml | 2 +-
.../_add_price_line_p_article_form.html.haml | 21 +-
pdf.js | 6 +-
pdf3.js | 32 +++
pdf_stamp/cgv.pdf | Bin 0 -> 747033 bytes
pdf_stamp/en-tete.pdf | Bin 400140 -> 0 bytes
pdf_stamp/en-tête.pdf | Bin 0 -> 53244 bytes
16 files changed, 335 insertions(+), 175 deletions(-)
create mode 100644 pdf3.js
create mode 100644 pdf_stamp/cgv.pdf
delete mode 100644 pdf_stamp/en-tete.pdf
create mode 100644 pdf_stamp/en-tête.pdf
diff --git a/.sass-cache/f6b9a0b1905a68d5dbb2139e95d49cba92f6fa93/(__TEMPLATE__)c b/.sass-cache/f6b9a0b1905a68d5dbb2139e95d49cba92f6fa93/(__TEMPLATE__)c
index f14f6942a4eff9a4b9af0c9026e5b8e2e708b671..e1c3ae14c64ffb6b86d264611307231a215c18c3 100644
GIT binary patch
delta 389
zcmX@BcaKZYSkGL~gv-Ft$jCf3HQB=4I4#v6HPtxPBq=#1&D_W+H6It+*WW5_3~Mm3W{MlU*3sGxAOT!WauA
zgP5*QUc@3R#*>m+T#%Dk$!5(NV#V!HmY7qT8qGFYo>zSGdlp?8&b<7*RInVcLw-R?
zW`16AH3QJ(lFEYA$(F48%IwzS`PLGg){^!FD8Pv&LQl7O1)pl>bfAZ0D*AZ;yVV6Ew(F}aIP8t9#DHaRm5D?W#k
v)Lfu%N`SsrfrUpkmx2P+lU5+#SaWgJa&d8iJOy+U+vJbjiacy^Qw>7^kL+bZ
literal 5965
zcmbVQUvt~W5f?Qbii9jtbo9@ZEVHzu*orOEk{sE0Gwmg=JYgnrG#1krJz$RHi9!S7
zPym#pdi>UWh4f?eOSNC2eQb9Re~w2&ij*hfh}*s2?(P0|7yG-1y9d_c!NDQ#?RC4a
z&iLMo?w)8J?Dt;r=l$Nx7hJsT9f~iyqPyR+epiy@-U$ywLOOvEguIh7dMo?l4q0Tq
zbI0um!aFTbZW_4)H&uwm0(d?xwi{~?yRv_2hY^pQFmnDn5@C@Pk2>To^LY@8zKuIW
zNgDBSC&CrINCt$wmct=G5g_69M2Rf0p%`{W5S|t#xj(r%-8V;QNPD@13FViged}
zylZW8SG!*V=pG-6c4KuKH!XMIwd;7oDS{u)99Q7p7GMiU-M;{C^(aR{4=pO4h^Pnx
z=R7?BIP(T94%I6=;NCz;vYs5T{sb4}zhzQk;Hx0AeF-Wy%q_<Nw?l5_F
z7K#WS7ntz+N`%(bOS<8#!_f$_1yI3y8AKvzp&-2*|HO}EgN2FDZ37=&FVlNc>nqaD
zvDG@g-)?;J*tR=I-yMJZW#`DYpA^ACbW4(YjJlm13PJP+aDwKJ%Sg~6E^pK)C+zI1b6Mr)MRR}EnL|f^(xS`RQFKjS@6{!GzeTt3dXzB!B##da$vL>+Qg$D>x=Zh~8r@|8sY@TY!Y6Q!}IKdyCapKFPl4E-urP7$dT74kGjsl?nze$M#k2E9|sWk
zB3j>Rs`~)1UHXE|hnNKs_-+Qwg+P=(Mrin929TE~3@!msD}#+IlER*#lH)-7NF_^j
z2`^(sV|=FIsVmvWR8NBKq!&1Tl+x9=4g@=QOLTi`!=KS|LQbLpqM%H-k)pnM{o<>`
zug0uY>YuPz^fOX%`e2`P=7@kaSYP;o=OhIEWMQ_gNoolT>(b;xX;eu+AHx{ie#?w+
zWEqcV!HqBccAROo$Z#HqV$_%OWSOY|1CRA=m9=q*Z9XNlh7>GW0KecT)8ePxB^Lo#7dHWdWS-qw;QL;9hLYup(v|9#%VEMkot6z
zr&LBiqmRw3TTBBqNrOeers=i(Oq=(
z(!`ldaLQulS6pqSXDW(s(v}H2Pk{z)DtI1O6IS@Ual%4&!k$rX5-hCnbGkvBUG2)C
zFM?-*GdPb_9w03n)~_D;Kh;C&I{ow()IPyK
z^M5f;Sk6u`%}=nf!auSN84WI^xLKI#GDCTs%WAo7rM&U0{l#@WwS1E-)wzabyOCw7
z60SPS5QOT{%+h7pt0i#-l2>Kv{w=aJX(XnzZzXkUl6@<1roKsB?WYKI7*1p#d6aPW
zL|YI>No#Ll=OhJ6`QE2sXD6@-dY9!EN7vJt9z-p=v`Jzflk<)0DU{c5zC_6XQkHe3#{~H
zg?XbPG*d8>*(1*ZZ_Plb0X>m~?%4Qukx3u{_|t7SP#gfhftbnzxM2X)#0CJt*FTEO
z_dqHz|7^wX{2_8&Lf*$X(}eqW>ND=b&|heb5tN9|!Fwl&>N8;dh>ezRO`0gALH^
z5A1k(1(J$^w38A6pX>PYmMm7xYc
z(Uk#Lx`9uJ(5ySUdV(`rg==TAv{%?jothMg4LG`%c^6ktvzy2bhCBs27)%9eFwAZh
zj3czIX0wohVY3ekDTwKexTaOSkq0&>Jg^BiuV(OY^*B8|pAqsDXb+eQG7q%02XMz#
z`H+BNv(GaR=!B@H$k}W~t22XVKb;k!7QiPXWOMi+H~VgO`di`$t6tY1YH(GrH=Fuv
z!Og}65Yi&o3=E+Dqh)=xa=W;jOr!{~*}TOdV;FNivRLcnph4lp@eZA6!c8V33I^p{
zbbGWhhB~%Kj}?-qb!Y^hj14~5;2A3b3ez+fBA}aIRAO|3C};XZv#q3w%DzY>jDiia
NrnY#MHog0u{{w}+6Mp~z
diff --git a/app/controllers/admin/price_documents_controller.rb b/app/controllers/admin/price_documents_controller.rb
index 0446561..4e02801 100644
--- a/app/controllers/admin/price_documents_controller.rb
+++ b/app/controllers/admin/price_documents_controller.rb
@@ -427,38 +427,39 @@ class Admin::PriceDocumentsController < ApplicationController
end
- def print
-
-
-
+ def OLD_print
@price_document = PriceDocument.find_by_token(params[:id])
@element = @price_document.ref_element
doc_number = @price_document.d_number
url = print_admin_price_document_path(:id => @price_document.token, :html => true)
-
-
-
-
params[:inline] = true
if !params[:html] # and !Rails.env.development?
-
@data_to_send = File.open(@price_document.generate_pdf).read
-
-
-
-
-
send_data @data_to_send, :filename =>"#{doc_number}.pdf" , :type => 'application/pdf',:disposition => (params[:inline] ? 'inline' : "attachment")
#render :inline => "y"
-
else
render :layout => false
end
-
end
-
+
+
+ def print
+ @price_document = PriceDocument.find_by_token(params[:id])
+ @element = @price_document.ref_element
+
+ doc_number = @price_document.d_number
+ url = print_admin_price_document_path(:id => @price_document.token, :html => true)
+ params[:inline] = true
+ if !params[:html] # and !Rails.env.development?
+ @data_to_send = File.open(@price_document.generate_pdf).read
+ send_data @data_to_send, :filename =>"#{doc_number}.pdf" , :type => 'application/pdf',:disposition => (params[:inline] ? 'inline' : "attachment")
+ #render :inline => "y"
+ else
+ render :layout => false
+ end
+ end
def create_avoir
diff --git a/app/models/price_document.rb b/app/models/price_document.rb
index 9629fe2..d9568c0 100644
--- a/app/models/price_document.rb
+++ b/app/models/price_document.rb
@@ -585,50 +585,79 @@ class PriceDocument < ApplicationRecord
end
- def generate_pdf
-
-
-
-
+ def OLD_generate_pdf
doc_number = self.d_number
- url = print_admin_price_document_path(:id => self.token, :html => true)
-
+ url = print_admin_price_document_path(:id => self.token, :html => true) #don't forget to copy line "include Rails.application.routes.url_helpers"
@temp_file = "#{Rails.root}/pdf/price_documents/#{doc_number}_temp.pdf"
@final_file = "#{Rails.root}/pdf/price_documents/#{doc_number}_temp2.pdf"
@final_file2 = "#{Rails.root}/pdf/price_documents/#{doc_number}.pdf"
- url = (Rails.env.development? ? "http://localhost:4000" : "http://mdmb.basiclabs.fr").to_s+url
- puts url
- pdf = ("pdf")
-
+ url = (Rails.env.development? ? "http://localhost:3000" : "http://mdmb.basiclabs.fr").to_s+url
+ pdf = ("pdf2")
node_file = @temp_file
+ puts "NODE IFLEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEE"
+ puts url
+ puts url
+ puts url
+ puts url
+ puts url
+ puts node_file
+ puts "NODE IFLEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEE"
+
+
+
+ system("node #{pdf}.js #{Shellwords.escape(url)} #{Shellwords.escape(@temp_file)}")
+ require 'posix/spawn'
+
+ ::POSIX::Spawn::Child.new 'pdftk', @temp_file, 'stamp', "#{Rails.root}/pdf_stamp/en-tete.pdf", 'output', @final_file
+ ::POSIX::Spawn::Child.new 'pdftk', @final_file,"#{Rails.root}/pdf_stamp/cgv.pdf", 'cat', 'output', @final_file2 #AJOUT CGV
+
+ # File.rename(@temp_file, @final_file2) if File.exist?(@temp_file)
+ # File.delete(@temp_file) if File.exist?(@temp_file)
+ # File.delete(@final_file) if File.exist?(@final_file)
+
+ return @final_file
+
+ end
+
+
+ def generate_pdf
+ doc_number = self.d_number
+ url = print_admin_price_document_path(:id => self.token, :html => true) #don't forget to copy line "include Rails.application.routes.url_helpers"
+
+ @temp_file = "#{Rails.root}/pdf/price_documents/#{doc_number}_temp.pdf"
+ @final_file = "#{Rails.root}/pdf/price_documents/#{doc_number}_temp2.pdf"
+ @final_file2 = "#{Rails.root}/pdf/price_documents/#{doc_number}.pdf"
+
+ url = (Rails.env.development? ? "http://localhost:3000" : "http://mdmb.basiclabs.fr").to_s+url
+ pdf = ("pdf")
+ node_file = @temp_file
+
system("node #{pdf}.js #{Shellwords.escape(url)} #{Shellwords.escape(@temp_file)}")
require 'posix/spawn'
-
::POSIX::Spawn::Child.new 'pdftk', @temp_file, 'stamp', "#{Rails.root}/pdf_stamp/en-tete.pdf", 'output', @final_file
-
-
- # ::POSIX::Spawn::Child.new 'pdftk', @final_file,"#{Rails.root}/pdf_stamp/cgv.pdf", 'cat', 'output', @final_file2 #AJOUT CGV
+ # if true
+ if self.label != "Bon de livraison"
+ #::POSIX::Spawn::Child.new 'pdftk', @final_file,"#{Rails.root}/pdf_stamp/cgv.pdf", 'cat', 'output', @final_file2 #AJOUT CGV
+ return @final_file2
+ else
+ return @final_file
+ end
# File.rename(@temp_file, @final_file2)
-
-
#File.delete(@temp_file) if File.exist?(@temp_file)
#File.delete(@final_file) if File.exist?(@final_file)
-
- return @final_file
-
-
-
end
+
+
def create_avoir
past_price_document = self
diff --git a/app/views/admin/p_articles/_form.html.haml b/app/views/admin/p_articles/_form.html.haml
index 6b380c1..36c987f 100644
--- a/app/views/admin/p_articles/_form.html.haml
+++ b/app/views/admin/p_articles/_form.html.haml
@@ -1,20 +1,19 @@
- if params[:controller] == "admin/p_articles"
=semantic_form_for [:admin, @p_article], :remote => true do |f|
- .content
- =f.inputs do
- -if params[:p_product_ref_id]
- = f.input :p_product_ref, as: :select, collection: PProductRef.all.distinct.pluck(:cc_name, :id), :selected => f.object.p_product_ref , :label => f.object.label_for(:p_product_ref)
- -else
- = f.input :p_product_ref, as: :select, collection: PProductRef.all.distinct.pluck(:cc_name, :id), :label => f.object.label_for(:p_product_ref)
- -if PGrade::ACTIVATED
- = f.input :p_grade, as: :select, collection: PGrade.pluck(:grade, :id), :label => "Grade"
- %h4 Numero de série :
- .p_article_serial_nums_form
- = f.semantic_fields_for :p_article_serial_nums do |form|
- =render :partial => "admin/p_article_serial_nums/form", :locals => {:form => form}
- %p= link_to_add_fields "Ajouter un numéro de série", f, :p_article_serial_nums, {:class => "btn btn-primary"}
+ =f.inputs do
+ -if params[:p_product_ref_id]
+ = f.input :p_product_ref, as: :select, collection: PProductRef.all.distinct.pluck(:cc_name, :id), :selected => f.object.p_product_ref , :label => f.object.label_for(:p_product_ref)
+ -else
+ = f.input :p_product_ref, as: :select, collection: PProductRef.all.distinct.pluck(:cc_name, :id), :label => f.object.label_for(:p_product_ref)
+ -if PGrade::ACTIVATED
+ = f.input :p_grade, as: :select, collection: PGrade.pluck(:grade, :id), :label => "Grade"
+ %h4 Numero de série :
+ .p_article_serial_nums_form
+ = f.semantic_fields_for :p_article_serial_nums do |form|
+ =render :partial => "admin/p_article_serial_nums/form", :locals => {:form => form}
+ %p= link_to_add_fields "Ajouter un numéro de série", f, :p_article_serial_nums, {:class => "btn btn-primary"}
- .actions=f.submit "sauvegarder", :class => "btn btn-primary"
+ .actions=f.submit "sauvegarder", :class => "btn btn-primary"
- elsif params[:controller] == "admin/price_lines"
= form.inputs do
-if params[:p_product_ref_id]
diff --git a/app/views/admin/p_customer_sheets/show.html.haml b/app/views/admin/p_customer_sheets/show.html.haml
index 8bab240..d664b6d 100644
--- a/app/views/admin/p_customer_sheets/show.html.haml
+++ b/app/views/admin/p_customer_sheets/show.html.haml
@@ -16,14 +16,11 @@
.qi_row
- .qi_pannel.qi_plain.padding
-
-
-
+ .qi_pannel.qi_plain.padding
-if @bon_de_commande = @p_customer_sheet.price_documents.where(:cc_label => "Bon de commande").first
-price_line_block = @bon_de_commande.price_line_block
%h3
- Contenu du bon de commande
+ Contenu du bon de commande
=@bon_de_commande.d_number
=":"
-else
@@ -108,4 +105,5 @@
:javascript
- $('.p_articles_lines').hide();
\ No newline at end of file
+ $('.p_articles_lines').hide();
+
\ No newline at end of file
diff --git a/app/views/admin/price_documents/print.html.haml b/app/views/admin/price_documents/print.html.haml
index af7294a..349e5fc 100644
--- a/app/views/admin/price_documents/print.html.haml
+++ b/app/views/admin/price_documents/print.html.haml
@@ -1,99 +1,213 @@
%head
- :scss
- body{
- font-size:10px;
- font-family:arial, sans-serif;
-
- .table{
- border-collapse:collapse;
- font-size:10px;
- font-family:arial, sans-serif;
-
- td,th{
- border:1px solid gray;
- }
- }
-
- .table{
- td{
- padding:2px 5px;
- }
- }
- }
-
-
- .clear{
- clear:both;
- }
-
- .table{
- width:100%;
- }
-
- td.numeraire{
- white-space: nowrap;
- text-align:right;
- }
-
-
+:css
+ html {
+ -webkit-print-color-adjust: exact;
+ }
+
+ body{
+ font-family:arial, sans-serif;
+ }
+
+ .font-13px {
+ font-size: 13px;
+ }
+
+ .bordered {
+ border: 1px solid black;
+ border-collapse: collapse;
+ }
+
+ .line-height-100 {
+ text-align: center;
+ height: 100px;
+ }
+
+ .line-height-20 {
+ text-align: center;
+ height: 20px;
+ }
+
+ .border-left {
+ border-left: 1px solid;
+ }
+
+ .border-top {
+ border-top: 1px solid;
+ }
+
+ .border-right {
+ border-right: 1px solid;
+ }
+
+ .border-bottom {
+ border-bottom: 1px solid;
+ }
+
+ .bg-grey {
+ background-color: rgb(239, 239, 239)
+ }
+
+ table, tbody {
+ font-size: 13px;
+ }
+
+
+
+
+
+
+
-price_line_block = @price_document.price_line_block
%body
+
+ -if @price_document.label == "Bon de livraison"
+ -@bl = true
+ -particular_doc = price_line_block.particular_send
+
+
+ -else
+ -particular_doc = price_line_block.particular_bill
-
- %div{:style => "float:right;margin-top:4cm;font-size:13px;margin-bottom:0.5cm;padding-right:2cm;"}
-
- -if @price_document.label == "Bon de livraison"
- -@bl = true
- -particular_doc = price_line_block.particular_send
-
-
- -else
- -particular_doc = price_line_block.particular_bill
-
-
- -if particular_doc.organisation?
- %strong=particular_doc.organisation
- -if particular_doc.com_name?
- %br
- =particular_doc.com_name
-
+
+ -if particular_doc.organisation?
+ %strong=particular_doc.organisation
+ -if particular_doc.com_name?
%br
- -if particular_doc.firstname? or particular_doc.name?
- =particular_doc.civilite
-
- =particular_doc.firstname
+ =particular_doc.com_name
+
+ %br
+ -if particular_doc.firstname? or particular_doc.name?
+ =particular_doc.civilite
+
+ =particular_doc.firstname
- =particular_doc.name
- %br
-
- =particular_doc.address_2
-
- -if particular_doc.address_3?
- %br
- =particular_doc.address_3
+ =particular_doc.name
%br
- =particular_doc.cp
- =particular_doc.city
+ =particular_doc.address_2
+
+ -if particular_doc.address_3?
%br
- =particular_doc.country
+ =particular_doc.address_3
+ %br
+ =particular_doc.cp
+
+ =particular_doc.city
+ %br
+ =particular_doc.country
- #top_left{:style => "width:230px;text-align:center;"}
- =image_tag "https://mdmb.basiclabs.fr/logo-mdmb.png", :style => "width:100px;display:block;margin:auto;"
- .address
- %strong MAISON DES METIERS DE BOUCHE
- %br
- 20 chemin des Posés
- %br
- 74330 POISY
+
+ %table
+ %thead
+ %tr
+ %th{:style => "width: 25%"}
+ %th{:style => "width: 75%"}
+ %tbody
+ %tr
+ %td
+ =image_tag "", :style => "width:200px;display:block;margin:auto;"
+ %td{:style => "padding-left: 35px"}
+ %strong{style: "font-size: 20px;"} S.A.S PRESTAPHONE
+ %p{style: "line-height: 3px;"} PONT DE BEAUVOISIN
+ %p{style: "line-height: 3px;"} Avenue Jean Jaures 73330 PONT DE BEAUVOISIN
+ %p{style: "line-height: 3px;"} 74330 POISY
+ %p{style: "line-height: 20px;"} TEL :0981251293
+
+
+ %table
+ %thead
+ %tr
+ %th{:style => "width: 15%"}
+ %th{:style => "width: 50%"}
+ %th{:style => "width: 25%"}
+ %tbody
+ %tr
+ %td
+ %td
+ %td
+ %strong{style: "line-height: 70px;"}
+ FACTURE
+ =@price_document.d_number
+ %tr
+ %td{style: "line-height: 3px;"} Date :
+ %td{style: "line-height: 3px;"}
+ =l @price_document.date, :format => :date
+ %td
+ %p{style: "line-height: 3px;"} Josef Falser
+ %p{style: "line-height: 3px;"} zona produttiva Bodner 2
+ %p{style: "line-height: 3px;"} 39053 Prato Isarco, IT
+
+
+ %table{style: "margin-top: 40px"}
+ %thead
+ %tr
+ %th.border-left.border-top{:style => "width: 5%"}
+ %th.border-left.border-top{:style => "width: 20%"} DESIGNATION
+ %th.border-left.border-top{:style => "width: 45%"} DESCRIPTION
+ %th.border-left.border-top{:style => "width: 15%"} PRIX UNITAIRE
+ %th.border-left.border-top.border-right{:style => "width: 15%"} TOTAL
+ %tbody
+ %tr.line-height-100
+ %td.border-left.border-top 1
+ %td.border-left.border-top SMARTPHONE RECONDITIONNE
+ %td.border-left.border-top Samsung Galaxy Xcover 4 | SIM unique | schwarz
+ %td.border-left.border-top 147,00 €
+ %td.border-left.border-top.border-right 147,00 €
+ %tr.line-height-100
+ %td.border-left.border-top
+ %td.border-left.border-top
+ %td.border-left.border-top IMEI : Non renseigne
+ %td.border-left.border-top
+ %td.border-left.border-top.border-right
+ %tr.line-height-20
+ %td.border-top
+ %td.border-top
+ %td.border-top
+ %td.border-left.border-top Total HT
+ %td.border-top.border-left.border-right.bg-grey
+ %strong 147,00 €
+ %tr.line-height-20
+ %td
+ %td
+ %td
+ %td.border-left Taux T.V.A.
+ %td.border-left.border-right.bg-grey
+ %strong TVA/MARGE
+ %tr.line-height-20
+ %td
+ %td
+ %td
+ %td.border-left.border-bottom
+ %strong Total TTC
+ %td.border-left.border-right.border-bottom.bg-grey
+ %strong 147,00 €
+
.clear
+ %br
+ %br
+ %br
+ %br
+ %br
+ %br
+ %br
+ %br
+ %br
+ %br
+ %br
+ %br
+ %br
+ %br
+ %br
+ %br
+ %br
+ %br
diff --git a/app/views/admin/price_line_blocks/_form.html.haml b/app/views/admin/price_line_blocks/_form.html.haml
index d069561..62518b3 100644
--- a/app/views/admin/price_line_blocks/_form.html.haml
+++ b/app/views/admin/price_line_blocks/_form.html.haml
@@ -32,14 +32,6 @@
=render :partial => "admin/particulars/form", :locals => {:form => form_particular_bill}
=form_particular_bill.hidden_field :owner_id
=form_particular_bill.hidden_field :owner_type
-
-
-
-
-
-
-
-
-if current_admin.has_permission?("customer-sheets-bl")
=# f.input :bl_comment, :label => "Commentaire à mettre sur le BL :", :input_html => {:style => "min-height:50px;height:50px;"}
@@ -102,8 +94,5 @@
:javascript
$('.p_product_ref_select').select2();
$('.add_lines').click(function() {
- $('.p_product_ref_select').last().select2({
- //theme: "bootstrap"
- });
- //$('.p_product_ref_select').last().removeClass('form-control');
- })
\ No newline at end of file
+ $('.p_product_ref_select').last().select2(});
+ });
\ No newline at end of file
diff --git a/app/views/admin/price_line_blocks/_form_facture_achat.html.haml b/app/views/admin/price_line_blocks/_form_facture_achat.html.haml
index d71d68c..71a8487 100644
--- a/app/views/admin/price_line_blocks/_form_facture_achat.html.haml
+++ b/app/views/admin/price_line_blocks/_form_facture_achat.html.haml
@@ -61,8 +61,9 @@
.price_lines_form
=f.semantic_fields_for :price_lines do |f|
- =render :partial => "admin/price_lines/form_bon_de_reception_achat", :locals => {:form => f}
-
+ -# =render :partial => "admin/price_lines/form_bon_de_reception_achat", :locals => {:form => f}
+ =render :partial => "admin/price_lines/form", :locals => {:form => f}
+
%p= link_to_add_fields "Ajouter une ligne", f, :price_lines, {:class => "btn btn-primary add_lines"}
@@ -105,9 +106,7 @@
= f.input :ct_payment_month_end, :label => "Fin de mois ?"
:javascript
+ $('.p_product_ref_select').select2();
$('.add_lines').click(function() {
- $('.p_product_ref_select').last().select2({
- //theme: "bootstrap"
- });
- //$('.p_product_ref_select').last().removeClass('form-control');
- })
+ $('.p_product_ref_select').last().select2();
+ });
diff --git a/app/views/admin/price_line_p_articles/_form.html.haml b/app/views/admin/price_line_p_articles/_form.html.haml
index b58b1ec..2dcf600 100644
--- a/app/views/admin/price_line_p_articles/_form.html.haml
+++ b/app/views/admin/price_line_p_articles/_form.html.haml
@@ -1,7 +1 @@
= form.input :p_article_id, as: :select, collection: PArticle.joins(:p_product_ref).where(p_product_ref: @price_line.p_product_ref).map{|p_article| [p_article.serialized_name, p_article.id]}, label: "Article(s) associé(s)", input_html: {class:"p_article_select"}
-
-:javascript
- $('.p_article_select').select2({
- //theme: "bootstrap"
- });
- //$('.p_article_select').removeClass('form-control');
diff --git a/app/views/admin/price_lines/_add_p_article_form.html.haml b/app/views/admin/price_lines/_add_p_article_form.html.haml
index 6367aa5..aed4cdb 100644
--- a/app/views/admin/price_lines/_add_p_article_form.html.haml
+++ b/app/views/admin/price_lines/_add_p_article_form.html.haml
@@ -6,4 +6,4 @@
= f.semantic_fields_for :p_articles do |form|
=render :partial => "admin/p_articles/form", :locals => {:form => form, @price_line => f.object}
%p= link_to_add_fields "Ajouter un article", f, :p_articles, {:class => "btn btn-primary"} if f.object.p_articles.count < f.object.qte
- .actions=f.submit "Sauvegarder", :class => "btn btn-primary"
+ =render :partial => "qi/actions", :locals => {:f => f}
diff --git a/app/views/admin/price_lines/_add_price_line_p_article_form.html.haml b/app/views/admin/price_lines/_add_price_line_p_article_form.html.haml
index d410809..95fe240 100644
--- a/app/views/admin/price_lines/_add_price_line_p_article_form.html.haml
+++ b/app/views/admin/price_lines/_add_price_line_p_article_form.html.haml
@@ -1,8 +1,17 @@
.mx-2.my-2
=semantic_form_for [:admin, @price_line], :remote => true do |f|
- =f.inputs do
- .price_line_p_articles_form.col-3
- = f.semantic_fields_for :price_line_p_articles do |form|
- = render "admin/price_line_p_articles/form", form: form, price_line: @price_line
- %p= link_to_add_fields "Ajouter un article", f, :price_line_p_articles, {:class => "btn btn-primary"} if @price_line.p_articles.count < @price_line.qte
- =render :partial => "qi/actions", :locals => {:f => f}
+ .content
+ =f.inputs do
+ .price_line_p_articles_form
+ = f.semantic_fields_for :price_line_p_articles do |form|
+ = render "admin/price_line_p_articles/form", form: form, price_line: @price_line
+ %p= link_to_add_fields "Ajouter un article", f, :price_line_p_articles, {:class => "btn btn-primary add_price_line_p_article"} if @price_line.p_articles.count < @price_line.qte
+ =render :partial => "qi/actions", :locals => {:f => f}
+
+
+
+:javascript
+ $('.p_article_select').select2();
+ $('.add_price_line_p_article').click(function() {
+ $('.p_article_select').last().select2();
+ });
diff --git a/pdf.js b/pdf.js
index 9ecda95..3e5666b 100644
--- a/pdf.js
+++ b/pdf.js
@@ -8,16 +8,12 @@ const createPdf = async() => {
browser = await puppeteer.launch({args: ['--no-sandbox', '--disable-setuid-sandbox']});
const page = await browser.newPage();
//await page.setViewport({width: 794, height: 1122, deviceScaleFactor: 1});
- await page._emulationManager._client.send(
- 'Emulation.setDefaultBackgroundColorOverride',
- { color: { r: 0, g: 0, b: 0, a: 0 } }
- );
await page.goto(process.argv[2], {timeout: 3000, waitUntil: 'networkidle2'});
await page.waitFor(250);
await page.pdf({
path: process.argv[3],
format: 'A4',
- margin: { top: "0cm", right: "0cm", bottom: "0cm", left: "0cm" },
+ margin: { top: "0.5cm", right: "1cm", bottom: "4.2cm", left: "1cm" },
printBackground: false
});
} catch (err) {
diff --git a/pdf3.js b/pdf3.js
new file mode 100644
index 0000000..9ecda95
--- /dev/null
+++ b/pdf3.js
@@ -0,0 +1,32 @@
+'use strict';
+
+const puppeteer = require('puppeteer');
+
+const createPdf = async() => {
+ let browser;
+ try {
+ browser = await puppeteer.launch({args: ['--no-sandbox', '--disable-setuid-sandbox']});
+ const page = await browser.newPage();
+ //await page.setViewport({width: 794, height: 1122, deviceScaleFactor: 1});
+ await page._emulationManager._client.send(
+ 'Emulation.setDefaultBackgroundColorOverride',
+ { color: { r: 0, g: 0, b: 0, a: 0 } }
+ );
+ await page.goto(process.argv[2], {timeout: 3000, waitUntil: 'networkidle2'});
+ await page.waitFor(250);
+ await page.pdf({
+ path: process.argv[3],
+ format: 'A4',
+ margin: { top: "0cm", right: "0cm", bottom: "0cm", left: "0cm" },
+ printBackground: false
+ });
+ } catch (err) {
+ console.log(err.message);
+ } finally {
+ if (browser) {
+ browser.close();
+ }
+ process.exit();
+ }
+};
+createPdf();
\ No newline at end of file
diff --git a/pdf_stamp/cgv.pdf b/pdf_stamp/cgv.pdf
new file mode 100644
index 0000000000000000000000000000000000000000..09b6619a796badbf9e05420463bd5733496cc079
GIT binary patch
literal 747033
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