142 lines
		
	
	
		
			7.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			142 lines
		
	
	
		
			7.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
@extends('layouts.base')
 | 
						|
 | 
						|
@push('head')
 | 
						|
@endpush
 | 
						|
 | 
						|
@section('content')
 | 
						|
<div class="container">
 | 
						|
    <div class="row">
 | 
						|
        <div class="col-lg-4">
 | 
						|
            <div class="card mb-4">
 | 
						|
                <div class="card-body">
 | 
						|
                    <div class="d-flex flex-row align-items-end mb-4">
 | 
						|
                        <img src="{{ Auth::user()->getProfileImageUrl(48) }}" class="rounded mr-2">
 | 
						|
                        <div class="d-flex flex-column overflow-hidden">
 | 
						|
                            <h5 class="card-title text-truncate">
 | 
						|
                                <a class="text-dark" href="{{ route('user.profile', ['name' => Auth::user()->name]) }}">{{ Auth::user()->display_name }}</a>
 | 
						|
                            </h5>
 | 
						|
                            <h6 class="card-subtitle">
 | 
						|
                                <a class="text-muted" href="{{ route('user.profile', ['name' => Auth::user()->name]) }}">@{{ Auth::user()->name }}</a>
 | 
						|
                                @if (Auth::user()->is_protected)
 | 
						|
                                    <span class="oi oi-lock-locked text-muted"></span>
 | 
						|
                                @endif
 | 
						|
                            </h6>
 | 
						|
                        </div>
 | 
						|
                    </div>
 | 
						|
                    @component('components.profile-stats', ['user' => Auth::user()])
 | 
						|
                    @endcomponent
 | 
						|
                </div>
 | 
						|
            </div>
 | 
						|
            <div class="card mb-4">
 | 
						|
                <div class="card-header">サイトからのお知らせ</div>
 | 
						|
                <div class="list-group list-group-flush tis-sidebar-info">
 | 
						|
                    @foreach($informations as $info)
 | 
						|
                        <a class="list-group-item" href="{{ route('info.show', ['id' => $info->id]) }}">
 | 
						|
                            @if ($info->pinned)
 | 
						|
                                <span class="badge badge-secondary"><span class="oi oi-pin"></span>ピン留め</span>
 | 
						|
                            @endif
 | 
						|
                            <span class="badge {{ $categories[$info->category]['class'] }}">{{ $categories[$info->category]['label'] }}</span> {{ $info->title }} <small class="text-secondary">- {{ $info->created_at->format('n月j日') }}</small>
 | 
						|
                        </a>
 | 
						|
                    @endforeach
 | 
						|
                    <a href="{{ route('info') }}" class="list-group-item text-right">お知らせ一覧 »</a>
 | 
						|
                </div>
 | 
						|
            </div>
 | 
						|
        </div>
 | 
						|
        <div class="col-lg-8">
 | 
						|
            @if (!empty($publicLinkedEjaculations))
 | 
						|
                <h5 class="mb-3">お惣菜コーナー</h5>
 | 
						|
                <p class="text-secondary">最近の公開チェックインから、オカズリンク付きのものを表示しています。</p>
 | 
						|
                <ul class="list-group">
 | 
						|
                    @foreach ($publicLinkedEjaculations as $ejaculation)
 | 
						|
                        <li class="list-group-item no-side-border pt-3 pb-3 tis-word-wrap">
 | 
						|
                            <!-- span -->
 | 
						|
                            <div class="d-flex justify-content-between">
 | 
						|
                                <h5>
 | 
						|
                                    <a href="{{ route('user.profile', ['id' => $ejaculation->user->name]) }}" class="text-dark"><img src="{{ $ejaculation->user->getProfileImageUrl(30) }}" width="30" height="30" class="rounded d-inline-block align-bottom"> {{ $ejaculation->user->display_name }}</a>
 | 
						|
                                    <a href="{{ route('checkin.show', ['id' => $ejaculation->id]) }}" class="text-muted"><small>{{ $ejaculation->ejaculated_date->format('Y/m/d H:i') }}</small></a>
 | 
						|
                                </h5>
 | 
						|
                                <div>
 | 
						|
                                    <a class="text-secondary timeline-action-item" href="{{ route('checkin', ['link' => $ejaculation->link, 'tags' => $ejaculation->textTags()]) }}"><span class="oi oi-reload" data-toggle="tooltip" data-placement="bottom" title="同じオカズでチェックイン"></span></a>
 | 
						|
                                </div>
 | 
						|
                            </div>
 | 
						|
                            <!-- tags -->
 | 
						|
                            @if ($ejaculation->tags->isNotEmpty())
 | 
						|
                                <p class="mb-2">
 | 
						|
                                    @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">
 | 
						|
                                    <div class="card link-card mb-2 px-0 col-12 col-md-6 d-none" style="font-size: small;">
 | 
						|
                                        <a class="text-dark card-link" href="{{ $ejaculation->link }}" target="_blank" rel="noopener">
 | 
						|
                                            <img src="" alt="Thumbnail" class="card-img-top bg-secondary">
 | 
						|
                                            <div class="card-body">
 | 
						|
                                                <h6 class="card-title font-weight-bold">タイトル</h6>
 | 
						|
                                                <p class="card-text">コンテンツの説明文</p>
 | 
						|
                                            </div>
 | 
						|
                                        </a>
 | 
						|
                                    </div>
 | 
						|
                                    <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-0 tis-word-wrap">
 | 
						|
                                    {!! Formatter::linkify(nl2br(e($ejaculation->note))) !!}
 | 
						|
                                </p>
 | 
						|
                            @endif
 | 
						|
                        </li>
 | 
						|
                    @endforeach
 | 
						|
                </ul>
 | 
						|
            @endif
 | 
						|
        </div>
 | 
						|
    </div>
 | 
						|
</div>
 | 
						|
@endsection
 | 
						|
 | 
						|
@push('script')
 | 
						|
    <script>
 | 
						|
        $('.link-card').each(function () {
 | 
						|
            var $this = $(this);
 | 
						|
            $.ajax({
 | 
						|
                url: '{{ url('/api/checkin/card') }}',
 | 
						|
                method: 'get',
 | 
						|
                type: 'json',
 | 
						|
                data: {
 | 
						|
                    url: $this.find('a').attr('href')
 | 
						|
                }
 | 
						|
            }).then(function (data) {
 | 
						|
                var $title = $this.find('.card-title');
 | 
						|
                var $desc = $this.find('.card-text');
 | 
						|
                var $image = $this.find('img');
 | 
						|
 | 
						|
                if (data.title === '') {
 | 
						|
                    $title.hide();
 | 
						|
                } else {
 | 
						|
                    $title.text(data.title);
 | 
						|
                }
 | 
						|
 | 
						|
                if (data.description === '') {
 | 
						|
                    $desc.hide();
 | 
						|
                } else {
 | 
						|
                    $desc.text(data.description);
 | 
						|
                }
 | 
						|
 | 
						|
                if (data.image === '') {
 | 
						|
                    $image.hide();
 | 
						|
                } else {
 | 
						|
                    $image.attr('src', data.image);
 | 
						|
                }
 | 
						|
 | 
						|
                if (data.title !== '' || data.description !== '' || data.image !== '') {
 | 
						|
                    $this.removeClass('d-none');
 | 
						|
                }
 | 
						|
            });
 | 
						|
        });
 | 
						|
    </script>
 | 
						|
@endpush |