115 lines
3.1 KiB
Ruby
115 lines
3.1 KiB
Ruby
# coding: utf-8
|
|
require 'CSV'
|
|
require 'yaml'
|
|
require 'mysql2'
|
|
|
|
load 'config.rb'
|
|
|
|
db = Mysql2::Client.new(:host => DB_HOST, :username => DB_USER, :database => DB_DB)
|
|
|
|
YAML_BASE = {"author": "Christoffer Müller Madsen", "city": "Aarhus", "from": ["Falstersgade 18, 4. th", "8000 Aarhus C"], 'currency': 'DKK', 'commasep': true, 'lang': 'danish', 'seriffont': 'Linux Libertine', 'sansfont': 'Linux Biolinum', 'fontsize': '10pt', 'geometry': 'a4paper, left=43mm, right=43mm, top=51mm, bottom=17mm', 'closingnote': %Q[Overfør venligst det anførte beløb via MobilePay til følgende telefonnummer i løbet af de næste 14 dage:
|
|
|
|
+45 81 73 02 02
|
|
|
|
På forhånd tak.
|
|
|
|
Med venlig hilsen
|
|
] }
|
|
|
|
PATH_BASE = "./pdf/"
|
|
|
|
|
|
PRODUCTS = Hash.new
|
|
NAMES = Hash.new
|
|
PRICES = Hash.new
|
|
|
|
# Initialize product and member hashses
|
|
db.query("SELECT * FROM products").each do |product|
|
|
PRODUCTS[product['id']] = product['pretty_name']
|
|
PRICES[product['id']] = product['price']
|
|
end
|
|
|
|
db.query("SELECT * FROM members").each do |member|
|
|
NAMES[member['id']] = member['name']
|
|
end
|
|
|
|
|
|
class LogItem
|
|
def initialize(time,person,product,amount: 1)
|
|
@time = time
|
|
@person = person
|
|
@product = product
|
|
@amount = amount
|
|
end
|
|
attr_accessor :time, :person, :product, :amount
|
|
end
|
|
|
|
def read_file(file)
|
|
rows = Array.new
|
|
CSV.foreach(file, col_sep: ';', converters: :float) do |row|
|
|
rows << LogItem.new(row[0],row[1],row[2],amount: row[3])
|
|
end
|
|
rows
|
|
end
|
|
|
|
def read_db(db)
|
|
rows = Array.new
|
|
db.query("SELECT * FROM transactions").each do |row|
|
|
if date_of_prev('monday').to_time < row["time"]
|
|
rows << LogItem.new(row["time"], row["buyer"], row["product"], amount: row["amount"])
|
|
end
|
|
end
|
|
rows
|
|
end
|
|
|
|
def partition_rows(rows)
|
|
skyldnere = Hash.new
|
|
rows.each do |row|
|
|
skyldnere[row.person] = Hash.new unless skyldnere[row.person]
|
|
skyldnere[row.person][row.product] = 0 unless skyldnere[row.person][row.product]
|
|
skyldnere[row.person][row.product] += row.amount
|
|
end
|
|
skyldnere
|
|
end
|
|
|
|
def generate_receipt(skyldnere)
|
|
counter = 0
|
|
skyldnere.each do |person, products|
|
|
counter += 1
|
|
yaml = YAML_BASE.clone
|
|
yaml["to"] = NAMES[person]
|
|
products.each do |product, amount|
|
|
yaml["invoice-nr"] = Time.now.strftime('%Y%W') + "-" + counter.to_s
|
|
yaml["service"] = Array.new unless yaml["service"]
|
|
hash = {description: PRODUCTS[product], price: PRICES[product].to_i*amount, amount: amount}
|
|
yaml["service"] << Hash[hash.map{ |k, v| [k.to_s, v] }]
|
|
end
|
|
output = Hash[yaml.map{ |k, v| [k.to_s, v] }].to_yaml
|
|
output += "---\n"
|
|
file = File.open("./pandoc/details.yml","w")
|
|
file << output
|
|
file.close
|
|
`cd pandoc/; make -B`
|
|
`cp pandoc/output.pdf pdf/#{yaml["invoice-nr"]}.pdf`
|
|
puts "#{person}: #{yaml["invoice-nr"]}.pdf"
|
|
end
|
|
end
|
|
|
|
# Utility
|
|
|
|
def date_of_next(day)
|
|
date = Date.parse(day)
|
|
delta = date > Date.today ? 0 : 7
|
|
date + delta
|
|
end
|
|
|
|
def date_of_prev(day)
|
|
date = Date.parse(day)
|
|
delta = date < Date.today ? 0 : 7
|
|
date - delta
|
|
end
|
|
|
|
#partition = partition_rows(read_file("./log/matkant-#{Time.now.strftime('%Y%W')}.log"))
|
|
partition = partition_rows(read_db(db))
|
|
generate_receipt(partition)
|