<?php /** * Implementation of RoleMgr view * * @category DMS * @package SeedDMS * @license GPL 2 * @version @version@ * @author Uwe Steinmann <uwe@steinmann.cx> * @copyright Copyright (C) 2002-2005 Markus Westphal, * 2006-2008 Malcolm Cowe, 2010 Matteo Lucarelli, * 2010-2012 Uwe Steinmann * @version Release: @package_version@ */ /** * Include parent class */ //require_once("class.Bootstrap.php"); /** * Class which outputs the html page for RoleMgr view * * @category DMS * @package SeedDMS * @author Markus Westphal, Malcolm Cowe, Uwe Steinmann <uwe@steinmann.cx> * @copyright Copyright (C) 2002-2005 Markus Westphal, * 2006-2008 Malcolm Cowe, 2010 Matteo Lucarelli, * 2010-2012 Uwe Steinmann * @version Release: @package_version@ */ class SeedDMS_View_RoleMgr extends SeedDMS_Theme_Style { function js() { /* {{{ */ $selrole = $this->params['selrole']; header('Content-Type: application/javascript'); ?> function checkForm() { msg = new Array(); if($("#name").val() == "") msg.push("<?php printMLText("js_no_name");?>"); if (msg != "") { noty({ text: msg.join('<br />'), type: 'error', dismissQueue: true, layout: 'topRight', theme: 'defaultTheme', _timeout: 1500, }); return false; } else return true; } $(document).ready( function() { $('body').on('submit', '#form', function(ev){ if(checkForm()) return; event.preventDefault(); }); $( "#selector" ).change(function() { $('div.ajax').trigger('update', {roleid: $(this).val()}); window.history.pushState({"html":"","pageTitle":""},"", '../out/out.RoleMgr.php?roleid=' + $(this).val()); }); }); <?php } /* }}} */ function info() { /* {{{ */ $dms = $this->params['dms']; $user = $this->params['user']; $selrole = $this->params['selrole']; $settings = $this->params['settings']; $accessobject = $this->params['accessobject']; if($selrole) { $this->contentHeading(getMLText("role_info")); $users = $selrole->getUsers(); if($users) { echo "<table class=\"table table-condensed table-sm\"><thead><tr><th>".getMLText('name')."</th><th></th></tr></thead><tbody>\n"; foreach($users as $currUser) { echo "<tr>"; echo "<td>"; echo htmlspecialchars($currUser->getFullName())." (".htmlspecialchars($currUser->getLogin()).")"; echo "<br /><a href=\"mailto:".htmlspecialchars($currUser->getEmail())."\">".htmlspecialchars($currUser->getEmail())."</a>"; if($currUser->getComment()) echo "<br /><small>".htmlspecialchars($currUser->getComment())."</small>"; echo "</td>"; echo "<td>"; if($accessobject->check_view_access(array('UsrMgr', 'RemoveUser'))) { echo "<div class=\"list-action\">"; echo $this->html_link('UsrMgr', array('userid'=>$currUser->getID()), array(), '<i class="fa fa-edit"></i>', false); echo $this->html_link('RemoveUser', array('userid'=>$currUser->getID()), array(), '<i class="fa fa-remove"></i>', false); echo "</div>"; } echo "</td>"; echo "</tr>"; } echo "</tbody></table>"; } } } /* }}} */ function actionmenu() { /* {{{ */ $dms = $this->params['dms']; $user = $this->params['user']; $selrole = $this->params['selrole']; $accessop = $this->params['accessobject']; if($selrole) { if(!$selrole->isUsed() && $accessop->check_controller_access('RoleMgr', array('action'=>'removerole'))) { ?> <form style="display: inline-block;" method="post" action="../op/op.RoleMgr.php" > <?php echo createHiddenFieldWithKey('removerole'); ?> <input type="hidden" name="roleid" value="<?php echo $selrole->getID()?>"> <input type="hidden" name="action" value="removerole"> <?php $this->formSubmit('<i class="fa fa-remove"></i> '.getMLText('rm_role'),'','','secondary');?> </form> <?php } } } /* }}} */ function form() { /* {{{ */ $selrole = $this->params['selrole']; $this->showRoleForm($selrole); } /* }}} */ function showRoleForm($currRole) { /* {{{ */ $dms = $this->params['dms']; $user = $this->params['user']; $accessop = $this->params['accessobject']; ?> <form class="form-horizontal" action="../op/op.RoleMgr.php" method="post" enctype="multipart/form-data" name="form" id="form"> <?php if($currRole) { echo createHiddenFieldWithKey('editrole'); ?> <input type="hidden" name="roleid" id="roleid" value="<?php print $currRole->getID();?>"> <input type="hidden" name="action" value="editrole"> <?php } else { echo createHiddenFieldWithKey('addrole'); ?> <input type="hidden" id="roleid" value="0"> <input type="hidden" name="action" value="addrole"> <?php } $this->contentContainerStart(); $this->formField( getMLText("role_name"), array( 'element'=>'input', 'type'=>'text', 'id'=>'name', 'name'=>'name', 'value'=>($currRole ? htmlspecialchars($currRole->getName()) : '') ) ); $options = array(); $options[] = array(SeedDMS_Core_Role::role_user, getMLText("role_user"), $currRole && $currRole->getRole() == SeedDMS_Core_Role::role_user); $options[] = array(SeedDMS_Core_Role::role_admin, getMLText("role_admin"), $currRole && $currRole->getRole() == SeedDMS_Core_Role::role_admin); $options[] = array(SeedDMS_Core_Role::role_guest, getMLText("role_guest"), $currRole && $currRole->getRole() == SeedDMS_Core_Role::role_guest); $this->formField( getMLText("role_type"), array( 'element'=>'select', 'name'=>'role', 'options'=>$options ) ); if($currRole && $currRole->getRole() != SeedDMS_Core_Role::role_admin) { $options = array(); foreach(array(S_DRAFT_REV, S_DRAFT_APP, S_IN_WORKFLOW, S_REJECTED, S_RELEASED, S_IN_REVISION, S_DRAFT, S_EXPIRED, S_OBSOLETE, S_NEEDS_CORRECTION) as $status) { $options[] = array($status, getOverallStatusText($status), in_array($status, $currRole->getNoAccess())); } $this->formField( getMLText("restrict_access"), array( 'element'=>'select', 'name'=>'noaccess[]', 'options'=>$options, 'multiple'=>true, ) ); } $this->contentContainerEnd(); if($currRole && $accessop->check_controller_access('RoleMgr', array('action'=>'editrole')) || !$currRole && $accessop->check_controller_access('RoleMgr', array('action'=>'addrole'))) { $this->formSubmit("<i class=\"fa fa-save\"></i> ".getMLText($currRole ? "save" : "add_role")); } ?> </form> <?php } /* }}} */ function show() { /* {{{ */ $dms = $this->params['dms']; $user = $this->params['user']; $accessop = $this->params['accessobject']; $selrole = $this->params['selrole']; $roles = $this->params['allroles']; $this->htmlStartPage(getMLText("admin_tools")); $this->globalNavigation(); $this->contentStart(); $this->pageNavigation(getMLText("admin_tools"), "admin_tools"); $this->contentHeading(getMLText("role_management")); $this->rowStart(); $this->columnStart(4); ?> <form class="form-horizontal"> <?php $options = array(); $options[] = array("-1", getMLText("choose_role")); if($accessop->check_controller_access('RoleMgr', array('action'=>'addrole'))) { $options[] = array("0", getMLText("add_role")); } foreach ($roles as $currRole) { $options[] = array($currRole->getID(), htmlspecialchars($currRole->getName()), $selrole && $currRole->getID()==$selrole->getID()); } $this->formField( null, //getMLText("selection"), array( 'element'=>'select', 'id'=>'selector', 'class'=>'chzn-select', 'options'=>$options ) ); ?> </form> <div class="ajax" style="margin-bottom: 15px;" data-view="RoleMgr" data-action="actionmenu" <?php echo ($selrole ? "data-query=\"roleid=".$selrole->getID()."\"" : "") ?>></div> <?php if($accessop->check_view_access($this, array('action'=>'info'))) { ?> <div class="ajax" data-view="RoleMgr" data-action="info" <?php echo ($selrole ? "data-query=\"roleid=".$selrole->getID()."\"" : "") ?>></div> <?php } $this->columnEnd(); $this->columnStart(8); ?> <?php if($accessop->check_view_access($this, array('action'=>'form'))) { ?> <div class="ajax" data-view="RoleMgr" data-action="form" <?php echo ($selrole ? "data-query=\"roleid=".$selrole->getID()."\"" : "") ?>></div> <?php } else { $this->errorMsg(getMLText('access_denied')); } $this->rowEnd(); $this->columnEnd(); $this->contentEnd(); $this->htmlEndPage(); } /* }}} */ }