Публикация в группе: Плагин WP-Recall - Личный кабинет на WordPress

Категории группы: Обновления

Приветствую!

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

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

Все ошибки возникающие при регистрации и авторизации теперь можно получить через объект WP_Error, поэтому при кастомном добавлении какого либо своего поля в форму регистрации, можно будет легко добавить вывод своего текста ошибки при неудачной проверке этого поля, например так:

add_action('rcl_registration_errors','my_check_register_captcha');
function my_check_register_captcha($errors){
	if ( ! $rcl_captcha_correct ) { //тут проверка
        $errors = new WP_Error();
        $errors->add( 'rcl_register_captcha', __('Field filled not right CAPTCHA!','rcl') );
    }
	return $errors;
}

В этой версии плагина был полностью переписан порядок вывода пользователей на сайте. Взамен старому функционалу был написан гибкий и более более понятный класс Rcl_Users, благодаря этом добавились новые настройки в шорткод userlist. Порядок получения пользователей из базы данных стал более логичным и упорядоченным. Удалось решить проблему с неверным количеством пользователей при выводе, если был указан определенный лимит. Было настроено взаимодействие фильтров вывода пользователей и формы поиска среди пользователей, т.е. можно сначала получить через поиск всех пользователей с именем "Николай", а затем отсортировать всех Николаев по рейтингу, кол-ву публикаций или комментариев. Пользователей выводимых во вкладке своих подписчиков и подписок теперь можно также сортировать. Остановимся подробнее на новых настройках шорткода userlist.

Теперь вы можете указывать те данные которые будут выводится в списке пользователей, для этого используем новый атрибут "data", для указания выводимых данных. Например, если мы хотим вывести список пользователей с выводом текста их статусов и указанием кол-ва публикаций, то шорткод будет выглядеть так:

не в сети давно

AnthonyGes

Публикации: 0Продаж/Покупок: 0/0
не в сети давно

Charlesdug

Публикации: 0Продаж/Покупок: 0/0
не в сети давно

fnJVdYZRUKPu

Публикации: 0Продаж/Покупок: 0/0
не в сети давно

KevinMup

Публикации: 0Продаж/Покупок: 0/0
не в сети давно

Cedricbat

Публикации: 0Продаж/Покупок: 0/0
не в сети давно

GeorgeHof

Публикации: 0Продаж/Покупок: 0/0
не в сети давно

rochellefq3

Публикации: 0Продаж/Покупок: 0/0
не в сети давно

cindyip4

Публикации: 0Продаж/Покупок: 0/0
не в сети давно

gregsr11

Публикации: 0Продаж/Покупок: 0/0
не в сети давно

lorettahk18

Публикации: 0Продаж/Покупок: 0/0
не в сети давно

deidregm11

Публикации: 0Продаж/Покупок: 0/0
не в сети давно

Akatsuki007smany

Публикации: 0Продаж/Покупок: 0/0
не в сети давно

JeffreyHit

Публикации: 0Продаж/Покупок: 0/0
не в сети давно

Michaelmagma

Публикации: 0Продаж/Покупок: 0/0
не в сети давно

reynaof3

Публикации: 0Продаж/Покупок: 0/0
не в сети давно

onFYkWqHd

Публикации: 0Продаж/Покупок: 0/0
не в сети давно

Nathanocear

Публикации: 0Продаж/Покупок: 0/0
не в сети давно

tJasEqgl

Публикации: 0Продаж/Покупок: 0/0
не в сети давно

marvawk3

Публикации: 0Продаж/Покупок: 0/0
не в сети давно

gotoClode

Публикации: 0Продаж/Покупок: 0/0
не в сети давно

BruceTip

Публикации: 0Продаж/Покупок: 0/0
не в сети давно

Mattischqh

Публикации: 0Продаж/Покупок: 0/0
не в сети давно

ArtakDSshoom

Публикации: 0Продаж/Покупок: 0/0
не в сети давно

EduardoBlict

Публикации: 0Продаж/Покупок: 0/0
не в сети давно

pl11

Публикации: 0Продаж/Покупок: 0/0
не в сети давно

janetteof4

Публикации: 0Продаж/Покупок: 0/0
не в сети давно

wg16

Публикации: 0Продаж/Покупок: 0/0
не в сети давно

stephaniezx2

Публикации: 0Продаж/Покупок: 0/0
не в сети давно

taylorpi4

Публикации: 0Продаж/Покупок: 0/0
не в сети давно

PjXZVbDusJF

Публикации: 0Продаж/Покупок: 0/0

полный же набор выводимых данных будет таким:

не в сети давно

AnthonyGes

0
Комментарии: 0Публикации: 0Регистрация: 21-04-2022Продаж/Покупок: 0/0
не в сети давно

Charlesdug

0
Комментарии: 0Публикации: 0Регистрация: 21-04-2022Продаж/Покупок: 0/0
не в сети давно

fnJVdYZRUKPu

0
Комментарии: 0Публикации: 0Регистрация: 21-04-2022Продаж/Покупок: 0/0
не в сети давно

KevinMup

0
Комментарии: 0Публикации: 0Регистрация: 21-04-2022Продаж/Покупок: 0/0
не в сети давно

