1
0
mirror of https://github.com/EGroupware/egroupware.git synced 2025-01-22 13:58:36 +01:00
egroupware/home/inc/class.home_note_portlet.inc.php

176 lines
4.5 KiB
PHP
Raw Normal View History

<?php
2016-04-28 20:06:46 +02:00
/**
* Egroupware
* @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License
* @package home
* @subpackage portlet
* @link http://www.egroupware.org
* @author Nathan Gray
* @version $Id$
*/
2016-04-28 20:06:46 +02:00
use EGroupware\Api;
use EGroupware\Api\Etemplate;
/**
* A simple HTML note-to-self
*
* The implementation is a little more complicated because CKEditor needs some
* CSP exceptions, but the headers will always be already sent. This means we
* need a popup window instead of edit in place or a dialog.
*/
class home_note_portlet extends home_portlet
{
// Allow access to edit from client
public $public_functions = array(
'edit' => true
);
2016-04-28 20:06:46 +02:00
/**
* Context for this portlet
*/
public function __construct(Array &$context = array(), &$need_reload = false)
{
2016-04-28 20:06:46 +02:00
if (false) parent::__construct();
// Title not set for new widgets created via context menu
if(!$context['title'])
{
// Set initial size to 3x2, default is too small
$context['width'] = 3;
$context['height'] = 2;
$need_reload = true;
}
2016-04-28 20:06:46 +02:00
$this->context = $context;
}
/**
* Edit the note in a popup to accommodate CKEditor's CSP
* @param type $content
*/
public function edit($content = array())
{
$id = $_GET['id'] ? $_GET['id'] : $content['id'];
$height = $_GET['height'] ? $_GET['height'] : $content['height'];
if($content['group'] && $GLOBALS['egw_info']['apps']['admin'])
{
2016-04-28 20:06:46 +02:00
$prefs = new Api\Preferences(is_numeric($content['group']) ? $content['group'] : $GLOBALS['egw_info']['user']['account_id']);
}
else
{
$prefs = $GLOBALS['egw']->preferences;
}
2016-04-28 20:06:46 +02:00
$type = is_numeric($content['group']) ? "user" : $content['group'];
$arr = $prefs->read_repository();
$portlets = $arr['home'];
if($content['button'])
{
2016-04-28 20:06:46 +02:00
// Save updated Api\Preferences
$portlets[$id]['note'] = $content['note'];
$prefs->add('home', $id, $portlets[$id],$type);
$prefs->save_repository(True,$type);
// Yay for AJAX submit
2016-04-28 20:06:46 +02:00
Api\Json\Response::get()->apply('window.opener.app.home.refresh',array($id));
if(key($content['button'])=='save')
{
2016-04-28 20:06:46 +02:00
Api\Json\Response::get()->apply('window.close',array());
}
}
2016-04-28 20:06:46 +02:00
$etemplate = new Etemplate('home.note');
$etemplate->setElementAttribute('note', 'width', '99%');
$etemplate->setElementAttribute('note', 'height', $height);
$preserve = array(
'id' => $id,
'height' => $height,
'group' => $portlets[$id]['group']
);
2016-04-28 20:06:46 +02:00
$etemplate->exec('home.home_note_portlet.edit',array(
'note' => $portlets[$id]['note']
), array(),array('note'=>false,'save'=>false), $preserve);
}
2016-04-28 20:06:46 +02:00
public function exec($id = null, Etemplate &$etemplate = null)
{
// Allow to submit directly back here
if(is_array($id) && $id['id'])
{
$id = $id['id'];
}
$etemplate->read('home.note');
$etemplate->set_dom_id($id);
$content = $this->context;
if(!$content['note'])
{
$content['note'] = '';
2016-04-28 20:06:46 +02:00
Api\Json\Response::get()->apply('app.home.note_edit',array($id));
}
$etemplate->exec('home.home_note_portlet.exec',$content,array(),array('__ALL__'=>true),array('id' =>$id));
}
public function get_actions()
{
$actions = array(
'edit' => array(
'icon' => 'edit',
'caption' => lang('edit'),
'hideOnDisabled' => false,
'onExecute' => 'javaScript:app.home.note_edit',
'default' => true
),
'edit_settings' => array(
'default' => false
)
);
return $actions;
}
/**
* Return a list of settings to customize the portlet.
*
* Settings should be in the same style as for preferences. It is OK to return an empty array
* for no customizable settings.
*
* These should be already translated, no further translation will be done.
*
* @see preferences/inc/class.preferences_settings.inc.php
* @return Array of settings. Each setting should have the following keys:
* - name: Internal reference
* - type: Widget type for editing
* - label: Human name
* - help: Description of the setting, and what it does
* - default: Default value, for when it's not set yet
*/
public function get_properties()
{
$properties = parent::get_properties();
$properties[] = array(
'name' => 'title',
'type' => 'textbox',
'label' => lang('Title'),
);
// Internal - no type means it won't show in configure dialog
$properties[] = array(
'name' => 'note'
);
return $properties;
}
public function get_description()
{
return array(
'displayName'=> lang('Note'),
'title'=> $this->context['title'],
'description'=> lang('A quick note')
);
}
}