Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Highlight Support in ReadiumJS Disabled? #657

Closed
rkwright opened this issue Oct 19, 2017 · 16 comments
Closed

Highlight Support in ReadiumJS Disabled? #657

rkwright opened this issue Oct 19, 2017 · 16 comments

Comments

@rkwright
Copy link
Contributor

This issue is a Discussion

  • This is derived from an email thread beginning 19 October 2017

Related issue(s) and/or pull request(s)

None?

Expected Behaviour

Highlights should work

Observed behaviour

Instead, with release 0.27 they are disabled by default

Test file(s)

Not available?

Product

ReadiumJS, 0.28-alpha

Additional information

None?

@rkwright
Copy link
Contributor Author

rkwright commented Oct 19, 2017

from Ken Jones, ken@circularsoftware.com

I've noticed that the method I have been using to highlight overlaid panels on sheet music has stopped working on both readium.github.io/readium-js-viewer and readium.firebaseapp.com

e.g.

tracktracker

I am using a CSS brightness adjustment to affect the appearance of the panels in time with the SMIL.

@rkwright
Copy link
Contributor Author

from @danielweck

The highlighter feature has been removed from the default build configuration of readium-shared-js (consequently, this impacts the default deployment of the cloud reader at Firebase and Surge).
The actual code has not been removed though, you can easily re-activate the plugin by uncommenting this line:
https://github.com/readium/readium-shared-js/blob/62490d18031c6dd675639b442a7b791274bfe7b1/plugins/plugins.cson#L3
PS: note that readium.firebaseapp.com is always up to date (automatic builds from the develop branch), whereas readium.github.io/readium-js-viewer has historically been a little bit behind updates, and will be deprecated soon.
I hope this helps.
Let us know if you have any problems building your own version of the cloud reader. There are instructions in the README:
https://github.com/readium/readium-js-viewer/blob/develop/README.md#prerequisites

@rkwright
Copy link
Contributor Author

from @danielweck

Oh, and you probably want to deactivate the Hypothesis annotation plugin as well (comment the line):
https://github.com/readium/readium-shared-js/blob/62490d18031c6dd675639b442a7b791274bfe7b1/plugins/plugins.cson#L6

I am building a version of the cloud reader for you...

@rkwright
Copy link
Contributor Author

rkwright commented Oct 19, 2017

@llemeurfr
Copy link

In fact, activating hypothesis by default may have been a bad move, as many implementers are in fact relying on the default highlight module. We may decide to revert to the default highlight module for 0.28; any thoughts?

@rkwright
Copy link
Contributor Author

Many? Who? Bear in mind that this change only affects those deploying their own instance of CloudReader - not the SDK and not the Chrome app. When we made the decision to enable it, it was to enable it (the hypothes.is plugin) by default and document how to (easily) disable it.

@danielweck
Copy link
Member

@llemeurfr I think that the default build of readium-shared-js (which determines which plugins are activated) cannot possibly suit everybody's needs. Most developers actually build their own version of it anyway, as this is not really designed as an off-the-shelf component containing features that can be switched at runtime. There is some compile-time configuration.

@danielweck
Copy link
Member

The Chrome app is totally controlled by the Readium management team, so they decide what features are shipped (normally, the highlights plugin is deactivated).

The cloud reader deployed at Firebase and Surge is Readium's own build preference, and it contains Hypothesis instead of the highlights plugin (which did nothing but visually-select text, anyway).

@danielweck
Copy link
Member

danielweck commented Oct 19, 2017

I see a problem with native apps though. In the GitHub repository (i.e. the actual source tree, develop and master branches), there is a ready-to-use build of readium-shared-js. The intent was / is to provide an "off the shelf" shared-js component that can be directly integrated in a native apps's reader.html (by referencing the pre-built single or multiple AMD bundles). That's how the ReadiumSDK launcher apps work, via Git submodules.
Problem: the default readium-shared-js build now contains the Hypothesis plugin, which consequently gets activated in the native launcher apps.
Not a big deal for an existing Readium integrator that already compiles its own version of shared-js (thereby overriding the default build config), but really confusing for others.
We actually did talk about this with Juan etc. but the more urgent goal was to deliver Hypothesis integration in the mainstream cloud reader, so we put a punt on this issue.
See: readium/readium-shared-js#418

@rkwright
Copy link
Contributor Author

@danielweck
Thanks. Sigh. This points up the problem that we don't really know (or have any way to know) how people are using the SDK or the CloudReader. Do we know for a fact who might be using this pre-built version of shared-js?

@danielweck
Copy link
Member

And to be clear: Hypothesis is a proper cloud-based annotation service, thus why its default integration in the deployed Readium web reader made sense for our demo purposes.

The highlights plugin is a core utility feature with limited scope, not capable of managing actual annotations. It is meaningless to end-users, and only adds value when developers build functionality on top of it.

@danielweck
Copy link
Member

PS: this debate about "which plugin to activate in the default build" is likely to arise again. I think we need a default config for the cloud reader, one for the Chrome app (soon to be deprecated, so perhaps not such a priority), and one of the readium-shared-js build-output that ReadiumSDK native apps use. The rest of the world will have to ensure their configuration meets their deployment needs.

@danielweck
Copy link
Member

I have now realised that the reported bug has nothing to do with the highlights plugin that used to be shipped by default in the build of the cloud reader (now superceded by Hypothesis).
However this discussion remains relevant, and the title is correct ("Highlight Support in ReadiumJS Disabled?")

@danielweck
Copy link
Member

Closed via resolution of #658

@DougsAraujo
Copy link

@danielweck The hypothesis plugin when enabled in the cson file works normally, however the plugin highlights, enable but does not make the markup, what can I do?

@danielweck
Copy link
Member

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

4 participants