Урок 07. ч4. Интеграция шаблона сайта: интеграция реального шаблона сайта

Править на github


Интеграция шаблона сайта Обжорозаврик

Шаблон сайта можно скачать с github репозитория

Папка с шаблоном сайта

Создайте новую директорию для шаблона сайта local/templates/gluttonous

Описание шаблона сайта description.php

Создайте внутри нее файл с описанием шаблона description.php, добавьте в него следующий контент:

<?php
$arTemplate = [
    'NAME' => 'Шаблон главной страницы - Обжорозаврик',
    'DESCRIPTION' => 'Это шаблон для главной страницы, без боковых колонок',
    'SORT' => 100,
    'TYPE' => '',
];

Шапка шаблона сайта header.php

Создайте в той же директории файл header.php и разместите в него примерно следующий контент:

<?php
if (! defined('B_PROLOG_INCLUDED') || B_PROLOG_INCLUDED !== true) die();

?>
<!DOCTYPE html>
<html lang="ru">

<head>

    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
    <meta name="description" content="">
    <meta name="author" content="Волков Михаил">

    <title>Обжорозаврик - Приюти и покорми динозаврика</title>

    <link rel="apple-touch-icon" sizes="180x180" href="favicon/apple-touch-icon.png">
    <link rel="icon" type="image/png" sizes="32x32" href="favicon/favicon-32x32.png">
    <link rel="icon" type="image/png" sizes="16x16" href="favicon/favicon-16x16.png">

    <link href="vendor/bootstrap/css/bootstrap.min.css" rel="stylesheet">
    <link href="vendor/jquery.fancybox/jquery.fancybox.min.css" rel="stylesheet">
    <link href="vendor/fontawesome-free/css/all.css" rel="stylesheet">
    <link href="css/styles.css" rel="stylesheet">
    
    <script src="vendor/jquery/jquery.min.js"></script>
    <script src="vendor/bootstrap/js/bootstrap.bundle.min.js"></script>
    <script src="vendor/jquery.fancybox/jquery.fancybox.min.js"></script>
    <script src="js/script.js"></script>

</head>

<body>
<div class="main-wrapper" id="app">
    <nav class="navbar fixed-top navbar-expand-lg navbar-dark bg-dark fixed-top">
        <div class="container">
            <a class="navbar-brand" href="index.html">Обжорозаврик <i class="fas fa-dragon"></i></a>
            <button class="navbar-toggler navbar-toggler-right" type="button" data-toggle="collapse" data-target="#navbarResponsive" aria-controls="navbarResponsive" aria-expanded="false" aria-label="Toggle navigation">
                <span class="navbar-toggler-icon"></span>
            </button>
            <div class="collapse navbar-collapse" id="navbarResponsive">
                <ul class="navbar-nav ml-auto">
                    <li class="nav-item">
                        <a class="nav-link" href="dinosaurs.html">Динозавры</a>
                    </li>
                    <li class="nav-item">
                        <a class="nav-link" href="blog.html">Блог</a>
                    </li>
                    <li class="nav-item">
                        <a class="nav-link" href="shelter.html">Приют динозавриков</a>
                    </li>

                    <li class="nav-item">
                        <a class="btn btn-secondary" href="auth.html">Войти</a>
                        <a class="btn btn-outline-secondary" href="register.html">Зарегистрироваться</a>
                    </li>

                    <li class="nav-item dropdown">
                        <a class="avatar-link nav-link dropdown-toggle" href="#" id="navbarDropdownBlog" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
                            <img src="images/avartar-dinosaur-100.png"  class="rounded-circle bg-white avatar-img" alt="Аватар">
                        </a>
                        <div class="dropdown-menu dropdown-menu-right" aria-labelledby="navbarDropdownBlog">
                            <a class="dropdown-item" href="#">Личный кабинет</a>
                            <div class="dropdown-divider"></div>
                            <a class="dropdown-item" href="#">Выйти</a>
                        </div>
                    </li>
                </ul>
            </div>
        </div>
    </nav>

Подвал шаблона сайта footer.php

Создайте в той же директории файл footer.php и разместите в него примерно следующий контент:

