2005-01-15 21:26:54 +01:00
|
|
|
require "cgi"
|
|
|
|
require "page"
|
|
|
|
require "page_set"
|
|
|
|
require "wiki_words"
|
|
|
|
require "zip/zip"
|
|
|
|
|
|
|
|
class Web
|
2005-01-21 23:08:47 +01:00
|
|
|
attr_accessor :name, :address, :password, :markup, :color, :safe_mode, :pages
|
|
|
|
attr_accessor :additional_style, :published, :brackets_only, :count_pages
|
2005-01-15 21:26:54 +01:00
|
|
|
|
|
|
|
def initialize(name, address, password = nil)
|
|
|
|
@name, @address, @password, @safe_mode = name, address, password, false
|
|
|
|
@pages = {}
|
2005-01-21 23:08:47 +01:00
|
|
|
|
|
|
|
# assign default values
|
|
|
|
@color = '008B26'
|
|
|
|
@markup = :textile
|
2005-01-15 21:26:54 +01:00
|
|
|
end
|
|
|
|
|
|
|
|
def add_page(page)
|
|
|
|
@pages[page.name] = page
|
|
|
|
end
|
|
|
|
|
|
|
|
def remove_pages(pages_to_be_removed)
|
|
|
|
pages.delete_if { |page_name, page| pages_to_be_removed.include?(page) }
|
|
|
|
end
|
|
|
|
|
|
|
|
def select(&condition)
|
|
|
|
PageSet.new(self, @pages.values, condition)
|
|
|
|
end
|
|
|
|
|
|
|
|
def revised_on
|
|
|
|
select.most_recent_revision
|
|
|
|
end
|
|
|
|
|
|
|
|
def authors
|
|
|
|
select.authors
|
|
|
|
end
|
|
|
|
|
|
|
|
def categories
|
|
|
|
select.map { |page| page.categories }.flatten.uniq.sort
|
|
|
|
end
|
|
|
|
|
|
|
|
# Create a link for the given page name and link text based
|
|
|
|
# on the render mode in options and whether the page exists
|
|
|
|
# in the this web.
|
|
|
|
def make_link(name, text = nil, options = {})
|
|
|
|
page = pages[name]
|
|
|
|
text = text || WikiWords.separate(name)
|
|
|
|
link = CGI.escape(name)
|
2005-01-22 17:38:33 +01:00
|
|
|
link_type = options[:link_type] || :show
|
|
|
|
|
2005-01-15 21:26:54 +01:00
|
|
|
case options[:mode]
|
2005-01-22 17:38:33 +01:00
|
|
|
when :export
|
|
|
|
if page then "<a class=\"existingWikiWord\" href=\"#{link}.html\">#{text}</a>"
|
|
|
|
else "<span class=\"newWikiWord\">#{text}</span>" end
|
|
|
|
when :publish
|
|
|
|
if page then "<a class=\"existingWikiWord\" href=\"../published/#{link}\">#{text}</a>"
|
|
|
|
else "<span class=\"newWikiWord\">#{text}</span>" end
|
|
|
|
else
|
|
|
|
if page
|
|
|
|
"<a class=\"existingWikiWord\" href=\"../#{link_type}/#{link}\">#{text}</a>"
|
|
|
|
else
|
|
|
|
"<span class=\"newWikiWord\">#{text}<a href=\"../#{link_type}/#{link}\">?</a></span>"
|
|
|
|
end
|
2005-01-15 21:26:54 +01:00
|
|
|
end
|
2005-01-22 17:38:33 +01:00
|
|
|
|
2005-01-15 21:26:54 +01:00
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
# Clears the display cache for all the pages with references to
|
|
|
|
def refresh_pages_with_references(page_name)
|
|
|
|
select.pages_that_reference(page_name).each { |page|
|
|
|
|
page.revisions.each { |revision| revision.clear_display_cache }
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
def refresh_revisions
|
|
|
|
select.each { |page| page.revisions.each { |revision| revision.clear_display_cache } }
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
# Returns an array of all the wiki words in any current revision
|
|
|
|
def wiki_words
|
|
|
|
pages.values.inject([]) { |wiki_words, page| wiki_words << page.wiki_words }.flatten.uniq
|
|
|
|
end
|
|
|
|
|
|
|
|
# Returns an array of all the page names on this web
|
|
|
|
def page_names
|
|
|
|
pages.keys
|
|
|
|
end
|
|
|
|
end
|