cleanup, wip save
This commit is contained in:
parent
01e82fe535
commit
b98a177775
1 changed files with 24 additions and 68 deletions
|
@ -1,11 +1,11 @@
|
||||||
<?php
|
<?php
|
||||||
/*
|
/*
|
||||||
Plugin Name: SyntaxHighlighter
|
Plugin Name: SyntaxHighlighter-NG
|
||||||
Version: 1.0
|
Version: 1.0
|
||||||
Plugin URI: http://flatpress.sf.net
|
Plugin URI: https://git.la10cy.net/DeltaLima/flatpress-plugin-syntaxhighlighter-ng
|
||||||
Description: <a href="http://www.dreamprojections.com/syntaxhighlighter/">dp.SyntaxHighlighter 1.4.0</a> (edited to work with pre, thanks to <a href="https://www.gertthiel.de/blog/archive/2005/11/25/dp-syntaxhighlighter-pre">Gert Thiel </a>)
|
Description: <a href="https://git.la10cy.net/DeltaLima/flatpress-plugin-syntaxhighlighter-ng/">SyntaxHighlighter-NG 1.0.0</a> (forked from <a href="https://forum.flatpress.org/viewtopic.php?p=1130&hilit=syntax+highlight#p1135">Arvid's forum post</a>, using now <a href="https://prismjs.com">prism.js</a>)
|
||||||
Author: NoWhereMan
|
Author: 2005 NoWhereMan, 2023 DeltaLima
|
||||||
Author URI: http://flatpress.sf.net
|
Author URI: https://deltalima.org
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
@ -14,51 +14,11 @@ function plugin_syntaxhighlighter_add($lang=null) {
|
||||||
|
|
||||||
$pdir=plugin_geturl('syntaxhighlighter');
|
$pdir=plugin_geturl('syntaxhighlighter');
|
||||||
|
|
||||||
//if ($lang) {
|
// create array containing the used languages
|
||||||
//~ switch ($lang) {
|
|
||||||
//~ case 'c':
|
|
||||||
//~ case 'cpp':
|
|
||||||
//~ case 'c++':
|
|
||||||
//~ $scripts[] = "<script type=\"text/javascript\" src=\"{$pdir}res/shBrushCpp.js\"></script>\n"; break;
|
|
||||||
//~ case 'css':
|
|
||||||
//~ $scripts[] = "<script type=\"text/javascript\" src=\"{$pdir}res/shBrushCss.js\"></script>\n"; break;
|
|
||||||
//~ case 'c#':
|
|
||||||
//~ case 'c-sharp':
|
|
||||||
//~ case 'csharp':
|
|
||||||
//~ $scripts[] = "<script type=\"text/javascript\" src=\"{$pdir}res/shBrushCSharp.js\"></script>\n"; break;
|
|
||||||
//~ case 'vb':
|
|
||||||
//~ case 'vb.net':
|
|
||||||
//~ $scripts[] = "<script type=\"text/javascript\" src=\"{$pdir}res/shBrushVb.js\"></script>\n"; break;
|
|
||||||
//~ case 'delphi':
|
|
||||||
//~ case 'pascal':
|
|
||||||
//~ $scripts[] = "<script type=\"text/javascript\" src=\"{$pdir}res/shBrushDelphi.js\"></script>\n"; break;
|
|
||||||
|
|
||||||
//~ case 'js':
|
|
||||||
//~ case 'jscript':
|
|
||||||
//~ case 'javascript':
|
|
||||||
//~ $scripts[] = "<script type=\"text/javascript\" src=\"{$pdir}res/shBrushJScript.js\"></script>\n"; break;
|
|
||||||
//~ case 'php':
|
|
||||||
//~ $scripts[] = "<script type=\"text/javascript\" src=\"{$pdir}res/shBrushPhp.js\"></script>\n"; break;
|
|
||||||
//~ case 'py':
|
|
||||||
//~ case 'python':
|
|
||||||
//~ $scripts[] = "<script type=\"text/javascript\" src=\"{$pdir}res/shBrushPython.js\"></script>\n"; break;
|
|
||||||
//~ case 'ruby':
|
|
||||||
//~ $scripts[] = "<script type=\"text/javascript\" src=\"{$pdir}res/shBrushRuby.js\"></script>\n"; break;
|
|
||||||
//~ case 'sql':
|
|
||||||
//~ $scripts[] = "<script type=\"text/javascript\" src=\"{$pdir}res/shBrushSql.js\"></script>\n"; break;
|
|
||||||
//~ case 'xml':
|
|
||||||
//~ case 'xhtml':
|
|
||||||
//~ case 'xslt':
|
|
||||||
//~ case 'html':
|
|
||||||
//~ case 'xhtml':
|
|
||||||
//~ "<script type=\"text/javascript\" src=\"{$pdir}res/shBrushXml.js\"></script>\n";
|
|
||||||
|
|
||||||
//~ }
|
|
||||||
$languages[] = "{$lang}";
|
$languages[] = "{$lang}";
|
||||||
|
// remove unique
|
||||||
$languages = array_unique($languages);
|
$languages = array_unique($languages);
|
||||||
|
|
||||||
//}
|
|
||||||
//return $scripts;
|
|
||||||
return $languages;
|
return $languages;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -66,14 +26,13 @@ function plugin_syntaxhighlighter_add($lang=null) {
|
||||||
|
|
||||||
function plugin_syntaxhighlighter_head() {
|
function plugin_syntaxhighlighter_head() {
|
||||||
$pdir=plugin_geturl('syntaxhighlighter');
|
$pdir=plugin_geturl('syntaxhighlighter');
|
||||||
echo <<<SHL
|
echo <<<PRISMJS
|
||||||
<!-- start of SHL -->
|
<!-- start of prism.js -->
|
||||||
|
|
||||||
<!-- <link rel="stylesheet" type="text/css" href="{$pdir}res/SyntaxHighlighter.css" /> -->
|
|
||||||
<link rel="stylesheet" type="text/css" href="{$pdir}res/prism.css" />
|
<link rel="stylesheet" type="text/css" href="{$pdir}res/prism.css" />
|
||||||
|
|
||||||
<!-- end of SHL -->
|
<!-- end of prism.js -->
|
||||||
SHL;
|
PRISMJS;
|
||||||
|
|
||||||
}
|
}
|
||||||
add_action('wp_head', 'plugin_syntaxhighlighter_head');
|
add_action('wp_head', 'plugin_syntaxhighlighter_head');
|
||||||
|
@ -81,25 +40,22 @@ add_action('wp_head', 'plugin_syntaxhighlighter_head');
|
||||||
|
|
||||||
function plugin_syntaxhighlighter_foot() {
|
function plugin_syntaxhighlighter_foot() {
|
||||||
|
|
||||||
//$used_languages = implode(plugin_syntaxhighlighter_add(), "\n");
|
// convert the returned array into an json one, to have an easier time
|
||||||
|
// giving it to the javascript below
|
||||||
$used_languages = json_encode(plugin_syntaxhighlighter_add());
|
$used_languages = json_encode(plugin_syntaxhighlighter_add());
|
||||||
|
|
||||||
$pdir=plugin_geturl('syntaxhighlighter');
|
$pdir=plugin_geturl('syntaxhighlighter');
|
||||||
echo <<<SHLBOX
|
// javascript part
|
||||||
<!-- start of SHL -->
|
echo <<<PRISMBOX
|
||||||
<!-- <script type="text/javascript" src="{$pdir}res/shCore.js"></script> -->
|
<!-- start of prism.js -->
|
||||||
<!-- 1337ASD $used_languages-->
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<!-- <script type="text/javascript">
|
|
||||||
dp.SyntaxHighlighter.HighlightAll('code');
|
|
||||||
</script> -->
|
|
||||||
|
|
||||||
<script type="text/javascript" src="{$pdir}res/prism.js"></script>
|
<script type="text/javascript" src="{$pdir}res/prism.js"></script>
|
||||||
|
|
||||||
|
<!-- wrapping the content of pre html-tags into code-tags, as said in https://prismjs.com/index.html#basic-usage -->
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
// wrap the content of <pre> elements into <code></code> for prismjs
|
// wrap the content of <pre> elements into <code></code> for prismjs
|
||||||
|
|
||||||
// get an array of pre elements
|
// get an array of <pre></pre> elements
|
||||||
//var preEl = document.getElementsByTagName("pre");
|
//var preEl = document.getElementsByTagName("pre");
|
||||||
|
|
||||||
// split used_languages list into array
|
// split used_languages list into array
|
||||||
|
@ -107,17 +63,17 @@ function plugin_syntaxhighlighter_foot() {
|
||||||
|
|
||||||
for (let iUl = 0;iUl < used_languages.length; iUl++)
|
for (let iUl = 0;iUl < used_languages.length; iUl++)
|
||||||
{
|
{
|
||||||
// do nothing on empty elements
|
// do nothing on empty element
|
||||||
if ( used_languages[iUl] != "" )
|
if ( used_languages[iUl] != "" )
|
||||||
{
|
{
|
||||||
alert(used_languages[iUl]);
|
// get all <pre> elements with certain language
|
||||||
let preElements = document.querySelectorAll("pre." + used_languages[iUl]);
|
let preElements = document.querySelectorAll("pre." + used_languages[iUl]);
|
||||||
|
|
||||||
for (let iEl = 0;iEl < preElements.length; iEl++)
|
for (let iEl = 0;iEl < preElements.length; iEl++)
|
||||||
{
|
{
|
||||||
org_html = preElements[iEl].innerHTML;
|
org_html = preElements[iEl].innerHTML;
|
||||||
new_html = "<code class=\"language-" + used_languages[iUl] + "\">" + org_html + "</code>";
|
new_html = "<code class=\"language-" + used_languages[iUl] + "\">" + org_html + "</code>";
|
||||||
alert(new_html);
|
|
||||||
preElements[iEl].innerHTML = new_html;
|
preElements[iEl].innerHTML = new_html;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -139,7 +95,7 @@ function plugin_syntaxhighlighter_foot() {
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<!-- end of SHL -->
|
<!-- end of SHL -->
|
||||||
SHLBOX;
|
PRISMBOX;
|
||||||
}
|
}
|
||||||
add_action('wp_footer', 'plugin_syntaxhighlighter_foot');
|
add_action('wp_footer', 'plugin_syntaxhighlighter_foot');
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue