# encoding: utf-8 require "polish_number/version" module PolishNumber HUNDREDS = ['', 'sto ', 'dwieście ', 'trzysta ', 'czterysta ', 'pięćset ', 'sześćset ', 'siedemset ', 'osiemset ', 'dziewięćset '] TENS = ['', 'dziesięć ', 'dwadzieścia ', 'trzydzieści ', 'czterdzieści ', 'pięćdziesiąt ', 'sześćdziesiąt ', 'siedemdziesiąt ', 'osiemdziesiąt ', 'dziewięćdziesiąt '] TEENS = ['', 'jedenaście ', 'dwanaście ', 'trzynaście ', 'czternaście ', 'piętnaście ', 'szesnaście ', 'siedemnaście ', 'osiemnaście ', 'dziewiętnaście '] UNITIES = ['', 'jeden ', 'dwa ', 'trzy ', 'cztery ', 'pięć ', 'sześć ', 'siedem ', 'osiem ', 'dziewięć '] ZERO = 'zero' THOUSANDS = {:one => 'tysiąc', :few => 'tysiące', :many => 'tysięcy'} CURRENCIES = { :PLN => {:one => 'złoty', :few => 'złote', :many => 'złotych'} } def self.translate(number, options={}) if options[:currency] && !CURRENCIES.has_key?(options[:currency]) raise ArgumentError, "unknown :currency option '#{options[:currency].inspect}'. Choose one from: #{CURRENCIES.inspect}" end number = number.to_i unless (0..999999).include? number raise ArgumentError, 'number should be in 0..999999 range' end if number == 0 result = ZERO.dup else formatted_number = sprintf('%06.0f', number) digits = formatted_number.chars.map { |char| char.to_i } result = '' result << process_0_999(digits[0..2]) result << thousands(number/1000, digits[0..2]) result << ' ' result << process_0_999(digits[3..5]) result.strip! end if options[:currency] currency = CURRENCIES[options[:currency]] result << ' ' result << currency[classify(number, digits)] end result end private def self.process_0_999(digits) result = '' result << HUNDREDS[digits[0]] if digits[1] == 1 && digits[2] != 0 result << TEENS[digits[2]] else result << TENS[digits[1]] result << UNITIES[digits[2]] end result end def self.thousands(number, digits) if number == 0 '' else THOUSANDS[classify(number, digits)] end end def self.classify(number, digits) if number == 1 :one # all numbers with 2, 3 or 4 at the end, but not teens elsif digits && (2..4).include?(digits[-1]) && digits[-2] != 1 :few else :many end end end