Рельсы Axlsx рендерит условный цвет фона строки - PullRequest
0 голосов
/ 19 января 2020

Я использую axlsx gem для создания листов Excel в Ruby на Rails.

   wb = xlsx_package.workbook

   wb.styles do |s|
       title = s.add_style :b => true, :sz => 10,
           :border => { :style => :thin, :color => "00" },
           :alignment => {
              :horizontal => :center,
              :vertical => :center
           }
       row = s.add_style :b => false,
             :sz => 10,
             :border => { :style => :thin, :color => "00" },
             :alignment => {
                :horizontal => :left,
                :vertical => :center
             }


       wb.add_worksheet(name: "Customer") do |sheet|
       sheet.add_row ['Customer Name', 'Status'] :style => title
       @customers.each do |customer|
          sheet.add_row [customer.name, customer.status] :style => row
       end
   end

как я могу условно изменить цвет фона строки, если в статусе клиента, скажем, = "Поздний платеж"

1 Ответ

0 голосов
/ 19 января 2020

Я не проверял это, но это должно сделать работу.

wb = xlsx_package.workbook

wb.styles do |s|
   title = s.add_style :b => true, :sz => 10,
           :border => { :style => :thin, :color => "00" },
           :alignment => {
             :horizontal => :center,
             :vertical => :center
           }
   row = s.add_style :b => false,
         :sz => 10,
         :border => { :style => :thin, :color => "00" },
         :alignment => {
            :horizontal => :left,
            :vertical => :center
         }

   red_cell_row = s.add_style :b => false,
                  :sz => 10,
                  :border => { :style => :thin, :color => "00" },
                  :alignment => {
                    :horizontal => :left,
                    :vertical => :center
                  },
                  :bg_color => "FF0000", 
                  :fg_color => "000000"

   wb.add_worksheet(name: "Customer") do |sheet|
   sheet.add_row ['Customer Name', 'Status'] :style => title
   @customers.each do |customer|
      if customer.status == "Late Payment"
        sheet.add_row [customer.name, customer.status] :style => red_cell_row
      else
        sheet.add_row [customer.name, customer.status] :style => row
      end
   end
end
...