Аватарки на сайте

Продолжаю приводить новую версию в порядок, и теперь дело дошло до работы с аватарками.

Исторически я всегда использовал сервис Gravatar. который позволяет вывести фотку пользователя по md5 хэшу от его email. Идея отличная: ты грузишь аватарку один раз и все сайты, на которых ты зарегистрирован, могут её получить.

Но, во-первых, не все пользователи про это знают. И во-вторых, это всё-таки сторонний сервис, который может перестать работать и я останусь без аватарок.

Поэтому на моих сайтах всегда была возможность загрузить аватарку самостоятельно, и теперь я решил реализовать её как давно хотел (нажмите на картинку для запуска GIFки).

По катом немного подробностей.

Работа с аватаркой происходит в разделе настроек профиля пользователя через CropperJs. Загрузку файлов через выбор из браузера и drag-n-drop я рассказывал в прошлой заметке. Тут ничего нового.

А вот обрезать аватарки я не стал, сохраняя вместо этого область выделения как свойство загруженного файла. Поэтому при запросе картинки через контроллер Image можно проверять, есть ли у файла параметр crop, и передавать его библиотеке Glide, которая используется в Vesp из коробки.

Просто расширяем родной контроллер и добавляем проверку:

<?php

namespace App\Controllers;

use Psr\Http\Message\ResponseInterface;
use App\Models\File;

class Image extends \Vesp\Controllers\Data\Image
{
    public function get(): ResponseInterface
    {
        // Получаем файл по ID только если у него есть метаданные
        if ($file = File::query()->whereNotNull('metadata')->find($this->getProperty('id'))) {
            // И если в метаданных есть обрезка
            if ($crop = @$file->metadata['crop']) {
                // Собираем и выставляем дополнительные параметры 
                // для родительского контроллера
                $data = implode(',', [$crop['width'], $crop['height'], $crop['x'], $crop['y']])
                $this->setProperty('crop', $data);
            }
        }
        // Передаём работу родительскому контроллеру
        return parent::get();
    }
}

С одной стороны, это дополнительный запрос в БД на каждый файл, а с другой получается очень красиво и удобно. Теперь пользователь всегда может не только загрузить свою аватарку, но и отредактировать область отображения без новой загрузки.

Дальше дело техники. К модели пользователя привязан файл и все данные (заметки и комментарии) выбираются с этой привязкой.

Наличие картинки проверяется прямо на фронтенде. Если она есть, то выводится ссылка на аватар, которая правильно обрезается контроллером. Если нет, то показываем аватар по умолчанию.

Старым пользователям я подгрузил картинки из Gravatar, так что все картинки опять хранятся у меня на сервере. Можно авторизоваться и настраивать профиль.

← Предыдущая заметка
Работа с картинками
Следующая заметка →
Загрузка видеофайлов
Комментарии (0)
bezumkin
Василий Наумкин
09.04.2024 01:45
Ошибка 500 Это не похоже на ошибку Nginx, это скорее всего ошибка PHP - надо смотреть его логи. Во...
futuris
Futuris
04.04.2024 05:56
Я просто немного запутался. Когда в абзаце &quot;Vesp/Core&quot; ты пишешь про &quot;новый trait Fil...
bezumkin
Василий Наумкин
20.03.2024 18:21
Volledig!
Андрей
14.03.2024 10:47
Василий! Как всегда очень круто! Моё почтение!
russelgal
russel gal
09.03.2024 17:17
А этот стоило написать хотя бы затем, чтобы получить комментарий от юзера, который ничего не писал ...
inetlover
Александр Наумов
27.01.2024 00:06
Василий, спасибо! Извини, тупанул.
bezumkin
Василий Наумкин
22.01.2024 04:43
Давай-давай!
bezumkin
Василий Наумкин
24.12.2023 11:26
Спасибо!
bezumkin
Василий Наумкин
27.11.2023 02:43
Ура!
bezumkin
Василий Наумкин
25.11.2023 08:30
Vesp тянет 2 зависимости: vesp-frontent для фронта и vesp-core для бэкенда. Их можно обновлять, но э...