LoginSignup
0
0

More than 1 year has passed since last update.

社内サイト構築勉強④(さくらのレンタルサーバ+Laravel):トップページのカスタマイズ

Last updated at Posted at 2023-03-06

前提・概要

プロジェクトは前回記事にて作成したものを想定。

本日の完成形

1.ログアウト機能の実装
2.メニューのカスタマイズ
image.png

1.トップページの差し替え

先日作成したテンプレートをトップ画面にするように変更。
ログインしていない際、ログインが必要にする。

①トップページの変更(welcome.blade.php)

resources -> views -> top.blade.php の内容を
resources -> views -> welcome.blade.php にコピーする。

②ルーティングの設定(web.php)

web.phpにてアクセスされた際の挙動を制御している。
デフォルトではviewをそのままリターンしているが、ログインしている状態であることを確認する。

web.php
// 修正前
// Route::get('/', function () { return view('welcome'); });

// 修正後
Route::get('/', function () { return view('welcome'); })->middleware('auth');

③動作確認

http://localhost:8000 に接続するとログイン画面にリダイレクトすることを確認。
最初にログインしてしまっている場合、http://localhost:8000/home からログアウトする。

2.ログアウト機能実装

このままだとログアウトする場合、homeに遷移しないといけなくなるため、
テンプレートのページのログアウト機能を差し替える。

①homeのログアウトの挙動確認

まず正常にログアウトできるやり方を確認する。
resources -> views -> home.blade.php のログアウト部分を確認する。

すると特にログアウトの記載はなく、@extends('layouts.app')とあるため、
layouts -> app のソースを確認する。

resources -> views -> layouts -> app.blade.php
<div class="dropdown-menu dropdown-menu-end" aria-labelledby="navbarDropdown">
    <a class="dropdown-item" href="{{ route('logout') }}"
       onclick="event.preventDefault();
                     document.getElementById('logout-form').submit();">
        {{ __('Logout') }}
    </a>

    <form id="logout-form" action="{{ route('logout') }}" method="POST" class="d-none">
        @csrf
    </form>
</div>

すると、タグを用いてリンクの形でログアウト処理をしていることが分かる。

②テンプレートのログアウトの挙動確認 & 処理差し替え

次に適用したいテンプレートの処理を確認する。

resources -> views -> welcome.blade.php のログアウト部分を確認すると
モーダルの表示+リンク形式になっていることが確認できる。

resources -> views -> welcome.blade.php
   <!-- Logout Modal-->
    <div class="modal fade" id="logoutModal" tabindex="-1" role="dialog" aria-labelledby="exampleModalLabel" aria-hidden="true">
        // ・・・
            <a class="btn btn-primary" href="login.html">Logout</a>
        // ・・・
    </div>

つまり、単純にリンク部分を差し替える。

resources -> views -> welcome.blade.php
   <!-- Logout Modal-->
    <div class="modal fade" id="logoutModal" tabindex="-1" role="dialog" aria-labelledby="exampleModalLabel" aria-hidden="true">
        // ・・・
            <!--<a class="btn btn-primary" href="login.html">Logout</a> -->
            <a class="btn btn-primary" href="{{ route('logout') }}"
                onclick="event.preventDefault();
                                document.getElementById('logout-form').submit();">
                {{ __('Logout') }}
            </a>
    
            <form id="logout-form" action="{{ route('logout') }}" method="POST" class="d-none">
                @csrf
            </form>
        // ・・・
    </div>

③動作確認

テンプレートページからログアウトを実行すると、ログイン画面へ遷移することを確認する。
image.png

image.png

3.メニュー修正

表示されているメニューを修正する。

①テンプレートのサイドバーの挙動確認

Sidebar で囲まれた部分にリストの形式で設定可能。

resources -> views -> welcome.blade.php
<!-- Sidebar -->
<ul class="navbar-nav bg-gradient-primary sidebar sidebar-dark accordion" id="accordionSidebar">
    ・・・
</ul>
<!-- End of Sidebar -->    

改修は想定によってアレンジする。下記一例。
image.png

上記の画像のソースそのまま。

resources -> views -> welcome.blade.php
        <!-- Sidebar -->
        <ul class="navbar-nav bg-gradient-primary sidebar sidebar-dark accordion" id="accordionSidebar">

            <!-- Sidebar - Brand -->
            <a class="sidebar-brand d-flex align-items-center justify-content-center" href="index.html">
                <div class="sidebar-brand-icon rotate-n-15">
                    <i class="fas fa-laugh-wink"></i>
                </div>
                <div class="sidebar-brand-text mx-3">SB Admin <sup>2</sup></div>
            </a>

            <!-- Divider -->
            <hr class="sidebar-divider">

            <!-- Heading -->
            <div class="sidebar-heading">メイン業務</div>

            <!-- Nav Item - Pages Collapse Menu -->
            <li class="nav-item">
                <a class="nav-link collapsed" href="#" data-toggle="collapse" data-target="#collapseTwo"
                    aria-expanded="true" aria-controls="collapseTwo">
                    <i class="fas fa-fw fa-folder"></i>
                    <span>業務</span>
                </a>
                <div id="collapseTwo" class="collapse" aria-labelledby="headingTwo" data-parent="#accordionSidebar">
                    <div class="bg-white py-2 collapse-inner rounded">
                        <h6 class="collapse-header">sub業務:</h6>
                        <a class="collapse-item" href="buttons.html">業務1</a>
                        <a class="collapse-item" href="cards.html">業務2</a>
                    </div>
                </div>
            </li>

            <!-- Divider -->
            <hr class="sidebar-divider d-none d-md-block">

            <!-- Sidebar Toggler (Sidebar) -->
            <div class="text-center d-none d-md-inline">
                <button class="rounded-circle border-0" id="sidebarToggle"></button>
            </div>
        </ul>
        <!-- End of Sidebar -->

 

つまづいたポイントだけメモ。

  • アイコンはFont Awesomeを利用しているので、必要に応じて変更する。
  • アコーディオン部分は「collapseTwo」の部分をユニークにすること。
0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0