<?php
if (! defined('B_PROLOG_INCLUDED') || B_PROLOG_INCLUDED !== true) die();
?>
</div>
<footer class="py-5 bg-dark">
    <div class="container text-center mb-4">
        <div class="row">
            <div class="col-md-4">
                <a href="index.html" class="text-white">На главную</a>
            </div>
            <div class="col-md-4">
                <a href="faq.html" class="text-white">Вопросы и ответы</a>
            </div>
            <div class="col-md-4">
                <a href="catalog.html" class="text-white">Каталог</a>
            </div>
        </div>
    </div>
    <div class="container">
        <p class="m-0 text-center text-white">
            Copyright &copy; Обжорозаврик 2020.
            Создано для проекта <a href="https://bitrixcasts.ru" rel="nofollow" target="_blank">BitrixCasts</a>.
            Автор <a href="https://mvsvolkov.ru" rel="nofollow" target="_blank">Волков Михаил</a> <i class="fas fa-heart text-danger"></i>
        </p>
    </div>
</footer>
</body>

</html>

Стили и скрипты шаблона сайта

Создайте в той же директории файлы styles.css и template_styles.css и в него внесите содержимое файлов bootstrap.css и style.css

Перенесите директории из верстки:

favicon
vendor
js

Подключите стили и скрипты, выведите заголовок страницы админ панель

<?php
if (! defined('B_PROLOG_INCLUDED') || B_PROLOG_INCLUDED !== true) die();

use Bitrix\Main\Page\Asset;

$asset = Asset::getInstance();
$asset->addCss(SITE_TEMPLATE_PATH . '/vendor/jquery.fancybox/jquery.fancybox.css');
$asset->addCss(SITE_TEMPLATE_PATH . '/vendor/fontawesome-free/css/all.css');
$asset->addJs(SITE_TEMPLATE_PATH . '/vendor/jquery/jquery.js');
$asset->addJs(SITE_TEMPLATE_PATH . '/vendor/bootstrap/js/bootstrap.bundle.js');
$asset->addJs(SITE_TEMPLATE_PATH . '/vendor/jquery.fancybox/jquery.fancybox.js');
$asset->addJs(SITE_TEMPLATE_PATH . '/js/script.js');
?>
<!DOCTYPE html>
<html lang="ru">

<head>

    <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
    <?php $APPLICATION->ShowHead()?>

    <title><?php $APPLICATION->ShowTitle()?></title>

    <link rel="apple-touch-icon" sizes="180x180" href="favicon/apple-touch-icon.png">
    <link rel="icon" type="image/png" sizes="32x32" href="favicon/favicon-32x32.png">
    <link rel="icon" type="image/png" sizes="16x16" href="favicon/favicon-16x16.png">
</head>

<body>
<?php $APPLICATION->ShowPanel()?>

Контент индексной страницы

Поменяйте заголовки и на главной странице /index.php:

$APPLICATION->SetPageProperty("title", "Обжорозаврик - Приюти и покорми динозаврика");
$APPLICATION->SetPageProperty("NOT_SHOW_NAV_CHAIN", "Y");
$APPLICATION->SetTitle("Обжорозаврик - Приюти и покорми динозаврика");

Замените текущий контент на html из шаблона, должно получиться примерно так:

<?
require($_SERVER["DOCUMENT_ROOT"]."/bitrix/header.php");
$APPLICATION->SetPageProperty("title", "Обжорозаврик - Приюти и покорми динозаврика");
$APPLICATION->SetPageProperty("NOT_SHOW_NAV_CHAIN", "Y");
$APPLICATION->SetTitle("Обжорозаврик - Приюти и покорми динозаврика");
?>

