require 'vedeu/cursor/cursor' require 'vedeu/models/focus' require 'vedeu/models/geometry' require 'vedeu/models/group' require 'vedeu/models/view/line' require 'vedeu/output/border' require 'vedeu/support/common' module Vedeu module DSL # DSL for creating interfaces. # class Interface include Vedeu::Common include Vedeu::DSL include Vedeu::DSL::Colour include Vedeu::DSL::Style include Vedeu::DSL::Text include Vedeu::DSL::Use # Returns an instance of Vedeu::DSL::Interface. # # @param model [Vedeu::DSL::Interface] # @param client [Object] # @return [Vedeu::DSL::Interface] def initialize(model, client = nil) @model = model @client = client end # Allows the setting of a border for the interface. # # @param block [Proc] # @raise [InvalidSyntax] The required block was not given. # @return [Vedeu::Border] def border(&block) fail InvalidSyntax, 'block not given' unless block_given? border_attrs = attributes.merge!({ enabled: true, name: model.name }) Vedeu::Border.build(border_attrs, &block).store end # Applies the default border to the interface. # # @return [Vedeu::Border] def border! border do # adds default border end end # Set the cursor visibility on an interface. # # @param value [Boolean] Any value other than nil or false will evaluate # to true. # # @example # interface 'my_interface' do # cursor true # => show the cursor for this interface # cursor :show # => both of these are equivalent to line above # cursor! # # # ... # # cursor false # => hide the cursor for this interface # cursor :hide # => both of these are equivalent to line above # cursor nil # # # ... # # view 'my_interface' do # cursor true # # ... # # @return [Cursor] def cursor(value = true) Vedeu::Cursor.new({ name: model.name, state: value }).store end # Set the cursor to visible for the interface. # # @return [Vedeu::Cursor] def cursor! cursor(true) end # To maintain performance interfaces can be delayed from refreshing too # often, the reduces artefacts particularly when resizing the terminal # screen. # # @param value [Fixnum|Float] # # @example # interface 'my_interface' do # delay 0.5 # interface will not update more often than every 500ms. # # ... # # @return [Fixnum|Float] def delay(value) model.delay = value end # Specify this interface as being in focus when the application starts. # # @note If multiple interfaces are defined, and this is included in each, # then the last defined will be the interface in focus. # # @return [String] The name of the interface in focus. def focus! Vedeu::Focus.add(model.name, true) if defined_value?(model.name) end # Define the geometry for an interface. # # @param block [Proc] # # @example # interface 'my_interface' do # geometry do # # ... # # @raise [InvalidSyntax] The required block was not given. # @return [Geometry] # @see Vedeu::DSL::Geometry def geometry(&block) fail InvalidSyntax, 'block not given' unless block_given? Vedeu::Geometry.build({ name: model.name }, &block).store end # Specify a group for an interface. Interfaces of the same group can be # targetted together; for example you may want to refresh multiple # interfaces at once. # # @example # interface 'my_interface' do # group 'main_screen' # # ... # # @param name [String] The name of the group to which this interface # should belong. # @return [String] def group(name) return false unless defined_value?(name) if defined_value?(model.name) if Vedeu.groups.registered?(name) Vedeu.groups.find(name).add(model.name) else new_group = Vedeu::Group.new({ name: name }) new_group.add(model.name) end end model.group = name end # @see Vedeu::DSL::Keymap.keymap def keymap(name = model.name, &block) Vedeu.keymap(name, &block) end alias_method :keys, :keymap # Specify multiple lines in a view. # # @param block [Proc] # # @example # view 'my_interface' do # lines do # # ... see {Vedeu::DSL::Line} and {Vedeu::DSL::Stream} # end # end # # view 'my_interface' do # line do # # ... see {Vedeu::DSL::Line} and {Vedeu::DSL::Stream} # end # end # # @raise [InvalidSyntax] The required block was not given. # @return [Line] def lines(&block) fail InvalidSyntax, 'block not given' unless block_given? model.add(model.member.build(attributes, &block)) end alias_method :line, :lines # The name of the interface. Used to reference the interface throughout # your application's execution lifetime. # # @param value [String] # # @example # interface do # name 'my_interface' # # ... # # @return [String] def name(value) model.name = value end private attr_reader :client, :model # @return [Hash] def attributes { client: client, parent: model, } end end # Interface end # DSL end # Vedeu