'n2-ss-layer-col n2-ss-layer-with-background n2-ss-layer-content', 'style' => '' ); protected $localStyle = array( array( "group" => "normal", "selector" => '-inner', "css" => array() ), array( "group" => "hover", "selector" => '-inner:HOVER', "css" => array() ), ); protected $width; public function __construct($index, $owner, $group, $data) { parent::__construct($index, $owner, $group, $data); $this->container = new ComponentContainer($owner, $this, $data['layers']); $this->data->un_set('layers'); $this->upgradeData(); $this->attributes['style'] = ''; $devices = $this->owner->getAvailableDevices(); $desktopportraitInnerAlign = $this->data->get('desktopportraitinneralign', 'inherit'); $desktopPortraitMaxWidth = intval($this->data->get('desktopportraitmaxwidth')); foreach ($devices as $device) { if ($this->data->has($device . 'padding')) { $padding = $this->data->get($device . 'padding'); if (!empty($padding)) { $paddingValues = $this->spacingToPxValue($padding); $this->style->add($device, '-inner', 'padding:' . implode('px ', $paddingValues) . 'px'); } } if ($this->data->has($device . 'maxwidth')) { $maxWidth = intval($this->data->get($device . 'maxwidth')); if ($maxWidth > 0) { $this->style->add($device, '', 'max-width: ' . $maxWidth . 'px'); } else if ($device != 'desktopportrait' && $maxWidth != $desktopPortraitMaxWidth) { $this->style->add($device, '', 'max-width: none'); } } $innerAlign = $this->data->get($device . 'inneralign', ''); if ($device == 'desktopportrait') { if ($desktopportraitInnerAlign != 'inherit') { $this->style->add($device, '-inner', AbstractComponent::innerAlignToStyle($innerAlign)); } } else if ($desktopportraitInnerAlign != $innerAlign) { $this->style->add($device, '-inner', AbstractComponent::innerAlignToStyle($innerAlign)); } $verticalAlign = $this->data->get($device . 'verticalalign'); if (!empty($verticalAlign)) { $this->style->add($device, '-inner', 'justify-content:' . $verticalAlign); } if ($this->data->has($device . 'order')) { $order = intval($this->data->get($device . 'order')); if ($order > 0) { $this->style->add($device, '', 'order: ' . $order); } } } $this->renderBackground(); $borderRadius = intval($this->data->get('borderradius', '0')); $this->addLocalStyle('normal', 'borderradius', $this->getBorderRadiusCSS($borderRadius)); $borderRadiusHover = intval($this->data->get('borderradius-hover')); if (!empty($borderRadiusHover) && $borderRadiusHover != $borderRadius) { $this->addLocalStyle('hover', 'borderradius', $this->getBorderRadiusCSS($borderRadiusHover)); } $boxShadow = $this->data->get('boxshadow', '0|*|0|*|0|*|0|*|00000080'); $this->addLocalStyle('normal', 'boxshadow', $this->getBoxShadowCSS($boxShadow)); $boxShadowHover = $this->data->get('boxshadow-hover'); if (!empty($boxShadowHover) && $boxShadowHover != $boxShadow) { $this->addLocalStyle('hover', 'boxshadow', $this->getBoxShadowCSS($boxShadowHover)); } $borderWidth = $this->data->get('borderwidth', '1|*|1|*|1|*|1'); $borderStyle = $this->data->get('borderstyle', 'none'); $borderColor = $this->data->get('bordercolor', 'ffffffff'); if ($borderStyle != 'none') { $this->addLocalStyle('normal', 'border', $this->getBorderCSS($borderWidth, $borderStyle, $borderColor)); } $borderWidthHover = $this->data->get('borderwidth-hover'); $borderStyleHover = $this->data->get('borderstyle-hover'); $borderColorHover = $this->data->get('bordercolor-hover'); $isHoverDifferent = false; if (!empty($borderWidthHover) || $borderWidthHover != $borderWidth) { $isHoverDifferent = true; } if (!empty($borderStyleHover) || $borderStyleHover != $borderStyle) { $isHoverDifferent = true; } if (!empty($borderColorHover) || $borderColorHover != $borderColor) { $isHoverDifferent = true; } if ($isHoverDifferent) { if (empty($borderWidthHover)) $borderWidthHover = $borderWidth; if (empty($borderStyleHover)) $borderStyleHover = $borderStyle; if (empty($borderColorHover)) $borderColorHover = $borderColor; $this->addLocalStyle('hover', 'border', $this->getBorderCSS($borderWidthHover, $borderStyleHover, $borderColorHover)); } $this->placement->attributes($this->attributes); $width = explode('/', $this->data->get('colwidth', 1)); if (count($width) == 2) { if ($width[0] == 0 || $width[1] == 0) { $width[0] = 1; $width[1] = 2; $this->data->set('colwidth', '1/2'); } $width = floor($width[0] / $width[1] * 1000) / 10; } else { $width = 100; } $this->width = $width; if (!AbstractComponent::$isAdmin) { $this->makeLink(); } } public function setWidth($device) { $this->style->add($device, '', 'width:' . $this->width . '%'); } public function setWidthAuto($device) { $this->style->add($device, '', 'width:auto'); } public function setWrapAfterWidth($device, $width, $gutter) { $this->style->add($device, '', 'width:calc(' . $width . '% - ' . $gutter . 'px)'); } protected function upgradeData() { if ($this->data->has('verticalalign')) { /** * Upgrade data to device specific */ $this->data->set('desktopportraitverticalalign', $this->data->get('verticalalign')); $this->data->un_set('verticalalign'); } } public function getPlacement() { return 'default'; } private function getBorderRadiusCSS($borderRadius) { if ($borderRadius > 0) { return 'border-radius:' . $borderRadius . 'px;'; } return ''; } private function getBoxShadowCSS($boxShadow) { $boxShadowArray = explode('|*|', $boxShadow); if (count($boxShadowArray) == 5 && ($boxShadowArray[0] != 0 || $boxShadowArray[1] != 0 || $boxShadowArray[2] != 0 || $boxShadowArray[3] != 0) && Color::hex2alpha($boxShadowArray[4]) != 0) { return 'box-shadow:' . $boxShadowArray[0] . 'px ' . $boxShadowArray[1] . 'px ' . $boxShadowArray[2] . 'px ' . $boxShadowArray[3] . 'px ' . Color::colorToRGBA($boxShadowArray[4]) . ';'; } return ''; } private function getBorderCSS($width, $style, $color) { if ($style != 'none') { $values = explode('|*|', $width); $unit = 'px'; $values[4] = ''; $css = 'border-width:' . implode($unit . ' ', $values) . ';'; $css .= 'border-style:' . $style . ';'; $css .= 'border-color:' . Color::colorToRGBA($color) . ';'; return $css; } return ''; } private function makeLink() { $linkV1 = $this->data->get('link', ''); if (!empty($linkV1)) { list($link, $target) = array_pad((array)Common::parse($linkV1), 2, ''); $this->data->un_set('link'); $this->data->set('href', $link); $this->data->set('href-target', $target); } $link = $this->data->get('href'); if (($link != '#' && !empty($link))) { $target = $this->data->get('href-target'); $link = Link::parse($this->owner->fill($link), $this->attributes); $this->attributes['data-href'] = $link; $this->attributes['tabindex'] = 0; $this->attributes['role'] = 'button'; $ariaLabel = $this->data->get('aria-label'); if (!empty($ariaLabel)) { $this->attributes['aria-label'] = $this->owner->fill($ariaLabel); } if (!isset($this->attributes['onclick']) && !isset($this->attributes['data-n2-lightbox'])) { if (!empty($target) && $target != '_self') { $this->attributes['data-target'] = $target; } $this->attributes['data-n2click'] = "url"; } $this->attributes['data-force-pointer'] = ""; } } public function render($isAdmin) { if ($this->isRenderAllowed()) { $this->runPlugins(); $this->serveLocalStyle(); if ($isAdmin) { $this->admin(); } $this->prepareHTML(); $html = Html::tag('div', $this->colAttributes, parent::renderContainer($isAdmin)); $html = $this->renderPlugins($html); return Html::tag('div', $this->attributes, $html); } return ''; } protected function addUniqueClass($class) { $this->attributes['class'] .= ' ' . $class; $this->colAttributes['class'] .= ' ' . $class . '-inner'; } protected function admin() { $linkV1 = $this->data->get('link', ''); if (!empty($linkV1)) { list($link, $target) = array_pad((array)Common::parse($linkV1), 2, ''); $this->data->un_set('link'); $this->data->set('href', $link); $this->data->set('href-target', $target); } $this->createProperty('href', ''); $this->createProperty('href-target', '_self'); $this->createProperty('aria-label', ''); $this->createProperty('colwidth'); $this->createProperty('bgimage', ''); $this->createProperty('bgimagex', 50); $this->createProperty('bgimagey', 50); $this->createColorProperty('bgcolor', true, '00000000'); $this->createProperty('bgcolorgradient', 'off'); $this->createColorProperty('bgcolorgradientend', true, '00000000'); $this->createColorProperty('bgcolor-hover', true); $this->createProperty('bgcolorgradient-hover'); $this->createColorProperty('bgcolorgradientend-hover', true); $this->createProperty('borderradius', '0'); $this->createProperty('borderradius-hover'); $this->createProperty('boxshadow', '0|*|0|*|0|*|0|*|00000080'); $this->createProperty('boxshadow-hover'); $this->createProperty('borderwidth', '1|*|1|*|1|*|1'); $this->createProperty('borderstyle', 'none'); $this->createProperty('bordercolor', 'FFFFFFFF'); $this->createProperty('borderwidth-hover'); $this->createProperty('borderstyle-hover'); $this->createProperty('bordercolor-hover'); $this->createProperty('opened', 1); $this->createDeviceProperty('maxwidth', '0'); $this->createDeviceProperty('padding', '10|*|10|*|10|*|10'); $this->createDeviceProperty('verticalalign', 'flex-start'); $this->createDeviceProperty('inneralign', 'inherit'); $this->createDeviceProperty('order'); parent::admin(); } /** * @param ExportSlider $export * @param array $layer */ public static function prepareExport($export, $layer) { if (!empty($layer['bgimage'])) { $export->addImage($layer['bgimage']); } $export->prepareLayer($layer['layers']); } public static function prepareImport($import, &$layer) { if (!empty($layer['bgimage'])) { $layer['bgimage'] = $import->fixImage($layer['bgimage']); } $import->prepareLayers($layer['layers']); } public static function prepareSample(&$layer) { if (!empty($layer['bgimage'])) { $layer['bgimage'] = ResourceTranslator::toUrl($layer['bgimage']); } ModelSlides::prepareSample($layer['layers']); } /** * @param AbstractRenderableOwner $slide * @param array $layer */ public static function getFilled($slide, &$layer) { AbstractComponent::getFilled($slide, $layer); $fields = array( 'bgimage', 'href' ); foreach ($fields as $field) { if (!empty($layer[$field])) { $layer[$field] = $slide->fill($layer[$field]); } } $slide->fillLayers($layer['layers']); } public function getOrder($device) { $order = intval($this->data->get($device . 'order')); if ($order > 0) { return $order; } return 10; } public function getWidth() { return $this->width; } public static $compareOrderDevice; /** * @param ComponentCol $column1 * @param ComponentCol $column2 * * @return int */ public static function compareOrder($column1, $column2) { $order1 = $column1->getOrder(self::$compareOrderDevice); $order2 = $column2->getOrder(self::$compareOrderDevice); if ($order1 == $order2) { return 0; } return ($order1 < $order2) ? -1 : 1; } }