text * * @param string $href the link url. * @param string $title the link title. * @param string $misc other params. * @param string $newline * @static * @access public * @return string */ static public function a($href = '', $title = '', $target = "_self", $misc = '', $newline = true) { if(empty($target)) $target = '_self'; if($target != '_self') $misc .= " target='$target'"; if($target == '_blank') $misc .= " rel='noopener noreferrer'"; return parent::a($href, $title, $misc, $newline); } /** * 生成input输入标签。 * Create tags like "" * * @param string $name the name of the text input tag. * @param string $value the default value. * @param string $attrib other attribs. * @static * @access public * @return string */ static public function input($name, $value = "", $attrib = "", $autocomplete = false) { $id = "id='$name'"; if(strpos($attrib, 'id=') !== false) $id = ''; $value = str_replace("'", ''', $value); $autocomplete = $autocomplete ? 'autocomplete="on"' : 'autocomplete="off"'; return "\n"; } /** * 生成多选按钮。 * Create tags like "" * * @param string $name the name of the checkbox tag. * @param array $options the array to create checkbox tag from. * @param string $checked the value to checked by default, can be item1,item2 * @param string $attrib other attribs. * @param string $type inline or block * @static * @access public * @return string */ static public function checkbox($name, $options, $checked = "", $attrib = "", $type = 'block') { $options = (array)($options); if(!is_array($options) or empty($options)) return false; if(is_array($checked)) $checked = implode(',', $checked); $string = ''; $checked = ",$checked,"; $isBlock = $type == 'block'; foreach($options as $key => $value) { if($isBlock) $string .= "
"; else $string .= "
"; $string .= "
'; } return $string; } /** * 创建提交按钮。 * Create submit button. * * @param string $label the label of the button * @param string $class the class of the button * @param string $misc other params * @static * @access public * @return string the submit button tag. */ public static function submitButton($label = '', $misc = '', $class = 'btn btn-wide btn-primary') { return parent::submitButton($label, $class, $misc); } public static function commonButton($label = '', $misc = '', $class = 'btn', $icon = '') { return parent::commonButton($label, $class, $misc, $icon); } public static function linkButton($label = '', $link = '', $target = 'self', $misc = '', $class = 'btn') { return parent::linkButton($label, $link, $class, $misc, $target); } /** * 创建全选checkbox。 * Create select buttons include 'selectAll' and 'selectReverse'. * * @param string $scope the scope of select reverse. * @param bool $asGroup * @param string $appendClass * @static * @access public * @return string */ static public function selectButton($scope = "", $asGroup = true, $appendClass = 'btn') { global $lang; return "
"; } /** * 生成select标签。 * Create tags like "" * * @param string $name the name of the select tag. * @param array $options the array to create select tag from. * @param string $selectedItems the item(s) to be selected, can like item1,item2. * @param string $attrib other params such as multiple, size and style. * @param string $append adjust if add options[$selectedItems]. * @static * @access public * @return string */ static public function select($name = '', $options = array(), $selectedItems = "", $attrib = "", $append = false) { $options = (array)($options); if($append and !isset($options[$selectedItems])) $options[$selectedItems] = $selectedItems; /* The begin. */ $id = $name; if(strpos($name, '[') !== false) $id = trim(str_replace(']', '', str_replace('[', '', $name))); $id = "id='{$id}'"; if(strpos($attrib, 'id=') !== false) $id = ''; global $config; $convertedPinYin = (empty($config->isINT) and class_exists('common')) ? common::convert2Pinyin($options) : array(); if(count($options) >= $config->maxCount or isset($config->moreLinks[$name])) { if(strpos($attrib, 'chosen') !== false) $attrib = str_replace('chosen', 'picker-select', $attrib); if(isset($config->moreLinks[$name])) { $link = $config->moreLinks[$name]; $attrib .= " data-pickertype='remote' data-pickerremote='" . $link . "'"; } } $string = "\n"; } /** * Create input tag that type is number. * * @param string $name * @param string $value * @param string $attrib * @static * @access public * @return string */ static public function number($name, $value = '', $attrib = '') { $id = "id='$name'"; if(strpos($attrib, 'id=') !== false) $id = ''; $value = str_replace("'", ''', $value); return "\n"; } /** * Convert a string to a uni code * * @param string $string * @return int */ static public function stringToCode($string) { $stringLength = strlen($string); if($stringLength == 0) return 0; $code = 0; for($i = 0; $i < $stringLength; ++ $i) $code += ($i + 1) * ord($string[$i]); return $code; } /** * Create user avatar. * * @param string|object|array $user User object or user account * @param string|int $size Avatar size, can be a number or preset sizes: "xs", "sm", "", "lg", "xl", default is "" * @param string $className Avatar element class name, default is "avatar-circle" * @param string $attrib Extra attributes on avatar element * @param string $tag Avatar element tag name, default is "div" * @param string $hueDistance Hue distance used as background color for default avatar * @param string $saturation Saturation used as background color for default avatar * @param string $lightness Lightness used as background color for default avatar * @static * @access public * @return string */ static public function avatar($user, $size = '', $className = 'avatar-circle', $attrib = '', $tag = 'div', $hueDistance = 43, $saturation = '40%', $lightness = '60%') { $userObj = new stdClass(); if(is_string($user)) { $userObj->account = $user; $user = $userObj; } elseif(is_array($user)) { $userObj->avatar = $user['avatar']; $userObj->account = $user['account']; $user = $userObj; } $hasImage = !empty($user->avatar); $extraClassName = $hasImage ? ' has-img' : ' has-text'; $style = ''; if($size) { if(is_numeric($size)) $style .= "width: $size" . "px; height: $size" . "px; line-height: $size" . 'px;'; $extraClassName .= " avatar-$size"; } if(!$hasImage) { $colorHue = (html::stringToCode($user->account) * $hueDistance) % 360; $style .= "background: hsl($colorHue, $saturation, $lightness);"; if(is_numeric($size)) $style .= 'font-size: ' . round($size * 2 / 3) . 'px;'; } if(!empty($style)) $style = "style='$style'"; $html = "<$tag class='avatar$extraClassName $className' $attrib $style>"; $html .= $hasImage ? html::image($user->avatar) : '' . strtoupper($user->account[0]) . ''; $html .= ""; return $html; } /** * Create a small user avatar. * * @param string|object $user User object or user avatar url or user account * @param string $className Avatar element class name, default is "avatar-circle" * @param string $attrib Extra attributes on avatar element * @param string $tag Avatar element tag name, default is "div" * @static * @access public * @return string */ static public function smallAvatar($user, $className = 'avatar-circle', $attrib = '', $tag = 'div') { return html::avatar($user, 'sm', $className, $attrib, $tag); } /** * Create a large user avatar. * * @param string|object $user User object or user avatar url or user account * @param string $className Avatar element class name, default is "avatar-circle" * @param string $attrib Extra attributes on avatar element * @param string $tag Avatar element tag name, default is "div" * @static * @access public * @return string */ static public function largeAvatar($user, $className = 'avatar-circle', $attrib = '', $tag = 'div') { return html::avatar($user, 'lg', $className, $attrib, $tag); } } /** * JS类。 * JS class. * * @package front */ class js extends baseJS { } /** * css类。 * css class. * * @package front */ class css extends baseCSS { }