user photo add

This commit is contained in:
Билай Станислав 2024-12-25 16:32:23 +03:00
parent 2790105a7d
commit b5b7befd34
18 changed files with 92 additions and 38 deletions

View File

@ -36,7 +36,9 @@ class FileUpload
$newFileName = md5(time() . $this->fileName) . '.' . $this->fileExtension; $newFileName = md5(time() . $this->fileName) . '.' . $this->fileExtension;
if (in_array($this->fileExtension, $this->allowedFileExtensions)) { if (in_array($this->fileExtension, $this->allowedFileExtensions)) {
$this->uploadDir = $uploadDir . mb_substr($newFileName, 0, 2) . '/' . mb_substr($newFileName, 2, 2) . '/'; $this->uploadDir = $uploadDir . mb_substr($newFileName, 0, 2) . '/' . mb_substr($newFileName, 2, 2) . '/';
mkdir(ROOT_DIR . $this->uploadDir, 0777, true); $oldMask = umask(0);
mkdir(ROOT_DIR . $this->uploadDir, 0775, true);
umask($oldMask);
$uploadFileDir = ROOT_DIR . $this->uploadDir; $uploadFileDir = ROOT_DIR . $this->uploadDir;
$this->destPath = $uploadFileDir . $newFileName; $this->destPath = $uploadFileDir . $newFileName;
$this->uploadFile = $this->uploadDir . $newFileName; $this->uploadFile = $this->uploadDir . $newFileName;
@ -49,7 +51,9 @@ class FileUpload
} else { } else {
if (in_array($this->fileExtension, $this->allowedFileExtensions)) { if (in_array($this->fileExtension, $this->allowedFileExtensions)) {
$this->uploadDir = $uploadDir; $this->uploadDir = $uploadDir;
mkdir(ROOT_DIR . $this->uploadDir, 0777, true); $oldMask = umask(0);
mkdir(ROOT_DIR . $this->uploadDir, 0775, true);
umask($oldMask);
$uploadFileDir = ROOT_DIR . $this->uploadDir; $uploadFileDir = ROOT_DIR . $this->uploadDir;
$this->destPath = $uploadFileDir . $this->fileName; $this->destPath = $uploadFileDir . $this->fileName;
$this->uploadFile = $this->uploadDir . $this->fileName; $this->uploadFile = $this->uploadDir . $this->fileName;

View File

@ -27,7 +27,11 @@
<nav id="sidebar"> <nav id="sidebar">
<div class="p-4 pt-5"> <div class="p-4 pt-5">
<a href="#" class="img logo rounded-circle mb-5" <a href="#" class="img logo rounded-circle mb-5"
style="background-image: url(/resources/admin_theme/images/logo.jpg);"></a> style="background-image: url(<?= \kernel\modules\user\service\UserService::getAuthUserPhoto() ?? '/resources/images/noPhoto.png' ?>);"></a>
<!-- style="background-image: url(/resources/images/noPhoto.png);"></a>-->
<p> <p>
<?= \kernel\modules\user\service\UserService::getAuthUsername() ?> <?= \kernel\modules\user\service\UserService::getAuthUsername() ?>
</p> </p>

View File

@ -6,7 +6,7 @@ use itguild\forms\builders\SelectBuilder;
use Itguild\Tables\Filter\Filter; use Itguild\Tables\Filter\Filter;
use kernel\helpers\Debug; use kernel\helpers\Debug;
class CustomSelectFilterForAssociativeArr extends Filter class BootstrapSelectFilter extends Filter
{ {
public function fetch(): string public function fetch(): string

View File

@ -1,23 +0,0 @@
<?php
namespace kernel\filters;
use Itguild\Tables\Filter\Filter;
class CustomSelectFilter extends Filter
{
public function fetch()
{
$this->html = "<td><select class='form-control' name='$this->name'>";
foreach ($this->param as $value) {
if ($value === $this->value) {
$this->html .= "<option value='$value' selected>$value</option>";
} else {
$this->html .= "<option value='$value'>$value</option>";
}
}
$this->html .= "value='$this->value'</select></td>";
return $this->html;
}
}

View File

@ -19,12 +19,15 @@ $table = new ListEloquentTable(new EloquentDataProvider(Menu::class, [
'baseUrl' => "/admin/settings/menu", 'baseUrl' => "/admin/settings/menu",
])); ]));
$table->columns([ $table->columns([
'parent_id' => (function ($data) { 'parent_id' => function ($data) {
if ($data == 0) return null; if ($data == 0) return null;
return Menu::find($data)->label; return Menu::find($data)->label;
}), },
'icon_file' => function ($data) { 'icon_file' => function ($data) {
return $data ? "<img src='$data' width='150px'>" : ""; return $data ? "<img src='$data' width='150px'>" : "";
},
'status' => function ($data) {
return Menu::getStatus()[$data];
} }
]); ]);
$table->beforePrint(function () { $table->beforePrint(function () {

View File

@ -187,6 +187,7 @@ class ModuleShopClientController extends AdminController
'per_page' => $per_page, 'per_page' => $per_page,
'kernelService' => new KernelService(), 'kernelService' => new KernelService(),
'adminThemeService' => new AdminThemeService(), 'adminThemeService' => new AdminThemeService(),
'filterValues' => $filters
]); ]);
} else { } else {
$this->cgView->render("module_shop_error_connection.php"); $this->cgView->render("module_shop_error_connection.php");

View File

@ -7,11 +7,11 @@
* @var \kernel\services\ModuleService $moduleService * @var \kernel\services\ModuleService $moduleService
* @var \kernel\services\KernelService $kernelService * @var \kernel\services\KernelService $kernelService
* @var \kernel\services\AdminThemeService $adminThemeService * @var \kernel\services\AdminThemeService $adminThemeService
* @var array $filterValues
*/ */
use Itguild\Tables\ListJsonTable; use Itguild\Tables\ListJsonTable;
use kernel\widgets\ActionButtonWidget; use kernel\widgets\ActionButtonWidget;
$meta = []; $meta = [];
$meta['columns'] = [ $meta['columns'] = [
"name" => "Название", "name" => "Название",
@ -42,9 +42,12 @@ $table->addAction(function ($row, $url) use ($moduleService) {
$table->columns([ $table->columns([
'type' => [ 'type' => [
'filter' => [ 'filter' => [
'class' => \kernel\filters\CustomSelectFilter::class, 'class' => \kernel\filters\BootstrapSelectFilter::class,
'param' => ['kernel', 'entity'], 'param' => [
'value' => "kernel" 'kernel' => 'kernel',
'entity' => 'entity',
],
'value' => $filterValues['type'] ?? ''
], ],
] ]
]); ]);

View File

@ -72,7 +72,7 @@ $table->columns([
return User::find($data)->username; return User::find($data)->username;
}, },
'filter' => [ 'filter' => [
'class' => \kernel\filters\CustomSelectFilterForAssociativeArr::class, 'class' => \kernel\filters\BootstrapSelectFilter::class,
'param' => \kernel\modules\user\service\UserService::createUsernameArr(), 'param' => \kernel\modules\user\service\UserService::createUsernameArr(),
'value' => $get['user_id'] ?? '' 'value' => $get['user_id'] ?? ''
] ]

View File

@ -6,6 +6,8 @@ use Exception;
use JetBrains\PhpStorm\NoReturn; use JetBrains\PhpStorm\NoReturn;
use kernel\AdminController; use kernel\AdminController;
use kernel\EntityRelation; use kernel\EntityRelation;
use kernel\FileUpload;
use kernel\helpers\Debug;
use kernel\modules\user\models\forms\CreateUserForm; use kernel\modules\user\models\forms\CreateUserForm;
use kernel\modules\user\models\User; use kernel\modules\user\models\User;
use kernel\modules\user\service\UserService; use kernel\modules\user\service\UserService;
@ -35,10 +37,17 @@ class UserController extends AdminController
{ {
$userForm = new CreateUserForm(); $userForm = new CreateUserForm();
$userForm->load($_REQUEST); $userForm->load($_REQUEST);
if (isset($_FILES['user_photo']) && $_FILES['user_photo']['error'] === UPLOAD_ERR_OK) {
$file = new FileUpload($_FILES['user_photo'], ['jpg', 'jpeg', 'png']);
$file->upload();
$userForm->setItem('user_photo', $file->getUploadFile());
}
if ($userForm->validate()){ if ($userForm->validate()){
$user = $this->userService->create($userForm); $user = $this->userService->create($userForm);
$entityRelation = new EntityRelation(); $entityRelation = new EntityRelation();
$entityRelation->saveEntityRelation(entity: "user", model: $user, request: new Request()); $entityRelation->saveEntityRelation(entity: "user", model: $user, request: new Request());
@ -98,6 +107,13 @@ class UserController extends AdminController
$userForm = new CreateUserForm(); $userForm = new CreateUserForm();
$userService = new UserService(); $userService = new UserService();
$userForm->load($_REQUEST); $userForm->load($_REQUEST);
if (isset($_FILES['user_photo']) && $_FILES['user_photo']['error'] === UPLOAD_ERR_OK) {
$file = new FileUpload($_FILES['user_photo'], ['jpg', 'jpeg', 'png']);
$file->upload();
$userForm->setItem('user_photo', $file->getUploadFile());
}
if ($userForm->validateForUpdate()){ if ($userForm->validateForUpdate()){
$user = $userService->update($userForm, $user); $user = $userService->update($userForm, $user);

View File

@ -20,6 +20,7 @@ return new class extends Migration
$table->string('username', 255)->nullable(false); $table->string('username', 255)->nullable(false);
$table->string('email', 255); $table->string('email', 255);
$table->string('password_hash', 255); $table->string('password_hash', 255);
$table->string('user_photo', 255)->nullable();
$table->integer('role')->default(1); $table->integer('role')->default(1);
$table->string('access_token', 255)->nullable(true); $table->string('access_token', 255)->nullable(true);
$table->dateTime('access_token_expires_at')->nullable(true); $table->dateTime('access_token_expires_at')->nullable(true);

View File

@ -7,6 +7,7 @@ use Illuminate\Database\Eloquent\Model;
* @property string $username * @property string $username
* @property string $email * @property string $email
* @property string $password_hash * @property string $password_hash
* @property string $user_photo
* @property string $access_token * @property string $access_token
* @property string $access_token_expires_at * @property string $access_token_expires_at
* @method static find($id) * @method static find($id)
@ -17,7 +18,7 @@ class User extends Model {
const ADMIN_USER_ROLE = 9; const ADMIN_USER_ROLE = 9;
protected $table = 'user'; protected $table = 'user';
protected $fillable = ['username', 'email', 'password_hash', 'role', 'access_token', 'access_token_expires_at']; protected $fillable = ['username', 'email', 'password_hash', 'user_photo', 'role', 'access_token', 'access_token_expires_at'];
protected array $dates = ['deleted at']; protected array $dates = ['deleted at'];
public static function labels(): array public static function labels(): array
@ -25,6 +26,7 @@ class User extends Model {
return [ return [
'username' => 'Логин', 'username' => 'Логин',
'email' => 'Email', 'email' => 'Email',
'user_photo' => 'Фото профиля',
'created_at' => 'Создан', 'created_at' => 'Создан',
'updated_at' => 'Обновлен', 'updated_at' => 'Обновлен',
]; ];

View File

@ -12,7 +12,8 @@ class CreateUserForm extends FormModel
return [ return [
'username' => 'required|min-str-len:5|max-str-len:30', 'username' => 'required|min-str-len:5|max-str-len:30',
'password' => 'required|min-str-len:5|max-str-len:30', 'password' => 'required|min-str-len:5|max-str-len:30',
'email' => 'required|email' 'email' => 'required|email',
'user_photo' => ''
]; ];
} }
@ -21,7 +22,9 @@ class CreateUserForm extends FormModel
return [ return [
'username' => 'required|min-str-len:5|max-str-len:30', 'username' => 'required|min-str-len:5|max-str-len:30',
'password' => '', 'password' => '',
'email' => 'required|email' 'email' => 'required|email',
'user_photo' => ''
]; ];
} }

View File

@ -15,6 +15,7 @@ class UserService
$model->username = $form_model->getItem('username'); $model->username = $form_model->getItem('username');
$model->email = $form_model->getItem('email'); $model->email = $form_model->getItem('email');
$model->password_hash = password_hash($form_model->getItem('password'), PASSWORD_DEFAULT); $model->password_hash = password_hash($form_model->getItem('password'), PASSWORD_DEFAULT);
$model->user_photo = $form_model->getItem('user_photo');
if ($model->save()){ if ($model->save()){
return $model; return $model;
} }
@ -29,6 +30,7 @@ class UserService
if ($form_model->getItem('password')) { if ($form_model->getItem('password')) {
$user->password_hash = password_hash($form_model->getItem('password'), PASSWORD_DEFAULT); $user->password_hash = password_hash($form_model->getItem('password'), PASSWORD_DEFAULT);
} }
$user->user_photo = $form_model->getItem('user_photo');
if ($user->save()){ if ($user->save()){
return $user; return $user;
} }
@ -80,6 +82,18 @@ class UserService
return ''; return '';
} }
public static function getAuthUserPhoto(): string|null
{
$user = self::getAuthUser();
if ($user){
if ($user->user_photo) {
return $user->user_photo;
}
}
return null;
}
public function getByAccessToken(string $token) public function getByAccessToken(string $token)
{ {
return $this->getByField("access_token", $token); return $this->getByField("access_token", $token);

View File

@ -32,6 +32,16 @@ $form->field(class: \itguild\forms\inputs\TextInput::class, name: "email", param
->setLabel("Email") ->setLabel("Email")
->render(); ->render();
if (!empty($model->user_photo)){
echo "<div><img src='$model->user_photo' width='200px'></div>";
}
$form->field(class: \itguild\forms\inputs\File::class, name: "user_photo", params: [
'class' => "form-control",
'value' => $model->user_photo ?? ''
])
->setLabel("Фото профиля")
->render();
$entityRelations = new \kernel\EntityRelation(); $entityRelations = new \kernel\EntityRelation();
if (!isset($model)) { if (!isset($model)) {
$model = new User(); $model = new User();

View File

@ -40,6 +40,9 @@ $table->columns([
'class' => \Itguild\Tables\Filter\InputTextFilter::class 'class' => \Itguild\Tables\Filter\InputTextFilter::class
] ]
], ],
'user_photo' => function ($data) {
return $data ? "<img src='$data' width='150px'>" : "";
},
'created_at' => function ($data) { 'created_at' => function ($data) {
if (!$data){ if (!$data){
return null; return null;

View File

@ -35,6 +35,9 @@ foreach ($additionals as $key => $additional) {
} }
$table->rows([ $table->rows([
'user_photo' => function ($data) {
return $data ? "<img src='$data' width='300px'>" : "";
},
'created_at' => function ($data) { 'created_at' => function ($data) {
if (!$data){ if (!$data){
return null; return null;

View File

@ -51,6 +51,16 @@ $table = new \Itguild\Tables\ListJsonTable(json_encode(
] ]
)); ));
// Пример фильтра
$table->columns([
'title' => [
'filter' => [
'class' => \Itguild\Tables\Filter\InputTextFilter::class,
'value' => $get['title'] ?? ''
]
],
]
$table->beforePrint(function () { $table->beforePrint(function () {
return IconBtnCreateWidget::create(['url' => '/admin/{slug}/create'])->run(); return IconBtnCreateWidget::create(['url' => '/admin/{slug}/create'])->run();
}); });

Binary file not shown.

After

Width:  |  Height:  |  Size: 4.0 KiB