116 lines
		
	
	
		
			6.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			116 lines
		
	
	
		
			6.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
@extends('user.base')
 | 
						||
 | 
						||
@section('title', $user->display_name . ' (@' . $user->name . ')')
 | 
						||
 | 
						||
@section('sidebar')
 | 
						||
    {{-- TODO: タイムラインとオカズのテンプレを分けたら条件外す --}}
 | 
						||
    @if (Route::currentRouteName() === 'user.profile')
 | 
						||
    @if (!empty($tags) && (!$user->is_protected || $user->isMe()))
 | 
						||
        <div class="card mb-4">
 | 
						||
            <div class="card-header">
 | 
						||
                よく使っているタグ
 | 
						||
            </div>
 | 
						||
            <div class="list-group list-group-flush">
 | 
						||
                @foreach ($tags as $tag)
 | 
						||
                    <a class="list-group-item d-flex justify-content-between align-items-center text-dark" href="{{ route('search', ['q' => $tag->name]) }}">
 | 
						||
                        <div>
 | 
						||
                            <span class="oi oi-tag text-secondary"></span>
 | 
						||
                            {{ $tag->name }}
 | 
						||
                        </div>
 | 
						||
                        <span class="badge badge-secondary badge-pill">{{ $tag->count }}</span>
 | 
						||
                    </a>
 | 
						||
                @endforeach
 | 
						||
            </div>
 | 
						||
        </div>
 | 
						||
    @endif
 | 
						||
    @endif
 | 
						||
@endsection
 | 
						||
 | 
						||
@section('tab-content')
 | 
						||
@if ($user->is_protected && !$user->isMe())
 | 
						||
    <p class="mt-4">
 | 
						||
        <span class="oi oi-lock-locked"></span> このユーザはチェックイン履歴を公開していません。
 | 
						||
    </p>
 | 
						||
