Coppermine Photo Gallery v1.5.x: Documentation and Manual

Table of Contents

Javascript in Coppermine

A lot of pages in coppermine uses javascript for client side enhancements and validations. This guide will help developers to understand how javascript is organized in coppermine.

Target audience

This part of the documentation is not meant for end users of Coppermine, but only for developers. There is no support for this section, it comes as-is.

Javascript files location and organization

TODO

There is still lot of javascript inline with html (from cpg1.4). This javascript needs to be separated into their own files

How to include javascript files

Javascript files can be included from within php code by calling js_include() function.

// This line of code will include displayimage.js file
js_include('js/displayimage.js');
However there is a catch in using this function. This function should be called before the pageheader() function is called. The actual inclusion of javascript files is done in pageheader() function and that is the reason all js inclusion should be done before that.

If you need to add a javascript file for a plugin, the 'page_start' plugin action might be used.

How to pass PHP variables to included javascript

If you need to pass dynamic data from PHP code (e.g. a language string that resides in a PHP variable) to the JavaScript code that resides in an external file included with the method explained above, you can use the function set_js_var() that get's defined in include/functions.inc.php.

If you need to pass the content of the variable $foo to JS, use this code:
<?php
$foo = 'bar';
set_js_var('php_foo', $foo);
?>