* @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"); /** * Include class to preview documents */ require_once("SeedDMS/Preview.php"); /** * Class which outputs the html page for ViewDocument 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_ViewDocument extends SeedDMS_Bootstrap_Style { protected function getAccessModeText($defMode) { /* {{{ */ switch($defMode) { case M_NONE: return getMLText("access_mode_none"); break; case M_READ: return getMLText("access_mode_read"); break; case M_READWRITE: return getMLText("access_mode_readwrite"); break; case M_ALL: return getMLText("access_mode_all"); break; } } /* }}} */ protected function printAccessList($obj) { /* {{{ */ $accessList = $obj->getAccessList(); if (count($accessList["users"]) == 0 && count($accessList["groups"]) == 0) return; $content = ''; for ($i = 0; $i < count($accessList["groups"]); $i++) { $group = $accessList["groups"][$i]->getGroup(); $accesstext = $this->getAccessModeText($accessList["groups"][$i]->getMode()); $content .= $accesstext.": ".htmlspecialchars($group->getName()); if ($i+1 < count($accessList["groups"]) || count($accessList["users"]) > 0) $content .= "
"; } for ($i = 0; $i < count($accessList["users"]); $i++) { $user = $accessList["users"][$i]->getUser(); $accesstext = $this->getAccessModeText($accessList["users"][$i]->getMode()); $content .= $accesstext.": ".htmlspecialchars($user->getFullName()); if ($i+1 < count($accessList["users"])) $content .= "
"; } if(count($accessList["groups"]) + count($accessList["users"]) > 3) { $this->printPopupBox(getMLText('list_access_rights'), $content); } else { echo $content; } } /* }}} */ protected function printVersionAttributes($folder, $version) { /* {{{ */ $attributes = $version->getAttributes(); if($attributes) { foreach($attributes as $attribute) { $arr = $this->callHook('showDocumentContentAttribute', $version, $attribute); if(is_array($arr)) { print "
  • ".$arr[0].": ".$arr[1]."
  • \n"; } else { $attrdef = $attribute->getAttributeDefinition(); print "
  • ".htmlspecialchars($attrdef->getName()).": "; $this->printAttributeValue($attribute); echo "
  • \n"; } } } } /* }}} */ function documentListItem() { /* {{{ */ $dms = $this->params['dms']; $user = $this->params['user']; $previewwidth = $this->params['previewWidthList']; $cachedir = $this->params['cachedir']; $document = $this->params['document']; if($document) { if ($document->getAccessMode($user) >= M_READ) { $previewer = new SeedDMS_Preview_Previewer($cachedir, $previewwidth); $txt = $this->callHook('documentListItem', $document, $previewer, false, 'viewitem'); if(is_string($txt)) $content = $txt; else $content = $this->documentListRow($document, $previewer, true); echo $content; } } } /* }}} */ function timelinedata() { /* {{{ */ $dms = $this->params['dms']; $user = $this->params['user']; $document = $this->params['document']; $jsondata = array(); if($user->isAdmin()) { $data = $document->getTimeline(); foreach($data as $i=>$item) { switch($item['type']) { case 'add_version': $msg = getMLText('timeline_'.$item['type'], array('document'=>htmlspecialchars($item['document']->getName()), 'version'=> $item['version'])); break; case 'add_file': $msg = getMLText('timeline_'.$item['type'], array('document'=>htmlspecialchars($item['document']->getName()))); break; case 'status_change': $msg = getMLText('timeline_'.$item['type'], array('document'=>htmlspecialchars($item['document']->getName()), 'version'=> $item['version'], 'status'=> getOverallStatusText($item['status']))); break; case 'scheduled_revision': $msg = getMLText('timeline_'.$item['type'], array('document'=>htmlspecialchars($item['document']->getName()), 'version'=> $item['version'])); break; default: $msg = '???'; } $data[$i]['msg'] = $msg; } foreach($data as $item) { if($item['type'] == 'status_change') $classname = $item['type']."_".$item['status']; else $classname = $item['type']; $d = makeTsFromLongDate($item['date']); $jsondata[] = array('start'=>date('c', $d)/*$item['date']*/, 'content'=>$item['msg'], 'className'=>$classname); } } header('Content-Type: application/json'); echo json_encode($jsondata); } /* }}} */ function js() { /* {{{ */ $dms = $this->params['dms']; $user = $this->params['user']; $document = $this->params['document']; header('Content-Type: application/javascript'); parent::jsTranslations(array('cancel', 'splash_move_document', 'confirm_move_document', 'move_document', 'confirm_transfer_link_document', 'transfer_content', 'link_document', 'splash_move_folder', 'confirm_move_folder', 'move_folder')); if($user->isAdmin()) { $latestContent = $this->callHook('documentLatestContent', $document); if($latestContent === null) $latestContent = $document->getLatestContent(); $this->printTimelineJs('out.ViewDocument.php?action=timelinedata&documentid='.$latestContent->getDocument()->getID(), 300, '', date('Y-m-d')); } // $this->printDocumentChooserJs("form1"); $this->printDeleteDocumentButtonJs(); /* Add js for catching click on document in one page mode */ $this->printClickDocumentJs(); } /* }}} */ function documentInfos() { /* {{{ */ $dms = $this->params['dms']; $user = $this->params['user']; $document = $this->params['document']; $checkoutdir = $this->params['checkOutDir']; $txt = $this->callHook('documentInfos', $document); if(is_string($txt)) echo $txt; else { $this->contentHeading(getMLText("document_infos")); $txt = $this->callHook('checkOutInfo', $document); if(is_string($txt)) { echo $txt; } elseif($infos = $document->getCheckOutInfo()) { $session = $this->params['session']; if($session->getSu()) { $origuser = $dms->getUser($session->getUser()); $checkoutpath = sprintf($checkoutdir, preg_replace('/[^A-Za-z0-9_-]/', '', $origuser->getLogin())); } else { $origuser = $user; $checkoutpath = sprintf($checkoutdir, preg_replace('/[^A-Za-z0-9_-]/', '', $user->getLogin())); } foreach($infos as $info) { echo "
    "; echo "".getMLText('copied_to_checkout_as', array('date'=>$info['date'], 'filename'=>substr($info['filename'], strlen($checkoutpath)+1))).""; echo "
    "; } } $this->contentContainerStart(); $txt = $this->callHook('preDocumentInfos', $document); if(is_string($txt)) echo $txt; ?> isAdmin()) { echo ""; echo "\n"; echo "\n"; echo ""; } ?> getComment()) { ?> isAdmin() || $document->getAccessMode($user) > M_READ) { echo ""; echo ""; echo ""; echo ""; if($document->inheritsAccess()) { echo ""; echo "\n"; echo ""; } else { echo ""; echo ""; echo ""; echo ""; } } ?> expires()) { ?> getKeywords()) { $arr = $this->callHook('showDocumentKeywords', $document); if(is_array($arr)) { echo ""; echo ""; echo ""; echo ""; } elseif(is_string($arr)) { echo $arr; } else { ?> getCategories()) { $arr = $this->callHook('showDocumentCategories', $document); if(is_array($arr)) { echo ""; echo ""; echo ""; echo ""; } elseif(is_string($arr)) { echo $arr; } else { ?> getAttributes(); if($attributes) { foreach($attributes as $attribute) { $arr = $this->callHook('showDocumentAttribute', $document, $attribute); if(is_array($arr)) { echo ""; echo ""; echo ""; echo ""; } elseif(is_string($arr)) { echo $arr; } else { $attrdef = $attribute->getAttributeDefinition(); ?> callHook('additionalDocumentInfos', $document); if(is_array($arrarr)) { foreach($arrarr as $arr) { echo ""; echo ""; echo ""; echo ""; } } elseif(is_string($arrarr)) { echo $arrarr; } ?>
    ".getMLText("id").":".htmlspecialchars($document->getID())."
    : printInlineEdit(htmlspecialchars($document->getName()), $document);?>
    : getOwner(); print "getEmail())."\">".htmlspecialchars($owner->getFullName()).""; ?>
    : getComment());?>
    ".getMLText('default_access').":".$this->getAccessModeText($document->getDefaultAccess())."
    ".getMLText("access_mode").":"; echo getMLText("inherited")."
    "; $this->printAccessList($document); echo "
    ".getMLText('access_mode').":"; $this->printAccessList($document); echo "
    : getUsedDiskSpace());?>
    : getDate()); ?>
    : getExpires()); ?>
    ".$arr[0].":".$arr[1]."
    : getKeywords());?>
    ".$arr[0].":".$arr[1]."
    : getName()); echo implode(', ', $ct); ?>
    ".$arr[0].":".$arr[1]."
    getName()); ?>: getAttributeValue($attribute); ?>
    ".$arr[0].":".$arr[1]."
    callHook('postDocumentInfos', $document); if(is_string($txt)) echo $txt; $this->contentContainerEnd(); } } /* }}} */ function preview() { /* {{{ */ $dms = $this->params['dms']; $document = $this->params['document']; $timeout = $this->params['timeout']; $xsendfile = $this->params['xsendfile']; $showfullpreview = $this->params['showFullPreview']; $converttopdf = $this->params['convertToPdf']; $pdfconverters = $this->params['pdfConverters']; $cachedir = $this->params['cachedir']; if(!$showfullpreview) return; $accessobject = $this->params['accessobject']; if($accessobject->check_controller_access('ViewOnline', array('action'=>'version'))) { $latestContent = $this->callHook('documentLatestContent', $document); if($latestContent === null) $latestContent = $document->getLatestContent(); $txt = $this->callHook('preDocumentPreview', $latestContent); if(is_string($txt)) echo $txt; $txt = $this->callHook('documentPreview', $latestContent); if(is_string($txt)) echo $txt; else { switch($latestContent->getMimeType()) { case 'audio/mpeg': case 'audio/mp3': case 'audio/ogg': case 'audio/wav': $this->contentHeading(getMLText("preview")); ?> contentHeading(getMLText("preview")); ?> contentHeading(getMLText("preview")); ?> contentHeading(getMLText("preview")); ?> callHook('additionalDocumentPreview', $latestContent); if(is_string($txt)) echo $txt; break; } } $txt = $this->callHook('postDocumentPreview', $latestContent); if(is_string($txt)) echo $txt; if($converttopdf) { $pdfpreviewer = new SeedDMS_Preview_PdfPreviewer($cachedir, $timeout, $xsendfile); $pdfpreviewer->setConverters($pdfconverters); if($pdfpreviewer->hasConverter($latestContent->getMimeType())) { $this->contentHeading(getMLText("preview_pdf")); ?> callHook('preViewDocument'); $dms = $this->params['dms']; $user = $this->params['user']; $folder = $this->params['folder']; $document = $this->params['document']; $accessobject = $this->params['accessobject']; $viewonlinefiletypes = $this->params['viewonlinefiletypes']; $enableownerrevapp = $this->params['enableownerrevapp']; $enableownerreceipt = $this->params['enableownerreceipt']; $enablereceiptworkflow = $this->params['enablereceiptworkflow']; $enablereceiptreject = $this->params['enablereceiptreject']; $enablerevisionworkflow = $this->params['enablerevisionworkflow']; $workflowmode = $this->params['workflowmode']; $cachedir = $this->params['cachedir']; $previewwidthlist = $this->params['previewWidthList']; $previewwidthdetail = $this->params['previewWidthDetail']; $previewconverters = $this->params['previewConverters']; $pdfconverters = $this->params['pdfConverters']; $documentid = $document->getId(); $currenttab = $this->params['currenttab']; $timeout = $this->params['timeout']; $xsendfile = $this->params['xsendfile']; $versions = $this->callHook('documentVersions', $document); if($versions === null) $versions = $document->getContent(); $this->htmlAddHeader(''."\n", 'js'); $this->htmlAddHeader(''."\n", 'css'); $this->htmlAddHeader(''."\n", 'js'); $this->htmlAddHeader(''."\n", 'js'); $this->htmlStartPage(getMLText("document_title", array("documentname" => htmlspecialchars($document->getName())))); $this->globalNavigation($folder); $this->contentStart(); $this->pageNavigation($this->getFolderPathHTML($folder, true, $document), "view_document", $document); echo $this->callHook('preContent'); if ($document->isLocked()) { $lockingUser = $document->getLockingUser(); $txt = $this->callHook('documentIsLocked', $document, $lockingUser); if(is_string($txt)) echo $txt; else { ?>
    $lockingUser->getEmail(), "username" => htmlspecialchars($lockingUser->getFullName())));?>
    callHook('documentLatestContent', $document); if($latestContent === null) $latestContent = $document->getLatestContent(); $files = $document->getDocumentFiles($latestContent->getVersion()); $files = SeedDMS_Core_DMS::filterDocumentFiles($user, $files); /* Retrieve linked documents */ $links = $document->getDocumentLinks(); $links = SeedDMS_Core_DMS::filterDocumentLinks($user, $links, 'target'); /* Retrieve reverse linked documents */ $reverselinks = $document->getReverseDocumentLinks(); $reverselinks = SeedDMS_Core_DMS::filterDocumentLinks($user, $reverselinks, 'source'); $needwkflaction = false; if($workflowmode == 'traditional' || $workflowmode == 'traditional_only_approval') { } elseif($workflowmode == 'advanced') { $workflow = $latestContent->getWorkflow(); if($workflow) { $workflowstate = $latestContent->getWorkflowState(); $transitions = $workflow->getNextTransitions($workflowstate); $needwkflaction = $latestContent->needsWorkflowAction($user); } } if($needwkflaction) { $this->infoMsg(getMLText('needs_workflow_action')); } $status = $latestContent->getStatus(); $reviewStatus = $latestContent->getReviewStatus(); $approvalStatus = $latestContent->getApprovalStatus(); $receiptStatus = $latestContent->getReceiptStatus(); $revisionStatus = $latestContent->getRevisionStatus(); $this->rowStart(); $this->columnStart(4); $txt = $this->callHook('startLeftColumn', $document); if(is_string($txt)) echo $txt; $this->documentInfos(); if($accessobject->check_controller_access('ViewOnline', array('action'=>'run'))) { $this->preview(); } $this->columnEnd(); $this->columnStart(8); $txt = $this->callHook('startRightColumn', $document); if(is_string($txt)) echo $txt; ?>
    contentContainerStart(); print getMLText('document_content_missing'); $this->contentContainerEnd(); $this->contentEnd(); $this->htmlEndPage(); exit; } $checksum = SeedDMS_Core_File::checksum($dms->contentDir.$latestContent->getPath()); if($checksum != $latestContent->getChecksum()) { $this->errorMsg(getMLText('wrong_checksum')); } $txt = $this->callHook('preLatestVersionTab', $latestContent); if(is_string($txt)) echo $txt; // verify if file exists $file_exists=file_exists($dms->contentDir . $latestContent->getPath()); $this->contentContainerStart(); print ""; print "\n\n"; print "\n"; // print "\n"; // print "\n"; print "\n"; print "\n"; print "\n"; print "\n"; print "\n"; print "\n"; print ""; print ""; print "\n
    ".htmlspecialchars($latestContent->getOriginalFileName())."".getMLText("file")."".getMLText("comment")."".getMLText("status")."
    "; $previewer = new SeedDMS_Preview_Previewer($cachedir, $previewwidthdetail, $timeout, $xsendfile); $previewer->setConverters($previewconverters); $previewer->createPreview($latestContent); if ($file_exists) { if ($viewonlinefiletypes && (in_array(strtolower($latestContent->getFileType()), $viewonlinefiletypes) || in_array(strtolower($latestContent->getMimeType()), $viewonlinefiletypes))) { if($accessobject->check_controller_access('ViewOnline', array('action'=>'run'))) { print "getDocument()->getId()."&version=". $latestContent->getVersion()."\">"; } } else { if($accessobject->check_controller_access('Download', array('action'=>'version'))) { print "getDocument()->getId()."&version=".$latestContent->getVersion()."\">"; } } } if($previewer->hasPreview($latestContent)) { print("getDocument()->getID()."&version=".$latestContent->getVersion()."&width=".$previewwidthdetail."\" title=\"".htmlspecialchars($latestContent->getMimeType())."\">"); } else { print "getMimeIcon($latestContent->getFileType())."\" title=\"".htmlspecialchars($latestContent->getMimeType())."\">"; } if ($file_exists) { if($accessobject->check_controller_access('Download', array('action'=>'run')) || $accessobject->check_controller_access('ViewOnline', array('action'=>'run'))) print ""; } print "
      \n"; // print "
    • ".$latestContent->getOriginalFileName() ."
    • \n"; print "
    • ".getMLText('version').": ".$latestContent->getVersion()."
    • \n"; if ($file_exists) print "
    • ". SeedDMS_Core_File::format_filesize($latestContent->getFileSize()) .", ".htmlspecialchars($latestContent->getMimeType())."
    • "; else print "
    • ".getMLText("document_deleted")."
    • "; $updatingUser = $latestContent->getUser(); print "
    • ".getMLText("uploaded_by")." getEmail())."\">".htmlspecialchars($updatingUser->getFullName())."
    • "; print "
    • ".getLongReadableDate($latestContent->getDate())."
    • "; print "
    \n"; $txt = $this->callHook('showVersionComment', $latestContent); if($txt) { echo $txt; } else { if($latestContent->getComment()) print "

    ".htmlspecialchars($latestContent->getComment())."

    "; } print "
      \n"; $this->printVersionAttributes($folder, $latestContent); print "
    "; print getOverallStatusText($status["status"]); if ( $status["status"]==S_DRAFT_REV || $status["status"]==S_DRAFT_APP || $status["status"]==S_IN_WORKFLOW || $status["status"]==S_EXPIRED ){ print "
    hasExpired()?" class=\"warning\" ":"").">".(!$document->getExpires() ? getMLText("does_not_expire") : getMLText("expires").": ".getReadableDate($document->getExpires())).""; } print "
    "; if ($file_exists){ print ""; } print "
      "; if($accessobject->check_view_access('EditOnline')) if($accessobject->mayEditVersion($latestContent->getDocument())) { print "
    • ".$this->html_link('EditOnline', array('documentid'=>$latestContent->getDocument()->getId(), 'version'=>$latestContent->getVersion()), array(), "".getMLText("edit_version"), false, true)."
    • "; } /* Only admin has the right to remove version in any case or a regular * user if enableVersionDeletion is on */ if($accessobject->check_controller_access('RemoveVersion')) if($accessobject->mayRemoveVersion($latestContent->getDocument())) { print "
    • ".$this->html_link('RemoveVersion', array('documentid'=>$latestContent->getDocument()->getId(), 'version'=>$latestContent->getVersion()), array(), "".getMLText("rm_version"), false, true)."
    • "; } if($accessobject->check_controller_access('OverrideContentStatus')) if($accessobject->mayOverrideStatus($latestContent->getDocument())) { print "
    • ".$this->html_link('OverrideContentStatus', array('documentid'=>$latestContent->getDocument()->getId(), 'version'=>$latestContent->getVersion()), array(), "".getMLText("change_status"), false, true)."
    • "; } if($enablereceiptworkflow && $accessobject->check_controller_access('SetRecipients')) if($accessobject->maySetRecipients($latestContent->getDocument())) { print "
    • ".$this->html_link('SetRecipients', array('documentid'=>$latestContent->getDocument()->getId(), 'version'=>$latestContent->getVersion()), array(), "".getMLText("change_recipients"), false, true)."
    • "; } if($enablerevisionworkflow && $accessobject->check_controller_access('SetRevisors')) if($accessobject->maySetRevisors($latestContent->getDocument())) { print "
    • ".$this->html_link('SetRevisors', array('documentid'=>$latestContent->getDocument()->getId(), 'version'=>$latestContent->getVersion()), array(), "".getMLText("change_revisors"), false, true)."
    • "; } if($workflowmode == 'traditional' || $workflowmode == 'traditional_only_approval') { // Allow changing reviewers/approvals only if not reviewed if($accessobject->check_controller_access('SetReviewersApprovers')) if($accessobject->maySetReviewersApprovers($latestContent->getDocument())) { print "
    • ".$this->html_link('SetReviewersApprovers', array('documentid'=>$latestContent->getDocument()->getId(), 'version'=>$latestContent->getVersion()), array(), "".getMLText("change_assignments"), false, true)."
    • "; } } elseif($workflowmode == 'advanced') { if($accessobject->check_controller_access('SetWorkflow')) if($accessobject->maySetWorkflow($latestContent->getDocument())) { if(!$workflow) { print "
    • ".$this->html_link('SetWorkflow', array('documentid'=>$latestContent->getDocument()->getId(), 'version'=>$latestContent->getVersion()), array(), "".getMLText("set_workflow"), false, true)."
    • "; } } } /* if($accessobject->maySetExpires($latestContent->getDocument())) { print "
    • ".$this->html_link('SetExpires', array('documentid'=>$latestContent->getDocument()->getId()), array(), "".getMLText("set_expiry"), false, true)."
    • "; } */ if($accessobject->check_controller_access('AddToTransmittal')) if($dms->getAllTransmittals($user)) { if($accessobject->check_view_access('AddToTransmittal')) print "
    • ".$this->html_link('AddToTransmittal', array('documentid'=>$latestContent->getDocument()->getId(), 'version'=>$latestContent->getVersion()), array(), "".getMLText("add_to_transmittal"), false, true)."
    • "; } if($accessobject->check_controller_access('EditComment')) if($accessobject->mayEditComment($latestContent->getDocument())) { print "
    • ".$this->html_link('EditComment', array('documentid'=>$latestContent->getDocument()->getId(), 'version'=>$latestContent->getVersion()), array(), "".getMLText("edit_comment"), false, true)."
    • "; } if($accessobject->check_controller_access('EditAttributes')) if($accessobject->mayEditAttributes($latestContent->getDocument())) { print "
    • ".$this->html_link('EditAttributes', array('documentid'=>$latestContent->getDocument()->getId(), 'version'=>$latestContent->getVersion()), array(), "".getMLText("edit_attributes"), false, true)."
    • "; } $items = $this->callHook('extraVersionActions', $latestContent); if($items) { foreach($items as $item) { if(is_string($item)) echo "
    • ".$item."
    • "; elseif(is_array($item)) echo "
    • ".(!empty($item['icon']) ? "" : "").getMLText($item['label'])."
    • "; } } print "
    "; echo "
    \n"; $this->contentContainerEnd(); if($user->isAdmin()) { $this->contentHeading(getMLText("status")); $this->contentContainerStart(); $statuslog = $latestContent->getStatusLog(); echo ""; echo "\n"; echo ""; foreach($statuslog as $entry) { if($suser = $dms->getUser($entry['userID'])) $fullname = htmlspecialchars($suser->getFullName()); else $fullname = "--"; echo "\n"; } print "\n
    ".getMLText('date')."".getMLText('status')."".getMLText('user')."".getMLText('comment')."
    ".getLongReadableDate($entry['date'])."".getOverallStatusText($entry['status'])."".$fullname."".htmlspecialchars($entry['comment'])."
    \n"; $this->contentContainerEnd(); $wkflogs = $latestContent->getWorkflowLog(); if($wkflogs) { $this->contentHeading(getMLText("workflow_summary")); $this->contentContainerStart(); foreach($wkflogs as $wkflogt) { echo ""; echo "\n"; echo ""; foreach($wkflogt as $wkflog) { echo ""; echo ""; echo ""; echo ""; $loguser = $wkflog->getUser(); echo ""; echo ""; echo ""; } print "\n
    ".getMLText('workflow')."".getMLText('date')."".getMLText('action')."".getMLText('user')."".getMLText('comment')."
    ".$wkflog->getWorkflow()->getName()."".$wkflog->getDate()."".htmlspecialchars($wkflog->getTransition()->getAction()->getName())."".htmlspecialchars($loguser->getFullName())."".htmlspecialchars($wkflog->getComment())."
    \n"; } $this->contentContainerEnd(); } } ?>
    0) || (is_array($approvalStatus) && count($approvalStatus)>0)) { ?>
    rowStart(); /* Just check fo an exting reviewStatus, even workflow mode is set * to traditional_only_approval. There may be old documents which * are still in S_DRAFT_REV. */ if (/*$workflowmode != 'traditional_only_approval' &&*/ is_array($reviewStatus) && count($reviewStatus)>0) { $this->columnStart(6); // $this->contentContainerStart(); print "".getMLText('reviewers').""; print "\n"; print "\n"; print "\n"; print "\n"; // print ""; print "\n"; print "\n"; print "\n"; foreach ($reviewStatus as $r) { $class = ''; switch($r['status']) { case '-1': $class = 'error'; break; case '1': $class = 'success'; break; } $required = null; $is_reviewer = false; $accesserr = ''; switch ($r["type"]) { case 0: // Reviewer is an individual. $required = $dms->getUser($r["required"]); if (!is_object($required)) { $reqName = getMLText("unknown_user")." '".$r["required"]."'"; } else { $reqName = " ".htmlspecialchars($required->getFullName()." (".$required->getLogin().")"); if($user->isAdmin()) { if($document->getAccessMode($required) < M_READ || $latestContent->getAccessMode($required) < M_READ) $accesserr = getMLText("access_denied"); elseif(is_object($required) && $required->isDisabled()) $accesserr = getMLText("login_disabled_title"); } if($required->getId() == $user->getId()/* && ($user->getId() != $owner->getId() || $enableownerrevapp == 1)*/) $is_reviewer = true; } break; case 1: // Reviewer is a group. $required = $dms->getGroup($r["required"]); if (!is_object($required)) { $reqName = getMLText("unknown_group")." '".$r["required"]."'"; } else { $reqName = " ".htmlspecialchars($required->getName()); if($user->isAdmin()) { $grpusers = $required->getUsers(); if(!$grpusers) $accesserr = getMLText("no_group_members"); } if($required->isMember($user)/* && ($user->getId() != $owner->getId() || $enableownerrevapp == 1)*/) $is_reviewer = true; } break; } if($user->isAdmin() || $r["status"] > -2) { print "\n"; print "\n"; print "\n"; print "\n"; print "\n"; print "\n"; } } print "
    ".getMLText("name")."".getMLText("last_update").", ".getMLText("comment")."".getMLText("comment")."".getMLText("status")."
    ".$reqName."".getLongReadableDate($r["date"])." - "; /* $updateUser is the user who has done the review */ $updateUser = $dms->getUser($r["userID"]); print (is_object($updateUser) ? htmlspecialchars($updateUser->getFullName()." (".$updateUser->getLogin().")") : "unknown user id '".$r["userID"]."'")."
    "; print htmlspecialchars($r["comment"]); if($r['file']) { echo "
    "; if($accessobject->check_controller_access('Download', array('action'=>'run'))) { echo "getDocument()->getId()."&reviewlogid=".$r['reviewLogID']."\" class=\"btn btn-secondary btn-mini\"> ".getMLText('download').""; } } print "
    "; if($class) echo " "; print getReviewStatusText($r["status"])."
      "; if($accesserr) echo "
    • ".$accesserr."
    • "; if($accessobject->mayReview($latestContent->getDocument())) { if ($is_reviewer) { if ($r["status"]==0) { print "
    • ".$this->html_link('ReviewDocument', array('documentid'=>$latestContent->getDocument()->getId(), 'version'=>$latestContent->getVersion(), 'reviewid'=>$r['reviewID']), array('class'=>'btn btn-mini btn-primary'), getMLText("add_review"), false, true)."
    • "; } elseif ($accessobject->mayUpdateReview($latestContent->getDocument(), $updateUser) && (($r["status"]==1)||($r["status"]==-1))){ print "
    • ".$this->html_link('ReviewDocument', array('documentid'=>$latestContent->getDocument()->getId(), 'version'=>$latestContent->getVersion(), 'reviewid'=>$r['reviewID']), array('class'=>'btn btn-mini btn-primary'), getMLText("edit"), false, true)."
    • "; } } } print "
    "; // $this->contentContainerEnd(); $this->columnEnd(); } $this->columnStart(6); // $this->contentContainerStart(); print "".getMLText('approvers').""; print "\n"; if (is_array($approvalStatus) && count($approvalStatus)>0) { print "\n"; print "\n"; print "\n"; // print ""; print "\n"; print "\n"; print "\n"; foreach ($approvalStatus as $a) { $class = ''; switch($a['status']) { case '-1': $class = 'error'; break; case '1': $class = 'success'; break; } $required = null; $is_approver = false; $accesserr = ''; switch ($a["type"]) { case 0: // Approver is an individual. $required = $dms->getUser($a["required"]); if (!is_object($required)) { $reqName = getMLText("unknown_user")." '".$a["required"]."'"; } else { $reqName = " ".htmlspecialchars($required->getFullName()." (".$required->getLogin().")"); if($user->isAdmin()) { if($document->getAccessMode($required) < M_READ || $latestContent->getAccessMode($required) < M_READ) $accesserr = getMLText("access_denied"); elseif(is_object($required) && $required->isDisabled()) $accesserr = getMLText("login_disabled_title"); } if($required->getId() == $user->getId()) $is_approver = true; } break; case 1: // Approver is a group. $required = $dms->getGroup($a["required"]); if (!is_object($required)) { $reqName = getMLText("unknown_group")." '".$a["required"]."'"; } else { $reqName = " ".htmlspecialchars($required->getName()); if($user->isAdmin()) { $grpusers = $required->getUsers(); if(!$grpusers) $accesserr = getMLText("no_group_members"); } if($required->isMember($user)/* && ($user->getId() != $owner->getId() || $enableownerrevapp == 1)*/) $is_approver = true; } break; } if($user->isAdmin() || $a["status"] > -2) { print "\n"; print "\n"; print "\n"; print "\n"; print "\n"; print "\n"; } } } print "
    ".getMLText("name")."".getMLText("last_update").", ".getMLText("comment")."".getMLText("comment")."".getMLText("status")."
    ".$reqName."".getLongReadableDate($a["date"])." - "; /* $updateUser is the user who has done the approval */ $updateUser = $dms->getUser($a["userID"]); print (is_object($updateUser) ? htmlspecialchars($updateUser->getFullName()." (".$updateUser->getLogin().")") : "unknown user id '".$a["userID"]."'")."
    "; print htmlspecialchars($a["comment"]); if($a['file']) { echo "
    "; if($accessobject->check_controller_access('Download', array('action'=>'run'))) { echo "getDocument()->getId()."&approvelogid=".$a['approveLogID']."\" class=\"btn btn-secondary btn-mini\"> ".getMLText('download').""; } } echo "
    "; if($class) echo " "; print getApprovalStatusText($a["status"])."
      "; if($accesserr) echo "
    • ".$accesserr."
    • "; if($accessobject->mayApprove($latestContent->getDocument())) { if ($is_approver) { if ($a['status'] == 0) { print "
    • ".$this->html_link('ApproveDocument', array('documentid'=>$latestContent->getDocument()->getId(), 'version'=>$latestContent->getVersion(), 'approveid'=>$a['approveID']), array('class'=>'btn btn-mini btn-primary'), getMLText("add_approval"), false, true)."
    • "; } elseif ($accessobject->mayUpdateApproval($latestContent->getDocument(), $updateUser) && (($a["status"]==1)||($a["status"]==-1))){ print "
    • ".$this->html_link('ApproveDocument', array('documentid'=>$latestContent->getDocument()->getId(), 'version'=>$latestContent->getVersion(), 'approveid'=>$a['approveID']), array('class'=>'btn btn-mini btn-primary'), getMLText("edit"), false, true)."
    • "; } } } print "
    "; print "
    \n"; // $this->contentContainerEnd(); $this->columnEnd(); $this->rowEnd(); if($user->isAdmin() || $user->getId() == $document->getOwner()->getId()) { $this->rowStart(); /* Check for an existing review log, even if the workflowmode * is set to traditional_only_approval. There may be old documents * that still have a review log if the workflow mode has been * changed afterwards. */ if($latestContent->getReviewStatus(10) /*$workflowmode != 'traditional_only_approval'*/) { $this->columnStart(6); $this->printProtocol($latestContent, 'review'); $this->columnEnd(); } $this->columnStart(6); $this->printProtocol($latestContent, 'approval'); $this->columnEnd(); $this->rowEnd(); } ?>
    triggerWorkflowTransitionIsAllowed($user, $transition)) { $user_is_involved = true; } } ?>
    rowStart(); if ($user_is_involved && $accessobject->check_view_access('WorkflowGraph')) $this->columnStart(6); else $this->columnStart(12); $this->contentContainerStart(); if($user->isAdmin()) { if(SeedDMS_Core_DMS::checkIfEqual($workflow->getInitState(), $latestContent->getWorkflowState())) { print "
    getDocument()->getId()."\" />getVersion()."\" />
    "; } else { print "
    getDocument()->getId()."\" />getVersion()."\" />
    "; } } echo "

    ".htmlspecialchars($workflow->getName())."

    "; if($parentworkflow = $latestContent->getParentWorkflow()) { echo "

    Sub workflow of '".htmlspecialchars($parentworkflow->getName())."'

    "; } echo "
    ".getMLText('current_state').": ".htmlspecialchars($workflowstate->getName())."
    "; echo "\n"; echo ""; echo ""; foreach($transitions as $transition) { $nextstate = $transition->getNextState(); $docstatus = $nextstate->getDocumentStatus(); echo ""; } echo ""; echo ""; echo ""; foreach($transitions as $transition) { $action = $transition->getAction(); echo ""; } echo ""; echo ""; echo ""; foreach($transitions as $transition) { $transusers = $transition->getUsers(); echo ""; } echo ""; echo ""; echo ""; foreach($transitions as $transition) { $transgroups = $transition->getGroups(); echo ""; } echo ""; echo ""; echo ""; foreach($transitions as $transition) { echo ""; } echo ""; echo ""; echo ""; $allowedtransitions = array(); foreach($transitions as $transition) { echo ""; } echo ""; echo "
    ".getMLText('next_state').": ".htmlspecialchars($nextstate->getName())."
    ".getMLText('action').":".getMLText('action_'.strtolower($action->getName()), array(), htmlspecialchars($action->getName()))."
    ".getMLText('users').":"; foreach($transusers as $transuser) { $u = $transuser->getUser(); echo htmlspecialchars($u->getFullName()); if($document->getAccessMode($u) < M_READ) { echo " (no access)"; } echo "
    "; } echo "
    ".getMLText('groups').":"; foreach($transgroups as $transgroup) { $g = $transgroup->getGroup(); echo getMLText('at_least_n_users_of_group', array("number_of_users" => $transgroup->getNumOfUsers(), "group" => htmlspecialchars($g->getName()))); if ($document->getGroupAccessMode($g) < M_READ) { echo " (no access)"; } echo "
    "; } echo "
    ".getMLText('users_done_work').":"; if($latestContent->executeWorkflowTransitionIsAllowed($transition)) { /* If this is reached, then the transition should have been executed * but for some reason the next state hasn't been reached. This can * be causes, if a transition which was previously already executed * is about to be executed again. E.g. there was already a transition * T1 from state S1 to S2 triggered by user U1. * Then there was a second transition T2 from * S2 back to S1. If the state S1 has been reached again, then * executeWorkflowTransitionIsAllowed() will think that T1 could be * executed because there is already a log entry saying, that U1 * has triggered the workflow. */ echo "Done "; } $wkflogs = $latestContent->getWorkflowLog($transition); foreach($wkflogs as $wkflog) { $loguser = $wkflog->getUser(); echo htmlspecialchars($loguser->getFullName())." ("; $names = array(); foreach($loguser->getGroups() as $loggroup) { $names[] = htmlspecialchars($loggroup->getName()); } echo implode(", ", $names); echo ") - "; echo $wkflog->getDate(); echo "
    "; } echo "
    "; if($latestContent->triggerWorkflowTransitionIsAllowed($user, $transition)) { $action = $transition->getAction(); print "
    getDocument()->getId()."\" />getVersion()."\" />getID()."\" />getName()), array(), htmlspecialchars($action->getName()))."\" />
    "; $allowedtransitions[] = $transition; } echo "
    "; $workflows = $dms->getAllWorkflows(); if($workflows) { $subworkflows = array(); foreach($workflows as $wkf) { if($wkf->getInitState()->getID() == $workflowstate->getID()) { if($workflow->getID() != $wkf->getID()) { $subworkflows[] = $wkf; } } } if($subworkflows) { echo "
    getDocument()->getId()."\" />getVersion()."\" />"; echo ""; echo "
    0) { ?>
    ".getMLText('info_recipients_tab_not_released')."
    "; $txt = $this->callHook('preRecipientsTab', $receiptStatus); if(is_string($txt)) echo $txt; print "\n"; print "\n"; print "\n"; print "\n"; print ""; print "\n"; print "\n"; print "\n"; $stat = array('-1'=>0, '0'=>0, '1'=>0, '-2'=>0); foreach ($receiptStatus as $r) { $required = null; $is_recipient = false; $stat[''.$r['status']]++; $accesserr = ''; switch ($r["type"]) { case 0: // Recipient is an individual. $required = $dms->getUser($r["required"]); if (!is_object($required)) { $reqName = getMLText("unknown_user")." '".$r["required"]."'"; } else { $reqName = " ".htmlspecialchars($required->getFullName()." (".$required->getLogin().")"); if($user->isAdmin()) { if($document->getAccessMode($required) < M_READ || $latestContent->getAccessMode($required) < M_READ) $accesserr = getMLText("access_denied"); elseif(is_object($required) && $required->isDisabled()) $accesserr = getMLText("login_disabled_title"); } } if($r["required"] == $user->getId()/* && ($user->getId() != $owner->getId() || $enableownerreceipt == 1)*/) $is_recipient = true; break; case 1: // Recipient is a group. $required = $dms->getGroup($r["required"]); if (!is_object($required)) { $reqName = getMLText("unknown_group")." '".$r["required"]."'"; } else { $reqName = " ".htmlspecialchars($required->getName()); if($user->isAdmin()) { $grpusers = $required->getUsers(); if(!$grpusers) $accesserr = getMLText("no_group_members"); } if($required->isMember($user)/* && ($user->getId() != $owner->getId() || $enableownerreceipt == 1)*/) $is_recipient = true; } break; } /* Do not list users that has been removed from the list of recipients * unless admin is logged in. */ if($user->isAdmin() || $r["status"] > -2) { $class = ''; switch($r['status']) { case '-1': $class = 'error'; break; case '1': $class = 'success'; break; } print "\n"; print "\n"; print ""; print "\n"; print "\n"; print "\n"; print "\n"; } } ?>
    ".getMLText("name")."".getMLText("last_update")."".getMLText("comment")."".getMLText("status")."
    ".$reqName."
    • ".getLongReadableDate($r["date"])."
    • "; /* $updateUser is the user who has done the receipt */ $updateUser = $dms->getUser($r["userID"]); print "
    • ".(is_object($updateUser) ? htmlspecialchars($updateUser->getFullName()." (".$updateUser->getLogin().")") : "unknown user id '".$r["userID"]."'")."
    ".htmlspecialchars($r["comment"]).""; if($class) echo " "; print getReceiptStatusText($r["status"])."
      "; if($accesserr) echo "
    • ".$accesserr."
    • "; if($accessobject->mayReceipt($document)) { if ($is_recipient) { if($r["status"]==0) { print "
    • ".$this->html_link('ReceiptDocument', array('documentid'=>$documentid, 'version'=>$latestContent->getVersion(), 'receiptid'=>$r['receiptID']), array('class'=>'btn btn-mini btn-primary'), getMLText("add_receipt"), false, true)."
    • "; } elseif ($accessobject->mayUpdateReceipt($document, $updateUser) && (($r["status"]==1 && $enablereceiptreject)||($r["status"]==-1))) { print "
    • ".$this->html_link('ReceiptDocument', array('documentid'=>$documentid, 'version'=>$latestContent->getVersion(), 'receiptid'=>$r['receiptID']), array('class'=>'btn btn-mini btn-primary'), getMLText("edit"), false, true)."
    • "; } } } print "
    contentContainerEnd(); if($accessobject->check_view_access('ViewDocument', array('action'=>'receptionBar'))/* $user->isAdmin() || $user->getId() == $document->getOwner()->getId()*/) { /* Do not count entries '-2' as they are removed userѕ */ $totalreceipts = $stat['-1'] + $stat['0'] + $stat['1']; ?>
    printProtocol($latestContent, 'receipt'); ?>
    0) { ?>
    getRevisionDate()) { ?>
    substr($latestContent->getRevisionDate(), 0, 10))); ?>
    contentContainerStart(); print "\n"; print "\n"; print "\n"; print "\n"; print ""; print "\n"; print "\n"; print "\n"; foreach ($revisionStatus as $r) { $class = ''; switch($r['status']) { case '-1': $class = 'error'; break; case '1': $class = 'success'; break; } $required = null; $is_recipient = false; $accesserr = ''; switch ($r["type"]) { case 0: // Reviewer is an individual. $required = $dms->getUser($r["required"]); if (!is_object($required)) { $reqName = getMLText("unknown_user")." '".$r["required"]."'"; } else { $reqName = " ".htmlspecialchars($required->getFullName()." (".$required->getLogin().")"); if($user->isAdmin()) { if($document->getAccessMode($required) < M_READ || $latestContent->getAccessMode($required) < M_READ) $accesserr = getMLText("access_denied"); elseif(is_object($required) && $required->isDisabled()) $accesserr = getMLText("login_disabled_title"); } } if($r["required"] == $user->getId()/* && ($user->getId() != $owner->getId() || $enableownerrevapp == 1)*/) $is_recipient = true; break; case 1: // Reviewer is a group. $required = $dms->getGroup($r["required"]); if (!is_object($required)) { $reqName = getMLText("unknown_group")." '".$r["required"]."'"; } else { $reqName = " ".htmlspecialchars($required->getName()); if($required->isMember($user)/* && ($user->getId() != $owner->getId() || $enableownerrevapp == 1)*/) $is_recipient = true; } break; } if($user->isAdmin() || $r["status"] != -2) { print "\n"; print "\n"; print ""; print "\n"; print "\n"; print "\n"; print "\n"; } } ?>
    ".getMLText("name")."".getMLText("last_update")."".getMLText("comment")."".getMLText("status")."
    ".$reqName."
    • ".getLongReadableDate($r["date"])."
    • "; /* $updateUser is the user who has done the revision */ if($r['status'] != 0) { $updateUser = $dms->getUser($r["userID"]); print "
    • ".(is_object($updateUser) ? htmlspecialchars($updateUser->getFullName()." (".$updateUser->getLogin().")") : "unknown user id '".$r["userID"]."'")."
    • "; } print "
    ".htmlspecialchars($r["comment"]).""; if($class) echo " "; print getRevisionStatusText($r["status"])."
      "; if($accesserr) echo "
    • ".$accesserr."
    • "; if($accessobject->mayRevise($document)) { if ($is_recipient && $r["status"]==0) { print "
    • ".$this->html_link('ReviseDocument', array('documentid'=>$documentid, 'version'=>$latestContent->getVersion(), 'revisionid'=>$r['revisionID']), array('class'=>'btn btn-mini btn-primary'), getMLText("add_revision"), false, true)."
    • "; } elseif (($updateUser==$user)&&(($r["status"]==1)||($r["status"]==-1))&&(!$document->hasExpired())){ print "
    • ".$this->html_link('ReviseDocument', array('documentid'=>$documentid, 'version'=>$latestContent->getVersion(), 'revisionid'=>$r['revisionID']), array('class'=>'btn btn-mini btn-primary'), getMLText("edit"), false, true)."
    • "; } } print "
    contentContainerEnd(); if($user->isAdmin() || $user->getId() == $document->getOwner()->getId()) { ?>
    printProtocol($latestContent, 'revision'); ?>
    1) { ?>
    0) { print ""; print "\n\n"; print "\n"; print "\n"; print "\n"; print "\n"; print "\n\n\n"; foreach($files as $file) { $file_exists=file_exists($dms->contentDir . $file->getPath()); $responsibleUser = $file->getUser(); print ""; print ""; print ""; print ""; print ""; print ""; } print "\n
    ".getMLText("file")."".getMLText("comment")."
    "; $previewer->createPreview($file, $previewwidthdetail); if($file_exists) { if ($viewonlinefiletypes && (in_array(strtolower($file->getFileType()), $viewonlinefiletypes) || in_array(strtolower($file->getMimeType()), $viewonlinefiletypes))) { if($accessobject->check_controller_access('ViewOnline', array('action'=>'run'))) { print "getID()."\">"; } } else { if($accessobject->check_controller_access('Download', array('action'=>'file'))) { print "getID()."\">"; } } } if($previewer->hasPreview($file)) { print("getID()."&file=".$file->getID()."&width=".$previewwidthdetail."\" title=\"".htmlspecialchars($file->getMimeType())."\">"); } else { print "getMimeIcon($file->getFileType())."\" title=\"".htmlspecialchars($file->getMimeType())."\">"; } if($file_exists) { if($accessobject->check_controller_access('Download', array('action'=>'run')) || $accessobject->check_controller_access('ViewOnline', array('action'=>'run'))) print ""; } print "
      \n"; print "
    • ".htmlspecialchars($file->getName())."
    • \n"; if($file->getName() != $file->getOriginalFileName()) print "
    • ".htmlspecialchars($file->getOriginalFileName())."
    • \n"; if ($file_exists) print "
    • ".SeedDMS_Core_File::format_filesize(filesize($dms->contentDir . $file->getPath())) ." bytes, ".htmlspecialchars($file->getMimeType())."
    • "; else print "
    • ".htmlspecialchars($file->getMimeType())." - ".getMLText("document_deleted")."
    • "; print "
    • ".getMLText("uploaded_by")." getEmail())."\">".htmlspecialchars($responsibleUser->getFullName())."
    • "; print "
    • ".getLongReadableDate($file->getDate())."
    • "; if($file->getVersion()) print "
    • ".getMLText('linked_to_current_version')."
    • "; else print "
    • ".getMLText('linked_to_document')."
    • "; print "
    ".htmlspecialchars($file->getComment())."
      "; if ($file_exists) { if($accessobject->check_controller_access('Download', array('action'=>'file'))) { print "
    • getID()."\">".getMLText('download')."
    • "; } if ($viewonlinefiletypes && (in_array(strtolower($file->getFileType()), $viewonlinefiletypes) || in_array(strtolower($file->getMimeType()), $viewonlinefiletypes))) { if($accessobject->check_controller_access('ViewOnline', array('action'=>'run'))) { print "
    • getID()."\">" . getMLText("view_online") . "
    • "; } } } else print "
    • getMimeIcon($file->getFileType())."\" title=\"".htmlspecialchars($file->getMimeType())."\">"; echo "
    \n"; } else $this->infoMsg(getMLText("no_attached_files")); if($accessobject->check_controller_access('AddFile')) { $this->contentContainerStart(); if ($document->getAccessMode($user) >= M_READWRITE){ print $this->html_link('AddFile', array('documentid'=>$documentid), array('class'=>'btn btn-primary'), getMLText("add"), false, true)."\n"; } $this->contentContainerEnd(); } ?>
    $tab) { echo '
    '; echo $tab['content']; echo "
    \n"; } } ?> isAdmin()) { $this->contentHeading(getMLText("timeline")); $this->printTimelineHtml(300); } $this->columnEnd(); $this->rowEnd(); echo $this->callHook('postContent'); $this->contentEnd(); $this->htmlEndPage(); } /* }}} */ } ?>