Добро пожаловать на сайт SEDBY

Используем плагин Attach2 для работы с изображениями в тексте страницы

Популярные запросы: тема Omnis, плагин Pagelist, Cotonti 0.9.24.2, ЧПУ, Font Face

  • 296 просмотров
  • 1 мая, 2024
  • Обновлено: 2 июня, 2024
  • admin
  • Время чтения: 3 минуты
  • 1 (Подробно)

Плагин Attach2 был и остается одним из самых функциональных и одновременно простых и компактных решений для работы с изображениями в среде разработки Cotonti Siena. Плагин отлично приспособлен для генерирования в TPL-шаблоне миниатюр любых размеров с массой настроек и параметров. Это реализуется с помощью связки функций att_get() и att_thumb(). Первая получает оригинальное изображение, прикрепленное к объекту, а вторая “режет” миниатюру с указанными размерами (высота и ширина) и алгоритмом кадрирования (ширина, высота или обрезка).

Все это отлично работает в шаблоне, но иногда возникает необходимость использовать миниатюры в тексте страницы или, например, форумного поста. Правда использовать функцию в тексте непросто. Для этого надо создать специальный тег, парсить текст и оформлять вывод миниатюр. Проще придумать способ предварительной нарезки картинок и быстрой вставки их в текст страницы. Для этого я использую следующий алгоритм.

1. Нарезаем миниатюры

Как говорил известный персонаж,

Для того, чтобы что-нибудь продать, надо сперва что-нибудь купить.

Примерно так же обстоит дело и с нашими картинками. Предположим, мы прикрепили к странице несколько штук. Конечно, можно прямо из всплывающего окна скопировать ссылку на оригинал. И, как простой вариант, это тоже будет работать. Но мы пойдем другим путем.

Поскольку страница у нас создана, нам не хватает только локации, в которой можно единообразно нарезать все “аттачи”. Почему не использовать для этого режим правки страницы? Ведь доступ к нему есть только у соответствующих групп. Так что откроем шаблон page.edit.tpl и где-нибудь после формы правки страницы вставим следующий код:

...
		</form>
		{PAGEEDIT_FORM_ID|att_gallery('page', $this, 'attach2.edit')}
	</div>
...

Технически, мы просто добавили фотогалерею в шаблон правки страницы. Это позволит нам нарезать миниатюры необходимых (и одинаковых) размеров и пропорций. Именно то, что требуется.

Теперь оформим шаблон attach2.edit.tpl Разместить его можно в папке с шаблонами плагинов нашей темы (plugins/ или plugins/attach2/). Код будет следующий:

<!-- BEGIN: MAIN -->
<ul class="list-unstyled attachments">
<!-- BEGIN: ATTACH_ROW -->
	<li>
		<blockquote class="mb-2">{ATTACH_ROW_ID|att_thumb($this, 966, 644, 'width')}</blockquote>
		<img src="{ATTACH_ROW_ID|att_thumb($this, 1000, 600, 'crop')}" alt="{ATTACH_ROW_FILENAME}" class="img-fluid" />
	</li>
<!-- END: ATTACH_ROW -->
</ul>
<!-- END: MAIN -->

Ничего сложного. Единственный момент: мы вывели в шаблоне путь к картинке – чтобы быстро скопировать ее для вставки в тело страницы через CKEditor.

2. Упрощаем копирование пути к картинке

Шаг второй. Поскольку выделять и копировать путь все же слегка непродуктивно, почему бы не использовать jQuery для того, чтобы получить путь к картинке в один клик? И, раз уж мы делаем все правильно, добавим к пути и домен. Исходя из опыта, могу сказать что это часто оказывается необходимым.

Чтобы не делать строку с путем слишком длинной, спрячем домен сайта в какой-нибудь атрибут. Назовем его data-domain. Миниатюру сделаем кликабельной и добавим режим просмотра аттачей в режиме фотогалереи:

<!-- BEGIN: MAIN -->
<ul class="list-unstyled attachments">
<!-- BEGIN: ATTACH_ROW -->
	<li>
		<blockquote class="mb-2" title="Кликни чтобы скопировать" data-domain="{PHP.cfg.mainurl}/">{ATTACH_ROW_ID|att_thumb($this, 1000, 600, 'width')}</blockquote>
		<a href="{ATTACH_ROW_URL}" class="fancybox" rel="gallery" title="{ATTACH_ROW_TITLE}" >
			<img src="{ATTACH_ROW_ID|att_thumb($this, 1000, 600, 'width')}" alt="{ATTACH_ROW_FILENAME}" class="img-fluid" />
		</a>
	</li>
<!-- END: ATTACH_ROW -->
</ul>
<!-- END: MAIN -->

Теперь сам скрипт:

$(document).ready(function() {
	// Click to copy
	if ($('ul.attachments').length > 0) {
		$('blockquote').on("click", function() {
			value = $(this).attr('data-domain') + $(this).text(); // Формируем полный путь
			var $temp = $("<input>"); // Новый элемент в DOM
			$("body").append($temp);
			$temp.val(value).select(); // Выбираем его значение (путь)
			document.execCommand("copy"); // Копируем значение в буфер обмена
			$temp.remove(); // Удаляем созданный элемент из DOM
		});
	};
...
});

Вот, собственно и все. Оформить нашу импровизированную галерею можете на свой вкус. У меня это выглядит примерно так:

Минигалерея изображений, прикрепленных к странице из локации правки

Теперь у нас есть простой и пуленепробиваемый инструмент для генерации и добавления в текст страницы прикрепленных к ней картинок. Вполне возможно, есть и другие, более продуктивные способы. Вы можете поделиться ими в комментариях или на форумах.

Ранее мы рассказывали о том, как создать кастомную страницу 404 на Котонти.

Аватар

Я думаю, лучше будет width – чтобы без обрезки картинка вставлялась

Аватар

Всё-таки режим width или crop?

Аватар

Круто! Нужно попробовать. Как протестирую, напишу, если будут вопросы.

Новый комментарий

Имя:
Для редактирования комментария осталось 10 минут
Блок пользователя
Регистрация на нашем сайте позволит вам общаться на форумах и получить доступ к другому полезному функционалу
Вы вошли как Гость