<section>
    <div id="carouselExampleIndicators" class="carousel slide" data-ride="carousel">
        <ol class="carousel-indicators">
            <li data-target="#carouselExampleIndicators" data-slide-to="0" class="active"></li>
            <li data-target="#carouselExampleIndicators" data-slide-to="1"></li>
            <li data-target="#carouselExampleIndicators" data-slide-to="2"></li>
            <li data-target="#carouselExampleIndicators" data-slide-to="3"></li>
        </ol>
        <div class="carousel-inner" role="listbox">
            <div class="carousel-item active" style="background-image: url('/images/banners/dino_banner_1.jpg')">
                <div class="carousel-caption d-none d-md-block">
                    <h3>Динозавры не игрушки</h3>
                    <hr class="border-light">
                    <div>
                        <p>Эти гигантские животные жили много лет назад. Они были огромные тяжелые и опасные. Их не выводили гулять на поводке, как сейчас. И кормили они себя сами, разрывая все своими острыми зубами. Хорошо, что сейчас они такие лапушки, и прекрасно уживаются дома с нашими котиками <i class="text-danger fas fa-heart"></i></p>

                        <hr class="border-light">
                        <p><a class="btn btn-info" href="dinosaurs.html">Подробнее</a></p>
                    </div>
                </div>
            </div>
            <div class="carousel-item" style="background-image: url('/images/banners/dino_banner_2.jpg')">
                <div class="carousel-caption d-none d-md-block">
                    <h3>Когда у динозаврика режутся зубки</h3>
                    <hr class="border-light">
                    <div>
                        <p>Когда у вашего динозаврика режутся зубки, это очень тяжелый период как для малыша, так и для вас. Убирайте все, что можно грызть. Потому что погрызано будет все. И главное: терпение, терпение и еще раз терпение.</p>

                        <hr class="border-light">
                        <p><a class="btn btn-info" href="blog-post.html">Подробнее</a></p>
                    </div>
                </div>
            </div>
            <div class="carousel-item" style="background-image: url('/images/banners/dino_banner_3.jpg')">
                <div class="carousel-caption d-none d-md-block">
                    <h3>Хорошего динозавра много не бывает</h3>
                    <hr class="border-light">
                    <div>
                        <p>Для тех кто любит малышей покрупнее. Когда динозаврик обнимает тебя, а не ты его. А также любителям одна лапа здесь, другая там. Приходите к нам в приют и выбирайте друга побольше.</p>

                        <hr class="border-light">
                        <p><a class="btn btn-info" href="shelter.html">Подробнее</a></p>
                    </div>
                </div>
            </div>
            <div class="carousel-item" style="background-image: url('/images/banners/dino_banner_4.jpg')">
                <div class="carousel-caption d-none d-md-block">
                    <h3>Хищный или травоядный</h3>
                    <hr class="border-light">
                    <div>
                        <p>Вопрос: какого динозаврика взять хищного или травоядного, - самый острый при выборе своего питомца. Как не ошибиться с выбром и взять подходящего для себя малыша, рассказывают эксперты.</p>

                        <hr class="border-light">
                        <p><a class="btn btn-info" href="blog-post.html">Подробнее</a></p>
                    </div>
                </div>
            </div>
        </div>
        <a class="carousel-control-prev" href="#carouselExampleIndicators" role="button" data-slide="prev">
            <span class="carousel-control-prev-icon" aria-hidden="true"></span>
            <span class="sr-only">Previous</span>
        </a>
        <a class="carousel-control-next" href="#carouselExampleIndicators" role="button" data-slide="next">
            <span class="carousel-control-next-icon" aria-hidden="true"></span>
            <span class="sr-only">Next</span>
        </a>
    </div>
</section>

