Compare commits

..

No commits in common. "master" and "dev-contao3" have entirely different histories.

140 changed files with 2743 additions and 1176 deletions

3
.gitignore vendored
View File

@ -1,3 +0,0 @@
/.project
/vendor

View File

@ -57,6 +57,12 @@ class RateItArticle extends RateItFrontend {
->fetchAssoc(); ->fetchAssoc();
if ($arrArticle['addRating']) { if ($arrArticle['addRating']) {
if ($objTemplate->multiMode && $objTemplate->showTeaser) {
$objTemplate->setName('mod_'.$arrArticle['rateit_template'].'_teaser');
} else {
$objTemplate->setName($arrArticle['rateit_template']);
}
$ratingId = $arrArticle['id']; $ratingId = $arrArticle['id'];
$rating = $this->loadRating($ratingId, 'article'); $rating = $this->loadRating($ratingId, 'article');
$stars = !$rating ? 0 : $this->percentToStars($rating['rating']); $stars = !$rating ? 0 : $this->percentToStars($rating['rating']);
@ -84,15 +90,15 @@ class RateItArticle extends RateItFrontend {
$objTemplate->rateit_rating_after = true; $objTemplate->rateit_rating_after = true;
} }
$GLOBALS['TL_JAVASCRIPT'][] = 'bundles/cgoitrateit/js/onReadyRateIt.js|static'; $GLOBALS['TL_JAVASCRIPT'][] = 'system/modules/rateit/public/js/onReadyRateIt.js|static';
$GLOBALS['TL_JAVASCRIPT'][] = 'bundles/cgoitrateit/js/rateit.js|static'; $GLOBALS['TL_JAVASCRIPT'][] = 'system/modules/rateit/public/js/rateit.js|static';
$GLOBALS['TL_CSS'][] = 'bundles/cgoitrateit/css/rateit.min.css||static'; $GLOBALS['TL_CSS'][] = 'system/modules/rateit/public/css/rateit.min.css||static';
switch ($GLOBALS['TL_CONFIG']['rating_type']) { switch ($GLOBALS['TL_CONFIG']['rating_type']) {
case 'hearts' : case 'hearts' :
$GLOBALS['TL_CSS'][] = 'bundles/cgoitrateit/css/heart.min.css||static'; $GLOBALS['TL_CSS'][] = 'system/modules/rateit/public/css/heart.min.css||static';
break; break;
default: default:
$GLOBALS['TL_CSS'][] = 'bundles/cgoitrateit/css/star.min.css||static'; $GLOBALS['TL_CSS'][] = 'system/modules/rateit/public/css/star.min.css||static';
} }
} }
@ -108,7 +114,7 @@ class RateItArticle extends RateItFrontend {
->limit(1) ->limit(1)
->execute($article['articleId']) ->execute($article['articleId'])
->fetchAssoc(); ->fetchAssoc();
if ($arrArticle['addRating']) { if ($arrArticle['addRating']) {
if (!$bolTemplateFixed) { if (!$bolTemplateFixed) {
$objTemplate->setName($objTemplate->getName().'_rateit'); $objTemplate->setName($objTemplate->getName().'_rateit');
@ -119,7 +125,7 @@ class RateItArticle extends RateItFrontend {
$rating = $this->loadRating($ratingId, 'article'); $rating = $this->loadRating($ratingId, 'article');
$stars = !$rating ? 0 : $this->percentToStars($rating['rating']); $stars = !$rating ? 0 : $this->percentToStars($rating['rating']);
$percent = round($rating['rating'], 0)."%"; $percent = round($rating['rating'], 0)."%";
$article['descriptionId'] = 'rateItRating-'.$ratingId.'-description'; $article['descriptionId'] = 'rateItRating-'.$ratingId.'-description';
$article['description'] = $this->getStarMessage($rating); $article['description'] = $this->getStarMessage($rating);
$article['rateItID'] = 'rateItRating-'.$ratingId.'-article-'.$stars.'_'.$this->intStars; $article['rateItID'] = 'rateItRating-'.$ratingId.'-article-'.$stars.'_'.$this->intStars;
@ -128,32 +134,32 @@ class RateItArticle extends RateItFrontend {
$article['actRating'] = $this->percentToStars($rating['rating']); $article['actRating'] = $this->percentToStars($rating['rating']);
$article['maxRating'] = $this->intStars; $article['maxRating'] = $this->intStars;
$article['votes'] = $rating[totalRatings]; $article['votes'] = $rating[totalRatings];
if ($this->strTextPosition == "before") { if ($this->strTextPosition == "before") {
$article['showBefore'] = true; $article['showBefore'] = true;
} }
else if ($this->strTextPosition == "after") { else if ($this->strTextPosition == "after") {
$article['showAfter'] = true; $article['showAfter'] = true;
} }
if ($arrArticle['rateit_position'] == 'before') { if ($arrArticle['rateit_position'] == 'before') {
$article['rateit_rating_before'] = true; $article['rateit_rating_before'] = true;
} else if ($arrArticle['rateit_position'] == 'after') { } else if ($arrArticle['rateit_position'] == 'after') {
$article['rateit_rating_after'] = true; $article['rateit_rating_after'] = true;
} }
$GLOBALS['TL_JAVASCRIPT'][] = 'bundles/cgoitrateit/js/onReadyRateIt.js|static'; $GLOBALS['TL_JAVASCRIPT'][] = 'system/modules/rateit/public/js/onReadyRateIt.js|static';
$GLOBALS['TL_JAVASCRIPT'][] = 'bundles/cgoitrateit/js/rateit.js|static'; $GLOBALS['TL_JAVASCRIPT'][] = 'system/modules/rateit/public/js/rateit.js|static';
$GLOBALS['TL_CSS'][] = 'bundles/cgoitrateit/css/rateit.min.css||static'; $GLOBALS['TL_CSS'][] = 'system/modules/rateit/public/css/rateit.min.css||static';
switch ($GLOBALS['TL_CONFIG']['rating_type']) { switch ($GLOBALS['TL_CONFIG']['rating_type']) {
case 'hearts' : case 'hearts' :
$GLOBALS['TL_CSS'][] = 'bundles/cgoitrateit/css/heart.min.css||static'; $GLOBALS['TL_CSS'][] = 'system/modules/rateit/public/css/heart.min.css||static';
break; break;
default: default:
$GLOBALS['TL_CSS'][] = 'bundles/cgoitrateit/css/star.min.css||static'; $GLOBALS['TL_CSS'][] = 'system/modules/rateit/public/css/star.min.css||static';
} }
} }
$arrArticles[] = $article; $arrArticles[] = $article;
} }
$objTemplate->articles = $arrArticles; $objTemplate->articles = $arrArticles;
@ -166,10 +172,10 @@ class RateItArticle extends RateItFrontend {
->limit(1) ->limit(1)
->execute($objTemplate->id) ->execute($objTemplate->id)
->fetchAssoc(); ->fetchAssoc();
if ($arrGallery['rateit_active']) { if ($arrGallery['rateit_active']) {
$arrRating = array(); $arrRating = array();
if (version_compare(VERSION, '3.2', '>=')) { if (version_compare(VERSION, '3.2', '>=')) {
$objFiles = \FilesModel::findMultipleByUuids(deserialize($arrGallery['multiSRC'])); $objFiles = \FilesModel::findMultipleByUuids(deserialize($arrGallery['multiSRC']));
} else { } else {
@ -179,19 +185,19 @@ class RateItArticle extends RateItFrontend {
if ($objFiles !== null) { if ($objFiles !== null) {
// Get all images // Get all images
while ($objFiles->next()) { while ($objFiles->next()) {
// Continue if the files has been processed or does not exist // Continue if the files has been processed or does not exist
if (isset($arrRating[$objFiles->path]) || !file_exists(TL_ROOT . '/' . $objFiles->path)) { if (isset($arrRating[$objFiles->path]) || !file_exists(TL_ROOT . '/' . $objFiles->path)) {
continue; continue;
} }
// Single files // Single files
if ($objFiles->type == 'file') { if ($objFiles->type == 'file') {
$objFile = new \File($objFiles->path, true); $objFile = new \File($objFiles->path, true);
if (!$objFile->isGdImage) { if (!$objFile->isGdImage) {
continue; continue;
} }
$this->addRatingForImage($arrRating, $arrGallery['id'], $objFiles->id, $objFile->path); $this->addRatingForImage($arrRating, $arrGallery['id'], $objFiles->id, $objFile->path);
} }
// Folders // Folders
@ -201,23 +207,23 @@ class RateItArticle extends RateItFrontend {
} else { } else {
$objSubfiles = \FilesModel::findByPid($objFiles->id); $objSubfiles = \FilesModel::findByPid($objFiles->id);
} }
if ($objSubfiles === null) { if ($objSubfiles === null) {
continue; continue;
} }
while ($objSubfiles->next()) { while ($objSubfiles->next()) {
// Skip subfolders // Skip subfolders
if ($objSubfiles->type == 'folder') { if ($objSubfiles->type == 'folder') {
continue; continue;
} }
$objFile = new \File($objSubfiles->path, true); $objFile = new \File($objSubfiles->path, true);
if (!$objFile->isGdImage) { if (!$objFile->isGdImage) {
continue; continue;
} }
$this->addRatingForImage($arrRating, $arrGallery['id'], $objSubfiles->id, $objSubfiles->path); $this->addRatingForImage($arrRating, $arrGallery['id'], $objSubfiles->id, $objSubfiles->path);
} }
} }
@ -226,27 +232,27 @@ class RateItArticle extends RateItFrontend {
$objTemplate->arrRating = $arrRating; $objTemplate->arrRating = $arrRating;
$GLOBALS['TL_JAVASCRIPT'][] = 'bundles/cgoitrateit/js/onReadyRateIt.js|static'; $GLOBALS['TL_JAVASCRIPT'][] = 'system/modules/rateit/public/js/onReadyRateIt.js|static';
$GLOBALS['TL_JAVASCRIPT'][] = 'bundles/cgoitrateit/js/rateit.js|static'; $GLOBALS['TL_JAVASCRIPT'][] = 'system/modules/rateit/public/js/rateit.js|static';
$GLOBALS['TL_CSS'][] = 'bundles/cgoitrateit/css/rateit.min.css||static'; $GLOBALS['TL_CSS'][] = 'system/modules/rateit/public/css/rateit.min.css||static';
switch ($GLOBALS['TL_CONFIG']['rating_type']) { switch ($GLOBALS['TL_CONFIG']['rating_type']) {
case 'hearts' : case 'hearts' :
$GLOBALS['TL_CSS'][] = 'bundles/cgoitrateit/css/heart.min.css||static'; $GLOBALS['TL_CSS'][] = 'system/modules/rateit/public/css/heart.min.css||static';
break; break;
default: default:
$GLOBALS['TL_CSS'][] = 'bundles/cgoitrateit/css/star.min.css||static'; $GLOBALS['TL_CSS'][] = 'system/modules/rateit/public/css/star.min.css||static';
} }
} }
return $objTemplate; return $objTemplate;
} }
private function addRatingForImage(&$arrRating, $galleryId, $picId, $picPath) { private function addRatingForImage(&$arrRating, $galleryId, $picId, $picPath) {
$ratingId = $galleryId.'|'.$picId; $ratingId = $galleryId.'|'.$picId;
$rating = $this->loadRating($ratingId, 'galpic'); $rating = $this->loadRating($ratingId, 'galpic');
$stars = !$rating ? 0 : $this->percentToStars($rating['rating']); $stars = !$rating ? 0 : $this->percentToStars($rating['rating']);
$percent = round($rating['rating'], 0)."%"; $percent = round($rating['rating'], 0)."%";
$arrRating[$picPath] = array(); $arrRating[$picPath] = array();
$arrRating[$picPath]['descriptionId'] = 'rateItRating-'.$ratingId.'-description'; $arrRating[$picPath]['descriptionId'] = 'rateItRating-'.$ratingId.'-description';
$arrRating[$picPath]['description'] = $this->getStarMessage($rating); $arrRating[$picPath]['description'] = $this->getStarMessage($rating);
@ -256,7 +262,7 @@ class RateItArticle extends RateItFrontend {
$arrRating[$picPath]['actRating'] = $this->percentToStars($rating['rating']); $arrRating[$picPath]['actRating'] = $this->percentToStars($rating['rating']);
$arrRating[$picPath]['maxRating'] = $this->intStars; $arrRating[$picPath]['maxRating'] = $this->intStars;
$arrRating[$picPath]['votes'] = $rating[totalRatings]; $arrRating[$picPath]['votes'] = $rating[totalRatings];
if ($this->strTextPosition == "before") { if ($this->strTextPosition == "before") {
$arrRating[$picPath]['showBefore'] = true; $arrRating[$picPath]['showBefore'] = true;
} }
@ -265,4 +271,4 @@ class RateItArticle extends RateItFrontend {
} }
} }
} }
?> ?>

View File

@ -32,7 +32,7 @@ namespace cgoIT\rateit;
class RateItBackend class RateItBackend
{ {
const path = 'bundles/cgoitrateit/'; const path = 'system/modules/rateit/';
/** /**
* Get a css file. * Get a css file.
@ -41,7 +41,7 @@ class RateItBackend
*/ */
public static function css($file) public static function css($file)
{ {
return self::path.'css/'. $file.'.css'; return self::path.'public/css/'. $file.'.css';
} // file } // file
/** /**
@ -51,7 +51,7 @@ class RateItBackend
*/ */
public static function js($file) public static function js($file)
{ {
return self::path.'js/'. $file.'.js'; return self::path.'public/js/'. $file.'.js';
} // file } // file
/** /**
@ -61,7 +61,7 @@ class RateItBackend
*/ */
public static function image($file) public static function image($file)
{ {
$url = self::path.'images/'; $url = self::path.'public/images/';
if (is_file(TL_ROOT.'/'.$url.$file.'.png')) return $url.$file.'.png'; if (is_file(TL_ROOT.'/'.$url.$file.'.png')) return $url.$file.'.png';
if (is_file(TL_ROOT.'/'.$url.$file.'.gif')) return $url.$file.'.gif'; if (is_file(TL_ROOT.'/'.$url.$file.'.gif')) return $url.$file.'.gif';
return $url.'default.png'; return $url.'default.png';

View File

@ -30,7 +30,7 @@
namespace cgoIT\rateit; namespace cgoIT\rateit;
class RateItBackendModule extends \BackendModule class rateitBackendModule extends \BackendModule
{ {
protected $strTemplate; protected $strTemplate;
protected $actions = array(); protected $actions = array();
@ -235,7 +235,7 @@ class RateItBackendModule extends \BackendModule
*/ */
protected function exportRatings() protected function exportRatings()
{ {
$this->import('StringUtil'); $this->import('String');
$rateit = &$this->Template->rateit; $rateit = &$this->Template->rateit;
$options['order'] = 'rating desc'; $options['order'] = 'rating desc';
@ -264,11 +264,11 @@ class RateItBackendModule extends \BackendModule
// Werte setzen // Werte setzen
foreach($rateit->ratingitems as $item) { foreach($rateit->ratingitems as $item) {
$arrItem = (array)$item; $arrItem = (array)$item;
$intColCounter = 0; $intColCounter = 0;
foreach(array_keys($this->arrExportHeader) as $key) { foreach(array_keys($this->arrExportHeader) as $key) {
$strVal = $arrItem[$key]; $strVal = $arrItem[$key];
$strVal = $this->StringUtil->decodeEntities($strVal); $strVal = $this->String->decodeEntities($strVal);
$strVal = preg_replace(array('/<br.*\/*>/si'), array("\n"), $strVal); $strVal = preg_replace(array('/<br.*\/*>/si'), array("\n"), $strVal);
$strVal = $this->convertEncoding($strVal, $GLOBALS['TL_CONFIG']['characterSet'], 'CP1252'); $strVal = $this->convertEncoding($strVal, $GLOBALS['TL_CONFIG']['characterSet'], 'CP1252');
@ -299,7 +299,7 @@ class RateItBackendModule extends \BackendModule
$xls->setcell(array("sheetname" => $strXlsSheet,"row" => $intRowCounter, "col" => $intColCounter, "data" => $strVal, "type" => $cellType, "vallign" => XLSXF_VALLIGN_TOP, "fontfamily" => XLSFONT_FAMILY_NORMAL)); $xls->setcell(array("sheetname" => $strXlsSheet,"row" => $intRowCounter, "col" => $intColCounter, "data" => $strVal, "type" => $cellType, "vallign" => XLSXF_VALLIGN_TOP, "fontfamily" => XLSFONT_FAMILY_NORMAL));
$intColCounter++; $intColCounter++;
} }
$intRowCounter++; $intRowCounter++;
} }
@ -449,7 +449,7 @@ class RateItBackendModule extends \BackendModule
'typ' => $typ 'typ' => $typ
); );
$this->import('StringUtil'); $this->import('String');
$rateit = &$this->Template->rateit; $rateit = &$this->Template->rateit;
// query ratings // query ratings
@ -480,11 +480,11 @@ class RateItBackendModule extends \BackendModule
// Werte setzen // Werte setzen
foreach($ext->ratings as $item) { foreach($ext->ratings as $item) {
$arrItem = (array)$item; $arrItem = (array)$item;
$intColCounter = 0; $intColCounter = 0;
foreach(array_keys($this->arrExportHeaderDetails) as $key) { foreach(array_keys($this->arrExportHeaderDetails) as $key) {
$strVal = $arrItem[$key]; $strVal = $arrItem[$key];
$strVal = $this->StringUtil->decodeEntities($strVal); $strVal = $this->String->decodeEntities($strVal);
$strVal = preg_replace(array('/<br.*\/*>/si'), array("\n"), $strVal); $strVal = preg_replace(array('/<br.*\/*>/si'), array("\n"), $strVal);
$strVal = $this->convertEncoding($strVal, $GLOBALS['TL_CONFIG']['characterSet'], 'CP1252'); $strVal = $this->convertEncoding($strVal, $GLOBALS['TL_CONFIG']['characterSet'], 'CP1252');
@ -509,7 +509,7 @@ class RateItBackendModule extends \BackendModule
$xls->setcell(array("sheetname" => $strXlsSheet,"row" => $intRowCounter, "col" => $intColCounter, "data" => $strVal, "type" => $cellType, "vallign" => XLSXF_VALLIGN_TOP, "fontfamily" => XLSFONT_FAMILY_NORMAL)); $xls->setcell(array("sheetname" => $strXlsSheet,"row" => $intRowCounter, "col" => $intColCounter, "data" => $strVal, "type" => $cellType, "vallign" => XLSXF_VALLIGN_TOP, "fontfamily" => XLSFONT_FAMILY_NORMAL));
$intColCounter++; $intColCounter++;
} }
$intRowCounter++; $intRowCounter++;
} }
@ -535,7 +535,7 @@ class RateItBackendModule extends \BackendModule
*/ */
protected function createPageUrl($aPage, $aParams = null) protected function createPageUrl($aPage, $aParams = null)
{ {
$url = 'contao?do='.$aPage; $url = \Environment::get('script') . '?do='.$aPage;
if (is_array($aParams)) { if (is_array($aParams)) {
foreach ($aParams as $key => $val) foreach ($aParams as $key => $val)
if ($val!='') if ($val!='')

View File

@ -30,69 +30,64 @@
namespace cgoIT\rateit; namespace cgoIT\rateit;
use cgoIT\rateit\RateItRating; class RateItFaq extends RateItFrontend {
class RateItFaq extends RateItFrontend {
var $rateItRating;
/** /**
* Initialize the controller * Initialize the controller
*/ */
public function __construct() { public function __construct() {
parent::__construct(); parent::__construct();
$this->rateItRating = new RateItRating();
} }
public function getContentElementRateIt($objRow, $strBuffer) { public function getContentElementRateIt($objRow, $strBuffer) {
if ($objRow->type == 'module') { if ($objRow->type == 'module') {
$objModule = $this->Database->prepare("SELECT * FROM tl_module WHERE id=? AND type IN ('faqpage', 'faqreader')") $objModule = $this->Database->prepare("SELECT * FROM tl_module WHERE id=? AND type IN ('faqpage', 'faqreader')")
->limit(1) ->limit(1)
->execute($objRow->module); ->execute($objRow->module);
if ($objModule->numRows == 1) { if ($objModule->numRows == 1) {
$this->faq_categories = deserialize($objModule->faq_categories); $this->faq_categories = deserialize($objModule->faq_categories);
if ($objModule->type == 'faqreader') { if ($objModule->type == 'faqreader') {
$strBuffer = $this->generateForFaqReader($objModule, $strBuffer); $strBuffer = $this->generateForFaqReader($objModule, $strBuffer);
} else { } else {
$strBuffer = $this->generateForFaqPage($objModule, $strBuffer); $strBuffer = $this->generateForFaqPage($objModule, $strBuffer);
} }
$GLOBALS['TL_JAVASCRIPT'][] = 'bundles/cgoitrateit/js/onReadyRateIt.js|static'; $GLOBALS['TL_JAVASCRIPT'][] = 'system/modules/rateit/public/js/onReadyRateIt.js|static';
$GLOBALS['TL_JAVASCRIPT'][] = 'bundles/cgoitrateit/js/rateit.js|static'; $GLOBALS['TL_JAVASCRIPT'][] = 'system/modules/rateit/public/js/rateit.js|static';
$GLOBALS['TL_CSS'][] = 'bundles/cgoitrateit/css/rateit.min.css||static'; $GLOBALS['TL_CSS'][] = 'system/modules/rateit/public/css/rateit.min.css||static';
switch ($GLOBALS['TL_CONFIG']['rating_type']) { switch ($GLOBALS['TL_CONFIG']['rating_type']) {
case 'hearts' : case 'hearts' :
$GLOBALS['TL_CSS'][] = 'bundles/cgoitrateit/css/heart.min.css||static'; $GLOBALS['TL_CSS'][] = 'system/modules/rateit/public/css/heart.min.css||static';
break; break;
default: default:
$GLOBALS['TL_CSS'][] = 'bundles/cgoitrateit/css/star.min.css||static'; $GLOBALS['TL_CSS'][] = 'system/modules/rateit/public/css/star.min.css||static';
} }
} }
} }
return $strBuffer; return $strBuffer;
} }
private function generateForFaqPage($objModule, $strBuffer) { private function generateForFaqPage($objModule, $strBuffer) {
$objFaq = $this->Database $objFaq = $this->Database
->execute("SELECT *, author AS authorId, (SELECT headline FROM tl_faq_category WHERE tl_faq_category.id=tl_faq.pid) AS category, (SELECT name FROM tl_user WHERE tl_user.id=tl_faq.author) AS author FROM tl_faq WHERE pid IN(" . implode(',', array_map('intval', $this->faq_categories)) . ")" . (!BE_USER_LOGGED_IN ? " AND published=1" : "")); ->execute("SELECT *, author AS authorId, (SELECT headline FROM tl_faq_category WHERE tl_faq_category.id=tl_faq.pid) AS category, (SELECT name FROM tl_user WHERE tl_user.id=tl_faq.author) AS author FROM tl_faq WHERE pid IN(" . implode(',', array_map('intval', $this->faq_categories)) . ")" . (!BE_USER_LOGGED_IN ? " AND published=1" : ""));
if ($objFaq->numRows < 1) { if ($objFaq->numRows < 1) {
return $strBuffer; return $strBuffer;
} }
$htmlBuffer = new \simple_html_dom(); $htmlBuffer = new \simple_html_dom();
$htmlBuffer->load($strBuffer); $htmlBuffer->load($strBuffer);
$arrFaqs = $objFaq->fetchAllAssoc(); $arrFaqs = $objFaq->fetchAllAssoc();
foreach ($arrFaqs as $arrFaq) { foreach ($arrFaqs as $arrFaq) {
$rating = $this->generateSingle($arrFaq, $strBuffer); $rating = $this->generateSingle($arrFaq, $strBuffer);
$h3 = $htmlBuffer->find('#'.$arrFaq['alias']); $h3 = $htmlBuffer->find('#'.$arrFaq['alias']);
if (is_array($h3) && count($h3) == 1) { if (is_array($h3) && count($h3) == 1) {
$section = $h3[0]->parent(); $section = $h3[0]->parent();
if ($arrFaq['rateit_position'] == 'before') { if ($arrFaq['rateit_position'] == 'before') {
$section->innertext = $rating.$section->innertext; $section->innertext = $rating.$section->innertext;
} else if ($arrFaq['rateit_position'] == 'after') { } else if ($arrFaq['rateit_position'] == 'after') {
@ -100,37 +95,37 @@ class RateItFaq extends RateItFrontend {
} }
} }
} }
$strBuffer = $htmlBuffer->save(); $strBuffer = $htmlBuffer->save();
// Aufräumen // Aufräumen
$htmlBuffer->clear(); $htmlBuffer->clear();
unset($htmlBuffer); unset($htmlBuffer);
return $strBuffer; return $strBuffer;
} }
private function generateForFaqReader($objModule, $strBuffer) { private function generateForFaqReader($objModule, $strBuffer) {
// Set the item from the auto_item parameter // Set the item from the auto_item parameter
if ($GLOBALS['TL_CONFIG']['useAutoItem'] && isset($_GET['auto_item'])) { if ($GLOBALS['TL_CONFIG']['useAutoItem'] && isset($_GET['auto_item'])) {
$this->Input->setGet('items', $this->Input->get('auto_item')); $this->Input->setGet('items', $this->Input->get('auto_item'));
} }
// Do not index or cache the page if no FAQ has been specified // Do not index or cache the page if no FAQ has been specified
if (!$this->Input->get('items')) { if (!$this->Input->get('items')) {
return $strBuffer; return $strBuffer;
} }
$objFaq = $this->Database->prepare("SELECT *, author AS authorId, (SELECT title FROM tl_faq_category WHERE tl_faq_category.id=tl_faq.pid) AS category, (SELECT name FROM tl_user WHERE tl_user.id=tl_faq.author) AS author FROM tl_faq WHERE pid IN(" . implode(',', array_map('intval', $this->faq_categories)) . ") AND (id=? OR alias=?)" . (!BE_USER_LOGGED_IN ? " AND published=1" : "")) $objFaq = $this->Database->prepare("SELECT *, author AS authorId, (SELECT title FROM tl_faq_category WHERE tl_faq_category.id=tl_faq.pid) AS category, (SELECT name FROM tl_user WHERE tl_user.id=tl_faq.author) AS author FROM tl_faq WHERE pid IN(" . implode(',', array_map('intval', $this->faq_categories)) . ") AND (id=? OR alias=?)" . (!BE_USER_LOGGED_IN ? " AND published=1" : ""))
->limit(1) ->limit(1)
->execute((is_numeric($this->Input->get('items')) ? $this->Input->get('items') : 0), $this->Input->get('items')); ->execute((is_numeric($this->Input->get('items')) ? $this->Input->get('items') : 0), $this->Input->get('items'));
if ($objFaq->numRows == 1) { if ($objFaq->numRows == 1) {
$arrFaq = $objFaq->fetchAssoc(); $arrFaq = $objFaq->fetchAssoc();
$rating = $this->generateSingle($arrFaq, $strBuffer); $rating = $this->generateSingle($arrFaq, $strBuffer);
} }
if ($arrFaq['rateit_position'] == 'before') { if ($arrFaq['rateit_position'] == 'before') {
$strBuffer = $rating.$strBuffer; $strBuffer = $rating.$strBuffer;
} else if ($arrFaq['rateit_position'] == 'after') { } else if ($arrFaq['rateit_position'] == 'after') {
@ -139,25 +134,26 @@ class RateItFaq extends RateItFrontend {
return $strBuffer; return $strBuffer;
} }
private function generateSingle($arrFaq, $strBuffer) { private function generateSingle($arrFaq, $strBuffer) {
$rating = ''; $rating = '';
if ($arrFaq['addRating']) { if ($arrFaq['addRating']) {
$actRecord = $this->Database->prepare("SELECT * FROM tl_rateit_items WHERE rkey=? and typ='faq'") $actRecord = $this->Database->prepare("SELECT * FROM tl_rateit_items WHERE rkey=? and typ='faq'")
->execute($arrFaq['id']) ->execute($arrFaq['id'])
->fetchAssoc(); ->fetchAssoc();
if ($actRecord['active']) { if ($actRecord['active']) {
$this->rateItRating->rkey = $arrFaq['id']; $this->import('rateit\\RateItRating', 'RateItRating');
$this->rateItRating->ratingType = 'faq'; $this->RateItRating->rkey = $arrFaq['id'];
$this->rateItRating->generate(); $this->RateItRating->ratingType = 'faq';
$this->RateItRating->generate();
$rating = $this->rateItRating->output();
$rating = $this->RateItRating->output();
} }
} }
return $rating; return $rating;
} }
} }
?> ?>

View File

@ -41,31 +41,31 @@ class RateItFrontend extends \Hybrid
* @var string * @var string
*/ */
protected $strPk = 'id'; protected $strPk = 'id';
/** /**
* Typ * Typ
* @var string * @var string
*/ */
protected $strType = 'hearts'; protected $strType = 'hearts';
/** /**
* Template * Template
* @var string * @var string
*/ */
protected $strTemplate = 'rateit_default'; protected $strTemplate = 'rateit_default';
/** /**
* Anzahl der Herzen/Sterne * Anzahl der Herzen/Sterne
* @var int * @var int
*/ */
protected $intStars = 5; protected $intStars = 5;
/** /**
* Textposition * Textposition
* @var string * @var string
*/ */
protected $strTextPosition = 'after'; protected $strTextPosition = 'after';
/** /**
* Initialize the controller * Initialize the controller
*/ */
@ -77,10 +77,10 @@ class RateItFrontend extends \Hybrid
elseif ($objElement instanceof \Model\Collection) { elseif ($objElement instanceof \Model\Collection) {
$this->strTable = $objElement->current()->getTable(); $this->strTable = $objElement->current()->getTable();
} }
$this->strKey = $this->strPk; $this->strKey = $this->strPk;
} }
$stars = intval($GLOBALS['TL_CONFIG']['rating_count']); $stars = intval($GLOBALS['TL_CONFIG']['rating_count']);
if ($stars > 0) { if ($stars > 0) {
$this->intStars = $stars; $this->intStars = $stars;
@ -110,7 +110,7 @@ class RateItFrontend extends \Hybrid
*/ */
protected function compile() { protected function compile() {
} }
public function getStarMessage($rating) { public function getStarMessage($rating) {
$this->loadLanguageFile('default'); $this->loadLanguageFile('default');
$stars = $this->percentToStars($rating['rating']); $stars = $this->percentToStars($rating['rating']);
@ -136,12 +136,12 @@ class RateItFrontend extends \Hybrid
public function loadRating($rkey, $typ) { public function loadRating($rkey, $typ) {
$SQL_GET_RATINGS = "SELECT i.rkey AS rkey, $SQL_GET_RATINGS = "SELECT i.rkey AS rkey,
i.title AS title, i.title AS title,
IFNULL(AVG(r.rating),0) AS rating, IFNULL(AVG(r.rating),0) AS rating,
COUNT( r.rating ) AS totalRatings COUNT( r.rating ) AS totalRatings
FROM tl_rateit_items i FROM tl_rateit_items i
LEFT OUTER JOIN tl_rateit_ratings r LEFT OUTER JOIN tl_rateit_ratings r
ON ( i.id = r.pid ) WHERE i.rkey = ? and typ=? and active='1' ON ( i.id = r.pid ) WHERE i.rkey = ? and typ=? and active='1'
GROUP BY i.rkey, i.title;"; GROUP BY i.rkey;";
$result = $this->Database->prepare($SQL_GET_RATINGS) $result = $this->Database->prepare($SQL_GET_RATINGS)
->execute($rkey, $typ) ->execute($rkey, $typ)
->fetchAssoc(); ->fetchAssoc();
@ -154,4 +154,4 @@ class RateItFrontend extends \Hybrid
} }
} }
?> ?>

View File

@ -66,15 +66,15 @@ abstract class RateItHybrid extends RateItFrontend
$this->strType = $GLOBALS['TL_CONFIG']['rating_type']; $this->strType = $GLOBALS['TL_CONFIG']['rating_type'];
$this->strTextPosition = $GLOBALS['TL_CONFIG']['rating_textposition']; $this->strTextPosition = $GLOBALS['TL_CONFIG']['rating_textposition'];
$GLOBALS['TL_JAVASCRIPT'][] = 'bundles/cgoitrateit/js/onReadyRateIt.js|static'; $GLOBALS['TL_JAVASCRIPT'][] = 'system/modules/rateit/public/js/onReadyRateIt.js|static';
$GLOBALS['TL_JAVASCRIPT'][] = 'bundles/cgoitrateit/js/rateit.js|static'; $GLOBALS['TL_JAVASCRIPT'][] = 'system/modules/rateit/public/js/rateit.js|static';
$GLOBALS['TL_CSS'][] = 'bundles/cgoitrateit/css/rateit.min.css||static'; $GLOBALS['TL_CSS'][] = 'system/modules/rateit/public/css/rateit.min.css||static';
switch ($this->strType) { switch ($this->strType) {
case 'hearts' : case 'hearts' :
$GLOBALS['TL_CSS'][] = 'bundles/cgoitrateit/css/heart.min.css||static'; $GLOBALS['TL_CSS'][] = 'system/modules/rateit/public/css/heart.min.css||static';
break; break;
default: default:
$GLOBALS['TL_CSS'][] = 'bundles/cgoitrateit/css/star.min.css||static'; $GLOBALS['TL_CSS'][] = 'system/modules/rateit/public/css/star.min.css||static';
} }
return parent::generate(); return parent::generate();

View File

@ -69,15 +69,15 @@ class RateItNews extends RateItFrontend {
$objTemplate->rateit_rating_after = true; $objTemplate->rateit_rating_after = true;
} }
$GLOBALS['TL_JAVASCRIPT'][] = 'bundles/cgoitrateit/js/onReadyRateIt.js|static'; $GLOBALS['TL_JAVASCRIPT'][] = 'system/modules/rateit/public/js/onReadyRateIt.js|static';
$GLOBALS['TL_JAVASCRIPT'][] = 'bundles/cgoitrateit/js/rateit.js|static'; $GLOBALS['TL_JAVASCRIPT'][] = 'system/modules/rateit/public/js/rateit.js|static';
$GLOBALS['TL_CSS'][] = 'bundles/cgoitrateit/css/rateit.min.css||static'; $GLOBALS['TL_CSS'][] = 'system/modules/rateit/public/css/rateit.min.css||static';
switch ($GLOBALS['TL_CONFIG']['rating_type']) { switch ($GLOBALS['TL_CONFIG']['rating_type']) {
case 'hearts' : case 'hearts' :
$GLOBALS['TL_CSS'][] = 'bundles/cgoitrateit/css/heart.min.css||static'; $GLOBALS['TL_CSS'][] = 'system/modules/rateit/public/css/heart.min.css||static';
break; break;
default: default:
$GLOBALS['TL_CSS'][] = 'bundles/cgoitrateit/css/star.min.css||static'; $GLOBALS['TL_CSS'][] = 'system/modules/rateit/public/css/star.min.css||static';
} }
} }
} }

View File

@ -29,36 +29,32 @@
namespace cgoIT\rateit; namespace cgoIT\rateit;
use cgoIT\rateit\RateItRating;
class RateItPage extends \Frontend { class RateItPage extends \Frontend {
var $rateItRating;
/** /**
* Initialize the controller * Initialize the controller
*/ */
public function __construct() { public function __construct() {
parent::__construct(); parent::__construct();
$this->rateItRating = new RateItRating();
$this->loadDataContainer('settings'); $this->loadDataContainer('settings');
} }
public function generatePage($objPage, $objLayout, $objPageType) { public function generatePage($objPage, $objLayout, $objPageType) {
if ($objPage->addRating) { if ($objPage->addRating) {
$actRecord = $this->Database->prepare("SELECT * FROM tl_rateit_items WHERE rkey=? and typ='page'") $actRecord = $this->Database->prepare("SELECT * FROM tl_rateit_items WHERE rkey=? and typ='page'")
->execute($objPage->id) ->execute($objPage->id)
->fetchAssoc(); ->fetchAssoc();
if ($actRecord['active']) { if ($actRecord['active']) {
$this->rateItRating->rkey = $objPage->id; $this->import('rateit\\RateItRating', 'RateItRating');
$this->rateItRating->generate(); $this->RateItRating->rkey = $objPage->id;
$this->RateItRating->generate();
$rating = $this->rateItRating->output();
$rating = $this->RateItRating->output();
$rating .= $this->includeJs(); $rating .= $this->includeJs();
$rating .= $this->includeCss(); $rating .= $this->includeCss();
$objTemplate = $objPageType->Template; $objTemplate = $objPageType->Template;
if ($objTemplate) { if ($objTemplate) {
if ($objPage->rateit_position == 'after') { if ($objPage->rateit_position == 'after') {
@ -76,7 +72,7 @@ class RateItPage extends \Frontend {
$strHeadTags = ''; $strHeadTags = '';
if (is_array($GLOBALS['TL_CSS'])) { if (is_array($GLOBALS['TL_CSS'])) {
foreach ($GLOBALS['TL_CSS'] as $script) { foreach ($GLOBALS['TL_CSS'] as $script) {
if ($this->startsWith($script, 'bundles/cgoitrateit/css/rateit') === true) { if ($this->startsWith($script, 'system/modules/rateit/public/css/rateit') === true) {
$included = true; $included = true;
break; break;
} }
@ -84,24 +80,24 @@ class RateItPage extends \Frontend {
} }
if (!$included) { if (!$included) {
$strHeadTags = '<link rel="stylesheet" href="'.$this->addStaticUrlTo('bundles/cgoitrateit/css/rateit.min.css').'">'; $strHeadTags = '<link rel="stylesheet" href="'.$this->addStaticUrlTo('system/modules/rateit/public/css/rateit.min.css').'">';
switch ($GLOBALS['TL_CONFIG']['rating_type']) { switch ($GLOBALS['TL_CONFIG']['rating_type']) {
case 'hearts' : case 'hearts' :
$strHeadTags .= '<link rel="stylesheet" href="'.$this->addStaticUrlTo('bundles/cgoitrateit/css/heart.min.css').'">'; $strHeadTags .= '<link rel="stylesheet" href="'.$this->addStaticUrlTo('system/modules/rateit/public/css/heart.min.css').'">';
break; break;
default: default:
$strHeadTags .= '<link rel="stylesheet" href="'.$this->addStaticUrlTo('bundles/cgoitrateit/css/star.min.css').'">'; $strHeadTags .= '<link rel="stylesheet" href="'.$this->addStaticUrlTo('system/modules/rateit/public/css/star.min.css').'">';
} }
} }
return $strHeadTags; return $strHeadTags;
} }
private function includeJs() { private function includeJs() {
$included = false; $included = false;
$strHeadTags = ''; $strHeadTags = '';
if (is_array($GLOBALS['TL_JAVASCRIPT'])) { if (is_array($GLOBALS['TL_JAVASCRIPT'])) {
foreach ($GLOBALS['TL_JAVASCRIPT'] as $script) { foreach ($GLOBALS['TL_JAVASCRIPT'] as $script) {
if ($this->startsWith($script, 'bundles/cgoitrateit/js/rateit') === true) { if ($this->startsWith($script, 'system/modules/rateit/public/js/rateit') === true) {
$included = true; $included = true;
break; break;
} }
@ -109,15 +105,15 @@ class RateItPage extends \Frontend {
} }
if (!$included) { if (!$included) {
$strHeadTags = '<script' . (($objPage->outputFormat == 'xhtml') ? ' type="text/javascript"' : '') . ' src="' . $this->addStaticUrlTo('bundles/cgoitrateit/js/onReadyRateIt.js') . '"></script>' . "\n"; $strHeadTags = '<script' . (($objPage->outputFormat == 'xhtml') ? ' type="text/javascript"' : '') . ' src="' . $this->addStaticUrlTo('system/modules/rateit/public/js/onReadyRateIt.js') . '"></script>' . "\n";
$strHeadTags .= '<script' . (($objPage->outputFormat == 'xhtml') ? ' type="text/javascript"' : '') . ' src="' . $this->addStaticUrlTo('bundles/cgoitrateit/js/rateit.js') . '"></script>' . "\n"; $strHeadTags .= '<script' . (($objPage->outputFormat == 'xhtml') ? ' type="text/javascript"' : '') . ' src="' . $this->addStaticUrlTo('system/modules/rateit/public/js/rateit.js') . '"></script>' . "\n";
} }
return $strHeadTags; return $strHeadTags;
} }
function startsWith($haystack, $needle) { function startsWith($haystack, $needle) {
// search backwards starting from haystack length characters from the end // search backwards starting from haystack length characters from the end
return $needle === "" || strrpos($haystack, $needle, -strlen($haystack)) !== FALSE; return $needle === "" || strrpos($haystack, $needle, -strlen($haystack)) !== FALSE;
} }
} }
?> ?>

View File

@ -36,13 +36,13 @@ namespace cgoIT\rateit;
class RateItTopRatingsModule extends RateItFrontend class RateItTopRatingsModule extends RateItFrontend
{ {
private static $arrUrlCache = array(); private static $arrUrlCache = array();
/** /**
* Initialize the controller * Initialize the controller
*/ */
public function __construct($objElement) { public function __construct($objElement) {
parent::__construct($objElement); parent::__construct($objElement);
$this->strKey = "rateit_top_ratings"; $this->strKey = "rateit_top_ratings";
} }
@ -62,22 +62,22 @@ class RateItTopRatingsModule extends RateItFrontend
return $objTemplate->parse(); return $objTemplate->parse();
} }
$this->strTemplate = $this->rateit_template; $this->strTemplate = $this->rateit_template;
$this->arrTypes = deserialize($this->rateit_types); $this->arrTypes = deserialize($this->rateit_types);
$GLOBALS['TL_JAVASCRIPT'][] = 'bundles/cgoitrateit/js/onReadyRateIt.js|static'; $GLOBALS['TL_JAVASCRIPT'][] = 'system/modules/rateit/public/js/onReadyRateIt.js|static';
$GLOBALS['TL_JAVASCRIPT'][] = 'bundles/cgoitrateit/js/rateit.js|static'; $GLOBALS['TL_JAVASCRIPT'][] = 'system/modules/rateit/public/js/rateit.js|static';
$GLOBALS['TL_CSS'][] = 'bundles/cgoitrateit/css/rateit.min.css||static'; $GLOBALS['TL_CSS'][] = 'system/modules/rateit/public/css/rateit.min.css||static';
switch ($GLOBALS['TL_CONFIG']['rating_type']) { switch ($GLOBALS['TL_CONFIG']['rating_type']) {
case 'hearts' : case 'hearts' :
$GLOBALS['TL_CSS'][] = 'bundles/cgoitrateit/css/heart.min.css||static'; $GLOBALS['TL_CSS'][] = 'system/modules/rateit/public/css/heart.min.css||static';
break; break;
default: default:
$GLOBALS['TL_CSS'][] = 'bundles/cgoitrateit/css/star.min.css||static'; $GLOBALS['TL_CSS'][] = 'system/modules/rateit/public/css/star.min.css||static';
} }
return parent::generate(); return parent::generate();
} }
@ -86,9 +86,9 @@ class RateItTopRatingsModule extends RateItFrontend
*/ */
protected function compile() { protected function compile() {
$this->Template = new \FrontendTemplate($this->strTemplate); $this->Template = new \FrontendTemplate($this->strTemplate);
$this->Template->setData($this->arrData); $this->Template->setData($this->arrData);
$this->import("\\Database", "Database"); $this->import("\\Database", "Database");
$arrResult = $this->Database->prepare("SELECT i.id AS item_id, $arrResult = $this->Database->prepare("SELECT i.id AS item_id,
i.rkey AS rkey, i.rkey AS rkey,
@ -114,32 +114,32 @@ class RateItTopRatingsModule extends RateItFrontend
$return = new \stdClass(); $return = new \stdClass();
$return->title = $result['title']; $return->title = $result['title'];
$return->typ = $result['typ']; $return->typ = $result['typ'];
// ID ermitteln // ID ermitteln
$stars = $this->percentToStars($result['best']); $stars = $this->percentToStars($result['best']);
$return->rateItID = 'rateItRating-'.$result['rkey'].'-'.$result['typ'].'-'. $return->rateItID = 'rateItRating-'.$result['rkey'].'-'.$result['typ'].'-'.
$stars.'_'.intval($GLOBALS['TL_CONFIG']['rating_count']); $stars.'_'.intval($GLOBALS['TL_CONFIG']['rating_count']);
$return->descriptionId = 'rateItRating-'.$result['rkey'].'-description'; $return->descriptionId = 'rateItRating-'.$result['rkey'].'-description';
$return->rateit_class = 'rateItRating'; $return->rateit_class = 'rateItRating';
$return->url = $this->getUrl($result); $return->url = $this->getUrl($result);
// Beschriftung ermitteln // Beschriftung ermitteln
$rating = array(); $rating = array();
$rating['totalRatings'] = $result['most']; $rating['totalRatings'] = $result['most'];
$rating['rating'] = $result['best']; $rating['rating'] = $result['best'];
$return->description = $this->getStarMessage($rating); $return->description = $this->getStarMessage($rating);
$return->rating = $result['best']; $return->rating = $result['best'];
$return->count = $result['most']; $return->count = $result['most'];
$return->rel = 'not-rateable'; $return->rel = 'not-rateable';
$objReturn[] = $return; $objReturn[] = $return;
} }
$this->Template->arrRatings = $objReturn; $this->Template->arrRatings = $objReturn;
} }
private function getUrl($rating) { private function getUrl($rating) {
if ($rating['typ'] === 'page') { if ($rating['typ'] === 'page') {
return \PageModel::findById($rating['rkey'])->getAbsoluteUrl(); return \PageModel::findById($rating['rkey'])->getAbsoluteUrl();
@ -153,25 +153,25 @@ class RateItTopRatingsModule extends RateItFrontend
if ($rating['typ'] === 'news') { if ($rating['typ'] === 'news') {
$objNews = \NewsModel::findById($rating['rkey']); $objNews = \NewsModel::findById($rating['rkey']);
$objArticle = \NewsModel::findPublishedByPid($objNews->pid); $objArticle = \NewsModel::findPublishedByPid($objNews->pid);
// Internal link // Internal link
if ($objArticle->source != 'external') { if ($objArticle->source != 'external') {
return $this->generateNewsUrl($objNews); return $this->generateNewsUrl($objNews);
} }
// Encode e-mail addresses // Encode e-mail addresses
if (substr($objArticle->url, 0, 7) == 'mailto:') { if (substr($objArticle->url, 0, 7) == 'mailto:') {
$strArticleUrl = \StringUtil::encodeEmail($objArticle->url); $strArticleUrl = \StringUtil::encodeEmail($objArticle->url);
} }
// Ampersand URIs // Ampersand URIs
else { else {
$strArticleUrl = ampersand($objArticle->url); $strArticleUrl = ampersand($objArticle->url);
} }
/** @var \PageModel $objPage */ /** @var \PageModel $objPage */
global $objPage; global $objPage;
// External link // External link
return $strArticleUrl; return $strArticleUrl;
} }
@ -180,15 +180,15 @@ class RateItTopRatingsModule extends RateItFrontend
private function generateNewsUrl($objItem) { private function generateNewsUrl($objItem) {
$strCacheKey = 'id_' . $objItem->id; $strCacheKey = 'id_' . $objItem->id;
// Load the URL from cache // Load the URL from cache
if (isset(self::$arrUrlCache[$strCacheKey])) { if (isset(self::$arrUrlCache[$strCacheKey])) {
return self::$arrUrlCache[$strCacheKey]; return self::$arrUrlCache[$strCacheKey];
} }
// Initialize the cache // Initialize the cache
self::$arrUrlCache[$strCacheKey] = null; self::$arrUrlCache[$strCacheKey] = null;
switch ($objItem->source) { switch ($objItem->source) {
// Link to an external page // Link to an external page
case 'external' : case 'external' :
@ -198,7 +198,7 @@ class RateItTopRatingsModule extends RateItFrontend
self::$arrUrlCache[$strCacheKey] = ampersand($objItem->url); self::$arrUrlCache[$strCacheKey] = ampersand($objItem->url);
} }
break; break;
// Link to an internal page // Link to an internal page
case 'internal' : case 'internal' :
if (($objTarget = $objItem->getRelated('jumpTo')) !== null) { if (($objTarget = $objItem->getRelated('jumpTo')) !== null) {
@ -206,7 +206,7 @@ class RateItTopRatingsModule extends RateItFrontend
self::$arrUrlCache[$strCacheKey] = ampersand($objTarget->getFrontendUrl()); self::$arrUrlCache[$strCacheKey] = ampersand($objTarget->getFrontendUrl());
} }
break; break;
// Link to an article // Link to an article
case 'article' : case 'article' :
if (($objArticle = \ArticleModel::findByPk($objItem->articleId, array( if (($objArticle = \ArticleModel::findByPk($objItem->articleId, array(
@ -217,25 +217,25 @@ class RateItTopRatingsModule extends RateItFrontend
} }
break; break;
} }
// Link to the default page // Link to the default page
if (self::$arrUrlCache[$strCacheKey] === null) { if (self::$arrUrlCache[$strCacheKey] === null) {
$objPage = \PageModel::findWithDetails($objItem->getRelated('pid')->jumpTo); $objPage = \PageModel::findWithDetails($objItem->getRelated('pid')->jumpTo);
if ($objPage === null) { if ($objPage === null) {
self::$arrUrlCache[$strCacheKey] = ampersand(\Environment::get('request'), true); self::$arrUrlCache[$strCacheKey] = ampersand(\Environment::get('request'), true);
} else { } else {
self::$arrUrlCache[$strCacheKey] = ampersand($objPage->getFrontendUrl(((\Config::get('useAutoItem') && ! \Config::get('disableAlias')) ? '/' : '/items/') . ((! \Config::get('disableAlias') && $objItem->alias != '') ? $objItem->alias : $objItem->id))); self::$arrUrlCache[$strCacheKey] = ampersand($objPage->getFrontendUrl(((\Config::get('useAutoItem') && ! \Config::get('disableAlias')) ? '/' : '/items/') . ((! \Config::get('disableAlias') && $objItem->alias != '') ? $objItem->alias : $objItem->id)));
} }
// Add the current archive parameter (news archive) // Add the current archive parameter (news archive)
if ($blnAddArchive && \Input::get('month') != '') { if ($blnAddArchive && \Input::get('month') != '') {
self::$arrUrlCache[$strCacheKey] .= (\Config::get('disableAlias') ? '&amp;' : '?') . 'month=' . \Input::get('month'); self::$arrUrlCache[$strCacheKey] .= (\Config::get('disableAlias') ? '&amp;' : '?') . 'month=' . \Input::get('month');
} }
} }
return self::$arrUrlCache[$strCacheKey]; return self::$arrUrlCache[$strCacheKey];
} }
} }
?> ?>

View File

@ -1,18 +1,9 @@
{ {
"name":"cgo-it/contao-rate-it-bundle", "name":"cgo-it/rate-it",
"description":"RateIt extension for the Contao Open Source CMS as contao 4 bundle", "description":"RateIt extension for the Contao Open Source CMS",
"keywords":["contao", "rating", "rateit", "bewertung", "bundle"], "keywords":["contao", "rating", "rateit", "bewertung"],
"type":"contao-bundle", "type":"contao-module",
"homepage":"https://cgo-it.de",
"license":"LGPL-3.0+", "license":"LGPL-3.0+",
"prefer-stable": true,
"config": {
"preferred-install": {
"cgo-it/*": "dist",
"*": "dist"
},
"gitlab-domains": [ "git.cgo-it.de" ]
},
"authors":[ "authors":[
{ {
"name":"cgo IT", "name":"cgo IT",
@ -22,46 +13,34 @@
} }
], ],
"support": { "support": {
"issues": "https://git.cgo-it.de/contao/rate-it/issues", "email": "info@cgo-it.de",
"issues": "https://bitbucket.org/cgo-it/contao-rate-it/issues?status=new&status=open",
"forum": "https://community.contao.org/de/showthread.php?38471-Rate-It", "forum": "https://community.contao.org/de/showthread.php?38471-Rate-It",
"source": "https://git.cgo-it.de/contao/rate-it.git" "source": "https://bitbucket.org/cgo-it/contao-rate-it/src"
}, },
"require":{ "require":{
"php":">=7.0", "php":">=5.3",
"contao/core-bundle": "^4.4", "contao/core":">=3.0",
"cgo-it/contao-xls_export-bundle": "^4.0" "contao-community-alliance/composer-plugin": "~2.0",
"cgo-it/xls_export":"3.0.0"
}, },
"require-dev": { "replace": {
"contao/manager-plugin": "^2.0" "cgo-it/rate-it": "<3.5.4"
}, },
"conflict": { "conflict": {
"contao/core": "*", "contao/core": "2.11.*"
"contao/manager-plugin": "<2.0 || >=3.0"
}, },
"repositories": [ "extra":{
{
"type": "gitlab",
"url": "https://git.cgo-it.de/contao/rate-it.git"
}
],
"autoload": {
"psr-4": {
"cgoIT\\rateit\\": "src/"
},
"classmap": [
"src/Resources/contao/"
],
"exclude-from-classmap": [
"src/Resources/contao/config/",
"src/Resources/contao/dca/",
"src/Resources/contao/languages/",
"src/Resources/contao/templates/"
]
},
"extra": {
"contao": { "contao": {
"runonce": ["src/Resources/contao/runonce/create-initial-data.php"] "sources":{
}, "":"system/modules/rateit"
"contao-manager-plugin": "cgoIT\\rateit\\ContaoManagerPlugin" },
"transifex":{
"project": "rateit",
"prefix": "core-",
"languages_cto": "languages",
"languages_tx": "languages"
}
}
} }
} }

7
config/autoload.ini Normal file
View File

@ -0,0 +1,7 @@
;;
; Configure what you want the autoload creator to register
;;
register_namespaces = true
register_classes = true
register_templates = true

73
config/autoload.php Normal file
View File

@ -0,0 +1,73 @@
<?php
/**
* Contao Open Source CMS
*
* Copyright (c) 2005-2014 Leo Feyer
*
* @package Rateit
* @link https://contao.org
* @license http://www.gnu.org/licenses/lgpl-3.0.html LGPL
*/
/**
* Register the namespaces
*/
ClassLoader::addNamespaces(array
(
'cgoIT',
));
/**
* Register the classes
*/
ClassLoader::addClasses(array
(
// Classes
'cgoIT\rateit\DcaHelper' => 'system/modules/rateit/classes/DcaHelper.php',
'cgoIT\rateit\RateItArticle' => 'system/modules/rateit/classes/RateItArticle.php',
'cgoIT\rateit\RateItBackend' => 'system/modules/rateit/classes/RateItBackend.php',
'cgoIT\rateit\RateItCE' => 'system/modules/rateit/classes/RateItCE.php',
'cgoIT\rateit\RateItFaq' => 'system/modules/rateit/classes/RateItFaq.php',
'cgoIT\rateit\RateItFrontend' => 'system/modules/rateit/classes/RateItFrontend.php',
'cgoIT\rateit\RateItHybrid' => 'system/modules/rateit/classes/RateItHybrid.php',
'cgoIT\rateit\RateItModule' => 'system/modules/rateit/classes/RateItModule.php',
'cgoIT\rateit\RateItNews' => 'system/modules/rateit/classes/RateItNews.php',
'cgoIT\rateit\RateItPage' => 'system/modules/rateit/classes/RateItPage.php',
'cgoIT\rateit\RateItRating' => 'system/modules/rateit/classes/RateItRating.php',
'cgoIT\rateit\RateItBackendModule' => 'system/modules/rateit/classes/RateItBackendModule.php',
'cgoIT\rateit\RateItTopRatingsModule' => 'system/modules/rateit/classes/RateItTopRatingsModule.php',
'cgoIT\rateit\RateIt' => 'system/modules/rateit/public/php/rateit.php',
'simple_html_dom' => 'system/modules/rateit/classes/extern/simple_html_dom.php',
));
/**
* Register the templates
*/
TemplateLoader::addFiles(array
(
'article_rateit_default' => 'system/modules/rateit/templates',
'article_rateit_default_microdata' => 'system/modules/rateit/templates',
'gallery_rateit_default' => 'system/modules/rateit/templates',
'j_colorbox_rateit' => 'system/modules/rateit/templates',
'mod_article_list_rateit' => 'system/modules/rateit/templates',
'mod_article_rateit_default_microdata_teaser' => 'system/modules/rateit/templates',
'mod_article_rateit_default_teaser' => 'system/modules/rateit/templates',
'mod_rateit_top_ratings' => 'system/modules/rateit/templates',
'moo_mediabox_rateit' => 'system/modules/rateit/templates',
'news_full_rateit' => 'system/modules/rateit/templates',
'news_full_rateit_microdata' => 'system/modules/rateit/templates',
'news_latest_rateit' => 'system/modules/rateit/templates',
'news_latest_rateit_microdata' => 'system/modules/rateit/templates',
'news_short_rateit' => 'system/modules/rateit/templates',
'news_short_rateit_microdata' => 'system/modules/rateit/templates',
'news_simple_rateit' => 'system/modules/rateit/templates',
'news_simple_rateit_microdata' => 'system/modules/rateit/templates',
'rateitbe_ratinglist' => 'system/modules/rateit/templates',
'rateitbe_ratingview' => 'system/modules/rateit/templates',
'rateit_default' => 'system/modules/rateit/templates',
'rateit_microdata' => 'system/modules/rateit/templates',
));

View File

@ -33,32 +33,33 @@ use cgoIT\rateit\RateItBackend;
/** /**
* Hooks * Hooks
*/ */
$GLOBALS['TL_HOOKS']['generatePage'][] = array('cgoIT\rateit\RateItPage', 'generatePage'); $GLOBALS['TL_HOOKS']['generatePage'][] = array('rateit\\RateItPage', 'generatePage');
$GLOBALS['TL_HOOKS']['parseArticles'][] = array('cgoIT\rateit\RateItNews', 'parseArticle'); $GLOBALS['TL_HOOKS']['rateitAjax'][] = array('rateit\\RateIt', 'doVote');
$GLOBALS['TL_HOOKS']['getContentElement'][] = array('cgoIT\rateit\RateItFaq', 'getContentElementRateIt'); $GLOBALS['TL_HOOKS']['parseArticles'][] = array('rateit\\RateItNews', 'parseArticle');
$GLOBALS['TL_HOOKS']['parseTemplate'][] = array('cgoIT\rateit\RateItArticle', 'parseTemplateRateIt'); $GLOBALS['TL_HOOKS']['getContentElement'][] = array('rateit\\RateItFaq', 'getContentElementRateIt');
$GLOBALS['TL_HOOKS']['parseTemplate'][] = array('rateit\\RateItArticle', 'parseTemplateRateIt');
/** /**
* Back end modules * Back end modules
*/ */
array_insert($GLOBALS['BE_MOD']['content'], -1, array_insert($GLOBALS['BE_MOD']['content'], count($GLOBALS['BE_MOD']['content']),
array('rateit' => array ( array('rateit' => array (
'callback' => 'cgoIT\rateit\RateItBackendModule', 'callback' => 'rateit\\RateItBackendModule',
'icon' => RateItBackend::image('icon'), 'icon' => rateit\RateItBackend::image('icon'),
'stylesheet' => RateItBackend::css('backend'), 'stylesheet' => rateit\RateItBackend::css('backend'),
'javascript' => RateItBackend::js('RateItBackend') 'javascript' => rateit\RateItBackend::js('RateItBackend')
) )
)); ));
/** /**
* frontend moduls * frontend moduls
*/ */
$GLOBALS['FE_MOD']['application']['rateit'] = 'cgoIT\rateit\RateItModule'; $GLOBALS['FE_MOD']['application']['rateit'] = 'rateit\\RateItModule';
$GLOBALS['FE_MOD']['application']['rateit_top_ratings'] = 'cgoIT\rateit\RateItTopRatingsModule'; $GLOBALS['FE_MOD']['application']['rateit_top_ratings'] = 'rateit\\RateItTopRatingsModule';
/** /**
* content elements * content elements
*/ */
$GLOBALS['TL_CTE']['includes']['rateit'] = 'cgoIT\rateit\RateItCE'; $GLOBALS['TL_CTE']['includes']['rateit'] = 'rateit\\RateItCE';
?> ?>

View File

@ -27,9 +27,8 @@
* @license GNU/LGPL * @license GNU/LGPL
* @filesource * @filesource
*/ */
use cgoIT\rateit\DcaHelper;
/** /**
* Extend tl_article * Extend tl_article
*/ */
@ -70,13 +69,40 @@ $GLOBALS['TL_DCA']['tl_article']['fields']['rateit_position'] = array
'eval' => array('mandatory'=>true, 'tl_class'=>'w50') 'eval' => array('mandatory'=>true, 'tl_class'=>'w50')
); );
class tl_article_rating extends DcaHelper { $GLOBALS['TL_DCA']['tl_article']['fields']['rateit_template'] = array
(
'label' => &$GLOBALS['TL_LANG']['tl_article']['rateit_template'],
'default' => 'rateit_default',
'exclude' => true,
'inputType' => 'select',
'options_callback' => array('tl_article_rating', 'getRateItArticleTemplates'),
'sql' => "varchar(255) NOT NULL default ''",
'eval' => array('mandatory'=>true, 'tl_class'=>'w50')
);
class tl_article_rating extends rateit\DcaHelper {
/** /**
* Constructor * Constructor
*/ */
public function __construct() { public function __construct() {
parent::__construct(); parent::__construct();
} }
/**
* Return all navigation templates as array
* @param DataContainer
* @return array
*/
public function getRateItArticleTemplates(\DataContainer $dc) {
$intPid = $dc->activeRecord->pid;
if ($this->Input->get('act') == 'overrideAll')
{
$intPid = $this->Input->get('id');
}
return $this->getTemplateGroup('article_rateit_', $intPid);
}
public function insert(\DC_Table $dc) { public function insert(\DC_Table $dc) {
return $this->insertOrUpdateRatingKey($dc, 'article', $dc->activeRecord->title); return $this->insertOrUpdateRatingKey($dc, 'article', $dc->activeRecord->title);

View File

@ -28,8 +28,6 @@
* @filesource * @filesource
*/ */
use cgoIT\rateit\DcaHelper;
$GLOBALS['TL_DCA']['tl_content']['config']['onsubmit_callback'][] = array('tl_content_rateit','insert'); $GLOBALS['TL_DCA']['tl_content']['config']['onsubmit_callback'][] = array('tl_content_rateit','insert');
$GLOBALS['TL_DCA']['tl_content']['config']['ondelete_callback'][] = array('tl_content_rateit','delete'); $GLOBALS['TL_DCA']['tl_content']['config']['ondelete_callback'][] = array('tl_content_rateit','delete');
@ -64,7 +62,7 @@ $GLOBALS['TL_DCA']['tl_content']['fields']['rateit_active'] = array
/** /**
* Class tl_content_rateit * Class tl_content_rateit
*/ */
class tl_content_rateit extends DcaHelper { class tl_content_rateit extends rateit\DcaHelper {
/** /**
* Constructor * Constructor
@ -72,31 +70,31 @@ class tl_content_rateit extends DcaHelper {
public function __construct() { public function __construct() {
parent::__construct(); parent::__construct();
} }
public function insert(\DC_Table $dc) { public function insert(\DC_Table $dc) {
if ($dc->activeRecord->type == "gallery") { if ($dc->activeRecord->type == "gallery") {
$type = 'galpic'; $type = 'galpic';
// Alle vorherigen Bilder erst mal auf inaktiv setzen // Alle vorherigen Bilder erst mal auf inaktiv setzen
$this->Database->prepare("UPDATE tl_rateit_items SET active='' WHERE rkey LIKE ? AND typ=?")->execute($dc->activeRecord->id.'|%', $type); $this->Database->prepare("UPDATE tl_rateit_items SET active='' WHERE rkey LIKE ? AND typ=?")->execute($dc->activeRecord->id.'|%', $type);
if (version_compare(VERSION, '3.2', '>=')) { if (version_compare(VERSION, '3.2', '>=')) {
$objFiles = \FilesModel::findMultipleByUuids(deserialize($dc->activeRecord->multiSRC)); $objFiles = \FilesModel::findMultipleByUuids(deserialize($dc->activeRecord->multiSRC));
} else { } else {
$objFiles = \FilesModel::findMultipleByIds(deserialize($dc->activeRecord->multiSRC)); $objFiles = \FilesModel::findMultipleByIds(deserialize($dc->activeRecord->multiSRC));
} }
if ($objFiles !== null) { if ($objFiles !== null) {
// Get all images // Get all images
while ($objFiles->next()) { while ($objFiles->next()) {
// Single files // Single files
if ($objFiles->type == 'file') { if ($objFiles->type == 'file') {
$objFile = new \File($objFiles->path, true); $objFile = new \File($objFiles->path, true);
if (!$objFile->isGdImage) { if (!$objFile->isGdImage) {
continue; continue;
} }
$this->insertOrUpdateRatingItemGallery($dc, $type, $objFile->name, $objFiles->id, ($dc->activeRecord->rateit_active ? '1' : '')); $this->insertOrUpdateRatingItemGallery($dc, $type, $objFile->name, $objFiles->id, ($dc->activeRecord->rateit_active ? '1' : ''));
} }
// Folders // Folders
@ -106,23 +104,23 @@ class tl_content_rateit extends DcaHelper {
} else { } else {
$objSubfiles = \FilesModel::findByPid($objFiles->id); $objSubfiles = \FilesModel::findByPid($objFiles->id);
} }
if ($objSubfiles === null) { if ($objSubfiles === null) {
continue; continue;
} }
while ($objSubfiles->next()) { while ($objSubfiles->next()) {
// Skip subfolders // Skip subfolders
if ($objSubfiles->type == 'folder') { if ($objSubfiles->type == 'folder') {
continue; continue;
} }
$objFile = new \File($objSubfiles->path, true); $objFile = new \File($objSubfiles->path, true);
if (!$objFile->isGdImage) { if (!$objFile->isGdImage) {
continue; continue;
} }
$this->insertOrUpdateRatingItemGallery($dc, $type, $objSubfiles->name, $objSubfiles->id, ($dc->activeRecord->rateit_active ? '1' : '')); $this->insertOrUpdateRatingItemGallery($dc, $type, $objSubfiles->name, $objSubfiles->id, ($dc->activeRecord->rateit_active ? '1' : ''));
} }
} }
@ -144,7 +142,7 @@ class tl_content_rateit extends DcaHelper {
return $this->deleteRatingKey($dc, 'ce'); return $this->deleteRatingKey($dc, 'ce');
} }
} }
private function insertOrUpdateRatingItemGallery(\DC_Table &$dc, $type, $strName, $imgId, $active) { private function insertOrUpdateRatingItemGallery(\DC_Table &$dc, $type, $strName, $imgId, $active) {
$rkey = $dc->activeRecord->id.'|'.$imgId; $rkey = $dc->activeRecord->id.'|'.$imgId;
$headline = deserialize($dc->activeRecord->headline); $headline = deserialize($dc->activeRecord->headline);
@ -175,4 +173,4 @@ class tl_content_rateit extends DcaHelper {
} }
} }
} }
?> ?>

View File

@ -27,9 +27,8 @@
* @license GNU/LGPL * @license GNU/LGPL
* @filesource * @filesource
*/ */
use cgoIT\rateit\DcaHelper;
/** /**
* Extend tl_article * Extend tl_article
*/ */
@ -70,14 +69,14 @@ $GLOBALS['TL_DCA']['tl_faq']['fields']['rateit_position'] = array
'eval' => array('mandatory'=>true, 'tl_class'=>'w50') 'eval' => array('mandatory'=>true, 'tl_class'=>'w50')
); );
class tl_faq_rating extends DcaHelper { class tl_faq_rating extends rateit\DcaHelper {
/** /**
* Constructor * Constructor
*/ */
public function __construct() { public function __construct() {
parent::__construct(); parent::__construct();
} }
public function insert(\DC_Table $dc) { public function insert(\DC_Table $dc) {
return $this->insertOrUpdateRatingKey($dc, 'faq', $dc->activeRecord->question); return $this->insertOrUpdateRatingKey($dc, 'faq', $dc->activeRecord->question);
} }

View File

@ -1,4 +1,4 @@
<?php <?php
/** /**
* Contao Open Source CMS * Contao Open Source CMS
@ -28,8 +28,6 @@
* @filesource * @filesource
*/ */
use cgoIT\rateit\DcaHelper;
$GLOBALS['TL_DCA']['tl_module']['config']['onsubmit_callback'][] = array('tl_module_rateit','insert'); $GLOBALS['TL_DCA']['tl_module']['config']['onsubmit_callback'][] = array('tl_module_rateit','insert');
$GLOBALS['TL_DCA']['tl_module']['config']['ondelete_callback'][] = array('tl_module_rateit','delete'); $GLOBALS['TL_DCA']['tl_module']['config']['ondelete_callback'][] = array('tl_module_rateit','delete');
@ -109,7 +107,7 @@ $GLOBALS['TL_DCA']['tl_module']['fields']['rateit_template'] = array
/** /**
* Class tl_module_rateit * Class tl_module_rateit
*/ */
class tl_module_rateit extends DcaHelper { class tl_module_rateit extends rateit\DcaHelper {
/** /**
* Constructor * Constructor
@ -117,7 +115,7 @@ class tl_module_rateit extends DcaHelper {
public function __construct() { public function __construct() {
parent::__construct(); parent::__construct();
} }
public function insert(\DC_Table $dc) { public function insert(\DC_Table $dc) {
return $this->insertOrUpdateRatingKey($dc, 'module', $dc->activeRecord->rateit_title); return $this->insertOrUpdateRatingKey($dc, 'module', $dc->activeRecord->rateit_title);
} }
@ -139,4 +137,4 @@ class tl_module_rateit extends DcaHelper {
return $this->getTemplateGroup('mod_rateit_top', $intPid); return $this->getTemplateGroup('mod_rateit_top', $intPid);
} }
} }
?> ?>

View File

@ -27,9 +27,8 @@
* @license GNU/LGPL * @license GNU/LGPL
* @filesource * @filesource
*/ */
use cgoIT\rateit\DcaHelper;
/** /**
* Extend tl_article * Extend tl_article
*/ */
@ -70,14 +69,14 @@ $GLOBALS['TL_DCA']['tl_news']['fields']['rateit_position'] = array
'eval' => array('mandatory'=>true, 'tl_class'=>'w50') 'eval' => array('mandatory'=>true, 'tl_class'=>'w50')
); );
class tl_news_rating extends DcaHelper { class tl_news_rating extends rateit\DcaHelper {
/** /**
* Constructor * Constructor
*/ */
public function __construct() { public function __construct() {
parent::__construct(); parent::__construct();
} }
public function insert(\DC_Table $dc) { public function insert(\DC_Table $dc) {
return $this->insertOrUpdateRatingKey($dc, 'news', $dc->activeRecord->headline); return $this->insertOrUpdateRatingKey($dc, 'news', $dc->activeRecord->headline);
} }

View File

@ -27,10 +27,8 @@
* @license GNU/LGPL * @license GNU/LGPL
* @filesource * @filesource
*/ */
use cgoIT\rateit\DcaHelper;
/** /**
* Extend tl_page * Extend tl_page
*/ */
@ -83,14 +81,14 @@ $GLOBALS['TL_DCA']['tl_page']['fields']['rateit_position'] = array
'eval' => array('mandatory'=>true, 'tl_class'=>'w50') 'eval' => array('mandatory'=>true, 'tl_class'=>'w50')
); );
class tl_page_rateit extends DcaHelper { class tl_page_rateit extends rateit\DcaHelper {
/** /**
* Constructor * Constructor
*/ */
public function __construct() { public function __construct() {
parent::__construct(); parent::__construct();
} }
public function insert(\DC_Table $dc) { public function insert(\DC_Table $dc) {
return $this->insertOrUpdateRatingKey($dc, 'page', $dc->activeRecord->title); return $this->insertOrUpdateRatingKey($dc, 'page', $dc->activeRecord->title);
} }

View File

@ -28,8 +28,6 @@
* @filesource * @filesource
*/ */
use cgoIT\rateit\DcaHelper;
/** /**
* palettes * palettes
*/ */
@ -115,7 +113,21 @@ $GLOBALS['TL_DCA']['tl_settings']['fields']['rating_description'] = array
'eval' => array('mandatory'=>true, 'allowHtml'=>true, 'tl_class'=>'w50') 'eval' => array('mandatory'=>true, 'allowHtml'=>true, 'tl_class'=>'w50')
); );
class tl_settings_rateit extends DcaHelper class tl_settings_rateit extends rateit\DcaHelper
{ {
public function getUserFullName() {
$this->import('jicw\\JICWHelper', 'JICWHelper');
return $this->JICWHelper->getUserFullName();
}
public function getUserEmail() {
$this->import('jicw\\JICWHelper', 'JICWHelper');
return $this->JICWHelper->getUserEmail();
}
public function getInstalledModules() {
$this->import('jicw\\JICWHelper', 'JICWHelper');
return $this->JICWHelper->getInstalledModules();
}
} }
?> ?>

View File

@ -48,10 +48,10 @@
text-align:left; text-align:left;
line-height:1; line-height:1;
} }
.mod_rateit table th.selectall { .mod_rateit table th.selectall {
background-color:#fff; background-color:#fff;
} }
.mod_rateit table.rating-selectall { .mod_rateit table.rating-selectall {
border:0px; border:0px;
} }
.mod_rateit table th { background-color:#fbf7f1; } .mod_rateit table th { background-color:#fbf7f1; }
@ -116,12 +116,11 @@
} }
.mod_rateit div.ratebartext { margin-left:65px; } .mod_rateit div.ratebartext { margin-left:65px; }
.mod_rateit a.header_export_excel{ .mod_rateit a.header_export_excel{
padding:2px 0 3px 20px; padding:2px 0 3px 20px;
background-image:url("../images/exportEXCEL.svg"); background-image:url("../images/exportEXCEL.gif");
background-size: 16px 16px;
background-position:left center; background-position:left center;
background-repeat:no-repeat; background-repeat:no-repeat;
} }
.mod_rateit div.chart { .mod_rateit div.chart {

View File

Before

Width:  |  Height:  |  Size: 847 B

After

Width:  |  Height:  |  Size: 847 B

View File

Before

Width:  |  Height:  |  Size: 392 B

After

Width:  |  Height:  |  Size: 392 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 282 B

View File

Before

Width:  |  Height:  |  Size: 1.4 KiB

After

Width:  |  Height:  |  Size: 1.4 KiB

View File

Before

Width:  |  Height:  |  Size: 722 B

After

Width:  |  Height:  |  Size: 722 B

View File

Before

Width:  |  Height:  |  Size: 354 B

After

Width:  |  Height:  |  Size: 354 B

View File

Before

Width:  |  Height:  |  Size: 625 B

After

Width:  |  Height:  |  Size: 625 B

View File

Before

Width:  |  Height:  |  Size: 815 B

After

Width:  |  Height:  |  Size: 815 B

View File

@ -3,24 +3,24 @@ var RateItRating;
function doRateIt() { function doRateIt() {
if (window.MooTools) { if (window.MooTools) {
var RateItRatings = new Class({ var RateItRatings = new Class({
Implements: Options, Implements: Options,
options: { options: {
step: 0.1, /* Schrittweite */ step: 0.1, /* Schrittweite */
readonly: false, /* Bewertungen zulassen */ readonly: false, /* Bewertungen zulassen */
resetable: false /* Nicht zurücksetzbar */ resetable: false /* Nicht zurücksetzbar */
}, },
initialize: function(options) { initialize: function(options) {
this.setOptions(options); this.setOptions(options);
$$('.rateItRating').each(function(el) { $$('.rateItRating').each(function(el) {
this.initMe(el); this.initMe(el);
}.bind(this)); }.bind(this));
}, },
initMe: function(el) { initMe: function(el) {
//Does this if the browser is NOT IE6. IE6 users don't deserve fancy ratings. >:( //Does this if the browser is NOT IE6. IE6 users don't deserve fancy ratings. >:(
if (!Browser.ie || Browser.version > 6) { if (!Browser.ie || Browser.version > 6) {
@ -31,7 +31,7 @@ function doRateIt() {
el.selected = el.wrapper.getElement('.rateItRating-selected'); el.selected = el.wrapper.getElement('.rateItRating-selected');
el.hover = el.wrapper.getElement('.rateItRating-hover'); el.hover = el.wrapper.getElement('.rateItRating-hover');
el.widthFx = new Fx.Tween(el.selected, {property:'width', link:'chain'}); el.widthFx = new Fx.Tween(el.selected, {property:'width', link:'chain'});
var backgroundImage = this.getBackgroundImage(el.wrapper); var backgroundImage = this.getBackgroundImage(el.wrapper);
this.options.starwidth = backgroundImage.width; this.options.starwidth = backgroundImage.width;
this.options.starheight = backgroundImage.height / 3; // da immer drei Sterne "übereinander" gebraucht werden this.options.starheight = backgroundImage.height / 3; // da immer drei Sterne "übereinander" gebraucht werden
@ -41,77 +41,77 @@ function doRateIt() {
if (this.options.starheight === undefined || this.options.starheight < 16) { if (this.options.starheight === undefined || this.options.starheight < 16) {
this.options.starheight = 16; this.options.starheight = 16;
} }
this.setBackgroundPosition(el.selected, -1 * this.options.starheight); this.setBackgroundPosition(el.selected, -1 * this.options.starheight);
this.setBackgroundPosition(el.hover, -1 * 2 * this.options.starheight); this.setBackgroundPosition(el.hover, -1 * 2 * this.options.starheight);
el.starPercent = this.getStarPercent(el.id); el.starPercent = this.getStarPercent(el.id);
el.ratableId = this.getRatableId(el.id); el.ratableId = this.getRatableId(el.id);
el.ratableType = this.getRatableType(el.id); el.ratableType = this.getRatableType(el.id);
// Maximalwert (=Anzahl Sterne) ermitteln // Maximalwert (=Anzahl Sterne) ermitteln
this.options.max = this.getRatableMaxValue(el.id); this.options.max = this.getRatableMaxValue(el.id);
// Höhe für selected und hover einstellen // Höhe für selected und hover einstellen
el.selected.setStyle('height', this.options.starheight); el.selected.setStyle('height', this.options.starheight);
el.hover.setStyle('height', this.options.starheight); el.hover.setStyle('height', this.options.starheight);
// Wrapper-Größe so anpassen, dass alle Sterne angezeigt werden // Wrapper-Größe so anpassen, dass alle Sterne angezeigt werden
el.wrapper.setStyle('width', this.options.starwidth * this.options.max); el.wrapper.setStyle('width', this.options.starwidth * this.options.max);
el.wrapper.setStyle('height', this.options.starheight); el.wrapper.setStyle('height', this.options.starheight);
// Breite des rateItRating-selected divs setzen // Breite des rateItRating-selected divs setzen
this.fillVote(el.starPercent, el); this.fillVote(el.starPercent, el);
// Breite f<>r rateItRating-selected div ermitteln // Breite f<>r rateItRating-selected div ermitteln
el.currentFill = this.getFillPercent(el.starPercent); el.currentFill = this.getFillPercent(el.starPercent);
if (el.rateable) { if (el.rateable) {
el.mouseCrap = function(e) { el.mouseCrap = function(e) {
var fill = e.event.layerX; var fill = e.event.layerX;
if (!fill) { if (!fill) {
fill = e.event.offsetX; fill = e.event.offsetX;
} }
var fillPercent = this.getVotePercent(fill); var fillPercent = this.getVotePercent(fill);
var nextStep = Math.ceil((fillPercent / 100) * this.options.max); var nextStep = Math.ceil((fillPercent / 100) * this.options.max);
var w = nextStep * this.options.starwidth; var w = nextStep * this.options.starwidth;
if (el.hover.getStyle('width').toInt() != w) { if (el.hover.getStyle('width').toInt() != w) {
el.selected.setStyle('display', 'none'); el.selected.setStyle('display', 'none');
el.hover.setStyle('width', Math.min(w, this.options.starwidth * this.options.max)); el.hover.setStyle('width', Math.min(w, this.options.starwidth * this.options.max));
el.hover.setStyle('display', 'block'); el.hover.setStyle('display', 'block');
} }
var newFill = nextStep / this.options.max * 100; var newFill = nextStep / this.options.max * 100;
this.fillVote(newFill, el); this.fillVote(newFill, el);
}.bind(this); }.bind(this);
el.wrapper.addEvent('mouseenter', function(e) { el.wrapper.addEvent('mouseenter', function(e) {
el.wrapper.addEvent('mousemove', el.mouseCrap); el.wrapper.addEvent('mousemove', el.mouseCrap);
}); });
el.wrapper.addEvent('mouseleave', function(e) { el.wrapper.addEvent('mouseleave', function(e) {
el.removeEvent('mousemove'); el.removeEvent('mousemove');
el.hover.setStyle('width', 0); el.hover.setStyle('width', 0);
el.hover.setStyle('display', 'none'); el.hover.setStyle('display', 'none');
el.selected.setStyle('display', 'block'); el.selected.setStyle('display', 'block');
el.widthFx.start(el.currentFill); el.widthFx.start(el.currentFill);
}); });
el.wrapper.addEvent('click', function(e) { el.wrapper.addEvent('click', function(e) {
el.currentFill = el.newFill; el.currentFill = el.newFill;
el.wrapper.removeEvents(); el.wrapper.removeEvents();
el.textEl.oldTxt = el.textEl.get('text'); el.textEl.oldTxt = el.textEl.get('text');
el.textEl.set('html', '&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;'); el.textEl.set('html', '&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;');
el.textEl.addClass('loading'); el.textEl.addClass('loading');
// falls aus LightBox, entsprechendes ursprüngliches Rating aktualisieren // falls aus LightBox, entsprechendes ursprüngliches Rating aktualisieren
if (typeof($('.mbrateItRating')) != 'undefined' && el.id.indexOf('mb') == 0) { if (typeof($('.mbrateItRating')) != 'undefined' && el.id.indexOf('mb') == 0) {
var mbid = el.id; var mbid = el.id;
mbid = mbid.replace('mb', ''); mbid = mbid.replace('mb', '');
if (typeof(arrRatings) == 'object') { if (typeof(arrRatings) == 'object') {
for (var ri = 0; ri < arrRatings.length; ri++) { for (var ri = 0; ri < arrRatings.length; ri++) {
if (arrRatings[ri].rateItID == mbid) { if (arrRatings[ri].rateItID == mbid) {
@ -121,7 +121,7 @@ function doRateIt() {
} }
} }
} }
if (typeof($(mbid)) != 'undefined') { if (typeof($(mbid)) != 'undefined') {
var origWrapper = $(mbid).getElement('.wrapper'); var origWrapper = $(mbid).getElement('.wrapper');
origWrapper.removeEvents(); origWrapper.removeEvents();
@ -140,28 +140,28 @@ function doRateIt() {
} }
} }
} }
var votePercent = this.getVotePercent(el.newFill); var votePercent = this.getVotePercent(el.newFill);
if (this.options.url != null) { if (this.options.url != null) {
new Request({ new Request({
url:this.options.url, url:this.options.url,
onComplete:el.updateText onComplete:el.updateText
}) })
.post({vote:votePercent,id:el.ratableId,type:el.ratableType}); .post({vote:votePercent,id:el.ratableId,type:el.ratableType});
} }
}.bind(this)); }.bind(this));
el.updateText = function(text) { el.updateText = function(text) {
error = text.split('ERROR:')[1]; error = text.split('ERROR:')[1];
el.textEl.removeClass('loading'); el.textEl.removeClass('loading');
if (error) { el.showError(error); return false; } if (error) { el.showError(error); return false; }
el.textEl.set('text', text); el.textEl.set('text', text);
// falls aus LightBox, entsprechendes ursprüngliches Rating aktualisieren // falls aus LightBox, entsprechendes ursprüngliches Rating aktualisieren
if (typeof($('.mbrateItRating')) != 'undefined' && el.id.indexOf('mb') == 0) { if (typeof($('.mbrateItRating')) != 'undefined' && el.id.indexOf('mb') == 0) {
var mbid = el.getAttribute('id'); var mbid = el.getAttribute('id');
mbid = mbid.replace('mb', ''); mbid = mbid.replace('mb', '');
if (typeof(arrRatings) == 'object') { if (typeof(arrRatings) == 'object') {
for (var ri = 0; ri < arrRatings.length; ri++) { for (var ri = 0; ri < arrRatings.length; ri++) {
if (arrRatings[ri].rateItID == mbid) { if (arrRatings[ri].rateItID == mbid) {
@ -170,7 +170,7 @@ function doRateIt() {
} }
} }
} }
if (typeof($(mbid)) != 'undefined') { if (typeof($(mbid)) != 'undefined') {
$(mbid).getElement('.ratingText').set('text', text); $(mbid).getElement('.ratingText').set('text', text);
} }
@ -186,7 +186,7 @@ function doRateIt() {
} }
}; };
} }
el.showError = function(error) { el.showError = function(error) {
el.textEl.addClass('ratingError'); el.textEl.addClass('ratingError');
el.textEl.set('text', error); el.textEl.set('text', error);
@ -202,15 +202,15 @@ function doRateIt() {
el.remove(); el.remove();
} }
}, },
fillVote: function(percent, el) { fillVote: function(percent, el) {
el.newFill = this.getFillPercent(percent); el.newFill = this.getFillPercent(percent);
if (this.getVotePercent(el.newFill) > 100) { el.newFill = this.getFillPercent(100); } if (this.getVotePercent(el.newFill) > 100) { el.newFill = this.getFillPercent(100); }
el.selected.setStyle('width', el.newFill); el.selected.setStyle('width', el.newFill);
}, },
getStarPercent: function(id) { getStarPercent: function(id) {
/* Format = anyStringHere-<id>-<float(currentStars)>_(scale); /* Format = anyStringHere-<id>-<float(currentStars)>_(scale);
* Example: RateItRatings-5-3_5 //Primary key id = 5, 3/5 stars. */ * Example: RateItRatings-5-3_5 //Primary key id = 5, 3/5 stars. */
var stars = id.match(/(\d*\|?\d*)-(page|article|ce|module|news|faq|galpic|news4ward)-(\d*\.?\d+)_(\d*\.?\d+)$/); var stars = id.match(/(\d*\|?\d*)-(page|article|ce|module|news|faq|galpic|news4ward)-(\d*\.?\d+)_(\d*\.?\d+)$/);
if (stars != null) { if (stars != null) {
@ -222,42 +222,42 @@ function doRateIt() {
return 0; return 0;
} }
}, },
// Ermittelt die Breite des rateItRating-selected divs // Ermittelt die Breite des rateItRating-selected divs
getFillPercent: function (starPercent) { getFillPercent: function (starPercent) {
return (starPercent / 100) * (this.options.starwidth * this.options.max); return (starPercent / 100) * (this.options.starwidth * this.options.max);
}, },
// Aus der Breite des rateItRating-selected divs die Prozentzahl ermitteln // Aus der Breite des rateItRating-selected divs die Prozentzahl ermitteln
getVotePercent: function(actVote) { getVotePercent: function(actVote) {
var starsWidth = this.options.starwidth * this.options.max; var starsWidth = this.options.starwidth * this.options.max;
var percent = (actVote / starsWidth * 100).round(2); var percent = (actVote / starsWidth * 100).round(2);
return percent; return percent;
}, },
getRatableId: function(id) { getRatableId: function(id) {
var stars = id.match(/(\d*\|?\d*)-(page|article|ce|module|news|faq|galpic|news4ward)-(\d*\.?\d+)_(\d*\.?\d+)$/); var stars = id.match(/(\d*\|?\d*)-(page|article|ce|module|news|faq|galpic|news4ward)-(\d*\.?\d+)_(\d*\.?\d+)$/);
return stars != null ? stars[1] : ''; return stars != null ? stars[1] : '';
}, },
getRatableType: function(id) { getRatableType: function(id) {
var stars = id.match(/(\d*\|?\d*)-(page|article|ce|module|news|faq|galpic|news4ward)-(\d*\.?\d+)_(\d*\.?\d+)$/); var stars = id.match(/(\d*\|?\d*)-(page|article|ce|module|news|faq|galpic|news4ward)-(\d*\.?\d+)_(\d*\.?\d+)$/);
return stars != null ? stars[2] : ''; return stars != null ? stars[2] : '';
}, },
getRatableMaxValue: function(id) { getRatableMaxValue: function(id) {
var stars = id.match(/(\d*\|?\d*)-(page|article|ce|module|news|faq|galpic|news4ward)-(\d*\.?\d+)_(\d*\.?\d+)$/); var stars = id.match(/(\d*\|?\d*)-(page|article|ce|module|news|faq|galpic|news4ward)-(\d*\.?\d+)_(\d*\.?\d+)$/);
return stars != null ? stars[4].toInt() : 0; return stars != null ? stars[4].toInt() : 0;
}, },
setBackgroundPosition: function(el, pos) { setBackgroundPosition: function(el, pos) {
el.setStyle('background-position', '0% ' + pos + 'px'); el.setStyle('background-position', '0% ' + pos + 'px');
}, },
getBackgroundImagePath: function(el) { getBackgroundImagePath: function(el) {
return el.getStyle('background-image'); return el.getStyle('background-image');
}, },
getBackgroundImage: function(el) { getBackgroundImage: function(el) {
var reg_imgFile = /url\s*\(["']?(.*)["']?\)/i; var reg_imgFile = /url\s*\(["']?(.*)["']?\)/i;
var dummy = document.createElement('img'); var dummy = document.createElement('img');
@ -267,40 +267,40 @@ function doRateIt() {
dummy.src = string; dummy.src = string;
return dummy; return dummy;
} }
}); });
window.addEvent('domready', function(e) { window.addEvent('domready', function(e) {
RateItRating = new RateItRatings({url:'rateit'}); RateItRating = new RateItRatings({url:'system/modules/rateit/public/php/rateit-ajax.php?do=rateit'});
}); });
} else if (window.jQuery) { } else if (window.jQuery) {
// the rateit plugin as an Object // the rateit plugin as an Object
(function() { (function() {
RateItRatings = { RateItRatings = {
options: { options: {
step: 0.1, /* Schrittweite */ step: 0.1, /* Schrittweite */
readonly: false, /* Bewertungen zulassen */ readonly: false, /* Bewertungen zulassen */
resetable: false /* Nicht zurücksetzbar */ resetable: false /* Nicht zurücksetzbar */
}, },
// this should be called first before doing anything else // this should be called first before doing anything else
initialize: function(options) { initialize: function(options) {
if (typeof options == 'object' && typeof options['url'] != 'undefined') if (typeof options == 'object' && typeof options['url'] != 'undefined')
this.options.url = options['url']; this.options.url = options['url'];
var self = this; var self = this;
jQuery('.rateItRating').each(function(i, element) { jQuery('.rateItRating').each(function(i, element) {
self.initMe(element); self.initMe(element);
}); });
return this; return this;
}, },
initMe: function(element) { initMe: function(element) {
var self = this; var self = this;
//Does this if the browser is NOT IE6. IE6 users don't deserve fancy ratings. >:( //Does this if the browser is NOT IE6. IE6 users don't deserve fancy ratings. >:(
if (!Browser.Engine.trident4) { if (!Browser.Engine.trident4) {
var el = jQuery(element); var el = jQuery(element);
@ -311,7 +311,7 @@ function doRateIt() {
// el.data('offset', getPosition(element).x); // el.data('offset', getPosition(element).x);
el.data('selected', el.find('.rateItRating-selected')); el.data('selected', el.find('.rateItRating-selected'));
el.data('hover', el.find('.rateItRating-hover')); el.data('hover', el.find('.rateItRating-hover'));
jQuery.when(self.getBackgroundImage(el.data('wrapper'))).done(function(backgroundImageSize) { jQuery.when(self.getBackgroundImage(el.data('wrapper'))).done(function(backgroundImageSize) {
self.options.starwidth = backgroundImageSize[0]; self.options.starwidth = backgroundImageSize[0];
self.options.starheight = backgroundImageSize[1] / 3; // da immer drei Sterne "übereinander" gebraucht werden self.options.starheight = backgroundImageSize[1] / 3; // da immer drei Sterne "übereinander" gebraucht werden
@ -322,57 +322,57 @@ function doRateIt() {
if (self.options.starheight === undefined || self.options.starheight < 16) { if (self.options.starheight === undefined || self.options.starheight < 16) {
self.options.starheight = 16; self.options.starheight = 16;
} }
self.setBackgroundPosition(el.data('selected'), -1 * self.options.starheight); self.setBackgroundPosition(el.data('selected'), -1 * self.options.starheight);
self.setBackgroundPosition(el.data('hover'), -1 * 2 * self.options.starheight); self.setBackgroundPosition(el.data('hover'), -1 * 2 * self.options.starheight);
el.data('starPercent', self.getStarPercent(el.data('id'))); el.data('starPercent', self.getStarPercent(el.data('id')));
el.data('ratableId', self.getRatableId(el.data('id'))); el.data('ratableId', self.getRatableId(el.data('id')));
el.data('ratableType', self.getRatableType(el.data('id'))); el.data('ratableType', self.getRatableType(el.data('id')));
// Maximalwert (=Anzahl Sterne) ermitteln // Maximalwert (=Anzahl Sterne) ermitteln
self.options.max = self.getRatableMaxValue(el.data('id')); self.options.max = self.getRatableMaxValue(el.data('id'));
// Höhe für selected und hover einstellen // Höhe für selected und hover einstellen
el.data('selected').css('height', self.options.starheight); el.data('selected').css('height', self.options.starheight);
el.data('hover').css('height', self.options.starheight); el.data('hover').css('height', self.options.starheight);
// Wrapper-Größe so anpassen, dass alle Sterne angezeigt werden // Wrapper-Größe so anpassen, dass alle Sterne angezeigt werden
el.data('wrapper').css('width', self.options.starwidth * self.options.max); el.data('wrapper').css('width', self.options.starwidth * self.options.max);
el.data('wrapper').css('height', self.options.starheight); el.data('wrapper').css('height', self.options.starheight);
// Breite des rateItRating-selected divs setzen // Breite des rateItRating-selected divs setzen
self.fillVote(el.data('starPercent'), el); self.fillVote(el.data('starPercent'), el);
// Breite für rateItRating-selected div ermitteln // Breite für rateItRating-selected div ermitteln
el.data('currentFill', self.getFillPercent(el.data('starPercent'))); el.data('currentFill', self.getFillPercent(el.data('starPercent')));
if (el.data('rateable')) { if (el.data('rateable')) {
el.data('wrapper').mouseenter(function(event) { el.data('wrapper').mouseenter(function(event) {
el.data('selected').hide(500, "easeInOutQuad"); el.data('selected').hide(500, "easeInOutQuad");
el.data('hover').show(); el.data('hover').show();
el.data('wrapper').mousemove({'el': el, 'self': self}, self.mouseCrap); el.data('wrapper').mousemove({'el': el, 'self': self}, self.mouseCrap);
}); });
el.data('wrapper').mouseleave(function(event) { el.data('wrapper').mouseleave(function(event) {
el.data('wrapper').unbind('mousemove'); el.data('wrapper').unbind('mousemove');
el.data('hover').hide(); el.data('hover').hide();
el.data('selected').show(); el.data('selected').show();
el.data('selected').animate({width: el.data('currentFill')}, 500); el.data('selected').animate({width: el.data('currentFill')}, 500);
}); });
el.data('wrapper').click(function(event) { el.data('wrapper').click(function(event) {
el.data('currentFill', el.data('newFill')); el.data('currentFill', el.data('newFill'));
el.data('wrapper').unbind(); el.data('wrapper').unbind();
el.data('oldTxt', el.data('textEl').text()); el.data('oldTxt', el.data('textEl').text());
el.data('textEl').html('&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;'); el.data('textEl').html('&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;');
el.data('textEl').addClass('loading'); el.data('textEl').addClass('loading');
// falls aus LightBox, entsprechendes ursprüngliches Rating aktualisieren // falls aus LightBox, entsprechendes ursprüngliches Rating aktualisieren
if (typeof(jQuery('.mbrateItRating')) != 'undefined' && el.data('id').indexOf('mb') == 0) { if (typeof(jQuery('.mbrateItRating')) != 'undefined' && el.data('id').indexOf('mb') == 0) {
var mbid = el.data('id'); var mbid = el.data('id');
mbid = mbid.replace('mb', ''); mbid = mbid.replace('mb', '');
if (typeof(arrRatings) == 'object') { if (typeof(arrRatings) == 'object') {
for (var ri = 0; ri < arrRatings.length; ri++) { for (var ri = 0; ri < arrRatings.length; ri++) {
if (arrRatings[ri].rateItID == mbid) { if (arrRatings[ri].rateItID == mbid) {
@ -382,7 +382,7 @@ function doRateIt() {
} }
} }
} }
if (typeof(jQuery('#' + jEscape(mbid))) != 'undefined') { if (typeof(jQuery('#' + jEscape(mbid))) != 'undefined') {
var origWrapper = jQuery('#' + jEscape(mbid)).find('.wrapper'); var origWrapper = jQuery('#' + jEscape(mbid)).find('.wrapper');
origWrapper.unbind(); origWrapper.unbind();
@ -401,7 +401,7 @@ function doRateIt() {
} }
} }
} }
var votePercent = self.getVotePercent(el.data('newFill')); var votePercent = self.getVotePercent(el.data('newFill'));
if (self.options.url != null) { if (self.options.url != null) {
jQuery.ajax({ jQuery.ajax({
@ -414,43 +414,43 @@ function doRateIt() {
} }
}); });
} }
el.data('updateText', self.updateText); el.data('updateText', self.updateText);
} else { } else {
alert("Ich bin ein IE6"); alert("Ich bin ein IE6");
} }
}, },
fillVote: function(percent, el) { fillVote: function(percent, el) {
el.data('newFill', this.getFillPercent(percent)); el.data('newFill', this.getFillPercent(percent));
if (this.getVotePercent(el.data('newFill')) > 100) { el.data('newFill', this.getFillPercent(100)); } if (this.getVotePercent(el.data('newFill')) > 100) { el.data('newFill', this.getFillPercent(100)); }
el.data('selected').css('width', el.data('newFill')); el.data('selected').css('width', el.data('newFill'));
}, },
mouseCrap: function(event) { mouseCrap: function(event) {
var el = event.data['el']; var el = event.data['el'];
var self = event.data['self']; var self = event.data['self'];
var fill = event.originalEvent.layerX; var fill = event.originalEvent.layerX;
if (!fill) { if (!fill) {
fill = event.originalEvent.offsetX; fill = event.originalEvent.offsetX;
} }
var fillPercent = self.getVotePercent(fill); var fillPercent = self.getVotePercent(fill);
var nextStep = Math.ceil((fillPercent / 100) * self.options.max); var nextStep = Math.ceil((fillPercent / 100) * self.options.max);
var w = nextStep * self.options.starwidth; var w = nextStep * self.options.starwidth;
if (parseInt(el.data('hover').css('width')) != w) { if (parseInt(el.data('hover').css('width')) != w) {
el.data('selected').css('display', 'none'); el.data('selected').css('display', 'none');
el.data('hover').css('width', Math.min(w, self.options.starwidth * self.options.max)); el.data('hover').css('width', Math.min(w, self.options.starwidth * self.options.max));
el.data('hover').css('display', 'block'); el.data('hover').css('display', 'block');
} }
var newFill = nextStep / self.options.max * 100; var newFill = nextStep / self.options.max * 100;
self.fillVote(newFill, el); self.fillVote(newFill, el);
}, },
getStarPercent: function(id) { getStarPercent: function(id) {
/* Format = anyStringHere-<id>-<float(currentStars)>_(scale); /* Format = anyStringHere-<id>-<float(currentStars)>_(scale);
* Example: RateItRatings-5-3_5 //Primary key id = 5, 3/5 stars. */ * Example: RateItRatings-5-3_5 //Primary key id = 5, 3/5 stars. */
var stars = id.match(/(\d*\|?\d*)-(page|article|ce|module|news|faq|galpic|news4ward)-(\d*\.?\d+)_(\d*\.?\d+)$/); var stars = id.match(/(\d*\|?\d*)-(page|article|ce|module|news|faq|galpic|news4ward)-(\d*\.?\d+)_(\d*\.?\d+)$/);
if (stars != null) { if (stars != null) {
@ -462,42 +462,42 @@ function doRateIt() {
return 0; return 0;
} }
}, },
// Ermittelt die Breite des rateItRating-selected divs // Ermittelt die Breite des rateItRating-selected divs
getFillPercent: function (starPercent) { getFillPercent: function (starPercent) {
return (starPercent / 100) * (this.options.starwidth * this.options.max); return (starPercent / 100) * (this.options.starwidth * this.options.max);
}, },
// Aus der Breite des rateItRating-selected divs die Prozentzahl ermitteln // Aus der Breite des rateItRating-selected divs die Prozentzahl ermitteln
getVotePercent: function(actVote) { getVotePercent: function(actVote) {
var starsWidth = this.options.starwidth * this.options.max; var starsWidth = this.options.starwidth * this.options.max;
var percent = (actVote / starsWidth * 100).toFixed(2); var percent = (actVote / starsWidth * 100).toFixed(2);
return percent; return percent;
}, },
getRatableId: function(id) { getRatableId: function(id) {
var stars = id.match(/(\d*\|?\d*)-(page|article|ce|module|news|faq|galpic|news4ward)-(\d*\.?\d+)_(\d*\.?\d+)$/); var stars = id.match(/(\d*\|?\d*)-(page|article|ce|module|news|faq|galpic|news4ward)-(\d*\.?\d+)_(\d*\.?\d+)$/);
return stars != null ? stars[1] : ''; return stars != null ? stars[1] : '';
}, },
getRatableType: function(id) { getRatableType: function(id) {
var stars = id.match(/(\d*\|?\d*)-(page|article|ce|module|news|faq|galpic|news4ward)-(\d*\.?\d+)_(\d*\.?\d+)$/); var stars = id.match(/(\d*\|?\d*)-(page|article|ce|module|news|faq|galpic|news4ward)-(\d*\.?\d+)_(\d*\.?\d+)$/);
return stars != null ? stars[2] : ''; return stars != null ? stars[2] : '';
}, },
getRatableMaxValue: function(id) { getRatableMaxValue: function(id) {
var stars = id.match(/(\d*\|?\d*)-(page|article|ce|module|news|faq|galpic|news4ward)-(\d*\.?\d+)_(\d*\.?\d+)$/); var stars = id.match(/(\d*\|?\d*)-(page|article|ce|module|news|faq|galpic|news4ward)-(\d*\.?\d+)_(\d*\.?\d+)$/);
return stars != null ? parseInt(stars[4]) : 0; return stars != null ? parseInt(stars[4]) : 0;
}, },
setBackgroundPosition: function(el, pos) { setBackgroundPosition: function(el, pos) {
el.css('background-position', '0% ' + pos + 'px'); el.css('background-position', '0% ' + pos + 'px');
}, },
getBackgroundImagePath: function(el) { getBackgroundImagePath: function(el) {
return el.css("background-image"); return el.css("background-image");
}, },
getBackgroundImage: function(el) { getBackgroundImage: function(el) {
var dfd = jQuery.Deferred(); var dfd = jQuery.Deferred();
var backgroundImageSize = new Array(); var backgroundImageSize = new Array();
@ -515,13 +515,13 @@ function doRateIt() {
}); });
return dfd.promise(); return dfd.promise();
}, },
updateText: function(el, text) { updateText: function(el, text) {
error = text.split('ERROR:')[1]; error = text.split('ERROR:')[1];
el.data('textEl').removeClass('loading'); el.data('textEl').removeClass('loading');
if (error) { this.RateItRating.showError(el, error); return false; } if (error) { this.RateItRating.showError(el, error); return false; }
el.data('textEl').text(text); el.data('textEl').text(text);
// falls aus LightBox, entsprechendes ursprüngliches Rating aktualisieren // falls aus LightBox, entsprechendes ursprüngliches Rating aktualisieren
if (typeof(jQuery('.mbrateItRating')) != 'undefined' && el.data('id').indexOf('mb') == 0) { if (typeof(jQuery('.mbrateItRating')) != 'undefined' && el.data('id').indexOf('mb') == 0) {
var mbid = el.attr('id'); var mbid = el.attr('id');
@ -535,7 +535,7 @@ function doRateIt() {
} }
} }
} }
if (typeof(jQuery('#' + jEscape(mbid))) != 'undefined') { if (typeof(jQuery('#' + jEscape(mbid))) != 'undefined') {
jQuery('#' + jEscape(mbid)).find('.ratingText').text(text); jQuery('#' + jEscape(mbid)).find('.ratingText').text(text);
} }
@ -550,7 +550,7 @@ function doRateIt() {
} }
} }
}, },
showError: function(el, error) { showError: function(el, error) {
el.data('textEl').addClass('ratingError'); el.data('textEl').addClass('ratingError');
//oldTxt = el.data('textEl').text(); //oldTxt = el.data('textEl').text();
@ -561,27 +561,27 @@ function doRateIt() {
}, 2000); }, 2000);
} }
}; };
})(jQuery); })(jQuery);
jQuery(document).ready(function() { jQuery(document).ready(function() {
jQuery.ajax({ jQuery.ajax({
type: "GET", type: "GET",
url: "bundles/cgoitrateit/js/jquery-ui-effects.custom.min.js", url: "system/modules/rateit/public/js/jquery-ui-effects.custom.min.js",
dataType: "script", dataType: "script",
async: false, async: false,
cache: true cache: true
}); });
jQuery.ajax({ jQuery.ajax({
type: "GET", type: "GET",
url: "bundles/cgoitrateit/js/helper.min.js", url: "system/modules/rateit/public/js/helper.min.js",
dataType: "script", dataType: "script",
async: false, async: false,
cache: true cache: true
}); });
RateItRating = Object.create(RateItRatings).initialize({url:'rateit'}); RateItRating = Object.create(RateItRatings).initialize({url:'system/modules/rateit/public/php/rateit-ajax.php?do=rateit'});
}); });
var jEscape = function(jquery) { var jEscape = function(jquery) {
jquery = jquery.replace(new RegExp("\\$", "g"), "\\$"); jquery = jquery.replace(new RegExp("\\$", "g"), "\\$");
jquery = jquery.replace(new RegExp("\~", "g"), "\\~"); jquery = jquery.replace(new RegExp("\~", "g"), "\\~");
@ -595,6 +595,6 @@ function doRateIt() {
} }
} }
onReadyRateIt(function() { onReadyRateIt(function() {
doRateIt(); doRateIt();
}); });

View File

@ -9,7 +9,7 @@ var votePercent=this.getVotePercent(el.newFill);if(this.options.url!=null){new R
el.textEl.set('text',text);if(typeof($('.mbrateItRating'))!='undefined'&&el.id.indexOf('mb')==0){var mbid=el.getAttribute('id');mbid=mbid.replace('mb','');if(typeof(arrRatings)=='object'){for(var ri=0;ri<arrRatings.length;ri++){if(arrRatings[ri].rateItID==mbid){arrRatings[ri].description=text;break;}}} el.textEl.set('text',text);if(typeof($('.mbrateItRating'))!='undefined'&&el.id.indexOf('mb')==0){var mbid=el.getAttribute('id');mbid=mbid.replace('mb','');if(typeof(arrRatings)=='object'){for(var ri=0;ri<arrRatings.length;ri++){if(arrRatings[ri].rateItID==mbid){arrRatings[ri].description=text;break;}}}
if(typeof($(mbid))!='undefined'){$(mbid).getElement('.ratingText').set('text',text);}}else{if(typeof(arrRatings)=='object'){for(var ri=0;ri<arrRatings.length;ri++){if(arrRatings[ri].rateItID==el.id){arrRatings[ri].description=text;break;}}}}};} if(typeof($(mbid))!='undefined'){$(mbid).getElement('.ratingText').set('text',text);}}else{if(typeof(arrRatings)=='object'){for(var ri=0;ri<arrRatings.length;ri++){if(arrRatings[ri].rateItID==el.id){arrRatings[ri].description=text;break;}}}}};}
el.showError=function(error){el.textEl.addClass('ratingError');el.textEl.set('text',error);(function(){el.textEl.set('text',el.textEl.oldTxt);el.textEl.removeClass('ratingError');}).delay(2000);};}else{el.getElement('.ratingText').inject(el,'before');el.remove();}},fillVote:function(percent,el){el.newFill=this.getFillPercent(percent);if(this.getVotePercent(el.newFill)>100){el.newFill=this.getFillPercent(100);} el.showError=function(error){el.textEl.addClass('ratingError');el.textEl.set('text',error);(function(){el.textEl.set('text',el.textEl.oldTxt);el.textEl.removeClass('ratingError');}).delay(2000);};}else{el.getElement('.ratingText').inject(el,'before');el.remove();}},fillVote:function(percent,el){el.newFill=this.getFillPercent(percent);if(this.getVotePercent(el.newFill)>100){el.newFill=this.getFillPercent(100);}
el.selected.setStyle('width',el.newFill);},getStarPercent:function(id){var stars=id.match(/(\d*\|?\d*)-(page|article|ce|module|news|faq|galpic|news4ward)-(\d*\.?\d+)_(\d*\.?\d+)$/);if(stars!=null){var score=stars[3].toFloat();var scale=stars[4].toFloat();var percent=(score/scale)*100;return percent;}else{return 0;}},getFillPercent:function(starPercent){return(starPercent/100)*(this.options.starwidth*this.options.max);},getVotePercent:function(actVote){var starsWidth=this.options.starwidth*this.options.max;var percent=(actVote/starsWidth*100).round(2);return percent;},getRatableId:function(id){var stars=id.match(/(\d*\|?\d*)-(page|article|ce|module|news|faq|galpic|news4ward)-(\d*\.?\d+)_(\d*\.?\d+)$/);return stars!=null?stars[1]:'';},getRatableType:function(id){var stars=id.match(/(\d*\|?\d*)-(page|article|ce|module|news|faq|galpic|news4ward)-(\d*\.?\d+)_(\d*\.?\d+)$/);return stars!=null?stars[2]:'';},getRatableMaxValue:function(id){var stars=id.match(/(\d*\|?\d*)-(page|article|ce|module|news|faq|galpic|news4ward)-(\d*\.?\d+)_(\d*\.?\d+)$/);return stars!=null?stars[4].toInt():0;},setBackgroundPosition:function(el,pos){el.setStyle('background-position','0% '+pos+'px');},getBackgroundImagePath:function(el){return el.getStyle('background-image');},getBackgroundImage:function(el){var reg_imgFile=/url\s*\(["']?(.*)["']?\)/i;var dummy=document.createElement('img');var string=this.getBackgroundImagePath(el);string=string.match(reg_imgFile)[1];string=string.replace('\"','');dummy.src=string;return dummy;}});window.addEvent('domready',function(e){RateItRating=new RateItRatings({url:'rateit'});});}else if(window.jQuery){(function(){RateItRatings={options:{step:0.1,readonly:false,resetable:false},initialize:function(options){if(typeof options=='object'&&typeof options['url']!='undefined') el.selected.setStyle('width',el.newFill);},getStarPercent:function(id){var stars=id.match(/(\d*\|?\d*)-(page|article|ce|module|news|faq|galpic|news4ward)-(\d*\.?\d+)_(\d*\.?\d+)$/);if(stars!=null){var score=stars[3].toFloat();var scale=stars[4].toFloat();var percent=(score/scale)*100;return percent;}else{return 0;}},getFillPercent:function(starPercent){return(starPercent/100)*(this.options.starwidth*this.options.max);},getVotePercent:function(actVote){var starsWidth=this.options.starwidth*this.options.max;var percent=(actVote/starsWidth*100).round(2);return percent;},getRatableId:function(id){var stars=id.match(/(\d*\|?\d*)-(page|article|ce|module|news|faq|galpic|news4ward)-(\d*\.?\d+)_(\d*\.?\d+)$/);return stars!=null?stars[1]:'';},getRatableType:function(id){var stars=id.match(/(\d*\|?\d*)-(page|article|ce|module|news|faq|galpic|news4ward)-(\d*\.?\d+)_(\d*\.?\d+)$/);return stars!=null?stars[2]:'';},getRatableMaxValue:function(id){var stars=id.match(/(\d*\|?\d*)-(page|article|ce|module|news|faq|galpic|news4ward)-(\d*\.?\d+)_(\d*\.?\d+)$/);return stars!=null?stars[4].toInt():0;},setBackgroundPosition:function(el,pos){el.setStyle('background-position','0% '+pos+'px');},getBackgroundImagePath:function(el){return el.getStyle('background-image');},getBackgroundImage:function(el){var reg_imgFile=/url\s*\(["']?(.*)["']?\)/i;var dummy=document.createElement('img');var string=this.getBackgroundImagePath(el);string=string.match(reg_imgFile)[1];string=string.replace('\"','');dummy.src=string;return dummy;}});window.addEvent('domready',function(e){RateItRating=new RateItRatings({url:'system/modules/rateit/public/php/rateit-ajax.php?do=rateit'});});}else if(window.jQuery){(function(){RateItRatings={options:{step:0.1,readonly:false,resetable:false},initialize:function(options){if(typeof options=='object'&&typeof options['url']!='undefined')
this.options.url=options['url'];var self=this;jQuery('.rateItRating').each(function(i,element){self.initMe(element);});return this;},initMe:function(element){var self=this;if(!Browser.Engine.trident4){var el=jQuery(element);el.data('id',el.attr('id'));el.data('rateable',el.attr('rel')=='not-rateable'?false:true);el.data('wrapper',el.find('.wrapper'));el.data('textEl',el.find('.ratingText'));el.data('selected',el.find('.rateItRating-selected'));el.data('hover',el.find('.rateItRating-hover'));jQuery.when(self.getBackgroundImage(el.data('wrapper'))).done(function(backgroundImageSize){self.options.starwidth=backgroundImageSize[0];self.options.starheight=backgroundImageSize[1]/3;});if(self.options.starwidth===undefined||self.options.starwidth<16){self.options.starwidth=16;} this.options.url=options['url'];var self=this;jQuery('.rateItRating').each(function(i,element){self.initMe(element);});return this;},initMe:function(element){var self=this;if(!Browser.Engine.trident4){var el=jQuery(element);el.data('id',el.attr('id'));el.data('rateable',el.attr('rel')=='not-rateable'?false:true);el.data('wrapper',el.find('.wrapper'));el.data('textEl',el.find('.ratingText'));el.data('selected',el.find('.rateItRating-selected'));el.data('hover',el.find('.rateItRating-hover'));jQuery.when(self.getBackgroundImage(el.data('wrapper'))).done(function(backgroundImageSize){self.options.starwidth=backgroundImageSize[0];self.options.starheight=backgroundImageSize[1]/3;});if(self.options.starwidth===undefined||self.options.starwidth<16){self.options.starwidth=16;}
if(self.options.starheight===undefined||self.options.starheight<16){self.options.starheight=16;} if(self.options.starheight===undefined||self.options.starheight<16){self.options.starheight=16;}
self.setBackgroundPosition(el.data('selected'),-1*self.options.starheight);self.setBackgroundPosition(el.data('hover'),-1*2*self.options.starheight);el.data('starPercent',self.getStarPercent(el.data('id')));el.data('ratableId',self.getRatableId(el.data('id')));el.data('ratableType',self.getRatableType(el.data('id')));self.options.max=self.getRatableMaxValue(el.data('id'));el.data('selected').css('height',self.options.starheight);el.data('hover').css('height',self.options.starheight);el.data('wrapper').css('width',self.options.starwidth*self.options.max);el.data('wrapper').css('height',self.options.starheight);self.fillVote(el.data('starPercent'),el);el.data('currentFill',self.getFillPercent(el.data('starPercent')));if(el.data('rateable')){el.data('wrapper').mouseenter(function(event){el.data('selected').hide(500,"easeInOutQuad");el.data('hover').show();el.data('wrapper').mousemove({'el':el,'self':self},self.mouseCrap);});el.data('wrapper').mouseleave(function(event){el.data('wrapper').unbind('mousemove');el.data('hover').hide();el.data('selected').show();el.data('selected').animate({width:el.data('currentFill')},500);});el.data('wrapper').click(function(event){el.data('currentFill',el.data('newFill'));el.data('wrapper').unbind();el.data('oldTxt',el.data('textEl').text());el.data('textEl').html('&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;');el.data('textEl').addClass('loading');if(typeof(jQuery('.mbrateItRating'))!='undefined'&&el.data('id').indexOf('mb')==0){var mbid=el.data('id');mbid=mbid.replace('mb','');if(typeof(arrRatings)=='object'){for(var ri=0;ri<arrRatings.length;ri++){if(arrRatings[ri].rateItID==mbid){arrRatings[ri].rated=true;arrRatings[ri].width=el.data('hover').css('width');break;}}} self.setBackgroundPosition(el.data('selected'),-1*self.options.starheight);self.setBackgroundPosition(el.data('hover'),-1*2*self.options.starheight);el.data('starPercent',self.getStarPercent(el.data('id')));el.data('ratableId',self.getRatableId(el.data('id')));el.data('ratableType',self.getRatableType(el.data('id')));self.options.max=self.getRatableMaxValue(el.data('id'));el.data('selected').css('height',self.options.starheight);el.data('hover').css('height',self.options.starheight);el.data('wrapper').css('width',self.options.starwidth*self.options.max);el.data('wrapper').css('height',self.options.starheight);self.fillVote(el.data('starPercent'),el);el.data('currentFill',self.getFillPercent(el.data('starPercent')));if(el.data('rateable')){el.data('wrapper').mouseenter(function(event){el.data('selected').hide(500,"easeInOutQuad");el.data('hover').show();el.data('wrapper').mousemove({'el':el,'self':self},self.mouseCrap);});el.data('wrapper').mouseleave(function(event){el.data('wrapper').unbind('mousemove');el.data('hover').hide();el.data('selected').show();el.data('selected').animate({width:el.data('currentFill')},500);});el.data('wrapper').click(function(event){el.data('currentFill',el.data('newFill'));el.data('wrapper').unbind();el.data('oldTxt',el.data('textEl').text());el.data('textEl').html('&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;');el.data('textEl').addClass('loading');if(typeof(jQuery('.mbrateItRating'))!='undefined'&&el.data('id').indexOf('mb')==0){var mbid=el.data('id');mbid=mbid.replace('mb','');if(typeof(arrRatings)=='object'){for(var ri=0;ri<arrRatings.length;ri++){if(arrRatings[ri].rateItID==mbid){arrRatings[ri].rated=true;arrRatings[ri].width=el.data('hover').css('width');break;}}}
@ -20,5 +20,5 @@ el.data('selected').css('width',el.data('newFill'));},mouseCrap:function(event){
var fillPercent=self.getVotePercent(fill);var nextStep=Math.ceil((fillPercent/100)*self.options.max);var w=nextStep*self.options.starwidth;if(parseInt(el.data('hover').css('width'))!=w){el.data('selected').css('display','none');el.data('hover').css('width',Math.min(w,self.options.starwidth*self.options.max));el.data('hover').css('display','block');} var fillPercent=self.getVotePercent(fill);var nextStep=Math.ceil((fillPercent/100)*self.options.max);var w=nextStep*self.options.starwidth;if(parseInt(el.data('hover').css('width'))!=w){el.data('selected').css('display','none');el.data('hover').css('width',Math.min(w,self.options.starwidth*self.options.max));el.data('hover').css('display','block');}
var newFill=nextStep/self.options.max*100;self.fillVote(newFill,el);},getStarPercent:function(id){var stars=id.match(/(\d*\|?\d*)-(page|article|ce|module|news|faq|galpic|news4ward)-(\d*\.?\d+)_(\d*\.?\d+)$/);if(stars!=null){var score=parseFloat(stars[3]);var scale=parseFloat(stars[4]);var percent=(score/scale)*100;return percent;}else{return 0;}},getFillPercent:function(starPercent){return(starPercent/100)*(this.options.starwidth*this.options.max);},getVotePercent:function(actVote){var starsWidth=this.options.starwidth*this.options.max;var percent=(actVote/starsWidth*100).toFixed(2);return percent;},getRatableId:function(id){var stars=id.match(/(\d*\|?\d*)-(page|article|ce|module|news|faq|galpic|news4ward)-(\d*\.?\d+)_(\d*\.?\d+)$/);return stars!=null?stars[1]:'';},getRatableType:function(id){var stars=id.match(/(\d*\|?\d*)-(page|article|ce|module|news|faq|galpic|news4ward)-(\d*\.?\d+)_(\d*\.?\d+)$/);return stars!=null?stars[2]:'';},getRatableMaxValue:function(id){var stars=id.match(/(\d*\|?\d*)-(page|article|ce|module|news|faq|galpic|news4ward)-(\d*\.?\d+)_(\d*\.?\d+)$/);return stars!=null?parseInt(stars[4]):0;},setBackgroundPosition:function(el,pos){el.css('background-position','0% '+pos+'px');},getBackgroundImagePath:function(el){return el.css("background-image");},getBackgroundImage:function(el){var dfd=jQuery.Deferred();var backgroundImageSize=new Array();var reg_imgFile=/url\s*\(["']?(.*)["']?\)/i;var string=this.getBackgroundImagePath(el);string=string.match(reg_imgFile)[1];string=string.replace('\"','');jQuery('<img/>').attr('src',string).load(function(){backgroundImageSize.push(this.width);backgroundImageSize.push(this.height);dfd.resolve(backgroundImageSize);});return dfd.promise();},updateText:function(el,text){error=text.split('ERROR:')[1];el.data('textEl').removeClass('loading');if(error){this.RateItRating.showError(el,error);return false;} var newFill=nextStep/self.options.max*100;self.fillVote(newFill,el);},getStarPercent:function(id){var stars=id.match(/(\d*\|?\d*)-(page|article|ce|module|news|faq|galpic|news4ward)-(\d*\.?\d+)_(\d*\.?\d+)$/);if(stars!=null){var score=parseFloat(stars[3]);var scale=parseFloat(stars[4]);var percent=(score/scale)*100;return percent;}else{return 0;}},getFillPercent:function(starPercent){return(starPercent/100)*(this.options.starwidth*this.options.max);},getVotePercent:function(actVote){var starsWidth=this.options.starwidth*this.options.max;var percent=(actVote/starsWidth*100).toFixed(2);return percent;},getRatableId:function(id){var stars=id.match(/(\d*\|?\d*)-(page|article|ce|module|news|faq|galpic|news4ward)-(\d*\.?\d+)_(\d*\.?\d+)$/);return stars!=null?stars[1]:'';},getRatableType:function(id){var stars=id.match(/(\d*\|?\d*)-(page|article|ce|module|news|faq|galpic|news4ward)-(\d*\.?\d+)_(\d*\.?\d+)$/);return stars!=null?stars[2]:'';},getRatableMaxValue:function(id){var stars=id.match(/(\d*\|?\d*)-(page|article|ce|module|news|faq|galpic|news4ward)-(\d*\.?\d+)_(\d*\.?\d+)$/);return stars!=null?parseInt(stars[4]):0;},setBackgroundPosition:function(el,pos){el.css('background-position','0% '+pos+'px');},getBackgroundImagePath:function(el){return el.css("background-image");},getBackgroundImage:function(el){var dfd=jQuery.Deferred();var backgroundImageSize=new Array();var reg_imgFile=/url\s*\(["']?(.*)["']?\)/i;var string=this.getBackgroundImagePath(el);string=string.match(reg_imgFile)[1];string=string.replace('\"','');jQuery('<img/>').attr('src',string).load(function(){backgroundImageSize.push(this.width);backgroundImageSize.push(this.height);dfd.resolve(backgroundImageSize);});return dfd.promise();},updateText:function(el,text){error=text.split('ERROR:')[1];el.data('textEl').removeClass('loading');if(error){this.RateItRating.showError(el,error);return false;}
el.data('textEl').text(text);if(typeof(jQuery('.mbrateItRating'))!='undefined'&&el.data('id').indexOf('mb')==0){var mbid=el.attr('id');mbid=mbid.replace('mb','');if(typeof(arrRatings)=='object'){for(var ri=0;ri<arrRatings.length;ri++){if(arrRatings[ri].rateItID==mbid){arrRatings[ri].description=text;break;}}} el.data('textEl').text(text);if(typeof(jQuery('.mbrateItRating'))!='undefined'&&el.data('id').indexOf('mb')==0){var mbid=el.attr('id');mbid=mbid.replace('mb','');if(typeof(arrRatings)=='object'){for(var ri=0;ri<arrRatings.length;ri++){if(arrRatings[ri].rateItID==mbid){arrRatings[ri].description=text;break;}}}
if(typeof(jQuery('#'+jEscape(mbid)))!='undefined'){jQuery('#'+jEscape(mbid)).find('.ratingText').text(text);}}else{if(typeof(arrRatings)=='object'){for(var ri=0;ri<arrRatings.length;ri++){if(arrRatings[ri].rateItID==el.data('id')){arrRatings[ri].description=text;break;}}}}},showError:function(el,error){el.data('textEl').addClass('ratingError');el.data('textEl').text(error);setTimeout(function(){el.data('textEl').text(el.data('oldTxt'));el.data('textEl').removeClass('ratingError');},2000);}};})(jQuery);jQuery(document).ready(function(){jQuery.ajax({type:"GET",url:"bundles/cgoitrateit/js/jquery-ui-effects.custom.min.js",dataType:"script",async:false,cache:true});jQuery.ajax({type:"GET",url:"bundles/cgoitrateit/js/helper.min.js",dataType:"script",async:false,cache:true});RateItRating=Object.create(RateItRatings).initialize({url:'rateit'});});var jEscape=function(jquery){jquery=jquery.replace(new RegExp("\\$","g"),"\\$");jquery=jquery.replace(new RegExp("\~","g"),"\\~");jquery=jquery.replace(new RegExp("\\[","g"),"\\[");jquery=jquery.replace(new RegExp("\\]","g"),"\\]");jquery=jquery.replace(new RegExp("\\|","g"),"\\|");jquery=jquery.replace(new RegExp("\\.","g"),"\\.");jquery=jquery.replace(new RegExp("#","g"),"\\#");return jquery;};}} if(typeof(jQuery('#'+jEscape(mbid)))!='undefined'){jQuery('#'+jEscape(mbid)).find('.ratingText').text(text);}}else{if(typeof(arrRatings)=='object'){for(var ri=0;ri<arrRatings.length;ri++){if(arrRatings[ri].rateItID==el.data('id')){arrRatings[ri].description=text;break;}}}}},showError:function(el,error){el.data('textEl').addClass('ratingError');el.data('textEl').text(error);setTimeout(function(){el.data('textEl').text(el.data('oldTxt'));el.data('textEl').removeClass('ratingError');},2000);}};})(jQuery);jQuery(document).ready(function(){jQuery.ajax({type:"GET",url:"system/modules/rateit/public/js/jquery-ui-effects.custom.min.js",dataType:"script",async:false,cache:true});jQuery.ajax({type:"GET",url:"system/modules/rateit/public/js/helper.min.js",dataType:"script",async:false,cache:true});RateItRating=Object.create(RateItRatings).initialize({url:'system/modules/rateit/public/php/rateit-ajax.php?do=rateit'});});var jEscape=function(jquery){jquery=jquery.replace(new RegExp("\\$","g"),"\\$");jquery=jquery.replace(new RegExp("\~","g"),"\\~");jquery=jquery.replace(new RegExp("\\[","g"),"\\[");jquery=jquery.replace(new RegExp("\\]","g"),"\\]");jquery=jquery.replace(new RegExp("\\|","g"),"\\|");jquery=jquery.replace(new RegExp("\\.","g"),"\\.");jquery=jquery.replace(new RegExp("#","g"),"\\#");return jquery;};}}
onReadyRateIt(function(){doRateIt();}); onReadyRateIt(function(){doRateIt();});

139
public/php/rateit-ajax.php Normal file
View File

@ -0,0 +1,139 @@
<?php
/**
* Contao Open Source CMS
* Copyright (C) 2005-2011 Leo Feyer
*
* Formerly known as TYPOlight Open Source CMS.
*
* This program is free software: you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation, either
* version 3 of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this program. If not, please visit the Free
* Software Foundation website at <http://www.gnu.org/licenses/>.
*
* PHP version 5
* @copyright Leo Unglaub 2012
* @author Leo Unglaub <leo@leo-unglaub.net>
* @package simple_ajax
* @license LGPL
*/
// simple trick for Contao < 2.10
$arrPost = $_POST;
unset($_POST);
// inizialize the contao framework
define('TL_MODE', 'FE');
require('../../../../initialize.php');
// write the post data back into the array
$_POST = $arrPost;
/**
* Class RateitAjax
* Contain methods to catch ajax requests and send responses back to the client.
*
* Description
* ```````````
*
* The usage of the RateitAjax extensions is very easy. The extension provides
* the hook $GLOBALS['TL_HOOKS']['rateitAjax'] for extension developers. You
* simply have to register your class/method and the extension will call
* your class if there is an incomming ajax request.
*
* You simply have to deside if it's an ajax request for your module and return
* the data you want.
*
* There are a few thinks you should know about the extension:
* * YOU have the full controll over the response. That also means
* that you have to set the correct header.
* * YOU have to terminate the request after you have send the response.
* * If the ajax request is not for your method you simply have nothing to
* * return.
*
*
* Usage
* `````
* // config.php
* $GLOBALS['TL_HOOKS']['rateitAjax'][] = array('MyClass', 'myMethod');
*
* // MyClass.php
* class MyClass extends System
* {
* public function myMethod()
* {
* if ($this->Input->get('acid') == 'myrequest')
* {
* $arrReturn = array('foo', 'bar', 'foobar');
*
* header('Content-Type: application/json');
* echo json_encode($arrReturn);
* exit;
* }
* }
* }
*/
class RateitAjax extends Controller
{
/**
* Call the parent constructor.
*
* !!! DON'T REMOVE THIS !!!
*
* If you remove this you get the following error message:
* Fatal error: Call to protected System::__construct() from invalid
* context
*
* @param void
* @return void
*/
public function __construct()
{
parent::__construct();
}
/**
* Get the ajax request and call all hooks
*
* @param void
* @return void
*/
public function run()
{
// check if a hook is registered
if (is_array($GLOBALS['TL_HOOKS']['rateitAjax']) && count($GLOBALS['TL_HOOKS']['rateitAjax']) > 0)
{
// execute every registered callback
foreach ($GLOBALS['TL_HOOKS']['rateitAjax'] as $callback)
{
$this->import($callback[0]);
$this->{$callback[0]}->{$callback[1]}();
}
}
// if there is no other output, we generate a 412 error response
header('HTTP/1.1 412 Precondition Failed');
die('Rateit Ajax: Invalid AJAX call.');
}
}
// create a rateit-ajax instance and run it
$objRateitAjax = new RateitAjax();
$objRateitAjax->run();
?>

177
public/php/rateit.php Normal file
View File

@ -0,0 +1,177 @@
<?php
/**
* Contao Open Source CMS
* Copyright (C) 2005-2011 Leo Feyer
*
* Formerly known as TYPOlight Open Source CMS.
*
* This program is free software: you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation, either
* version 3 of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this program. If not, please visit the Free
* Software Foundation website at <http://www.gnu.org/licenses/>.
*
* PHP version 5
* @copyright cgo IT, 2013
* @author Carsten Götzinger (info@cgo-it.de)
* @package rateit
* @license GNU/LGPL
* @filesource
*/
namespace cgoIT\rateit;
define(RETURN_AJAX_HEADER, 'Content-Type: text/html');
class RateIt extends \Frontend {
var $allowDuplicates = false;
/**
* Initialize the controller
*/
public function __construct() {
parent::__construct();
$this->loadLanguageFile('default');
$this->allowDuplicates = $GLOBALS['TL_CONFIG']['rating_allow_duplicate_ratings'];
$this->allowDuplicatesForMembers = $GLOBALS['TL_CONFIG']['rating_allow_duplicate_ratings_for_members'];
}
/**
* doVote
*
* This is the function in charge of handling a vote and saving it to the
* database.
*
* NOTE: This method is meant to be called as part of an AJAX request. As
* such, it unitlizes the die() function to display its errors. THIS
* WOULD BE A VERY BAD FUNCTION TO CALL FROM WITHIN ANOTHER PAGE.
*
* @param integer id - The id of key to register a rating for.
* @param integer percent - The rating in percentages.
*/
function doVote() {
if ($this->Input->get('do') == 'rateit') {
$ip = $_SERVER['REMOTE_ADDR'];
$rkey = $this->Input->post('id');
$percent = $this->Input->post('vote');
$type = $this->Input->post('type');
//Make sure that the ratable ID is a number and not something crazy.
if (strstr($rkey, '|')) {
$arrRkey = explode('|', $rkey);
foreach ($arrRkey as $key) {
if (!is_numeric($key)) {
header(RETURN_AJAX_HEADER);
echo $GLOBALS['TL_LANG']['rateit']['error']['invalid_rating'];
exit;
}
$id = $rkey;
}
} else {
if (is_numeric($rkey)) {
$id = $rkey;
} else {
header(RETURN_AJAX_HEADER);
echo $GLOBALS['TL_LANG']['rateit']['error']['invalid_rating'];
exit;
}
}
//Make sure the percent is a number and under 100.
if (is_numeric($percent) && $percent < 101) {
$rating = $percent;
} else {
header(RETURN_AJAX_HEADER);
echo $GLOBALS['TL_LANG']['rateit']['error']['invalid_rating'];
exit;
}
//Make sure that the ratable type is 'page' or 'ce' or 'module'
if (!($type === 'page' || $type === 'article' || $type === 'ce' || $type === 'module' || $type === 'news' || $type === 'faq' || $type === 'galpic' || $type === 'news4ward')) {
header(RETURN_AJAX_HEADER);
echo $GLOBALS['TL_LANG']['rateit']['error']['invalid_type'];
exit;
}
$strHash = sha1(session_id() . (!$GLOBALS['TL_CONFIG']['disableIpCheck'] ? \Environment::get('ip') : '') . 'FE_USER_AUTH');
// FrontendUser auslesen
if (FE_USER_LOGGED_IN) {
$objUser = $this->Database->prepare("SELECT pid FROM tl_session WHERE hash=?")
->limit(1)
->execute($strHash);
if ($objUser->numRows) {
$userId = $objUser->pid;
}
}
$ratableKeyId = $this->Database->prepare('SELECT id FROM tl_rateit_items WHERE rkey=? and typ=?')
->execute($id, $type)
->fetchAssoc();
$canVote = false;
if (isset($userId)) {
$countUser = $this->Database->prepare('SELECT * FROM tl_rateit_ratings WHERE pid=? and memberid=?')
->execute($ratableKeyId['id'], $userId)
->count();
}
$countIp = $this->Database->prepare('SELECT * FROM tl_rateit_ratings WHERE pid=? and ip_address=?')
->execute($ratableKeyId['id'], $ip)
->count();
// Die with an error if the insert fails (duplicate IP or duplicate member id for a vote).
if ((!$this->allowDuplicatesForMembers && (isset($countUser) ? $countUser == 0 : false)) || ($this->allowDuplicatesForMembers && isset($userId))) {
// Insert the data.
$arrSet = array('pid' => $ratableKeyId['id'],
'tstamp' => time(),
'ip_address' => $ip,
'memberid' => isset($userId) ? $userId : null,
'rating' => $rating,
'createdat'=> time()
);
$this->Database->prepare('INSERT INTO tl_rateit_ratings %s')
->set($arrSet)
->execute();
} elseif (!isset($countUser) && ((!$this->allowDuplicates && $countIp == 0) || $this->allowDuplicates)) {
// Insert the data.
$arrSet = array('pid' => $ratableKeyId['id'],
'tstamp' => time(),
'ip_address' => $ip,
'memberid' => isset($userId) ? $userId : null,
'rating' => $rating,
'createdat'=> time()
);
$this->Database->prepare('INSERT INTO tl_rateit_ratings %s')
->set($arrSet)
->execute();
} else {
header(RETURN_AJAX_HEADER);
echo $GLOBALS['TL_LANG']['rateit']['error']['duplicate_vote'];
exit;
}
$this->import('rateit\\RateItFrontend', 'RateItFrontend');
$rating = $this->RateItFrontend->loadRating($id, $type);
header(RETURN_AJAX_HEADER);
echo $this->RateItFrontend->getStarMessage($rating);
exit;
}
}
}
?>

View File

@ -1,14 +0,0 @@
<?php
namespace cgoIT\rateit;
use Symfony\Component\HttpKernel\Bundle\Bundle;
/**
* Configures the Contao aeo bundle.
*
* @author Carsten Götzinger
*/
class CgoITRateItBundle extends Bundle
{
}

View File

@ -1,42 +0,0 @@
<?php
namespace cgoIT\rateit;
use Contao\CoreBundle\ContaoCoreBundle;
use Contao\ManagerPlugin\Bundle\Config\BundleConfig;
use Contao\ManagerPlugin\Bundle\BundlePluginInterface;
use Contao\ManagerPlugin\Bundle\Parser\ParserInterface;
use Contao\ManagerPlugin\Routing\RoutingPluginInterface;
use Symfony\Component\Config\Loader\LoaderResolverInterface;
use Symfony\Component\HttpKernel\KernelInterface;
/**
* Plugin for the Contao Manager.
*
* @author Carsten Götzinger
*/
class ContaoManagerPlugin implements BundlePluginInterface, RoutingPluginInterface
{
/**
* {@inheritdoc}
*/
public function getBundles(ParserInterface $parser)
{
return [
BundleConfig::create(CgoITRateItBundle::class)
->setLoadAfter([ContaoCoreBundle::class])
->setReplace(['rate-it']),
];
}
/**
* {@inheritdoc}
*/
public function getRouteCollection(LoaderResolverInterface $resolver, KernelInterface $kernel)
{
return $resolver
->resolve(__DIR__.'/Resources/config/routing.yml')
->load(__DIR__.'/Resources/config/routing.yml')
;
}
}

View File

@ -1,36 +0,0 @@
<?php
/**
* Created by PhpStorm.
* User: darko
* Date: 23.10.17
* Time: 23:55
*/
namespace cgoIT\rateit\Controller;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;
use Symfony\Bundle\FrameworkBundle\Controller\Controller;
use Symfony\Component\HttpFoundation\Response;
use cgoIT\rateit\RateIt;
class AjaxRateItController extends Controller {
/**
* Handles rating requests.
*
* @return JsonResponse
*
* @Route("/rateit", name="ajax_rateit", defaults={"_scope" = "frontend", "_token_check" = false})
*/
public function ajaxAction() {
$this->container->get('contao.framework')->initialize();
$controller = new RateIt();
$response = $controller->doVote();
$response->send();
return new Response(null);
}
}

View File

@ -1,3 +0,0 @@
ajax_rateit:
resource: "@CgoITRateItBundle/Controller/"
type: annotation

View File

@ -1,175 +0,0 @@
<?php
/**
* Contao Open Source CMS
* Copyright (C) 2005-2011 Leo Feyer
*
* Formerly known as TYPOlight Open Source CMS.
*
* This program is free software: you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation, either
* version 3 of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this program. If not, please visit the Free
* Software Foundation website at <http://www.gnu.org/licenses/>.
*
* PHP version 5
* @copyright cgo IT, 2013
* @author Carsten Götzinger (info@cgo-it.de)
* @package rateit
* @license GNU/LGPL
* @filesource
*/
namespace cgoIT\rateit;
use cgoIT\rateit\RateItFrontend;
use Symfony\Component\HttpFoundation\JsonResponse;
class RateIt extends \Frontend {
var $allowDuplicates = false;
var $rateItFrontend;
/**
* Initialize the controller
*/
public function __construct() {
parent::__construct();
// See #4099
if (!defined('BE_USER_LOGGED_IN'))
{
define('BE_USER_LOGGED_IN', false);
}
if (!defined('FE_USER_LOGGED_IN'))
{
define('FE_USER_LOGGED_IN', false);
}
$this->rateItFrontend = new RateItFrontend();
$this->loadLanguageFile('default');
$this->allowDuplicates = $GLOBALS['TL_CONFIG']['rating_allow_duplicate_ratings'];
$this->allowDuplicatesForMembers = $GLOBALS['TL_CONFIG']['rating_allow_duplicate_ratings_for_members'];
}
/**
* doVote
*
* This is the function in charge of handling a vote and saving it to the
* database.
*
* NOTE: This method is meant to be called as part of an AJAX request. As
* such, it unitlizes the die() function to display its errors. THIS
* WOULD BE A VERY BAD FUNCTION TO CALL FROM WITHIN ANOTHER PAGE.
*
* @param integer id - The id of key to register a rating for.
* @param integer percent - The rating in percentages.
*/
public function doVote() {
$ip = $_SERVER['REMOTE_ADDR'];
$rkey = $this->Input->post('id');
$percent = $this->Input->post('vote');
$type = $this->Input->post('type');
//Make sure that the ratable ID is a number and not something crazy.
if (strstr($rkey, '|')) {
$arrRkey = explode('|', $rkey);
foreach ($arrRkey as $key) {
if (!is_numeric($key)) {
return new JsonResponse($GLOBALS['TL_LANG']['rateit']['error']['invalid_rating']);
}
$id = $rkey;
}
} else {
if (is_numeric($rkey)) {
$id = $rkey;
} else {
return new JsonResponse($GLOBALS['TL_LANG']['rateit']['error']['invalid_rating']);
}
}
//Make sure the percent is a number and under 100.
if (is_numeric($percent) && $percent < 101) {
$rating = $percent;
} else {
return new JsonResponse($GLOBALS['TL_LANG']['rateit']['error']['invalid_rating']);
}
//Make sure that the ratable type is 'page' or 'ce' or 'module'
if (!($type === 'page' || $type === 'article' || $type === 'ce' || $type === 'module' || $type === 'news' || $type === 'faq' || $type === 'galpic' || $type === 'news4ward')) {
return new JsonResponse($GLOBALS['TL_LANG']['rateit']['error']['invalid_type']);
}
$strHash = sha1(session_id() . (!$GLOBALS['TL_CONFIG']['disableIpCheck'] ? \Environment::get('ip') : '') . 'FE_USER_AUTH');
// FrontendUser auslesen
if (FE_USER_LOGGED_IN) {
$objUser = $this->Database->prepare("SELECT pid FROM tl_session WHERE hash=?")
->limit(1)
->execute($strHash);
if ($objUser->numRows) {
$userId = $objUser->pid;
}
}
$ratableKeyId = $this->Database->prepare('SELECT id FROM tl_rateit_items WHERE rkey=? and typ=?')
->execute($id, $type)
->fetchAssoc();
$canVote = false;
if (isset($userId)) {
$countUser = $this->Database->prepare('SELECT * FROM tl_rateit_ratings WHERE pid=? and memberid=?')
->execute($ratableKeyId['id'], $userId)
->count();
}
$countIp = $this->Database->prepare('SELECT * FROM tl_rateit_ratings WHERE pid=? and ip_address=?')
->execute($ratableKeyId['id'], $ip)
->count();
// Die with an error if the insert fails (duplicate IP or duplicate member id for a vote).
if ((!$this->allowDuplicatesForMembers && (isset($countUser) ? $countUser == 0 : false)) || ($this->allowDuplicatesForMembers && isset($userId))) {
// Insert the data.
$arrSet = array('pid' => $ratableKeyId['id'],
'tstamp' => time(),
'ip_address' => $ip,
'memberid' => isset($userId) ? $userId : null,
'rating' => $rating,
'createdat'=> time()
);
$this->Database->prepare('INSERT INTO tl_rateit_ratings %s')
->set($arrSet)
->execute();
} elseif (!isset($countUser) && ((!$this->allowDuplicates && $countIp == 0) || $this->allowDuplicates)) {
// Insert the data.
$arrSet = array('pid' => $ratableKeyId['id'],
'tstamp' => time(),
'ip_address' => $ip,
'memberid' => isset($userId) ? $userId : null,
'rating' => $rating,
'createdat'=> time()
);
$this->Database->prepare('INSERT INTO tl_rateit_ratings %s')
->set($arrSet)
->execute();
} else {
return new JsonResponse($GLOBALS['TL_LANG']['rateit']['error']['duplicate_vote']);
}
$rating = $this->rateItFrontend->loadRating($id, $type);
return new JsonResponse($this->rateItFrontend->getStarMessage($rating));
}
}
?>

View File

@ -1,37 +0,0 @@
<?php $this->extend('mod_article'); ?>
<?php $this->block('content'); ?>
<?php if ($this->rateit_rating_before): ?>
<!-- indexer::stop -->
<div id="<?= $this->rateItID ?>" class="<?= $this->class ?> <?= $this->rateit_class ?>">
<?php if ($this->showBefore) : ?>
<div id="<?= $this->descriptionId ?>" class="ratingText"><?= $this->description ?></div>
<?php endif; ?>
<div class="wrapper">
<div class="rateItRating-selected" style="display: block;"></div>
<div class="rateItRating-hover"></div>
</div>
<?php if ($this->showAfter) : ?>
<div id="<?= $this->descriptionId ?>" class="ratingText"><?= $this->description ?></div>
<?php endif; ?>
</div>
<!-- indexer::continue -->
<?php endif; ?>
<?php $this->parent(); ?>
<?php if ($this->rateit_rating_after): ?>
<!-- indexer::stop -->
<div id="<?= $this->rateItID ?>" class="<?= $this->class ?> <?= $this->rateit_class ?>">
<?php if ($this->showBefore) : ?>
<div id="<?= $this->descriptionId ?>" class="ratingText"><?= $this->description ?></div>
<?php endif; ?>
<div class="wrapper">
<div class="rateItRating-selected" style="display: block;"></div>
<div class="rateItRating-hover"></div>
</div>
<?php if ($this->showAfter) : ?>
<div id="<?= $this->descriptionId ?>" class="ratingText"><?= $this->description ?></div>
<?php endif; ?>
</div>
<!-- indexer::continue -->
<?php endif; ?>
<?php $this->endblock(); ?>

View File

@ -1,55 +0,0 @@
<?php $this->extend('mod_article'); ?>
<?php $this->block('content'); ?>
<?php if ($this->rateit_rating_before): ?>
<!-- indexer::stop -->
<div itemtype="http://schema.org/CreativeWork" itemscope class="rating-microdata">
<div id="<?= $this->rateItID ?>" class="<?= $this->class ?> <?= $this->rateit_class ?>">
<?php if ($this->showBefore) : ?>
<div id="<?= $this->descriptionId ?>" class="ratingText"><?= $this->description ?></div>
<?php endif; ?>
<div class="wrapper">
<div class="rateItRating-selected" style="display: block;"></div>
<div class="rateItRating-hover"></div>
</div>
<?php if ($this->showAfter) : ?>
<div id="<?= $this->descriptionId ?>" class="ratingText"><?= $this->description ?></div>
<?php endif; ?>
</div>
<span class="rating-microdata" itemprop="name"><?php echo $this->itemreviewed; ?></span>
<span class="rating-microdata" itemtype="http://schema.org/AggregateRating" itemscope itemprop="aggregateRating">
<span itemprop="ratingValue"><?php echo $this->actRating; ?></span>
<span itemprop="worstRating">0</span>
<span itemprop="bestRating"><?php echo $this->maxRating; ?></span>
<span itemprop="ratingCount"><?php echo $this->votes; ?></span>
</span>
</div>
<!-- indexer::continue -->
<?php endif; ?>
<?php $this->parent(); ?>
<?php if ($this->rateit_rating_after): ?>
<!-- indexer::stop -->
<div itemtype="http://schema.org/CreativeWork" itemscope class="rating-microdata">
<div id="<?= $this->rateItID ?>" class="<?= $this->class ?> <?= $this->rateit_class ?>">
<?php if ($this->showBefore) : ?>
<div id="<?= $this->descriptionId ?>" class="ratingText"><?= $this->description ?></div>
<?php endif; ?>
<div class="wrapper">
<div class="rateItRating-selected" style="display: block;"></div>
<div class="rateItRating-hover"></div>
</div>
<?php if ($this->showAfter) : ?>
<div id="<?= $this->descriptionId ?>" class="ratingText"><?= $this->description ?></div>
<?php endif; ?>
</div>
<span class="rating-microdata" itemprop="name"><?php echo $this->itemreviewed; ?></span>
<span class="rating-microdata" itemtype="http://schema.org/AggregateRating" itemscope itemprop="aggregateRating">
<span itemprop="ratingValue"><?php echo $this->actRating; ?></span>
<span itemprop="worstRating">0</span>
<span itemprop="bestRating"><?php echo $this->maxRating; ?></span>
<span itemprop="ratingCount"><?php echo $this->votes; ?></span>
</span>
</div>
<!-- indexer::continue -->
<?php endif; ?>
<?php $this->endblock(); ?>

View File

@ -1,47 +0,0 @@
<?php $this->extend('block_unsearchable'); ?>
<?php $this->block('content'); ?>
<ul>
<?php foreach ($this->articles as $article): ?>
<?php if ($article['rateit_rating_before']): ?>
<!-- indexer::stop -->
<?php $this->block('rating'); ?>
<div id="<?= $article['rateItID'] ?>" class="<?= $article['rateit_class'] ?>">
<?php if ($article['showBefore']) : ?>
<div id="<?= $article['descriptionId'] ?>" class="ratingText"><?= $article['description'] ?></div>
<?php endif; ?>
<div class="wrapper">
<div class="rateItRating-selected" style="display: block;"></div>
<div class="rateItRating-hover"></div>
</div>
<?php if ($article['showAfter']) : ?>
<div id="<?= $article['descriptionId'] ?>" class="ratingText"><?= $article['description'] ?></div>
<?php endif; ?>
</div>
<?php $this->endblock(); ?>
<!-- indexer::continue -->
<?php endif; ?>
<?php $this->parent(); ?>
<?php if ($article['rateit_rating_after']): ?>
<!-- indexer::stop -->
<?php $this->block('rating'); ?>
<div id="<?= $article['rateItID'] ?>" class="<?= $article['rateit_class'] ?>">
<?php if ($article['showBefore']) : ?>
<div id="<?= $article['descriptionId'] ?>" class="ratingText"><?= $article['description'] ?></div>
<?php endif; ?>
<div class="wrapper">
<div class="rateItRating-selected" style="display: block;"></div>
<div class="rateItRating-hover"></div>
</div>
<?php if ($article['showAfter']) : ?>
<div id="<?= $article['descriptionId'] ?>" class="ratingText"><?= $article['description'] ?></div>
<?php endif; ?>
</div>
<?php $this->endblock(); ?>
<!-- indexer::continue -->
<?php endif; ?>
<?php endforeach; ?>
</ul>
<?php $this->endblock(); ?>

View File

@ -1,16 +0,0 @@
<?php $this->extend('mod_articlelist_rateit'); ?>
<?php $this->block('rating'); ?>
<!-- indexer::stop -->
<div itemtype="http://schema.org/CreativeWork" itemscope class="rating-microdata">
<?php $this->parent(); ?>
<span class="rating-microdata" itemprop="name"><?= $article['itemreviewed'] ?></span>
<span class="rating-microdata" itemtype="http://schema.org/AggregateRating" itemscope itemprop="aggregateRating">
<span itemprop="ratingValue"><?= $article['actRating'] ?></span>
<span itemprop="worstRating">0</span>
<span itemprop="bestRating"><?= $article['maxRating'] ?></span>
<span itemprop="ratingCount"><?= $article['votes'] ?></span>
</span>
</div>
<!-- indexer::continue -->
<?php $this->endblock(); ?>

View File

@ -1,40 +0,0 @@
<?php if ($this->rateit_rating_before): ?>
<!-- indexer::stop -->
<?php $this->block('rating'); ?>
<div id="<?= $this->ratingId ?>" class="<?= $this->class ?> <?= $this->rateit_class ?>">
<?php if ($this->showBefore) : ?>
<div id="<?= $this->descriptionId ?>" class="ratingText"><?= $this->description ?></div>
<?php endif; ?>
<div class="wrapper">
<div class="rateItRating-selected" style="display: block;"></div>
<div class="rateItRating-hover"></div>
</div>
<?php if ($this->showAfter) : ?>
<div id="<?= $this->descriptionId ?>" class="ratingText"><?= $this->description ?></div>
<?php endif; ?>
</div>
<?php $this->endblock(); ?>
<!-- indexer::continue -->
<?php endif; ?>
<?php $this->insert('news_full', $this->arrData); ?>
<?php if ($this->rateit_rating_after): ?>
<!-- indexer::stop -->
<?php $this->block('rating'); ?>
<div id="<?= $this->ratingId ?>" class="<?= $this->class ?> <?= $this->rateit_class ?>">
<?php if ($this->showBefore) : ?>
<div id="<?= $this->descriptionId ?>" class="ratingText"><?= $this->description ?></div>
<?php endif; ?>
<div class="wrapper">
<div class="rateItRating-selected" style="display: block;"></div>
<div class="rateItRating-hover"></div>
</div>
<?php if ($this->showAfter) : ?>
<div id="<?= $this->descriptionId ?>" class="ratingText"><?= $this->description ?></div>
<?php endif; ?>
</div>
<?php $this->endblock(); ?>
<!-- indexer::continue -->
<?php endif; ?>

View File

@ -1,17 +0,0 @@
<?php $this->extend('news_full_rateit'); ?>
<?php $this->block('rating'); ?>
<!-- indexer::stop -->
<div itemtype="http://schema.org/CreativeWork" itemscope class="rating-microdata">
<?php $this->parent(); ?>
<span class="rating-microdata" itemprop="name"><?php echo $this->itemreviewed; ?></span>
<span class="rating-microdata" itemtype="http://schema.org/AggregateRating" itemscope itemprop="aggregateRating">
<span itemprop="ratingValue"><?php echo $this->actRating; ?></span>
<span itemprop="worstRating">0</span>
<span itemprop="bestRating"><?php echo $this->maxRating; ?></span>
<span itemprop="ratingCount"><?php echo $this->votes; ?></span>
</span>
</div>
<!-- indexer::continue -->
<?php $this->endblock(); ?>

View File

@ -1,40 +0,0 @@
<?php if ($this->rateit_rating_before): ?>
<!-- indexer::stop -->
<?php $this->block('rating'); ?>
<div id="<?= $this->ratingId ?>" class="<?= $this->class ?> <?= $this->rateit_class ?>">
<?php if ($this->showBefore) : ?>
<div id="<?= $this->descriptionId ?>" class="ratingText"><?= $this->description ?></div>
<?php endif; ?>
<div class="wrapper">
<div class="rateItRating-selected" style="display: block;"></div>
<div class="rateItRating-hover"></div>
</div>
<?php if ($this->showAfter) : ?>
<div id="<?= $this->descriptionId ?>" class="ratingText"><?= $this->description ?></div>
<?php endif; ?>
</div>
<?php $this->endblock(); ?>
<!-- indexer::continue -->
<?php endif; ?>
<?php $this->insert('news_latest', $this->arrData); ?>
<?php if ($this->rateit_rating_after): ?>
<!-- indexer::stop -->
<?php $this->block('rating'); ?>
<div id="<?= $this->ratingId ?>" class="<?= $this->class ?> <?= $this->rateit_class ?>">
<?php if ($this->showBefore) : ?>
<div id="<?= $this->descriptionId ?>" class="ratingText"><?= $this->description ?></div>
<?php endif; ?>
<div class="wrapper">
<div class="rateItRating-selected" style="display: block;"></div>
<div class="rateItRating-hover"></div>
</div>
<?php if ($this->showAfter) : ?>
<div id="<?= $this->descriptionId ?>" class="ratingText"><?= $this->description ?></div>
<?php endif; ?>
</div>
<?php $this->endblock(); ?>
<!-- indexer::continue -->
<?php endif; ?>

View File

@ -1,17 +0,0 @@
<?php $this->extend('news_latest_rateit'); ?>
<?php $this->block('rating'); ?>
<!-- indexer::stop -->
<div itemtype="http://schema.org/CreativeWork" itemscope class="rating-microdata">
<?php $this->parent(); ?>
<span class="rating-microdata" itemprop="name"><?php echo $this->itemreviewed; ?></span>
<span class="rating-microdata" itemtype="http://schema.org/AggregateRating" itemscope itemprop="aggregateRating">
<span itemprop="ratingValue"><?php echo $this->actRating; ?></span>
<span itemprop="worstRating">0</span>
<span itemprop="bestRating"><?php echo $this->maxRating; ?></span>
<span itemprop="ratingCount"><?php echo $this->votes; ?></span>
</span>
</div>
<!-- indexer::continue -->
<?php $this->endblock(); ?>

View File

@ -1,40 +0,0 @@
<?php if ($this->rateit_rating_before): ?>
<!-- indexer::stop -->
<?php $this->block('rating'); ?>
<div id="<?= $this->ratingId ?>" class="<?= $this->class ?> <?= $this->rateit_class ?>">
<?php if ($this->showBefore) : ?>
<div id="<?= $this->descriptionId ?>" class="ratingText"><?= $this->description ?></div>
<?php endif; ?>
<div class="wrapper">
<div class="rateItRating-selected" style="display: block;"></div>
<div class="rateItRating-hover"></div>
</div>
<?php if ($this->showAfter) : ?>
<div id="<?= $this->descriptionId ?>" class="ratingText"><?= $this->description ?></div>
<?php endif; ?>
</div>
<?php $this->endblock(); ?>
<!-- indexer::continue -->
<?php endif; ?>
<?php $this->insert('news_short', $this->arrData); ?>
<?php if ($this->rateit_rating_after): ?>
<!-- indexer::stop -->
<?php $this->block('rating'); ?>
<div id="<?= $this->ratingId ?>" class="<?= $this->class ?> <?= $this->rateit_class ?>">
<?php if ($this->showBefore) : ?>
<div id="<?= $this->descriptionId ?>" class="ratingText"><?= $this->description ?></div>
<?php endif; ?>
<div class="wrapper">
<div class="rateItRating-selected" style="display: block;"></div>
<div class="rateItRating-hover"></div>
</div>
<?php if ($this->showAfter) : ?>
<div id="<?= $this->descriptionId ?>" class="ratingText"><?= $this->description ?></div>
<?php endif; ?>
</div>
<?php $this->endblock(); ?>
<!-- indexer::continue -->
<?php endif; ?>

View File

@ -1,17 +0,0 @@
<?php $this->extend('news_short_rateit'); ?>
<?php $this->block('rating'); ?>
<!-- indexer::stop -->
<div itemtype="http://schema.org/CreativeWork" itemscope class="rating-microdata">
<?php $this->parent(); ?>
<span class="rating-microdata" itemprop="name"><?php echo $this->itemreviewed; ?></span>
<span class="rating-microdata" itemtype="http://schema.org/AggregateRating" itemscope itemprop="aggregateRating">
<span itemprop="ratingValue"><?php echo $this->actRating; ?></span>
<span itemprop="worstRating">0</span>
<span itemprop="bestRating"><?php echo $this->maxRating; ?></span>
<span itemprop="ratingCount"><?php echo $this->votes; ?></span>
</span>
</div>
<!-- indexer::continue -->
<?php $this->endblock(); ?>

View File

@ -1,40 +0,0 @@
<?php if ($this->rateit_rating_before): ?>
<!-- indexer::stop -->
<?php $this->block('rating'); ?>
<div id="<?= $this->ratingId ?>" class="<?= $this->class ?> <?= $this->rateit_class ?>">
<?php if ($this->showBefore) : ?>
<div id="<?= $this->descriptionId ?>" class="ratingText"><?= $this->description ?></div>
<?php endif; ?>
<div class="wrapper">
<div class="rateItRating-selected" style="display: block;"></div>
<div class="rateItRating-hover"></div>
</div>
<?php if ($this->showAfter) : ?>
<div id="<?= $this->descriptionId ?>" class="ratingText"><?= $this->description ?></div>
<?php endif; ?>
</div>
<?php $this->endblock(); ?>
<!-- indexer::continue -->
<?php endif; ?>
<?php $this->insert('news_simple', $this->arrData); ?>
<?php if ($this->rateit_rating_after): ?>
<!-- indexer::stop -->
<?php $this->block('rating'); ?>
<div id="<?= $this->ratingId ?>" class="<?= $this->class ?> <?= $this->rateit_class ?>">
<?php if ($this->showBefore) : ?>
<div id="<?= $this->descriptionId ?>" class="ratingText"><?= $this->description ?></div>
<?php endif; ?>
<div class="wrapper">
<div class="rateItRating-selected" style="display: block;"></div>
<div class="rateItRating-hover"></div>
</div>
<?php if ($this->showAfter) : ?>
<div id="<?= $this->descriptionId ?>" class="ratingText"><?= $this->description ?></div>
<?php endif; ?>
</div>
<?php $this->endblock(); ?>
<!-- indexer::continue -->
<?php endif; ?>

View File

@ -1,17 +0,0 @@
<?php $this->extend('news_simple_rateit'); ?>
<?php $this->block('rating'); ?>
<!-- indexer::stop -->
<div itemtype="http://schema.org/CreativeWork" itemscope class="rating-microdata">
<?php $this->parent(); ?>
<span class="rating-microdata" itemprop="name"><?php echo $this->itemreviewed; ?></span>
<span class="rating-microdata" itemtype="http://schema.org/AggregateRating" itemscope itemprop="aggregateRating">
<span itemprop="ratingValue"><?php echo $this->actRating; ?></span>
<span itemprop="worstRating">0</span>
<span itemprop="bestRating"><?php echo $this->maxRating; ?></span>
<span itemprop="ratingCount"><?php echo $this->votes; ?></span>
</span>
</div>
<!-- indexer::continue -->
<?php $this->endblock(); ?>

View File

@ -1,14 +0,0 @@
<!-- indexer::stop -->
<div id="<?= $this->id ?>" class="<?= $this->class ?> <?= $this->rateit_class ?> block"<?= $this->cssID ?><?php if ($this->style): ?> style="<?= $this->style ?>"<?php endif; ?>>
<?php if ($this->showBefore) : ?>
<div id="<?= $this->descriptionId ?>" class="ratingText"><?= $this->description ?></div>
<?php endif; ?>
<div class="wrapper">
<div class="rateItRating-selected" style="display: block;"></div>
<div class="rateItRating-hover"></div>
</div>
<?php if ($this->showAfter) : ?>
<div id="<?= $this->descriptionId ?>" class="ratingText"><?= $this->description ?></div>
<?php endif; ?>
</div>
<!-- indexer::continue -->

View File

@ -1,23 +0,0 @@
<!-- indexer::stop -->
<div itemtype="http://schema.org/CreativeWork" itemscope class="rating-microdata">
<div id="<?= $this->id ?>" class="<?= $this->class ?> <?= $this->rateit_class ?> block"<?= $this->cssID ?><?php if ($this->style): ?> style="<?= $this->style ?>"<?php endif; ?>>
<?php if ($this->showBefore) : ?>
<div id="<?= $this->descriptionId ?>" class="ratingText"><?= $this->description ?></div>
<?php endif; ?>
<div class="wrapper">
<div class="rateItRating-selected" style="display: block;"></div>
<div class="rateItRating-hover"></div>
</div>
<?php if ($this->showAfter) : ?>
<div id="<?= $this->descriptionId ?>" class="ratingText"><?= $this->description ?></div>
<?php endif; ?>
</div>
<span class="rating-microdata" itemprop="name"><?php echo $this->itemreviewed; ?></span>
<span class="rating-microdata" itemtype="http://schema.org/AggregateRating" itemscope itemprop="aggregateRating">
<span itemprop="ratingValue"><?php echo $this->actRating; ?></span>
<span itemprop="worstRating">0</span>
<span itemprop="bestRating"><?php echo $this->maxRating; ?></span>
<span itemprop="ratingCount"><?php echo $this->votes; ?></span>
</span>
</div>
<!-- indexer::continue -->

View File

@ -1,95 +0,0 @@
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<svg
xmlns:dc="http://purl.org/dc/elements/1.1/"
xmlns:cc="http://creativecommons.org/ns#"
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
xmlns:svg="http://www.w3.org/2000/svg"
xmlns="http://www.w3.org/2000/svg"
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
width="110.03758"
height="107.5"
viewBox="0 0 88.030066 86"
version="1.1"
id="svg2"
inkscape:version="0.48.3.1 r9886"
sodipodi:docname="word.svg">
<metadata
id="metadata126">
<rdf:RDF>
<cc:Work
rdf:about="">
<dc:format>image/svg+xml</dc:format>
<dc:type
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
<dc:title></dc:title>
</cc:Work>
</rdf:RDF>
</metadata>
<defs
id="defs124" />
<sodipodi:namedview
pagecolor="#ffffff"
bordercolor="#666666"
borderopacity="1"
objecttolerance="10"
gridtolerance="10"
guidetolerance="10"
inkscape:pageopacity="0"
inkscape:pageshadow="2"
inkscape:window-width="1280"
inkscape:window-height="960"
id="namedview122"
showgrid="false"
inkscape:zoom="1.0905983"
inkscape:cx="344.89442"
inkscape:cy="53.75"
inkscape:window-x="0"
inkscape:window-y="0"
inkscape:window-maximized="1"
inkscape:current-layer="svg2"
fit-margin-top="0"
fit-margin-left="0"
fit-margin-right="0"
fit-margin-bottom="0" />
<path
d="m 46.04,0 5.94,0 c 0,2.67 0,5.33 0,8 10.01,0 20.02,0.02 30.03,-0.03 1.69,0.07 3.55,-0.05 5.02,0.96 1.03,1.48 0.91,3.36 0.98,5.06 -0.05,17.36 -0.03,34.71 -0.02,52.06 -0.05,2.91 0.27,5.88 -0.34,8.75 -0.4,2.08 -2.9,2.13 -4.57,2.2 -10.36,0.03 -20.73,-0.02 -31.1,0 0,3 0,6 0,9 l -6.21,0 C 30.53,83.23 15.26,80.67 0,78 0,54.67 0,31.34 0,8.01 15.35,5.34 30.7,2.71 46.04,0 z"
id="path10"
inkscape:connector-curvature="0"
style="fill:#207245" />
<path
d="m 51.98,11 c 11,0 22,0 33,0 0,21 0,42 0,63 -11,0 -22,0 -33,0 0,-2 0,-4 0,-6 2.67,0 5.33,0 8,0 0,-2.33 0,-4.67 0,-7 -2.67,0 -5.33,0 -8,0 0,-1.33 0,-2.67 0,-4 2.67,0 5.33,0 8,0 0,-2.33 0,-4.67 0,-7 -2.67,0 -5.33,0 -8,0 0,-1.33 0,-2.67 0,-4 2.67,0 5.33,0 8,0 0,-2.33 0,-4.67 0,-7 -2.67,0 -5.33,0 -8,0 0,-1.33 0,-2.67 0,-4 2.67,0 5.33,0 8,0 0,-2.33 0,-4.67 0,-7 -2.67,0 -5.33,0 -8,0 0,-1.33 0,-2.67 0,-4 2.67,0 5.33,0 8,0 0,-2.33 0,-4.67 0,-7 -2.67,0 -5.33,0 -8,0 0,-2 0,-4 0,-6 z"
id="path48"
inkscape:connector-curvature="0"
style="fill:#ffffff" />
<path
d="m 63.98,17 c 4.67,0 9.33,0 14,0 0,2.33 0,4.67 0,7 -4.67,0 -9.33,0 -14,0 0,-2.33 0,-4.67 0,-7 z"
id="path58"
inkscape:connector-curvature="0"
style="fill:#207245" />
<path
d="m 29.62,26.37 c 2.26,-0.16 4.53,-0.3 6.8,-0.41 -2.67,5.47 -5.35,10.94 -8.07,16.39 2.75,5.6 5.56,11.16 8.32,16.76 -2.41,-0.14 -4.81,-0.29 -7.22,-0.46 -1.7,-4.17 -3.77,-8.2 -4.99,-12.56 -1.36,4.06 -3.3,7.89 -4.86,11.87 -2.19,-0.03 -4.38,-0.12 -6.57,-0.21 2.57,-5.03 5.05,-10.1 7.7,-15.1 -2.25,-5.15 -4.72,-10.2 -7.04,-15.32 2.2,-0.13 4.4,-0.26 6.6,-0.38 1.49,3.91 3.12,7.77 4.35,11.78 1.32,-4.25 3.29,-8.25 4.98,-12.36 z"
id="path72"
inkscape:connector-curvature="0"
style="fill:#ffffff" />
<path
d="m 63.98,28 c 4.67,0 9.33,0 14,0 0,2.33 0,4.67 0,7 -4.67,0 -9.33,0 -14,0 0,-2.33 0,-4.67 0,-7 z"
id="path90"
inkscape:connector-curvature="0"
style="fill:#207245" />
<path
d="m 63.98,39 c 4.67,0 9.33,0 14,0 0,2.33 0,4.67 0,7 -4.67,0 -9.33,0 -14,0 0,-2.33 0,-4.67 0,-7 z"
id="path108"
inkscape:connector-curvature="0"
style="fill:#207245" />
<path
d="m 63.98,50 c 4.67,0 9.33,0 14,0 0,2.33 0,4.67 0,7 -4.67,0 -9.33,0 -14,0 0,-2.33 0,-4.67 0,-7 z"
id="path114"
inkscape:connector-curvature="0"
style="fill:#207245" />
<path
d="m 63.98,61 c 4.67,0 9.33,0 14,0 0,2.33 0,4.67 0,7 -4.67,0 -9.33,0 -14,0 0,-2.33 0,-4.67 0,-7 z"
id="path120"
inkscape:connector-curvature="0"
style="fill:#207245" />
</svg>

Before

Width:  |  Height:  |  Size: 4.0 KiB

Some files were not shown because too many files have changed in this diff Show More