<?php /** * Implementation of FolderAccess 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 FolderAccess 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_FolderAccess extends SeedDMS_Theme_Style { function printAccessModeSelection($defMode) { /* {{{ */ echo self::getAccessModeSelection($defMode); } /* }}} */ function getAccessModeSelection($defMode) { /* {{{ */ $content = "<select name=\"mode\" class=\"form-control\">\n"; $content .= "\t<option value=\"".M_NONE."\"" . (($defMode == M_NONE) ? " selected" : "") . ">" . getMLText("access_mode_none") . "\n"; $content .= "\t<option value=\"".M_READ."\"" . (($defMode == M_READ) ? " selected" : "") . ">" . getMLText("access_mode_read") . "\n"; $content .= "\t<option value=\"".M_READWRITE."\"" . (($defMode == M_READWRITE) ? " selected" : "") . ">" . getMLText("access_mode_readwrite") . "\n"; $content .= "\t<option value=\"".M_ALL."\"" . (($defMode == M_ALL) ? " selected" : "") . ">" . getMLText("access_mode_all") . "\n"; $content .= "</select>\n"; return $content; } /* }}} */ function js() { /* {{{ */ header('Content-Type: application/javascript; charset=UTF-8'); ?> function checkForm() { msg = new Array() if ((document.form1.userid.options[document.form1.userid.selectedIndex].value == -1) && (document.form1.groupid.options[document.form1.groupid.selectedIndex].value == -1)) msg.push("<?php printMLText("js_select_user_or_group");?>"); 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', '#form1', function(ev){ if(checkForm()) return; ev.preventDefault(); }); }); <?php } /* }}} */ function show() { /* {{{ */ $dms = $this->params['dms']; $user = $this->params['user']; $folder = $this->params['folder']; $allUsers = $this->params['allusers']; $allGroups = $this->params['allgroups']; $rootfolderid = $this->params['rootfolderid']; $this->htmlStartPage(getMLText("folder_title", array("foldername" => htmlspecialchars($folder->getName())))); $this->globalNavigation($folder); $this->contentStart(); $this->pageNavigation($this->getFolderPathHTML($folder, true), "view_folder", $folder); $this->contentHeading(getMLText("edit_folder_access")); $this->rowStart(); $this->columnStart(4); if ($user->isAdmin()) { ?> <form class="form-horizontal mb-4" action="../op/op.FolderAccess.php"> <?php echo createHiddenFieldWithKey('folderaccess'); ?> <input type="hidden" name="action" value="setowner"> <input type="hidden" name="folderid" value="<?php print $folder->getID();?>"> <?php $this->contentContainerStart(); $owner = $folder->getOwner(); $options = array(); foreach ($allUsers as $currUser) { if (!$currUser->isGuest()) $options[] = array($currUser->getID(), htmlspecialchars($currUser->getLogin()), ($currUser->getID()==$owner->getID()), array(array('data-subtitle', htmlspecialchars($currUser->getFullName())))); } $this->formField( getMLText("set_owner"), array( 'element'=>'select', 'name'=>'ownerid', 'class'=>'chzn-select', 'options'=>$options ) ); $this->contentContainerEnd(); $this->formSubmit("<i class=\"fa fa-save\"></i> ".getMLText('save')); ?> </form> <?php } if ($folder->getID() != $rootfolderid && $folder->getParent()){ $this->contentHeading(getMLText("access_inheritance")); if ($folder->inheritsAccess()) { $this->infoMsg(getMLText("inherits_access_msg")); ?> <p> <form action="../op/op.FolderAccess.php" style="display: inline-block;"> <?php echo createHiddenFieldWithKey('folderaccess'); ?> <input type="hidden" name="folderid" value="<?php print $folder->getID();?>"> <input type="hidden" name="action" value="notinherit"> <input type="hidden" name="mode" value="copy"> <input type="submit" class="btn btn-primary" value="<?php printMLText("inherits_access_copy_msg")?>"> </form> <form action="../op/op.FolderAccess.php" style="display: inline-block;"> <?php echo createHiddenFieldWithKey('folderaccess'); ?> <input type="hidden" name="folderid" value="<?php print $folder->getID();?>"> <input type="hidden" name="action" value="notinherit"> <input type="hidden" name="mode" value="empty"> <input type="submit" class="btn btn-primary" value="<?php printMLText("inherits_access_empty_msg")?>"> </form> </p> <?php $this->columnEnd(); $this->rowEnd(); $this->contentEnd(); $this->htmlEndPage(); return; } ?> <form action="../op/op.FolderAccess.php"> <?php echo createHiddenFieldWithKey('folderaccess'); ?> <input type="hidden" name="folderid" value="<?php print $folder->getID();?>"> <input type="hidden" name="action" value="inherit"> <input type="submit" class="btn btn-primary" value="<?php printMLText("does_not_inherit_access_msg")?>"> </form> <?php } $this->columnEnd(); $this->columnStart(4); $accessList = $folder->getAccessList(); ?> <form class="form-horizontal mb-4" action="../op/op.FolderAccess.php"> <?php echo createHiddenFieldWithKey('folderaccess'); ?> <input type="hidden" name="folderid" value="<?php print $folder->getID();?>"> <input type="hidden" name="action" value="setdefault"> <?php $this->contentContainerStart(); $this->formField( getMLText("default_access"), $this->getAccessModeSelection($folder->getDefaultAccess()) ); $this->contentContainerEnd(); $this->formSubmit("<i class=\"fa fa-save\"></i> ".getMLText('save')); ?> </form> <?php ?> <form class="form-horizontal" action="../op/op.FolderAccess.php" id="form1" name="form1"> <?php echo createHiddenFieldWithKey('folderaccess'); ?> <input type="hidden" name="folderid" value="<?php print $folder->getID()?>"> <input type="hidden" name="action" value="addaccess"> <?php $this->contentContainerStart(); $options = array(); $options[] = array(-1, getMLText('select_one')); foreach ($allUsers as $currUser) { if (!$currUser->isGuest()) $options[] = array($currUser->getID(), htmlspecialchars($currUser->getLogin()), false, array(array('data-subtitle', htmlspecialchars($currUser->getFullName())))); } $this->formField( getMLText("user"), array( 'element'=>'select', 'name'=>'userid', 'id'=>'userid', 'class'=>'chzn-select', 'attributes'=>array(array('data-allow-clear', 'true'), array('data-placeholder',getMLText('select_user'))), 'options'=>$options ) ); $options = array(); $options[] = array(-1, getMLText('select_one')); foreach ($allGroups as $groupObj) { $options[] = array($groupObj->getID(), htmlspecialchars($groupObj->getName())); } $this->formField( getMLText("group"), array( 'element'=>'select', 'name'=>'groupid', 'class'=>'chzn-select', 'attributes'=>array(array('data-allow-clear', 'true'), array('data-placeholder', getMLText('select_group'))), 'options'=>$options ) ); $this->formField( getMLText("access_mode"), $this->getAccessModeSelection(M_READ) ); $this->contentContainerEnd(); $this->formSubmit("<i class=\"fa fa-plus\"></i> ".getMLText('add')); ?> </form> <?php $this->columnEnd(); $this->columnStart(4); if ((count($accessList["users"]) != 0) || (count($accessList["groups"]) != 0)) { print "<table class=\"table-condensed\">"; foreach ($accessList["users"] as $userAccess) { $userObj = $userAccess->getUser(); print "<tr>\n"; print "<td><i class=\"fa fa-user\"></i></td>\n"; print "<td>". htmlspecialchars($userObj->getFullName()) . "</td>\n"; print "<form action=\"../op/op.FolderAccess.php\">\n"; echo createHiddenFieldWithKey('folderaccess')."\n"; print "<input type=\"hidden\" name=\"folderid\" value=\"".$folder->getID()."\">\n"; print "<input type=\"hidden\" name=\"action\" value=\"editaccess\">\n"; print "<input type=\"hidden\" name=\"userid\" value=\"".$userObj->getID()."\">\n"; print "<td>\n"; $this->printAccessModeSelection($userAccess->getMode()); print "</td>\n"; print "<td>\n"; print "<button type=\"submit\" class=\"btn btn-primary btn-mini btn-sm\"><i class=\"fa fa-save\"></i> ".getMLText("save")."</button>"; print "</td>\n"; print "</form>\n"; print "<form action=\"../op/op.FolderAccess.php\">\n"; echo createHiddenFieldWithKey('folderaccess')."\n"; print "<input type=\"hidden\" name=\"folderid\" value=\"".$folder->getID()."\">\n"; print "<input type=\"hidden\" name=\"action\" value=\"delaccess\">\n"; print "<input type=\"hidden\" name=\"userid\" value=\"".$userObj->getID()."\">\n"; print "<td>\n"; print "<button type=\"submit\" class=\"btn btn-danger btn-mini btn-sm\"><i class=\"fa fa-remove\"></i> ".getMLText("delete")."</button>"; print "</td>\n"; print "</form>\n"; print "</tr>\n"; } foreach ($accessList["groups"] as $groupAccess) { $groupObj = $groupAccess->getGroup(); $mode = $groupAccess->getMode(); print "<tr>"; print "<td><i class=\"fa fa-group\"></i></td>"; print "<td>". htmlspecialchars($groupObj->getName()) . "</td>"; print "<form action=\"../op/op.FolderAccess.php\">"; echo createHiddenFieldWithKey('folderaccess')."\n"; print "<input type=\"hidden\" name=\"folderid\" value=\"".$folder->getID()."\">"; print "<input type=\"hidden\" name=\"action\" value=\"editaccess\">"; print "<input type=\"hidden\" name=\"groupid\" value=\"".$groupObj->getID()."\">"; print "<td>"; $this->printAccessModeSelection($groupAccess->getMode()); print "</td>\n"; print "<td><span class=\"actions\">\n"; print "<button type=\"submit\" class=\"btn btn-primary btn-mini btn-sm\"><i class=\"fa fa-save\"></i> ".getMLText("save")."</button>"; print "</span></td>\n"; print "</form>"; print "<form action=\"../op/op.FolderAccess.php\">\n"; echo createHiddenFieldWithKey('folderaccess')."\n"; print "<input type=\"hidden\" name=\"folderid\" value=\"".$folder->getID()."\">\n"; print "<input type=\"hidden\" name=\"action\" value=\"delaccess\">\n"; print "<input type=\"hidden\" name=\"groupid\" value=\"".$groupObj->getID()."\">\n"; print "<td>"; print "<button type=\"submit\" class=\"btn btn-danger btn-mini btn-sm\"><i class=\"fa fa-remove\"></i> ".getMLText("delete")."</button>"; print "</td>\n"; print "</form>"; print "</tr>\n"; } print "</table><br>"; } $this->columnEnd(); $this->rowEnd(); $this->contentEnd(); $this->htmlEndPage(); } /* }}} */ } ?>