class Block < ActiveRecord::Base
  # to be able to generate HTML
  include ActionView::Helpers::UrlHelper
  include ActionView::Helpers::TagHelper
  # Block-specific stuff
  include BlockHelper
  delegate :environment, :to => :box, :allow_nil => true
  acts_as_list :scope => :box
  belongs_to :box
  acts_as_having_settings
  named_scope :enabled, :conditions => { :enabled => true }
  # Determines whether a given block must be visible. Optionally a
  # context must be specified. context must be a hash, and
  # may contain the following keys:
  #
  # * :article: the article being viewed currently
  # * :language: in which language the block will be displayed
  def visible?(context = nil)
    if display == 'never'
      return false
    end
    if context
      if language != 'all' && language != context[:locale]
        return false
      end
      if display == 'home_page_only'
        if context[:article]
          return context[:article] == owner.home_page
        else
          return context[:request_path] == '/'
        end
      elsif display == 'except_home_page'
        if context[:article]
          return context[:article] != owner.home_page
        else
          return context[:request_path] != '/' + owner.identifier
        end
      end
    end
    true
  end
  # The condition for displaying a block. It can assume the following values:
  #
  # * 'always': the block is always displayed
  # * 'never': the block is hidden (it does not appear for visitors)
  # * 'home_page_only' the block is displayed only when viewing the
  #   homepage of its owner.
  # * 'except_home_page' the block is displayed only when viewing
  #   the homepage of its owner.
  settings_items :display, :type => :string, :default => 'always'
  # The block can be configured to be displayed in all languages or in just one language. It can assume any locale of the environment:
  #
  # * 'all': the block is always displayed
  settings_items :language, :type => :string, :default => 'all'
  # returns the description of the block, used when the user sees a list of
  # blocks to choose one to include in the design.
  #
  # Must be redefined in subclasses to match the description of each block
  # type. 
  def self.description
    '(dummy)'
  end
  # Returns the content to be used for this block.
  #
  # This method can return several types of objects:
  #
  # * String: if the string starts with http:// or https://, then it is assumed to be address of an IFRAME. Otherwise it's is used as regular HTML.
  # * Hash: the hash is used to build an URL that is used as the address for a IFRAME. 
  # * Proc: the Proc is evaluated in the scope of BoxesHelper. The
  # block can then use render, link_to, etc.
  #
  # The method can also return nil, which means "no content".
  #
  # See BoxesHelper#extract_block_content for implementation details. 
  def content(args={})
    "This is block number %d" % self.id
  end
  # A footer to be appended to the end of the block. Returns nil.
  #
  # Override in your subclasses. You can return the same types supported by
  # #content.
  def footer
    nil
  end
  # Is this block editable? (Default to false)
  def editable?
    true
  end
  # must always return false, except on MainBlock clas.
  def main?
    false
  end
  def owner
    box ? box.owner : nil
  end
  def default_title
    ''
  end
  def title
    if self[:title].blank?
      self.default_title
    else
      self[:title]
    end
  end
  def view_title
    title
  end
  def cacheable?
    true
  end
  alias :active_record_cache_key :cache_key
  def cache_key(language='en')
    active_record_cache_key+'-'+language
  end
  def timeout
    4.hours
  end
  def has_macro?
    false
  end
end