<?php

namespace App\Http\Controllers;

use App\Http\Requests\{{modelName}}Request;
use App\Http\Resources\{{modelName}}Resource;
use App\Http\Resources\{{modelName}}Collection;
use App\Models\{{modelName}};
use App\Repositories\{{modelName}}Repository;
use Illuminate\Http\Request;
use Illuminate\Http\Response;

class {{modelName}}Controller extends Controller
{
    protected $repository;

    public function __construct({{modelName}}Repository $repository)
    {
        $this->repository = $repository;
    }

    /**
     * Display a listing of the resource.
     *
     * @param  \Illuminate\Http\Request  $request
     * @return \Illuminate\Http\Response
     */
    public function index(Request $request)
    {
        $items = $this->repository->getAll($request);
        return new {{modelName}}Collection($items);
    }

    /**
     * Store a newly created resource in storage.
     *
     * @param  \App\Http\Requests\{{modelName}}Request  $request
     * @return \Illuminate\Http\Response
     */
    public function store({{modelName}}Request $request)
    {
        $item = $this->repository->create($request->validated());
        return new {{modelName}}Resource($item);
    }

    /**
     * Display the specified resource.
     *
     * @param  \App\Models\{{modelName}}  ${{camelCase}}
     * @return \Illuminate\Http\Response
     */
    public function show({{modelName}} ${{camelCase}})
    {
        return new {{modelName}}Resource(${{camelCase}});
    }

    /**
     * Update the specified resource in storage.
     *
     * @param  \App\Http\Requests\{{modelName}}Request  $request
     * @param  \App\Models\{{modelName}}  ${{camelCase}}
     * @return \Illuminate\Http\Response
     */
    public function update({{modelName}}Request $request, {{modelName}} ${{camelCase}})
    {
        $item = $this->repository->update(${{camelCase}}, $request->validated());
        return new {{modelName}}Resource($item);
    }

    /**
     * Remove the specified resource from storage.
     *
     * @param  \App\Models\{{modelName}}  ${{camelCase}}
     * @return \Illuminate\Http\Response
     */
    public function destroy({{modelName}} ${{camelCase}})
    {
        $this->repository->delete(${{camelCase}});
        return response()->json(null, Response::HTTP_NO_CONTENT);
    }

{{#relationships}}
{{#isHasMany}}
    /**
     * Display a listing of the related {{name}} resources.
     *
     * @param  \App\Models\{{modelName}}  ${{camelCase}}
     * @return \Illuminate\Http\Response
     */
    public function get{{pascalName}}({{modelName}} ${{camelCase}})
    {
        $items = ${{camelCase}}->{{name}}()->with([/* Include relationships here */])->get();
        return response()->json(['data' => $items]);
    }

    /**
     * Associate {{name}} resources with this {{modelName}}.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  \App\Models\{{modelName}}  ${{camelCase}}
     * @return \Illuminate\Http\Response
     */
    public function update{{pascalName}}(Request $request, {{modelName}} ${{camelCase}})
    {
        $request->validate([
            'ids' => 'required|array',
            'ids.*' => 'exists:{{relatedTable}},id'
        ]);
        
        // Update the relationship based on the IDs provided
        $this->repository->sync{{pascalName}}(${{camelCase}}, $request->ids);
        
        return response()->json(['message' => '{{name}} updated successfully']);
    }
{{/isHasMany}}

{{#isHasOne}}
    /**
     * Display the related {{name}} resource.
     *
     * @param  \App\Models\{{modelName}}  ${{camelCase}}
     * @return \Illuminate\Http\Response
     */
    public function get{{pascalName}}({{modelName}} ${{camelCase}})
    {
        $item = ${{camelCase}}->{{name}};
        return response()->json(['data' => $item]);
    }

    /**
     * Associate a {{name}} resource with this {{modelName}}.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  \App\Models\{{modelName}}  ${{camelCase}}
     * @return \Illuminate\Http\Response
     */
    public function update{{pascalName}}(Request $request, {{modelName}} ${{camelCase}})
    {
        $request->validate([
            'id' => 'required|exists:{{relatedTable}},id'
        ]);
        
        // Update the relationship based on the ID provided
        $this->repository->update{{pascalName}}(${{camelCase}}, $request->id);
        
        return response()->json(['message' => '{{name}} updated successfully']);
    }
{{/isHasOne}}

{{#isBelongsToMany}}
    /**
     * Display a listing of the related {{name}} resources.
     *
     * @param  \App\Models\{{modelName}}  ${{camelCase}}
     * @return \Illuminate\Http\Response
     */
    public function get{{pascalName}}({{modelName}} ${{camelCase}})
    {
        $items = ${{camelCase}}->{{name}}()->with([/* Include relationships here */])->get();
        return response()->json(['data' => $items]);
    }

    /**
     * Sync {{name}} resources with this {{modelName}}.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  \App\Models\{{modelName}}  ${{camelCase}}
     * @return \Illuminate\Http\Response
     */
    public function sync{{pascalName}}(Request $request, {{modelName}} ${{camelCase}})
    {
        $request->validate([
            'ids' => 'required|array',
            'ids.*' => 'exists:{{relatedTable}},id',
            {{#withPivot}}
            'pivot' => 'array',
            {{/withPivot}}
        ]);
        
        // Sync the relationship based on the IDs provided
        $this->repository->sync{{pascalName}}(${{camelCase}}, $request->ids, $request->pivot ?? []);
        
        return response()->json(['message' => '{{name}} synced successfully']);
    }
{{/isBelongsToMany}}
{{/relationships}}
}