route, 'module',true);
        
        $data['breadcrumbs'] = [
            ['name' => 'Dashboard','url' => url('dashboard')],
            ['name' => 'Management & Akses Role'],
            ['name' => 'Data User','active' => true],
        ];
        $data['title'] = $this->title;
        $data['route'] = $this->route;
        return view($this->template.'.index',$data);
    }
    public function grid(Request $request)
    {
        $data = User::with(['group'])->where('ms_group_id','!=',2)->where('id','!=',auth()->user()->id)->orderBy('id','DESC')->get();
        $_data = [];
        foreach ($data as $key => $row) {
            $action = '';
            if((permission('is_create', $this->route.'.*','module',false)) || (permission('is_update', $this->route.'.*','module',false))){
                $action .= '';
                if(session('group_id') == 1){
                    $action .= '';
                    $action .= '';
                }
            }
            
           $_data[] = [
            'no'                => $key+1,
            'id'                => encode_id($row->id),
            'name'              => @$row->name,
            'role'              => @$row->group->name,
            'username'          => @$row->username,
            'email'             => @$row->email,
            'created_at'        => dateTime(@$row->created_at),
            'action'            => @$action,
        ];
        }
        // return response()->json($_data);  // Return the data as a JSON response
        return response()->json($_data);
    }
    /**
     * Show the form for creating a new resource.
     */
    public function create()
    {
        //
    }
    /**
     * Store a newly created resource in storage.
     */
    public function store(Request $request)
    {
        try {
            $keyId = decode_id($request->secure_id);
            if(@$keyId){
                Validator::make($request->all(), [
                    'email'           => 'required|unique:users,email,'.$keyId.'|email',
                    'name'            => 'required|max:50',
                    'group'           => 'required',
                    'username'        => 'required|unique:users,username,'.$keyId,
                    'password'        => 'nullable|min:8|regex:/[a-z]/|regex:/[A-Z]/|regex:/[0-9]/|regex:/[@$!%*#?&]/', //min 8 char, maks 15 char, min 1 symbol, min 1 uppercase, min 1 lowercase, 1 number
                ],[
                    'password.min' => 'password Minimal 8 Karakter',
                    'password.max' => 'password Maksimal 15 Karakter',
                    'password.regex' => 'Format Kata Sandi harus mengandung minimal Huruf Besar, Huruf Kecil, Angka, Spesial Karakter',
                ])->validate();
                $user = User::find($keyId);
                $user->email = $request->email;
                $user->username = $request->username;
                $user->ms_group_id = decode_id($request->group);
                if(@$request->password){
                    $user->password = Hash::make($request->password);
                }
                $user->name     = $request->name;
                $user->save();
            }else{
                Validator::make($request->all(), [
                    'email'           => 'required|unique:users,email|email',
                    'name'            => 'required|max:50',
                    'group'           => 'required',
                    'username'        => 'required|unique:users,username',
                    'password'        => 'required|min:8|regex:/[a-z]/|regex:/[A-Z]/|regex:/[0-9]/|regex:/[@$!%*#?&]/', //min 8 char, maks 15 char, min 1 symbol, min 1 uppercase, min 1 lowercase, 1 number
                ],[
                    'password.min' => 'password Minimal 8 Karakter',
                    'password.max' => 'password Maksimal 15 Karakter',
                    'password.regex' => 'Format Kata Sandi harus mengandung minimal Huruf Besar, Huruf Kecil, Angka, Spesial Karakter',
                ])->validate();
                $user = new User;
                $user->email = $request->email;
                $user->username = $request->username;
                $user->ms_group_id = decode_id($request->group);
                if(@$request->password){
                    $user->password = Hash::make($request->password);
                }
                $user->name     = $request->name;
                $user->save();
            }
            return redirect()->back()->with([
                'message' => 'Berhasil update data',
                'type'    => 'success',
            ]);
            
        } catch (Exception $e) {
            return redirect()->back()->with([
                     'message' => $e->getMessage(),
                     'type'    => "error"
                ]);
        }
    }
    /**
     * Display the specified resource.
     */
    public function show(string $id)
    {
        //
    }
    /**
     * Show the form for editing the specified resource.
     */
    public function edit(string $id)
    {
        //
    }
    /**
     * Update the specified resource in storage.
     */
    public function update($id = null)
    {
        $data['breadcrumbs'] = [
            ['name' => 'Dashboard','url' => url('dashboard')],
            ['name' => 'Management & Akses Role'],
            ['name' => 'Data User','active' => true],
        ];
        $keyId = decode_id($id);
        $data['title'] = $this->title;
        $data['route'] = $this->route;
        $data['keyId'] = $id;
        $data['item'] = User::with('profile')->where('id',$keyId)->first();
        $data['group'] = MasterGroup::where('MsGroupId','!=',1)->get();
        return view($this->template.'.form',$data);
    }
    /**
     * Remove the specified resource from storage.
     */
    public function destroy(string $id)
    {
        //
    }
    public function delete($id)
    {
        $keyId = decode_id($id);
        $user = User::where('id',$keyId)->delete();
        return response()->json(['success' => true,'message' => 'Berhasil update data','type' => 'success']);
    }
    public function forcelogin($id = null)
    {
        //dd($id);
    
        if (!$id) {
            return response()->json(['success' => false,'message' => 'Data Tidak Temukan','type' => 'error']);
        }
        $keyId = decode_id($id);
        $user = User::find($keyId);
        if (!$user) {
            return response()->json(['success' => false,'message' => 'Data Tidak Temukan','type' => 'error']);
        } else {
            // if ($user->username && $user->password) {
                Auth::logout();
                if (Auth::loginUsingId($keyId)) {
                    $session = [
                        'username'                  => $user->username,
                        'name'                      => $user->name,
                        'email'                     => $user->email,
                        'sekolah_id'                => @$user->profile->sekolah->MsSekolahId,
                        'npsn'                      => @$user->profile->npsn,
                        'tingkat_sekolah'           => @$user->profile->tingkat->name,
                        'status_sekolah'            => @$user->profile->status_sekolah,
                        'alamat_sekolah'            => @$user->profile->alamat_sekolah,
                        'kontak_person'             => @$user->profile->kontak_person,
                        'telp'                      => @$user->profile->telp,
                        'currYear'                  => date('Y'),
                        'group_id'                  => @$user->ms_group_id,
                        'group_alias'               => @$user->group->alias,
                        'group_name'                => @$user->group->name,
                    ];
                    // $this->repository->updateById($user->user_id,['last_login' => Carbon::now(), 'is_online' => session_id()]);
                    // session($session);
                    session()->put($session);
                    session()->save();
                    // logActivity($request, __('strings.backend.logs.login_success',['name' => $user->username]));
                    return response()->json(['status' => true,'message' => 'Selamat datang kembali','type' => 'success','data' => session($session)]);
                }else{
                    return response()->json(['status' => false,'message' => 'Maaf Terjadi Kesalahan','type' => 'error']);
                }
            // } else {
            //     return response()->json(['status' => false,'message' => 'Maaf Terjadi Kesalahan','type' => 'error']);
            // }
        }
    }
}