module Docs
class Angular < UrlScraper
self.type = 'angular'
self.root_path = 'api/'
self.links = {
home: 'https://angular.io/',
code: 'https://github.com/angular/angular'
}
html_filters.push 'angular/entries', 'angular/clean_html'
options[:skip_patterns] = [/deprecated/, /VERSION-let/]
options[:skip] = %w(
index.html
styleguide.html
quickstart.html
cheatsheet.html
guide/cheatsheet.html
guide/style-guide.html)
options[:replace_paths] = {
'testing/index.html' => 'guide/testing.html',
'guide/glossary.html' => 'glossary.html',
'tutorial' => 'tutorial/',
'api' => 'api/'
}
options[:fix_urls] = -> (url) do
url.sub! %r{\A(https://(?:v2\.)?angular\.io/docs/.+/)index\.html\z}, '\1'
url
end
options[:attribution] = <<-HTML
© 2010–2017 Google, Inc.
Licensed under the Creative Commons Attribution License 4.0.
HTML
stub 'api/' do
base_url = URL.parse(self.base_url)
capybara = load_capybara_selenium
capybara.app_host = base_url.origin
capybara.visit(base_url.path + 'api/')
capybara.execute_script('return document.body.innerHTML')
end
version '4 TypeScript' do
self.release = '4.0.0'
self.base_url = 'https://angular.io/docs/ts/latest/'
end
version '2 TypeScript' do
self.release = '2.4.10'
self.base_url = 'https://v2.angular.io/docs/ts/latest/'
end
private
def parse(response)
response.body.gsub! '', 'live example'
response.body.gsub! '