wicketstuff / core

Wicketstuff-core projects are bundled user contributions for use with Apache Wicket (https://wicket.apache.org/). They are released in step with Wicket releases to make them easy to use.
342 stars 298 forks source link

TinyMCE6: /current/ in Webjar URL #1053

Open f-wunderlich opened 1 month ago

f-wunderlich commented 1 month ago

The wicketstuff-tinymce6 module hardcodes the path to the TinyMCE JS in the Webjar with "current" instead of the version number. How is that supposed to work?

TinyMCESettings: public static final ResourceReference TINYMCE_JS_REF = new JavaScriptResourceReference( TinyMceBehavior.class, "../../../webjars/tinymce/current/tinymce.js"); public static final ResourceReference TINYMCE_JS_REF_MIN = new JavaScriptResourceReference( TinyMceBehavior.class, "../../../webjars/tinymce/current/tinymce.min.js");

pom.xml:

org.webjars.npm
        <artifactId>tinymce</artifactId>
        <version>6.8.3</version>

$ jar tf ~/.m2/repository/org/webjars/npm/tinymce/6.8.3/tinymce-6.8.3.jar | grep tinymce.js META-INF/resources/webjars/tinymce/6.8.3/tinymce.js

Unsurprisingly, the example does not work: $ mvn -Dexec.mainClass=org.wicketstuff.examples.tinymce.Start -Dexec.classpathScope=test test-compile exec:java [...] [qtp493343679-81] WARN org.apache.wicket.request.resource.PackageResource - resource [path = webjars/tinymce/current/tinymce.js, style = null, variation = null, locale = null]: Unable to find resource (status=404)

Either change the path in TinyMCESettings to match the Webjar ("6.8.3" instead of "current"), or use something like org.webjars:webjars-servlet-2.x and get rid of the "current/" segment in the path.

As far as I can tell, this "current" segment is only generated by de.agilecoders.wicket.webjars:wicket-webjars which is quite useless as it only works for its own IWebjarsResourceReference derived classes (see WebjarsResourceFinder#find) and with a massive amount of code only replicates what the container does anyway. In any case, neither is this artifact used by the TinyMCE6 module, nor would it work if it was, since TinyMCESettings declares standard JavaScriptResourceReferences.

martin-g commented 1 month ago

@renoth ^^

martin-g commented 1 month ago

@f-wunderlich The idea is to use current + WebjarsResourceReference and update the version only in pom.xml. Using JavaScriptResourceReference must be a mistake.

It is not very clear how https://github.com/webjars/webjars-servlet-2.x works from its README. It might do the same or something else. I cannot tell...

f-wunderlich commented 1 month ago

For de.agilecoders.wicket.webjars:wicket-webjars I believe the following is necessary:

The org.webjars:webjars-servlet-2.x artifact is documented at the official Webjars website: https://www.webjars.org/documentation#servlet2 It is useless for anything halfway modern since it uses javax.servlet classes and can only serve as an example on how to make web applications agnostic of the webjar version they are using with maybe 20 lines of code: https://github.com/webjars/webjars-servlet-2.x/blob/master/src/main/java/org/webjars/servlet/WebjarsServlet.java

martin-g commented 1 month ago

@f-wunderlich Do you want to send a Pull Request?

renoth commented 2 weeks ago

IMHO it doesnt matter that much anymore because TinyMCE 6 is EOL tomorrow https://github.com/tinymce/tinymce/discussions/9609 and TinyMCE 7 self hosted will be GPLv2 which will make it unusable for most people. Any good alternatives with Wicket?

Shitstorm-Thread here https://github.com/tinymce/tinymce/discussions/9496