Url.php 3.97 KB
Newer Older
zYne's avatar
zYne committed
1 2 3 4 5 6 7 8 9 10 11
<?php
// vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4:
/**
 * Url rule end renderer for Xhtml
 *
 * PHP versions 4 and 5
 *
 * @category   Text
 * @package    Text_Wiki
 * @author     Paul M. Jones <pmjones@php.net>
 * @license    http://www.gnu.org/copyleft/lesser.html  LGPL License 2.1
12
 * @version    CVS: $Id: Url.php,v 1.18 2007/05/26 17:15:41 mic Exp $
zYne's avatar
zYne committed
13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75
 * @link       http://pear.php.net/package/Text_Wiki
 */

/**
 * This class renders URL links in XHTML.
 *
 * @category   Text
 * @package    Text_Wiki
 * @author     Paul M. Jones <pmjones@php.net>
 * @license    http://www.gnu.org/copyleft/lesser.html  LGPL License 2.1
 * @version    Release: @package_version@
 * @link       http://pear.php.net/package/Text_Wiki
 */
class Text_Wiki_Render_Xhtml_Url extends Text_Wiki_Render {


    var $conf = array(
        'target' => '_blank',
        'images' => true,
        'img_ext' => array('jpg', 'jpeg', 'gif', 'png'),
        'css_inline' => null,
        'css_footnote' => null,
        'css_descr' => null,
        'css_img' => null
    );

    /**
    *
    * Renders a token into text matching the requested format.
    *
    * @access public
    *
    * @param array $options The "options" portion of the token (second
    * element).
    *
    * @return string The text rendered from the token options.
    *
    */

    function token($options)
    {
        // create local variables from the options array (text,
        // href, type)
        extract($options);

        // find the rightmost dot and determine the filename
        // extension.
        $pos = strrpos($href, '.');
        $ext = strtolower(substr($href, $pos + 1));
        $href = $this->textEncode($href);

        // does the filename extension indicate an image file?
        if ($this->getConf('images') &&
            in_array($ext, $this->getConf('img_ext', array()))) {

            // create alt text for the image
            if (! isset($text) || $text == '') {
                $text = basename($href);
                $text = $this->textEncode($text);
            }

            // generate an image tag
            $css = $this->formatConf(' class="%s"', 'css_img');
76 77
            $start = "<img$css src=\"$href\" alt=\"$text\" title=\"$text\" /><!-- ";
            $end = " -->";
zYne's avatar
zYne committed
78 79 80 81 82

        } else {

            // should we build a target clause?
            if ($href{0} == '#' ||
83 84 85
              strtolower(substr($href, 0, 7)) == 'mailto:') {
              // targets not allowed for on-page anchors
              // and mailto: links.
zYne's avatar
zYne committed
86 87
                $target = '';
            } else {
88
        // allow targets on non-anchor non-mailto links
zYne's avatar
zYne committed
89 90 91 92 93 94
                $target = $this->getConf('target');
            }

            // generate a regular link (not an image)
            $text = $this->textEncode($text);
            $css = $this->formatConf(' class="%s"', "css_$type");
95
            $start = "<a$css href=\"$href\"";
zYne's avatar
zYne committed
96

97
            if ($target && $target != '_self') {
zYne's avatar
zYne committed
98 99 100
                // use a "popup" window.  this is XHTML compliant, suggested by
                // Aaron Kalin.  uses the $target as the new window name.
                $target = $this->textEncode($target);
101 102 103 104 105 106
                $start .= " onclick=\"window.open(this.href, '$target');";
                $start .= " return false;\"";
            }
            
            if (isset($name)) {
                $start .= " id=\"$name\"";
zYne's avatar
zYne committed
107 108 109
            }

            // finish up output
110 111
            $start .= ">";
            $end = "</a>";
zYne's avatar
zYne committed
112 113 114 115

            // make numbered references look like footnotes when no
            // CSS class specified, make them superscript by default
            if ($type == 'footnote' && ! $css) {
116 117
                $start = '<sup>' . $start;
                $end = $end . '</sup>';
zYne's avatar
zYne committed
118 119 120
            }
        }

121 122 123 124 125 126 127
        if ($options['type'] == 'start') {
            $output = $start;
        } else if ($options['type'] == 'end') {
            $output = $end;
        } else {
            $output = $start . $text . $end;
        }
zYne's avatar
zYne committed
128 129 130 131
        return $output;
    }
}
?>