summaryrefslogtreecommitdiffstats
path: root/plugins/55/wrap/syntax
diff options
context:
space:
mode:
Diffstat (limited to 'plugins/55/wrap/syntax')
-rw-r--r--plugins/55/wrap/syntax/closesection.php35
-rw-r--r--plugins/55/wrap/syntax/div.php134
-rw-r--r--plugins/55/wrap/syntax/divblock.php19
-rw-r--r--plugins/55/wrap/syntax/divwrap.php18
-rw-r--r--plugins/55/wrap/syntax/span.php100
-rw-r--r--plugins/55/wrap/syntax/spaninline.php18
-rw-r--r--plugins/55/wrap/syntax/spanwrap.php19
7 files changed, 343 insertions, 0 deletions
diff --git a/plugins/55/wrap/syntax/closesection.php b/plugins/55/wrap/syntax/closesection.php
new file mode 100644
index 0000000..6e87481
--- /dev/null
+++ b/plugins/55/wrap/syntax/closesection.php
@@ -0,0 +1,35 @@
+<?php
+/**
+ * Section close helper of the Wrap Plugin
+ *
+ * @license GPL 2 (http://www.gnu.org/licenses/gpl.html)
+ * @author Michael Hamann <michael@content-space.de>
+ */
+
+class syntax_plugin_wrap_closesection extends DokuWiki_Syntax_Plugin {
+
+ function getType(){ return 'substition';}
+ function getPType(){ return 'block';}
+ function getSort(){ return 195; }
+
+ /**
+ * Dummy handler, this syntax part has no syntax but is directly added to the instructions by the div syntax
+ */
+ function handle($match, $state, $pos, Doku_Handler $handler){
+ }
+
+ /**
+ * Create output
+ */
+ function render($format, Doku_Renderer $renderer, $data) {
+ if($format == 'xhtml'){
+ /** @var Doku_Renderer_xhtml $renderer */
+ $renderer->finishSectionEdit();
+ return true;
+ }
+ return false;
+ }
+
+
+}
+
diff --git a/plugins/55/wrap/syntax/div.php b/plugins/55/wrap/syntax/div.php
new file mode 100644
index 0000000..7bec01e
--- /dev/null
+++ b/plugins/55/wrap/syntax/div.php
@@ -0,0 +1,134 @@
+<?php
+/**
+ * Div Syntax Component of the Wrap Plugin
+ *
+ * @license GPL 2 (http://www.gnu.org/licenses/gpl.html)
+ * @author Anika Henke <anika@selfthinker.org>
+ */
+
+class syntax_plugin_wrap_div extends DokuWiki_Syntax_Plugin {
+ protected $special_pattern = '<div\b[^>\r\n]*?/>';
+ protected $entry_pattern = '<div\b.*?>(?=.*?</div>)';
+ protected $exit_pattern = '</div>';
+
+ function getType(){ return 'formatting';}
+ function getAllowedTypes() { return array('container', 'formatting', 'substition', 'protected', 'disabled', 'paragraphs'); }
+ function getPType(){ return 'stack';}
+ function getSort(){ return 195; }
+ // override default accepts() method to allow nesting - ie, to get the plugin accepts its own entry syntax
+ function accepts($mode) {
+ if ($mode == substr(get_class($this), 7)) return true;
+ return parent::accepts($mode);
+ }
+
+ /**
+ * Connect pattern to lexer
+ */
+ function connectTo($mode) {
+ $this->Lexer->addSpecialPattern($this->special_pattern,$mode,'plugin_wrap_'.$this->getPluginComponent());
+ $this->Lexer->addEntryPattern($this->entry_pattern,$mode,'plugin_wrap_'.$this->getPluginComponent());
+ }
+
+ function postConnect() {
+ $this->Lexer->addExitPattern($this->exit_pattern, 'plugin_wrap_'.$this->getPluginComponent());
+ $this->Lexer->addPattern('[ \t]*={2,}[^\n]+={2,}[ \t]*(?=\n)', 'plugin_wrap_'.$this->getPluginComponent());
+ }
+
+ /**
+ * Handle the match
+ */
+ function handle($match, $state, $pos, Doku_Handler $handler){
+ global $conf;
+ switch ($state) {
+ case DOKU_LEXER_ENTER:
+ case DOKU_LEXER_SPECIAL:
+ $data = strtolower(trim(substr($match,strpos($match,' '),-1)," \t\n/"));
+ return array($state, $data);
+
+ case DOKU_LEXER_UNMATCHED:
+ $handler->addCall('cdata', array($match), $pos);
+ break;
+
+ case DOKU_LEXER_MATCHED:
+ // we have a == header ==, use the core header() renderer
+ // (copied from core header() in inc/parser/handler.php)
+ $title = trim($match);
+ $level = 7 - strspn($title,'=');
+ if($level < 1) $level = 1;
+ $title = trim($title,'=');
+ $title = trim($title);
+
+ $handler->addCall('header',array($title,$level,$pos), $pos);
+ // close the section edit the header could open
+ if ($title && $level <= $conf['maxseclevel']) {
+ $handler->addPluginCall('wrap_closesection', array(), DOKU_LEXER_SPECIAL, $pos, '');
+ }
+ break;
+
+ case DOKU_LEXER_EXIT:
+ return array($state, '');
+ }
+ return false;
+ }
+
+ /**
+ * Create output
+ */
+ function render($format, Doku_Renderer $renderer, $indata) {
+ static $type_stack = array ();
+
+ if (empty($indata)) return false;
+ list($state, $data) = $indata;
+
+ if($format == 'xhtml'){
+ /** @var Doku_Renderer_xhtml $renderer */
+ switch ($state) {
+ case DOKU_LEXER_ENTER:
+ $sectionEditStartData = ['target' => 'plugin_wrap_start', 'hid' => ''];
+ $sectionEditEndData = ['target' =>'plugin_wrap_end', 'hid' => ''];
+ if (!defined('SEC_EDIT_PATTERN')) {
+ // backwards-compatibility for Frusterick Manners (2017-02-19)
+ $sectionEditStartData = 'plugin_wrap_start';
+ $sectionEditEndData = 'plugin_wrap_end';
+ }
+ // add a section edit right at the beginning of the wrap output
+ $renderer->startSectionEdit(0, $sectionEditStartData);
+ $renderer->finishSectionEdit();
+ // add a section edit for the end of the wrap output. This prevents the renderer
+ // from closing the last section edit so the next section button after the wrap syntax will
+ // include the whole wrap syntax
+ $renderer->startSectionEdit(0, $sectionEditEndData);
+
+ case DOKU_LEXER_SPECIAL:
+ $wrap = $this->loadHelper('wrap');
+ $attr = $wrap->buildAttributes($data, 'plugin_wrap');
+
+ $renderer->doc .= '<div'.$attr.'>';
+ if ($state == DOKU_LEXER_SPECIAL) $renderer->doc .= '</div>';
+ break;
+
+ case DOKU_LEXER_EXIT:
+ $renderer->doc .= '</div>';
+ $renderer->finishSectionEdit();
+ break;
+ }
+ return true;
+ }
+ if($format == 'odt'){
+ switch ($state) {
+ case DOKU_LEXER_ENTER:
+ $wrap = plugin_load('helper', 'wrap');
+ array_push ($type_stack, $wrap->renderODTElementOpen($renderer, 'div', $data));
+ break;
+
+ case DOKU_LEXER_EXIT:
+ $element = array_pop ($type_stack);
+ $wrap = plugin_load('helper', 'wrap');
+ $wrap->renderODTElementClose ($renderer, $element);
+ break;
+ }
+ return true;
+ }
+ return false;
+ }
+}
diff --git a/plugins/55/wrap/syntax/divblock.php b/plugins/55/wrap/syntax/divblock.php
new file mode 100644
index 0000000..e5da725
--- /dev/null
+++ b/plugins/55/wrap/syntax/divblock.php
@@ -0,0 +1,19 @@
+<?php
+/**
+ * Alternate div syntax component for the wrap plugin
+ *
+ * Defines <block> ... </block> syntax
+ *
+ * @license GPL 2 (http://www.gnu.org/licenses/gpl.html)
+ * @author Anika Henke <anika@selfthinker.org>
+ */
+
+class syntax_plugin_wrap_divblock extends syntax_plugin_wrap_div {
+
+ protected $special_pattern = '<block\b[^>\r\n]*?/>';
+ protected $entry_pattern = '<block\b.*?>(?=.*?</block>)';
+ protected $exit_pattern = '</block>';
+
+
+}
+
diff --git a/plugins/55/wrap/syntax/divwrap.php b/plugins/55/wrap/syntax/divwrap.php
new file mode 100644
index 0000000..7aa88ae
--- /dev/null
+++ b/plugins/55/wrap/syntax/divwrap.php
@@ -0,0 +1,18 @@
+<?php
+/**
+ * Alternate div syntax component for the wrap plugin
+ *
+ * Defines <WRAP> ... </WRAP> syntax
+ *
+ * @license GPL 2 (http://www.gnu.org/licenses/gpl.html)
+ * @author Anika Henke <anika@selfthinker.org>
+ */
+
+class syntax_plugin_wrap_divwrap extends syntax_plugin_wrap_div {
+
+ protected $special_pattern = '<WRAP\b[^>\r\n]*?/>';
+ protected $entry_pattern = '<WRAP\b.*?>(?=.*?</WRAP>)';
+ protected $exit_pattern = '</WRAP>';
+
+}
+
diff --git a/plugins/55/wrap/syntax/span.php b/plugins/55/wrap/syntax/span.php
new file mode 100644
index 0000000..ac75713
--- /dev/null
+++ b/plugins/55/wrap/syntax/span.php
@@ -0,0 +1,100 @@
+<?php
+/**
+ * Span Syntax Component of the Wrap Plugin
+ *
+ * @license GPL 2 (http://www.gnu.org/licenses/gpl.html)
+ * @author Anika Henke <anika@selfthinker.org>
+ */
+
+class syntax_plugin_wrap_span extends DokuWiki_Syntax_Plugin {
+ protected $special_pattern = '<span\b[^>\r\n]*?/>';
+ protected $entry_pattern = '<span\b.*?>(?=.*?</span>)';
+ protected $exit_pattern = '</span>';
+
+ function getType(){ return 'formatting';}
+ function getAllowedTypes() { return array('formatting', 'substition', 'disabled'); }
+ function getPType(){ return 'normal';}
+ function getSort(){ return 195; }
+ // override default accepts() method to allow nesting - ie, to get the plugin accepts its own entry syntax
+ function accepts($mode) {
+ if ($mode == substr(get_class($this), 7)) return true;
+ return parent::accepts($mode);
+ }
+
+ /**
+ * Connect pattern to lexer
+ */
+ function connectTo($mode) {
+ $this->Lexer->addSpecialPattern($this->special_pattern,$mode,'plugin_wrap_'.$this->getPluginComponent());
+ $this->Lexer->addEntryPattern($this->entry_pattern,$mode,'plugin_wrap_'.$this->getPluginComponent());
+ }
+
+ function postConnect() {
+ $this->Lexer->addExitPattern($this->exit_pattern, 'plugin_wrap_'.$this->getPluginComponent());
+ }
+
+ /**
+ * Handle the match
+ */
+ function handle($match, $state, $pos, Doku_Handler $handler){
+ switch ($state) {
+ case DOKU_LEXER_ENTER:
+ case DOKU_LEXER_SPECIAL:
+ $data = strtolower(trim(substr($match,strpos($match,' '),-1)," \t\n/"));
+ return array($state, $data);
+
+ case DOKU_LEXER_UNMATCHED :
+ $handler->addCall('cdata', array($match), $pos);
+ return false;
+
+ case DOKU_LEXER_EXIT :
+ return array($state, '');
+
+ }
+ return false;
+ }
+
+ /**
+ * Create output
+ */
+ function render($format, Doku_Renderer $renderer, $indata) {
+ static $type_stack = array ();
+
+ if (empty($indata)) return false;
+ list($state, $data) = $indata;
+
+ if($format == 'xhtml'){
+ switch ($state) {
+ case DOKU_LEXER_ENTER:
+ case DOKU_LEXER_SPECIAL:
+ $wrap = $this->loadHelper('wrap');
+ $attr = $wrap->buildAttributes($data);
+
+ $renderer->doc .= '<span'.$attr.'>';
+ if ($state == DOKU_LEXER_SPECIAL) $renderer->doc .= '</span>';
+ break;
+
+ case DOKU_LEXER_EXIT:
+ $renderer->doc .= '</span>';
+ break;
+ }
+ return true;
+ }
+ if($format == 'odt'){
+ switch ($state) {
+ case DOKU_LEXER_ENTER:
+ $wrap = plugin_load('helper', 'wrap');
+ array_push ($type_stack, $wrap->renderODTElementOpen($renderer, 'span', $data));
+ break;
+
+ case DOKU_LEXER_EXIT:
+ $element = array_pop ($type_stack);
+ $wrap = plugin_load('helper', 'wrap');
+ $wrap->renderODTElementClose ($renderer, $element);
+ break;
+ }
+ return true;
+ }
+ return false;
+ }
+}
diff --git a/plugins/55/wrap/syntax/spaninline.php b/plugins/55/wrap/syntax/spaninline.php
new file mode 100644
index 0000000..977ec49
--- /dev/null
+++ b/plugins/55/wrap/syntax/spaninline.php
@@ -0,0 +1,18 @@
+<?php
+/**
+ * Alternate span syntax component for the wrap plugin
+ *
+ * Defines <inline> ... </inline> syntax
+ *
+ * @license GPL 2 (http://www.gnu.org/licenses/gpl.html)
+ * @author Anika Henke <anika@selfthinker.org>
+ */
+
+class syntax_plugin_wrap_spaninline extends syntax_plugin_wrap_span {
+
+ protected $special_pattern = '<inline\b[^>\r\n]*?/>';
+ protected $entry_pattern = '<inline\b.*?>(?=.*?</inline>)';
+ protected $exit_pattern = '</inline>';
+
+}
+
diff --git a/plugins/55/wrap/syntax/spanwrap.php b/plugins/55/wrap/syntax/spanwrap.php
new file mode 100644
index 0000000..054d299
--- /dev/null
+++ b/plugins/55/wrap/syntax/spanwrap.php
@@ -0,0 +1,19 @@
+<?php
+/**
+ * Alternate span syntax component for the wrap plugin
+ *
+ * Defines <wrap> ... </wrap> syntax
+ *
+ * @license GPL 2 (http://www.gnu.org/licenses/gpl.html)
+ * @author Anika Henke <anika@selfthinker.org>
+ */
+
+class syntax_plugin_wrap_spanwrap extends syntax_plugin_wrap_span {
+
+ protected $special_pattern = '<wrap\b[^>\r\n]*?/>';
+ protected $entry_pattern = '<wrap\b.*?>(?=.*?</wrap>)';
+ protected $exit_pattern = '</wrap>';
+
+
+}
+