MediaWiki
Jmol MediaWiki Extension enables the use of JSmol inside MediaWiki pages
- Jmol as a standalone application.
- J(S)mol as a web applet or HTML5 object.
- compatibility with JavaScript frameworks or libraries.
- J(S)mol embedded in wikis or blogs.
- Borrowed JSmol, or running JSmol without your own server.
- Running Jmol using Java Web Start.
- JSmol in a Jupyter notebook.
- Jmol in an Android tablet.
- Troubleshooting.
Contents
Description
MediaWiki is an open source wiki engine licensed under the GNU General Public License. It is used by many websites, including this one. The Jmol MediaWiki Extension enables the use of the JSmol object inside wiki pages driven by MediaWiki.
Current version is Jmol MediaWiki Extension 6.0. It uses JSmol, in the HTML5 modality (it may be set by the administrator to use the WebGL modality). It is compatible with MediaWiki 1.43 (likely also with 1.39 and 1.41)
(You can check which version a Wiki is using by going to the Special:Version
page in that Wiki)
Previous versions:
- Version 5 uses JSmol (in HTML5 modality by default, but also compatible with Java modality if you use a web browser that still supports Java applets). Some functionality was added, apart from compatibility with MediaWiki version 1.32.
- Version 4 used JSmol (in HTML5 modality by default, but also compatible with Java modality)
- Version 3 used Jmol-Java.
- Security is hopefully correct now. The delay effect can be obtained by using Jmol applet in a popup window.
- The Jmol MediaWiki Extension is fully functional and stabilized. It currently needs to be modified for a few things: better security, ability to delay loading the applet.
Wikis using the Jmol Extension
If you know a Wiki using the Jmol MediaWiki Extension, please add it to the list of Wikis using Jmol.
How to use the Jmol Extension
Once the Jmol Extension is installed in the wiki, you can start adding JSmol objects and controls.
How to know if the Extension is installed, and which version it is? Visit the Special:Version
page in your wiki; the extension should be listed there.
- How to use version 6 of the Jmol Extension. Compatible with MediaWiki 1.39 to 1.43, PHP 8.1.0 and JSmol 16.3.7 (likely also with former versions of JSmol)
- How to use version 5 of the Jmol Extension. Compatible with MediaWiki 1.32, PHP 7.0 and JSmol 14.29.32
- How to use version 4 of the Jmol Extension
- How to use version 3 of the Jmol Extension
Installation
(This must be done by the wiki administrator.)
Problems yet to be solved
Note: if you have some problem, please first check compatibility between versions of the Extension and versions of the MediaWiki engine. See MediaWiki#How_to_use_the_Jmol_Extension
Already solved
These are left here for reference, as you may still have these problems depending on your version of MediaWiki or your version of the Jmol MediaWiki Extension.
- Having problems with Jmol applets that are placed below the flow of a link, button, or other user interface element in markup. I get what appears to be a Java error when loading an uploaded file. --Mevans86 18:58, 13 October 2010 (UTC)
- Does not work with Media wiki 1.17 (and probably 1.15,1.16). I think there was a rewrite of MediaWiki code and I get:
- Warning: Parameter 1 to Jmol::tag_jmol() expected to be a reference, value given in /var/www/mediawiki/extensions/StubManager/StubManager.php on line 783
- --Jacksmind 01:00, 10 October 2010 (UTC)
- Hopefully this is solved with version 3.3 of the Extension, since it no longer depends on StubManager. (Still to be confirmed, but it is working fine with MW 1.16 in this site.) --AngelHerraez 12:32, 22 November 2010 (CET)
- The developers at WikiMedia / WikiMedia Commons / Wikipedia apparently advocate the use of a simpler way of inserting Jmol applets, by just linking to the (previously uploaded) model file (as it is done e.g. with images) and having the server decide upon the way to handle it, with something simpler than the current Extension (see a discussion about this).
- However, in my opinion rendering of a 3D molecular model clearly calls for something more flexible than a simple, barebone viewer with default settings. Maybe we would have to resort to a simpler extension for Wikipedia and a full one for other wikis?
- New tags are available since version 3.3 of the extension, which are much more simple to use (<jmolFile>, <jmolPdb>, <jmolSmiles>), but are currently not flexible. A solution to explore may be the use of HTML templates to give the opporunity to choose between differently configured viewers (with different controls and informations). --NicolasVervelle 22:44, 28 November 2010 (CET)
- An interesting feature would be the server-side automation of the snapshot ability of the Jmol application, so that images are generated into the wiki page as a thumbnail that will link to --or be replaced by-- the applet when the user clicks on the image, or on a link below it (see an example of this idea, though not server-generated).
- I have just upgraded to MediaWiki 1.18.1 and I now have:
- Warning: Parameter 3 to Jmol::jmolPdbTag() expected to be a reference, value given in /var/www/SklogWiki/includesparser/Parser.php on line 3580
- Any advice? --SklogWiki 19:31, 31 January 2012 (CET)
- The installation does not work when the wiki is installed in a non-root folder of the server (e.g. http://www.myserver.com/mywiki/index.php instead of http://mywiki.myserver.com/index.php).
- Fixed (2008-Nov-29) in revision 10393.
- Using <jmolAppletButton> or <jmolAppletlink> throws an error in Internet Explorer: "Invalid argument", and prevents the pop-up.
- Partially fixed (2008-Dec-2) in revision 10411.
- Completely fixed (2008-Dec-8) in revision 10467.
- The scripts associated to checkboxes rendered by <jmolCheckbox> have no effect on the applet.
- Fixed (2008-Dec-8) in revision 10467.
- This was the discussion of the problem:
(Bob) something in /skins/common/wikibits.js?97 is disabling checkboxes.
(Nico) Yes, good catch, thanks a lot. Now, I need to find a way to overcome the behaviour of setupCheckboxShiftClick()
. I am going to ask on MediaWiki list.
(Bugzilla) discussion
- Since Jmol scripting can include a call to javascript commands, the Jmol applet inserted by the Jmol MediaWiki Extension can execute arbitrary javascript added by any user editing the page (see demo). This is an unacceptable security hole for some systems such as Wikipedia, and will prevent Jmol from being used there. There is hence a need to implement a "scripting-without-javascript" mode of the applet, i.e. a way to completely disable the
javascript
command in Jmol scripts run from the MediaWiki Extension.
- Fixed (2008-Dec-8) in revision 10467.
- No javascript will be executed by Jmol applets inserted by the Extension.
- The signed applet was not being used even when explicitly authorized in the wiki configuration (
$wgJmolAuthorizeChoosingSignedApplet=true
) and requested for the applet (<signed>true</signed>
).
- Fixed (2008-Dec-8) in revision 10467.
- Now you can also have both signed and unsigned applets in the same page.
- Inserting applets with models read from php pages fails. The applet is using the <urlContents> tag and the url contains the '&' character.
- Fixed (2009-Nov-13) in revision 11738, version 3.2 of the Extension.
- The '&' is not tolerated by the wikicode. The solution is to use %26 (the wikicode for &) instead of the ampersand(s) in the url, content of the <urlContents> tag. The Extension will later filter those %26 codes and convert them to & so that the server correctly provides the model.
External links
- Wikipedia: Using Jmol to display molecular models
- Wikipedia: WikiProject Chemistry
- MediaWiki: Jmol Extension for MediaWiki
Contributors
AngelHerraez, NicolasVervelle, Rzepa, Mevans86, Ngreeves, Pimpim, SklogWiki, Jacksmind, EricMartz