<div class="container">

    <h1 class="my-4">О динозаврах</h1>


    <div class="row">
        <div class="col-lg-4 col-sm-6 portfolio-item">
            <div class="card h-100">
                <a href="dinosaur-item.html"><img class="card-img-top" src="/images/dinosaurs/tirannozavr.jpg" alt="Тираннозавр"></a>
                <div class="card-body">
                    <h4 class="card-title">
                        <a href="dinosaur-item.html">Тираннозавр</a>
                    </h4>
                    <p class="card-text">Тиранноза́вр — монотипический род плотоядных динозавров из группы целурозавров подотряда теропод, включающий единственный валидный вид — Tyrannosaurus rex.</p>
                </div>
            </div>
        </div>
        <div class="col-lg-4 col-sm-6 portfolio-item">
            <div class="card h-100">
                <a href="dinosaur-item.html"><img class="card-img-top" src="/images/dinosaurs/velociraptor_p.jpg" alt="Велоцираптор"></a>
                <div class="card-body">
                    <h4 class="card-title">
                        <a href="dinosaur-item.html">Велоцираптор</a>
                    </h4>
                    <p class="card-text">Велоцира́птор — род хищных двуногих динозавров из семейства дромеозаврид, подсемейства велоцирапторин. Типовой вид — Velociraptor mongoliensis.</p>
                </div>
            </div>
        </div>
        <div class="col-lg-4 col-sm-6 portfolio-item">
            <div class="card h-100">
                <a href="dinosaur-item.html"><img class="card-img-top" src="/images/dinosaurs/triceratops.jpg" alt="Трицератопс"></a>
                <div class="card-body">
                    <h4 class="card-title">
                        <a href="dinosaur-item.html">Трицератопс</a>
                    </h4>
                    <p class="card-text">Трицера́топс — род растительноядных динозавров из семейства цератопсид, существовали в конце маастрихтского века мелового периода и начале палеоценовой эпохи палеогенового периода.</p>
                </div>
            </div>
        </div>
        <div class="col-lg-4 col-sm-6 portfolio-item">
            <div class="card h-100">
                <a href="dinosaur-item.html"><img class="card-img-top" src="/images/dinosaurs/brontozavr.jpg" alt="Бронтозавр"></a>
                <div class="card-body">
                    <h4 class="card-title">
                        <a href="dinosaur-item.html">Бронтозавр</a>
                    </h4>
                    <p class="card-text">Бронтозавр — род гигантских четвероногих динозавров-завропод, в который включают три вида. Хотя типовой вид, Brontosaurus excelsus, уже давно считается одним из видов близкородственного апатозавра, более поздние исследования показали, что бронтозавр — род, отдельный от Apatosaurus.</p>
                </div>
            </div>
        </div>
        <div class="col-lg-4 col-sm-6 portfolio-item">
            <div class="card h-100">
                <a href="dinosaur-item.html"><img class="card-img-top" src="/images/dinosaurs/pterodaktil.jpg" alt="Птеродактиль"></a>
                <div class="card-body">
                    <h4 class="card-title">
                        <a href="dinosaur-item.html">Птеродактиль</a>
                    </h4>
                    <p class="card-text">Птерода́ктили — род птерозавров, ископаемые остатки которых были обнаружены преимущественно в Зольнхофенских известняках Германии, которые датируются концом юрского периода, 152,1—145 млн лет назад, хотя более фрагментарные ископаемые остатки были найдены в других странах Европы и в Африке.</p>
                </div>
            </div>
        </div>
        <div class="col-lg-4 col-sm-6 portfolio-item">
            <div class="card h-100">
                <a href="dinosaur-item.html"><img class="card-img-top" src="/images/dinosaurs/parazavrolofus.jpg" alt="Паразавролофус"></a>
                <div class="card-body">
                    <h4 class="card-title">
                        <a href="dinosaur-item.html">Паразавролофус</a>
                    </h4>
                    <p class="card-text">Паразауролофы — род динозавров. Обитали в конце мелового периода, около 76—73 млн лет назад на территории Северной Америки. Окаменелости обнаружены в провинции Альберта в Канаде и Нью-Мексико и Юта в США. Впервые описаны в 1923 году Уильямом Парксом. Учёные относят их к утконосым динозаврам.</p>
                </div>
            </div>
        </div>
    </div>

    <div class="row mb-4 justify-content-center">
        <div class="col-md-4">
            <a class="btn btn-lg btn-outline-primary btn-block" href="dinosaurs.html">Все динозавры</a>
        </div>
    </div>

    <hr>

    <div class="row">
        <div class="col-lg-6">
            <h2>Обжорозаврик <i class="fas fa-dragon"></i> - это круто</h2>
            <p>На нашем сайте вы можете:</p>
            <ul>
                <li>
                    <strong>Приютить динозаврика</strong>
                </li>
                <li>Узнать о динозаврах побольше</li>
                <li>Поделится интересным</li>
                <li>Почитать об историях о домашних динозаврах</li>
                <li>Купить своему динозаврику покушать или кроватку</li>
            </ul>
            <p>Польный каталог динозавров. Огромный магазин товаров для динозваров. Дружелюбное сообщество любителей динозавров. И свой приют для динозавров - все это <strong>Обжорозаврик</strong>.</p>
        </div>
        <div class="col-lg-6 text-center">
            <img class="img full-width" src="/images/zavri.jpg" alt="Обжорозаврик" width="300" height="300">
        </div>
    </div>


    <hr>

    <h2>Последнее в блоге</h2>

    <div class="row">
        <div class="col-lg-4 mb-4">
            <div class="card h-100">
                <h4 class="card-header">Хищный или травоядный</h4>
                <div class="card-body">
                    <h6 class="card-subtitle mb-2 text-muted">Мнение эксперта</h6>
                    <p class="card-text">Вопрос: какого динозаврика взять хищного или травоядного - самый острый при выборе своего питомца. Как не ошибиться с выбром и взять подходящего для себя малыша, рассказывают эксперты.</p>
                    <small class="mt-2 text-muted">Опубликовано вчера</small>
                </div>
                <div class="card-footer">
                    <a href="blog-post.html" class="btn btn-primary">Подробнее</a>
                </div>
            </div>
        </div>
        <div class="col-lg-4 mb-4">
            <div class="card h-100">
                <h4 class="card-header">Велоцираптор Веган</h4>
                <div class="card-body">
                    <h6 class="card-subtitle mb-2 text-muted">Разное</h6>
                    <p class="card-text">Всякое бывает. Наш велоцираптор ни в какую не хочет кушать мясо. Ни птицу, ни рыбу, вообще ни кусочка. Любит кашу и брокколи. Мы уже давно смирились с этим, а в этой статье я оставлю несколько советов, что делать в такой ситуации.</p>
                    <small class="mt-2 text-muted">Опубликовано вчера</small>
                </div>
                <div class="card-footer">
                    <a href="blog-post.html" class="btn btn-primary">Подробнее</a>
                </div>
            </div>
        </div>
        <div class="col-lg-4 mb-4">
            <div class="card h-100">
                <h4 class="card-header">Когда у динозаврика режутся зубки</h4>
                <div class="card-body">
                    <h6 class="card-subtitle mb-2 text-muted">Воспитание</h6>
                    <p class="card-text">Когда у вашего динозаврика режутся зубки, это очень тяжелый период как для малыша, так и для вас. Убирайте все, что можно грызть. Потому что погрызано будет все. И главное: терпение, терпение и еще раз терпение.</p>
                    <small class="mt-2 text-muted">Опубликовано вчера</small>
                </div>
                <div class="card-footer">
                    <a href="blog-post.html" class="btn btn-primary">Подробнее</a>
                </div>
            </div>
        </div>
    </div>

    <div class="row mb-4 justify-content-center">
        <div class="col-md-4">
            <a class="btn btn-lg btn-outline-primary btn-block" href="blog.html">Перейти в блог</a>
        </div>
    </div>

