<?php
/**
* This file implements the ".inc file" Widget class, and it is used to embed any '.inc.php' file
*
* This file is part of the evoCore framework - {@link http://evocore.net/}
* See also {@link http://sourceforge.net/projects/evocms/}.
*
* @copyright (c)2003-2014 by Francois Planque - {@link http://fplanque.com/}
*
* {@internal License choice
* - If you have received this file as part of a package, please find the license.txt file in
* the same folder or the closest folder above for complete license terms.
* - If you have received this file individually (e-g: from http://evocms.cvs.sourceforge.net/)
* then you must choose one of the following licenses before using the file:
* - GNU General Public License 2 (GPL) - http://www.opensource.org/licenses/gpl-license.php
* - Mozilla Public License 1.1 (MPL) - http://www.opensource.org/licenses/mozilla1.1.php
* }}
*
* @package evocore
*
* {@internal Below is a list of authors who have contributed to design/coding of this file: }}
* @author asimo: Evo Factory / Attila Simo
*
* @version $Id: _inc_file.widget.php 10060 2016-03-09 10:40:31Z yura $
*/
if( !defined('EVO_MAIN_INIT') ) die( 'Please, do not access this page directly.' );
load_class( 'widgets/model/_widget.class.php', 'ComponentWidget' );
/**
* Widget Class
*
* A ComponentWidget is a displayable entity that can be placed into a Container on a web page.
*
* @package evocore
*/
class inc_file_Widget extends ComponentWidget
{
var $icon = 'file';
/**
* Constructor
*/
function __construct( $db_row = NULL )
{
// Call parent constructor:
parent::__construct( $db_row, 'core', 'inc_file' );
}
/**
* Get help URL
*
* @return string URL
*/
function get_help_url()
{
return get_manual_url( 'inc-file-widget' );
}
/**
* Display the widget!
*
* @param array MUST contain at least the basic display params
*/
function display( $params )
{
global $Blog;
$this->init_display( $params );
// Collection common links:
echo $this->disp_params['block_start'];
$this->disp_title( $this->disp_params['title'] );
echo $this->disp_params['block_body_start'];
skin_include( $this->disp_params['file_name'], $params );
echo $this->disp_params['block_body_end'];
echo $this->disp_params['block_end'];
return true;
}
/**
* Get name of widget
*/
function get_name()
{
$title = T_( '.inc file' );
return $title;
}
/**
* Get a very short desc. Used in the widget list.
*/
function get_short_desc()
{
return format_to_output( $this->disp_params['title'] );
}
/**
* Get short description
*/
function get_desc()
{
return T_('Embed any ".inc.php" file content found in the current skin. Useful for upgrades/backwards compatibility.');
}
/**
* Get definitions for editable params
*
* @param $params
*/
function get_param_definitions( $params )
{
// Demo data:
$r = array_merge( array(
'title' => array(
'label' => T_('Block title'),
'size' => 60,
),
'file_name' => array(
'label' => T_('.inc file name'),
'note' => T_( 'The name of the ".inc.php" file which should be embedded.' ),
'type' => 'text',
'size' => 40,
'defaultvalue' => ''
),
), parent::get_param_definitions( $params ) );
return $r;
}
}
?>