「駐輪場マスタ」画面修正
All checks were successful
Deploy main / deploy (push) Successful in 23s

This commit is contained in:
你的名字 2025-09-03 11:04:04 +09:00
parent 542a910aa5
commit 7c5ba49a47
5 changed files with 211 additions and 104 deletions

View File

@ -30,6 +30,7 @@ class ParkController extends Controller
'p.alert_flag',
'p.print_number',
'p.keep_alive',
'p.operator_id',
]);
if ($request->filled('park_name')) {
@ -69,7 +70,7 @@ class ParkController extends Controller
$park->fill($validated);
$park->save();
return redirect()->route('parks')->with('success', '登録しました');
return redirect()->route('parks')->with('success', '新規登録に完了しました');
}
return view('admin.parks.add', [

View File

@ -26,10 +26,15 @@
<div class="alert alert-danger"><ul class="mb-0">@foreach($errors->all() as $e)<li>{{ $e }}</li>@endforeach</ul></div>
@endif
{{-- 成功メッセージ表示 --}}
@if (session('success'))
<div class="alert alert-success">{{ session('success') }}</div>
@endif
{{-- 入力フォーム --}}
<div class="card">
<div class="card-body">
<form method="post" action="{{ route('news_add') }}">
<form method="post" action="{{ route('news_add') }}" id="news-add-form">
@csrf
<div class="form-group">
<label>ニュース内容 <span class="text-danger">*</span></label>
@ -63,7 +68,7 @@
</div>
<div class="text-right">
<a href="{{ route('news') }}" class="btn btn-outline-secondary">戻る</a>
<button class="btn btn-primary">登録</button>
<button type="button" class="btn btn-primary" id="register-btn">登録</button>
</div>
</form>
</div>
@ -71,3 +76,14 @@
</div>
</section>
@endsection
@push('scripts')
<script>
// 登録ボタン押下時に確認ダイアログ
document.getElementById('register-btn').addEventListener('click', function(e) {
if (confirm('登録してよろしいですか?')) {
document.getElementById('news-add-form').submit();
}
});
</script>
@endpush

View File

@ -2,68 +2,141 @@
@section('title', '駐輪場マスタ 新規')
@section('content')
<div class="container-fluid page-park py-3">
{{-- 画面上部のツールバー(新規は登録だけ/目标图一致) --}}
<div class="screen-toolbar mb-2">
<div class="left">
<button type="submit" form="park-add-form" class="btn btn-success btn-sm">登録</button>
<div class="container-fluid page-park py-3">
{{-- 成功メッセージ表示 --}}
@if (session('success'))
<div class="alert alert-success">{{ session('success') }}</div>
@endif
{{-- パンくず --}}
<div class="content-header">
<div class="container-fluid">
<div class="row mb-2">
<div class="col-lg-6">
<h1 class="m-0 text-dark">新規</h1>
</div>
<div class="col-lg-6">
<ol class="breadcrumb float-sm-right text-sm">
<li class="breadcrumb-item"><a href="{{ route('home') }}">ホーム</a></li>
<li class="breadcrumb-item"><a href="{{ route('parks') }}">駐輪場マスタ</a></li>
<li class="breadcrumb-item active">新規</li>
</ol>
</div>
</div>
</div>
</div>
<div class="right"><!-- 新規は削除無し --></div>
{{-- 画面上部のツールバー(登録ボタン)
<div class="screen-toolbar mb-2">
<div class="left">
<button type="submit" form="park-add-form" class="btn btn-success btn-sm">登録</button>
</div>
<div class="right"><!-- 新規は削除無し --></div>
</div>--}}
{{-- 本体フォーム(白背景のカード) --}}
<form id="park-add-form" method="POST" action="{{ route('parks.store') }}" enctype="multipart/form-data"
class="card card-body form-card">
@csrf
@include('admin.parks._form')
<div class="form-footer mt-3 pt-2">
<button type="button" id="register-btn" class="btn btn-success">登録</button>
<a href="{{ route('parks') }}" class="btn btn-outline-secondary">戻る</a>
</div>
</form>
</div>
{{-- 本体フォーム(白背景のカード) --}}
<form id="park-add-form" method="POST" action="{{ route('parks.store') }}" enctype="multipart/form-data" class="card card-body form-card">
@csrf
@include('admin.parks._form')
@push('scripts')
<script>
document.getElementById('register-btn').addEventListener('click', function (e) {
if (confirm('登録してよろしいですか?')) {
// 重複チェック駐輪場名Ajax
const form = document.getElementById('park-add-form');
const formData = new FormData(form);
fetch('{{ route('parks.check_duplicate') }}', {
method: 'POST',
headers: {
'X-CSRF-TOKEN': '{{ csrf_token() }}'
},
body: formData
})
.then(response => response.json())
.then(data => {
if (data.duplicate) {
alert('登録内容に重複があります。重複駐輪場ID' + data.park_id + ' 駐輪場名:' + data.park_name + '');
} else {
form.submit();
}
})
.catch(() => {
alert('重複チェックに失敗しました。');
});
}
});
</script>
@endpush
<div class="form-footer mt-3 pt-2">
<button type="button" id="register-btn" class="btn btn-success">登録</button>
<a href="{{ route('parks') }}" class="btn btn-outline-secondary">戻る</a>
</div>
</form>
</div>
<style>
.page-park {
background: #f4f6f9;
}
<script>
document.getElementById('register-btn').addEventListener('click', function(e) {
if(confirm('登録してよろしいですか?')) {
// 重複チェック駐輪場名Ajax
const form = document.getElementById('park-add-form');
const formData = new FormData(form);
fetch('{{ route('parks.check_duplicate') }}', {
method: 'POST',
headers: {
'X-CSRF-TOKEN': '{{ csrf_token() }}'
},
body: formData
})
.then(response => response.json())
.then(data => {
if(data.duplicate) {
alert('登録内容に重複があります。重複駐輪場ID' + data.park_id + ' 駐輪場名:' + data.park_name + '');
} else {
form.submit();
}
})
.catch(() => {
alert('重複チェックに失敗しました。');
});
}
});
</script>
.form-card {
border: 1px solid #e5e7eb;
box-shadow: 0 1px 1px rgba(0, 0, 0, .04)
}
<style>
.page-park{background:#f4f6f9;}
.form-card{border:1px solid #e5e7eb;box-shadow:0 1px 1px rgba(0,0,0,.04)}
.screen-toolbar{display:flex;justify-content:space-between;align-items:center}
.screen-toolbar .btn{border-radius:3px;padding:.35rem .7rem}
.screen-toolbar .btn-light{background:#fff;border:1px solid #dcdfe3;color:#333}
.form-group{margin-bottom:.6rem}
.col-form-label{padding-top:.55rem;font-weight:600}
.req:after{content:" *";color:#dc3545}
input.form-control,select.form-control{height:34px;padding:.25rem .5rem}
textarea.form-control{min-height:72px}
.img-thumbnail{border:1px dashed #d0d7de;background:repeating-linear-gradient(45deg,#fafafa,#fafafa 8px,#f3f4f6 8px,#f3f4f6 16px)}
.form-footer{border-top:1px dashed #e9ecef}
</style>
@endsection
.screen-toolbar {
display: flex;
justify-content: space-between;
align-items: center
}
.screen-toolbar .btn {
border-radius: 3px;
padding: .35rem .7rem
}
.screen-toolbar .btn-light {
background: #fff;
border: 1px solid #dcdfe3;
color: #333
}
.form-group {
margin-bottom: .6rem
}
.col-form-label {
padding-top: .55rem;
font-weight: 600
}
.req:after {
content: " *";
color: #dc3545
}
input.form-control,
select.form-control {
height: 34px;
padding: .25rem .5rem
}
textarea.form-control {
min-height: 72px
}
.img-thumbnail {
border: 1px dashed #d0d7de;
background: repeating-linear-gradient(45deg, #fafafa, #fafafa 8px, #f3f4f6 8px, #f3f4f6 16px)
}
.form-footer {
border-top: 1px dashed #e9ecef
}
</style>
@endsection

View File

@ -2,6 +2,23 @@
@section('title', '駐輪場マスタ 編集')
@section('content')
{{-- パンくず --}}
<div class="content-header">
<div class="container-fluid">
<div class="row mb-2">
<div class="col-lg-6">
<h1 class="m-0 text-dark">編集</h1>
</div>
<div class="col-lg-6">
<ol class="breadcrumb float-sm-right text-sm">
<li class="breadcrumb-item"><a href="{{ route('home') }}">ホーム</a></li>
<li class="breadcrumb-item"><a href="{{ route('parks') }}">駐輪場マスタ</a></li>
<li class="breadcrumb-item active">編集</li>
</ol>
</div>
</div>
</div>
</div>
<div class="container-fluid page-park py-3">
{{-- 画面上部のツールバー(左:登録/その他、右:削除) --}}

View File

@ -2,9 +2,17 @@
@section('content')
<div class="container-fluid pt-4">
{{-- フラッシュメッセージ --}}
@if(session('success'))
<div class="alert alert-success">{{ session('success') }}</div>
@endif
@if(session('error'))
<div class="alert alert-danger">{{ session('error') }}</div>
@endif
<div class="d-flex justify-content-between align-items-center mb-3">
<h3 class="mb-0">駐輪場マスタ</h3>
<ol class="breadcrumb float-sm-right text-sm mb-0"style="background: #f8f9fa;">
<ol class="breadcrumb float-sm-right text-sm mb-0" style="background: #f8f9fa;">
<li class="breadcrumb-item"><a href="{{ url('/home') }}">ホーム</a></li>
<li class="breadcrumb-item active">駐輪場マスタ</li>
</ol>
@ -67,10 +75,10 @@
<th>住所</th>
<th>閉設フラグ</th>
<th>閉設日</th>
<th>価格メモ</th>
<th>残警告チェックフラグ</th>
<th>印字数</th>
<th>最新キープアライブ</th>
<th>更新オペレータID</th>
<th>更新期間開始日</th>
<th>更新期間開始時</th>
<th>更新期間終了日</th>
@ -118,25 +126,26 @@
<a href="{{ route('parks.edit', ['id' => $park->park_id]) }}"
class="btn btn-sm btn-outline-primary ml-2">編集</a>
</td>
<td class='sm-item text-left'><span>{{ $park->park_id }}</span></td>
<td class='sm-item text-right'><span>{{ $park->city_name }}</span></td>
<td class='sm-item text-right'><span>{{ $park->park_name }}</span></td>
<td class='sm-item text-right'><span>{{ $park->park_ruby }}</span></td>
<td class='sm-item text-left'><span>{{ $park->park_syllabary }}</span></td>
<td class='sm-item text-right'><span>{{ $park->park_adrs }}</span></td>
<td class='sm-item text-right'>
<span>
@if($park->park_close_flag == 1)
閉設
@else
営業中
@endif
</span>
</td>
<td class='sm-item text-right'><span>{{ $park->park_day }}</span></td>
<td class='sm-item text-left'><span>{{ $park->alert_flag }}</span></td>
<td class='sm-item text-left'><span>{{ $park->print_number }}</span></td>
<td class='sm-item text-left'><span>{{ $park->keep_alive }}</span></td>
<td class='sm-item text-left'><span>{{ $park->park_id }}</span></td>
<td class='sm-item text-right'><span>{{ $park->city_name }}</span></td>
<td class='sm-item text-right'><span>{{ $park->park_name }}</span></td>
<td class='sm-item text-right'><span>{{ $park->park_ruby }}</span></td>
<td class='sm-item text-left'><span>{{ $park->park_syllabary }}</span></td>
<td class='sm-item text-right'><span>{{ $park->park_adrs }}</span></td>
<td class='sm-item text-right'>
<span>
@if($park->park_close_flag == 1)
閉設
@else
営業中
@endif
</span>
</td>
<td class='sm-item text-right'><span>{{ $park->park_day }}</span></td>
<td class='sm-item text-left'><span>{{ $park->alert_flag }}</span></td>
<td class='sm-item text-left'><span>{{ $park->print_number }}</span></td>
<td class='sm-item text-left'><span>{{ $park->keep_alive }}</span></td>
<td class='sm-item text-left'><span>{{ $park->operator_id ?? '' }}</span></td>
</tr>
@endforeach
</tbody>
@ -150,32 +159,23 @@
@endsection
@push('scripts')
@extends('layouts.app')
@section('content')
<div class="container-fluid pt-4">
{{-- ここにテーブルやフォーム --}}
</div>
@endsection
@push('scripts')
<script>
// チェックボックス全選択
document.getElementById('check_all')?.addEventListener('change', function () {
document.querySelectorAll('.row_checkbox').forEach(cb => {
cb.checked = this.checked;
});
});
</script>
@endpush
<script>
$('#check_all').on('change', function () {
$('.row_checkbox').prop('checked', this.checked);
// チェックボックス全選択
document.getElementById('check_all')?.addEventListener('change', function () {
document.querySelectorAll('.row_checkbox').forEach(cb => {
cb.checked = this.checked;
});
});
// jQuery fallbackもしjQueryが使われていれば
if (window.$) {
$('#check_all').on('change', function () {
$('.row_checkbox').prop('checked', this.checked);
});
}
// 削除ボタンの確認ダイアログ
document.getElementById('delete-btn').addEventListener('click', function() {
document.getElementById('delete-btn').addEventListener('click', function () {
if (confirm('削除してよろしいですか?')) {
document.getElementById('parks-delete-form').submit();
}