File indexing completed on 2025-02-09 07:20:14

0001 <?php
0002 /**
0003  * Zend Framework
0004  *
0005  * LICENSE
0006  *
0007  * This source file is subject to the new BSD license that is bundled
0008  * with this package in the file LICENSE.txt.
0009  * It is also available through the world-wide-web at this URL:
0010  * http://framework.zend.com/license/new-bsd
0011  * If you did not receive a copy of the license and are unable to
0012  * obtain it through the world-wide-web, please send an email
0013  * to license@zend.com so we can send you a copy immediately.
0014  *
0015  * @category   Zend
0016  * @package    Zend_Markup
0017  * @subpackage Renderer_Html
0018  * @copyright  Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
0019  * @license    http://framework.zend.com/license/new-bsd     New BSD License
0020  * @version    $Id$
0021  */
0022 
0023 /**
0024  * @see Zend_Markup_Renderer_Html_HtmlAbstract
0025  */
0026 // require_once 'Zend/Markup/Renderer/Html/HtmlAbstract.php';
0027 
0028 /**
0029  * Tag interface
0030  *
0031  * @category   Zend
0032  * @package    Zend_Markup
0033  * @subpackage Renderer_Html
0034  * @copyright  Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
0035  * @license    http://framework.zend.com/license/new-bsd     New BSD License
0036  */
0037 class Zend_Markup_Renderer_Html_List extends Zend_Markup_Renderer_Html_HtmlAbstract
0038 {
0039 
0040     /**
0041      * Convert the token
0042      *
0043      * @param Zend_Markup_Token $token
0044      * @param string $text
0045      *
0046      * @return string
0047      */
0048     public function convert(Zend_Markup_Token $token, $text)
0049     {
0050         $type = null;
0051         if ($token->hasAttribute('list')) {
0052             // because '01' == '1'
0053             if ($token->getAttribute('list') === '01') {
0054                 $type = 'decimal-leading-zero';
0055             } else {
0056                 switch ($token->getAttribute('list')) {
0057                     case '1':
0058                         $type = 'decimal';
0059                         break;
0060                     case 'i':
0061                         $type = 'lower-roman';
0062                         break;
0063                     case 'I':
0064                         $type = 'upper-roman';
0065                         break;
0066                     case 'a':
0067                         $type = 'lower-alpha';
0068                         break;
0069                     case 'A':
0070                         $type = 'upper-alpha';
0071                         break;
0072 
0073                     // the following type is unsupported by IE (including IE8)
0074                     case 'alpha':
0075                         $type = 'lower-greek';
0076                         break;
0077 
0078                     // the CSS names itself
0079                     case 'armenian': // unsupported by IE (including IE8)
0080                     case 'decimal':
0081                     case 'decimal-leading-zero': // unsupported by IE (including IE8)
0082                     case 'georgian': // unsupported by IE (including IE8)
0083                     case 'lower-alpha':
0084                     case 'lower-greek': // unsupported by IE (including IE8)
0085                     case 'lower-latin': // unsupported by IE (including IE8)
0086                     case 'lower-roman':
0087                     case 'upper-alpha':
0088                     case 'upper-latin': // unsupported by IE (including IE8)
0089                     case 'upper-roman':
0090                         $type = $token->getAttribute('list');
0091                         break;
0092                 }
0093             }
0094         }
0095 
0096         if (null !== $type) {
0097             return "<ol style=\"list-style-type: {$type}\">{$text}</ol>";
0098         } else {
0099             return "<ul>{$text}</ul>";
0100         }
0101     }
0102 
0103 }