krgm.so-manager-dev.com/app/Http/Controllers/Admin/TermsController.php

138 lines
4.1 KiB
PHP
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<?php
namespace App\Http\Controllers\Admin;
use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use App\Models\Term;
use App\Models\City;
class TermsController extends Controller
{
// 一覧表示
public function list(Request $request)
{
$sort = $request->input('sort', 'terms_id');
$sort_type = $request->input('sort_type', 'asc');
$allowedSorts = ['terms_id', 'terms_revision', 'start_date', 'use_flag'];
if (!in_array($sort, $allowedSorts)) {
$sort = 'terms_id';
}
if (!in_array($sort_type, ['asc', 'desc'])) {
$sort_type = 'asc';
}
$terms = Term::select([
'terms_id',
'terms_revision',
'terms_text',
'start_date',
'use_flag',
'memo',
'city_id',
'operator_id'
])->orderBy($sort, $sort_type)->paginate(20);
return view('admin.terms.list', compact('terms', 'sort', 'sort_type'));
}
// 新規登録画面・登録処理
public function add(Request $request)
{
if ($request->isMethod('post')) {
$validated = $request->validate([
'terms_revision' => 'required|string|max:255',
'terms_text' => 'required|string',
'start_date' => 'nullable|date',
'use_flag' => 'required|in:0,1',
'memo' => 'nullable|string|max:255',
'city_id' => 'nullable|integer',
'operator_id' => 'nullable|integer',
]);
Term::create($validated);
return redirect()->route('terms')->with('success', '利用規約が登録されました');
}
// 都市の選択肢を取得
$cities = City::pluck('city_name', 'city_id');
return view('admin.terms.add', compact('cities'));
}
// 編集画面・更新処理
public function edit(Request $request, $id)
{
$term = Term::findOrFail($id);
$cities = City::pluck('city_name', 'city_id');
if ($request->isMethod('post')) {
$validated = $request->validate([
'terms_revision' => 'required|string|max:255',
'terms_text' => 'required|string',
'start_date' => 'nullable|date',
'use_flag' => 'required|in:0,1',
'memo' => 'nullable|string|max:255',
'city_id' => 'nullable|integer',
'operator_id' => 'nullable|integer',
]);
$term->update($validated);
return redirect()->route('terms')->with('success', '利用規約が更新されました');
}
return view('admin.terms.edit', compact('term', 'cities'));
}
// 詳細表示
public function info($id)
{
$term = Term::findOrFail($id);
return view('admin.terms.info', compact('term'));
}
// 削除処理(複数)
public function delete(Request $request)
{
$ids = $request->input('id', []); // 修正点:'pk' → 'id'
if (!empty($ids)) {
Term::destroy($ids);
return redirect()->route('terms')->with('success', '削除しました');
}
return redirect()->route('terms')->with('error', '削除対象が見つかりません');
}
// CSVインポート
public function import(Request $request)
{
return redirect()->route('terms')->with('info', 'CSVインポートは未実装です');
}
// CSVエクスポートfputcsv使用
public function export()
{
return response()->streamDownload(function () {
$handle = fopen('php://output', 'w');
fputcsv($handle, ['terms_id', 'terms_revision', 'terms_text', 'start_date', 'use_flag']);
foreach (Term::all() as $term) {
fputcsv($handle, [
$term->terms_id,
$term->terms_revision,
$term->terms_text,
$term->start_date,
$term->use_flag,
]);
}
fclose($handle);
}, 'terms.csv');
}
}