calixteman
a0bdd67bc3
Merge pull request #19507 from calixteman/bug1948771
...
[Editor] Add a scrollbar to the signature doorhanger when it's overflowing (bug 1948771)
2025-02-17 21:31:01 +01:00
Calixte Denizet
cde7d83319
[Editor] Add a scrollbar to the signature doorhanger when it's overflowing (bug 1948771)
2025-02-17 21:09:56 +01:00
Calixte Denizet
3fc6b1321f
[Editor] Scale the signature editor when it's too large (bug 1948741)
2025-02-17 20:20:26 +01:00
Jonas Jenwald
36979e9eb2
Fix all outstanding ESLint arrow-body-style
warnings
...
Currently this rule is disabled in a number of spots across the code-base, and unless absolutely necessary we probably shouldn't disable linting, so let's just update the code to fix all the outstanding cases.
2025-02-17 15:45:44 +01:00
Jonas Jenwald
affce70a09
Merge pull request #19503 from Snuffleupagus/web-rm-some-eslint-disable
...
Remove a few `eslint-disable` statements in the `web/` folder
2025-02-17 15:21:57 +01:00
calixteman
2df0f925b9
Merge pull request #19500 from calixteman/test_signature1
...
[Editor] Add two integration tests for the signature UI
2025-02-17 14:48:07 +01:00
Calixte Denizet
b8993cfcc8
[Editor] Add two integration tests for the signature UI
2025-02-17 13:58:54 +01:00
Jonas Jenwald
a2d15ceb84
Remove a few eslint-disable
statements in the web/
folder
...
These cases could be easily re-written to avoid having to disable ESLint rules.
2025-02-17 13:40:09 +01:00
Tim van der Meij
33c97570f5
Merge pull request #19499 from Snuffleupagus/useWorkerFetch-ensure-boolean
...
Ensure that the `useWorkerFetch` fallback value is always a boolean
2025-02-16 14:50:29 +01:00
Jonas Jenwald
06e4580f8b
Ensure that the useWorkerFetch
fallback value is always a boolean
...
If either of the factory-urls are missing or invalid, the fallback value would currently become `useWorkerFetch === null`.
While that is obviously a falsy value, which means that the code still works as intended, we should ensure that this is consistent.
2025-02-16 14:04:30 +01:00
Jonas Jenwald
c2e33307b1
Introduce some URL.parse()
usage in the code-base
...
This (fairly new) static method allows parsing URLs without having to wrap `new URL(...)` calls within `try...catch` blocks, thus simplifying the code; see https://developer.mozilla.org/en-US/docs/Web/API/URL/parse_static
For older browsers/environments the functionality will be polyfilled, but *only* in `legacy` builds, via `core-js`; see https://github.com/zloirock/core-js?tab=readme-ov-file#url-and-urlsearchparams
*Please note:* This is currently limited to the `src/`- and `web/`-folders, such that we don't break development/testing, since the functionality is not available in all Node.js versions that we support; see https://developer.mozilla.org/en-US/docs/Web/API/URL/parse_static#browser_compatibility
2025-02-15 19:10:36 +01:00
Jonas Jenwald
3f15e0c469
Merge pull request #19495 from Snuffleupagus/issue-19494
...
Check more of the stream when looking for commands after inline image (issue 19494)
2025-02-15 17:05:59 +01:00
Jonas Jenwald
8dec353c7a
Merge pull request #19496 from Snuffleupagus/shorter-#buildObjectKey
...
Shorten the `CipherTransformFactory.prototype.#buildObjectKey` method
2025-02-15 17:03:35 +01:00
Jonas Jenwald
65df1d336f
Check more of the stream when looking for commands after inline image (issue 19494)
...
Currently we only check `followingBytes`, which turns out to be too short to find e.g. valid transform (cm) commands with decimal arguments.
2025-02-15 15:14:47 +01:00
Jonas Jenwald
a722ca4de5
Shorten the CipherTransformFactory.prototype.#buildObjectKey
method
...
- Use `TypedArray.prototype.set()` rather than a manual loop when building the `key`.
- Use an existing local variable to avoid re-computing the length of the `encryptionKey`.
2025-02-15 13:00:42 +01:00
calixteman
92ff26e4ff
Merge pull request #19427 from calixteman/bug1946181
...
Add some unicode mapping for ligatures when writing the cmap table in the font (bug 1946181)
2025-02-14 17:46:07 +01:00
Jonas Jenwald
144e5fe196
Merge pull request #19476 from Snuffleupagus/issue-19474
...
Search for destinations in both /Names and /Dests dictionaries (issue 19474)
2025-02-14 16:05:36 +01:00
Jonas Jenwald
33cba30bdb
Search for destinations in both /Names and /Dests dictionaries (issue 19474)
...
Currently we only use either one of them, preferring the NameTree when it's available.
2025-02-14 15:49:05 +01:00
Jonas Jenwald
c69282a64f
Merge pull request #19487 from Snuffleupagus/OverlayManager-closeIfActive
...
Add a new `closeIfActive` method in the `OverlayManager` class
2025-02-14 15:46:13 +01:00
Jonas Jenwald
96f5dcbd91
Add a new closeIfActive
method in the OverlayManager
class
...
It's now pretty common that we only want to close a `dialog` *if* it's currently active, to avoid throwing errors, and this new method provides a shorter and more convenient way to achieve that.
2025-02-14 15:43:00 +01:00
calixteman
6258a77bd7
Merge pull request #19486 from calixteman/signature_edit_desc
...
[Editor] Add the possibility to change a signature description (bug 1948116)
2025-02-14 15:41:45 +01:00
Jonas Jenwald
6ad56135c9
Merge pull request #19481 from Snuffleupagus/GenericL10n-fetch-bundles-parallel
...
[GenericL10n] Fetch the language bundles in parallel to reduce load time
2025-02-14 15:33:29 +01:00
Jonas Jenwald
c81a404138
Merge pull request #19475 from Snuffleupagus/injectLinkAnnotations-method-event
...
Move the auto-link handling into its own `PDFPageView` helper-method, and dispatch a "linkannotationsadded" event
2025-02-14 14:05:06 +01:00
Calixte Denizet
1d82b2ce94
[Editor] Add the possibility to change a signature description (bug 1948116)
2025-02-14 14:00:45 +01:00
Jonas Jenwald
a877493826
Merge pull request #19485 from Snuffleupagus/SignatureManager-Array-from-shorten
...
Slightly shorten an `Array.from` usage in the `SignatureManager` class
2025-02-14 10:44:37 +01:00
Jonas Jenwald
7dbf8c8e4b
Slightly shorten an Array.from
usage in the SignatureManager
class
...
This should be equivalent to the old code, and besides being ever so slightly shorter I'm also finding it a little bit easier to read at a glance.
2025-02-13 20:04:02 +01:00
calixteman
74a7576c2c
Merge pull request #19478 from calixteman/signature_init
...
[Editor] Populate the 'Add signature' menu with the saved signatures (bug 1947828)
2025-02-13 16:46:01 +01:00
Calixte Denizet
68451fe17e
[Editor] Populate the 'Add signature' menu with the saved signatures (bug 1947828)
2025-02-13 15:59:57 +01:00
Jonas Jenwald
8d8e25c89d
[GenericL10n] Fetch the language bundles in parallel to reduce load time
...
For non `en-US` locales this will, ever so slightly, shorten the time it takes to load and parse the language bundles.
2025-02-13 11:53:45 +01:00
Jonas Jenwald
8727a04ae5
Move the auto-link handling into its own PDFPageView
helper-method, and dispatch a "linkannotationsadded" event
...
This is similar to a lot of existing functionality for various layers, and the new event might be helpful in e.g. the integration-tests.
2025-02-12 14:57:44 +01:00
Jonas Jenwald
d6f63d0e4b
Merge pull request #19469 from Snuffleupagus/bug-1947248
...
[api-major] Apply the `userUnit` using CSS, to fix the text/annotation layers (bug 1947248)
2025-02-11 23:13:46 +01:00
calixteman
5b13ea14c2
Merge pull request #19472 from calixteman/update_button_hover_color
...
Fix the color of the background button when hovering it
2025-02-11 22:42:51 +01:00
Calixte Denizet
6950a312aa
Fix the color of the background button when hovering it
2025-02-11 20:15:17 +01:00
Jonas Jenwald
e2d2263788
Merge pull request #19464 from Snuffleupagus/autolinking-catch
...
Catch and ignore any errors during auto-linking parsing (PR 19110 follow-up)
2025-02-11 20:06:33 +01:00
Jonas Jenwald
bd05b255fa
[api-major] Apply the userUnit
using CSS, to fix the text/annotation layers (bug 1947248)
...
Rather than modifying the "raw" dimensions of the page, we'll instead apply the `userUnit` as an *additional* scale-factor via CSS.
*Please note:* It's not clear to me if this solution is fully correct either, or if there's other problems with it, but it at least *appears* to work.
---
With these changes, the following CSS variables are now assumed to be available/set as necessary: `--total-scale-factor`, `--scale-factor`, `--user-unit`, `--scale-round-x`, and `--scale-round-y`.
2025-02-11 14:36:06 +01:00
calixteman
e3cca6d513
Merge pull request #19425 from calixteman/signature_save
...
[Editor] Add the possibility to compress/decompress the signature data in order to store them in the logins storage in Firefox (bug 1946171)
2025-02-10 19:20:32 +01:00
Calixte Denizet
6b95095e14
Add the possibility to compress/decompress the signature data in order to store them in the logins storage in Firefox (bug 1946171)
2025-02-10 19:09:51 +01:00
Jonas Jenwald
29fbed384a
Merge pull request #19461 from Snuffleupagus/autolinking-lazy-borderStyle
...
Create the `borderStyle` of inferred links lazily (PR 19110 follow-up)
2025-02-10 16:32:12 +01:00
Jonas Jenwald
357ff4afde
Catch and ignore any errors during auto-linking parsing (PR 19110 follow-up)
...
While investigating a bug, that I've not yet had time to fully investigate and report, I found that if there's ever an error thrown from the `Autolinker` class it'll prevent the annotationEditorLayer from rendering *and* the renderTask itself will be treated as having failed.
2025-02-10 16:28:02 +01:00
Jonas Jenwald
de1c2146b8
Merge pull request #19458 from timvandermeij/updates
...
Update dependencies and translations to the most recent versions
2025-02-10 12:47:56 +01:00
Jonas Jenwald
fba5f3c237
Create the borderStyle
of inferred links lazily (PR 19110 follow-up)
...
Given that most inferred links will overlap existing LinkAnnotations, creating a lot of unused `borderStyle` objects seem unnecessary.
Hence we can move that into the `AnnotationLayer.prototype.addLinkAnnotations` method instead, which also allows us to slightly reduce the API-surface.
2025-02-10 11:53:22 +01:00
Jonas Jenwald
e608daed9f
Merge pull request #19460 from Snuffleupagus/autolinking-check-annotationLayer
...
Check that the annotationLayer is still active before injecting inferred links (PR 19110 follow-up)
2025-02-10 10:08:47 +01:00
Jonas Jenwald
81e99da440
Check that the annotationLayer is still active before injecting inferred links (PR 19110 follow-up)
...
This issue is quite difficult to trigger reliably, however it's possible for rendering to have been aborted and thus for the annotationLayer to have been removed once we're invoking `injectLinkAnnotations`. In that case, an Error is thrown[1].
The way that I'm able to *intermittently* trigger this is by:
- Loading http://localhost:8888/web/viewer.html?file=/test/pdfs/pdf.pdf#disableHistory=true
- Enable "Wrapped Srolling" mode.
- Quickly zoom out, to the minimum zoom level.
---
[1]
```
renderView: TypeError: can't access property "injectLinkAnnotations", this.annotationLayer is null
resultPromise http://localhost:8888/web/pdf_page_view.js:1116
draw http://localhost:8888/web/pdf_page_view.js:1099
renderView http://localhost:8888/web/pdf_rendering_queue.js:196
forceRendering http://localhost:8888/web/pdf_viewer.js:1849
promise callback*forceRendering http://localhost:8888/web/pdf_viewer.js:1848
renderHighestPriority http://localhost:8888/web/pdf_rendering_queue.js:79
renderView http://localhost:8888/web/pdf_rendering_queue.js:198
renderView http://localhost:8888/web/pdf_rendering_queue.js:197
forceRendering http://localhost:8888/web/pdf_viewer.js:1849
promise callback*forceRendering http://localhost:8888/web/pdf_viewer.js:1848
renderHighestPriority http://localhost:8888/web/pdf_rendering_queue.js:79
renderView http://localhost:8888/web/pdf_rendering_queue.js:198
renderView http://localhost:8888/web/pdf_rendering_queue.js:197
forceRendering http://localhost:8888/web/pdf_viewer.js:1849
promise callback*forceRendering http://localhost:8888/web/pdf_viewer.js:1848
renderHighestPriority http://localhost:8888/web/pdf_rendering_queue.js:79
renderView http://localhost:8888/web/pdf_rendering_queue.js:198
renderView http://localhost:8888/web/pdf_rendering_queue.js:197
forceRendering http://localhost:8888/web/pdf_viewer.js:1849
promise callback*forceRendering http://localhost:8888/web/pdf_viewer.js:1848
renderHighestPriority http://localhost:8888/web/pdf_rendering_queue.js:79
renderView http://localhost:8888/web/pdf_rendering_queue.js:198
renderView http://localhost:8888/web/pdf_rendering_queue.js:197
forceRendering http://localhost:8888/web/pdf_viewer.js:1849
promise callback*forceRendering http://localhost:8888/web/pdf_viewer.js:1848
renderHighestPriority http://localhost:8888/web/pdf_rendering_queue.js:79
update http://localhost:8888/web/pdf_viewer.js:1677
onScaleChanging http://localhost:8888/web/app.js:2550
dispatch http://localhost:8888/web/event_utils.js:115
#setScaleUpdatePages http://localhost:8888/web/pdf_viewer.js:1363
#setScale http://localhost:8888/web/pdf_viewer.js:1389
updateScale http://localhost:8888/web/pdf_viewer.js:2263
updateZoom http://localhost:8888/web/app.js:814
zoomOut http://localhost:8888/web/app.js:827
onKeyDown http://localhost:8888/web/app.js:2780
bindWindowEvents http://localhost:8888/web/app.js:2097
initialize http://localhost:8888/web/app.js:262
run http://localhost:8888/web/app.js:704
webViewerLoad http://localhost:8888/web/viewer.js:294
<anonymous> http://localhost:8888/web/viewer.js:305
pdf_rendering_queue.js:204:21
```
2025-02-10 09:19:04 +01:00
Jonas Jenwald
86ae2ca01c
Merge pull request #19449 from Snuffleupagus/autolinking-URL-fuzzy-match
...
Ignore the URLs when checking if inferred links overlap existing LinkAnnotations (PR 19110 follow-up)
2025-02-09 22:51:37 +01:00
Jonas Jenwald
37ef0b4a86
Ignore the URLs when checking if inferred links overlap existing LinkAnnotations (PR 19110 follow-up)
...
*Note:* For the issue mentioned on Matrix it'll obviously still make sense to improve the regular expression to detect more URL edge-cases.
However it occurred to me that even once that particular case is fixed there'll always be a risk that inferred links could overlap, and effectively block, the actual LinkAnnotations.
Hence this patch removes the URL comparison to ensure that overlapping inferred links will always be ignored.
2025-02-09 22:06:58 +01:00
Tim van der Meij
58a60b8959
Update translations to the most recent versions
2025-02-09 18:59:00 +01:00
Tim van der Meij
d2a07dcac6
Update dependencies to the most recent versions
...
Moreover, fix the linting issues (using `npx gulp lint --fix`) that are
found by the new versions of the linting tools.
2025-02-09 18:58:26 +01:00
Tim van der Meij
d88035525c
Merge pull request #19457 from timvandermeij/integration-tests-ink-isolate
...
Isolate the ink editor integration tests
2025-02-09 18:10:29 +01:00
Jonas Jenwald
b4a6b1ba0b
Merge pull request #19456 from Snuffleupagus/more-TypedArray-fill
...
Replace a couple of loops with `TypedArray.prototype.fill()`
2025-02-09 17:45:17 +01:00
calixteman
6862e84daa
Merge pull request #19437 from calixteman/signature_save_print1
...
[Editor] Add the ability to print and save some newly added signatures (bug 1946795)
2025-02-09 17:13:01 +01:00