mirror of
				https://github.com/Icinga/icingaweb2.git
				synced 2025-10-26 17:04:15 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			216 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			216 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /* Icinga Web 2 | (c) 2015 Icinga Development Team | GPLv2+ */
 | |
| 
 | |
| namespace Icinga\Module\Doc\Search;
 | |
| 
 | |
| use UnexpectedValueException;
 | |
| use Icinga\Application\Icinga;
 | |
| use Icinga\Web\View;
 | |
| 
 | |
| /**
 | |
|  * A doc search match
 | |
|  */
 | |
| class DocSearchMatch
 | |
| {
 | |
|     /**
 | |
|      * CSS class for highlighting matches
 | |
|      *
 | |
|      * @var string
 | |
|      */
 | |
|     const HIGHLIGHT_CSS_CLASS = 'search-highlight';
 | |
| 
 | |
|     /**
 | |
|      * Header match
 | |
|      *
 | |
|      * @var int
 | |
|      */
 | |
|     const MATCH_HEADER = 1;
 | |
| 
 | |
|     /**
 | |
|      * Content match
 | |
|      *
 | |
|      * @var int
 | |
|      */
 | |
|     const MATCH_CONTENT = 2;
 | |
| 
 | |
|     /**
 | |
|      * Line
 | |
|      *
 | |
|      * @var string
 | |
|      */
 | |
|     protected $line;
 | |
| 
 | |
|     /**
 | |
|      * Line number
 | |
|      *
 | |
|      * @var int
 | |
|      */
 | |
|     protected $lineno;
 | |
| 
 | |
|     /**
 | |
|      * Type of the match
 | |
|      *
 | |
|      * @var int
 | |
|      */
 | |
|     protected $matchType;
 | |
| 
 | |
|     /**
 | |
|      * Matches
 | |
|      *
 | |
|      * @var array
 | |
|      */
 | |
|     protected $matches = array();
 | |
| 
 | |
|     /**
 | |
|      * View
 | |
|      *
 | |
|      * @var View|null
 | |
|      */
 | |
|     protected $view;
 | |
| 
 | |
|     /**
 | |
|      * Set the line
 | |
|      *
 | |
|      * @param   string  $line
 | |
|      *
 | |
|      * @return  $this
 | |
|      */
 | |
|     public function setLine($line)
 | |
|     {
 | |
|         $this->line = (string) $line;
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get the line
 | |
|      *
 | |
|      * @return string
 | |
|      */
 | |
|     public function getLine()
 | |
|     {
 | |
|         return $this->line;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Set the line number
 | |
|      *
 | |
|      * @param   int $lineno
 | |
|      *
 | |
|      * @return  $this
 | |
|      */
 | |
|     public function setLineno($lineno)
 | |
|     {
 | |
|         $this->lineno = (int) $lineno;
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Set the match type
 | |
|      *
 | |
|      * @param   int $matchType
 | |
|      *
 | |
|      * @return  $this
 | |
|      */
 | |
|     public function setMatchType($matchType)
 | |
|     {
 | |
|         $matchType = (int) $matchType;
 | |
|         if ($matchType !== static::MATCH_HEADER && $matchType !== static::MATCH_CONTENT) {
 | |
|             throw new UnexpectedValueException();
 | |
|         }
 | |
|         $this->matchType = $matchType;
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get the match type
 | |
|      *
 | |
|      * @return int
 | |
|      */
 | |
|     public function getMatchType()
 | |
|     {
 | |
|         return $this->matchType;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Append a match
 | |
|      *
 | |
|      * @param   string  $match
 | |
|      * @param   int     $position
 | |
|      *
 | |
|      * @return  $this
 | |
|      */
 | |
|     public function appendMatch($match, $position)
 | |
|     {
 | |
|         $this->matches[(int) $position] = (string) $match;
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get the matches
 | |
|      *
 | |
|      * @return array
 | |
|      */
 | |
|     public function getMatches()
 | |
|     {
 | |
|         return $this->matches;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Set the view
 | |
|      *
 | |
|      * @param   View    $view
 | |
|      *
 | |
|      * @return  $this
 | |
|      */
 | |
|     public function setView(View $view)
 | |
|     {
 | |
|         $this->view = $view;
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get the view
 | |
|      *
 | |
|      * @return View
 | |
|      */
 | |
|     public function getView()
 | |
|     {
 | |
|         if ($this->view === null) {
 | |
|             $this->view = Icinga::app()->getViewRenderer()->view;
 | |
|         }
 | |
|         return $this->view;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get the line having matches highlighted
 | |
|      *
 | |
|      * @return string
 | |
|      */
 | |
|     public function highlight()
 | |
|     {
 | |
|         $highlighted = '';
 | |
|         $offset = 0;
 | |
|         $matches = $this->getMatches();
 | |
|         ksort($matches);
 | |
|         foreach ($matches as $position => $match) {
 | |
|             $highlighted .= $this->getView()->escape(substr($this->line, $offset, $position - $offset))
 | |
|                 . '<span class="' . static::HIGHLIGHT_CSS_CLASS .'">'
 | |
|                 . $this->getView()->escape($match)
 | |
|                 . '</span>';
 | |
|             $offset = $position + strlen($match);
 | |
|         }
 | |
|         $highlighted .= $this->getView()->escape(substr($this->line, $offset));
 | |
|         return $highlighted;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Whether the match is empty
 | |
|      *
 | |
|      * @return bool
 | |
|      */
 | |
|     public function isEmpty()
 | |
|     {
 | |
|         return empty($this->matches);
 | |
|     }
 | |
| }
 |