Sociable Badges API

From CjWiki
Revision as of 04:28, 21 August 2019 by Corejoomla (talk | contribs)
Jump to navigation Jump to search


Add the required Sociable API library:

require_once JPATH_ROOT.'/components/com_sociable/lib/api.php';

Now get the profile API:

$profileApi = SociableApi::getBadgesApi();

Rules XML File

Create sociable_rules.xml either in your component administrator folder or site folder (e.g. administrator/components/com_sociable) with the content like below.

<?xml version="1.0" encoding="UTF-8"?>
		<name>{rule name}</name>
		<asset_name>{asset name}</asset_name>
		<introtext>{brief intro}</introtext>
		<description>{badge description}</description>
		<rule_content>{rule conditions}</rule_content>
		<class_name>{icon font}</class_name>
{rule name} - the rule name
{asset name} - your component name
e.g. com_sociable
{title} - title of the badge
e.g. Post Photos
{brief intro} - small intro about the badge
e.g. Submit N Photos
{badge description} - badge description
description shown below the title of the badge e.g. To unlock this badge, submit 10 photos.
{rule conditions} - json formated rules
e.g. {"condition": "AND", "rules": [{"id": "photos", "field": "photos", "type": "integer", "input": "text", "operator": "equal", "value": "10"}], "valid": true}
{image} - badge image
if you want to use image shown for the badge, use this. absolute url of the image or url relative to the site root.
{icon font} - badge icon
for badge image you can use icon fonts instead of image above. for example, fa fa-camera
{state} - published state
default state of the rule when published, for example 1
{access} - user access level
default access level, for example 1

Syntax: getUserProfile

Syntax of the getBadgesApi API call to award a badge to the user:

getBadgesApi($ruleName, $values[], $options[])
$ruleName - rule name
the rulename that you defined in your rules xml file. For example, ''
$values[] - array
Associative array of values that are validated to award the badge. For example, in your rule, you defined 10 photos to get this award, the values can be something like array('photos' => $photosCount) where photos is the "field" attribute defined in your rules conditions
$options[] - array
Array of options, for example to restrict the badge to be awarded only once to the user; pass array('ref_id' => $user->id)