Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
💄 Design quick frontend for managing Google accounts
- Loading branch information
1 parent
f663934
commit 433195f
Showing
12 changed files
with
435 additions
and
7 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Original file line | Diff line number | Diff line change |
---|---|---|---|
@@ -0,0 +1,42 @@ | |||
<?php | |||
|
|||
namespace App\Http\Controllers; | |||
|
|||
use App\GoogleAccount; | |||
use App\Services\Google; | |||
use Illuminate\Http\Request; | |||
|
|||
class GoogleAccountController extends Controller | |||
{ | |||
public function __construct() | |||
{ | |||
$this->middleware('auth'); | |||
} | |||
|
|||
/** | |||
* Display a listing of the google accounts. | |||
*/ | |||
public function index() | |||
{ | |||
return view('accounts', [ | |||
'accounts' => auth()->user()->googleAccounts, | |||
]); | |||
} | |||
|
|||
/** | |||
* Handle the OAuth connection which leads to | |||
* the creating of a new Google Account. | |||
*/ | |||
public function store(Request $request, Google $google) | |||
{ | |||
// TODO | |||
} | |||
|
|||
/** | |||
* Revoke the account's token and delete the it locally. | |||
*/ | |||
public function destroy(GoogleAccount $googleAccount) | |||
{ | |||
// TODO | |||
} | |||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Original file line | Diff line number | Diff line change |
---|---|---|---|
@@ -0,0 +1,40 @@ | |||
@extends('layouts.app') | |||
|
|||
@section('content') | |||
<div class="container"> | |||
<div class="row justify-content-center"> | |||
<div class="col-md-8"> | |||
<div class="card"> | |||
<div class="card-header d-flex justify-content-between align-items-center"> | |||
<span>Google Accounts</span> | |||
<a class="btn btn-primary btn-sm" href="{{ route('google.store') }}"> | |||
Add account | |||
</a> | |||
</div> | |||
|
|||
<div class="card-body"> | |||
<ul class="list-group list-group-flush"> | |||
@forelse ($accounts as $account) | |||
<li class="list-group-item d-flex justify-content-between align-items-center"> | |||
<span>{{ $account->name }}</span> | |||
<form action="{{ route('google.destroy', $account) }}" method="post"> | |||
{{ csrf_field() }} | |||
{{ method_field('delete') }} | |||
|
|||
<button type="submit" class="btn btn-outline-secondary btn-sm"> | |||
delete | |||
</button> | |||
</form> | |||
</li> | |||
@empty | |||
<li class="list-group-item"> | |||
No google accounts. | |||
</li> | |||
@endforelse | |||
</ul> | |||
</div> | |||
</div> | |||
</div> | |||
</div> | |||
</div> | |||
@endsection |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Original file line | Diff line number | Diff line change |
---|---|---|---|
@@ -0,0 +1,71 @@ | |||
@extends('layouts.app') | |||
|
|||
@section('content') | |||
<div class="container"> | |||
<div class="row justify-content-center"> | |||
<div class="col-md-8"> | |||
<div class="card"> | |||
<div class="card-header">{{ __('Login') }}</div> | |||
|
|||
<div class="card-body"> | |||
<form method="POST" action="{{ route('login') }}" aria-label="{{ __('Login') }}"> | |||
@csrf | |||
|
|||
<div class="form-group row"> | |||
<label for="email" class="col-sm-4 col-form-label text-md-right">{{ __('E-Mail Address') }}</label> | |||
|
|||
<div class="col-md-6"> | |||
<input id="email" type="email" class="form-control{{ $errors->has('email') ? ' is-invalid' : '' }}" name="email" value="{{ old('email') }}" required autofocus> | |||
|
|||
@if ($errors->has('email')) | |||
<span class="invalid-feedback" role="alert"> | |||
<strong>{{ $errors->first('email') }}</strong> | |||
</span> | |||
@endif | |||
</div> | |||
</div> | |||
|
|||
<div class="form-group row"> | |||
<label for="password" class="col-md-4 col-form-label text-md-right">{{ __('Password') }}</label> | |||
|
|||
<div class="col-md-6"> | |||
<input id="password" type="password" class="form-control{{ $errors->has('password') ? ' is-invalid' : '' }}" name="password" required> | |||
|
|||
@if ($errors->has('password')) | |||
<span class="invalid-feedback" role="alert"> | |||
<strong>{{ $errors->first('password') }}</strong> | |||
</span> | |||
@endif | |||
</div> | |||
</div> | |||
|
|||
<div class="form-group row"> | |||
<div class="col-md-6 offset-md-4"> | |||
<div class="form-check"> | |||
<input class="form-check-input" type="checkbox" name="remember" id="remember" {{ old('remember') ? 'checked' : '' }}> | |||
|
|||
<label class="form-check-label" for="remember"> | |||
{{ __('Remember Me') }} | |||
</label> | |||
</div> | |||
</div> | |||
</div> | |||
|
|||
<div class="form-group row mb-0"> | |||
<div class="col-md-8 offset-md-4"> | |||
<button type="submit" class="btn btn-primary"> | |||
{{ __('Login') }} | |||
</button> | |||
|
|||
<a class="btn btn-link" href="{{ route('password.request') }}"> | |||
{{ __('Forgot Your Password?') }} | |||
</a> | |||
</div> | |||
</div> | |||
</form> | |||
</div> | |||
</div> | |||
</div> | |||
</div> | |||
</div> | |||
@endsection |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Original file line | Diff line number | Diff line change |
---|---|---|---|
@@ -0,0 +1,47 @@ | |||
@extends('layouts.app') | |||
|
|||
@section('content') | |||
<div class="container"> | |||
<div class="row justify-content-center"> | |||
<div class="col-md-8"> | |||
<div class="card"> | |||
<div class="card-header">{{ __('Reset Password') }}</div> | |||
|
|||
<div class="card-body"> | |||
@if (session('status')) | |||
<div class="alert alert-success" role="alert"> | |||
{{ session('status') }} | |||
</div> | |||
@endif | |||
|
|||
<form method="POST" action="{{ route('password.email') }}" aria-label="{{ __('Reset Password') }}"> | |||
@csrf | |||
|
|||
<div class="form-group row"> | |||
<label for="email" class="col-md-4 col-form-label text-md-right">{{ __('E-Mail Address') }}</label> | |||
|
|||
<div class="col-md-6"> | |||
<input id="email" type="email" class="form-control{{ $errors->has('email') ? ' is-invalid' : '' }}" name="email" value="{{ old('email') }}" required> | |||
|
|||
@if ($errors->has('email')) | |||
<span class="invalid-feedback" role="alert"> | |||
<strong>{{ $errors->first('email') }}</strong> | |||
</span> | |||
@endif | |||
</div> | |||
</div> | |||
|
|||
<div class="form-group row mb-0"> | |||
<div class="col-md-6 offset-md-4"> | |||
<button type="submit" class="btn btn-primary"> | |||
{{ __('Send Password Reset Link') }} | |||
</button> | |||
</div> | |||
</div> | |||
</form> | |||
</div> | |||
</div> | |||
</div> | |||
</div> | |||
</div> | |||
@endsection |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Original file line | Diff line number | Diff line change |
---|---|---|---|
@@ -0,0 +1,65 @@ | |||
@extends('layouts.app') | |||
|
|||
@section('content') | |||
<div class="container"> | |||
<div class="row justify-content-center"> | |||
<div class="col-md-8"> | |||
<div class="card"> | |||
<div class="card-header">{{ __('Reset Password') }}</div> | |||
|
|||
<div class="card-body"> | |||
<form method="POST" action="{{ route('password.request') }}" aria-label="{{ __('Reset Password') }}"> | |||
@csrf | |||
|
|||
<input type="hidden" name="token" value="{{ $token }}"> | |||
|
|||
<div class="form-group row"> | |||
<label for="email" class="col-md-4 col-form-label text-md-right">{{ __('E-Mail Address') }}</label> | |||
|
|||
<div class="col-md-6"> | |||
<input id="email" type="email" class="form-control{{ $errors->has('email') ? ' is-invalid' : '' }}" name="email" value="{{ $email ?? old('email') }}" required autofocus> | |||
|
|||
@if ($errors->has('email')) | |||
<span class="invalid-feedback" role="alert"> | |||
<strong>{{ $errors->first('email') }}</strong> | |||
</span> | |||
@endif | |||
</div> | |||
</div> | |||
|
|||
<div class="form-group row"> | |||
<label for="password" class="col-md-4 col-form-label text-md-right">{{ __('Password') }}</label> | |||
|
|||
<div class="col-md-6"> | |||
<input id="password" type="password" class="form-control{{ $errors->has('password') ? ' is-invalid' : '' }}" name="password" required> | |||
|
|||
@if ($errors->has('password')) | |||
<span class="invalid-feedback" role="alert"> | |||
<strong>{{ $errors->first('password') }}</strong> | |||
</span> | |||
@endif | |||
</div> | |||
</div> | |||
|
|||
<div class="form-group row"> | |||
<label for="password-confirm" class="col-md-4 col-form-label text-md-right">{{ __('Confirm Password') }}</label> | |||
|
|||
<div class="col-md-6"> | |||
<input id="password-confirm" type="password" class="form-control" name="password_confirmation" required> | |||
</div> | |||
</div> | |||
|
|||
<div class="form-group row mb-0"> | |||
<div class="col-md-6 offset-md-4"> | |||
<button type="submit" class="btn btn-primary"> | |||
{{ __('Reset Password') }} | |||
</button> | |||
</div> | |||
</div> | |||
</form> | |||
</div> | |||
</div> | |||
</div> | |||
</div> | |||
</div> | |||
@endsection |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Original file line | Diff line number | Diff line change |
---|---|---|---|
@@ -0,0 +1,77 @@ | |||
@extends('layouts.app') | |||
|
|||
@section('content') | |||
<div class="container"> | |||
<div class="row justify-content-center"> | |||
<div class="col-md-8"> | |||
<div class="card"> | |||
<div class="card-header">{{ __('Register') }}</div> | |||
|
|||
<div class="card-body"> | |||
<form method="POST" action="{{ route('register') }}" aria-label="{{ __('Register') }}"> | |||
@csrf | |||
|
|||
<div class="form-group row"> | |||
<label for="name" class="col-md-4 col-form-label text-md-right">{{ __('Name') }}</label> | |||
|
|||
<div class="col-md-6"> | |||
<input id="name" type="text" class="form-control{{ $errors->has('name') ? ' is-invalid' : '' }}" name="name" value="{{ old('name') }}" required autofocus> | |||
|
|||
@if ($errors->has('name')) | |||
<span class="invalid-feedback" role="alert"> | |||
<strong>{{ $errors->first('name') }}</strong> | |||
</span> | |||
@endif | |||
</div> | |||
</div> | |||
|
|||
<div class="form-group row"> | |||
<label for="email" class="col-md-4 col-form-label text-md-right">{{ __('E-Mail Address') }}</label> | |||
|
|||
<div class="col-md-6"> | |||
<input id="email" type="email" class="form-control{{ $errors->has('email') ? ' is-invalid' : '' }}" name="email" value="{{ old('email') }}" required> | |||
|
|||
@if ($errors->has('email')) | |||
<span class="invalid-feedback" role="alert"> | |||
<strong>{{ $errors->first('email') }}</strong> | |||
</span> | |||
@endif | |||
</div> | |||
</div> | |||
|
|||
<div class="form-group row"> | |||
<label for="password" class="col-md-4 col-form-label text-md-right">{{ __('Password') }}</label> | |||
|
|||
<div class="col-md-6"> | |||
<input id="password" type="password" class="form-control{{ $errors->has('password') ? ' is-invalid' : '' }}" name="password" required> | |||
|
|||
@if ($errors->has('password')) | |||
<span class="invalid-feedback" role="alert"> | |||
<strong>{{ $errors->first('password') }}</strong> | |||
</span> | |||
@endif | |||
</div> | |||
</div> | |||
|
|||
<div class="form-group row"> | |||
<label for="password-confirm" class="col-md-4 col-form-label text-md-right">{{ __('Confirm Password') }}</label> | |||
|
|||
<div class="col-md-6"> | |||
<input id="password-confirm" type="password" class="form-control" name="password_confirmation" required> | |||
</div> | |||
</div> | |||
|
|||
<div class="form-group row mb-0"> | |||
<div class="col-md-6 offset-md-4"> | |||
<button type="submit" class="btn btn-primary"> | |||
{{ __('Register') }} | |||
</button> | |||
</div> | |||
</div> | |||
</form> | |||
</div> | |||
</div> | |||
</div> | |||
</div> | |||
</div> | |||
@endsection |
Oops, something went wrong.