Description
Activating this plugin now means that you are able to award users for specific actions that they take.
NOTE: Currently this only works for actions that update or add to user meta values.
At a basic level, the following happens when you activate this plugin:
-
Awards custom post type is added to the administration window. Regular post type window but with a few additional meta boxes that provide access to the core behavior of this plugin.
-
A new table is created under the name of
{wpdb_prefix}user_awards
. This contains all award assignment references to users. The User Awards sub-menu provides an interface to help perform administrative actions on the table.
There is also a User Awards
sub-menu which gives a tabular view of all the awards that are assigned to users. This is accessible from the Awards
admin menu in your WordPress administration area.
Usage
Understanding the different actions you can take in each available window is key to having this plugin work for you.
Award List Window
This window displays all of the specific “Award” post types.
There are two different bulk actions available to you:
-
Bulk Assign – Assign multiple awards to a user
-
Bulk Give – Give multiple awards to a user
New Award / Edit Award Window
These administration windows have three meta boxes associated with them. Below are descriptions of each metabox and why it is included.
Awards Trigger
Text Input. Accepts an awards trigger string, which will describe the behavior of how an award will be assigned to users. Documentation for the awards trigger is shown below.
Example
You have a membership blog site, and because you’re a nice person, you want to award your members for being engaged with your site and liking at least ten blog posts!
A previous developer implemented a like button on each of your site’s blog posts that increments a post_likes
user_meta value on the user that clicks it (e.g. If a member likes 3 blog posts, they will have a post_likes
meta value of 3
).
We’ve decided to name our award the “User Engagement” award. In order to assign it to a member based on the prerequisites, you would put something like this in the “Awards Trigger” input.
CURRENT_USER_META ASSIGNED WHERE key=post_likes EQ 10
This string tells the award to assign itself to the user if the post_likes
value of the current user’s meta was updated or created to equal a value of 10
.
Auto-Give Award
Checkbox input. Check this box to automatically have the award be given to a user when it would originally be assigned.
Apply/Give Award To User
Select Input combined with a checkbox input. Select a user from your member list to either assign/give an award by clicking on the Assign submit button.
User Awards Window
This window allows administrators to physically see and update the status of all of the awards that are assigned to users.
This window will allow you to perform the following actions:
- Singular/Bulk remove awards from members
- Singular give awards to members
- Edit Awards
Documentation
Awards Trigger Syntax
Explanation of each of the items that make up our trigger string, with accepted values of each listed under.
-
[ entity ] — Used to scope your awards trigger to a specific action.
- CURRENT_USER_META — Consider the meta value of the current user
-
[ trigger_type ] — Type of action that is performed to the current entity.
- UPDATED — When entity value is updated (Listens to calls of the update_user_meta() function)
- CREATED — When entity value is created (Listens to calls of the add_user_meta() function)
- ASSIGNED — Listens to calls of both the update_user_meta() and add_user_meta() function.
- ~EXCLUDED~ — Not Implemented
-
[ trigger ] – Made up of three separate values itself, [ descriptor ] [ operator ] [ control ]
-
[ descriptor ]
- [ entity_type ] = [ value ] ex: key = hours
-
[ operator ]
- GT – greater than
- LT – less than
- EQ – equal to
- GTEQ – greater than equal to
- LTEQ – less than equal to
-
[ control ]
- Value used to compare against. e.g. 2
- NOTE: The control can also be a string, but in order for this to work, you must use the EQ operator, as shown above.
-
EXAMPLE:
CURRENT_USER_META UPDATED WHERE key=total_hours GT 600
This example creates a wp action handler that only applies when a user’s meta tags are updated.
In the handler, we will compare the meta tag being updated to the given comparitors in the [ trigger ].
i.e. we will look for a meta tag of the current user that is labeled “total_hours” and check to see if the value is
greater than 600. If that’s the case then the award will be assigned. If not then nothing happens.
$UserAward Global Object
The awards trigger syntax, while nice, is too limited in its current form. Our plugin provides a global $UserAward variable that allows developers to interact with the core API of the plugin in order to award items through methods that simply are not possible / too complex.
You will find documentation and usage for functions available to you below.
global $UserAward;
/**
* Check to see if a user already has a specific award
* @param int $user_id – WPUser_ID
* @param int $award_id – UserAward_ID (Post ID)
* @return bool Whether or not this user has an award with the current award id
*/
$UserAwards->UserHasAward( $user_id, $award_id );
/**
* Assigns multiple awards to users using AssignAward
* @param int $user_id – WPUser_ID
* @param array $award_ids – Array of UserAward_IDs (Post ID)
* @return bool – True if awards were assigned, false if there was an error with assigning awards
*/
$UserAwards->AssignAwards( $user_id, $award_ids );
/**
* Function that marks an award as assigned to a user.
* We insert a new record into our awards table that relates the award to the user.
*
* We do check to see if there is an auto-assignment of the award before we finish up our function though.
*
* @param int $user_id – ID of the user that we are “awarding” the award to
* @param int $award_id – ID of the award that we are “awarding”
* @return bool – True if award was assigned,
* False if:
* – User already has that award
* – Error with assigning our award
*/
$UserAwards->AssignAward( $user_id, $award_id );
/**
* Give multiple awards to users using GiveAward().
* @param int $user_id – WPUser_ID
* @param array $award_ids – Array of UserAward_IDs (Post ID)
* @return bool – True if awards were given, false if there was an error with giving awards
*/
$UserAwards->GiveAwards( $user_id, $award_ids );
/**
* Function that will mark an award as given to a user,
* which essentially means that we mark the “date_given” time with
* an actual date.
*
* Returns the return value of a db->update
call
*
* @param int $user_id – ID of the user that we are “awarding” the award to
* @param int $award_id – ID of the award that we are “awarding”
* @return mixed – Return value of a $wpdb->update() call
*/
$UserAwards->GiveAward( $user_id, $award_id );
/**
* Removes awards from our database.
* If “$award_id” is null, then we are going to delete everything in the database with the specific “$user_id”
*
* @param int $user_id – ID of the user that we are “awarding” the award to
* @param int $award_id – ID of the award that we are “awarding”
* @return mixed – Return the value of a $wpdb->delete() call
*/
$UserAwards->RemoveUserAward( $user_id, $award_id = NULL );
/**
* Function that grabs as many awards assigned to the user as we can based on the parameters given.
* For example, if just a user_id is supplied, then we will return all of the awards with that user_id.
* If an award_id is supplied along with our user_id then we will probably get only one award. Hopefully
*
* @param int $user_id – ID of the user that we are “awarding” the award to
* @param int $award_id – ID of the award that we are “awarding”
* @return mixed – Returnes the value of a $wpdb->get_results() call
*/
$UserAwards->GetUserAward( $user_id, $award_id = NULL);
Attribution
This plugin’s icon is not an original piece of work. It was made by Freepik from Flaticon.com
Screenshots
Installation
- Upload the plugin files to the
/wp-content/plugins/user-awards
directory install the plugin through the WordPress plugins screen directly - Activate the plugin through the
This section describes how to install the plugin and get it working. - Activate the plugin through the ‘Plugins’ screen in WordPress. You should be notified if the plugin activation was successful.
- Click on the
Awards
menu item on the administrator sidebar in order to interact with the User Awards plugin administration actions.
FAQ
No frequently asked questions are known at this time.
Reviews
There are no reviews for this plugin.
Contributors & Developers
“User Awards” is open source software. The following people have contributed to this plugin.
ContributorsTranslate “User Awards” into your language.
Interested in development?
Browse the code, check out the SVN repository, or subscribe to the development log by RSS.
Changelog
Version 0.0.2
Updating readme.txt
Version 0.0.1
Initial version of the plugin.