select( 'pp_articles', [ 'id' ], [ 'hash' => $hash ] ); if ( is_array( $rows ) ) foreach ( $rows as $row ) { $article = \front\factory\Articles::article_details( $row['id'], 'pl' ); $text = '

Witaj,
'; $text .= 'Użytkownik zatwierdził listę wybranych przez siebie zdjęć.
'; $text .= 'Poniżej znajdziesz nazwy wybranych zdjęć.

'; $text .= ''; \S::send_email( $settings['contact_email'], 'Powiadomienie ze strony: ' . $_SERVER['SERVER_NAME'], $text ); return true; } return false; } public static function pixieset_image_favorite( $image_id, $hash ) { global $mdb; $rows = $mdb -> select( 'pp_articles', [ 'id' ], [ 'hash' => $hash ] ); if ( is_array( $rows ) ) foreach ( $rows as $row ) { $status = $mdb -> get( 'pp_articles_images', 'favorite', [ 'AND' => [ 'article_id' => $row['id'], 'id' => $image_id ] ] ); $mdb -> update( 'pp_articles_images', [ 'favorite' => !$status ], [ 'AND' => [ 'article_id' => $row['id'], 'id' => $image_id ] ] ); \S::delete_dir( 'temp/' ); return !$status; } } public static function article_password( $article_id ) { global $mdb; return $mdb -> get( 'pp_articles', 'password', [ 'id' => $article_id ] ); } public static function articles_by_tags( $tag_id, $lang_id ) { global $mdb; if ( !$articles = \Cache::fetch( "articles_by_tags:$tag_id:$lang_id" ) ) { $results = $mdb -> query( 'SELECT ' . 'pa.id ' . 'FROM ' . 'pp_articles AS pa ' . 'INNER JOIN pp_articles_tags AS pat ON pat.article_id = pa.id ' . 'WHERE ' . 'status = 1 ' . 'AND ' . 'tag_id = ' . (int)$tag_id ) -> fetchAll(); if ( is_array( $results ) and !empty( $results ) ) foreach ( $results as $row ) $articles[] = \front\factory\Articles::article_details( $row['id'], $lang_id ); \Cache::store( "articles_by_tags:$tag_id:$lang_id", $articles ); } return $articles; } public static function tag_details( $tag_id ) { global $mdb; if ( !$tag = \Cache::fetch( "tag_details:$tag_id" ) ) { $tag = $mdb -> get( 'pp_tags', '*', [ 'id' => (int)$tag_id ] ); \Cache::store( "tag_details:$tag_id", $tag ); } return $tag; } public static function tags() { global $mdb; if ( !$tags = \Cache::fetch( 'tags' ) ) { $tags = $mdb -> query( 'SELECT ' . 'name, COUNT( tag_id ) AS c ' . 'FROM ' . 'pp_tags AS pt ' . 'INNER JOIN pp_articles_tags ON pt.id = tag_id ' . 'GROUP BY ' . 'tag_id ' . 'ORDER BY ' . 'c DESC ' . 'LIMIT 20' ) -> fetchAll(); \Cache::store( 'tags', $tags ); } return $tags; } public static function articles_by_date( $month, $year, $lang_id ) { global $mdb; if ( !$articles = \Cache::fetch( "articles_by_date:$month:$year:$lang_id" ) ) { $results = $mdb -> query( 'SELECT ' . 'id ' . 'FROM ' . 'pp_articles ' . 'WHERE ' . 'status = 1 ' . 'AND ' . '( ' . '( date_start BETWEEN \'' . date( 'Y-m-d', strtotime( '01-' . $month . '-' . $year ) ) . '\' AND \'' . date( 'Y-m-t', strtotime( '01-' . $month . '-' . $year ) ) . '\' ) ' . 'OR ' . '( date_end BETWEEN \'' . date( 'Y-m-d', strtotime( '01-' . $month . '-' . $year ) ) . '\' AND \'' . date( 'Y-m-t', strtotime( '01-' . $month . '-' . $year ) ) . '\' ) ' . 'OR ' . '( date_start <= \'' . date( 'Y-m-t', strtotime( '01-' . $month . '-' . $year ) ) . '\' AND date_end >= \'' . date( 'Y-m-t', strtotime( '01-' . $month . '-' . $year ) ) . '\' ) ' . ')' ) -> fetchAll(); if ( is_array( $results ) and !empty( $results ) ) foreach ( $results as $row ) $articles[] = \front\factory\Articles::article_details( $row['id'], $lang_id ); \Cache::store( "articles_by_date:$month:$year:$lang_id", $articles ); } return $articles; } public static function news( $page_id, $limit = 6, $lang_id ) { $sort = \front\factory\Pages::page_sort( $page_id ); $articles_id = \front\factory\Articles::artciles_id( (int)$page_id, $lang_id, $limit, $sort, 0 ); if ( is_array( $articles_id ) and !empty( $articles_id ) ) foreach ( $articles_id as $article_id ) $articles[] = \front\factory\Articles::article_details( $article_id, $lang_id ); return $articles; } public static function get_image( $article, $skip_entry = false ) { if ( $article['language']['main_image'] ) { if ( file_exists( substr( $article['language']['main_image'], 1, strlen( $article['language']['main_image'] ) ) ) ) return $article['language']['main_image']; } if ( !$skip_entry ) { $dom = new \DOMDocument(); $dom -> loadHTML( mb_convert_encoding( $article['language']['entry'], 'HTML-ENTITIES', "UTF-8" ) ); $images = $dom -> getElementsByTagName( 'img' ); foreach ( $images as $img ) { $src = $img -> getAttribute( 'src' ); if ( file_exists( substr( $src, 1, strlen( $src ) ) ) ) return $src; } } $dom = new \DOMDocument(); $dom -> loadHTML( mb_convert_encoding( $article['language']['text'], 'HTML-ENTITIES', "UTF-8" ) ); $images = $dom -> getElementsByTagName( 'img' ); foreach ( $images as $img ) { $src = $img -> getAttribute( 'src' ); if ( file_exists( substr( $src, 1, strlen( $src ) ) ) ) return $src; } if ( $article['images'] ) return $article['images'][0]['src']; return false; } public static function article_noindex( $article_id ) { global $mdb, $lang; if ( !$noindex = \Cache::fetch( "article_noindex:$article_id:" . $lang[0] ) ) { $noindex = $mdb -> get( 'pp_articles_langs', 'noindex', [ 'AND' => [ 'article_id' => (int)$article_id, 'lang_id' => $lang[0] ] ] ); \Cache::store( "article_noindex:$article_id:" . $lang[0], $noindex ); } return $noindex; } public static function page_articles( $page, $lang_id, $bs ) { $count = \front\factory\Articles::page_articles_count( $page['id'], $lang_id ); $ls = ceil( $count / $page['articles_limit'] ); if ( $bs < 1 ) $bs = 1; else if ( $bs > $ls ) $bs = $ls; $from = $page['articles_limit'] * ( $bs - 1 ); if ( $from < 0 ) $from = 0; $results['articles'] = \front\factory\Articles::artciles_id( (int)$page['id'], $lang_id, (int)$page['articles_limit'], $page['sort_type'], $from ); $results['ls'] = $ls; return $results; } public static function article_details( $article_id, $lang_id ) { global $mdb; if ( !$article = \Cache::fetch( "article_details:$lang_id:$article_id" ) ) { $article = $mdb -> get( 'pp_articles', '*', [ 'id' => (int)$article_id ] ); $results = $mdb -> select( 'pp_articles_langs', '*', [ 'AND' => [ 'article_id' => (int)$article_id, 'lang_id' => $lang_id ] ] ); if ( is_array( $results ) ) foreach ( $results as $row ) { if ( $row['copy_from'] ) { $results2 = $mdb -> select( 'pp_articles_langs', '*', [ 'AND' => [ 'article_id' => (int)$article_id, 'lang_id' => $row['copy_from'] ] ] ); if ( is_array( $results2 ) ) foreach ( $results2 as $row2 ) $article['language'] = $row2; } else $article['language'] = $row; preg_match_all( \front\view\Site::container_pattern, $article['language']['entry'], $container_list ); if ( is_array( $container_list[0] ) ) foreach( $container_list[0] as $container_list_tmp ) { $container_list_tmp = explode( ':', $container_list_tmp ); $article['language']['entry'] = str_replace( '[KONTENER:' . $container_list_tmp[1] . ']', \front\view\Scontainers::scontainer( $container_list_tmp[1] ), $article['language']['entry'] ); } preg_match_all( \front\view\Site::container_pattern, $article['language']['text'], $container_list ); if ( is_array( $container_list[0] ) ) foreach( $container_list[0] as $container_list_tmp ) { $container_list_tmp = explode( ':', $container_list_tmp ); $article['language']['text'] = str_replace( '[KONTENER:' . $container_list_tmp[1] . ']', \front\view\Scontainers::scontainer( $container_list_tmp[1] ), $article['language']['text'] ); } } $article['images'] = $mdb -> select( 'pp_articles_images', '*', [ 'article_id' => (int)$article_id, 'ORDER' => [ 'o' => 'ASC', 'id' => 'ASC' ] ] ); $article['files'] = $mdb -> select( 'pp_articles_files', '*', [ 'article_id' => (int)$article_id ] ); $article['pages'] = $mdb -> select( 'pp_articles_pages', 'page_id', [ 'article_id' => (int)$article_id ] ); $article['tags'] = $mdb -> select( 'pp_tags', [ '[><]pp_articles_tags' => [ 'id' => 'tag_id' ] ], 'name', [ 'article_id' => (int)$article_id ] ); $results = $mdb -> select( 'pp_articles_additional_params', [ '[><]pp_articles_additional_values' => [ 'id' => 'param_id' ] ], [ 'name', 'value', 'language_id' ], [ 'article_id' => (int)$article_id ] ); if ( is_array( $results ) ) foreach ( $results as $row ) { if ( !$row['language_id'] ) $params[ $row['name'] ] = $row['value']; else $params[ $row['name'] ][$row['language_id']] = $row['value']; } $article['params'] = $params; \Cache::store( "article_details:$lang_id:$article_id", $article ); } return $article; } public static function artciles_id( $page_id, $lang_id, $articles_limit, $sort_type, $from ) { global $mdb; switch ( $sort_type ) { case 0: $order = 'priority DESC, date_add ASC'; break; case 1: $order = 'priority DESC, date_add DESC'; break; case 2: $order = 'priority DESC, date_modify ASC'; break; case 3: $order = 'priority DESC, date_modify DESC'; break; case 4: $order = 'priority DESC, o ASC'; break; case 5: $order = 'priority DESC, title ASC'; break; case 6: $order = 'priority DESC, title DESC'; break; default: $order = 'priority DESC, id ASC'; break; } if ( !$output = \Cache::fetch( "artciles_id:$page_id:$lang_id:$order:$from:$articles_limit" ) ) { $results = $mdb -> query( 'SELECT * FROM ( ' . 'SELECT ' . 'a.id, date_modify, date_add, o, priority, ' . '( CASE ' . 'WHEN copy_from IS NULL THEN title ' . 'WHEN copy_from IS NOT NULL THEN ( ' . 'SELECT ' . 'title ' . 'FROM ' . 'pp_articles_langs ' . 'WHERE ' . 'lang_id = al.copy_from AND article_id = a.id ' . ') ' . 'END ) AS title ' . 'FROM ' . 'pp_articles_pages AS ap ' . 'INNER JOIN pp_articles AS a ON a.id = ap.article_id ' . 'INNER JOIN pp_articles_langs AS al ON al.article_id = ap.article_id ' . 'WHERE ' . 'status = 1 AND page_id = ' . (int)$page_id . ' AND lang_id = \'' . $lang_id . '\' ' . ') AS q1 ' . 'WHERE ' . 'q1.title IS NOT NULL ' . 'ORDER BY ' . 'q1.' . $order . ' ' . 'LIMIT ' . (int)$from . ',' . (int)$articles_limit ) -> fetchAll(); if ( is_array( $results ) and !empty( $results ) ) foreach ( $results as $row ) $output[] = $row['id']; \Cache::store( "artciles_id:$page_id:$lang_id:$order:$from:$articles_limit", $output ); } return $output; } public static function page_articles_count( $page_id, $lang_id ) { global $mdb; if ( !$output = \Cache::fetch( "page_articles_count:$page_id:$lang_id" ) ) { $results = $mdb -> query( 'SELECT COUNT(0) FROM ( ' . 'SELECT ' . 'a.id, ' . '( CASE ' . 'WHEN copy_from IS NULL THEN title ' . 'WHEN copy_from IS NOT NULL THEN ( ' . 'SELECT ' . 'title ' . 'FROM ' . 'pp_articles_langs ' . 'WHERE ' . 'lang_id = al.copy_from AND article_id = a.id ' . ') ' . 'END ) AS title ' . 'FROM ' . 'pp_articles_pages AS ap ' . 'INNER JOIN pp_articles AS a ON a.id = ap.article_id ' . 'INNER JOIN pp_articles_langs AS al ON al.article_id = ap.article_id ' . 'WHERE ' . 'status = 1 AND page_id = ' . (int)$page_id . ' AND lang_id = \'' . $lang_id . '\' ' . ') AS q1 ' . 'WHERE ' . 'q1.title IS NOT NULL' ) -> fetchAll(); $output = $results[0][0]; \Cache::store( "page_articles_count:$page_id:$lang_id", $output ); } return $output; } }