</div>

<?require($_SERVER["DOCUMENT_ROOT"]."/bitrix/footer.php");?>

Подключение шаблона сайта

В административном интерфейсе Настройки -> Сайты -> Список сайтов перейдите в редактирование сайта s1

В блоке "Шаблон сайта" добавьте новую запись

Шаблон Тип условия Условие
Шаблон главной страницы - Обжорозаврик Без условия

Теперь можно первый раз взглянуть на результат.

Доработка шаблона сайта

Иконка сайта

Скорректируйте подключение иконок шаблона сайта

<link rel="apple-touch-icon" sizes="180x180" href="<?=SITE_TEMPLATE_PATH?>/favicon/apple-touch-icon.png">
<link rel="icon" type="image/png" sizes="32x32" href="<?=SITE_TEMPLATE_PATH?>/favicon/favicon-32x32.png">
<link rel="icon" type="image/png" sizes="16x16" href="<?=SITE_TEMPLATE_PATH?>/favicon/favicon-16x16.png">

Изображения на сайте

Скопируйте папку images в корень вашего сайта и скорректируйте пути ко всем изображениям

src="image/..."
->
src="/images/..."

Проверьте результат работы


Задать вопрос или оставить комментарий
1

Урок 01. Установка Bitrix

0:06:21
2

Урок 02. Инициализация git репозитория в Bitrix

0:01:21
3

Урок 03. Инспекция админки Bitrix

0:03:38
4

Урок 04. Создание страниц и разделов на сайте

0:03:04
5

Урок 04 ч.2. Создание логической структуры сайта

0:02:29
6

Урок 04 ч.3. Свойства страниц и разделов

0:04:36
7

Урок 05. Конфигурирование Bitrix

0:02:20
8

Урок 06. Куда писать свой код в Bitrix

0:01:38
9

Урок 06 ч.2. Установка composer в Bitrix

0:02:09
10

Урок 06 ч.3. Место для отладки в Bitrix

0:01:45
11

Урок 07. ч1. Интеграция шаблона сайта: Как не надо делать

0:05:31
12

Урок 07. ч2. Интеграция шаблона сайта: создание первого шаблона

0:09:05
13

Урок 07. ч3. Интеграция шаблона сайта: что будем интегрировать

0:03:06
14

Урок 07. ч4. Интеграция шаблона сайта: интеграция реального шаблона сайта

0:06:35
15

Урок 07. ч5. Разбор интеграции шаблона сайта: метод ShowHead

0:01:46
16

Урок 07. ч6. Разбор интеграции шаблона сайта: метод ShowTitle

0:02:35
17

Урок 07. ч7. Разбор интеграции шаблона сайта: проверка на пролог

0:02:19
18

Урок 08. Отложенные функции, ShowHead, ShowTitle, ShowProperty

0:07:28