* @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 AddDocument view * * @category DMS * @package SeedDMS * @author Markus Westphal, Malcolm Cowe, Uwe Steinmann * @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_AddDocument extends SeedDMS_Bootstrap_Style { function js() { /* {{{ */ $dropfolderdir = $this->params['dropfolderdir']; $partitionsize = $this->params['partitionsize']; $maxuploadsize = $this->params['maxuploadsize']; $enablelargefileupload = $this->params['enablelargefileupload']; $enablemultiupload = $this->params['enablemultiupload']; $enableattachmentupload = $this->params['enableattachmentupload']; header('Content-Type: application/javascript; charset=UTF-8'); if($enablelargefileupload) { $this->printFineUploaderJs('../op/op.UploadChunks.php', $partitionsize, $maxuploadsize, $enablemultiupload); if($enableattachmentupload) { //$this->printFineUploaderJs('../op/op.UploadChunks.php', $partitionsize, $maxuploadsize, , $enablemultiupload, 'attachment'); } } ?> $(document).ready(function() { $('#new-file').click(function(event) { $("#userfile-upload-file").clone().appendTo("#userfile-upload-files").removeAttr("id").children('div').children('input').val(''); }); $('#new-attachment').click(function(event) { console.log('Hallo'); $("#attachment-upload-file").clone().appendTo("#attachment-upload-files").removeAttr("id").children('div').children('input').val(''); }); jQuery.validator.addMethod("alternatives", function(value, element, params) { if(value == '' && params.val() == '') return false; return true; }, ""); /* The fineuploader validation is actually checking all fields that can contain * a file to be uploaded. First checks if an alternative input field is set, * second loops through the list of scheduled uploads, checking if at least one * file will be submitted. */ jQuery.validator.addMethod("fineuploader", function(value, element, params) { if(params[1].val() != '') return true; uploader = params[0]; arr = uploader.getUploads(); for(var i in arr) { if(arr[i].status == 'submitted') return true; } return false; }, ""); $("#form1").validate({ debug: false, ignore: ":hidden:not(.do_validate)", invalidHandler: function(e, validator) { noty({ text: (validator.numberOfInvalids() == 1) ? "".replace('#', validator.numberOfInvalids()) : "".replace('#', validator.numberOfInvalids()), type: 'error', dismissQueue: true, layout: 'topRight', theme: 'defaultTheme', timeout: 1500, }); }, submitHandler: function(form) { userfileuploader.uploadStoredFiles(); // attachmentuploader.uploadStoredFiles(); }, rules: { 'userfile-fine-uploader-uuids': { fineuploader: [ userfileuploader, $('#dropfolderfileform1') ] } 'userfile[]': { alternatives: $('#dropfolderfileform1') }, dropfolderfileform1: { alternatives: $(".btn-file input") } }, messages: { name: "", comment: "", keywords: "" }, errorPlacement: function( error, element ) { if ( element.is( ":file" ) ) { error.appendTo( element.parent().parent().parent()); } else { error.appendTo( element.parent()); } } }); $('#presetexpdate').on('change', function(ev){ if($(this).val() == 'date') $('#control_expdate').show(); else $('#control_expdate').hide(); }); }); printKeywordChooserJs("form1"); if($dropfolderdir) { $this->printDropFolderChooserJs("form1"); } } /* }}} */ function show() { /* {{{ */ $dms = $this->params['dms']; $user = $this->params['user']; $folder = $this->params['folder']; $enablelargefileupload = $this->params['enablelargefileupload']; $enablemultiupload = $this->params['enablemultiupload']; $enableattachmentupload = $this->params['enableattachmentupload']; $enableadminrevapp = $this->params['enableadminrevapp']; $enableownerrevapp = $this->params['enableownerrevapp']; $enableselfrevapp = $this->params['enableselfrevapp']; $strictformcheck = $this->params['strictformcheck']; $dropfolderdir = $this->params['dropfolderdir']; $workflowmode = $this->params['workflowmode']; $presetexpiration = $this->params['presetexpiration']; $sortusersinlist = $this->params['sortusersinlist']; $orderby = $this->params['orderby']; $folderid = $folder->getId(); $this->htmlAddHeader(''."\n", 'js'); if($enablelargefileupload) { $this->htmlAddHeader(''."\n", 'js'); $this->htmlAddHeader($this->getFineUploaderTemplate(), 'js'); } $this->htmlStartPage(getMLText("folder_title", array("foldername" => htmlspecialchars($folder->getName())))); $this->globalNavigation($folder); $this->contentStart(); $this->pageNavigation($this->getFolderPathHTML($folder, true), "view_folder", $folder); $msg = getMLText("max_upload_size").": ".ini_get( "upload_max_filesize"); $this->warningMsg($msg); $this->contentHeading(getMLText("add_document")); $this->contentContainerStart(); // Retrieve a list of all users and groups that have review / approve // privileges. $docAccess = $folder->getReadAccessList($enableadminrevapp, $enableownerrevapp); ?>
> isAdmin()) { ?> getAllAttributeDefinitions(array(SeedDMS_Core_AttributeDefinition::objtype_document, SeedDMS_Core_AttributeDefinition::objtype_all)); if($attrdefs) { foreach($attrdefs as $attrdef) { $arr = $this->callHook('editDocumentAttribute', null, $attrdef); if(is_array($arr)) { echo ""; echo ""; echo ""; echo ""; } else { ?> callHook('addDocumentAttributes', $folder); if(is_array($arrs)) { foreach($arrs as $arr) { echo ""; echo ""; echo ""; echo ""; } } ?> getAllAttributeDefinitions(array(SeedDMS_Core_AttributeDefinition::objtype_documentcontent, SeedDMS_Core_AttributeDefinition::objtype_all)); if($attrdefs) { foreach($attrdefs as $attrdef) { $arr = $this->callHook('editDocumentAttribute', null, $attrdef); if(is_array($arr)) { echo ""; echo ""; echo ""; echo ""; } else { ?>
contentSubHeading(getMLText("document_infos")); ?>
:
:
: printKeywordChooserHtml("form1");?>
:
: printSequenceChooser($folder->getDocuments('s')); if($orderby != 's') echo "
".getMLText('order_by_sequence_off'); ?>
:
:
:
".$arr[0].":".$arr[1]."
getName()); ?> printAttributeEditField($attrdef, '') ?>
".$arr[0].":".$arr[1]."
contentSubHeading(getMLText("version_info")); ?>
:
: printFineUploaderHtml(); else { $this->printFileChooser('userfile[]', false); if($enablemultiupload) { ?>
: printDropFolderChooserHtml("form1");?>
:
".$arr[0].":".$arr[1]."
getName()); ?> printAttributeEditField($attrdef, '', 'attributes_version') ?>
contentSubHeading(getMLText("linked_files")); ?>
: printFineUploaderHtml('attachment'); else { $this->printFileChooser('attachment[]', false); ?>
:
getMandatoryWorkflows(); if($mandatoryworkflows) { if(count($mandatoryworkflows) == 1) { ?> getName()); ?>
warningMsg(getMLText("add_doc_workflow_warning")); ?>
contentSubHeading(getMLText("assign_reviewers")); ?>
:
getMandatoryReviewers(); ?> 0) { $u = $dms->getUser($r['reviewerUserID']); $tmp[] = htmlspecialchars($u->getFullName().' ('.$u->getLogin().')'); } } if($tmp) { echo '
'.getMLText('mandatory_reviewers').': '; echo implode(', ', $tmp); echo "
\n"; } } /* Check for mandatory reviewer without access */ foreach($res as $r) { if($r['reviewerUserID']) { $hasAccess = false; foreach ($docAccess["users"] as $usr) { if ($r['reviewerUserID']==$usr->getID()) $hasAccess = true; } if(!$hasAccess) { $noAccessUser = $dms->getUser($r['reviewerUserID']); echo "
".getMLText("mandatory_reviewer_no_access", array('user'=>htmlspecialchars($noAccessUser->getFullName()." (".$noAccessUser->getLogin().")")))."
"; } } } ?>
:
0) { $u = $dms->getGroup($r['reviewerGroupID']); $tmp[] = htmlspecialchars($u->getName()); } } if($tmp) { echo '
'.getMLText('mandatory_reviewergroups').': '; echo implode(', ', $tmp); echo "
\n"; } } /* Check for mandatory reviewer group without access */ foreach($res as $r) { if ($r['reviewerGroupID']) { $hasAccess = false; foreach ($docAccess["groups"] as $grp) { if ($r['reviewerGroupID']==$grp->getID()) $hasAccess = true; } if(!$hasAccess) { $noAccessGroup = $dms->getGroup($r['reviewerGroupID']); echo "
".getMLText("mandatory_reviewergroup_no_access", array('group'=>htmlspecialchars($noAccessGroup->getName())))."
"; } } } ?>
contentSubHeading(getMLText("assign_approvers")); ?>
:
0) { $u = $dms->getUser($r['approverUserID']); $tmp[] = htmlspecialchars($u->getFullName().' ('.$u->getLogin().')'); } } if($tmp) { echo '
'.getMLText('mandatory_approvers').': '; echo implode(', ', $tmp); echo "
\n"; } } /* Check for mandatory approvers without access */ foreach($res as $r) { if($r['approverUserID']) { $hasAccess = false; foreach ($docAccess["users"] as $usr) { if ($r['approverUserID']==$usr->getID()) $hasAccess = true; } if(!$hasAccess) { $noAccessUser = $dms->getUser($r['approverUserID']); echo "
".getMLText("mandatory_approver_no_access", array('user'=>htmlspecialchars($noAccessUser->getFullName()." (".$noAccessUser->getLogin().")")))."
"; } } } ?>
:
0) { $u = $dms->getGroup($r['approverGroupID']); $tmp[] = htmlspecialchars($u->getName()); } } if($tmp) { echo '
'.getMLText('mandatory_approvergroups').': '; echo implode(', ', $tmp); echo "
\n"; } } /* Check for mandatory approver groups without access */ foreach($res as $r) { if ($r['approverGroupID']) { $hasAccess = false; foreach ($docAccess["groups"] as $grp) { if ($r['approverGroupID']==$grp->getID()) $hasAccess = true; } if(!$hasAccess) { $noAccessGroup = $dms->getGroup($r['approverGroupID']); echo "
".getMLText("mandatory_approvergroup_no_access", array('group'=>htmlspecialchars($noAccessGroup->getName())))."
"; } } } ?>
contentSubHeading(getMLText("add_document_notify")); ?>
:
:

">

contentContainerEnd(); $this->contentEnd(); $this->htmlEndPage(); } /* }}} */ } ?>