diff --git a/app/Http/Controllers/Auth/Users.php b/app/Http/Controllers/Auth/Users.php index 03965e65b..b11328c4d 100644 --- a/app/Http/Controllers/Auth/Users.php +++ b/app/Http/Controllers/Auth/Users.php @@ -47,9 +47,19 @@ class Users extends Controller * * @return Response */ - public function show() + public function show(User $user) { - return redirect()->route('users.index'); + $u = new \stdClass(); + $u->role = $user->roles()->first(); + $u->landing_pages = []; + + event(new LandingPageShowing($u)); + + $landing_pages = $u->landing_pages; + + $companies = $user->companies()->collect(); + + return view('auth.users.show', compact('user', 'landing_pages', 'companies')); } /** @@ -95,7 +105,7 @@ class Users extends Controller $response = $this->ajaxDispatch(new CreateUser($request)); if ($response['success']) { - $response['redirect'] = route('users.index'); + $response['redirect'] = route('users.show', $response['data']->id); $message = trans('messages.success.invited', ['type' => trans_choice('general.users', 1)]); @@ -191,7 +201,7 @@ class Users extends Controller $response = $this->ajaxDispatch(new UpdateUser($user, $request)); if ($response['success']) { - $response['redirect'] = user()->can('read-auth-users') ? route('users.index') : route('users.edit', $user->id); + $response['redirect'] = user()->can('read-auth-users') ? route('users.show', $user->id) : route('users.edit', $user->id); $message = trans('messages.success.updated', ['type' => $user->name]); diff --git a/app/Models/Auth/User.php b/app/Models/Auth/User.php index 0caf3a9f2..88eeeea78 100644 --- a/app/Models/Auth/User.php +++ b/app/Models/Auth/User.php @@ -378,13 +378,23 @@ class User extends Authenticatable implements HasLocalePreference return $actions; } + $actions[] = [ + 'title' => trans('general.show'), + 'icon' => 'visibility', + 'url' => route('users.show', $this->id), + 'permission' => 'read-auth-users', + 'attributes' => [ + 'id' => 'index-line-actions-show-user-' . $this->id, + ], + ]; + $actions[] = [ 'title' => trans('general.edit'), 'icon' => 'edit', 'url' => route('users.edit', $this->id), 'permission' => 'update-auth-users', 'attributes' => [ - 'id' => 'index-line-actions-show-user-' . $this->id, + 'id' => 'index-line-actions-edit-user-' . $this->id, ], ]; diff --git a/resources/views/auth/users/index.blade.php b/resources/views/auth/users/index.blade.php index e7ac922dd..ddeb0518a 100644 --- a/resources/views/auth/users/index.blade.php +++ b/resources/views/auth/users/index.blade.php @@ -46,7 +46,7 @@ @foreach($users as $item) - + + + {{ $user->name }} + + + + @if (! $user->enabled) + + @endif + + + + + + @stack('create_button_start') + + @stack('edit_button_start') + + @can('update-auth-users') + + {{ trans('general.edit') }} + + @endcan + + @stack('edit_button_end') + + + + @stack('more_button_start') + + + + more_horiz + + + @stack('delete_button_start') + + @can('delete-auth-users') + + @endcan + + @stack('delete_button_end') + + + @stack('more_button_end') + + + + + + @stack('profile_start') + + + + @if (setting('default.use_gravatar', '0') == '1') + + @elseif (is_object($user->picture)) + + @else + + @endif + + + {{ $user->email }} + + + + + + + + + @stack('name_input_start') + @stack('name_input_end') + + @stack('logo_input_start') + @stack('logo_input_end') + + @stack('email_input_start') + @stack('email_input_end') + + @stack('roles_input_start') +
+
{{ trans_choice('general.roles', 1) }}
+ {{ $user->roles()?->first()?->display_name }} +
+ @stack('roles_input_end') + + @stack('landing_page_input_start') +
+
{{ trans('auth.landing_page') }}
+ {{ $landing_pages[$user->landing_page] }} +
+ @stack('landing_page_input_end') + + @stack('locale_input_start') +
+
{{ trans_choice('general.languages', 1) }}
+ {{ language()->allowed()[$user->locale] }} +
+ @stack('locale_input_end') +
+ + + + + @stack('companies_nav_start') + + + + @stack('companies_nav_end') + + + + @stack('companies_tab_start') + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + @foreach($companies as $item) + @if (in_array($item->id, user()->company_ids)) + + + {{ $item->id }} + + + + +
+ {{ $item->name }} +
+ + @if (! $item->enabled) + + @endif +
+ + @if ($item->tax_number) + {{ $item->tax_number }} + @else + + @endif + +
+ + + + @if ($item->email) + {{ $item->email }} + @else + + @endif + + + @if ($item->phone) + {{ $item->phone }} + @else + + @endif + + + + + + @if ($item->country) + + @else + + @endif + + + @if ($item->currency) + + @else + + @endif + + +
+ @else + + + *** + + + + +
+ *** +
+
+ + *** + +
+ + + + *** + + + *** + + + + + + *** + + + *** + + +
+ @endif + @endforeach +
+
+
+ + @stack('companies_tab_end') +
+
+
+
+ +
+ + +