| Server IP : / Your IP : 10.244.4.16 [ Web Server : nginx/1.25.3 System : Linux escuela-portal-app-54f56585bc-kst6g 5.15.0-1084-azure #93-Ubuntu SMP Sat Mar 15 14:12:29 UTC 2025 x86_64 User : root ( 0) PHP Version : 8.2.13 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals, Domains : 0 Domains MySQL : OFF | cURL : ON | WGET : OFF | Perl : ON | Python : OFF | Sudo : OFF | Pkexec : OFF Directory : /var/www/app/app/Http/Controllers/Managment/ |
Upload File : |
<?php
namespace App\Http\Controllers\Managment;
use App\Http\Controllers\Controller;
use App\Models\Page;
use App\Models\Section;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB;
use PhpOffice\PhpSpreadsheet\Writer\Xlsx\Rels;
class PageController extends Controller
{
public function index()
{
return Page::get();
}
public function getPages()
{
return DB::table('pages AS p')
->leftjoin('page_sections AS ps', 'p.id', 'ps.page_id')
->select(
array(
'p.id', 'p.name', 'p.slug', 'p.is_menu', DB::raw('COUNT( DISTINCT ps.id) AS sections'),
)
)
->groupBy('p.id')->orderBy('p.is_menu', 'desc')->orderBy('p.name')->get();
}
public function getSections(){
return Section::select('id', 'name')->orderBy('name')->get();
}
public function edit($id){
return Page::find($id)->getFullData();
}
public function update( Request $request, $id){
try {
DB::transaction(function () use ($request, $id) {
Page::find($id)->updateFullData($request);
});
return true;
} catch (\Throwable $th) {
return $th;
}
}
public function destroy($id)
{
try {
DB::transaction(function () use ($id) {
Page::find($id)->delete();
});
$response = true;
} catch (\Throwable $th) {
$response = $th;
}
return $response;
}
}