X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=program%2Fsteps%2Fsettings%2Fedit_identity.inc;fp=program%2Fsteps%2Fsettings%2Fedit_identity.inc;h=3e96b2477996f759593a23c67e09fbe9e5a2f127;hb=3adad46e27086084a8b28a32fc4fbc953dbfef6c;hp=ee61e1aeb527e90f224b3e7705332a637d5a3ddc;hpb=48e8459231a1efa3e97284d07a328776a5b7485b;p=roundcube.git diff --git a/program/steps/settings/edit_identity.inc b/program/steps/settings/edit_identity.inc index ee61e1a..3e96b24 100644 --- a/program/steps/settings/edit_identity.inc +++ b/program/steps/settings/edit_identity.inc @@ -15,69 +15,70 @@ | Author: Thomas Bruederli | +-----------------------------------------------------------------------+ - $Id: edit_identity.inc 1412 2008-05-21 07:45:54Z alec $ + $Id: edit_identity.inc 2040 2008-11-05 10:19:44Z alec $ */ -$OUTPUT->set_pagetitle(rcube_label('identities')); +define('IDENTITIES_LEVEL', intval($RCMAIL->config->get('identities_level', 0))); -if (($_GET['_iid'] || $_POST['_iid']) && $RCMAIL->action=='edit-identity') - { +// edit-identity +if (($_GET['_iid'] || $_POST['_iid']) && $RCMAIL->action=='edit-identity') { $IDENTITY_RECORD = $USER->get_identity(get_input_value('_iid', RCUBE_INPUT_GPC)); if (is_array($IDENTITY_RECORD)) $OUTPUT->set_env('iid', $IDENTITY_RECORD['identity_id']); + else { + $OUTPUT->show_message('opnotpermitted', 'error'); + // go to identities page + rcmail_overwrite_action('identities'); + return; } - - -$OUTPUT->include_script('list.js'); +} +// add-identity +else { + if (IDENTITIES_LEVEL > 1) { + $OUTPUT->show_message('opnotpermitted', 'error'); + // go to identities page + rcmail_overwrite_action('identities'); + return; + } + else if (IDENTITIES_LEVEL == 1) + $IDENTITY_RECORD['email'] = rcmail_get_email(); +} function rcube_identity_form($attrib) { global $IDENTITY_RECORD, $RCMAIL, $OUTPUT; - $tinylang = substr($_SESSION['language'], 0, 2); - if (!file_exists('program/js/tiny_mce/langs/'.$tinylang.'.js')) - { - $tinylang = 'en'; - } - - $OUTPUT->include_script('tiny_mce/tiny_mce.js'); - $OUTPUT->add_script("tinyMCE.init({ mode : 'textareas'," . - "editor_selector : 'mce_editor'," . - "apply_source_formatting : true," . - "language : '$tinylang'," . - "content_css : '\$__skin_path' + '/editor_content.css'," . - "theme : 'advanced'," . - "theme_advanced_toolbar_location : 'top'," . - "theme_advanced_toolbar_align : 'left'," . - "theme_advanced_buttons1 : 'bold,italic,underline,strikethrough,justifyleft,justifycenter,justifyright,justifyfull,separator,outdent,indent,charmap,hr'," . - "theme_advanced_buttons2 : 'link,unlink,code,forecolor,fontselect,fontsizeselect'," . - "theme_advanced_buttons3 : '' });"); - - if (!$IDENTITY_RECORD && $RCMAIL->action != 'add-identity') - return rcube_label('notfound'); + rcube_html_editor('identity'); // add some labels to client - rcube_add_label('noemailwarning', 'nonamewarning'); + $OUTPUT->add_label('noemailwarning', 'nonamewarning', 'converting', 'editorwarning'); + $i_size = !empty($attrib['size']) ? $attrib['size'] : 40; + $t_rows = !empty($attrib['textarearows']) ? $attrib['textarearows'] : 6; + $t_cols = !empty($attrib['textareacols']) ? $attrib['textareacols'] : 40; list($form_start, $form_end) = get_form_tags($attrib, 'save-identity', array('name' => '_iid', 'value' => $IDENTITY_RECORD['identity_id'])); unset($attrib['form']); - // list of available cols - $a_show_cols = array('name' => array('type' => 'text'), - 'email' => array('type' => 'text'), - 'organization' => array('type' => 'text'), - 'reply-to' => array('type' => 'text', 'label' => 'replyto'), - 'bcc' => array('type' => 'text'), - 'signature' => array('type' => 'textarea', 'size' => "40", 'rows' => "6"), - 'html_signature'=>array('type' => 'checkbox', 'label' => 'htmlsignature', 'onclick' => 'return rcmail.toggle_editor(this, \'rcmfd_signature\');'), + $a_show_cols = array('name' => array('type' => 'text', 'size' => $i_size), + 'email' => array('type' => 'text', 'size' => $i_size), + 'organization' => array('type' => 'text', 'size' => $i_size), + 'reply-to' => array('type' => 'text', 'label' => 'reply-to', 'size' => $i_size), + 'bcc' => array('type' => 'text', 'size' => $i_size), + 'signature' => array('type' => 'textarea', 'size' => $t_cols, 'rows' => $t_rows), + 'html_signature'=>array('type' => 'checkbox', 'label' => 'htmlsignature', 'onclick' => 'return rcmail_toggle_editor(this.checked, \'rcmfd_signature\');'), 'standard' => array('type' => 'checkbox', 'label' => 'setdefault')); - + // disable some field according to access level + if (IDENTITIES_LEVEL == 1 || IDENTITIES_LEVEL == 3) { + $a_show_cols['email']['disabled'] = true; + $a_show_cols['email']['class'] = 'disabled'; + } + // a specific part is requested if ($attrib['part']) { @@ -85,7 +86,7 @@ function rcube_identity_form($attrib) if (is_array($colprop)) { $out = $form_start; - $out .= rcmail_get_edit_field($attrib['part'], $IDENTITY_RECORD[$attrib['part']], $attrib + array('size' => 30), $colprop['type']); + $out .= rcmail_get_edit_field($attrib['part'], $IDENTITY_RECORD[$attrib['part']], $attrib, $colprop['type']); return $out; } else @@ -98,33 +99,22 @@ function rcube_identity_form($attrib) foreach ($a_show_cols as $col => $colprop) { - $attrib['id'] = 'rcmfd_'.$col; - - if (strlen($colprop['onclick'])) - $attrib['onclick'] = $colprop['onclick']; - else - unset($attrib['onclick']); + $colprop['id'] = 'rcmfd_'.$col; if ($col == 'signature') { - $attrib['size'] = $colprop['size']; - $attrib['rows'] = $colprop['rows']; + $colprop['spellcheck'] = true; if ($IDENTITY_RECORD['html_signature']) { - $attrib['class'] = "mce_editor"; + $colprop['class'] = 'mce_editor'; } } - else - { - $attrib['size'] = 40; - unset($attrib['rows']); - } $label = strlen($colprop['label']) ? $colprop['label'] : $col; - $value = rcmail_get_edit_field($col, $IDENTITY_RECORD[$col], $attrib, $colprop['type']); + $value = rcmail_get_edit_field($col, $IDENTITY_RECORD[$col], $colprop, $colprop['type']); $out .= sprintf("%s\n", - $attrib['id'], + $colprop['id'], Q(rcube_label($label)), $value); } @@ -134,10 +124,15 @@ function rcube_identity_form($attrib) return $out; } +$OUTPUT->include_script('list.js'); $OUTPUT->add_handler('identityform', 'rcube_identity_form'); +$OUTPUT->set_env('identities_level', IDENTITIES_LEVEL); -if ($RCMAIL->action=='add-identity' && template_exists('addidentity')) +$OUTPUT->set_pagetitle(rcube_label(($RCMAIL->action=='add-identity' ? 'newidentity' : 'edititem'))); + +if ($RCMAIL->action=='add-identity' && $OUTPUT->template_exists('addidentity')) $OUTPUT->send('addidentity'); $OUTPUT->send('editidentity'); + ?>