@else
 | 
						||
    <ul class="list-group">
 | 
						||
        @forelse ($ejaculations as $ejaculation)
 | 
						||
            <li class="list-group-item border-bottom-only pt-3 pb-3 text-break">
 | 
						||
                <!-- span -->
 | 
						||
                <div>
 | 
						||
                    <h5>{{ $ejaculation->ejaculated_span ?? '精通' }} <a href="{{ route('checkin.show', ['id' => $ejaculation->id]) }}" class="text-muted"><small>{{ $ejaculation->before_date }}{{ !empty($ejaculation->before_date) ? ' ~ ' : '' }}{{ $ejaculation->ejaculated_date->format('Y/m/d H:i') }}</small></a></h5>
 | 
						||
                </div>
 | 
						||
                <!-- tags -->
 | 
						||
                @if ($ejaculation->is_private || $ejaculation->tags->isNotEmpty())
 | 
						||
                    <p class="mb-2">
 | 
						||
                        @if ($ejaculation->is_private)
 | 
						||
                            <span class="badge badge-warning"><span class="oi oi-lock-locked"></span> 非公開</span>
 | 
						||
                        @endif
 | 
						||
                        @foreach ($ejaculation->tags as $tag)
 | 
						||
                            <a class="badge badge-secondary" href="{{ route('search', ['q' => $tag->name]) }}"><span class="oi oi-tag"></span> {{ $tag->name }}</a>
 | 
						||
                        @endforeach
 | 
						||
                    </p>
 | 
						||
                @endif
 | 
						||
                <!-- okazu link -->
 | 
						||
                @if (!empty($ejaculation->link))
 | 
						||
                    <div class="row mx-0">
 | 
						||
                        @component('components.link-card', ['link' => $ejaculation->link, 'is_too_sensitive' => $ejaculation->is_too_sensitive])
 | 
						||
                        @endcomponent
 | 
						||
                        <p class="d-flex align-items-baseline mb-2 col-12 px-0">
 | 
						||
                            <span class="oi oi-link-intact mr-1"></span><a class="overflow-hidden" href="{{ $ejaculation->link }}" target="_blank" rel="noopener">{{ $ejaculation->link }}</a>
 | 
						||
                        </p>
 | 
						||
                    </div>
 | 
						||
                @endif
 | 
						||
                <!-- note -->
 | 
						||
                @if (!empty($ejaculation->note))
 | 
						||
                    <p class="mb-2 text-break">
 | 
						||
                        {!! Formatter::linkify(nl2br(e($ejaculation->note))) !!}
 | 
						||
                    </p>
 | 
						||
                @endif
 | 
						||
                <!-- likes -->
 | 
						||
                @if ($ejaculation->likes_count > 0)
 | 
						||
                    <div class="my-2 py-1 border-top border-bottom d-flex align-items-center">
 | 
						||
                        <div class="ml-2 mr-3 text-secondary flex-shrink-0"><small><strong>{{ $ejaculation->likes_count }}</strong> 件のいいね</small></div>
 | 
						||
                        <div class="like-users flex-grow-1 overflow-hidden">
 | 
						||
                            @foreach ($ejaculation->likes as $like)
 | 
						||
                                @if ($like->user !== null)
 | 
						||
                                    <a href="{{ route('user.profile', ['name' => $like->user->name]) }}"><img src="{{ $like->user->getProfileImageUrl(30) }}" srcset="{{ Formatter::profileImageSrcSet($like->user, 30) }}" width="30" height="30" class="rounded" data-toggle="tooltip" data-placement="bottom" title="{{ $like->user->display_name }}"></a>
 | 
						||
                                @endif
 | 
						||
                            @endforeach
 | 
						||
                        </div>
 | 
						||
                    </div>
 | 
						||
                @endif
 | 
						||
                <!-- actions -->
 | 
						||
                <div class="ejaculation-actions">
 | 
						||
                    <button type="button" class="btn btn-link text-secondary" data-toggle="tooltip" data-placement="bottom" title="同じオカズでチェックイン" data-href="{{ $ejaculation->makeCheckinURL() }}"><span class="oi oi-reload"></span></button>
 | 
						||
                    <button type="button" class="btn btn-link text-secondary like-button" data-toggle="tooltip" data-placement="bottom" data-trigger="hover" title="いいね" data-id="{{ $ejaculation->id }}" data-liked="{{ (bool)$ejaculation->is_liked }}"><span class="oi oi-heart {{ $ejaculation->is_liked ? 'text-danger' : '' }}"></span><span class="like-count">{{ $ejaculation->likes_count ? $ejaculation->likes_count : '' }}</span></button>
 | 
						||
                    @if ($user->isMe())
 | 
						||
                        <button type="button" class="btn btn-link text-secondary" data-toggle="tooltip" data-placement="bottom" title="修正" data-href="{{ route('checkin.edit', ['id' => $ejaculation->id]) }}"><span class="oi oi-pencil"></span></button>
 | 
						||
                        <button type="button" class="btn btn-link text-secondary" data-toggle="tooltip" data-placement="bottom" title="削除" data-target="#deleteCheckinModal" data-id="{{ $ejaculation->id }}" data-date="{{ $ejaculation->ejaculated_date }}"><span class="oi oi-trash"></span></button>
 | 
						||
                    @endif
 | 
						||
                </div>
 | 
						||
            </li>
 | 
						||
        @empty
 | 
						||
            <li class="list-group-item border-bottom-only">
 | 
						||
                <p>まだチェックインしていません。</p>
 | 
						||
            </li>
 | 
						||
        @endforelse
 | 
						||
    </ul>
 | 
						||
    {{ $ejaculations->links(null, ['className' => 'mt-4 justify-content-center']) }}
 | 
						||
@endif
 | 
						||
 | 
						||
@component('components.modal', ['id' => 'deleteCheckinModal'])
 | 
						||
    @slot('title')
 | 
						||
        削除確認
 | 
						||
    @endslot
 | 
						||
    <span class="date-label"></span> のチェックインを削除してもよろしいですか?
 | 
						||
    <form action="{{ route('checkin.destroy', ['id' => '@']) }}" method="post">
 | 
						||
        {{ csrf_field() }}
 | 
						||
        {{ method_field('DELETE') }}
 | 
						||
    </form>
 | 
						||
    @slot('footer')
 | 
						||
        <button type="button" class="btn btn-secondary" data-dismiss="modal">キャンセル</button>
 | 
						||
        <button type="button" class="btn btn-danger">削除</button>
 | 
						||
    @endslot
 | 
						||
@endcomponent
 | 
						||
@endsection
 |