require 'githubstats' require 'matrix' ## # Graphing tool for creating Github-style contribution charts module GithubChart class << self ## # Helper to create new charts def new(*args) self::Chart.new(*args) end ## # Helper to list supported types def supported @supported ||= [] end ## # Helper to check for type support def supports?(type) supported.include? type.to_sym end protected ## # Add support for a type def add_support(type) @supported ||= [] @supported << type.to_sym end end ## # Color schemes for gradient COLOR_SCHEMES = { default: ['#eeeeee', '#d6e685', '#8cc665', '#44a340', '#1e6823'], halloween: ['#EEEEEE', '#FFEE4A', '#FFC501', '#FE9600', '#03001C'] } ## # Object for parsing and outputing Github stats data class Chart attr_reader :stats attr_accessor :colors ## # Create a new chart object # Passes the username through to GithubStats # Uses colors rather than default, if provided def initialize(params = {}) params = { user: params } unless params.is_a? Hash @stats = params.fetch(:data) { GithubStats.new(params[:user]).data } @colors = params[:colors] || :default @colors = COLOR_SCHEMES[@colors] unless @colors.is_a? Array end private ## # Convert the data into a matrix of weeks # The fill value is used to pad the front and backdd def matrix(fill_value = -1) Matrix[*@stats.pad(fill_value).each_slice(7).to_a.transpose] end end end ## # Add helper methods to Integer class Integer ## # Add ordinalize to simplify converting to spoken string def ordinalize return to_s if self.zero? return "#{self}th" if (11..13).include?(abs % 100) case abs % 10 when 1 then "#{self}st" when 2 then "#{self}nd" when 3 then "#{self}rd" else "#{self}th" end end end require 'githubchart/version' require 'githubchart/svg'