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

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

Исторически я всегда использовал сервис 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, так что все картинки опять хранятся у меня на сервере. Можно авторизоваться и настраивать профиль.

Комментарии (1)
Это сообщение было удалено
ЕвгенийК
09.04.2022 03:35
Это хорошо, что такая возможность есть и может быть использована. А то тенденция, мания, что-то в по...
begoodco1
07.04.2022 05:49
Зарегистрировался чтобы выразить благодарность за доступное и подробное описание процесса. Была возм...
bezumkin
Василий Наумкин
18.03.2022 12:35
Авторизация есть из коробки, для входа в базовую админку. Можно установить через composer и собрать ...
bezumkin
Василий Наумкин
10.03.2022 12:08
Ну, я имел в виду, что по закону можно =) А в реальности с валютой очевидные проблемы.
Сергей Лелеко
04.03.2022 06:12
О как! не знал! спасибо
bezumkin
Василий Наумкин
01.03.2022 15:32
Я делал одного бота на botman/botman, но из-за своей универсальности конкретно с Телеграм на нём раб...
bezumkin
Василий Наумкин
25.02.2022 09:22
P.S. Кажется цитаты у тебя никак не стилизуются в комментариях... Спасибо, поправил!
Electrica
Михаил
08.02.2022 11:19
Работает!
Алексей
09.01.2019 10:55
Насыщенный год ) От души поздравляю с ДР! Счастья, успехов и семейного благополучия! Жаль лимит заме...
septa rose
28.05.2018 22:16
hmmm, keren abis