瀏覽代碼

3.3 Added page template using Bootstrap container, regions.

Frederic G. MARAND 9 年之前
父節點
當前提交
407709065e
共有 3 個文件被更改,包括 152 次插入1 次删除
  1. 32 1
      dr821.info.yml
  2. 11 0
      dr821.libraries.yml
  3. 109 0
      templates/layout/page.html.twig

+ 32 - 1
dr821.info.yml

@@ -2,6 +2,37 @@ name: DR-821
 type: theme
 description: 'Theme OSInet Formation DR-821'
 core: 8.x
+# Pas de base theme -> stable
 
 libraries:
-  - dr821/bootstrap
+  # Activer l'une des deux versions, pas les deux.
+
+  # Version production, minifiée
+  # - dr821/bootstrap
+
+  # Version développement/déboguage, non minifiée
+  - dr821/bootstrap-dev
+
+regions:
+  header: Header
+  primary_menu: 'Primary menu'
+  secondary_menu: 'Secondary menu'
+  highlighted: Highlighted
+  featured_top: 'Featured top'
+  breadcrumb: Breadcrumb
+  help: Help
+  content: Content
+  sidebar_first: 'Sidebar first'
+  sidebar_second: 'Sidebar second'
+  featured_bottom_first: 'Featured bottom first'
+  featured_bottom_second: 'Featured bottom second'
+  featured_bottom_third: 'Featured bottom third'
+  footer_first: 'Footer first'
+  footer_second: 'Footer second'
+  footer_third: 'Footer third'
+  footer_fourth: 'Footer fourth'
+  legalese_first: 'Legalese first'
+  legalese_second: 'Legalese second'
+
+regions_hidden:
+  - sidebar_second

+ 11 - 0
dr821.libraries.yml

@@ -4,6 +4,17 @@ bootstrap:
       node_modules/bootstrap/dist/css/bootstrap.min.css: {}
     theme:
       node_modules/bootstrap/dist/css/bootstrap-theme.min.css: {}
+  js:
+    node_modules/bootstrap/dist/js/bootstrap.min.js: {}
+    dependencies:
+      - core/jquery
+
+bootstrap-dev:
+  css:
+    layout:
+      node_modules/bootstrap/dist/css/bootstrap.css: {}
+    theme:
+      node_modules/bootstrap/dist/css/bootstrap-theme.css: {}
   js:
     node_modules/bootstrap/dist/js/bootstrap.js: {}
     dependencies:

+ 109 - 0
templates/layout/page.html.twig

@@ -0,0 +1,109 @@
+{#
+/**
+ * @file
+ * Theme override to display a single page.
+ *
+ * The doctype, html, head and body tags are not in this template. Instead they
+ * can be found in the html.html.twig template in this directory.
+ *
+ * Available variables:
+ *
+ * General utility variables:
+ * - base_path: The base URL path of the Drupal installation. Will usually be
+ *   "/" unless you have installed Drupal in a sub-directory.
+ * - is_front: A flag indicating if the current page is the front page.
+ * - logged_in: A flag indicating if the user is registered and signed in.
+ * - is_admin: A flag indicating if the user has permission to access
+ *   administration pages.
+ *
+ * Site identity:
+ * - front_page: The URL of the front page. Use this instead of base_path when
+ *   linking to the front page. This includes the language domain or prefix.
+ *
+ * Page content (in order of occurrence in the default page.html.twig):
+ * - messages: Status and error messages. Should be displayed prominently.
+ * - node: Fully loaded node, if there is an automatically-loaded node
+ *   associated with the page and the node ID is the second argument in the
+ *   page's path (e.g. node/12345 and node/12345/revisions, but not
+ *   comment/reply/12345).
+ *
+ * Regions:
+ * FIXME Update for DR821.
+ * - page.header: Items for the header region.
+ * - page.primary_menu: Items for the primary menu region.
+ * - page.secondary_menu: Items for the secondary menu region.
+ * - page.highlighted: Items for the highlighted content region.
+ * - page.help: Dynamic help text, mostly for admin pages.
+ * - page.content: The main content of the current page.
+ * - page.sidebar_first: Items for the first sidebar.
+ * - page.sidebar_second: Items for the second sidebar.
+ * - page.footer: Items for the footer region.
+ * - page.breadcrumb: Items for the breadcrumb region.
+ *
+ * @see template_preprocess_page()
+ * @see html.html.twig
+ */
+#}
+<div class="layout-container container">
+  <header role="banner">
+    {{ page.header }}
+  </header>
+
+  {{ page.primary_menu }}
+  {{ page.secondary_menu }}
+
+  {{ page.breadcrumb }}
+
+  {{ page.highlighted }}
+
+  {{ page.help }}
+
+  {% if page.featured_top %}
+    <div class="featured-top">
+      <aside class="featured-top__inner section layout-container clearfix" role="complementary">
+        {{ page.featured_top }}
+      </aside>
+    </div>
+  {% endif %}
+
+  <main role="main">
+    <a id="main-content" tabindex="-1"></a>{# link is in html.html.twig #}
+
+    <div class="layout-content">
+      {{ page.content }}
+    </div>{# /.layout-content #}
+
+    {% if page.sidebar_first %}
+      <aside class="layout-sidebar-first" role="complementary">
+        {{ page.sidebar_first }}
+      </aside>
+    {% endif %}
+  </main>
+
+  {% if page.featured_bottom_first or page.featured_bottom_second or page.featured_bottom_third %}
+    <div class="featured-bottom">
+      <aside class="layout-container clearfix" role="complementary">
+        {{ page.featured_bottom_first }}
+        {{ page.featured_bottom_second }}
+        {{ page.featured_bottom_third }}
+      </aside>
+    </div>
+  {% endif %}
+
+  {% if page.footer_first or page.footer_second or page.footer_third or page.footer_fourth %}
+    <footer role="contentinfo">
+      {{ page.footer_first }}
+      {{ page.footer_second }}
+      {{ page.footer_third }}
+      {{ page.footer_fourth }}
+    </footer>
+  {% endif %}
+
+  {%  if page.legalese_first or page_legalese_second %}
+    <footer role="contentinfo">
+      {{ page.legalese_first }}
+      {{ page.legalese_second }}
+    </footer>
+  {% endif %}
+
+</div>{# /.layout-container #}