浏览代码

Add Puppeteer documentation

Jasper van Merle 7 年之前
父节点
当前提交
a6b7bd53c2

+ 5 - 0
assets/javascripts/templates/pages/about_tmpl.coffee

@@ -560,6 +560,11 @@ credits = [
     '1996-2018 The PostgreSQL Global Development Group<br>&copy; 1994 The Regents of the University of California',
     'PostgreSQL',
     'https://www.postgresql.org/about/licence/'
+  ], [
+    'Puppeteer',
+    '2017 Google Inc',
+    'Apache',
+    'https://raw.githubusercontent.com/GoogleChrome/puppeteer/master/LICENSE'
   ], [
     'Pygame',
     'Pygame Developpers',

+ 22 - 0
lib/docs/filters/puppeteer/clean_html.rb

@@ -0,0 +1,22 @@
+module Docs
+  class Puppeteer
+    class CleanHtmlFilter < Filter
+      def call
+        # None of the elements to remove have classes, so the order of the remove calls is trivial
+
+        # Remove links to previous versions of the reference
+        at_css('h5').remove
+
+        # Remove table of contents
+        at_css('h5').remove
+        at_css('ul').remove
+
+        # Make headers bigger by transforming them into a bigger variant
+        css('h3').each {|node| node.name = 'h2'}
+        css('h4').each {|node| node.name = 'h3'}
+
+        doc
+      end
+    end
+  end
+end

+ 41 - 0
lib/docs/filters/puppeteer/entries.rb

@@ -0,0 +1,41 @@
+module Docs
+  class Puppeteer
+    class EntriesFilter < Docs::EntriesFilter
+      # The entire reference is one big page, so get_name and get_type are not necessary
+
+      def additional_entries
+        entries = []
+
+        css('h3').each do |node|
+          name = node.content.split(': ').last
+
+          # Find all sub-items (all h4's between the current h3 and the next)
+          current = node.next
+          while !current.nil? && current.name != 'h3'
+            if current.name == 'h4'
+              current_name = current.content
+
+              # Prepend events with the class name
+              if current_name.start_with?('event: ')
+                current_name = "#{name} event: '#{current_name[/'(.*)'/, 1]}'"
+              end
+
+              # Remove arguments from functions
+              if current_name.include?('(')
+                current_name = current_name.split('(')[0] + '()'
+              end
+
+              entries << [current_name, current['id'], name]
+            end
+
+            current = current.next
+          end
+
+          entries << [name, node['id'], name]
+        end
+
+        entries
+      end
+    end
+  end
+end

+ 18 - 0
lib/docs/scrapers/puppeteer.rb

@@ -0,0 +1,18 @@
+module Docs
+  class Puppeteer < Github
+    self.release = '1.6.2'
+    self.base_url = 'https://github.com/GoogleChrome/puppeteer/blob/v1.6.2/docs/api.md'
+    self.links = {
+      code: 'https://github.com/GoogleChrome/puppeteer'
+    }
+
+    html_filters.push 'puppeteer/entries', 'puppeteer/clean_html'
+
+    options[:container] = '.markdown-body'
+
+    options[:attribution] = <<-HTML
+      &copy; 2017 Google Inc<br>
+      Licensed under the Apache License 2.0.
+    HTML
+  end
+end

二进制
public/icons/docs/puppeteer/16.png


二进制
public/icons/docs/puppeteer/16@2x.png


+ 1 - 0
public/icons/docs/puppeteer/SOURCE

@@ -0,0 +1 @@
+https://github.com/GoogleChromeLabs/pptr.dev/tree/master/src/favicons