Загрузка файла в один клик в Drupal формах

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

Рассмотрим шаблон, генерируемый Drupal для поля загрузки файла.

Предусмотрена следующая логика:

  • пользователь читает описание поля,
  • нажимает на кнопку «Выберите файл» (появляется диалог выбора файла),
  • выбирает файл на локальном носителе (диалог скрывается, а имя файла появляется в поле на форме),
  • пользователь нажимает «закачать», чтобы файл был отправлен на сервер

Хотя нажимать кнопку «закачать» — не является обязательным действием сразу после выбора файла, но пользователи путаются в этих лишних кнопках, раздражаются и тратят больше времени, чем необходимо. А все файлы итак будут загружены при отправке формы.

Это лишнее действие следует оптимизировать.

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

Загрузка сразу при выборе файла

Нажмем кнопку загрузки файла за пользователя, при этом саму кнопку спрячем, чтобы она не отвлекала внимание.

Выполнять эту не хитрую операцию будет следующий скрипт:

Оформлен код в виде behaviors, в первую очередь для того, чтобы это работало также и для форм, подгружаемых динамически по ajax.

Чтобы скрыть кнопку, я добавляю стили вроде следующего:

Скрипт можно подключить глобально в вашу тему или выборочно к нужным формам. Пример подключения скрипта только к веб-формам:

Мало букафф? Читайте есчо !

Добавление пунктов меню в Administration menu (admin_menu)

Апрель 8, 2020 г.

Популярный административный модуль admin_menu, собирает всё самое нужное и важное для управления сайтом. И хотя в 7 версии в ядре вы найдете модуль tool, обладающий похожим функционалом, ему не удалось заменить admin_menu. Далее, разберем код, добавляющий ...

Читать

Программно выводим блок в Drupal

Февраль 7, 2019 г.

Если вы решили вывести блок, реализованный в каком либо модуле, программно, то следующие  примеры кода помогут вам. Используя block API Запрашиваем данные блока через API, готовим массив для последующего рендеринга: [crayon-6987d0ebd13d9759379255/] ...

Читать

Удалить список публикаций со страницы термина таксономии в Drupal

Апрель 10, 2021 г.

Стандартный шаблон страницы термина таксономии taxonomy-term.tpl.php не позволяет управлять выводом публикаций, он лишь служит как обертка для полей термина. Единственная настройка CMS, которая влияет на вывод списка - это переменная default_nodes_main, ...

Читать

Программно устанавливаем значения настроек на страницах, созданных Config Pages

Ноябрь 22, 2018 г.

Модуль Config Pages позволяет создавать страницы конфигурации для вашего модуля, всего сайта, или может быть просто одного из разделов сайта. Потом эти значения можно читать из программы и использовать так, как вам требуется. Но API Config Pages не содержит ...

Читать
 

Комментарии к «Загрузка файла в один клик в Drupal формах»

Понравилась статья? Есть вопросы? - пишите в комментариях.



Комментарий: