114 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			114 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
namespace FML\Script\Features;
 | 
						|
 | 
						|
use FML\Script\Builder;
 | 
						|
use FML\Script\Script;
 | 
						|
use FML\Script\ScriptLabel;
 | 
						|
 | 
						|
/**
 | 
						|
 * Script Feature for Image Preloading
 | 
						|
 *
 | 
						|
 * @author    steeffeen <mail@steeffeen.com>
 | 
						|
 * @copyright FancyManiaLinks Copyright © 2017 Steffen Schröder
 | 
						|
 * @license   http://www.gnu.org/licenses/ GNU General Public License, Version 3
 | 
						|
 */
 | 
						|
class Preload extends ScriptFeature
 | 
						|
{
 | 
						|
 | 
						|
    /**
 | 
						|
     * @var string[] $imageUrls Image urls
 | 
						|
     */
 | 
						|
    protected $imageUrls = array();
 | 
						|
 | 
						|
    /**
 | 
						|
     * Construct a new Preload
 | 
						|
     *
 | 
						|
     * @api
 | 
						|
     * @param string[] $imageUrls (optional) Image urls
 | 
						|
     */
 | 
						|
    public function __construct(array $imageUrls = null)
 | 
						|
    {
 | 
						|
        if ($imageUrls) {
 | 
						|
            $this->setImageUrls($imageUrls);
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Get Image Urls to preload
 | 
						|
     *
 | 
						|
     * @api
 | 
						|
     * @return string[]
 | 
						|
     */
 | 
						|
    public function getImageUrls()
 | 
						|
    {
 | 
						|
        return $this->imageUrls;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Add an Image Url to preload
 | 
						|
     *
 | 
						|
     * @api
 | 
						|
     * @param string $imageUrl Image Url
 | 
						|
     * @return static
 | 
						|
     */
 | 
						|
    public function addImageUrl($imageUrl)
 | 
						|
    {
 | 
						|
        if (!in_array($imageUrl, $this->imageUrls)) {
 | 
						|
            array_push($this->imageUrls, $imageUrl);
 | 
						|
        }
 | 
						|
        return $this;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Set Image Urls to preload
 | 
						|
     *
 | 
						|
     * @api
 | 
						|
     * @param string[] $imageUrls Image Urls
 | 
						|
     * @return static
 | 
						|
     */
 | 
						|
    public function setImageUrls(array $imageUrls = array())
 | 
						|
    {
 | 
						|
        $this->imageUrls = $imageUrls;
 | 
						|
        return $this;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Remove all Image Urls
 | 
						|
     *
 | 
						|
     * @api
 | 
						|
     * @return static
 | 
						|
     */
 | 
						|
    public function removeAllImageUrls()
 | 
						|
    {
 | 
						|
        $this->imageUrls = array();
 | 
						|
        return $this;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * @see ScriptFeature::prepare()
 | 
						|
     */
 | 
						|
    public function prepare(Script $script)
 | 
						|
    {
 | 
						|
        $script->appendGenericScriptLabel(ScriptLabel::ONINIT, $this->getScriptText());
 | 
						|
        return $this;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Get the script text
 | 
						|
     *
 | 
						|
     * @return string
 | 
						|
     */
 | 
						|
    protected function getScriptText()
 | 
						|
    {
 | 
						|
        $scriptText = "";
 | 
						|
        foreach ($this->imageUrls as $imageUrl) {
 | 
						|
            $escapedImageUrl = Builder::escapeText($imageUrl);
 | 
						|
            $scriptText .= "
 | 
						|
PreloadImage({$escapedImageUrl});";
 | 
						|
        }
 | 
						|
        return $scriptText;
 | 
						|
    }
 | 
						|
 | 
						|
}
 |