Completed
Branch master (e6292e)
by Bobby
01:52
created

HtmlTransformer::buildHtmlLink()   A

Complexity

Conditions 3
Paths 4

Size

Total Lines 18
Code Lines 9

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 11
CRAP Score 3

Importance

Changes 5
Bugs 0 Features 2
Metric Value
c 5
b 0
f 2
dl 0
loc 18
ccs 11
cts 11
cp 1
rs 9.4285
cc 3
eloc 9
nc 4
nop 3
crap 3
1
<?php
2
3
namespace Ballen\Linguist\Transformers;
4
5
use Ballen\Linguist\Transformers\TransformerInitTrait;
6
use Ballen\Linguist\Transformers\TransformerInterface;
7
use Ballen\Linguist\Transformers\Transformer;
8
9
/**
10
 * Linguist
11
 *
12
 * Linguist is a PHP library for parsing strings, it can extract and manipulate
13
 *  prefixed words in content ideal for working with @mentions, #topics and
14
 *  even custom action tags!
15
 *
16
 * @author Bobby Allen <[email protected]>
17
 * @license http://www.gnu.org/licenses/gpl-3.0.html
18
 * @link https://github.com/bobsta63/linguist
19
 * @link http://www.bobbyallen.me
20
 *
21
 */
22
class HtmlTransformer extends Transformer implements TransformerInterface
23
{
24
25
    use TransformerInitTrait;
26
27
    /**
28
     * Transforms the message string.
29
     * @param string $string
30
     * @return void
31
     */
32 4 View Code Duplication
    private function transform($string)
0 ignored issues
show
Unused Code introduced by
This method is not used, and could be removed.
Loading history...
Duplication introduced by
This method seems to be duplicated in your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
33
    {
34
35 4
        $string = preg_replace("/(http|https|ftp|ftps)\:\/\/[a-zA-Z0-9\-\.]+\.[a-zA-Z]{2,3}(\/\S*)?/", "<a href=\"$0\">$0</a> ", $string);
36
37 4
        foreach (array_keys($this->tags) as $tagtype) {
38 4
            $tagconf = $this->tags[$tagtype];
39 4
            $string = preg_replace_callback('/\s+' . $this->tags[$tagtype]['prefix'] . '(\w+)/', function($matches) use ($tagconf) {
40 4
                return ' ' . trim($this->buildHtmlLink($matches[1], trim($matches[0]), $tagconf));
41 4
            }, $string);
42 4
        }
43
44 4
        $this->formatted = $string;
45 4
    }
46
47
    /**
48
     * Builds the HTML link replacement for the HTML transformation.
49
     * @param string $link The URL
50
     * @param string $text The name of the link
51
     * @param array $tag
52
     * @return string
53
     */
54 4
    private function buildHtmlLink($link, $text, $tag)
55
    {
56 4
        $url = sprintf($tag['url'], $link);
57 4
        $html_link = "<a href = \"{$url}\"";
58
59
        // Add the class tag if one is available.
60 4
        if (!is_null($tag['class'])) {
61 2
            $html_link .= " class=\"{$tag['class']}\"";
62 2
        }
63
64
        // Add the target="_blank" attribute if the user requires it!
65 4
        if ($tag['target']) {
66 4
            $html_link .= " target=\"_blank\"";
67 4
        }
68
69 4
        $html_link .= ">{$text}</a>";
70 4
        return $html_link;
71
    }
72
}
73