snipt

Ctrl+h for KB shortcuts

PHP

Pass the theme path to javascript in Drupal

<?php
// In your theme's template.php file:

function MYTHEME_preprocess_page(&$variables) {
drupal_add_js('jQuery.extend(Drupal.settings, { "pathToTheme": "' . path_to_theme() . '" });', 'inline');
}


// In your theme's js file

 $('#IMG').attr('src', Drupal.settings.basePath + Drupal.settings.pathToTheme + '/PATH/TO/SOME/FILE.png');
 
 // Source: https://drupal.org/node/1427564
https://snipt.net/embed/4891f4100c1a64f3fdf7c634221e88a3/
/raw/4891f4100c1a64f3fdf7c634221e88a3/
4891f4100c1a64f3fdf7c634221e88a3
php
PHP
13
2019-08-18T21:59:11
True
False
False
Feb 21, 2014 at 06:18 PM
/api/public/snipt/115863/
pass-the-theme-path-to-javascript-in-drupal
<table class="highlighttable"><tr><td class="linenos"><div class="linenodiv"><pre><a href="#L-1"> 1</a> <a href="#L-2"> 2</a> <a href="#L-3"> 3</a> <a href="#L-4"> 4</a> <a href="#L-5"> 5</a> <a href="#L-6"> 6</a> <a href="#L-7"> 7</a> <a href="#L-8"> 8</a> <a href="#L-9"> 9</a> <a href="#L-10">10</a> <a href="#L-11">11</a> <a href="#L-12">12</a> <a href="#L-13">13</a></pre></div></td><td class="code"><div class="highlight"><pre><span></span><span id="L-1"><a name="L-1"></a><span class="cp">&lt;?php</span> </span><span id="L-2"><a name="L-2"></a><span class="c1">// In your theme&#39;s template.php file:</span> </span><span id="L-3"><a name="L-3"></a> </span><span id="L-4"><a name="L-4"></a><span class="k">function</span> <span class="nf">MYTHEME_preprocess_page</span><span class="p">(</span><span class="o">&amp;</span><span class="nv">$variables</span><span class="p">)</span> <span class="p">{</span> </span><span id="L-5"><a name="L-5"></a><span class="nx">drupal_add_js</span><span class="p">(</span><span class="s1">&#39;jQuery.extend(Drupal.settings, { &quot;pathToTheme&quot;: &quot;&#39;</span> <span class="o">.</span> <span class="nx">path_to_theme</span><span class="p">()</span> <span class="o">.</span> <span class="s1">&#39;&quot; });&#39;</span><span class="p">,</span> <span class="s1">&#39;inline&#39;</span><span class="p">);</span> </span><span id="L-6"><a name="L-6"></a><span class="p">}</span> </span><span id="L-7"><a name="L-7"></a> </span><span id="L-8"><a name="L-8"></a> </span><span id="L-9"><a name="L-9"></a><span class="c1">// In your theme&#39;s js file</span> </span><span id="L-10"><a name="L-10"></a> </span><span id="L-11"><a name="L-11"></a> <span class="err">$</span><span class="p">(</span><span class="s1">&#39;#IMG&#39;</span><span class="p">)</span><span class="o">.</span><span class="nx">attr</span><span class="p">(</span><span class="s1">&#39;src&#39;</span><span class="p">,</span> <span class="nx">Drupal</span><span class="o">.</span><span class="nx">settings</span><span class="o">.</span><span class="nx">basePath</span> <span class="o">+</span> <span class="nx">Drupal</span><span class="o">.</span><span class="nx">settings</span><span class="o">.</span><span class="nx">pathToTheme</span> <span class="o">+</span> <span class="s1">&#39;/PATH/TO/SOME/FILE.png&#39;</span><span class="p">);</span> </span><span id="L-12"><a name="L-12"></a> </span><span id="L-13"><a name="L-13"></a> <span class="c1">// Source: https://drupal.org/node/1427564</span> </span></pre></div> </td></tr></table>
drupal, js, php