271 lines
6.9 KiB
PHP
271 lines
6.9 KiB
PHP
<?php
|
|
|
|
namespace Kirby\Panel;
|
|
|
|
/**
|
|
* Provides information about the user model for the Panel
|
|
* @since 3.6.0
|
|
*
|
|
* @package Kirby Panel
|
|
* @author Nico Hoffmann <nico@getkirby.com>
|
|
* @link https://getkirby.com
|
|
* @copyright Bastian Allgeier
|
|
* @license https://getkirby.com/license
|
|
*/
|
|
class User extends Model
|
|
{
|
|
/**
|
|
* @var \Kirby\Cms\User
|
|
*/
|
|
protected $model;
|
|
|
|
/**
|
|
* Breadcrumb array
|
|
*
|
|
* @return array
|
|
*/
|
|
public function breadcrumb(): array
|
|
{
|
|
return [
|
|
[
|
|
'label' => $this->model->username(),
|
|
'link' => $this->url(true),
|
|
]
|
|
];
|
|
}
|
|
|
|
/**
|
|
* Provides options for the user dropdown
|
|
*
|
|
* @param array $options
|
|
* @return array
|
|
*/
|
|
public function dropdown(array $options = []): array
|
|
{
|
|
$account = $this->model->isLoggedIn();
|
|
$i18nPrefix = $account ? 'account' : 'user';
|
|
$permissions = $this->options(['preview']);
|
|
$url = $this->url(true);
|
|
$result = [];
|
|
|
|
$result[] = [
|
|
'dialog' => $url . '/changeName',
|
|
'icon' => 'title',
|
|
'text' => t($i18nPrefix . '.changeName'),
|
|
'disabled' => $this->isDisabledDropdownOption('changeName', $options, $permissions)
|
|
];
|
|
|
|
$result[] = '-';
|
|
|
|
$result[] = [
|
|
'dialog' => $url . '/changeEmail',
|
|
'icon' => 'email',
|
|
'text' => t('user.changeEmail'),
|
|
'disabled' => $this->isDisabledDropdownOption('changeEmail', $options, $permissions)
|
|
];
|
|
|
|
$result[] = [
|
|
'dialog' => $url . '/changeRole',
|
|
'icon' => 'bolt',
|
|
'text' => t('user.changeRole'),
|
|
'disabled' => $this->isDisabledDropdownOption('changeRole', $options, $permissions)
|
|
];
|
|
|
|
$result[] = [
|
|
'dialog' => $url . '/changePassword',
|
|
'icon' => 'key',
|
|
'text' => t('user.changePassword'),
|
|
'disabled' => $this->isDisabledDropdownOption('changePassword', $options, $permissions)
|
|
];
|
|
|
|
$result[] = [
|
|
'dialog' => $url . '/changeLanguage',
|
|
'icon' => 'globe',
|
|
'text' => t('user.changeLanguage'),
|
|
'disabled' => $this->isDisabledDropdownOption('changeLanguage', $options, $permissions)
|
|
];
|
|
|
|
$result[] = '-';
|
|
|
|
$result[] = [
|
|
'dialog' => $url . '/delete',
|
|
'icon' => 'trash',
|
|
'text' => t($i18nPrefix . '.delete'),
|
|
'disabled' => $this->isDisabledDropdownOption('delete', $options, $permissions)
|
|
];
|
|
|
|
return $result;
|
|
}
|
|
|
|
/**
|
|
* Returns the setup for a dropdown option
|
|
* which is used in the changes dropdown
|
|
* for example.
|
|
*
|
|
* @return array
|
|
*/
|
|
public function dropdownOption(): array
|
|
{
|
|
return [
|
|
'icon' => 'user',
|
|
'text' => $this->model->username(),
|
|
] + parent::dropdownOption();
|
|
}
|
|
|
|
/**
|
|
* @return string|null
|
|
*/
|
|
public function home(): ?string
|
|
{
|
|
if ($home = ($this->model->blueprint()->home() ?? null)) {
|
|
$url = $this->model->toString($home);
|
|
return url($url);
|
|
}
|
|
|
|
return Panel::url('site');
|
|
}
|
|
|
|
/**
|
|
* Default settings for the user's Panel image
|
|
*
|
|
* @return array
|
|
*/
|
|
protected function imageDefaults(): array
|
|
{
|
|
return array_merge(parent::imageDefaults(), [
|
|
'back' => 'black',
|
|
'icon' => 'user',
|
|
'ratio' => '1/1',
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* Returns the image file object based on provided query
|
|
*
|
|
* @param string|null $query
|
|
* @return \Kirby\Cms\File|\Kirby\Filesystem\Asset|null
|
|
*/
|
|
protected function imageSource(string $query = null)
|
|
{
|
|
if ($query === null) {
|
|
return $this->model->avatar();
|
|
}
|
|
|
|
return parent::imageSource($query);
|
|
}
|
|
|
|
/**
|
|
* Returns the full path without leading slash
|
|
*
|
|
* @return string
|
|
*/
|
|
public function path(): string
|
|
{
|
|
// path to your own account
|
|
if ($this->model->isLoggedIn() === true) {
|
|
return 'account';
|
|
}
|
|
|
|
return 'users/' . $this->model->id();
|
|
}
|
|
|
|
/**
|
|
* Returns prepared data for the panel user picker
|
|
*
|
|
* @param array|null $params
|
|
* @return array
|
|
*/
|
|
public function pickerData(array $params = null): array
|
|
{
|
|
$params['text'] ??= '{{ user.username }}';
|
|
|
|
return array_merge(parent::pickerData($params), [
|
|
'email' => $this->model->email(),
|
|
'username' => $this->model->username(),
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* Returns navigation array with
|
|
* previous and next user
|
|
*
|
|
* @internal
|
|
*
|
|
* @return array
|
|
*/
|
|
public function prevNext(): array
|
|
{
|
|
$user = $this->model;
|
|
|
|
return [
|
|
'next' => fn () => $this->toPrevNextLink($user->next(), 'username'),
|
|
'prev' => fn () => $this->toPrevNextLink($user->prev(), 'username')
|
|
];
|
|
}
|
|
|
|
/**
|
|
* Returns the data array for the
|
|
* view's component props
|
|
*
|
|
* @internal
|
|
*
|
|
* @return array
|
|
*/
|
|
public function props(): array
|
|
{
|
|
$user = $this->model;
|
|
$account = $user->isLoggedIn();
|
|
$avatar = $user->avatar();
|
|
|
|
return array_merge(
|
|
parent::props(),
|
|
$account ? [] : $this->prevNext(),
|
|
[
|
|
'blueprint' => $this->model->role()->name(),
|
|
'model' => [
|
|
'account' => $account,
|
|
'avatar' => $avatar ? $avatar->url() : null,
|
|
'content' => $this->content(),
|
|
'email' => $user->email(),
|
|
'id' => $user->id(),
|
|
'language' => $this->translation()->name(),
|
|
'link' => $this->url(true),
|
|
'name' => $user->name()->toString(),
|
|
'role' => $user->role()->title(),
|
|
'username' => $user->username(),
|
|
]
|
|
]
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Returns the Translation object
|
|
* for the selected Panel language
|
|
*
|
|
* @return \Kirby\Cms\Translation
|
|
*/
|
|
public function translation()
|
|
{
|
|
$kirby = $this->model->kirby();
|
|
$lang = $this->model->language();
|
|
return $kirby->translation($lang);
|
|
}
|
|
|
|
/**
|
|
* Returns the data array for
|
|
* this model's Panel view
|
|
*
|
|
* @internal
|
|
*
|
|
* @return array
|
|
*/
|
|
public function view(): array
|
|
{
|
|
return [
|
|
'breadcrumb' => $this->breadcrumb(),
|
|
'component' => 'k-user-view',
|
|
'props' => $this->props(),
|
|
'title' => $this->model->username(),
|
|
];
|
|
}
|
|
}
|