PHP Classes

File: example.php

Recommend this page to a friend!
  Classes of Martin   Time_When   example.php   Download  
File: example.php
Role: Example script
Content type: text/plain
Description: Example
Class: Time_When
Convert relative times into English expressions
Author: By
Last change: Changed to new version
Date: 13 years ago
Size: 5,669 bytes
 

Contents

Class file image Download
<?php
require('Time_When.php');

/**
 *
 * Showdown of types
 *
 */

$obj = Time_When::getInstance();
// Let us add a instance to our object

$obj->addType('-3months', array('time' => -(60*60*60*24*30*3), 'text' => '1 quarter ago'));
$obj->addType('-6months', array('time' => -(60*60*60*24*30*6), 'text' => '2 quarters ago'));
$obj->addType('-9months', array('time' => -(60*60*60*24*30*9), 'text' => '3 quarters ago'));
// If you dont use $obj->textAssigner in the text field, you dont need to add assignments

$obj->addType('-xmonths', array('time' => -(60*60*60*24*30*3), 'text' => '1 quarter ago'))
    ->
addType('-xxmonths', array('time' => -(60*60*60*24*30*6), 'text' => '2 quarters ago'))
    ->
addType('-xxxmonths', array('time' => -(60*60*60*24*30*9), 'text' => '3 quarters ago'));
// Can also be typed in oneline

// Example of a complete type
$obj->addType(
           
'yearexample', // The unique identifier name
           
array(
               
'time' => -(60*60*60*24*30*12),
               
// Here we add our time search (REMEMBER - if its less than...
               
'text' => $obj->textAssigner . ' ' . $obj->textAssigner . ' ago',
               
// Here we assign some text, $obj->textAssigner will be replaced by our assign array
               
'assign' => array(
                               
// Now to our assigns, as we have used $obj->textAssigner 2 times, we also need to items in this array
                               
$obj->textReplacer,
                               
// The first $obj->textAssigner we will replace by our replace sign (which will be calculated by 'time')
                               
array(EQUALS, 1, 'year', 'years')
                               
// Here we have a if statement, it says
                                // If 1 == $obj->textReplacer then replace $obj->textAssigner with year, else replace $obj->textAssigner with years
                           
)
            )
        );


$obj->removeType('year');
// And let us remove it again - remember to type the unique identifier name

$obj = Time_When::getInstance()->reset();
// // Let us add a instance to our object again, just to reset our previous settings ;-)

/**
 *
 * Showdown of timers
 *
 */
$obj->addTimer(time());
// We need a unix timestamp for the first argument, this is where we will start our calculations from

$obj->addTimer(time()-60, time());
// We can also add a timer with a different endtime than time()

$obj->addTimer(time()-60, time(), 'testing');
// And we can also add a name for it, so it can be seen when we get our full results

$obj->addTimer(time()-60*60*60, time(), '1 hour ago');
// Let us add a timer with a "1 hour ago"

$obj->addTimer(time()+60, time(), 'plus min');
// And a timer for the future :)

/**
 *
 * Showdown of results
 *
 */
$obj = Time_When::getInstance()->reset();
$obj->addTimer(time()+60*60*55, time(), '1 hour ago');
// Let us start by initialising some different things...

$array = $obj->getResult();
// Let us get a full result with everything, great for debugging
echo '<pre>';
var_dump( $array );
/*
array
  '1 hour ago' =>
    array
      'starttimer' => int 1254375267
      'endtimer' => int 1254162867
      'timer' => int -212400
      'result' =>
        array
          'converter' =>
            array
              '-min' =>
                array
                  'time' => int -3600
                  'text' => string '%s %s ago' (length=9)
                  'assign' =>
                    array
                      0 => string '[NUM]' (length=5)
                      1 =>
                        array
                          0 => string '<' (length=1)
                          1 => int 2
                          2 => string 'minute' (length=6)
                          3 => string 'minutes' (length=7)
                  'assignments' =>
                    array
                      0 => string '59' (length=2)
                      1 => string 'minutes' (length=7)
          'translated' => string '59 minutes ago' (length=14)
*/
// This array will be outputted, so we can both debug and other stuff

$string = $obj->__toString();
// But instead of using getResult() we can use __toString()
var_dump( $string );
/*
string '59 minutes ago' (length=14)
*/

// If we had several timers, we would get an array in __toString() example
$obj->addTimer(time()-60*60*60, time());
$obj->addTimer(time()-60*60*60, time(), 'testing #1');
$obj->addTimer(time()-60*60*60, time());
$obj->addTimer(time()-60*60*60, time(), 'testing #2');
$string = $obj->__toString();
var_dump( $string );
/*
array
  '1 hour ago' => string '1 hour ago' (length=10)
  0 => string '1 hour ago' (length=10)
  'testing #1' => string '1 hour ago' (length=10)
  1 => string '1 hour ago' (length=10)
  'testing #2' => string '1 hour ago' (length=10)
*/

echo Time_When::getInstance()->addTimer(time()-60*60*60);
// The fastest way to get a single will be
// You dont need to invoke __toString() because this is magic function in PHP

// After __toString() has been invoked all timers will be removed!
// This will NOT happen after getResult()

$obj = Time_When::getInstance()->reset();
// We can also add times for the future
$obj->addTimer(time()-(60*60*60*24*30*10), time(), '10 months ago');
$array = $obj->getResult();
// Let us get a full result with everything, great for debugging
echo '<pre>';
var_dump( $array );

/**
 *
 * Showdown of removing timers
 *
 */
$obj = Time_When::getInstance()->reset();

$obj->removeTimer();
// This will remove ALL timers!
// You can also echo this to see how many timers there have been removed

$obj->removeTimer('1 hour ago');
// This will remove the timer with id '1 hour ago'
// You can also echo this to see if the timer has removed one.