Update & improve Angular documentation (1.5.3)

Fixes #352.
pull/382/head
Thibaut Courouble 9 years ago
parent f9470dffe9
commit 8d959592b4

@ -278,6 +278,7 @@ class App < Sinatra::Application
get %r{\A/([\w~\.]+)(\-[\w\-]+)?(/.*)?\z} do |doc, type, rest| get %r{\A/([\w~\.]+)(\-[\w\-]+)?(/.*)?\z} do |doc, type, rest|
return redirect "/#{DOC_REDIRECTS[doc]}#{type}#{rest}" if DOC_REDIRECTS.key?(doc) return redirect "/#{DOC_REDIRECTS[doc]}#{type}#{rest}" if DOC_REDIRECTS.key?(doc)
return redirect "/angular/api#{rest}", 301 if doc == 'angular' && rest.start_with?('/ng')
return 404 unless @doc = find_doc(doc) return 404 unless @doc = find_doc(doc)
if rest.nil? if rest.nil?

@ -36,7 +36,9 @@ module Docs
node.before(node.children).remove node.before(node.children).remove
end end
at_css('h1').prepend_child(css('.view-source', '.improve-docs')) if h1 = at_css('h1')
h1.prepend_child(css('.view-source', '.improve-docs'))
end
# Remove root-level <div> # Remove root-level <div>
while div = at_css('h1 + div') while div = at_css('h1 + div')

@ -2,8 +2,8 @@ module Docs
class Angular class Angular
class CleanUrlsFilter < Filter class CleanUrlsFilter < Filter
def call def call
html.gsub! "angularjs.org/#{Angular.release}/docs/partials/api/", "angularjs.org/#{Angular.release}/docs/api/" html.gsub! %r{angularjs\.org/([\d\.]+)/docs/partials/(\w+)/}, 'angularjs.org/\1/docs/\2/'
html.gsub! %r{angularjs.org/#{Angular.release}/docs/api/(.+?)\.html}, "angularjs.org/#{Angular.release}/docs/api/\1" html.gsub! %r{angularjs\.org/([\d\.]+)/docs/(\w+)/(.+?)\.html}, 'angularjs.org/\1/docs/\2/\3'
html html
end end
end end

@ -2,17 +2,27 @@ module Docs
class Angular class Angular
class EntriesFilter < Docs::EntriesFilter class EntriesFilter < Docs::EntriesFilter
def get_name def get_name
name = slug.split('/').last if slug.start_with?('api')
name.remove! %r{\Ang\.} name = URI.unescape(slug).split('/').last
name << " (#{subtype})" if subtype == 'directive' || subtype == 'filter' name.remove! %r{\Ang\.}
name.prepend("#{type}.") unless type.starts_with?('ng ') || name == type name << " (#{subtype})" if subtype == 'directive' || subtype == 'filter'
name name.prepend("#{type}.") unless type.starts_with?('ng ') || name == type
name
elsif slug.start_with?('guide')
name = URI.decode(at_css('.improve-docs')['href'][/message=docs\(guide%2F(.+?)\)/, 1])
name.prepend 'Guide: '
name
end
end end
def get_type def get_type
type = slug.split('/').first if slug.start_with?('api')
type << " #{subtype}s" if type == 'ng' && subtype type = slug.split('/').drop(1).first
type type << " #{subtype}s" if type == 'ng' && subtype
type
elsif slug.start_with?('guide')
'Guide'
end
end end
def subtype def subtype
@ -23,6 +33,7 @@ module Docs
end end
def additional_entries def additional_entries
return [] unless slug.start_with?('api')
entries = [] entries = []
css('ul.defs').each do |list| css('ul.defs').each do |list|
@ -37,10 +48,6 @@ module Docs
entries entries
end end
def include_default_entry?
!at_css('h1 + .definition-table:last-child')
end
end end
end end
end end

@ -5,8 +5,10 @@ module Docs
self.name = 'Angular.js' self.name = 'Angular.js'
self.slug = 'angular' self.slug = 'angular'
self.type = 'angular' self.type = 'angular'
self.release = '1.5.0' self.release = '1.5.3'
self.base_url = "https://code.angularjs.org/#{release}/docs/partials/api/" self.base_url = "https://code.angularjs.org/#{release}/docs/partials/"
self.root_path = 'api.html'
self.initial_paths = %w(guide.html)
html_filters.push 'angular/clean_html', 'angular/entries', 'title' html_filters.push 'angular/clean_html', 'angular/entries', 'title'
text_filters.push 'angular/clean_urls' text_filters.push 'angular/clean_urls'
@ -14,14 +16,25 @@ module Docs
options[:title] = false options[:title] = false
options[:root_title] = 'Angular.js' options[:root_title] = 'Angular.js'
options[:decode_and_clean_paths] = true
options[:fix_urls_before_parse] = ->(str) do
str.gsub!('[', '%5B')
str.gsub!(']', '%5D')
str
end
options[:fix_urls] = ->(url) do options[:fix_urls] = ->(url) do
url.sub! '/partials/api/api/', '/partials/api/' %w(api guide).each do |str|
url.sub! %r{/api/(.+?)/api/}, '/api/' url.sub! "/partials/#{str}/#{str}/", "/partials/#{str}/"
url.sub! %r{/partials/api/(.+?)(?<!\.html)(?:\z|(#.*))}, '/partials/api/\1.html\2' url.sub! %r{/#{str}/img/}, "/img/"
url.sub! %r{/#{str}/(.+?)/#{str}/}, "/#{str}/"
url.sub! %r{/partials/#{str}/(.+?)(?<!\.html)(?:\z|(#.*))}, "/partials/#{str}/\\1.html\\2"
end
url url
end end
options[:skip] = %w(ng.html) options[:only_patterns] = [%r{\Aapi/}, %r{\Aguide/}]
options[:skip] = %w(api/ng.html)
options[:attribution] = <<-HTML options[:attribution] = <<-HTML
&copy; 2010&ndash;2016 Google, Inc.<br> &copy; 2010&ndash;2016 Google, Inc.<br>
@ -31,9 +44,11 @@ module Docs
private private
def root_page_body def root_page_body
require 'capybara' require 'capybara/dsl'
Capybara.current_driver = :selenium Capybara.current_driver = :selenium
Capybara.visit("https://code.angularjs.org/#{self.class.release}/docs/api") Capybara.run_server = false
Capybara.app_host = 'https://code.angularjs.org'
Capybara.visit("/#{self.class.release}/docs/api")
Capybara.find('.side-navigation')['innerHTML'] Capybara.find('.side-navigation')['innerHTML']
end end
end end

Loading…
Cancel
Save