前提・実現したいこと
タスクの状態ラベルの色分けを実装したいのですが、参考サイトのように書いても実装できません。
こちらの記事を参考にしておリます。
開発環境
Laravel 8.4
「未着手」の文字列を表示させたいのに、label-dangerとかえってきてしまう。
##実現したい内容
中の文字も未着手、着手中と表示されるように。
該当のソースコード
Task.php
<?php namespace App\Models; use Carbon\Carbon; use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Database\Eloquent\Model; class Task extends Model { /** * 状態定義 */ const STATUS = [ 1 => [ 'label' => '未着手', 'class' => 'label-danger' ], 2 => [ 'label' => '着手中', 'class' => 'label-info' ], 3 => [ 'label' => '完了', 'class' => '' ], ]; /** * 状態のラベル * @return string */ public function getStatusLabelAttribute() { // 状態値 $status = $this->attributes['status']; // 定義されていなければ空文字を返す if (!isset(self::STATUS[$status])) { return ''; } return self::STATUS[$status]['class']; } /** * 整形した期限日 * @return string */ public function getFormattedDueDateAttribute() { return Carbon::createFromFormat('Y-m-d', $this->attributes['due_date']) ->format('Y/m/d'); } }
index.blade.php
@extends('layout') @section('content') <div class="container"> <div class="row"> <div class="col col-md-4"> <nav class="panel panel-default"> <div class="panel-heading">フォルダ</div> <div class="panel-body"> <a href="{{ route('folders.create') }}" class="btn btn-default btn-block"> フォルダを追加する </a> </div> <div class="list-group"> @foreach($folders as $folder) <a href="{{ route('tasks.index', ['folder' => $folder->id]) }}" class="list-group-item {{ $current_folder_id === $folder->id ? 'active' : '' }}" > {{ $folder->title }} </a> @endforeach </div> </nav> </div> <div class="column col-md-8"> <div class="panel panel-default"> <div class="panel-heading">タスク</div> <div class="panel-body"> <div class="text-right"> <a href="{{ route('tasks.create', ['folder' => $current_folder_id]) }}" class="btn btn-default btn-block"> タスクを追加する </a> </div> </div> <table class="table"> <thead> <tr> <th>タイトル</th> <th>状態</th> <th>期限</th> <th></th> </tr> </thead> <tbody> @foreach($tasks as $task) ーーーーーーーー該当箇所ーーーーーーーーーーーー <tr> <td>{{ $task->title }}</td> <td><span class="label {{ $task->status_class }}">{{ $task->status_label }}</span></td> <td>{{ $task->formatted_due_date }}</td> <td><a href="{{ route('tasks.edit', ['folder' => $task->folder_id, 'task' => $task->id]) }}">編集</a></td> </tr> @endforeach ーーーーーーーー該当箇所ーーーーーーーーーーーー </tbody> </table> </div> </div> </div> </div> @endsection
css
@import url('https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css'); @import url('https://cdnjs.cloudflare.com/ajax/libs/bootflat/2.0.4/css/bootflat.min.css'); body { background-color: #f4f7f8; } .navbar { margin: 2rem 0 2.5rem 0; } .my-navbar { align-items: center; background: #333; display: flex; height: 6rem; justify-content: space-between; padding: 0 2%; margin-bottom: 3rem; } .my-navbar-brand { font-size: 18px; } .my-navbar-brand, .my-navbar-item { color: #8c8c8c; } .my-navbar-brand:hover, a.my-navbar-item:hover { color: #ffffff; } .table td:nth-child(2), .table td:nth-child(3), .table td:nth-child(4) { white-space: nowrap; width: 1px; } .form-control[disabled], .form-control[readonly] { background-color: #fff; }
試したこと
cssで読み込んでいるブートストラップが影響している?
最新のブートストラップのcdnにしてみたがレイアウト崩れる。
よろしくお願いいたします。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
退会済みユーザー
2021/05/24 11:55
2021/05/24 13:09
退会済みユーザー
2021/05/24 13:17