module Vedeu module Buffers # Refreshes the given named interface. # class Refresh include Vedeu::Common # @example # Vedeu.trigger(:_refresh_view_, name) # # @param (see #initialize) # @return (see #by_name) def self.by_name(name = Vedeu.focus) name ||= Vedeu.focus new(name).by_name end # @example # Vedeu.trigger(:_refresh_view_content_, name) # # @param (see #initialize) # @return (see #by_name) def self.refresh_content_by_name(name = Vedeu.focus) name ||= Vedeu.focus new(name, content_only: true).by_name end # Return a new instance of Vedeu::Buffers::Refresh. # # @param name [String|Symbol] The name of the interface/view to # be refreshed. Defaults to `Vedeu.focus`. # @param options [Hash Boolean>] # @option options content_only [Boolean] # @return [Vedeu::Buffers::Refresh] def initialize(name, options = {}) @name = present?(name) ? name : Vedeu.focus @options = options end # @return [Array|Vedeu::Error::ModelNotFound] def by_name Vedeu.trigger(:_clear_view_content_, name) buffer.render Vedeu.trigger(:_refresh_border_, name) unless content_only? end protected # @!attribute [r] name # @return [String|Symbol] attr_reader :name # @return [Vedeu::Buffers::Buffer] def buffer Vedeu.buffers.by_name(name) end # @return [Boolean] def content_only? truthy?(options[:content_only]) end # @return [Hash Boolean>] def options defaults.merge!(@options) end # @return [Hash Boolean>] def defaults { content_only: false } end end # Refresh end # Buffers # :nocov: # See {file:docs/events/refresh.md} Vedeu.bind(:_refresh_view_) do |name| Vedeu::Buffers::Refresh.by_name(name) if Vedeu.ready? end # See {file:docs/events/refresh.md} Vedeu.bind(:_refresh_view_content_) do |name| Vedeu::Buffers::Refresh.refresh_content_by_name(name) if Vedeu.ready? end # :nocov: end # Vedeu