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.3' 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! '