mirror of
https://git.code.sf.net/p/seeddms/code
synced 2025-10-24 09:42:58 +00:00
556 lines
16 KiB
PHP
556 lines
16 KiB
PHP
<?php
|
|
/**
|
|
* Implementation of UsrMgr 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 UsrMgr 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_UsrMgr extends SeedDMS_Bootstrap_Style {
|
|
|
|
function show() { /* {{{ */
|
|
$dms = $this->params['dms'];
|
|
$user = $this->params['user'];
|
|
$seluser = $this->params['seluser'];
|
|
$users = $this->params['allusers'];
|
|
$groups = $this->params['allgroups'];
|
|
$passwordstrength = $this->params['passwordstrength'];
|
|
$passwordexpiration = $this->params['passwordexpiration'];
|
|
$httproot = $this->params['httproot'];
|
|
$enableuserimage = $this->params['enableuserimage'];
|
|
$workflowmode = $this->params['workflowmode'];
|
|
|
|
$this->htmlStartPage(getMLText("admin_tools"));
|
|
$this->globalNavigation();
|
|
$this->contentStart();
|
|
$this->pageNavigation(getMLText("admin_tools"), "admin_tools");
|
|
|
|
?>
|
|
<script language="JavaScript">
|
|
|
|
function checkForm(num)
|
|
{
|
|
msg = "";
|
|
eval("var formObj = document.form" + num + ";");
|
|
|
|
if (formObj.login.value == "") msg += "<?php printMLText("js_no_login");?>\n";
|
|
if ((num == '0') && (formObj.pwd.value == "")) msg += "<?php printMLText("js_no_pwd");?>\n";
|
|
if ((formObj.pwd.value != formObj.pwdconf.value)&&(formObj.pwd.value != "" )&&(formObj.pwd.value != "" )) msg += "<?php printMLText("js_pwd_not_conf");?>\n";
|
|
if (formObj.name.value == "") msg += "<?php printMLText("js_no_name");?>\n";
|
|
if (formObj.email.value == "") msg += "<?php printMLText("js_no_email");?>\n";
|
|
//if (formObj.comment.value == "") msg += "<?php printMLText("js_no_comment");?>\n";
|
|
if (msg != "")
|
|
{
|
|
alert(msg);
|
|
return false;
|
|
}
|
|
else
|
|
return true;
|
|
}
|
|
|
|
|
|
obj = -1;
|
|
function showUser(selectObj) {
|
|
if (obj != -1)
|
|
obj.style.display = "none";
|
|
|
|
id = selectObj.options[selectObj.selectedIndex].value;
|
|
if (id == -1)
|
|
return;
|
|
|
|
obj = document.getElementById("keywords" + id);
|
|
obj.style.display = "";
|
|
}
|
|
</script>
|
|
<?php
|
|
$this->contentHeading(getMLText("user_management"));
|
|
?>
|
|
|
|
<div class="row-fluid">
|
|
<div class="span4">
|
|
<div class="well">
|
|
<?php echo getMLText("selection")?>:
|
|
<select onchange="showUser(this)" id="selector" class="span9">
|
|
<option value="-1"><?php echo getMLText("choose_user")?>
|
|
<option value="0"><?php echo getMLText("add_user")?>
|
|
<?php
|
|
$selected=0;
|
|
$count=2;
|
|
foreach ($users as $currUser) {
|
|
if ($seluser && $currUser->getID()==$seluser->getID()) $selected=$count;
|
|
print "<option value=\"".$currUser->getID()."\">" . htmlspecialchars($currUser->getLogin() . " - ". $currUser->getFullName());
|
|
$count++;
|
|
}
|
|
?>
|
|
</select>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="span8">
|
|
<div class="well">
|
|
<table class="table-condensed">
|
|
<tr>
|
|
<td id="keywords0" style="display : none;">
|
|
|
|
<form action="../op/op.UsrMgr.php" method="post" enctype="multipart/form-data" name="form0" onsubmit="return checkForm('0');">
|
|
<?php echo createHiddenFieldWithKey('adduser'); ?>
|
|
<input type="Hidden" name="action" value="adduser">
|
|
<table class="table-condensed">
|
|
<tr>
|
|
<td><?php printMLText("user_login");?>:</td>
|
|
<td><input type="text" name="login"></td>
|
|
</tr>
|
|
<tr>
|
|
<td><?php printMLText("password");?>:</td>
|
|
<td><input class="pwd" type="password" rel="strengthbar" name="pwd" id="password"></td>
|
|
</tr>
|
|
<?php
|
|
if($passwordstrength > 0) {
|
|
?>
|
|
<tr>
|
|
<td><?php printMLText("password_strength");?>:</td>
|
|
<td>
|
|
<div id="strengthbar" class="progress" style="width: 220px; height: 30px; margin-bottom: 8px;"><div class="bar bar-danger" style="width: 0%;"></div></div>
|
|
</td>
|
|
</tr>
|
|
<?php
|
|
}
|
|
?>
|
|
<tr>
|
|
<td><?php printMLText("confirm_pwd");?>:</td>
|
|
<td><input type="password" name="pwdconf"></td>
|
|
</tr>
|
|
<?php
|
|
if($passwordexpiration > 0) {
|
|
?>
|
|
<tr>
|
|
<td><?php printMLText("password_expiration");?>:</td>
|
|
<td><select name="pwdexpiration"><option value="<?php echo date('Y-m-d H:i:s'); ?>"><?php printMLText("now");?></option><option value="<?php echo date('Y-m-d H:i:s', time()+$passwordexpiration*86400); ?>"><?php printMLText("according_settings");?></option></select></td>
|
|
</tr>
|
|
<?php
|
|
}
|
|
?>
|
|
<tr>
|
|
<td><?php printMLText("user_name");?>:</td>
|
|
<td><input type="text" name="name"></td>
|
|
</tr>
|
|
<tr>
|
|
<td><?php printMLText("email");?>:</td>
|
|
<td><input type="text" name="email"></td>
|
|
</tr>
|
|
<tr>
|
|
<td><?php printMLText("comment");?>:</td>
|
|
<td><textarea name="comment" rows="4" cols="50"></textarea></td>
|
|
</tr>
|
|
<tr>
|
|
<td><?php printMLText("role");?>:</td>
|
|
<td><select name="role"><option value="<?php echo SeedDMS_Core_User::role_user ?>"><?php printMLText("role_user"); ?></option><option value="<?php echo SeedDMS_Core_User::role_admin ?>"><?php printMLText("role_admin"); ?></option><option value="<?php echo SeedDMS_Core_User::role_guest ?>"><?php printMLText("role_guest"); ?></option></select></td>
|
|
</tr>
|
|
<tr>
|
|
<td><?php printMLText("groups");?>:</td>
|
|
<td><select class="chzn-select" multiple="multiple" name="groups[]" data-placeholder="<?php printMLText('select_groups'); ?>">
|
|
<?php
|
|
foreach($groups as $group) {
|
|
echo '<option value="'.$group->getID().'">'.$group->getName().'</option>';
|
|
}
|
|
?>
|
|
</select></td>
|
|
</tr>
|
|
<tr>
|
|
<td><?php printMLText("is_hidden");?>:</td>
|
|
<td><input type="checkbox" name="ishidden" value="1"></td>
|
|
</tr>
|
|
<tr>
|
|
<td><?php printMLText("is_disabled");?>:</td>
|
|
<td><input type="checkbox" name="isdisabled" value="1"></td>
|
|
</tr>
|
|
|
|
<?php if ($enableuserimage){ ?>
|
|
|
|
<tr>
|
|
<td><?php printMLText("user_image");?>:</td>
|
|
<td><input type="File" name="userfile"></td>
|
|
</tr>
|
|
|
|
<?php
|
|
}
|
|
if($workflowmode == "traditional") {
|
|
?>
|
|
|
|
<tr>
|
|
<td colspan="2"><?php printMLText("reviewers");?>:</td>
|
|
</tr>
|
|
<tr>
|
|
<td>
|
|
<div class="cbSelectTitle"><?php printMLText("individuals");?>:</div>
|
|
</td>
|
|
<td>
|
|
<select class="chzn-select" name="usrReviewers[]" multiple="multiple" data-placeholder="<?php printMLText('select_users'); ?>">
|
|
<?php
|
|
foreach ($users as $usr) {
|
|
|
|
if ($usr->isGuest()) continue;
|
|
|
|
print "<option value=\"".$usr->getID()."\">". htmlspecialchars($usr->getLogin()." - ".$usr->getFullName())."</option>";
|
|
}
|
|
?>
|
|
</select>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td>
|
|
<div class="cbSelectTitle"><?php printMLText("groups");?>:</div>
|
|
</td>
|
|
<td>
|
|
<select class="chzn-select" name="grpReviewers[]" multiple="multiple">
|
|
<?php
|
|
foreach ($groups as $grp) {
|
|
print "<option value=\"".$grp->getID()."\">". htmlspecialchars($grp->getName())."</option>";
|
|
}
|
|
?>
|
|
</select>
|
|
</td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td colspan="2"><?php printMLText("approvers");?>:</td>
|
|
</tr>
|
|
<tr>
|
|
<td>
|
|
<div class="cbSelectTitle"><?php printMLText("individuals");?>:</div>
|
|
</td>
|
|
<td>
|
|
<select class="chzn-select" name="usrApprovers[]" multiple="multiple">
|
|
<?php
|
|
foreach ($users as $usr) {
|
|
|
|
if ($usr->isGuest()) continue;
|
|
|
|
print "<option value=\"".$usr->getID()."\">". htmlspecialchars($usr->getLogin()." - ".$usr->getFullName())."</option>";
|
|
}
|
|
?>
|
|
</select>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td>
|
|
<div class="cbSelectTitle"><?php printMLText("groups");?>:</div>
|
|
</td>
|
|
<td>
|
|
<select class="chzn-select" name="grpApprovers[]" multiple="multiple">
|
|
<?php
|
|
foreach ($groups as $grp) {
|
|
|
|
print "<option value=\"".$grp->getID()."\">". htmlspecialchars($grp->getName())."</option>";
|
|
}
|
|
?>
|
|
</select>
|
|
</td>
|
|
</tr>
|
|
<?php
|
|
} else {
|
|
$workflows = $dms->getAllWorkflows();
|
|
if($workflows) {
|
|
?>
|
|
<tr>
|
|
<td>
|
|
<div class="cbSelectTitle"><?php printMLText("workflow");?>:</div>
|
|
</td>
|
|
<td>
|
|
<select name="workflow" data-placeholder="<?php printMLText('select_workflow'); ?>">
|
|
<?php
|
|
$workflows = $dms->getAllWorkflows();
|
|
print "<option value=\"\">"."</option>";
|
|
foreach ($workflows as $workflow) {
|
|
print "<option value=\"".$workflow->getID()."\">". htmlspecialchars($workflow->getName())."</option>";
|
|
}
|
|
?>
|
|
</select>
|
|
</td>
|
|
</tr>
|
|
<?php
|
|
}
|
|
}
|
|
?>
|
|
<tr>
|
|
<td></td>
|
|
<td><input type="submit" class="btn" value="<?php printMLText("add_user");?>"></td>
|
|
</tr>
|
|
</table>
|
|
</form>
|
|
|
|
</td>
|
|
|
|
|
|
<?php
|
|
foreach ($users as $currUser) {
|
|
|
|
print "<td id=\"keywords".$currUser->getID()."\" style=\"display : none;\">";
|
|
?>
|
|
<form action="../op/op.UsrMgr.php" method="post" enctype="multipart/form-data" name="form<?php print $currUser->getID();?>" onsubmit="return checkForm('<?php print $currUser->getID();?>');">
|
|
<?php echo createHiddenFieldWithKey('edituser'); ?>
|
|
<input type="hidden" name="userid" value="<?php print $currUser->getID();?>">
|
|
<input type="hidden" name="action" value="edituser">
|
|
<table class="table-condensed">
|
|
<tr>
|
|
<td></td>
|
|
<td><a class="standardText btn" href="../out/out.RemoveUser.php?userid=<?php print $currUser->getID();?>"><i class="icon-remove"></i> <?php printMLText("rm_user");?></a></td>
|
|
</tr>
|
|
<tr>
|
|
<td><?php printMLText("user_login");?>:</td>
|
|
<td><input type="text" name="login" value="<?php print htmlspecialchars($currUser->getLogin());?>"></td>
|
|
</tr>
|
|
<tr>
|
|
<td><?php printMLText("password");?>:</td>
|
|
<td><input type="password" class="pwd" rel="strengthbar<?php echo $currUser->getID(); ?>" name="pwd"></td>
|
|
</tr>
|
|
<?php
|
|
if($passwordstrength > 0) {
|
|
?>
|
|
<tr>
|
|
<td><?php printMLText("password_strength");?>:</td>
|
|
<td>
|
|
<div id="strengthbar<?php echo $currUser->getID(); ?>" class="progress" style="width: 220px; height: 30px; margin-bottom: 8px;"><div class="bar bar-danger" style="width: 0%;"></div></div>
|
|
</td>
|
|
</tr>
|
|
<?php
|
|
}
|
|
?>
|
|
<tr>
|
|
<td><?php printMLText("confirm_pwd");?>:</td>
|
|
<td><input type="Password" name="pwdconf"></td>
|
|
</tr>
|
|
<?php
|
|
if($passwordexpiration > 0) {
|
|
?>
|
|
<tr>
|
|
<td><?php printMLText("password_expiration");?>:</td>
|
|
<td><select name="pwdexpiration"><option value="<?php echo date('Y-m-d H:i:s'); ?>"><?php printMLText("now");?></option><option value="<?php echo date('Y-m-d H:i:s', time()+$passwordexpiration*86400); ?>"><?php printMLText("according_settings");?></option></select> <?php echo $currUser->getPwdExpiration(); ?></td>
|
|
</tr>
|
|
<?php
|
|
}
|
|
?>
|
|
<tr>
|
|
<td><?php printMLText("user_name");?>:</td>
|
|
<td><input type="text" name="name" value="<?php print htmlspecialchars($currUser->getFullName());?>"></td>
|
|
</tr>
|
|
<tr>
|
|
<td><?php printMLText("email");?>:</td>
|
|
<td><input type="text" name="email" value="<?php print htmlspecialchars($currUser->getEmail()) ;?>"></td>
|
|
</tr>
|
|
<tr>
|
|
<td><?php printMLText("comment");?>:</td>
|
|
<td><textarea name="comment" rows="4" cols="50"><?php print htmlspecialchars($currUser->getComment());?></textarea></td>
|
|
</tr>
|
|
<tr>
|
|
<td><?php printMLText("role");?>:</td>
|
|
<td><select name="role"><option value="<?php echo SeedDMS_Core_User::role_user ?>"><?php printMLText("role_user"); ?></option><option value="<?php echo SeedDMS_Core_User::role_admin ?>" <?php if($currUser->getRole() == SeedDMS_Core_User::role_admin) echo "selected"; ?>><?php printMLText("role_admin"); ?></option><option value="<?php echo SeedDMS_Core_User::role_guest ?>" <?php if($currUser->getRole() == SeedDMS_Core_User::role_guest) echo "selected"; ?>><?php printMLText("role_guest"); ?></option></select></td>
|
|
</tr>
|
|
<tr>
|
|
<td><?php printMLText("groups");?>:</td>
|
|
<td><select class="chzn-select" multiple="multiple" name="groups[]" data-placeholder="<?php printMLText('select_groups'); ?>">
|
|
<?php
|
|
foreach($groups as $group) {
|
|
echo '<option value="'.$group->getID().'"'.($group->isMember($currUser) ? ' selected' : '').'>'.$group->getName().'</option>';
|
|
}
|
|
?>
|
|
</select></td>
|
|
</tr>
|
|
<tr>
|
|
<td><?php printMLText("is_hidden");?>:</td>
|
|
<td><input type="checkbox" name="ishidden" value="1"<?php print ($currUser->isHidden() ? " checked='checked'" : "");?>></td>
|
|
</tr>
|
|
<tr>
|
|
<td><?php printMLText("is_disabled");?>:</td>
|
|
<td><input type="checkbox" name="isdisabled" value="1"<?php print ($currUser->isDisabled() ? " checked='checked'" : "");?>></td>
|
|
</tr>
|
|
|
|
<?php if ($enableuserimage){ ?>
|
|
|
|
<tr>
|
|
<td><?php printMLText("user_image");?>:</td>
|
|
<td>
|
|
<?php
|
|
if ($currUser->hasImage())
|
|
print "<img src=\"".$httproot . "out/out.UserImage.php?userid=".$currUser->getId()."\">";
|
|
else
|
|
printMLText("no_user_image");
|
|
?>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td><?php printMLText("new_user_image");?>:</td>
|
|
<td><input type="file" name="userfile" accept="image/jpeg"></td>
|
|
</tr>
|
|
|
|
<?php
|
|
}
|
|
if($workflowmode == "traditional") {
|
|
?>
|
|
|
|
<tr>
|
|
<td colspan="2"><?php printMLText("reviewers");?>:</td>
|
|
</tr>
|
|
<tr>
|
|
<td>
|
|
<div class="cbSelectTitle"><?php printMLText("individuals");?>:</div>
|
|
</td>
|
|
<td>
|
|
<select class="chzn-select" name="usrReviewers[]" multiple="multiple">
|
|
<?php
|
|
|
|
$res=$currUser->getMandatoryReviewers();
|
|
|
|
foreach ($users as $usr) {
|
|
|
|
if ($usr->isGuest() || ($usr->getID() == $currUser->getID()))
|
|
continue;
|
|
|
|
$checked=false;
|
|
foreach ($res as $r) if ($r['reviewerUserID']==$usr->getID()) $checked=true;
|
|
|
|
print "<option value=\"".$usr->getID()."\" ".($checked?"selected='selected' ":"").">". htmlspecialchars($usr->getLogin()." - ".$usr->getFullName())."</option>";
|
|
}
|
|
?>
|
|
</select>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td>
|
|
<div class="cbSelectTitle"><?php printMLText("groups");?>:</div>
|
|
</td>
|
|
<td>
|
|
<select class="chzn-select" name="grpReviewers[]" multiple="multiple" data-placeholder="<?php printMLText('select_groups'); ?>">
|
|
<?php
|
|
foreach ($groups as $grp) {
|
|
|
|
$checked=false;
|
|
foreach ($res as $r) if ($r['reviewerGroupID']==$grp->getID()) $checked=true;
|
|
|
|
print "<option value=\"".$grp->getID()."\" ".($checked?"selected='selected' ":"").">". htmlspecialchars($grp->getName())."</option>";
|
|
}
|
|
?>
|
|
</select>
|
|
</td>
|
|
</tr>
|
|
|
|
<tr>
|
|
<td colspan="2"><?php printMLText("approvers");?>:</td>
|
|
</tr>
|
|
<tr>
|
|
<td>
|
|
<div class="cbSelectTitle"><?php printMLText("individuals");?>:</div>
|
|
</td>
|
|
<td>
|
|
<select class="chzn-select" name="usrApprovers[]" multiple="multiple" data-placeholder="<?php printMLText('select_users'); ?>">
|
|
<?php
|
|
$res=$currUser->getMandatoryApprovers();
|
|
foreach ($users as $usr) {
|
|
if ($usr->isGuest() || ($usr->getID() == $currUser->getID()))
|
|
continue;
|
|
|
|
$checked=false;
|
|
foreach ($res as $r) if ($r['approverUserID']==$usr->getID()) $checked=true;
|
|
|
|
print "<option value=\"".$usr->getID()."\" ".($checked?"selected='selected' ":"").">". htmlspecialchars($usr->getLogin()." - ".$usr->getFullName())."</option>";
|
|
}
|
|
?>
|
|
</select>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td>
|
|
<div class="cbSelectTitle"><?php printMLText("groups");?>:</div>
|
|
</td>
|
|
<td>
|
|
<select class="chzn-select" name="grpApprovers[]" multiple="multiple" data-placeholder="<?php printMLText('select_groups'); ?>">
|
|
<?php
|
|
foreach ($groups as $grp) {
|
|
|
|
$checked=false;
|
|
foreach ($res as $r) if ($r['approverGroupID']==$grp->getID()) $checked=true;
|
|
|
|
print "<option value=\"".$grp->getID()."\" ".($checked?"selected='selected' ":"").">". htmlspecialchars($grp->getName())."</option>";
|
|
}
|
|
?>
|
|
</select>
|
|
</td>
|
|
</tr>
|
|
<?php
|
|
} else {
|
|
$workflows = $dms->getAllWorkflows();
|
|
if($workflows) {
|
|
?>
|
|
<tr>
|
|
<td>
|
|
<div class="cbSelectTitle"><?php printMLText("workflow");?>:</div>
|
|
</td>
|
|
<td>
|
|
<select name="workflow" data-placeholder="<?php printMLText('select_workflow'); ?>">
|
|
<?php
|
|
print "<option value=\"\">"."</option>";
|
|
foreach ($workflows as $workflow) {
|
|
print "<option value=\"".$workflow->getID()."\"";
|
|
if($currUser->getMandatoryWorkflow() && $currUser->getMandatoryWorkflow()->getID() == $workflow->getID())
|
|
echo " selected=\"selected\"";
|
|
print ">". htmlspecialchars($workflow->getName())."</option>";
|
|
}
|
|
?>
|
|
</select>
|
|
</td>
|
|
</tr>
|
|
<?php
|
|
}
|
|
}
|
|
?>
|
|
<tr>
|
|
<td></td>
|
|
<td><button type="submit" class="btn"><i class="icon-save"></i> <?php printMLText("save")?></button></td>
|
|
</tr>
|
|
</table>
|
|
</form>
|
|
</td>
|
|
<?php } ?>
|
|
</tr></table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<script language="JavaScript">
|
|
|
|
sel = document.getElementById("selector");
|
|
sel.selectedIndex=<?php print $selected ?>;
|
|
showUser(sel);
|
|
|
|
</script>
|
|
|
|
|
|
<?php
|
|
$this->htmlEndPage();
|
|
} /* }}} */
|
|
}
|
|
?>
|