sunlab / wn-gamification-plugin
A Gamification plugin for WinterCMS
Installs: 63
Dependents: 1
Suggesters: 0
Security: 0
Stars: 1
Watchers: 2
Forks: 1
Type:winter-plugin
Requires
- php: >=7.0
- composer/installers: ~1.0
- sunlab/wn-measures-plugin: ^v1.0.0
- winter/wn-user-plugin: ^2.0
This package is auto-updated.
Last update: 2025-01-18 16:09:24 UTC
README
This plugin allows you to reward your members when some actions are made. To increment the statistics, this plugin is using SunLab.Measures
How to use
From the backend, create all the needed badges. A badge need at least, a name.
Automatic attachment with SunLab.Measures
When filling measure name and amount needed: the users will automatically receive badges once the measure reach the amount needed. Refer to SunLab.Measures for measure incrementation.
Manually attaching/detaching badge
To attach or detach a badge manually, use attachBadge
and detachBadge
method,
which accept a badge reference as string (its name), int (its id), or a Badge model.
\Winter\User\Models\User::extend(function ($user) { Event::listen('winter.user.activate', function($user) { $user->attachBadge('Verified User'); }); });
Verify badge attachment
To simplify badge attachment verification, the plugin include a hasBadge
method,
which accept a badge reference as string (its name), int (its id), or a Badge model.
if ($user->haBadge('Verified User')) { // User has the 'Verified User' badge }
Components
This plugin comes with two components:
BadgesList
Displays all the badge that can be rewarded, and the number of members of member who already won it.
UserBadges
Displays only the badges that a specific member won. The member could be the one actually logged in, or set by an url parameter.
Tree view
The Badge
model implement SimpleTree
.
If you want to display the badges as a tree,
use the components' property tree-displayed
to optimize the database search.
The default query will load the badges ordered by their measure name and amount needed.
Measures reminder
SunLab.Measures is internally used by the plugin to increment
some measures when some events are emitted.
You can configure the most basic events from the backend using the generic event listener of Measures
,
but for complexes cases, you'll need to manually create the listener from a Plugin.php
file.
A use case for this could be to give a badge rewarding immediately after the registration,
because plugins' events are not supported by Measures
as of today, we need to create it manually:
\Winter\User\Models\User::extend(function ($user) { $user->bindEvent('model.afterCreate', function () use ($user) { $user->incrementMeasure('registered'); }); });