Create plugin to present identities settings dialog to new users
parent
742d61aaf3
commit
5edb5b6634
@ -0,0 +1,107 @@
|
||||
<?php
|
||||
|
||||
/**
|
||||
* Present identities settings dialog to new users
|
||||
*
|
||||
* When a new user is created, this plugin checks the default identity
|
||||
* and sets a session flag in case it is incomplete. An overlay box will appear
|
||||
* on the screen until the user has reviewed/completed his identity.
|
||||
*
|
||||
* @version 1.0
|
||||
* @author Thomas Bruederli
|
||||
*/
|
||||
class new_user_dialog extends rcube_plugin
|
||||
{
|
||||
public $task = 'mail';
|
||||
|
||||
function init()
|
||||
{
|
||||
$this->add_hook('create_identity', array($this, 'create_identity'));
|
||||
|
||||
// register additional hooks if session flag is set
|
||||
if ($_SESSION['plugin.newuserdialog']) {
|
||||
$this->add_hook('render_page', array($this, 'render_page'));
|
||||
$this->register_action('plugin.newusersave', array($this, 'save_data'));
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Check newly created identity at first login
|
||||
*/
|
||||
function create_identity($p)
|
||||
{
|
||||
// set session flag when a new user was created and the default identity seems to be incomplete
|
||||
$rcmail = rcmail::get_instance();
|
||||
if ($p['login'] && !$p['complete'] && (empty($p['record']['name']) || $p['record']['name'] == $rcmail->user->data['username']))
|
||||
$_SESSION['plugin.newuserdialog'] = true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Callback function when HTML page is rendered
|
||||
* We'll add an overlay box here.
|
||||
*/
|
||||
function render_page($p)
|
||||
{
|
||||
if ($_SESSION['plugin.newuserdialog'] && $p['template'] == 'mail') {
|
||||
$rcmail = rcmail::get_instance();
|
||||
$identity = $rcmail->user->get_identity();
|
||||
$identities_level = intval($rcmail->config->get('identities_level', 0));
|
||||
|
||||
// compose user-identity dialog
|
||||
$table = new html_table(array('cols' => 2));
|
||||
|
||||
$table->add('title', $this->gettext('name'));
|
||||
$table->add(null, html::tag('input', array('type' => "text", 'name' => "_name", 'value' => $identity['name'])));
|
||||
|
||||
$table->add('title', $this->gettext('email'));
|
||||
$table->add(null, html::tag('input', array('type' => "text", 'name' => "_email", 'value' => $identity['email'], 'disabled' => ($identities_level == 1 || $identities_level == 3))));
|
||||
|
||||
// add overlay input box to html page
|
||||
$rcmail->output->add_footer(html::div(array('id' => "newuseroverlay"),
|
||||
html::tag('form', array(
|
||||
'action' => $rcmail->url('plugin.newusersave'),
|
||||
'method' => "post"),
|
||||
html::tag('h3', null, 'Please complete your sender identity') . // TODO: localize title
|
||||
$table->show() .
|
||||
html::p(array('class' => "formbuttons"),
|
||||
html::tag('input', array('type' => "submit", 'class' => "button mainaction", 'value' => $this->gettext('save'))))
|
||||
)
|
||||
));
|
||||
|
||||
$this->include_stylesheet('newuserdialog.css');
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Handler for submitted form
|
||||
*
|
||||
* Check fields and save to default identity if valid.
|
||||
* Afterwards the session flag is removed and we're done.
|
||||
*/
|
||||
function save_data()
|
||||
{
|
||||
$rcmail = rcmail::get_instance();
|
||||
$identity = $rcmail->user->get_identity();
|
||||
$identities_level = intval($rcmail->config->get('identities_level', 0));
|
||||
|
||||
$save_data = array(
|
||||
'name' => get_input_value('_name', RCUBE_INPUT_POST),
|
||||
'email' => get_input_value('_email', RCUBE_INPUT_POST),
|
||||
);
|
||||
|
||||
// don't let the user alter the e-mail address if disabled by config
|
||||
if ($identities_level == 1 || $identities_level == 3)
|
||||
$save_data['email'] = $identity['email'];
|
||||
|
||||
// save data if not empty
|
||||
if (!empty($save_data['name']) && !empty($save_data['name'])) {
|
||||
$rcmail->user->update_identity($identity['identity_id'], $save_data);
|
||||
rcube_sess_unset('plugin.newuserdialog');
|
||||
}
|
||||
|
||||
$rcmail->output->redirect('');
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
?>
|
@ -0,0 +1,48 @@
|
||||
/** Styles for the new-user-dialog overlay box */
|
||||
|
||||
#newuseroverlay {
|
||||
position: absolute;
|
||||
top: 0;
|
||||
left: 0;
|
||||
right: 0;
|
||||
bottom: 0;
|
||||
z-index: 10000;
|
||||
background: rgba(0,0,0,0.5) !important;
|
||||
background: black;
|
||||
|
||||
/** IE hacks */
|
||||
-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=85)";
|
||||
width: expression(document.documentElement.clientWidth+'px');
|
||||
height: expression(document.documentElement.clientHeight+'px');
|
||||
}
|
||||
|
||||
#newuseroverlay h3 {
|
||||
color: #333;
|
||||
font-size: normal;
|
||||
margin-top: 0.5em;
|
||||
}
|
||||
|
||||
#newuseroverlay form {
|
||||
width: 30em;
|
||||
margin: 6em auto;
|
||||
padding: 1em 2em;
|
||||
background: #F6F6F6;
|
||||
border: 2px solid #999;
|
||||
}
|
||||
|
||||
#newuseroverlay table td.title
|
||||
{
|
||||
color: #666;
|
||||
text-align: right;
|
||||
padding-right: 1em;
|
||||
white-space: nowrap;
|
||||
}
|
||||
|
||||
#newuseroverlay table td input
|
||||
{
|
||||
width: 20em;
|
||||
}
|
||||
|
||||
#newuseroverlay .formbuttons {
|
||||
text-align: center;
|
||||
}
|
Loading…
Reference in New Issue