-
Notifications
You must be signed in to change notification settings - Fork 0
/
market.php
128 lines (109 loc) · 3.69 KB
/
market.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
<?php
/**
* market
*
* @package Sngine
* @author Zamblek
*/
// fetch bootloader
require('bootloader.php');
// market enabled
if(!$system['market_enabled']) {
_error(404);
}
// user access
if(!$system['system_public']) {
user_access();
}
// page header
page_header($system['system_title'].' - '.__("Market"));
// market
try {
// get view content
$_GET['view'] = (isset($_GET['view']))? $_GET['view'] : '';
switch ($_GET['view']) {
case '':
// get promoted products
$promoted_products = array();
$get_promoted = $db->query("SELECT posts.post_id FROM posts INNER JOIN posts_products ON posts.post_id = posts_products.post_id WHERE posts.post_type = 'product' AND posts_products.available = '1' AND posts.boosted = '1' ORDER BY RAND() LIMIT 3") or _error("SQL_ERROR");
while($promoted_product = $get_promoted->fetch_assoc()) {
$promoted_product = $user->get_post($promoted_product['post_id']);
if($promoted_product) {
$promoted_products[] = $promoted_product;
}
}
/* assign variables */
$smarty->assign('promoted_products', $promoted_products);
// prepare query
/* prepare where query */
$where_query = "";
/* prepare pager url */
$url = "";
break;
case 'search':
// check query
if(!isset($_GET['query']) || is_empty($_GET['query'])) {
redirect('/market');
}
/* assign variables */
$smarty->assign('query', $_GET['query']);
// prepare query
/* prepare where query */
$where_query = sprintf('AND (posts.text LIKE %1$s OR posts_products.name LIKE %1$s)', secure($_GET['query'], 'search') );
/* prepare pager url */
$url = "/search/".$_GET['query'];
break;
case 'category':
// check category
if(!in_array($_GET['category_id'], $user->get_market_categories_ids())) {
_error(404);
}
/* assign variables */
$smarty->assign('category_id', $_GET['category_id']);
// prepare query
/* prepare where query */
$where_query = sprintf("AND posts_products.category_id = %s", secure($_GET['category_id'], 'int'));
/* prepare pager url */
$url = "/category/".$_GET['category_id']."/".$_GET['category_url'];
break;
default:
_error(404);
break;
}
// get market categories
$categories = $user->get_market_categories();
/* assign variables */
$smarty->assign('categories', $categories);
// get products
require('includes/class-pager.php');
$params['selected_page'] = ( (int) $_GET['page'] == 0) ? 1 : $_GET['page'];
$total = $db->query("SELECT COUNT(*) as count FROM posts INNER JOIN posts_products ON posts.post_id = posts_products.post_id WHERE posts.post_type = 'product' AND posts_products.available = '1'".$where_query) or _error("SQL_ERROR");
$params['total_items'] = $total->fetch_assoc()['count'];
$params['items_per_page'] = $system['min_results_even'];
$params['url'] = $system['system_url'].'/market'.$url.'/%s';
$pager = new Pager($params);
$limit_query = $pager->getLimitSql();
// get posts
$rows = array();
$get_rows = $db->query("SELECT posts.post_id FROM posts INNER JOIN posts_products ON posts.post_id = posts_products.post_id WHERE posts.post_type = 'product' AND posts_products.available = '1'".$where_query." ORDER BY post_id DESC ".$limit_query) or _error("SQL_ERROR");
while($row = $get_rows->fetch_assoc()) {
$row = $user->get_post($row['post_id']);
if($row) {
$rows[] = $row;
}
}
/* assign variables */
$smarty->assign('rows', $rows);
$smarty->assign('total', $params['total_items']);
$smarty->assign('pager', $pager->getPager());
$smarty->assign('view', $_GET['view']);
// get ads
$ads = $user->ads('market');
/* assign variables */
$smarty->assign('ads', $ads);
} catch (Exception $e) {
_error(__("Error"), $e->getMessage());
}
// page footer
page_footer("market");
?>