2ed3591b22
*This patch is based on something that I noticed while working on PR 10126.* The recent re-factoring of `PDFFindController` brought many improvements, among those the fact that access to `BaseViewer` is no longer required. However, with these changes there's one thing which now strikes me as not particularly user-friendly[1]: The fact that in order for searching to actually work, `PDFFindController.setDocument` must be called *and* a 'pagesinit' event must be dispatched (from somewhere). For all other viewer components, calling the `setDocument` method[2] is enough in order for the component to actually be usable. The `PDFFindController` thus stands out quite a bit, and it also becomes difficult to work with in any sort of custom implementation. For example: Imagine someone trying to use `PDFFindController` separately from the viewer[3], which *should* now be relatively simple given the re-factoring, and thus having to (somehow) figure out that they'll also need to manually dispatch a 'pagesinit' event for searching to work. Note that the above even affects the unit-tests, where an out-of-place 'pagesinit' event is being used. To attempt to address these problems, I'm thus suggesting that *only* `setDocument` should be used to indicate that searching may start. For the default viewer and/or the viewer components, `BaseViewer.setDocument` will now call `PDFFindController.setDocument` when the document is ready, thus requiring no outside configuration anymore[4]. For custom implementation, and the unit-tests, it's now as simple as just calling `PDFFindController.setDocument` to allow searching to start. --- [1] I should have caught this during review of PR 10099, but unfortunately it's sometimes not until you actually work with the code in question that things like these become clear. [2] Assuming, obviously, that the viewer component in question actually implements such a method :-) [3] There's even a very recent issue, filed by someone trying to do just that. [4] Short of providing a `PDFFindController` instance when creating a `BaseViewer` instance, of course. |
||
---|---|---|
.. | ||
annotation_spec.js | ||
api_spec.js | ||
bidi_spec.js | ||
cff_parser_spec.js | ||
clitests_helper.js | ||
clitests.json | ||
cmap_spec.js | ||
colorspace_spec.js | ||
crypto_spec.js | ||
custom_spec.js | ||
display_svg_spec.js | ||
document_spec.js | ||
dom_utils_spec.js | ||
encodings_spec.js | ||
evaluator_spec.js | ||
function_spec.js | ||
jasmine-boot.js | ||
message_handler_spec.js | ||
metadata_spec.js | ||
murmurhash3_spec.js | ||
network_spec.js | ||
network_utils_spec.js | ||
node_stream_spec.js | ||
parser_spec.js | ||
pdf_find_controller_spec.js | ||
pdf_find_utils_spec.js | ||
pdf_history_spec.js | ||
primitives_spec.js | ||
stream_spec.js | ||
test_utils.js | ||
testreporter.js | ||
type1_parser_spec.js | ||
ui_utils_spec.js | ||
unicode_spec.js | ||
unit_test.html | ||
util_spec.js |