Skip to content

Commit

Permalink
chore: make possible choose the page when select the signer
Browse files Browse the repository at this point in the history
Signed-off-by: Vitor Mattos <[email protected]>
  • Loading branch information
vitormattos authored and backportbot-libresign[bot] committed Nov 18, 2024
1 parent 9b1f438 commit 713318f
Show file tree
Hide file tree
Showing 4 changed files with 74 additions and 11 deletions.
1 change: 1 addition & 0 deletions .github/workflows/owasp-dependency-check.yml
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ on: pull_request

jobs:
dependency-check:
if: false # temporary disabled
runs-on: ubuntu-latest
steps:
- name: Check out code
Expand Down
4 changes: 4 additions & 0 deletions src/Components/PdfEditor/PdfEditor.vue
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,8 @@
:origin-width="object.originWidth"
:origin-height="object.originHeight"
:page-scale="pagesScale"
:canvas-width="object.canvasWidth"
:canvas-height="object.canvasHeight"
@onUpdate="$refs.vuePdfEditor.updateObject(object.id, $event)"
@onDelete="onDeleteSigner(object)" />
</template>
Expand Down Expand Up @@ -78,6 +80,8 @@ export default {
originHeight: signer.element.coordinates.height,
x: signer.element.coordinates.llx,
y: signer.element.coordinates.ury,
canvasWidth: signer.element.coordinates.canvasWidth,
canvasHeight: signer.element.coordinates.canvasHeight,
}
this.$refs.vuePdfEditor.allObjects = this.$refs.vuePdfEditor.allObjects.map((objects, pIndex) => {
if (pIndex === signer.element.coordinates.page - 1) {
Expand Down
10 changes: 9 additions & 1 deletion src/Components/PdfEditor/Signature.vue
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@
:style="{
width: `${width + dw}px`,
height: `${Math.round((width + dw) / ratio)}px`,
transform: `translate(${x + dx}px, ${y + dy}px)`,
transform: translateCoordinates(),
}">
<div class="signature absolute w-full h-full"
:class="[
Expand Down Expand Up @@ -93,6 +93,14 @@ export default {
type: Number,
default: 1,
},
canvasWidth: {
type: Number,
default: 1,
},
canvasHeight: {
type: Number,
default: 1,
},
fixSize: {
type: Boolean,
default: false,
Expand Down
70 changes: 60 additions & 10 deletions src/Components/Request/VisibleElements.vue
Original file line number Diff line number Diff line change
Expand Up @@ -16,15 +16,20 @@
{{ statusLabel }}
</Chip>
</h2>
<p>
<small>
{{ t('libresign', 'Click the page to add visible signature, then select a signer to set their signature position') }}
</small>
</p>
<ul class="view-sign-detail__sidebar">
<li v-if="signerSelected"
:class="{ tip: signerSelected }">
{{ t('libresign', 'Click on the place you want to add.') }}
<NcButton type="primary"
@click="stopAddSigner">
{{ t('libresign', 'Cancel') }}
</NcButton>
</li>
<Signer v-for="(signer, key) in document.signers"
:key="key"
:ref="'li-' + key"
:current-signer="key"
:class="{ disabled: signerSelected }"
:signer="signer"
event="libresign:visible-elements-select-signer">
<slot v-bind="{signer}" slot="actions" name="actions" />
Expand All @@ -33,6 +38,7 @@
<NcButton v-if="canSave"
:type="typeOfRequestButton"
:wide="true"
:class="{ disabled: signerSelected }"
@click="showConfirm = true">
{{ t('libresign', 'Request') }}
</NcButton>
Expand Down Expand Up @@ -122,6 +128,7 @@ export default {
showConfirm: false,
loading: false,
errorConfirmRequest: '',
signerSelected: null,
}
},
computed: {
Expand Down Expand Up @@ -207,16 +214,42 @@ export default {
this.filesStore.loading = false
},
onSelectSigner(signer) {
signer.element = {
this.signerSelected = signer
const canvasList = this.$refs.pdfEditor.$refs.vuePdfEditor.$refs.pdfBody.querySelectorAll('canvas')
canvasList.forEach((canvas) => {
canvas.addEventListener('click', this.doSelectSigner)
})
},
doSelectSigner(event) {
const canvasList = this.$refs.pdfEditor.$refs.vuePdfEditor.$refs.pdfBody.querySelectorAll('canvas')
const page = Array.from(canvasList).indexOf(event.target)
this.addSignerToPosition(event, page)
this.stopAddSigner()
},
addSignerToPosition(event, page) {
const measurement = this.$refs.pdfEditor.$refs.vuePdfEditor.$refs['page' + page][0].getCanvasMeasurement()
const rect = event.target.getBoundingClientRect()
const x = event.clientX - rect.left
const y = event.clientY - rect.top
this.signerSelected.element = {
coordinates: {
page: this.$refs.pdfEditor.$refs.vuePdfEditor.selectedPageIndex + 1,
llx: 100,
ury: 100,
page: page + 1,
llx: x - SignatureImageDimensions.width / 2,
ury: y - SignatureImageDimensions.height / 2,
height: SignatureImageDimensions.height,
width: SignatureImageDimensions.width,
canvasWidth: measurement.canvasWidth,
canvasHeight: measurement.canvasHeight,
},
}
this.$refs.pdfEditor.addSigner(signer)
this.$refs.pdfEditor.addSigner(this.signerSelected)
},
stopAddSigner() {
const canvasList = this.$refs.pdfEditor.$refs.vuePdfEditor.$refs.pdfBody.querySelectorAll('canvas')
canvasList.forEach((canvas) => {
canvas.removeEventListener('click', this.doSelectSigner)
})
this.signerSelected = null
},
async onDeleteSigner(object) {
if (!object.signer.element.elementId) {
Expand Down Expand Up @@ -314,6 +347,23 @@ export default {
margin: 3px 3px 1em 3px;
}
}
.disabled {
pointer-events: none;
visibility: hidden;
}
.tip {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
margin-top: 1px;
margin-bottom: 1px;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
}
}
}
</style>

0 comments on commit 713318f

Please sign in to comment.