diff --git a/.sass-cache/f6b9a0b1905a68d5dbb2139e95d49cba92f6fa93/(__TEMPLATE__)c b/.sass-cache/f6b9a0b1905a68d5dbb2139e95d49cba92f6fa93/(__TEMPLATE__)c index f14f694..e1c3ae1 100644 Binary files a/.sass-cache/f6b9a0b1905a68d5dbb2139e95d49cba92f6fa93/(__TEMPLATE__)c and b/.sass-cache/f6b9a0b1905a68d5dbb2139e95d49cba92f6fa93/(__TEMPLATE__)c differ 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 0000000..09b6619 Binary files /dev/null and b/pdf_stamp/cgv.pdf differ diff --git a/pdf_stamp/en-tete.pdf b/pdf_stamp/en-tete.pdf deleted file mode 100644 index 72480fc..0000000 Binary files a/pdf_stamp/en-tete.pdf and /dev/null differ diff --git a/pdf_stamp/en-tête.pdf b/pdf_stamp/en-tête.pdf new file mode 100644 index 0000000..4f2ae93 Binary files /dev/null and b/pdf_stamp/en-tête.pdf differ