mirror of
https://github.com/LaCasemate/fab-manager.git
synced 2025-01-11 00:52:29 +01:00
76 lines
2.1 KiB
Ruby
76 lines
2.1 KiB
Ruby
|
# frozen_string_literal: true
|
||
|
|
||
|
# Helpers for excel exports, for use with AXSLX gem
|
||
|
module ExcelHelper
|
||
|
# format the given source data for an Excell cell
|
||
|
def format_xlsx_cell(source_data, data, styles, types, date_format: nil, source_data_type: '')
|
||
|
case source_data_type
|
||
|
when 'date'
|
||
|
data.push Date.strptime(source_data, '%Y-%m-%d')
|
||
|
styles.push date_format
|
||
|
types.push :date
|
||
|
when 'list'
|
||
|
data.push source_data.map { |e| e['name'] }.join(', ')
|
||
|
styles.push nil
|
||
|
types.push :string
|
||
|
when 'number'
|
||
|
data.push source_data
|
||
|
styles.push nil
|
||
|
types.push :float
|
||
|
else
|
||
|
data.push source_data
|
||
|
styles.push nil
|
||
|
types.push :string
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# build a new excel line for a statistic export
|
||
|
def statistics_line(hit, user, type, subtype, date_format)
|
||
|
data = [
|
||
|
Date.strptime(hit['_source']['date'], '%Y-%m-%d'),
|
||
|
user&.profile&.full_name || t('export.deleted_user'),
|
||
|
user&.email || '',
|
||
|
user&.profile&.phone || '',
|
||
|
t("export.#{hit['_source']['gender']}"),
|
||
|
hit['_source']['age'],
|
||
|
subtype.nil? ? '' : subtype.label
|
||
|
]
|
||
|
styles = [date_format, nil, nil, nil, nil, nil, nil]
|
||
|
types = %i[date string string string string integer string]
|
||
|
# do not proceed with the 'stat' field if the type is declared as 'simple'
|
||
|
unless type.simple
|
||
|
data.push hit['_source']['stat']
|
||
|
styles.push nil
|
||
|
types.push :string
|
||
|
end
|
||
|
|
||
|
[data, styles, types]
|
||
|
end
|
||
|
|
||
|
# append a cell containing the CA amount
|
||
|
def add_ca_cell(index, hit, data, styles, types)
|
||
|
return unless index.ca
|
||
|
|
||
|
data.push hit['_source']['ca']
|
||
|
styles.push nil
|
||
|
types.push :float
|
||
|
end
|
||
|
|
||
|
##
|
||
|
# Retrieve an item in the given array of items
|
||
|
# by default, the "id" is expected to match the given parameter but
|
||
|
# this can be overridden by passing a third parameter to specify the
|
||
|
# property to match
|
||
|
##
|
||
|
def get_item(array, id, key = nil)
|
||
|
array.each do |i|
|
||
|
if key.nil?
|
||
|
return i if i.id == id
|
||
|
elsif i[key] == id
|
||
|
return i
|
||
|
end
|
||
|
end
|
||
|
nil
|
||
|
end
|
||
|
end
|