diff --git a/lib/Service/FileService.php b/lib/Service/FileService.php index 7c20b31c2e..ba1bc45977 100644 --- a/lib/Service/FileService.php +++ b/lib/Service/FileService.php @@ -370,6 +370,19 @@ private function getFile(): array { 'displayName' => $this->userManager->get($this->file->getUserId())->getDisplayName(), ]; $return['file'] = $this->urlGenerator->linkToRoute('libresign.page.getPdf', ['uuid' => $this->file->getUuid()]); + if ($this->showVisibleElements) { + $signers = $this->signRequestMapper->getByMultipleFileId([$this->file->getId()]); + $return['visibleElements'] = []; + foreach ($this->signRequestMapper->getVisibleElementsFromSigners($signers) as $visibleElements) { + $return['visibleElements'] = array_merge( + $this->formatVisibleElementsToArray( + $visibleElements, + $this->file->getMetadata() + ), + $return['visibleElements'] + ); + } + } foreach ($this->getSigners() as $signer) { if ($signer['me']) { $return['url'] = $this->urlGenerator->linkToRoute('libresign.page.getPdfFile', ['uuid' => $signer['sign_uuid']]); @@ -504,29 +517,10 @@ private function associateAllAndFormat(IUser $user, array $files, array $signers } return $carry; }, false), - 'visibleElements' => array_map(function (FileElement $visibleElement) use ($file) { - $element = [ - 'elementId' => $visibleElement->getId(), - 'signRequestId' => $visibleElement->getSignRequestId(), - 'type' => $visibleElement->getType(), - 'coordinates' => [ - 'page' => $visibleElement->getPage(), - 'urx' => $visibleElement->getUrx(), - 'ury' => $visibleElement->getUry(), - 'llx' => $visibleElement->getLlx(), - 'lly' => $visibleElement->getLly() - ] - ]; - $metadata = json_decode($file['metadata'], true); - $dimension = $metadata['d'][$element['coordinates']['page'] - 1]; - - $element['coordinates']['left'] = $element['coordinates']['llx']; - $element['coordinates']['height'] = abs($element['coordinates']['ury'] - $element['coordinates']['lly']); - $element['coordinates']['top'] = $dimension['h'] - $element['coordinates']['ury']; - $element['coordinates']['width'] = $element['coordinates']['urx'] - $element['coordinates']['llx']; - - return $element; - }, $visibleElements[$signer->getId()] ?? []), + 'visibleElements' => $this->formatVisibleElementsToArray( + $visibleElements[$signer->getId()] ?? [], + json_decode($file['metadata'], true) + ), 'identifyMethods' => array_map(function (IdentifyMethod $identifyMethod) use ($signer): array { return [ 'method' => $identifyMethod->getIdentifierKey(), @@ -583,6 +577,36 @@ private function associateAllAndFormat(IUser $user, array $files, array $signers return $files; } + /** + * @param FileElement[] $visibleElements + * @param array + * @return array + */ + private function formatVisibleElementsToArray(array $visibleElements, array $metadata): array { + return array_map(function (FileElement $visibleElement) use ($metadata) { + $element = [ + 'elementId' => $visibleElement->getId(), + 'signRequestId' => $visibleElement->getSignRequestId(), + 'type' => $visibleElement->getType(), + 'coordinates' => [ + 'page' => $visibleElement->getPage(), + 'urx' => $visibleElement->getUrx(), + 'ury' => $visibleElement->getUry(), + 'llx' => $visibleElement->getLlx(), + 'lly' => $visibleElement->getLly() + ] + ]; + $dimension = $metadata['d'][$element['coordinates']['page'] - 1]; + + $element['coordinates']['left'] = $element['coordinates']['llx']; + $element['coordinates']['height'] = abs($element['coordinates']['ury'] - $element['coordinates']['lly']); + $element['coordinates']['top'] = $dimension['h'] - $element['coordinates']['ury']; + $element['coordinates']['width'] = $element['coordinates']['urx'] - $element['coordinates']['llx']; + + return $element; + }, $visibleElements); + } + public function getMyLibresignFile(int $nodeId): File { return $this->signRequestMapper->getMyLibresignFile( userId: $this->me->getUID(),