2016-02-28 14:41:01 +01:00
|
|
|
!!! 5
|
2017-05-08 10:35:25 +09:00
|
|
|
%html{ lang: I18n.locale }
|
2016-02-22 16:00:20 +01:00
|
|
|
%head
|
2017-05-08 10:35:25 +09:00
|
|
|
%meta{ charset: 'utf-8' }/
|
2018-03-09 00:35:07 +01:00
|
|
|
%meta{ name: 'viewport', content: 'width=device-width, initial-scale=1' }/
|
2018-10-10 01:31:10 +02:00
|
|
|
|
|
|
|
- if cdn_host?
|
|
|
|
%link{ rel: 'dns-prefetch', href: cdn_host }/
|
2020-10-13 01:19:35 +02:00
|
|
|
%meta{ name: 'cdn-host', content: cdn_host }/
|
2018-10-10 01:31:10 +02:00
|
|
|
|
|
|
|
- if storage_host?
|
|
|
|
%link{ rel: 'dns-prefetch', href: storage_host }/
|
|
|
|
|
2022-06-09 22:25:23 +02:00
|
|
|
%link{ rel: 'icon', href: '/favicon.ico', type: 'image/x-icon' }/
|
|
|
|
|
|
|
|
- %w(16 32 48).each do |size|
|
2024-01-17 13:19:51 +01:00
|
|
|
%link{ rel: 'icon', sizes: "#{size}x#{size}", href: frontend_asset_path("icons/favicon-#{size}x#{size}.png"), type: 'image/png' }/
|
2022-06-09 22:25:23 +02:00
|
|
|
|
|
|
|
- %w(57 60 72 76 114 120 144 152 167 180 1024).each do |size|
|
2024-01-17 13:19:51 +01:00
|
|
|
%link{ rel: 'apple-touch-icon', sizes: "#{size}x#{size}", href: frontend_asset_path("icons/apple-touch-icon-#{size}x#{size}.png") }/
|
2022-06-09 22:25:23 +02:00
|
|
|
|
2024-01-17 13:19:51 +01:00
|
|
|
%link{ rel: 'mask-icon', href: frontend_asset_path('images/logo-symbol-icon.svg'), color: '#6364FF' }/
|
2022-06-09 22:25:23 +02:00
|
|
|
%link{ rel: 'manifest', href: manifest_path(format: :json) }/
|
2022-10-23 15:58:24 +02:00
|
|
|
%meta{ name: 'theme-color', content: '#191b22' }/
|
2017-05-08 10:35:25 +09:00
|
|
|
%meta{ name: 'apple-mobile-web-app-capable', content: 'yes' }/
|
2016-11-02 15:18:40 +01:00
|
|
|
|
2023-11-09 08:05:57 -05:00
|
|
|
%title= html_title
|
2016-09-30 00:00:45 +02:00
|
|
|
|
2020-11-06 11:56:31 +01:00
|
|
|
= stylesheet_pack_tag 'common', media: 'all', crossorigin: 'anonymous'
|
|
|
|
= stylesheet_pack_tag current_theme, media: 'all', crossorigin: 'anonymous'
|
2024-01-12 10:32:45 +01:00
|
|
|
-# Needed for the wicg-inert polyfill. It needs to be on it's own <style> tag, with this `id`
|
|
|
|
= stylesheet_pack_tag 'inert', media: 'all', id: 'inert-style'
|
|
|
|
|
2020-11-06 11:56:31 +01:00
|
|
|
= javascript_pack_tag 'common', crossorigin: 'anonymous'
|
2023-07-21 11:14:26 +02:00
|
|
|
= preload_pack_asset "locale/#{I18n.locale}-json.js"
|
2023-04-25 16:51:38 +02:00
|
|
|
= csrf_meta_tags unless skip_csrf_meta_tags?
|
2020-07-07 01:33:38 +02:00
|
|
|
%meta{ name: 'style-nonce', content: request.content_security_policy_nonce }
|
2016-09-30 00:00:45 +02:00
|
|
|
|
2022-10-29 14:04:24 +02:00
|
|
|
= stylesheet_link_tag custom_css_path, skip_pipeline: true, host: root_url, media: 'all'
|
2018-08-24 04:33:27 +02:00
|
|
|
|
2016-02-28 14:41:01 +01:00
|
|
|
= yield :header_tags
|
2016-09-30 00:00:45 +02:00
|
|
|
|
2018-08-25 22:55:25 +02:00
|
|
|
%body{ class: body_classes }
|
2016-03-12 16:09:46 +01:00
|
|
|
= content_for?(:content) ? yield(:content) : yield
|
2019-05-27 03:33:39 +02:00
|
|
|
|
2022-06-10 17:34:59 +02:00
|
|
|
.logo-resources{ 'tabindex' => '-1', 'inert' => true, 'aria-hidden' => true }
|
2022-06-09 22:25:23 +02:00
|
|
|
= render_symbol :icon
|
|
|
|
= render_symbol :wordmark
|