xref: /plugin/mikioplugin/syntax/carousel.php (revision ee3901e1d02c5d23fc24c57a42a9416a330b9b54)
117e6d639SJames Collins<?php
294f363a8Snomadjimbob
317e6d639SJames Collins/**
417e6d639SJames Collins * Mikio Syntax Plugin: Carousel
517e6d639SJames Collins *
67935713eSJames Collins * @link        http://github.com/nomadjimbob/mikioplugin
717e6d639SJames Collins * @license     GPL 2 (http://www.gnu.org/licenses/gpl.html)
817e6d639SJames Collins * @author      James Collins <james.collins@outlook.com.au>
917e6d639SJames Collins */
1017e6d639SJames Collinsif (!defined('DOKU_INC')) die();
1117e6d639SJames Collinsif (!defined('DOKU_PLUGIN')) define('DOKU_PLUGIN', DOKU_INC . 'lib/plugins/');
1217e6d639SJames Collinsrequire_once(dirname(__FILE__) . '/core.php');
1317e6d639SJames Collins
1494f363a8Snomadjimbobclass syntax_plugin_mikioplugin_carousel extends syntax_plugin_mikioplugin_core
1594f363a8Snomadjimbob{
1617e6d639SJames Collins    public $tag                 = 'carousel';
177935713eSJames Collins    public $hasEndTag           = true;
187935713eSJames Collins    public $options             = array(
1994f363a8Snomadjimbob        'transition'    => array(
2094f363a8Snomadjimbob            'type'     => 'choice',
217935713eSJames Collins            'data'     => array('slide', 'fade'),
2294f363a8Snomadjimbob            'default'  => ''
2394f363a8Snomadjimbob        ),
24*ee3901e1Snomadjimbob        'indicators'    => array(
25*ee3901e1Snomadjimbob            'type'     => 'choice',
26*ee3901e1Snomadjimbob            'data'     => array('true', 'false', 'circle'),
27*ee3901e1Snomadjimbob            'default'  => 'true'
28*ee3901e1Snomadjimbob        ),
297935713eSJames Collins        'controls'      => array('type'     => 'boolean',   'default'   => 'true'),
307935713eSJames Collins        'start'         => array('type'     => 'boolean',   'default'   => 'false'),
31062e2726SJames Collins        'cover'         => array('type'     => 'boolean',   'default'   => 'false'),
3294f363a8Snomadjimbob        'control-color' => array('type'     => 'color',     'default'   => '#fff'),
3394f363a8Snomadjimbob        'control-outline-color' => array('type'     => 'color',     'default'   => ''),
3494f363a8Snomadjimbob        'control-outline-width' => array('type'     => 'multisize',     'default'   => ''),
357935713eSJames Collins    );
3617e6d639SJames Collins
3794f363a8Snomadjimbob    public function __construct()
3894f363a8Snomadjimbob    {
396b66a10dSJames Collins        $this->addCommonOptions('height');
406b66a10dSJames Collins    }
416b66a10dSJames Collins
4217e6d639SJames Collins
4394f363a8Snomadjimbob    public function render_lexer_enter(Doku_Renderer $renderer, $data)
4494f363a8Snomadjimbob    {
457935713eSJames Collins        $classes = $this->buildClass($data, array('transition'));
466b66a10dSJames Collins        $styles = $this->buildStyle(array('height' => $data['height']), TRUE);
4717e6d639SJames Collins
48062e2726SJames Collins        $renderer->doc .= '<div class="' . $this->elemClass . ' ' . $this->classPrefix . 'carousel' . ($data['cover'] ? ' ' . $this->classPrefix . 'image-cover' : '') . $classes . '" data-auto-start="' . ($data['start'] ? 'true' : 'false') . '"' . $styles . '>';
497935713eSJames Collins        $renderer->doc .= '<div class="' . $this->elemClass . ' ' . $this->classPrefix . 'carousel-inner">';
5017e6d639SJames Collins    }
5117e6d639SJames Collins
5217e6d639SJames Collins
5394f363a8Snomadjimbob    public function render_lexer_exit(Doku_Renderer $renderer, $data)
5494f363a8Snomadjimbob    {
5557ae4893SJames Collins        $renderer->doc .= '</div>';
5657ae4893SJames Collins
577935713eSJames Collins        if ($data['controls'] === TRUE) {
5894f363a8Snomadjimbob            $svg_styles = $this->buildStyle(array('fill' => $data['control-color'], 'stroke' => $data['control-outline-color'], 'stroke-width' => $data['control-outline-width']), TRUE);
5994f363a8Snomadjimbob
6094f363a8Snomadjimbob            $renderer->doc .= '<a href="#" class="' . $this->elemClass . ' ' . $this->classPrefix . 'carousel-control ' . $this->classPrefix . 'carousel-control-prev" role="button"><svg xmlns="http://www.w3.org/2000/svg" width="48" height="48" viewBox="0 0 8 8"' . $svg_styles . '><path d="M5.25 0l-4 4 4 4 1.5-1.5L4.25 4l2.5-2.5L5.25 0z"/></svg></a>';
6194f363a8Snomadjimbob            $renderer->doc .= '<a href="#" class="' . $this->elemClass . ' ' . $this->classPrefix . 'carousel-control ' . $this->classPrefix . 'carousel-control-next" role="button"><svg xmlns="http://www.w3.org/2000/svg" width="48" height="48" viewBox="0 0 8 8"' . $svg_styles . '><path d="M2.75 0l-1.5 1.5L3.75 4l-2.5 2.5L2.75 8l4-4-4-4z"/></svg></a>';
627935713eSJames Collins        }
6357ae4893SJames Collins
64*ee3901e1Snomadjimbob        if (strcasecmp($data['indicators'], 'false') != 0) {
65*ee3901e1Snomadjimbob            $renderer->doc .= '<ul class="' . $this->elemClass . ' ' . $this->classPrefix . 'carousel-indicators' . (strcasecmp($data['indicators'], 'circle') == 0 ? ' ' . $this->classPrefix . 'carousel-indicators-circle' : '') . '"></ul>';
6657ae4893SJames Collins        }
6757ae4893SJames Collins
6857ae4893SJames Collins        $renderer->doc .= '</div>';
6917e6d639SJames Collins    }
7017e6d639SJames Collins}
71