diff --git a/core/modules/system/templates/image.html.twig b/core/modules/system/templates/image.html.twig
new file mode 100644
index 0000000..b6b238a
--- /dev/null
+++ b/core/modules/system/templates/image.html.twig
@@ -0,0 +1,14 @@
+{#
+/**
+ * @file
+ * Default theme implementation of an image.
+ *
+ * Available variables:
+ * - attributes: HTML attributes for the img tag.
+ *
+ * @see template_preprocess_image()
+ *
+ * @ingroup themeable
+ */
+#}
+
diff --git a/core/themes/seven/seven.theme b/core/themes/seven/seven.theme
index 7defd49..ea523ad 100644
--- a/core/themes/seven/seven.theme
+++ b/core/themes/seven/seven.theme
@@ -6,6 +6,8 @@
*/
use Drupal\Core\Template\RenderWrapper;
+use Drupal\Component\Utility\String;
+use Drupal\Component\Utility\Xss;
/**
* Implements hook_library_info().
@@ -57,104 +59,69 @@ function seven_preprocess_page(&$variables) {
}
/**
- * Displays the list of available node types for node creation.
+ * Implements hook_preprocess_HOOK() for list of available node type templates.
*/
-function seven_node_add_list($variables) {
- $content = $variables['content'];
- if ($content) {
- $output = '
';
}
- else {
- $output = '' . t('You have not created any content types yet. Go to the content type creation page to add a new content type.', array('@create-content' => url('admin/structure/types/add'))) . '
';
- }
- return $output;
}
/**
- * Overrides theme_custom_block_add_list().
+ * Implements hook_preprocess_HOOK() for custom block add list templates.
+ *
+ * Add variables for the label and the path separately.
*
- * Displays the list of available custom block types for creation.
+ * Displays the list of available custom block types for creation, adding
+ * separate variables for the label and the path.
*/
-function seven_custom_block_add_list($variables) {
- $output = '';
- if (!empty($variables['types'])) {
- $output = '';
}
- return $output;
}
/**
- * Overrides theme_admin_block_content().
+ * Implements hook_preprocess_HOOK() for block admin page templates.
*
* Uses an unordered list markup in both compact and extended mode.
*/
-function seven_admin_block_content($variables) {
- $content = $variables['content'];
- $output = '';
- if (!empty($content)) {
- $output = system_admin_compact_mode() ? '' : '';
}
- return $output;
}
/**
- * Overrides theme_tablesort_indicator().
+ * Implements hook_preprocess_HOOK() for tablesort indicator templates.
*
* Uses Seven's image versions, so the arrows show up as black and not gray on
* gray.
*/
-function seven_tablesort_indicator($variables) {
- $theme_path = drupal_get_path('theme', 'seven');
-
- if ($variables['style'] == 'asc') {
- $image_uri = $theme_path . '/images/arrow-asc.png';
- $text = t('Sort ascending');
- }
- else {
- $image_uri = $theme_path . '/images/arrow-desc.png';
- $text = t('Sort descending');
- }
-
- $image = array(
- '#theme' => 'image',
- '#uri' => $image_uri,
- '#alt' => $text,
- '#width' => 9,
- '#height' => 5,
- '#title' => $text,
- );
- return drupal_render($image);
+function seven_preprocess_tablesort_indicator(&$variables) {
+ $variables['uri'] = drupal_get_path('theme', 'seven') . '/images/arrow-' . ($variables['style'] == 'asc' ? 'asc' : 'desc') . '.png';
+ $variables['attributes']['src'] = file_create_url($variables['uri']);
}
/**
diff --git a/core/themes/seven/templates/admin-block-content.html.twig b/core/themes/seven/templates/admin-block-content.html.twig
new file mode 100644
index 0000000..f92fa22
--- /dev/null
+++ b/core/themes/seven/templates/admin-block-content.html.twig
@@ -0,0 +1,25 @@
+{#
+/**
+ * @file
+ * Seven's theme implementation for the content of an administrative block.
+ *
+ * Available variables:
+ * - content: List of administrative menu items. Each menu item contains:
+ * - path: Path to the admin section.
+ * - label: Short name of the section.
+ * - description: Description of the administrative menu item.
+ * - attributes: HTML attributes to be added to the element.
+ *
+ * @see template_preprocess_admin_block_content()
+ * @see seven_preprocess_admin_block_content()
+ *
+ * @ingroup themeable
+ */
+#}
+{% if content %}
+
+{% endif %}
diff --git a/core/themes/seven/templates/custom-block-add-list.html.twig b/core/themes/seven/templates/custom-block-add-list.html.twig
new file mode 100644
index 0000000..8e53e5c
--- /dev/null
+++ b/core/themes/seven/templates/custom-block-add-list.html.twig
@@ -0,0 +1,29 @@
+{#
+/**
+ * @file
+ * Overrides custom-block-add-list.html.twig.
+ *
+ * Displays the list of available custom block types for creation.
+ *
+ * Available variables:
+ * - types: A collection of all the available custom block types.
+ * Each type contains:
+ * - type: The custom block type, containing all the items below.
+ * - link: A link to add a block of this type.
+ * - description: A description of this custom block type.
+ * - label: The title of the custom block type.
+ * - path: A path for the link to add a block of this type.
+ *
+ * @see template_preprocess_custom_block_add_list()
+ * @see seven_preprocess_custom_block_add_list()
+ *
+ * @ingroup themeable
+ */
+ #}
+
diff --git a/core/themes/seven/templates/node-add-list.html.twig b/core/themes/seven/templates/node-add-list.html.twig
new file mode 100644
index 0000000..fe1fe1e
--- /dev/null
+++ b/core/themes/seven/templates/node-add-list.html.twig
@@ -0,0 +1,28 @@
+{#
+/**
+ * @file
+ * Seven's theme implementation to list node types available for adding content.
+ *
+ * Available variables:
+ * - types: List of content types. Each content type contains:
+ * - add_link: Link to create a piece of content of this type.
+ * - description: Description of this type of content.
+ *
+ * @see template_preprocess_node_add_list()
+ * @see seven_preprocess_node_add_list()
+ *
+ * @ingroup themeable
+ */
+#}
+{% if content %}
+
+{% else %}
+ {% set add_content_type_url = url('admin/structure/types/add') %}
+ {% trans %}
+ You have not created any content types yet. Go to the content type creation page to add a new content type.
+ {% endtrans %}
+{% endif %}