Cedricbat

0
Комментарии: 0Публикации: 0Регистрация: 21-04-2022Продаж/Покупок: 0/0
не в сети давно

GeorgeHof

0
Комментарии: 0Публикации: 0Регистрация: 21-04-2022Продаж/Покупок: 0/0
не в сети давно

rochellefq3

0
Комментарии: 0Публикации: 0Регистрация: 21-04-2022Продаж/Покупок: 0/0
не в сети давно

cindyip4

0
Комментарии: 0Публикации: 0Регистрация: 21-04-2022Продаж/Покупок: 0/0
не в сети давно

gregsr11

0
Комментарии: 0Публикации: 0Регистрация: 21-04-2022Продаж/Покупок: 0/0
не в сети давно

lorettahk18

0
Комментарии: 0Публикации: 0Регистрация: 21-04-2022Продаж/Покупок: 0/0
не в сети давно

deidregm11

0
Комментарии: 0Публикации: 0Регистрация: 21-04-2022Продаж/Покупок: 0/0
не в сети давно

Akatsuki007smany

0
Комментарии: 0Публикации: 0Регистрация: 21-04-2022Продаж/Покупок: 0/0
не в сети давно

JeffreyHit

0
Комментарии: 0Публикации: 0Регистрация: 21-04-2022Продаж/Покупок: 0/0
не в сети давно

Michaelmagma

0
Комментарии: 0Публикации: 0Регистрация: 21-04-2022Продаж/Покупок: 0/0
не в сети давно

reynaof3

0
Комментарии: 0Публикации: 0Регистрация: 21-04-2022Продаж/Покупок: 0/0
не в сети давно

onFYkWqHd

0
Комментарии: 0Публикации: 0Регистрация: 21-04-2022Продаж/Покупок: 0/0
не в сети давно

Nathanocear

0
Комментарии: 0Публикации: 0Регистрация: 21-04-2022Продаж/Покупок: 0/0
не в сети давно

tJasEqgl

0
Комментарии: 0Публикации: 0Регистрация: 21-04-2022Продаж/Покупок: 0/0
не в сети давно

marvawk3

0
Комментарии: 0Публикации: 0Регистрация: 21-04-2022Продаж/Покупок: 0/0
не в сети давно

gotoClode

0
Комментарии: 0Публикации: 0Регистрация: 21-04-2022Продаж/Покупок: 0/0
не в сети давно

BruceTip

0
Комментарии: 0Публикации: 0Регистрация: 21-04-2022Продаж/Покупок: 0/0
не в сети давно

Mattischqh

0
Комментарии: 0Публикации: 0Регистрация: 21-04-2022Продаж/Покупок: 0/0
не в сети давно

ArtakDSshoom

0
Комментарии: 0Публикации: 0Регистрация: 21-04-2022Продаж/Покупок: 0/0
не в сети давно

EduardoBlict

0
Комментарии: 0Публикации: 0Регистрация: 21-04-2022Продаж/Покупок: 0/0
не в сети давно

pl11

0
Комментарии: 0Публикации: 0Регистрация: 21-04-2022Продаж/Покупок: 0/0
не в сети давно

janetteof4

0
Комментарии: 0Публикации: 0Регистрация: 22-04-2022Продаж/Покупок: 0/0
не в сети давно

wg16

0
Комментарии: 0Публикации: 0Регистрация: 22-04-2022Продаж/Покупок: 0/0
не в сети давно

stephaniezx2

0
Комментарии: 0Публикации: 0Регистрация: 22-04-2022Продаж/Покупок: 0/0
не в сети давно

taylorpi4

0
Комментарии: 0Публикации: 0Регистрация: 22-04-2022Продаж/Покупок: 0/0
не в сети давно

PjXZVbDusJF

0
Комментарии: 0Публикации: 0Регистрация: 22-04-2022Продаж/Покупок: 0/0

Форма поиска и фильтры сортировки теперь не выводятся по-умолчанию, шорткод надо будет дополнить, атрибутом filters:

Поиск пользователей
Поиск

Всего пользователей: 72985

Пользователи не найдены

Если же мы захотим скрыть форму поиска, но оставить фильтры сортировки, то следует указать search_form="0":

Всего пользователей: 72985

Пользователи не найдены

Полное описание шорткода и его атрибутов можно найти на странице шорткодов плагина.

При желании вместо шорткода можно использовать функцию rcl_get_userlist(), передавая в нее нужные атрибуты в массиве:

rcl_get_userlist(array('data'=>'rating_total,comments_count,posts_count,description,user_registered', 'filters'=>1, 'search_form'=>0));

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

$query = array(
            'select'    => array(),
            'join'      => array(),
            'where'     => array(),
            'group'     => '',
            'orderby'     => ''
        );

Массив с полученными данными пользователей можно получить через фильтр 'rcl_users'.

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

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

В течении двух дней, данная версия будет доступна для тестирования на github проекта https://github.com/plechev-64/wp-recall, через два дня версия будет опубликована в репозитории.

В доработке этой версии принимали участие:

Пользователи не найдены

 

5

Автор публикации

Пользователи не найдены