Sha256: cbe8b78a48a1365600fb793303341e006b7be817af5acf8b138dd78f0c29c9ca

Contents?: true

Size: 1.17 KB

Versions: 2

Compression:

Stored size: 1.17 KB

Contents

class Fixnum

  # Augment Fixnum to calculate column width in a grid-based layout.
  #
  # The grid system splits the terminal width into 12 equal parts, by dividing
  # the available width by 12. If the terminal width is not a multiple of 12,
  # then Grid chooses the maximum value which will fit.
  #
  # Used primarily at interface creation time:
  #
  #   width: 9.columns  # (Terminal width / 12) * 9 characters wide; e.g.
  #                     # Terminal is 92 characters wide, maximum value is
  #                     # therefore 84, meaning a column is 7 characters wide.
  def columns
     Vedeu::Grid.columns(self)
  end
end

module Vedeu
  class Grid

    # @param value [Fixnum]
    # @return []
    def self.columns(value)
      new(value).columns
    end

    # @param value [Fixnum]
    # @return [Grid]
    def initialize(value)
      @value = value
    end

    # @return []
    def columns
      fail OutOfRange, 'Valid range is 1..12.' if out_of_range?

      column * value
    end

    private

    attr_reader :value

    def column
      actual / 12
    end

    def actual
      Terminal.width
    end

    def out_of_range?
      value < 1 || value > 12
    end

  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
vedeu-0.1.17 lib/vedeu/support/grid.rb
vedeu-0.1.16 lib/vedeu/support/grid.rb