set :product_name, "Vault" set :base_url, "https://www.vaultproject.io/" # Middleware for rendering preact components use ReshapeMiddleware, component_file: "assets/reshape.js" activate :hashicorp do |h| h.name = "vault" h.version = "1.1.1" h.github_slug = "hashicorp/vault" h.website_root = "website" h.releases_enabled = true h.datocms_api_key = '78d2968c99a076419fbb' end # Netlify redirects/headers proxy '_redirects', 'netlify-redirects', ignore: true helpers do # Formats and filters a category of docs for the sidebar component def get_sidebar_data(category) sitemap.resources.select { |resource| !!Regexp.new("^#{category}").match(resource.path) }.map { |resource| { path: resource.path, data: resource.data.to_hash.tap { |a| a.delete 'description'; a } } } end # Returns the FQDN of the image URL. # @param [String] path # @return [String] def image_url(path) File.join(config[:base_url], "/img/#{path}") end # Get the title for the page. # # @param [Middleman::Page] page # # @return [String] def title_for(page) if page && page.data.page_title return "#{page.data.page_title} - Vault by HashiCorp" end "Vault by HashiCorp" end # Get the description for the page # # @param [Middleman::Page] page # # @return [String] def description_for(page) description = (page.data.description || "") .gsub('"', '') .gsub(/\n+/, ' ') .squeeze(' ') return escape_html(description) end # This helps by setting the "active" class for sidebar nav elements # if the YAML frontmatter matches the expected value. def sidebar_current(expected) current = current_page.data.sidebar_current || "" if current.start_with?(expected) return " class=\"active\"" else return "" end end # Returns the id for this page. # @return [String] def body_id_for(page) if !(name = page.data.sidebar_current).blank? return "page-#{name.strip}" end if page.url == "/" || page.url == "/index.html" return "page-home" end if !(title = page.data.page_title).blank? return title .downcase .gsub('"', '') .gsub(/[^\w]+/, '-') .gsub(/_+/, '-') .squeeze('-') .squeeze(' ') end return "" end # Returns the list of classes for this page. # @return [String] def body_classes_for(page) classes = [] if !(layout = page.data.layout).blank? classes << "layout-#{page.data.layout}" end if !(title = page.data.page_title).blank? title = title .downcase .gsub('"', '') .gsub(/[^\w]+/, '-') .gsub(/_+/, '-') .squeeze('-') .squeeze(' ') classes << "page-#{title}" end return classes.join(" ") end end