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/] options[:skip] = %w( index.html styleguide.html quickstart.html guide/cheatsheet.html guide/style-guide.html) options[:replace_paths] = { 'testing/index.html' => 'guide/testing.html', 'guide/glossary.html' => 'glossary.html', 'tutorial' => 'tutorial/' } options[:fix_urls] = -> (url) do url.sub! %r{\A(https://angular\.io/docs/.+/)index\.html\z}, '\1' url end options[:attribution] = <<-HTML © 2010–2016 Google, Inc.
Licensed under the Creative Commons Attribution License 4.0. HTML stub 'api/' do capybara = load_capybara_selenium capybara.app_host = 'https://angular.io' capybara.visit(URL.parse(self.base_url).path + 'api/') capybara.execute_script('return document.body.innerHTML') end version '2 TypeScript' do self.release = '2.1.2' self.base_url = 'https://angular.io/docs/ts/latest/' end version '2 Dart' do self.release = '2.1.2' self.base_url = 'https://angular.io/docs/dart/latest/' options[:skip_patterns] += [/angular2\.compiler/] options[:skip_link] = ->(link) do link.parent['class'].try(:include?, 'inherited') || link.parent.parent['class'].try(:include?, 'inherited') end end private def parse(string) string.gsub! '', 'live example' string.gsub! '