<?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\Post;
use Illuminate\Support\Facades\Route;

function getSetting($key)
{
    if (!\Schema::hasTable('settings')){
        return false;
    }
    $x = Setting::where('key', $key)->first();
    if ($x == null) {
        $a = new \stdClass();
        return '';
    }
    return $x->value;
}
function getSettingCategory($key)
{
    $x = Setting::where('key', $key)->first();
    if ($x == null) {
        $a = new \stdClass();
        return '';
    }
    return Category::where('id',$x->value)->first();
}
function getSettingCat($key)
{
    $x = Setting::where('key', $key)->first();
    if ($x == null) {
        $a = new \stdClass();
        return '';
    }
    return Cat::where('id',$x->value)->first();
}


function stockTypes()
{
    return ["IN_STOCK" => __("In stock"), "OUT_STOCK" => __("Out stock"), "BACK_ORDER" => __("Back order")];
}

function metaing($metaz)
{
    $out = [];
    if ($metaz == null) {
        return $out;
    }
    foreach ($metaz as $k => $meta) {
        $out[$k] = $meta->value;
    }
    return $out;
}

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;
}


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;
}

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;
}

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;
}

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;
}

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;
}

function MenuShowByName($menu_name)
{
    $menu = Menu::whereName($menu_name)->firstOrFail();
    return MenuShowItems($menu->menuItems()->whereNull('parent')->get());
}

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>';
    }
}


function getMainCats($limit = 10)
{
    return Cat::whereNull('parent_id')->limit($limit)->get();
}

function getProductByCat($id, $order = 'id', $orderMethod = 'desc', $limit = 10)
{
    $cat = Cat::where('id', $id)->first();

    if ($cat == null){
        return  [];
    }
    return $cat->products()->where('active',1)
        ->orderBy($order, $orderMethod)->limit($limit)->get();
}
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();
}

function getSubCats($id)
{
    return Cat::where('parent_id', $id)->get();
}

function getProducts($order = 'id', $orderMethod = 'desc', $limit = 10)
{
    return Product::orderBy($order, $orderMethod)->limit($limit)->get();
}


function getProp($name)
{
    return Prop::where('name', $name)->first();
}

function getPropUnit($name)
{
    if ( Prop::where('name', $name)->count() == 0) {
        return  '';
    }
    return Prop::where('name', $name)->first()->unit;
}

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;
        }
    }
}

function isJson($str)
{
    $json = json_decode($str);
    return $json && $str != $json;
}

function jsonOrder($json)
{
    $data = json_decode( $json ,true);
    asort($data);
    return $data;
}

function showMetaValue($key, $value){
    $p = Prop::whereName($key)->first();
    foreach (json_decode($p->options) as $n){
        if ($n->value == $value){
            return $n->title;
        }
    }
}
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));
}

function time2persian($date, $format = 'Y/m/d')
{
    $dt = new TDate();
    return $dt->PDate($format, $date);
}

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;
}
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  'رنگ';
}

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;
}

function makeProductBreadcrumb($p, $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;
}

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);
}

function cardCount(){
    return count(array_merge(unserialize(session('card', serialize([]))),unserialize(session('qcard', serialize([])))));
}



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;
}

function remTitle($str){
    $re = '/<title>(.*?)<\/title>/m';
    return preg_replace($re,'',$str);
}
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';
}
function findLink($html){

    $url = preg_match('/<a href="(.+)">/', $html, $match);

    if (!isset($match[1])){
        return null;
    }

    return $match[1];

}