You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
xshop/app/Helpers/Helper.php

838 lines
21 KiB
PHP

<?php
namespace App\Helpers;
use App\Models\Cat;
use App\Models\Product;
use App\Models\Prop;
use App\Models\Setting;
use Xmen\StarterKit\Helpers\TDate;
use Xmen\StarterKit\Models\Category;
use Xmen\StarterKit\Models\Menu;
use Xmen\StarterKit\Models\MenuItem;
use Xmen\StarterKit\Models\Post;
use Illuminate\Support\Facades\Route;
/***
* get setting by key
* @param string $key setting key
* @return false|\Illuminate\Database\Eloquent\HigherOrderBuilderProxy|mixed|string|null
*/
function getSetting($key)
{
if (!isset($_SERVER['SERVER_NAME']) || !\Schema::hasTable('settings')) {
return false;
}
$x = Setting::where('key', $key)->first();
if ($x == null) {
$a = new \stdClass();
return '';
}
return $x->value;
}
/***
* get category form setting by key
* @param string $key setting key
* @return \Illuminate\Database\Eloquent\Builder|\Illuminate\Database\Eloquent\Model|object|string|Category|null
*/
function getSettingCategory($key)
{
$x = Setting::where('key', $key)->first();
if ($x == null) {
$a = new \stdClass();
return '';
}
return Category::where('id', $x->value)->first();
}
/***
* get product category by setting key
* @param string $key setting key
* @return Cat|\Illuminate\Database\Eloquent\Builder|\Illuminate\Database\Eloquent\Model|object|string|null
*/
function getSettingCat($key)
{
$x = Setting::where('key', $key)->first();
if ($x == null) {
$a = new \stdClass();
return '';
}
return Cat::where('id', $x->value)->first();
}
/***
* get stock types
* @return array
*/
function stockTypes()
{
return ["IN_STOCK" => __("In stock"), "OUT_STOCK" => __("Out stock"), "BACK_ORDER" => __("Back order")];
}
/***
* make meta with key and value
* @param $metaz
* @return array
*/
function metaing($metaz)
{
$out = [];
if ($metaz == null) {
return $out;
}
foreach ($metaz as $k => $meta) {
$out[$k] = $meta->value;
}
return $out;
}
/***
* get just pricable meta of product
* @param Product $pro
* @return array
*/
function getPriceableMeta(Product $pro)
{
$metas = $pro->getAllMeta()->toArray();
if (count($metas) == 0) {
return [];
}
$pricables = $pro->category->props()->where('priceable', 1)->pluck('name')->toArray();
$result = [];
if (is_array($pricables)) {
foreach ($pricables as $price) {
if (isset($metas[$price])) {
$result[$price] = $metas[$price];
}
}
}
return $result;
}
/***
* show product categories in node with ul-li
* @param $cats category node
* @param $liClass class of lis
* @param $ulClass class of uls
* @return string
*/
function showCats($cats = [], $liClass = '', $ulClass = '')
{
if ($cats == []) {
$cats = Cat::whereNull('parent_id')->get();
}
$txt = '';
foreach ($cats as $cat) {
$txt .= '<li class="' . $liClass . '">
<a href="' . route('cat', $cat->slug) . '">' . $cat->name . '</a>';
if ($cat->children()->count() > 0) {
// $txt .='<li> '.$cat->name;
$txt .= '<ul class="' . $ulClass . '">';
$txt .= showCats($cat->children, $liClass, $ulClass);
$txt .= '</ul>';
} else {
}
$txt .= '</li>';
}
return $txt;
}
/***
* show menu node for manage
* @param $arr
* @return string
*/
function showMenuMange($arr)
{
$back = '';
foreach ($arr as $menu) {
$ol = '';
if ($menu->children()->count() > 0) {
$ol = '<ol>' . showMenuMange($menu->children()->orderBy('sort')->get()) . '</ol>';
}
$back .= <<<LI
<li class="list-group-item"
data-menuabletype="$menu->menuable_type"
data-menuableid="$menu->menuable_id"
data-meta="$menu->meta"
data-kind="$menu->kind"
data-title="$menu->title"
>
<span>
$menu->title
</span>
$ol
</li>
LI;
}
return $back;
}
/***
* show menu node
* @param array $arr
* @return string
*/
function showMenu($arr)
{
$back = '';
foreach ($arr as $menu) {
$ol = '';
if ($menu->children()->count() > 0) {
$ol = '<ol>' . showMenu($menu->children()->orderBy('sort')->get()) . '</ol>';
}
switch ($menu->kind) {
case "empty":
$back .= <<<LI
<li class="nav-item">
<li class="nav-item">
<a class="nav-link" >$menu->title</a>
</li>
$ol
</li>
LI;
break;
case "link":
$back .= <<<LI
<li class="nav-item">
<li class="nav-item">
<a class="nav-link" href="$menu->meta">$menu->title</a>
</li>
$ol
</li>
LI;
break;
case "news":
break;
case "cat":
break;
case "cat-sub":
break;
case "cat-news":
break;
case "tag":
break;
case "tag-sub":
break;
default:
}
}
return $back;
}
/***
* show input products categories node
* @param Cat[] $arr
* @return string
*/
function showCatNode($arr)
{
$ret = '';
foreach ($arr as $cat) {
$ret .= "<li data-id='$cat->id' > $cat->name <ol> ";
if ($cat->children()->count() > 0) {
$ret .= showCatNode($cat->children);
}
$ret .= " </ol> </li> ";
}
return $ret;
}
/***
* show menu items as types
* @param MenuItem[] $items
* @return string
*/
function MenuShowItems($items)
{
$out = '';
foreach ($items as $item) {
$out .= '<li>';
switch ($item->kind) {
case "tag":
$out .= '<a href="' . route('n.tag', $item->meta) . '" >' . $item->title . '</a>';
break;
case "link":
$out .= '<a href="' . $item->meta . '" >' . $item->title . '</a>';
break;
case "news":
$n = Post::whereId($item->menuable_id)->firstOrFail();
$out .= '<a href="' . route('n.show', $n->slug) . '" >' . $item->title . '</a>';
break;
case "tag-sub":
$out .= $item->title;
$news = Post::withAnyTag($item->meta)->limit(10)->get(['title', 'slug']);
$out .= '<ul>';
foreach ($news as $new) {
$out .= '<li><a href="' . route('n.show', $new->slug) . '" >' . $new->title . '</a></li>';
}
$out .= '</ul>';
break;
case "cat":
$cat = Category::whereId($item->menuable_id)->firstOrFail();
$out .= '<a href="' . route('n.cat', $cat->slug) . '" >' . $item->title . '</a>';
break;
case "cat-sub":
$out .= $item->title;
$cats = Category::where('parent_id', $item->menuable_id)->limit(20)->get(['name', 'slug']);
$out .= '<ul>';
foreach ($cats as $c) {
$out .= '<li><a href="' . route('n.cat', $c->slug) . '" >' . $c->name . '</a></li>';
}
$out .= '</ul>';
break;
case "cat-news":
$out .= '<a class="menu-link">' . $item->title . '</a>';
$cat = Category::whereId($item->menuable_id)->firstOrFail();
$news = $cat->posts()->limit(10)->get(['slug', 'title']);
$out .= '<ul>';
foreach ($news as $new) {
$out .= '<li><a href="' . route('n.show', $new->slug) . '" >' . $new->title . '</a></li>';
}
$out .= '</ul>';
break;
default:
$out .= $item->title;
if ($item->children()->count() > 0) {
$out .= '<ul>' . MenuShowItems($item->children) . '</ul>';
}
}
$out .= '</li>';
}
$out .= '';
return $out;
}
/***
* show menu by name
* @param $menu_name
* @return string
*/
function MenuShowByName($menu_name)
{
$menu = Menu::whereName($menu_name)->firstOrFail();
return MenuShowItems($menu->menuItems()->whereNull('parent')->get());
}
/***
* make breadcrumbs for admin panel
* @return void
*/
function lastCrump()
{
$routes = explode('.', Route::currentRouteName());
if (count($routes) != 3) {
echo '<li class="step">
<a>
<i class="fa fa-cube" ></i>
' . __(ucfirst($routes[count($routes) - 1])) . '
</a>
</li>';
return;
}
$route = $routes[count($routes) - 1];
if ($route == 'home') {
return;
}
if ($route == 'all' || $route == 'index' || $route == 'list') {
echo '<li class="step">
<a>
<i class="fa fa-list" ></i>
' . __(ucfirst($routes[count($routes) - 2])) . '
</a>
</li>';
} else {
$link = '#';
$temp = $routes;
array_pop($temp);
$temp = implode('.', $temp) . '.';
if (Route::has($temp . 'index')) {
$link = \route($temp . 'index');
} elseif (Route::has($temp . 'all')) {
$link = \route($temp . 'all');
} elseif (Route::has($temp . 'list')) {
$link = \route($temp . 'list');
}
echo '<li class="step">
<a href="' . $link . '">
<i class="fa fa-list" ></i>
' . __(ucfirst($routes[count($routes) - 2])) . '
</a>
</li>';
switch ($route) {
case 'create':
$title = __('Add') . ' ' . __($routes[count($routes) - 2]);
$icon = 'fa fa-add';
break;
case 'edit':
$title = __('Edit') . ' ' . __($routes[count($routes) - 2]);
$icon = 'fa fa-edit';
break;
case 'show':
$title = __('Show') . ' ' . __($routes[count($routes) - 2]);
$icon = 'fa fa-eye';
break;
case 'sort':
$title = __('Sort') . ' ' . __($routes[count($routes) - 2]);
$icon = 'fa fa-sort';
break;
default:
$title = __('') . ' ' . __(ucfirst($routes[count($routes) - 1]));
$icon = 'fa fa-cube';
break;
}
echo '<li class="step">
<a>
<i class="' . $icon . '" ></i>
' . $title . '
</a>
</li>';
}
}
/***
* get main product categories
* @param int $limit
* @return Cat[]|\Illuminate\Database\Eloquent\Collection|\Illuminate\Database\Query\Builder[]|\Illuminate\Support\Collection|\LaravelIdea\Helper\App\Models\_IH_Cat_C
*/
function getMainCats($limit = 10)
{
return Cat::whereNull('parent_id')->limit($limit)->get();
}
/***
* get products by category id
* @param int $id
* @param string $order
* @param string $orderMethod
* @param int $limit
* @return Product[]|array|\Illuminate\Database\Eloquent\Collection|\LaravelIdea\Helper\App\Models\_IH_Product_C
*/
function getProductByCat($id, $order = 'id', $orderMethod = 'desc', $limit = 10)
{
$cat = Cat::where('id', $id)->first();
if ($cat == null) {
return [];
}
return $cat->active_products()->where('active', 1)
->orderBy($order, $orderMethod)->limit($limit)->get();
}
/***
* get product by category id where `stock_quantity` more than 0
* @param int $id
* @param string $order
* @param int $limit
* @return Product[]|array|\Illuminate\Database\Eloquent\Collection|\LaravelIdea\Helper\App\Models\_IH_Product_C
*/
function getProductByCatQ($id, $order = 'id', $limit = 10)
{
$cat = Cat::where('id', $id)->first();
if ($cat == null) {
return [];
}
return $cat->products()->where('active', 1)->where('stock_quantity', '>', 0)
->orderByDesc('id')->limit($limit)->get();
}
/***
* get sub product categories by id
* @param $id
* @return Cat[]|\Illuminate\Database\Eloquent\Builder[]|\Illuminate\Database\Eloquent\Collection|\LaravelIdea\Helper\App\Models\_IH_Cat_C
*/
function getSubCats($id)
{
return Cat::where('parent_id', $id)->get();
}
/***
* get products with sort
* @param string $order
* @param string $orderMethod
* @param int $limit
* @return Product[]|\Illuminate\Database\Eloquent\Collection|\Illuminate\Database\Query\Builder[]|\Illuminate\Support\Collection|\LaravelIdea\Helper\App\Models\_IH_Product_C
*/
function getProducts($order = 'id', $orderMethod = 'desc', $limit = 10)
{
return Product::orderBy($order, $orderMethod)->limit($limit)->get();
}
/***
* get property by name
* @param string $name
* @return Prop|\Illuminate\Database\Eloquent\Builder|\Illuminate\Database\Eloquent\Model|object|null
*/
function getProp($name)
{
return Prop::where('name', $name)->first();
}
/***
* get unit of property by name
* @param string $name
* @return \Illuminate\Database\Eloquent\HigherOrderBuilderProxy|mixed|string|null
*/
function getPropUnit($name)
{
if (Prop::where('name', $name)->count() == 0) {
return '';
}
return Prop::where('name', $name)->first()->unit;
}
/***
* get label of property by name
* @param string $name
* @return array|\Illuminate\Contracts\Foundation\Application|\Illuminate\Contracts\Translation\Translator|\Illuminate\Database\Eloquent\HigherOrderBuilderProxy|mixed|string|null
*/
function getPropLabel($name)
{
if (Prop::where('name', $name)->count() == 0) {
return '';
}
$n = Prop::where('name', $name)->first();
if ($n != null) {
return Prop::where('name', $name)->first()->label;
} else {
if ($name == 'weight') {
return __('weight');
} else {
return $name;
}
}
}
/***
* check is json or not
* @param string $str
* @return bool
*/
function isJson($str)
{
$json = json_decode($str);
return $json && $str != $json;
}
/***
* json decode and sort
* @param array $json
* @return mixed
*/
function jsonOrder($json)
{
$data = json_decode($json, true);
asort($data);
return $data;
}
/***
* get meta value
* @param string $key
* @param string $value
* @return void
*/
function getMetaValue($key, $value)
{
$p = Prop::whereName($key)->first();
foreach (json_decode($p->options) as $n) {
if ($n->value == $value) {
return $n->title;
}
}
}
/***
* show meta with values
* @param string $key
* @param string $value
* @return string
*/
function showMeta($key, $value)
{
if (Prop::whereName('warranty')->count() == 0 && $key == 'warranty') {
return '';
}
if ($key == 'weight') {
return $value . ' ' . __('Gram(s)');
}
if ($key == 'warranty') {
$p = Prop::whereName('warranty')->first();
foreach (json_decode($p->options) as $n) {
if ($n->value == $value) {
return $n->title;
}
}
}
if ($key == 'color') {
return '<div style="background: ' . $value . ';min-width: 15px; height:15px; display: inline-block; margin-right: 4px; margin-left: 4px" ></div><b style="position: relative;top: -3px;padding:2px;display: inline-block">' . getColorName($value) . '</b>';
}
$txt = $value;
if (isJson($value)) {
$txt = '';
foreach (json_decode($value, true) as $item) {
$txt .= '<div class="badge p-1 ps-2 pe-2 m-1 bg-primary mb-0" > ' . $item['title'] . ' </div>';
}
}
return trim($txt . ' ' . getPropUnit($key));
}
/***
* time to persian date
* @param $date
* @param $format
* @return float|int|string|\Xmen\StarterKit\Helpers\timestamp
*/
function time2persian($date, $format = 'Y/m/d')
{
if ($date == null){
return '-';
}
$dt = new TDate();
return $dt->PDate($format, $date);
}
/***
* get colors
* @return array
*/
function getColors()
{
$colors = Prop::where('name', 'color')->first();
if ($colors == null) {
return [];
}
$data = json_decode($colors->options, true);
$result = [];
foreach ($data as $color) {
$result[$color['value']] = $color['title'];
}
return $result;
}
/***
* get color name
* @param $colorVal
* @return mixed|string
*/
function getColorName($colorVal)
{
$colors = Prop::where('name', 'color')->first();
if ($colors == null) {
return 'رنگ';
}
$data = json_decode($colors->options, true);
foreach ($data as $color) {
if ($colorVal == $color['value']) {
return $color['title'];
}
}
return 'رنگ';
}
/***
* make chartjs
* @param $pro
* @return string
*/
function makeChart($pro)
{
$times = $pro->prices_history()->pluck('created_at')->toArray();
$dates = [];
foreach (array_reverse($times) as $time) {
$dates[] = \App\Helpers\time2persian($time->timestamp, 'd F Y');
}
$dts = json_encode($dates);
$prs = json_encode(array_reverse($pro->prices_history()->pluck('price')->toArray()));
$text = <<<TXT
<canvas id="canvas" style="display: block; height: 400px;" height="400" class="chartjs-render-monitor"></canvas>
<input type="hidden" id="labels" value='$dts'>
<input type="hidden" id="prices" value='$prs'>
TXT;
return $text;
}
/***
* make breadcrumb
* @param Product $p
* @param Cat $c
* @return array[]
*/
function makeProductBreadcrumb(Product $p, Cat $c)
{
$items = [
[
'name' => $c->name,
'link' => \route('cat', $c->slug)
]
];
while ($c->parent_id != null) {
$c = Cat::where('id', $c->parent_id)->first();
$items[] = [
'name' => $c->name,
'link' => \route('cat', $c->slug)
];
}
$items = array_reverse($items);
$items[] = [
'name' => $p->name,
'link' => \route('product', $p->slug)
];
return $items;
}
/***
* show markup breadcrumb
* @param $itemz
* @return void
*/
function showBreadcrumb($itemz = [])
{
$text = <<<DOC
<script type="application/ld+json">
{
"@context": "https://schema.org/",
"@type": "BreadcrumbList",
"itemListElement": [
ITEMS
]
}
</script>
DOC;
$items = '{
"@type": "ListItem",
"position": 1,
"name": "' . config('app.name') . '",
"item": "' . route('welcome') . '"
},';
foreach ($itemz as $k => $item) {
$items .= '{
"@type": "ListItem",
"position": ' . ($k + 2) . ',
"name": "' . $item['name'] . '",
"item": "' . $item['link'] . '"
},';
}
$items = ltrim($items);
echo str_replace('ITEMS', $items, $text);
}
/***
* get items count in shoppig card
* @return int
*/
function cardCount()
{
return count(array_merge(unserialize(session('card', serialize([]))), unserialize(session('qcard', serialize([])))));
}
/***
* send sms
* @param string $number phone number
* @param string $content sms content
* @return bool|string
*/
function sendSMSText($number, $content)
{
$url = 'http://rest.payamak-panel.com/api/SendSMS/SendSMS';
$options = array(
'content-type' => 'application/x-www-form-urlencoded',
'postman-token' => '3e37c158-2c35-75aa-1ae7-f76d90ebbe8f',
'cache-control' => 'no-cache'
);
$fields_string = http_build_query(array(
'username' => config('app.sms_user'),
'password' => config('app.sms_pass'),
'to' => $number,
'from' => config('app.sms_number'),
'text' => $content,
'isflash' => 'false'
));
//open connection
$ch = curl_init();
//set the url, number of POST vars, POST data
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_POSTFIELDS, $fields_string);
//So that curl_exec returns the contents of the cURL; rather than echoing it
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
//execute post
$result = curl_exec($ch);
return $result;
}
/***
* remove title of html code
* @param $str
* @return array|string|string[]|null
*/
function remTitle($str)
{
$re = '/<title>(.*?)<\/title>/m';
return preg_replace($re, '', $str);
}
/***
* show json by key
* @param $json
* @param $key
* @return mixed|string
*/
function showJsonByKey($json, $key)
{
$x = json_decode($json);
$x = json_decode($x->data, true);
$items = json_decode(\App\Helpers\getProp('size')->options, true);
foreach ($items as $item) {
if ($x[$key] == $item['value']) {
return $item['title'];
}
}
return 'x';
}
/***
* find html links
* @param $html
* @return string|null
*/
function findLink($html)
{
$url = preg_match('/<a href="(.+)">/', $html, $match);
if (!isset($match[1])) {
return null;
}
return $match[1];
}