Module: Gluttonberg::Content

Defined in:
lib/gluttonberg/content.rb,
lib/gluttonberg/content/block.rb,
lib/gluttonberg/content/workflow.rb,
lib/gluttonberg/content/clean_html.rb,
lib/gluttonberg/content/versioning.rb,
lib/gluttonberg/content/publishable.rb,
lib/gluttonberg/content/despamilator.rb,
lib/gluttonberg/content/localization.rb,
lib/gluttonberg/content/slug_management.rb,
lib/gluttonberg/content/import_export_csv.rb,
lib/gluttonberg/content/block_localization.rb,
lib/gluttonberg/content/despamilator/filter.rb,
lib/gluttonberg/content/despamilator/subject.rb,
lib/gluttonberg/content/despamilator/version.rb,
lib/gluttonberg/content/despamilator/filter/urls.rb,
lib/gluttonberg/content/despamilator/subject/text.rb,
lib/gluttonberg/content/despamilator/filter/emails.rb,
lib/gluttonberg/content/despamilator/filter/prices.rb,
lib/gluttonberg/content/despamilator/filter/shouting.rb,
lib/gluttonberg/content/despamilator/filter/html_tags.rb,
lib/gluttonberg/content/despamilator/filter/no_vowels.rb,
lib/gluttonberg/content/despamilator/filter/long_words.rb,
lib/gluttonberg/content/despamilator/filter/mixed_case.rb,
lib/gluttonberg/content/despamilator/filter/script_tag.rb,
lib/gluttonberg/content/despamilator/filter/spammy_tlds.rb,
lib/gluttonberg/content/despamilator/filter/naughty_words.rb,
lib/gluttonberg/content/despamilator/filter/ip_address_url.rb,
lib/gluttonberg/content/despamilator/filter/obfuscated_urls.rb,
lib/gluttonberg/content/despamilator/filter/square_brackets.rb,
lib/gluttonberg/content/despamilator/filter/trailing_number.rb,
lib/gluttonberg/content/despamilator/filter/gtubs_test_filter.rb,
lib/gluttonberg/content/despamilator/filter/numbers_and_words.rb,
lib/gluttonberg/content/despamilator/filter/weird_punctuation.rb,
lib/gluttonberg/content/despamilator/filter/unusual_characters.rb,
lib/gluttonberg/content/despamilator/filter/very_long_domain_name.rb

Overview

The content module contains a whole bunch classes and mixins related to the pages, localizations, content models and helpers for rendering content inside of views.

Defined Under Namespace

Modules: Block, BlockLocalization, CleanHtml, DespamilatorFilter, ImportExportCSV, Localization, Publishable, SlugManagement, Versioning, Workflow Classes: Despamilator

Constant Summary collapse

@@content_associations =
nil
@@non_localized_associations =
nil
@@localizations =
{}
@@localization_associations =
nil
@@localization_classes =
nil

Class Method Summary collapse

Class Method Details

.content_associationsObject

Return the collection of content association names.



46
47
48
# File 'lib/gluttonberg/content.rb', line 46

def self.content_associations
  @@content_associations
end

.localization_associationsObject

Returns an array of the localization association names.



63
64
65
# File 'lib/gluttonberg/content.rb', line 63

def self.localization_associations
  @@localization_associations
end

.localizationsObject

Returns a hash of content classes that are localized, keyed to the association name.



58
59
60
# File 'lib/gluttonberg/content.rb', line 58

def self.localizations
  @@localizations
end

.non_localized_associationsObject

For each content class that is registered, a corresponding association is declared against the Page model. We need to keep track of these, which is what this method does. It just returns an array of the association names.



38
39
40
41
42
43
# File 'lib/gluttonberg/content.rb', line 38

def self.non_localized_associations
  @@non_localized_associations ||= begin
    non_localized = Block.classes.select {|c| !c.localized? }
    non_localized.collect {|c| c.association_name }
  end
end

.register_localization(assoc_name, klass) ⇒ Object

If a content class has the is_localized declaration, this method is used to register it so we can keep track of all localized content.



52
53
54
# File 'lib/gluttonberg/content.rb', line 52

def self.register_localization(assoc_name, klass)
  @@localizations[assoc_name] = klass
end

.setupObject

This is called after the application loads so that we can define any extra associations or do house-keeping once everything is required and running



27
28
29
30
31
32
# File 'lib/gluttonberg/content.rb', line 27

def self.setup
  # Store the names of the associations in their own array for convenience
  @@localization_associations = @@localizations.keys
  @@localization_classes = @@localizations.values
  @@content_associations = Block.classes.collect { |k| k.association_name }
end