<?php use app\assets\FontAwesomeAsset; use app\models\PublicKeyCredentialSourceRepository; use app\models\User; use app\utils\FileSizeHelper; use app\utils\IPLocation; use kartik\editable\Editable; use yii\bootstrap5\ActiveForm; use yii\bootstrap5\Modal; use yii\helpers\Html; use yii\web\YiiAsset; use yii\widgets\DetailView; /** @var yii\web\View $this */ /** @var app\models\User $model */ $this->title = '用户ID: ' . $model->id; $this->params['breadcrumbs'][] = ['label' => '用户管理', 'url' => ['user']]; $this->params['breadcrumbs'][] = $this->title; $alreadyDisabled = $model->status == 0; $IPLocation = new IPLocation(); YiiAsset::register($this); FontAwesomeAsset::register($this); $this->registerCssFile('@web/css/admin-userv.css'); ?> <div class="user-view"> <h1>用户详情</h1> <p> <?= Html::a('禁用二步验证', ['user-totpoff', 'id' => $model->id], [ 'class' => 'btn btn-danger' . ($model->is_otp_enabled == 0 ? ' disabled' : ''), 'data' => [ 'confirm' => '你确定要取消这个用户的多因素登录吗?', 'method' => 'post', ], 'title' => '点击取消用户的多因素登录', ]) ?> <?= Html::button('重置密码', [ 'class' => 'btn btn-danger', 'data-bs-toggle' => 'modal', 'data-bs-target' => '#resetPasswordModal', 'title' => '点击重置用户密码', ]) ?> </p> <?= DetailView::widget([ 'model' => $model, 'attributes' => [ ['attribute' => 'id', 'label' => '用户ID'], ['attribute' => 'username', 'label' => '用户名'], ['attribute' => 'name', 'label' => '昵称', 'format' => 'raw', 'value' => function ($model) { return Editable::widget([ 'name' => 'name', 'asPopover' => true, 'value' => $model->name, 'header' => '昵称', 'size' => 'md', 'options' => ['class' => 'form-control', 'placeholder' => '在这里输入新的昵称...'], ]); }], ['attribute' => 'email', 'label' => '电子邮件'], ['label' => '头像', 'format' => 'html', 'value' => function ($model) { return $model->getGravatar(email: $model->email, s: 100, img: true); }], ['attribute' => 'status', 'label' => '账户状态', 'format' => 'raw', 'value' => function ($model) { if (Yii::$app->user->id == $model->id) { return $model->status == 0 ? '禁用' : '启用'; } return Editable::widget([ 'name' => 'status', 'value' => $model->status == 0 ? '禁用' : '启用', 'asPopover' => true, 'header' => '账户状态', 'format' => Editable::FORMAT_BUTTON, 'inputType' => Editable::INPUT_DROPDOWN_LIST, 'data' => [0 => '禁用', 1 => '启用',], 'options' => ['class' => 'form-control'], ]); }], ['attribute' => 'created_at', 'label' => '创建时间', 'value' => function ($model) { // 日期时间 (xx天前) return $model->created_at . ' (' . Yii::$app->formatter->asRelativeTime(new DateTime($model->created_at, new DateTimeZone('GMT+8'))) . ')'; }], ['attribute' => 'last_login', 'label' => '最后登录时间', 'value' => function ($model) { // 日期时间 (xx天前) return $model->last_login . ' (' . Yii::$app->formatter->asRelativeTime(new DateTime($model->last_login, new DateTimeZone('GMT+8'))) . ')'; }], ['attribute' => 'last_login_ip', 'label' => '上次登录IP', 'value' => function ($model) use ($IPLocation) { if (Yii::$app->params['enableIpInfo']) { return $IPLocation->getFormatDetails($model->last_login_ip); } else { return $model->last_login_ip; } }], ['attribute' => 'bio', 'label' => '用户简介', 'format' => 'raw', 'value' => function ($model) { return Editable::widget([ 'name' => 'bio', 'asPopover' => true, 'displayValue' => '查看', 'inputType' => Editable::INPUT_TEXTAREA, 'value' => $model->bio, 'header' => '用户简介', 'submitOnEnter' => false, 'size' => 'lg', 'options' => ['class' => 'form-control', 'rows' => 5] ]); }], ['attribute' => 'role', 'label' => '用户身份', 'value' => function ($model) { return $model->role == 'user' ? '用户' : '管理员'; }], ['attribute' => 'is_otp_enabled', 'label' => '多因素登录', 'value' => function ($model) { return $model->is_otp_enabled == 0 ? '禁用' : '启用'; }], ['label' => 'Passkey', 'value' => function ($Model) { $PKCSR = new PublicKeyCredentialSourceRepository(); $UserEntitys = $PKCSR->findAllForUserEntity($Model); if (empty($UserEntitys)) { return '禁用'; } else { return '启用'; } }], ['label' => '保险箱状态', 'value' => function ($model) { if ($model->role == 'admin') { return '不可用'; } return empty($model->vault_secret) ? '未初始化' : '已启用'; }], ['label' => '网盘已用空间', 'value' => function ($model) { if ($model->role == 'admin') { return '不可用'; } return FileSizeHelper::formatBytes(FileSizeHelper::getUserHomeDirSize($model->id)); }], ['label' => '保险箱已用空间', 'value' => function ($model) { if ($model->role == 'admin') { return '不可用'; } return FileSizeHelper::formatBytes(FileSizeHelper::getUserVaultDirSize($model->id)); }], // ['attribute' => 'storage_limit', 'label' => '存储容量限制', 'value' => function ($model) { // if ($model->role == 'admin') { // return '不可用'; // } // return FileSizeHelper::formatMegaBytes($model->storage_limit); // }], ['attribute' => 'storage_limit', 'label' => '存储容量限制', 'format' => 'raw', 'value' => function ($model) { if ($model->role == 'admin') { return '不可用'; } return Editable::widget([ 'name' => 'storage_limit', 'asPopover' => true, 'value' => FileSizeHelper::formatMegaBytes($model->storage_limit), 'header' => '存储容量限制(最小1MB)', 'size' => 'md', 'options' => ['class' => 'form-control', 'placeholder' => '在这里输入容量限制(最小值为1MB)...'], ]); }], ['attribute' => 'storage_limit', 'format' => 'html', 'label' => '存储空间使用状态', 'value' => function ($model) { if ($model->role == 'admin') { return '不可用'; } return FileSizeHelper::getUsedPercent($model->id) . '<br>' . FileSizeHelper::getFormatUserAllDirSize($model->id) . ' / ' . FileSizeHelper::formatMegaBytes($model->storage_limit); }], ], ]) ?> </div> <?php Modal::begin([ 'title' => '<h4>重置密码</h4>', 'id' => 'resetPasswordModal', 'size' => 'modal-lg', ]); $form = ActiveForm::begin(['id' => 'reset-password-form', 'action' => ['admin/user-pwdreset'], 'method' => 'post']); echo $form->field($model, 'id')->hiddenInput()->label(false); echo $form->field($model, 'password')->passwordInput(['maxlength' => true, 'value' => ''])->label('新密码'); echo Html::submitButton('提交', ['class' => 'btn btn-primary']); ActiveForm::end(); Modal::end(); ?>