From 0812ceedde2f89a8e4b391e58d6463f832ecec8e Mon Sep 17 00:00:00 2001 From: Frederic Guillot Date: Sun, 25 Jan 2015 12:23:27 -0500 Subject: Merge fix #545, fix invalid HTML when linking to URLs with numeric fragment identifiers and update Parsedown --- app/Core/Markdown.php | 43 +++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 43 insertions(+) create mode 100644 app/Core/Markdown.php (limited to 'app/Core/Markdown.php') diff --git a/app/Core/Markdown.php b/app/Core/Markdown.php new file mode 100644 index 00000000..3dd98617 --- /dev/null +++ b/app/Core/Markdown.php @@ -0,0 +1,43 @@ +link = $link; + $this->helper = $helper; + $this->InlineTypes['#'][] = 'TaskLink'; + $this->inlineMarkerList .= '#'; + } + + protected function inlineTaskLink($Excerpt) + { + // Replace task #123 by a link to the task + if (! empty($this->link) && preg_match('!#(\d+)!i', $Excerpt['text'], $matches)) { + + $url = $this->helper->u($this->link['controller'], + $this->link['action'], + $this->link['params'] + array('task_id' => $matches[1])); + return array( + 'extent' => strlen($matches[0]), + 'element' => array( + 'name' => 'a', + 'text' => $matches[0], + 'attributes' => array('href' => $url))); + } + } +} -- cgit v1.2.3