- Trickster
- Why Trickster?
- Installation
- Requirements
- Usage
- Trickster’s Tricks
- 1. Truncator
- 2. Email Validator
- 3. Slug Converter
- 4. YouTube Embed
- 5. Gravatar Grabber
- 6. Extension Splitter
- 7. Simple Social Analytics
- 8. BB Code Engine
- 9. Tags Sweeper
- 10. Time Ago
- 11. Cipher
- 12. Vimeo Video Embed
- 13. Video Info Grabber
- 14. Wikipedia Grabber
- 15. URL Shortener
- 16. Suggest
- 17. IP Grabber
- 18. Currency Converter
- Trickster is an Laravel package that makes Laravel Fun.
- Trickster provides tricks that makes coding with Laravel easy.
- With Trickster inside your Laravel framework, your app will become a Gambit. :-P
Installing Trickster is easy. Just type the command:
composer require secrethash/trickster
- Laravel 5.x
- cURL
- PHP 5.4.x
To start using Trickster, you will be needed to set it up first. Follow the below steps to setup Trickster:
You will be needing to add the Trickster Service Provider in your app.php
which is inside the config
directory.
- Open
config\app.php
- Find
'providers'
- At the last of this array in
Application Service Providers
addSecrethash\Trickster\TricksterServiceProvider::class,
To use Trickster flexibly, you need to add the Facade also. Facade will let you use Trickster directly. All you will need to do is add use Trickster;
at the head of the controller below namespace and use it by Trickster::trickName();
Lets Add the Trickster
Facade:
- Open
config\app.php
- Find
'aliases'
array. - At the end of this array, add
'Trickster' => Secrethash\Trickster\Facade\Trickster::class,
First of all you will need to run the following command in your console:
php artisan vendor:publish --provider="Secrethash\Trickster\TricksterServiceProvider"
This command will publish the
trickster.php
configuration file for Trickster to your application defaultconfig
directory.
From config\trickster.php
you can edit the default configurations.
You are almost done. Now what to do when you want to use a Trickster's Trick?
Here is a sample Controller to show you how to add Trickster and Use it:
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Http\Requests;
use Auth;
use Trickster; // Simply add the Facade
class TricksterDemoController extends Controller
{
/**
* Display a listing of the resource.
*
* @return \Illuminate\Http\Response
*/
public function index()
{
//checking if the user is Authenticated
if (Auth::check()) {
$user = Auth::user();
// Grabbing Gravatar
$gravatar = Trickster::gravatar($user->email, '200');
}
}
/**
* Show the form for creating a new resource.
*
* @return \Illuminate\Http\Response
*/
public function create()
{
//
}
}
If you want to use Trickster inside a view file, call the Trickster
method directly. That is the advantage of Facade.
For example:
{!! Trickster::bbcode($user->bio) !!}
or
{{ Trickster::truncator($blog->desc, '150', '(...summary)') }}
Truncate is a Text Truncator. It Truncates the text and enable you to add ellipses(...) or desired line at the end. For example:
The standard chunk of Lorem Ipsum used since the 1500s is reproduced below for those inter (read more...)
Just call the Trickster and provide it with details of the given parameters.
Trickster::truncator('Supplied text is written here, can also be given in a variable; lets leave it simple.', 30, '(read more...)');
// Output: Supplied text is written here, (read more...)
Email Validator gives you the power of validating the email address by just a simple line of code:
Trickster::emailValid('someone@example.com');
With Trickster by your side you will not have to write the validation code again and again. Just mention the Facade of Trickster an the validation function that's it.
Slug Converter makes your life easy for creating search engine friendly slug for your url.
For example: Text: Are search engines friendly to search engines?
SLUGish URL: example.com/are-search-engines-friendly-to-search-engines
COOL HUH?
It is really very simple with Trickster. Just call Trickster and specify the slug function, provide in the text and Ta-DA!
Trickster::slug('Are search engines friendly to search engines?'); // Just One Line!
//-> OR
$slug = 'Are search engines friendly to search engines?';
$slug = Trickster::slug($slug); // That's it!
YouTube Embedding can never be more easier! Embed YouTube Videos without writing lines of code just tell the Trickster about it. Call Trickster by:
Trickster::youtube('VIDEO URL', 'FRAME WIDTH', 'FRAME HEIGHT', 'FRAME THEME');
//OR LEAVE EVERYTHING ELSE FOR DEFAULT VALUES, JUST PUT THE LINK
Trickster::youtube('VIDEO URL');
DEFAULT VALUES:
Parameters | Description | Required | Value |
---|---|---|---|
Video URL | URL to the YouTube video | YES | NO |
Frame Width | Width of the video Frame | NO | 400 |
Frame Height | Height of the Video frame | NO | 250 |
Frame Theme | dark or light theme | NO | dark |
This amazing trick helps you to easily get the gravatar in the desired size, with desired rating. Not only that, but it also helps you to set the desired default image in case the grabbing fails. Not yet finished, two more amazing features; allows you to set the option of returning only the url of the gravatar or even the gravatar with the whole <img />
tag and in case you want Trickster to return the whole img tag then you also have the option of setting desired attributes in an array (ex. below).
Trickster::gravatar('example@email.com', '200', 'monsterid', 'r', 'true', array('class'=>'img-class', 'key'=>'value'));
The Parameters Explained:
- Email Address: Just simple email address. NO DEFAULT, REQUIRED.
- Size: Size of image in pixels. DEFAULT: 100, NOT REQUIRED.
- Default image: Default Image like mm(mystery man), monsterid, identicon, wavatar, 404. DEFAULT: mm, NOT REQUIRED.
- Rating: Image Max Rating (for ex. g, pg, r, x). DEFAULT: g, NOT REQUIRED.
<img />
: Do you want full HTML image tag? This parameter should be supplied with boolean value (TRUE/FALSE). DEFAULT: false, NOT REQUIRED.- Key-Value Attributes: An array is to be passed to defined any special attributes required by the html image tag, if requested. NO DEFAULT, NOT REQUIRED
This simple trick splits the file extension of the file supplied as the parameter and returns it. Simply call the Trickster and provide the full file name, the trick will split the file ext. from the file name and return it.
Trickster::getExtension('really-funny.image.jpg');
Finished? Not Yet!
This trick eases your life, seriously. Simple and easy it is to show your social counts with Trickster. Trickster's Simple Social Analytics shows the number of Shares or Comments over a specific URL on Facebook when the trick is executed.
Note: Twitter has been deprecated. As of 20th November 2015 there's no Tweet count API. Know More
- Supported Social Networks:
Twitter(deprecated)
- Returned Strings
- Facebook
- Share Count
- Comment Count
TwitterTweets
$fbAnalytics = Trickster::social('facebook', 'http://github.com/secrethash');
echo $fbAnalytics['share_count'].' Shares of Github.com/secrethash';
echo $fbAnalytics['comment_count'].' Comments on Github.com/secrethash';
Output 1: 95457821 Shares of Github.com/secrethash Output 2: 59865231 Comments on Github.com/secrethash
(Don't be bothered about the numbers, they are just random :-P )
BTW Simple, right?
BB code engine trick is a little distinctive. It's actually amazing. It makes easy to convert the BB Code to HTML format. Easy to initialize, it makes it unique.
// If implemented directly in the Blade View File.
{!! Trickster::bbcode($user->bio) !!}
***The Supported BB Codes Currently are: ***
BB Code | Description | Converted HTML |
---|---|---|
[b]...[/b] | Bold Text | <b>...</b> |
[i]...[/i] | Italics Text | <i>...</i> |
[u]...[/u] | Underlined | <u>...</u> |
[img=url]alt[/img] | Image Implementation. Where: url is the image url & alt is alternate text. | <img src="#url" alt="Alternate Text" /> |
[youtube]id[/youtube] | Youtube Embed. Where id is the Video ID of youtube video. | YouTube video frame of width 400px & height 250px |
[vimeo]id[/vimeo] | Vimeo Embed. Where id is the Video ID of Vimeo video. | Vimeo video frame of width 400px & height 250px |
[p]...[/p] | Paragraph. | <p>...</p> |
[br/] | Line Break | <br/> |
[url=URL]ALT[/url] | Adding a URL. Where: URL is the Target Link and ALT is the URL text to be shown. | <a href="#url">Google</a> |
Tag sweeper is a unwanted tag remover trick. It easily removes the unwanted script tags from the provided string. In accordance to the BB Code Engine, Tag Sweeper Cleans the HTML <script></script>
code and leaves the BB Code making the supplied text Clean and Safe.
Trickster::clean($string);
Time ago is a wonderful way of displaying the post time. You can use the Trickster's Facade Trickster
to convert easily the provided Time & Date to Time Ago. The default format for this is Y-m-d H:i:s
. In simple words 1996-07-30 21:52:30
, Year-Month-Day Hour:Min:Sec
For example: This repo was created 2 months ago
Trick:
Trickster::timeAgo('1996-07-30 21:52:30');
Cipher enables you to encrypt any provided string of plain text to convert into Encrypted text form. Any PHP supported algorithm can be provided to Cipher to encrypt it. You can also encrypt a string and add a Salt to make it more secure. One will need the Salt to decrypt it.
Trickster::encryptString('SHA1', 'Text to Encrypt', 'Desired Salt');
Vimeo Video Embed, same as YouTube Video Embed. It needs the video link of Vimeo Video as an input. Same as Youtube Embed you can set custom width and height in it also.
Trickster::vimeo('https://vimeo.com/30626474', '400', '250');
//-> OR, Simple <-//
Trickster::vimeo('https://vimeo.com/30626474');
A great way of getting the video information from YouTube and Vimeo. Video Info Grabber makes it easy for you to grab the video info from link of YouTube & Vimeo video portals and return an array containing the video info. Returning as an array gives you the flexibility to use the info as you want.
Trickster::getVideoInfo('https://vimeo.com/30626474');
// Output
Array
(
[title] => The Official Space Ibiza Closing Party 2011 Video
[description] =>
[thumbnail] => http://i1.ytimg.com/vi/AL-QX0wj44A/default.jpg
[duration] => 962
[upload_date] => 2011-11-05 02:11:05
)
This simple trick helps you to get the Wikipedia version definition of a particular keyword. Just pass the key word as the input to this function of Trickster
and get the definition right away as return string. Remember, like the above function this one also returns an array as it returns not only definition but also the input value and the link to Wikipedia, where that definition is. The example is well explained below:
Trickster::wiki('github');
// Returns
Array
(
[0] => GitHub
[1] => GitHub is a web-based Git repository hosting service. It offers all of the distributed revision control and source code management (SCM) functionality of Git as well as adding its own features.
[2] => http://en.wikipedia.org/wiki/GitHub
)
So if you only want to display the definition of GitHub as shown in the above example:
$trick = Trickster::wiki('github');
echo $trick[1];
URL shortener make your url short using the Google's goo.gl API and TinyURL API. Make your life simple with just one liner URL Shortener that can shorten the URL using 2 distinctive APIs.
// Google's URL Shortener
Trickster::shortenUrl('http://github.io', 'google');
// TinyURL URL Shortener
Trickster::shortenUrl('http://github.com', 'tinyurl');
Suggest uses the Google Suggest API to get the keyword suggestions. Just provide the input of the keyword that you want the suggestions for as the first parameter and the results will be generated and returned as an array.
Trickster::suggest('break');
// Output
Array
(
[0] => breaking
[1] => breaking bad
[2] => break the glass
[3] => break plan
[4] => breaking bad imdb
[5] => kitkat break
[6] => break the bones
[7] => breakthrough
[8] => breaking benjamin
[9] => breakup
)
Grabs the user's IP address. Simple but useful.
Trickster::ip();
// Output: 192.168.145.35
With the help of CURL and Google the currency is converted using the live exchange rate. Trickster's Trickster::currencyConvert()
can convert currency within seconds using the Currency Codes.
The Currency Converter excepts three Parameters with last an optional one.
Parameters & Inputs:
Parameters | Description | Value | Default | Accepts |
---|---|---|---|---|
Amount | The amount to convert | Integer | ------ | Currency Amount |
From | Convert Currency From | String | ------ | Currency Code |
To | Convert Currency To | String | INR | Currency Code |
INR is the Currency Code for Indian National Rupee
/**
* Sample Code
* @param $amount init Amount to convert
* @param $from string Currency Code
* @param $to string Currency Code
* @return string - converted amount
**/
$amount = 100;
$from = "USD";
$to = "INR";
$convert = Trickster::currencyConvert($amount, $from, $to);
echo $convert;
output: 60,000 //In INR (Just an Example).