Description
This plugin allows you to create special links that check whether a user is logged in and then follow the link if they are or show an ajax-powered login form in a simple lightbox if they are not. Once the user fills out the login form with valid credentials they will be logged in and redirected to the page the link points to.
Scenario
Let’s say you’ve got a page on your site that only logged in users are able to access. It could be a private page or ideally it is a page that is set up to show a standard login form to users who are not logged in. With this plugin you could add the class ‘ajax-login-trigger’ to all the links that point to that page, then when a user clicks one of these links an ajax request is sent to the server to check whether the user is already logged in, and if they are the user is redirected to the page without ever noticing that the login check was done, or if they aren’t logged in they’ll see a login form appear in a simple lightbox. When the user fills out the form, a second ajax request is sent to the server to attempt to log them in, and if successful the user is redirected to the page.
Customize It!
This plugin includes lots of hooks and filters that allow for all sorts of customizations and unique use cases. Here’s a quick list:
Actions:
mm_ajax_login_before_form_outside
mm_ajax_login_before_form_inside
mm_ajax_login_extra_buttons
mm_ajax_login_after_form_inside
mm_ajax_login_after_form_outside
Filters:
mm_ajax_login_trigger_selector
mm_ajax_login_form_title
mm_ajax_login_status_message
mm_ajax_login_username_label
mm_ajax_login_password_label
mm_ajax_login_rememberme_text
mm_ajax_login_lost_password_text
mm_ajax_login_button_text
mm_ajax_login_custom_login_action
mm_ajax_login_email_login_fail_message
mm_ajax_login_success_message
mm_ajax_login_fail_message
mm_ajax_login_allow_email_login
Many things are possible with these hooks. The hooks mm_ajax_login_before_form_inside
and mm_ajax_login_after_form_inside
allow you to add any custom input elements to the form. When the login form is submitted all of the values from the input elements included in the form will get passed to the PHP function that processes the ajax request, which will then pass the data to the mm_ajax_login_custom_login_action
filter. You can intercept the incoming data using this filter and proceed with any custom action you want, like registering new users and logging them in during the same action.
Filter Examples
Use a custom selector for the trigger link:
add_filter( 'mm_ajax_login_trigger_selector', 'prefix_custom_login_trigger' );
function prefix_custom_login_trigger( $selector ) {
// Custom selector goes here.
$selector = '.my-custom-selector';
return $selector;
}
Use a custom status message:
add_filter( 'mm_ajax_login_status_message', 'prefix_custom_status_message' );
function prefix_custom_status_message( $status_message ) {
// Custom status message goes here.
$status_message = 'Magic happening...';
return $status_message;
}
This plugin is on Github and pull requests are always welcome.
Screenshots
Installation
Manual Installation
- Upload the entire /mm-ajax-login directory to the /wp-content/plugins/ directory.
- Activate Mm Ajax Login through the ‘Plugins’ menu in WordPress.
Better Installation
- Go to Plugins > Add New in your WordPress admin and search for Mm Ajax Login.
- Click Install.
FAQ
- Can I use any selector I want?
-
Yes! The included filter
mm_ajax_login_trigger_selector
allows you to specify any custom selector you want as a string. The default value is.ajax-login-trigger
. - Can the form be styled?
-
Yes! The default CSS is designed to be minimal and work with the existing styles included in your theme, but you can write additional CSS to take full control over the lightbox and form.
Reviews
There are no reviews for this plugin.
Contributors & Developers
“Mm Ajax Login” is open source software. The following people have contributed to this plugin.
Contributors“Mm Ajax Login” has been translated into 1 locale. Thank you to the translators for their contributions.
Translate “Mm Ajax Login” into your language.
Interested in development?
Browse the code, check out the SVN repository, or subscribe to the development log by RSS.
Changelog
1.0.0
- First release