ajout de la partie slam dans le dossier web
This commit is contained in:
		
							
								
								
									
										751
									
								
								ap23/web/doku/inc/parser/metadata.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										751
									
								
								ap23/web/doku/inc/parser/metadata.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,751 @@ | ||||
| <?php | ||||
| /** | ||||
|  * The MetaData Renderer | ||||
|  * | ||||
|  * Metadata is additional information about a DokuWiki page that gets extracted mainly from the page's content | ||||
|  * but also it's own filesystem data (like the creation time). All metadata is stored in the fields $meta and | ||||
|  * $persistent. | ||||
|  * | ||||
|  * Some simplified rendering to $doc is done to gather the page's (text-only) abstract. | ||||
|  * | ||||
|  * @author Esther Brunner <wikidesign@gmail.com> | ||||
|  */ | ||||
| class Doku_Renderer_metadata extends Doku_Renderer | ||||
| { | ||||
|     /** the approximate byte lenght to capture for the abstract */ | ||||
|     const ABSTRACT_LEN = 250; | ||||
|  | ||||
|     /** the maximum UTF8 character length for the abstract */ | ||||
|     const ABSTRACT_MAX = 500; | ||||
|  | ||||
|     /** @var array transient meta data, will be reset on each rendering */ | ||||
|     public $meta = array(); | ||||
|  | ||||
|     /** @var array persistent meta data, will be kept until explicitly deleted */ | ||||
|     public $persistent = array(); | ||||
|  | ||||
|     /** @var array the list of headers used to create unique link ids */ | ||||
|     protected $headers = array(); | ||||
|  | ||||
|     /** @var string temporary $doc store */ | ||||
|     protected $store = ''; | ||||
|  | ||||
|     /** @var string keeps the first image reference */ | ||||
|     protected $firstimage = ''; | ||||
|  | ||||
|     /** @var bool whether or not data is being captured for the abstract, public to be accessible by plugins */ | ||||
|     public $capturing = true; | ||||
|  | ||||
|     /** @var bool determines if enough data for the abstract was collected, yet */ | ||||
|     public $capture = true; | ||||
|  | ||||
|     /** @var int number of bytes captured for abstract */ | ||||
|     protected $captured = 0; | ||||
|  | ||||
|     /** | ||||
|      * Returns the format produced by this renderer. | ||||
|      * | ||||
|      * @return string always 'metadata' | ||||
|      */ | ||||
|     public function getFormat() | ||||
|     { | ||||
|         return 'metadata'; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Initialize the document | ||||
|      * | ||||
|      * Sets up some of the persistent info about the page if it doesn't exist, yet. | ||||
|      */ | ||||
|     public function document_start() | ||||
|     { | ||||
|         global $ID; | ||||
|  | ||||
|         $this->headers = array(); | ||||
|  | ||||
|         // external pages are missing create date | ||||
|         if (!isset($this->persistent['date']['created']) || !$this->persistent['date']['created']) { | ||||
|             $this->persistent['date']['created'] = filectime(wikiFN($ID)); | ||||
|         } | ||||
|         if (!isset($this->persistent['user'])) { | ||||
|             $this->persistent['user'] = ''; | ||||
|         } | ||||
|         if (!isset($this->persistent['creator'])) { | ||||
|             $this->persistent['creator'] = ''; | ||||
|         } | ||||
|         // reset metadata to persistent values | ||||
|         $this->meta = $this->persistent; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Finalize the document | ||||
|      * | ||||
|      * Stores collected data in the metadata | ||||
|      */ | ||||
|     public function document_end() | ||||
|     { | ||||
|         global $ID; | ||||
|  | ||||
|         // store internal info in metadata (notoc,nocache) | ||||
|         $this->meta['internal'] = $this->info; | ||||
|  | ||||
|         if (!isset($this->meta['description']['abstract'])) { | ||||
|             // cut off too long abstracts | ||||
|             $this->doc = trim($this->doc); | ||||
|             if (strlen($this->doc) > self::ABSTRACT_MAX) { | ||||
|                 $this->doc = \dokuwiki\Utf8\PhpString::substr($this->doc, 0, self::ABSTRACT_MAX).'…'; | ||||
|             } | ||||
|             $this->meta['description']['abstract'] = $this->doc; | ||||
|         } | ||||
|  | ||||
|         $this->meta['relation']['firstimage'] = $this->firstimage; | ||||
|  | ||||
|         if (!isset($this->meta['date']['modified'])) { | ||||
|             $this->meta['date']['modified'] = filemtime(wikiFN($ID)); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Render plain text data | ||||
|      * | ||||
|      * This function takes care of the amount captured data and will stop capturing when | ||||
|      * enough abstract data is available | ||||
|      * | ||||
|      * @param $text | ||||
|      */ | ||||
|     public function cdata($text) | ||||
|     { | ||||
|         if (!$this->capture || !$this->capturing) { | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         $this->doc .= $text; | ||||
|  | ||||
|         $this->captured += strlen($text); | ||||
|         if ($this->captured > self::ABSTRACT_LEN) { | ||||
|             $this->capture = false; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Add an item to the TOC | ||||
|      * | ||||
|      * @param string $id       the hash link | ||||
|      * @param string $text     the text to display | ||||
|      * @param int    $level    the nesting level | ||||
|      */ | ||||
|     public function toc_additem($id, $text, $level) | ||||
|     { | ||||
|         global $conf; | ||||
|  | ||||
|         //only add items within configured levels | ||||
|         if ($level >= $conf['toptoclevel'] && $level <= $conf['maxtoclevel']) { | ||||
|             // the TOC is one of our standard ul list arrays ;-) | ||||
|             $this->meta['description']['tableofcontents'][] = array( | ||||
|                 'hid'   => $id, | ||||
|                 'title' => $text, | ||||
|                 'type'  => 'ul', | ||||
|                 'level' => $level - $conf['toptoclevel'] + 1 | ||||
|             ); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Render a heading | ||||
|      * | ||||
|      * @param string $text  the text to display | ||||
|      * @param int    $level header level | ||||
|      * @param int    $pos   byte position in the original source | ||||
|      */ | ||||
|     public function header($text, $level, $pos) | ||||
|     { | ||||
|         if (!isset($this->meta['title'])) { | ||||
|             $this->meta['title'] = $text; | ||||
|         } | ||||
|  | ||||
|         // add the header to the TOC | ||||
|         $hid = $this->_headerToLink($text, true); | ||||
|         $this->toc_additem($hid, $text, $level); | ||||
|  | ||||
|         // add to summary | ||||
|         $this->cdata(DOKU_LF.$text.DOKU_LF); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Open a paragraph | ||||
|      */ | ||||
|     public function p_open() | ||||
|     { | ||||
|         $this->cdata(DOKU_LF); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Close a paragraph | ||||
|      */ | ||||
|     public function p_close() | ||||
|     { | ||||
|         $this->cdata(DOKU_LF); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Create a line break | ||||
|      */ | ||||
|     public function linebreak() | ||||
|     { | ||||
|         $this->cdata(DOKU_LF); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Create a horizontal line | ||||
|      */ | ||||
|     public function hr() | ||||
|     { | ||||
|         $this->cdata(DOKU_LF.'----------'.DOKU_LF); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Callback for footnote start syntax | ||||
|      * | ||||
|      * All following content will go to the footnote instead of | ||||
|      * the document. To achieve this the previous rendered content | ||||
|      * is moved to $store and $doc is cleared | ||||
|      * | ||||
|      * @author Andreas Gohr <andi@splitbrain.org> | ||||
|      */ | ||||
|     public function footnote_open() | ||||
|     { | ||||
|         if ($this->capture) { | ||||
|             // move current content to store | ||||
|             // this is required to ensure safe behaviour of plugins accessed within footnotes | ||||
|             $this->store = $this->doc; | ||||
|             $this->doc   = ''; | ||||
|  | ||||
|             // disable capturing | ||||
|             $this->capturing = false; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Callback for footnote end syntax | ||||
|      * | ||||
|      * All content rendered whilst within footnote syntax mode is discarded, | ||||
|      * the previously rendered content is restored and capturing is re-enabled. | ||||
|      * | ||||
|      * @author Andreas Gohr | ||||
|      */ | ||||
|     public function footnote_close() | ||||
|     { | ||||
|         if ($this->capture) { | ||||
|             // re-enable capturing | ||||
|             $this->capturing = true; | ||||
|             // restore previously rendered content | ||||
|             $this->doc   = $this->store; | ||||
|             $this->store = ''; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Open an unordered list | ||||
|      */ | ||||
|     public function listu_open() | ||||
|     { | ||||
|         $this->cdata(DOKU_LF); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Open an ordered list | ||||
|      */ | ||||
|     public function listo_open() | ||||
|     { | ||||
|         $this->cdata(DOKU_LF); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Open a list item | ||||
|      * | ||||
|      * @param int $level the nesting level | ||||
|      * @param bool $node true when a node; false when a leaf | ||||
|      */ | ||||
|     public function listitem_open($level, $node=false) | ||||
|     { | ||||
|         $this->cdata(str_repeat(DOKU_TAB, $level).'* '); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Close a list item | ||||
|      */ | ||||
|     public function listitem_close() | ||||
|     { | ||||
|         $this->cdata(DOKU_LF); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Output preformatted text | ||||
|      * | ||||
|      * @param string $text | ||||
|      */ | ||||
|     public function preformatted($text) | ||||
|     { | ||||
|         $this->cdata($text); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Start a block quote | ||||
|      */ | ||||
|     public function quote_open() | ||||
|     { | ||||
|         $this->cdata(DOKU_LF.DOKU_TAB.'"'); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Stop a block quote | ||||
|      */ | ||||
|     public function quote_close() | ||||
|     { | ||||
|         $this->cdata('"'.DOKU_LF); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Display text as file content, optionally syntax highlighted | ||||
|      * | ||||
|      * @param string $text text to show | ||||
|      * @param string $lang programming language to use for syntax highlighting | ||||
|      * @param string $file file path label | ||||
|      */ | ||||
|     public function file($text, $lang = null, $file = null) | ||||
|     { | ||||
|         $this->cdata(DOKU_LF.$text.DOKU_LF); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Display text as code content, optionally syntax highlighted | ||||
|      * | ||||
|      * @param string $text     text to show | ||||
|      * @param string $language programming language to use for syntax highlighting | ||||
|      * @param string $file     file path label | ||||
|      */ | ||||
|     public function code($text, $language = null, $file = null) | ||||
|     { | ||||
|         $this->cdata(DOKU_LF.$text.DOKU_LF); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Format an acronym | ||||
|      * | ||||
|      * Uses $this->acronyms | ||||
|      * | ||||
|      * @param string $acronym | ||||
|      */ | ||||
|     public function acronym($acronym) | ||||
|     { | ||||
|         $this->cdata($acronym); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Format a smiley | ||||
|      * | ||||
|      * Uses $this->smiley | ||||
|      * | ||||
|      * @param string $smiley | ||||
|      */ | ||||
|     public function smiley($smiley) | ||||
|     { | ||||
|         $this->cdata($smiley); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Format an entity | ||||
|      * | ||||
|      * Entities are basically small text replacements | ||||
|      * | ||||
|      * Uses $this->entities | ||||
|      * | ||||
|      * @param string $entity | ||||
|      */ | ||||
|     public function entity($entity) | ||||
|     { | ||||
|         $this->cdata($entity); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Typographically format a multiply sign | ||||
|      * | ||||
|      * Example: ($x=640, $y=480) should result in "640×480" | ||||
|      * | ||||
|      * @param string|int $x first value | ||||
|      * @param string|int $y second value | ||||
|      */ | ||||
|     public function multiplyentity($x, $y) | ||||
|     { | ||||
|         $this->cdata($x.'×'.$y); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Render an opening single quote char (language specific) | ||||
|      */ | ||||
|     public function singlequoteopening() | ||||
|     { | ||||
|         global $lang; | ||||
|         $this->cdata($lang['singlequoteopening']); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Render a closing single quote char (language specific) | ||||
|      */ | ||||
|     public function singlequoteclosing() | ||||
|     { | ||||
|         global $lang; | ||||
|         $this->cdata($lang['singlequoteclosing']); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Render an apostrophe char (language specific) | ||||
|      */ | ||||
|     public function apostrophe() | ||||
|     { | ||||
|         global $lang; | ||||
|         $this->cdata($lang['apostrophe']); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Render an opening double quote char (language specific) | ||||
|      */ | ||||
|     public function doublequoteopening() | ||||
|     { | ||||
|         global $lang; | ||||
|         $this->cdata($lang['doublequoteopening']); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Render an closinging double quote char (language specific) | ||||
|      */ | ||||
|     public function doublequoteclosing() | ||||
|     { | ||||
|         global $lang; | ||||
|         $this->cdata($lang['doublequoteclosing']); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Render a CamelCase link | ||||
|      * | ||||
|      * @param string $link The link name | ||||
|      * @see http://en.wikipedia.org/wiki/CamelCase | ||||
|      */ | ||||
|     public function camelcaselink($link) | ||||
|     { | ||||
|         $this->internallink($link, $link); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Render a page local link | ||||
|      * | ||||
|      * @param string $hash hash link identifier | ||||
|      * @param string $name name for the link | ||||
|      */ | ||||
|     public function locallink($hash, $name = null) | ||||
|     { | ||||
|         if (is_array($name)) { | ||||
|             $this->_firstimage($name['src']); | ||||
|             if ($name['type'] == 'internalmedia') { | ||||
|                 $this->_recordMediaUsage($name['src']); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * keep track of internal links in $this->meta['relation']['references'] | ||||
|      * | ||||
|      * @param string            $id   page ID to link to. eg. 'wiki:syntax' | ||||
|      * @param string|array|null $name name for the link, array for media file | ||||
|      */ | ||||
|     public function internallink($id, $name = null) | ||||
|     { | ||||
|         global $ID; | ||||
|  | ||||
|         if (is_array($name)) { | ||||
|             $this->_firstimage($name['src']); | ||||
|             if ($name['type'] == 'internalmedia') { | ||||
|                 $this->_recordMediaUsage($name['src']); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         $parts = explode('?', $id, 2); | ||||
|         if (count($parts) === 2) { | ||||
|             $id = $parts[0]; | ||||
|         } | ||||
|  | ||||
|         $default = $this->_simpleTitle($id); | ||||
|  | ||||
|         // first resolve and clean up the $id | ||||
|         resolve_pageid(getNS($ID), $id, $exists); | ||||
|         @list($page) = explode('#', $id, 2); | ||||
|  | ||||
|         // set metadata | ||||
|         $this->meta['relation']['references'][$page] = $exists; | ||||
|         // $data = array('relation' => array('isreferencedby' => array($ID => true))); | ||||
|         // p_set_metadata($id, $data); | ||||
|  | ||||
|         // add link title to summary | ||||
|         if ($this->capture) { | ||||
|             $name = $this->_getLinkTitle($name, $default, $id); | ||||
|             $this->doc .= $name; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Render an external link | ||||
|      * | ||||
|      * @param string            $url  full URL with scheme | ||||
|      * @param string|array|null $name name for the link, array for media file | ||||
|      */ | ||||
|     public function externallink($url, $name = null) | ||||
|     { | ||||
|         if (is_array($name)) { | ||||
|             $this->_firstimage($name['src']); | ||||
|             if ($name['type'] == 'internalmedia') { | ||||
|                 $this->_recordMediaUsage($name['src']); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         if ($this->capture) { | ||||
|             $this->doc .= $this->_getLinkTitle($name, '<'.$url.'>'); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Render an interwiki link | ||||
|      * | ||||
|      * You may want to use $this->_resolveInterWiki() here | ||||
|      * | ||||
|      * @param string       $match     original link - probably not much use | ||||
|      * @param string|array $name      name for the link, array for media file | ||||
|      * @param string       $wikiName  indentifier (shortcut) for the remote wiki | ||||
|      * @param string       $wikiUri   the fragment parsed from the original link | ||||
|      */ | ||||
|     public function interwikilink($match, $name, $wikiName, $wikiUri) | ||||
|     { | ||||
|         if (is_array($name)) { | ||||
|             $this->_firstimage($name['src']); | ||||
|             if ($name['type'] == 'internalmedia') { | ||||
|                 $this->_recordMediaUsage($name['src']); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         if ($this->capture) { | ||||
|             list($wikiUri) = explode('#', $wikiUri, 2); | ||||
|             $name = $this->_getLinkTitle($name, $wikiUri); | ||||
|             $this->doc .= $name; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Link to windows share | ||||
|      * | ||||
|      * @param string       $url  the link | ||||
|      * @param string|array $name name for the link, array for media file | ||||
|      */ | ||||
|     public function windowssharelink($url, $name = null) | ||||
|     { | ||||
|         if (is_array($name)) { | ||||
|             $this->_firstimage($name['src']); | ||||
|             if ($name['type'] == 'internalmedia') { | ||||
|                 $this->_recordMediaUsage($name['src']); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         if ($this->capture) { | ||||
|             if ($name) { | ||||
|                 $this->doc .= $name; | ||||
|             } else { | ||||
|                 $this->doc .= '<'.$url.'>'; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Render a linked E-Mail Address | ||||
|      * | ||||
|      * Should honor $conf['mailguard'] setting | ||||
|      * | ||||
|      * @param string       $address Email-Address | ||||
|      * @param string|array $name    name for the link, array for media file | ||||
|      */ | ||||
|     public function emaillink($address, $name = null) | ||||
|     { | ||||
|         if (is_array($name)) { | ||||
|             $this->_firstimage($name['src']); | ||||
|             if ($name['type'] == 'internalmedia') { | ||||
|                 $this->_recordMediaUsage($name['src']); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         if ($this->capture) { | ||||
|             if ($name) { | ||||
|                 $this->doc .= $name; | ||||
|             } else { | ||||
|                 $this->doc .= '<'.$address.'>'; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Render an internal media file | ||||
|      * | ||||
|      * @param string $src     media ID | ||||
|      * @param string $title   descriptive text | ||||
|      * @param string $align   left|center|right | ||||
|      * @param int    $width   width of media in pixel | ||||
|      * @param int    $height  height of media in pixel | ||||
|      * @param string $cache   cache|recache|nocache | ||||
|      * @param string $linking linkonly|detail|nolink | ||||
|      */ | ||||
|     public function internalmedia($src, $title = null, $align = null, $width = null, | ||||
|                            $height = null, $cache = null, $linking = null) | ||||
|     { | ||||
|         if ($this->capture && $title) { | ||||
|             $this->doc .= '['.$title.']'; | ||||
|         } | ||||
|         $this->_firstimage($src); | ||||
|         $this->_recordMediaUsage($src); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Render an external media file | ||||
|      * | ||||
|      * @param string $src     full media URL | ||||
|      * @param string $title   descriptive text | ||||
|      * @param string $align   left|center|right | ||||
|      * @param int    $width   width of media in pixel | ||||
|      * @param int    $height  height of media in pixel | ||||
|      * @param string $cache   cache|recache|nocache | ||||
|      * @param string $linking linkonly|detail|nolink | ||||
|      */ | ||||
|     public function externalmedia($src, $title = null, $align = null, $width = null, | ||||
|                            $height = null, $cache = null, $linking = null) | ||||
|     { | ||||
|         if ($this->capture && $title) { | ||||
|             $this->doc .= '['.$title.']'; | ||||
|         } | ||||
|         $this->_firstimage($src); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Render the output of an RSS feed | ||||
|      * | ||||
|      * @param string $url    URL of the feed | ||||
|      * @param array  $params Finetuning of the output | ||||
|      */ | ||||
|     public function rss($url, $params) | ||||
|     { | ||||
|         $this->meta['relation']['haspart'][$url] = true; | ||||
|  | ||||
|         $this->meta['date']['valid']['age'] = | ||||
|             isset($this->meta['date']['valid']['age']) ? | ||||
|                 min($this->meta['date']['valid']['age'], $params['refresh']) : | ||||
|                 $params['refresh']; | ||||
|     } | ||||
|  | ||||
|     #region Utils | ||||
|  | ||||
|     /** | ||||
|      * Removes any Namespace from the given name but keeps | ||||
|      * casing and special chars | ||||
|      * | ||||
|      * @author Andreas Gohr <andi@splitbrain.org> | ||||
|      * | ||||
|      * @param string $name | ||||
|      * | ||||
|      * @return mixed|string | ||||
|      */ | ||||
|     public function _simpleTitle($name) | ||||
|     { | ||||
|         global $conf; | ||||
|  | ||||
|         if (is_array($name)) { | ||||
|             return ''; | ||||
|         } | ||||
|  | ||||
|         if ($conf['useslash']) { | ||||
|             $nssep = '[:;/]'; | ||||
|         } else { | ||||
|             $nssep = '[:;]'; | ||||
|         } | ||||
|         $name = preg_replace('!.*'.$nssep.'!', '', $name); | ||||
|         //if there is a hash we use the anchor name only | ||||
|         $name = preg_replace('!.*#!', '', $name); | ||||
|         return $name; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Construct a title and handle images in titles | ||||
|      * | ||||
|      * @author Harry Fuecks <hfuecks@gmail.com> | ||||
|      * @param string|array|null $title    either string title or media array | ||||
|      * @param string            $default  default title if nothing else is found | ||||
|      * @param null|string       $id       linked page id (used to extract title from first heading) | ||||
|      * @return string title text | ||||
|      */ | ||||
|     public function _getLinkTitle($title, $default, $id = null) | ||||
|     { | ||||
|         if (is_array($title)) { | ||||
|             if ($title['title']) { | ||||
|                 return '['.$title['title'].']'; | ||||
|             } else { | ||||
|                 return $default; | ||||
|             } | ||||
|         } elseif (is_null($title) || trim($title) == '') { | ||||
|             if (useHeading('content') && $id) { | ||||
|                 $heading = p_get_first_heading($id, METADATA_DONT_RENDER); | ||||
|                 if ($heading) { | ||||
|                     return $heading; | ||||
|                 } | ||||
|             } | ||||
|             return $default; | ||||
|         } else { | ||||
|             return $title; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Remember first image | ||||
|      * | ||||
|      * @param string $src image URL or ID | ||||
|      */ | ||||
|     protected function _firstimage($src) | ||||
|     { | ||||
|         global $ID; | ||||
|  | ||||
|         if ($this->firstimage) { | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         list($src) = explode('#', $src, 2); | ||||
|         if (!media_isexternal($src)) { | ||||
|             resolve_mediaid(getNS($ID), $src, $exists); | ||||
|         } | ||||
|         if (preg_match('/.(jpe?g|gif|png)$/i', $src)) { | ||||
|             $this->firstimage = $src; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Store list of used media files in metadata | ||||
|      * | ||||
|      * @param string $src media ID | ||||
|      */ | ||||
|     protected function _recordMediaUsage($src) | ||||
|     { | ||||
|         global $ID; | ||||
|  | ||||
|         list ($src) = explode('#', $src, 2); | ||||
|         if (media_isexternal($src)) { | ||||
|             return; | ||||
|         } | ||||
|         resolve_mediaid(getNS($ID), $src, $exists); | ||||
|         $this->meta['relation']['media'][$src] = $exists; | ||||
|     } | ||||
|  | ||||
|     #endregion | ||||
| } | ||||
|  | ||||
| //Setup VIM: ex: et ts=4 : | ||||
		Reference in New Issue
	
	Block a user