date('y', $time),
        '{Y}' => date('Y', $time),
        '{M}' => date('m', $time),
        '{D}' => date('d', $time),
        '{H}' => date('H', $time),
        '{I}' => date('i', $time),
        '{S}' => date('s', $time),
    ];
    $table = $config['table'];
    $data = $config['data'];
    $prefix = $config['prefix'];
    $length = $config['length'] > 0 ? $config['length'] : 4;
    $rule = empty($config['rule']) ? '{Y}{M}{D}' : $config['rule'];
    $bill_id = $config['bill_id'];
    // 生成序号调用插件
    $_data = App\Support\Hook::fire($table . '.onBillSeqNo', ['bill_id' => $bill_id, 'rule' => $rule]);
    extract($_data);
    if ($data) {
        $data = str_replace($prefix, '', $data);
        $new_rule = mb_substr($data, 0, mb_strlen($data) - $length);
    } else {
        $new_rule = str_replace(array_keys($items), array_values($items), $rule);
    }
    $no = DB::table('model_seq_no')
    ->where('bill_id', $bill_id)
    ->where('rule_code', $new_rule)
    ->first();
    if (empty($no)) {
        $new_sn = 1;
        if ($update == true) {
            DB::table('model_seq_no')
            ->insert([
                'bill_id' => $bill_id,
                'rule_code' => $new_rule,
                'seq_no' => $new_sn,
            ]);
        }
    } else {
        $new_sn = (int) $no['seq_no'] + 1;
        if ($update == true) {
            DB::table('model_seq_no')
            ->where('bill_id', $bill_id)
            ->where('rule_code', $new_rule)
            ->update([
                'seq_no' => $new_sn,
            ]);
        }
    }
    $new_value = $config['prefix'] . $new_rule . str_pad($new_sn, $length, '0', STR_PAD_LEFT);
    return ['new_rule' => $new_rule, 'new_sn' => $new_sn, 'new_value' => $new_value];
}
// 高级搜索生成 where 条件
function search_condition($query)
{
    $search = $query['search'];
    $type = $query['condition'];
    switch ($type) {
        case 'is':
            $condition = array('=', $search);
            break;
        case 'isnot':
            $condition = array('!=', $search);
            break;
        case 'like':
            $condition = array('like', '%' . $search . '%');
            break;
        case 'not_like':
            $condition = array('not like', '%' . $search . '%');
            break;
        case 'start_with':
            $condition = array('like', $search . '%');
            break;
        case 'not_start_with':
            $condition = array('not like', $search . '%');
            break;
        case 'end_with':
            $condition = array('like', '%' . $search);
            break;
        case 'empty':
            $condition = array('=', '');
            break;
        case 'not_empty':
            $condition = array('!=', '');
            break;
        case 'gt':
            $condition = array('>', $search);
            break;
        case 'egt':
            $condition = array('>=', $search);
            break;
        case 'lt':
            $condition = array('<', $search);
            break;
        case 'elt':
            $condition = array('<=', $search);
            break;
        case 'eq':
            $condition = array('=', $search);
            break;
        case 'neq':
            $condition = array('!=', $search);
            break;
        case 'birthday':
            $condition = array('birthday', $search);
            break;
        case 'birthbetween':
            $condition = array('birthbetween', $search);
            break;
        case 'pacs':
            $condition = array('pacs', $search);
            break;
        case 'region':
            $condition = array('region', $search);
            break;
        case 'in':
            $condition = array('in', explode(',', $search));
            break;
        case 'dialog':
            $condition = array('in', explode(',', $search));
            break;
        case 'address':
            $condition = array('!=', '');
            break;
        case 'second2':
            $condition = array('second2', [strtotime($search[0]), strtotime($search[1])]);
            break;
        case 'between':
            $search = strtotime($search);
            $condition = array('between', array($search - 1, $search + 86400));
            break;
        case 'not_between':
            $search = strtotime($search);
            $condition = array('not_between', array($search, $search + 86399));
            break;
        case 'tlt':
            $condition = array('<', strtotime($search));
            break;
        case 'tgt':
            $condition = array('>', strtotime($search) + 86400);
            break;
        default:
            $condition = array('=', $search);
    }
    return $condition;
}
// 组合搜索表单
function search_form($params = [], $columns = [], $type = 'old')
{
    if ($params['referer']) {
        $uri = join('_', Request::segments());
        Session::put('referer_' . $uri, URL::full());
    }
    $params['advanced'] = isset($params['advanced']) ? $params['advanced'] : 0;
    $gets = Request::all();
    $query = $where = [];
    foreach ($gets as $key => $get) {
        $key = str_replace('_', '.', $key);
        Arr::set($query, $key, $get);
    }
    if ($query['field']) {
        foreach ($query['field'] as $i => $field) {
            $forms['field'][$i] = $field;
            $forms['condition'][$i] = $query['condition'][$i];
            $forms['search'][$i] = $query['search'][$i];
            $forms['option'][$i] = $query['option'][$i];
            $where[$i]['field'] = $field;
            $where[$i]['condition'] = $query['condition'][$i];
            $where[$i]['search'] = $query['search'][$i];
            $active = 0;
            if ($query['condition'][$i] == 'not_empty' || $query['condition'][$i] == 'empty') {
                $active = 1;
            }
            if ($active == 0) {
                $values = is_array($query['search'][$i]) ? $query['search'][$i] : [$query['search'][$i]];
                foreach ($values as $key => $value) {
                    if ($value == '') {
                        continue;
                    }
                    $active = 1;
                }
            }
            $where[$i]['active'] = $active;
        }
    } else {
        if ($type == 'model') {
            foreach ($columns as $i => $column) {
                $forms['field'][$i] = $column['field'];
                $forms['condition'][$i] = '';
                $forms['search'][$i] = isset($column['value']) ? $column['value'] : '';
                $forms['option'][$i] = $column['options'];
            }
        } else {
            foreach ($columns as $i => $column) {
                $forms['field'][$i] = $column[1];
                $forms['condition'][$i] = '';
                $forms['search'][$i] = isset($column[3]) ? $column[3] : '';
                $forms['option'][$i] = $column['options'];
            }
        }
    }
    foreach ($params as $key => $default) {
        $params[$key] = Request::get($key, $default);
        $forms[$key] = $params[$key];
    }
    $gets['limit'] = $gets['limit'] > 0 ? $gets['limit'] : 50;
    $search['forms'] = $forms;
    $search['columns'] = $columns;
    $search['params'] = $params;
    $search['where'] = $where;
    $search['query'] = $gets + $params;
    return $search;
}
/**
 * 选择圈负责客户列表
 */
function regionCustomer($table = 'customer')
{
    $user = Auth::user();
    $role = DB::table('role')->find($user->role_id);
    $level = Gdoo\User\Services\UserService::authorise();
    $res['columns'] = [];
    $res['whereIn'] = [];
    $res['table'] = $table;
    $res['region1'] = [];
    $res['region2'] = [];
    $res['region3'] = [];
    $res['customer'] = [];
    $res['authorise'] = false;
    $query = [
        'region1_id' => 0,
        'region2_id' => 0,
        'region3_id' => 0,
        'customer_id' => 0,
    ];
    foreach ($query as $k => $v) {
        $query[$k] = Request::get($k, $v);
    }
    $regions = DB::table('customer_region')->get()->toNested();
    // 审批权限
    $owners = DB::table('customer_region')
    ->where('owner_user_id', $user->id)
    ->get()->toArray();
    // 查询权限
    $assists = DB::table('customer_region')
    ->whereRaw(db_instr('owner_assist', $user->id))
    ->get()->toArray();
    $region1 = $region2 = $region3 = [];
    $ids = [];
    foreach ($owners as $v) {
        $ids = array_merge($ids, $regions[$v['id']]['parent']);
        $ids = array_merge($ids, $regions[$v['id']]['child']);
    }
    foreach ($assists as $v) {
        $ids = array_merge($ids, $regions[$v['id']]['parent']);
        $ids = array_merge($ids, $regions[$v['id']]['child']);
    }
    $role_type = 'self';
    if (empty($ids)) {
        $role_type = 'all';
    } else {
        $role_type = 'region';
    }  
    // 销售组
    if ($level == 5) {
        $role_type = 'region';
    }
    
    // 客户
    if ($role['code'] == 'c001') {
        $role_type = 'customer';
    }
    // 客户联系人
    if ($role['code'] == 'c002') {
        $role_type = 'customer_contact';
    }
    // 登录账号类型
    switch ($role_type) {
            // 区域权限
        case 'region':
            // 查询省区权限
            $region1 = DB::table('customer_region')
            ->whereIn('id', $ids)
            ->where('layer', 1)
            ->get();
            $model = DB::table('customer_region')
            ->whereIn('id', $ids)
            ->where('layer', 2);
            if ($query['region1_id'] > 0) {
                $model->where('parent_id', $query['region1_id']);
            }
            $region2 = $model->get();
            $model = DB::table('customer_region')
            ->whereIn('id', $ids);
            if ($query['region1_id']) {
                $model->whereIn('parent_id', $region2->pluck('id'));
            }
            if ($query['region2_id'] > 0) {
                $model->where('parent_id', $query['region2_id']);
            }
            $region3 = $model->where('layer', 3)->get();
            if ($owners) {
                $res['owner_user'] = $owners;
            }
            if ($assists) {
                $res['owner_assist'] = $assists;
            }
            $res['region1'] = $region1;
            if ($query['region1_id'] > 0) {
                $res['region2'] = $region2;
            }
            if ($query['region2_id'] > 0) {
                $res['region3'] = $region3;
            }
            if ($query['region1_id'] == 0) {
                $query['region2_id'] = 0;
                $query['region3_id'] = 0;
                $query['customer_id'] = 0;
            }
            if ($query['region2_id'] == 0) {
                $query['region3_id'] = 0;
                $query['customer_id'] = 0;
            }
            if ($query['region3_id'] > 0) {
                $res['whereIn'][$table . '.region_id'] = [$query['region3_id']];
            } else {
                $res['whereIn'][$table . '.region_id'] = $region3->pluck('id')->toArray();
                $query['customer_id'] = 0;
            }
            $res['regionIn'] = $res['whereIn'][$table . '.region_id'];
            $res['authorise'] = true;
            break;
            // 客户角色
        case 'customer':
            $users[] = $user->id;
            $customerIds = DB::table('customer')->where('user_id', $user->id)->pluck('id');
            $res['whereIn'][$table . '.id'] = $customerIds;
            $res['customerIn'] = $customerIds;
            $res['regionIn'] = [];
            $res['authorise'] = true;
            break;
            // 客户联系人
        case 'customer_contact':
            $users[] = $user->id;
            $customerIds = DB::table('customer_contact')->where('user_id', $user->id)->pluck('customer_id');
            $res['whereIn'][$table . '.id'] = $customerIds;
            $res['customerIn'] = $customerIds;
            $res['regionIn'] = [];
            $res['authorise'] = true;
            break;
        case 'self':
            $users[] = $user->id;
            $res['whereIn'][$table . '.created_id'] = $users;
            $res['customerIn'] = [];
            $res['regionIn'] = [];
            $res['authorise'] = true;
            break;
        case 'all':
            if ($query['region1_id'] == 0) {
                $query['region2_id'] = 0;
                $query['region3_id'] = 0;
                $query['customer_id'] = 0;
            }
            if ($query['region2_id'] == 0) {
                $query['region3_id'] = 0;
                $query['customer_id'] = 0;
            }
            $region1 = DB::table('customer_region')
            ->where('layer', 1)
            ->get();
            $model = DB::table('customer_region');
            if ($query['region1_id'] > 0) {
                $model->where('parent_id', $query['region1_id']);
            } else {
                $model->whereIn('parent_id', $region1->pluck('id'));
            }
            $region2 = $model->where('layer', 2)->get();
            $model = DB::table('customer_region');
            if ($query['region2_id'] > 0) {
                $model->where('parent_id', $query['region2_id']);
            } else {
                $model->whereIn('parent_id', $region2->pluck('id'));
            }
            $region3 = $model->where('layer', 3)->get();
            $res['region1'] = $region1;
            if ($query['region1_id'] > 0) {
                $res['region2'] = $region2;
                $res['authorise'] = true;
            }
            if ($query['region2_id'] >  0) {
                $res['region3'] = $region3;
                $res['authorise'] = true;
            }
            if ($query['region3_id'] > 0) {
                $res['whereIn'][$table . '.region_id'] = [$query['region3_id']];
            } else {
                $res['whereIn'][$table . '.region_id'] = $region3->pluck('id')->toArray();
            }
            $res['regionIn'] = $res['whereIn'][$table . '.region_id'];
            break;
            // 默认其他角色
        default:
    }
    if ($query['region3_id'] > 0) {
        $res['customer'] = DB::table('customer')
        ->where('customer.region_id', $query['region3_id'])
        ->get(['id', 'status', 'name as customer_name'])->toArray();
    }
    if ($query['customer_id'] > 0) {
        $res['whereIn'] = [];
        $res['whereIn'][$table . '.id'] = [$query['customer_id']];
    }
    // 处理区域权限
    if ($level == 5) {
        $res['authorise'] = true;
    }
    $res['query'] = $query;
    return $res;
}
/**
 * 检查权限授权层级
 */
function authorise($action = null, $asset_name = null)
{
    return Gdoo\User\Services\UserService::authorise($action, $asset_name);
}
/**
 * 附件上传
 */
function attachment_uploader($field, $ids, $key, $draft = true)
{
    $attachments = Gdoo\Index\Services\AttachmentService::edit($ids, $key . '.' . $field);
    if ($draft == false) {
        unset($attachments['draft']);
    }
    return view('attachment/create2', [
        'field' => $field,
        'key' => $key,
        'attachments' => $attachments,
    ]);
}
/**
 * 附件显示
 */
function attachment_show($field, $ids = '')
{
    $attachments = Gdoo\Index\Services\AttachmentService::show($ids);
    return view('attachment/show2', [
        'attachments' => $attachments,
    ]);
}
/**
 * 附件编辑
 */
function attachment_edit($table, $id, $path = '')
{
    $attach['model'] = $table;
    $attach['path'] = $path;
    $attach['draft'] = DB::table($table)->where('created_id', Auth::id())->where('status', 0)->get();
    $id = array_filter(explode(',', $id));
    if ($id) {
        $queue = DB::table($table)->whereIn('id', $id)->where('status', 1)->get();
    }
    $attach['queue'] = array_by($queue);
    return $attach;
}
/**
 * 附件编辑
 */
function attachment_view($table, $id)
{
    $attach['model'] = $table;
    $id = array_filter(explode(',', $id));
    if ($id) {
        $queue = DB::table($table)->whereIn('id', $id)->where('status', 1)->get();
    }
    $attach['view'] = array_by($queue);
    return $attach;
}
/**
 * 查询附件
 */
function attachment_get($table, $id)
{
    $id = array_filter(explode(',', $id));
    if ($id) {
        return DB::table($table)->whereIn('id', $id)->get();
    }
    return [];
}
/**
 * 附件删除
 */
function attachment_delete($table, $id)
{
    if ($id) {
        $rows = DB::table($table)->whereIn('id', $id)->get();
        foreach ($rows as $row) {
            // 文件路径
            $name = $row['path'] == '' ? $row['name'] : $row['path'];
            $file = upload_path() . '/' . $name;
            if (is_file($file)) {
                unlink($file);
            }
            // 旧版文件删除
            $old = upload_path() . '/' . $row['path'] . '/' . $row['name'];
            if (is_file($old)) {
                unlink($old);
            }
            DB::table($table)->where('id', $row['id'])->delete();
        }
    }
    return true;
}
/**
 * 将草稿附件存储为可用
 */
function attachment_store($table, $id)
{
    if (empty($id)) {
        return '';
    }
    foreach ($id as $_id) {
        DB::table($table)->where('id', $_id)->update([
            'status' => 1,
        ]);
    }
    return join(',', array_filter($id));
}
// 多图片base64上传保存
function attachment_base64($table, $images, $path = 'default', $extension = 'jpg')
{
    $path = $path . '/' . date('Y/m');
    $directory = upload_path() . '/' . $path;
    if (!is_dir($directory)) {
        @mkdir($directory, 0777, true);
    }
    $res = [];
    foreach ($images as $image) {
        $name = date('dhis_') . str_random(4) . '.' . $extension;
        $name = mb_strtolower($name);
        $image = base64_decode(str_replace(' ', '+', $image));
        $size = file_put_contents($directory . '/' . $name, $image);
        if ($size) {
            $res[] = DB::table($table)->insertGetId([
                'path' => $path,
                'name' => $name,
                'title' => $name,
                'type' => $extension,
                'status' => 1,
                'size' => $size,
                'created_id' => Auth::id(),
                'created_at' => time(),
            ]);
        }
    }
    return join(',', array_filter($res));
}
// 多图片上传保存
function attachment_images($table, $name, $path = 'default')
{
    $images = Request::file($name);
    $path = $path . '/' . date('Y/m');
    $upload_path = upload_path() . '/' . $path;
    $res = [];
    foreach ($images as $image) {
        if ($image->isValid()) {
            // 文件后缀名
            $extension = $image->getClientOriginalExtension();
            // 兼容do开发的客户端上传
            if ($extension == 'do') {
                $clientName = $image->getClientOriginalName();
                $extension = pathinfo(substr($clientName, 0, -3), PATHINFO_EXTENSION);
            }
            // 文件新名字
            $filename = date('dhis_') . str_random(4) . '.' . $extension;
            $filename = mb_strtolower($filename);
            if ($image->move($upload_path, $filename)) {
                $res[] = DB::table($table)->insertGetId([
                    'path' => $path,
                    'name' => $filename,
                    'title' => $filename,
                    'type' => $extension,
                    'status' => 1,
                    'size' => $image->getClientSize(),
                    'created_id' => Auth::id(),
                    'created_at'    => time(),
                ]);
            }
        }
    }
    return join(',', array_filter($res));
}
/**
 * 单图片上传,并删除旧图片
 */
function image_create($path, $name = 'image', $oldfile = '')
{
    if (Request::hasFile($name)) {
        $file = Request::file($name);
        // 文件后缀名
        $extension = $file->getClientOriginalExtension();
        // 文件新名字
        $filename = date('dhis_') . str_random(4) . '.' . $extension;
        $filename = mb_strtolower($filename);
        $path = $path . '/' . date('Y/m');
        $upload_path = upload_path() . '/' . $path;
        if ($file->move($upload_path, $filename)) {
            // 上传成功删除旧文件
            if ($oldfile) {
                image_delete($oldfile);
            }
            return $path . '/' . $filename;
        }
    }
    return null;
}
/**
 * 删除单个图片
 */
function image_delete($file)
{
    $file = upload_path() . '/' . $file;
    if (is_file($file)) {
        unlink($file);
    }
}
/**
 * 生成缩略图
 */
function thumb($file, $width, $hight)
{
    $info = pathinfo($file);
    $thumb = $info['dirname'] . '/thumb-' . $width . '-' . $info['basename'];
    if (is_file($thumb)) {
        return 'thumb-' . $width . '-' . $info['basename'];
    }
    $img = new App\Support\Image();
    if (is_file($file)) {
        $img->crop($file, $width, $hight, 3, true);
        $img->save($thumb);
    }
    return 'thumb-' . $width . '-' . $info['basename'];
}
/**
 * 图片等比例缩放功能
 * $src_file:原文件
 * $dst_w:目标输出的宽
 * $dst_h:目标输出的高
 */
function imageResize($src_file, $dst_w, $dst_h)
{
    # 获取图片信息
    $imarr = getimagesize($src_file);
    # 获取图片类型 / 变量函数
    switch ($imarr[2]) {
        case 1:
            $imagecreatefrom = "imagecreatefromgif";
            $imageout = "imagegif";
            break;
        case 2:
            $imagecreatefrom = "imagecreatefromjpeg";
            $imageout = "imagejpeg";
            break;
        case 3:
            $imagecreatefrom = "imagecreatefrompng";
            $imageout = "imagepng";
            break;
    }
    # 大图
    $src_im = $imagecreatefrom($src_file);
    # 等比例计算目标资源的宽和高
    # 大图大小
    $src_w = imagesx($src_im);
    $src_h = imagesy($src_im);
    # 等比例缩放
    $scale = ($src_w / $dst_w) > ($src_h / $dst_h) ? ($src_w / $dst_w) : ($src_h / $dst_h);
    # 向下取整
    $dst_w = floor($src_w / $scale);
    $dst_h = floor($src_h / $scale);
    # 计算结束
    # 小图
    $dst_im = imagecreatetruecolor($dst_w, $dst_h);
    # 小图坐标
    $dst_x = 0;
    $dst_y = 0;
    # 大图坐标
    $src_x = 0;
    $src_y = 0;
    # 缩放
    imagecopyresampled($dst_im, $src_im, $dst_x, $dst_y, $src_x, $src_y, $dst_w, $dst_h, $src_w, $src_h);
    # 获取大图文件名并加工成小图文件名
    $t_name = 't_' . basename($src_file);
    # 获取大图文件目录
    $s_dir = dirname($src_file);
    # 定义小图保存目录,与大图一样
    $s_file = $s_dir . '/' . $t_name;
    $quality = 100;
    # 输出小图
    if ($imageout == "imagejpeg") {
        $imageout($dst_im, $src_file, $quality);
    } else {
        $imageout($dst_im, $src_file);
    }
}
// 用户头像处理
function avatar($avatar)
{
    if (is_file(upload_path('avatar') . '/' . $avatar)) {
        $src = URL::to('uploads/avatar') . '/' . $avatar;
    } else {
        $src = URL::to('assets/') . '/images/a1.jpg';
    }
    return $src;
}
/**
 * 计算年龄使用
 */
function date_year($date)
{
    if ($date == '0000-00-00') {
        return 0;
    }
    $d = new Carbon\Carbon($date);
    return $d->diffInYears();
}
/**
 * 计算剩余时间
 */
function remain_time($start, $end, $format = '%y年%m个月%d天%h小时%i分钟')
{
    if ($start == 0 || $end == 0) {
        return '';
    }
    $start = Carbon\Carbon::createFromTimeStamp($start);
    $end  = Carbon\Carbon::createFromTimeStamp($end);
    $diff = $start->diff($end);
    return $format == '' ? $diff : $diff->format($format);
}
function time_day_hour($time)
{
    $second = time() - $time;
    $day = floor($second / (3600 * 24));
    // 除去整天之后剩余的时间
    $second = $second % (3600 * 24);
    $hour = floor($second / 3600);
    return $day . '天' . $hour . '小时';
}
/**
 * 获取人性化的时间
 */
function human_time($time)
{
    return Carbon\Carbon::createFromTimeStamp($time)->diffForHumans();
}
/**
 * 人性化文件大小格式
 *
 * @param  int $bytes 文件字节
 * @return string     字符串
 */
function human_filesize($bytes)
{
    $s = ['B', 'KB', 'MB', 'GB', 'TB'];
    for ($f = 0; $bytes >= 1024 && $f < 4; $f++) {
        $bytes /= 1024;
    }
    return number_format((int) $bytes, 2) . $s[$f];
}
/**
 * 生产时间范围
 * 格式: 2012-8-20 - 2012-8-28
 */
function date_range($first, $last, $step = '+1 day', $format = 'Y-m-d')
{
    $dates = array();
    $current = strtotime($first);
    $last = strtotime($last);
    while ($current <= $last) {
        $dates[] = date($format, $current);
        $current = strtotime($step, $current);
    }
    return $dates;
}
// 时间戳格式化
function format_datetime($value, $default = '', $format = 'Y-m-d H:i')
{
    if ($value instanceof Carbon\Carbon) {
        $value = $value->getTimestamp();
    }
    if ($default) {
        $data = $default;
    }
    if ($value) {
        $data = $value;
    }
    if (strlen($data) != 10) {
        return '';
    }
    return $data ? date($format, $data) : '';
}
// 时间戳格式化到日期
function format_date($value, $default = '', $format = 'Y-m-d')
{
    return format_datetime($value, $default, $format);
}
// 时间戳格式化时间
function format_time($value, $default = '', $format = 'H:i')
{
    return format_datetime($value, $default, $format);
}
/**
 * 数字金额转换成大写金额
 */
function str_rmb($money)
{
    // 四舍五入
    $money = round($money, 2);
    if ($money <= 0) {
        return '零元';
    }
    $units   = array('', '拾', '佰', '仟', '', '万', '亿', '兆');
    $amount  = array('零', '壹', '贰', '叁', '肆', '伍', '陆', '柒', '捌', '玖');
    // 拆分小数点
    $arr     = explode('.', $money);
    // 翻转整数
    $money = strrev($arr[0]);
    // 获取数字的长度
    $length = strlen($money);
    for ($i = 0; $i < $length; $i++) {
        // 获取大写数字
        $int[$i] = $amount[$money[$i]];
        // 获取整数位
        if (!empty($money[$i])) {
            $int[$i] .= $units[$i % 4];
        }
        // 取整
        if ($i % 4 == 0) {
            $int[$i] .= $units[4 + floor($i / 4)];
        }
    }
    $con = isset($arr[1]) ? '元' . $amount[$arr[1][0]] . '角' . $amount[$arr[1][1]] . '分' : '元整';
    // 整合数组为字符串
    return implode('', array_reverse($int)) . $con;
}
/**
 * 根据参数自动获取模块控制器和方法组合 URL
 */
function url_build($path = null, $params = [])
{
    $module = Request::module();
    $controller = Request::controller();
    $action = Request::action();
    if (empty($path)) {
        $path = $module . '/' . $controller . '/' . $action;
    } else {
        $count = substr_count($path, '/');
        if ($count == 0) {
            $path = $module . '/' . $controller . '/' . $path;
        } elseif ($count == 1) {
            $path = $module . '/' . $path;
        }
    }
    if ($params) {
        $path = $path . '?' . http_build_query($params);
    }
    return URL::to($path);
}
/**
 * 组合URL使用referer
 */
function url_referer($path = null, $params = [], $referer = 1)
{
    // 模块内的跳转条件
    if ($referer) {
        $module = Request::module();
        $controller = Request::controller();
        $action = Request::action();
        if (empty($path)) {
            $uri = $module . '_' . $controller . '_' . $action;
        } else {
            $count = substr_count($path, '_');
            if ($count == 0) {
                $uri = $module . '_' . $controller . '_' . $path;
            } elseif ($count == 1) {
                $uri = $module . '_' . $path;
            }
        }
        $uri = Session::pull('referer_' . $uri);
        if ($uri) {
            return $uri;
        }
    }
    return url_build($path, $params);
}
/**
 * 复写Laravel的url
 */
function url($path = null, $params = [], $appends = [])
{
    $params = array_merge($params, $appends);
    return url_build($path, $params);
}
/**
 * 查找指定的字符串,支持逗号分隔多个字符
 */
function array_find($data, $key)
{
    $key = array_filter(explode(',', $key));
    if (empty($key)) {
        return false;
    }
    // 不是数组进行分割
    is_array($data) or $data = explode(',', $data);
    $data = array_filter($data);
    if (array_intersect($data, $key)) {
        return true;
    }
    return false;
}
/**
 * 数组重新按指定键排序
 */
function array_by($items, $key = 'id')
{
    $maps = [];
    if (empty($items)) {
        return $maps;
    }
    if ($key) {
        foreach ($items as $item) {
            $maps[$item[$key]] = $item;
        }
    } else {
        foreach ($items as $item) {
            $maps[] = $item;
        }
    }
    return $maps;
}
/** 把嵌套的数组转换到扁平化 */
function reduce_tree($arr, $level = -1)
{
    static $tree = [];
    $level++;
    foreach ($arr as $k => $v) {
        $v['level'] = $level;
        if ($v['children']) {
            $children = $v['children'];
            unset($v['children']);
            $tree[] = $v;
            reduce_tree($children, $level);
        } else {
            $tree[] = $v;
        }
    }
    return $tree;
}
/**
 * 把扁平数组格式化成嵌套数组
 */
function array_tree($items, $key = 'name', $id = 'id', $parentId = 'parent_id', $children = 'children')
{
    $items = is_array($items) ? $items : $items->toArray();
    $tree = $map = array();
    foreach ($items as $item) {
        $item['text'] = $item[$key];
        $item['folder'] = false;
        $item['isLeaf'] = true;
        $item['key'] = $item['id'];
        $map[$item[$id]] = $item;
    }
    foreach ($items as $item) {
        if (isset($map[$item[$parentId]])) {
            $map[$item[$parentId]]['folder'] = true;
            $map[$item[$parentId]]['isLeaf'] = false;
            $map[$item[$parentId]][$children][] = &$map[$item[$id]];
        } else {
            $tree[] = &$map[$item[$id]];
        }
    }
    unset($map, $items);
    return $tree;
}
/**
 * 重建树形结构的左右值
 *
 * @var $parent_id 构建的开始id
 */
function tree_rebuild($table, $parent_id = 0, $left = 0)
{
    // 左值 +1 是右值
    $right = $left + 1;
    // 获得这个节点的所有子节点
    $rows = DB::table($table)->where('parent_id', $parent_id)
        ->orderBy('sort', 'asc')
        ->get(['id', 'parent_id', 'lft', 'rgt']);
    if (sizeof($rows)) {
        foreach ($rows as $row) {
            // 这个节点的子$right是当前的右值,这是由treeRebuild函数递增
            $right = tree_rebuild($table, $row['id'], $right);
        }
    }
    // 更新左右值
    DB::table($table)->where('id', $parent_id)->orderBy('sort', 'asc')
        ->update(['lft' => $left, 'rgt' => $right]);
    // 返回此节点的右值+1
    return $right + 1;
}
function array_nest(&$items, $text = 'name')
{
    if (empty($items)) {
        return;
    }
    $tree = [];
    foreach ($items as $item) {
        $item['layer_level'] = 0;
        $item['layer_paths'] = $item['id'];
        $item['parent'] = [$item['id']];
        $item['child'] = [$item['id']];
        $item['layer_childs'] = $item['id'];
        $item['layer_html']  = '';
        $item['layer_space'] = '';
        $item['folder'] = false;
        $item['isLeaf'] = true;
        $item['expanded'] = false;
        $item['loaded'] = true;
        $item['text'] = $item[$text];
        $item['tree_path'] = [$item[$text]];
        $tree[$item['id']] = $item;
    }
    foreach ($items as $item) {
        if (isset($tree[$item['parent_id']])) {
            $tree[$item['parent_id']]['folder'] = true;
            $tree[$item['parent_id']]['isLeaf'] = false;
            $tree[$item['parent_id']]['expanded'] = true;
            $tree[$item['id']]['text'] = $tree[$item['parent_id']]['text'] . '/' . $tree[$item['id']]['text'];
            $tree[$item['id']]['layer_html'] = $tree[$item['parent_id']]['layer_html'] . '|– ';
            $tree[$item['id']]['layer_space'] = $tree[$item['parent_id']]['layer_space'] . ' ';
            $tree[$item['id']]['layer_level'] = $tree[$item['parent_id']]['layer_level'] + 1;
            $tree[$item['id']]['layer_paths'] = $tree[$item['parent_id']]['layer_paths'] . ',' . $tree[$item['id']]['layer_paths'];
            $tree[$item['parent_id']]['layer_childs'] = $tree[$item['id']]['layer_childs'] . ',' . $tree[$item['parent_id']]['layer_childs'];
            $tree[$item['id']]['tree_path'] = array_merge($tree[$item['parent_id']]['tree_path'], $tree[$item['id']]['tree_path']);
            $tree[$item['id']]['parent'] = array_merge($tree[$item['parent_id']]['parent'], $tree[$item['id']]['parent']);
            $tree[$item['parent_id']]['child'] = array_merge($tree[$item['parent_id']]['child'], $tree[$item['id']]['child']);
        }
    }
    return $tree;
}
/**
 * 百度编辑器
 */
function ueditor($name = 'content', $value = '', $config = [])
{
    static $loaded;
    if (empty($loaded)) {
        $e[] = '';
        $e[] = '';
        $e[] = '';
        $loaded = true;
    }
    $e[] = '';
    $e[] = '';
    return join("\n", $e);
}
/**
 * 获取选项
 */
function option($key, $value = '')
{
    static $items = [];
    static $values = [];
    if (empty($items[$key])) {
        $parent = DB::table('option')->where('value', $key)->first();
        if ($parent === null) {
            return [];
        }
        $items[$key] = DB::table('option')->where('parent_id', $parent['id'])->orderBy('sort', 'asc')->get(['name', 'value as id']);
        $values[$key] = array_by($items[$key], 'id');
    }
    if (func_num_args() == 2) {
        return $values[$key][$value]['name'];
    } else {
        return $items[$key];
    }
}
/**
 * 获取单用户数据
 */
function get_user($id = 0, $field = '', $letter = true)
{
    static $users = [];
    $args = func_num_args();
    if (empty($users)) {
        $users = DB::table('user')
            ->get(['id', 'department_id', 'role_id', 'username', 'name', 'email', 'phone', 'birthday', 'gender']);
        $users = array_by($users);
    }
    if ($args == 0) {
        return $users;
    }
    if ($args == 1) {
        return $users[$id];
    }
    if ($field == 'name' && $letter == true) {
        return '';
    } else {
        return $users[$id][$field];
    }
}
/* 读取表格内容 */
function readExcel($filename, $extension = '')
{
    if (empty($extension)) {
        $ext = pathinfo($filename, PATHINFO_EXTENSION);
    } else {
        $ext = $extension;
    }
    if ($ext == 'xlsx') {
        $type = 'Excel2007';
    } else {
        $type = 'Excel5';
    }
    // 设置以Excel5格式(Excel97-2003工作簿)
    $reader = PHPExcel_IOFactory::createReader($type);
    // 载入excel文件
    $PHPExcel = $reader->load($filename);
    // 读取第一個工作表
    $sheet = $PHPExcel->getSheet(0);
    // 取得总行数
    $highestRow = $sheet->getHighestRow();
    // 取得总列数
    $highestColumm = $sheet->getHighestColumn();
    // 转换列数
    $highestColumm = PHPExcel_Cell::columnIndexFromString($highestColumm);
    $rows = [];
    /** 循环读取每个单元格的数据 */
    // 行数是以第1行开始
    for ($i = 1; $i <= $highestRow; $i++) {
        // 列数是以A列开始
        for ($j = 0; $j < $highestColumm; $j++) {
            $rc = PHPExcel_Cell::stringFromColumnIndex($j) . $i;
            $rows[$i][] = (string) $sheet->getCell($rc)->getValue();
        }
    }
    return $rows;
}
/* 导出表格 */
function writeExcel($columns, $data, $filename)
{
    $obj = new PHPExcel();
    $obj->setActiveSheetIndex(0);
    $obj->getActiveSheet()->setTitle('sheet0');
    // 设置单元格宽度
    $obj->getActiveSheet()->getDefaultColumnDimension()->setWidth(16);
    $j = 0;
    // 设置第一行表格样式和名字
    foreach ($columns as $column) {
        $obj->getActiveSheet()->getStyleByColumnAndRow($j, 1)->getFont()->setBold(true);
        $obj->getActiveSheet()->setCellValueByColumnAndRow($j, 1, $column['label']);
        $j++;
    }
    $row = 2;
    foreach ($data as $i => $rows) {
        $col = 0;
        foreach ($columns as $key => $column) {
            $obj->getActiveSheet()->setCellValueByColumnAndRow($col, $row, $rows[$column['name']]);
            $col++;
        }
        $row++;
    }
    header('Content-Type: application/vnd.ms-excel');
    header('Content-Disposition: attachment;filename="' . urlencode($filename) . '.xls"');
    header('Cache-Control: max-age=0');
    $objWriter = PHPExcel_IOFactory::createWriter($obj, 'Excel5');
    $objWriter->save('php://output');
    exit;
}
// 显示商品图片
function goodsImage($v)
{
    $image = $v['image'] ? $v['image'] : 'products/' . $v['id'] . '.jpg';
    $image_path = upload_path() . '/' . $image;
    if (is_file($image_path)) {
        $thumb = thumb($image_path, 100, 100);
        $file = pathinfo($image);
        $thumb = $public_url . '/uploads/' . $file['dirname'] . '/' . $thumb;
        return ' ';
    } else {
        $thumb = $public_url . '/assets/images/default_img.png';
        return '
';
    } else {
        $thumb = $public_url . '/assets/images/default_img.png';
        return ' ';
    }
}
// 构建搜索下拉菜单数据
function search_select($data, $key = 'id', $value = 'name')
{
    $res = [];
    if (is_array($data)) {
        foreach ($data as $row) {
            $res[] = ['id' => $row[$key], 'name' => $row[$value]];
        }
    }
    return json_encode($res, JSON_UNESCAPED_UNICODE);
}
function userBrowser() { 
    $user_OSagent = $_SERVER['HTTP_USER_AGENT']; 
    if (strpos($user_OSagent, "Maxthon") && strpos($user_OSagent, "MSIE")) { 
        $visitor_browser = "Maxthon(Microsoft IE)"; 
    } elseif (strpos($user_OSagent, "Maxthon 2.0")) { 
        $visitor_browser = "Maxthon 2.0"; 
    } elseif (strpos($user_OSagent, "Maxthon")) { 
        $visitor_browser = "Maxthon"; 
    } elseif (strpos($user_OSagent, "MSIE 9.0")) { 
        $visitor_browser = "MSIE 9.0"; 
    } elseif (strpos($user_OSagent, "MSIE 8.0")) { 
        $visitor_browser = "MSIE 8.0"; 
    } elseif (strpos($user_OSagent, "MSIE 7.0")) { 
        $visitor_browser = "MSIE 7.0"; 
    } elseif (strpos($user_OSagent, "MSIE 6.0")) { 
        $visitor_browser = "MSIE 6.0"; 
    } elseif (strpos($user_OSagent, "MSIE 5.5")) { 
        $visitor_browser = "MSIE 5.5"; 
    } elseif (strpos($user_OSagent, "MSIE 5.0")) { 
        $visitor_browser = "MSIE 5.0"; 
    } elseif (strpos($user_OSagent, "MSIE 4.01")) { 
        $visitor_browser = "MSIE 4.01"; 
    } elseif (strpos($user_OSagent, "MSIE")) { 
        $visitor_browser = "MSIE 较高版本"; 
    } elseif (strpos($user_OSagent, "NetCaptor")) { 
        $visitor_browser = "NetCaptor"; 
    } elseif (strpos($user_OSagent, "Netscape")) { 
        $visitor_browser = "Netscape"; 
    } elseif (strpos($user_OSagent, "Chrome")) { 
        $visitor_browser = "Chrome"; 
    } elseif (strpos($user_OSagent, "Lynx")) { 
        $visitor_browser = "Lynx"; 
    } elseif (strpos($user_OSagent, "Opera")) { 
        $visitor_browser = "Opera"; 
    } elseif (strpos($user_OSagent, "Konqueror")) { 
        $visitor_browser = "Konqueror"; 
    } elseif (strpos($user_OSagent, "Mozilla/5.0")) { 
        $visitor_browser = "Mozilla"; 
    } elseif (strpos($user_OSagent, "Firefox")) { 
        $visitor_browser = "Firefox"; 
    } elseif (strpos($user_OSagent, "U")) { 
        $visitor_browser = "Firefox"; 
    } else { 
        $visitor_browser = "其它"; 
    } 
    return $visitor_browser;
}
function system_log($type, $name, $remark, $level = 'info') {
    $auth = auth()->user();
    DB::table('system_log')->insert([
        'type' => $type,
        'name' => $name,
        'remark' => $remark,
        'created_id' => $auth['id'],
        'created_by' => $auth['name'],
        'created_at' => time(),
        'ip' => Request::ip(),
        'error_count' => 0,
        'browser' => userBrowser(),
        'device' => '',
        'level' => $level,
    ]);
}
function db_instr($field, $str, $prefix = ',', $suffix = ',')
{
    $db_type = env('DB_CONNECTION');
    if ($db_type == 'pgsql') {
        return "strpos(concat('$prefix', $field, '$suffix'), '".$prefix.$str.$suffix."') > 0";
    } else if($db_type == 'mysql') {
        return "instr(concat('$prefix', $field, '$suffix'), '".$prefix.$str.$suffix."') > 0";
    } else if($db_type == 'sqlsrv') {
        return "charindex('" . $prefix . $str . $suffix . "', '$prefix' + $field + '$suffix') > 0";
    }
}
function get_device_type()
{
    $agent = strtolower($_SERVER['HTTP_USER_AGENT']);
    $type = 'other';
    if (strpos($agent, 'iphone') || strpos($agent, 'ipad')) {
        $type = 'ios';
    }
    if (strpos($agent, 'android')) {
        $type = 'android';
    }
    return $type;
}
function is_weixin()
{
    if (isset($_SERVER['HTTP_USER_AGENT']) && strpos($_SERVER['HTTP_USER_AGENT'], 'MicroMessenger') !== false) {
        return true;
    }
    return false;
}
function create_token($userId, $day = 7)
{
    $payload = array(
        'sub' => $userId,
        'iat' => time(),
        // $day 天有效
        'exp' => time() + ($day * 24 * 60 * 60),
    );
    return App\Support\JWT::encode($payload, config('app.key'));
}
/**
 * 返回json数据
 */
function response_json($data, $status = false)
{
    $json = [];
    if ($status === false) {
        $json['status'] = $status;
        $json['url'] = null;
    } else {
        $json['status'] = true;
        if ($status === true) {
            $json['url'] = '';
        } else {
            $json['url'] = url_referer($status);
        }
    }
    $json['data'] = $data;
    return response()->json($json);
}
// 登录是客户
function is_customer()
{
    return auth()->user()->group_id == 2;
}
/**
 * 登录是管理员
 */
function is_admin()
{
    return auth()->user()->admin == 1;
}
// 获取生产日期
function get_batch_sn($row)
{
    if ($row['batch_sn']) {
        $batch_sn = substr($row['batch_sn'], 0, 6);
        $sn = str_split($batch_sn, 2);
        $row['batch_date'] = date("Y-m-d", mktime(0, 0, 0, $sn[1], $sn[2], $sn[0]));
    } else {
        $row['batch_date'] = '';
    }
    return $row;
}
// url编码和js encodeURIComponent保持一致
function encodeURIComponent($str)
{
    $revert = ['%7E' => '~', '%21' => '!', '%2A' => '*', '%27' => "'", '%28' => '(', '%29' => ')'];
    return strtr(rawurlencode($str), $revert);
}
function plugin_sync_api($uri, $data = [])
{
    $base_url = env('PLUGIN_SYNC_API_URL');
    if (empty($base_url)) {
        return ['success' => true];
    }
    $url = $base_url . '/' . $uri;
    $data_string = json_encode($data);
    //初使化init方法
    $ch = curl_init();
    //指定URL
    curl_setopt($ch, CURLOPT_URL, $url);
    //设定请求后返回结果
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
    if (!empty($data)) {
        //声明使用POST方式来进行发送
        curl_setopt($ch, CURLOPT_POST, 1);
        //发送什么数据呢
        curl_setopt($ch, CURLOPT_POSTFIELDS, $data_string);
        curl_setopt($ch, CURLOPT_HTTPHEADER, [
            'Content-Type: application/json',
            'Content-Length: ' . strlen($data_string)
        ]);
    } else {
        curl_setopt($ch, CURLOPT_HTTPHEADER, [
            'Content-Type: application/json'
        ]);
    }
    //忽略证书
    curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
    curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);
    //忽略header头信息
    curl_setopt($ch, CURLOPT_HEADER, 0);
    //设置超时时间
    curl_setopt($ch, CURLOPT_TIMEOUT, 30);
    //发送请求
    $output = curl_exec($ch);
    $error = '';
    if ($output === false) {
        $error = curl_error($ch);
    }
    //关闭curl
    curl_close($ch);
    if ($error) {
        return ['msg' => $error, 'success' => false];
    }
    // 返回数据
    return json_decode($output, true);
}
function print_prince($view)
{
    $viewData = $view->getData();
    try {
        $prince = new App\Support\Prince(env('PRINCE_DIR'));
        header('Content-Type:application/pdf');
        header('Content-Disposition:inline;filename="' . $viewData['form']['template']['name'] . '.pdf"');
        $prince->convert_string_to_passthru($view);
    } catch (Exception $e) {
        echo $e->getMessage();
    }
}
function get_sql($row, $type = 'insert')
{
    $sqls = [];
    foreach ($row as $k => $v) {
        if ($type == 'insert') {
            if (is_string($v)) {
                $sqls[] = "'$v'";
            } else {
                $sqls[] = "$v";
            }
        } else {
            if (is_string($v)) {
                $sqls[] = "$k = '$v'";
            } else {
                $sqls[] = "$k = $v";
            }
        }
    }
    if ($type == 'insert') {
        return join(',', $sqls);
    } else {
        return join(',', $sqls);
    }
}
// 检查日期格式是否符合
function checkDateFormat($date)
{
    // 匹配日期格式
    if (preg_match ("/^([0-9]{4})-([0-9]{2})-([0-9]{2})$/", $date, $parts)) {
        // 检测是否为日期
        return checkdate($parts[2],$parts[3],$parts[1]);
    }
    return false;
}
';
    }
}
// 构建搜索下拉菜单数据
function search_select($data, $key = 'id', $value = 'name')
{
    $res = [];
    if (is_array($data)) {
        foreach ($data as $row) {
            $res[] = ['id' => $row[$key], 'name' => $row[$value]];
        }
    }
    return json_encode($res, JSON_UNESCAPED_UNICODE);
}
function userBrowser() { 
    $user_OSagent = $_SERVER['HTTP_USER_AGENT']; 
    if (strpos($user_OSagent, "Maxthon") && strpos($user_OSagent, "MSIE")) { 
        $visitor_browser = "Maxthon(Microsoft IE)"; 
    } elseif (strpos($user_OSagent, "Maxthon 2.0")) { 
        $visitor_browser = "Maxthon 2.0"; 
    } elseif (strpos($user_OSagent, "Maxthon")) { 
        $visitor_browser = "Maxthon"; 
    } elseif (strpos($user_OSagent, "MSIE 9.0")) { 
        $visitor_browser = "MSIE 9.0"; 
    } elseif (strpos($user_OSagent, "MSIE 8.0")) { 
        $visitor_browser = "MSIE 8.0"; 
    } elseif (strpos($user_OSagent, "MSIE 7.0")) { 
        $visitor_browser = "MSIE 7.0"; 
    } elseif (strpos($user_OSagent, "MSIE 6.0")) { 
        $visitor_browser = "MSIE 6.0"; 
    } elseif (strpos($user_OSagent, "MSIE 5.5")) { 
        $visitor_browser = "MSIE 5.5"; 
    } elseif (strpos($user_OSagent, "MSIE 5.0")) { 
        $visitor_browser = "MSIE 5.0"; 
    } elseif (strpos($user_OSagent, "MSIE 4.01")) { 
        $visitor_browser = "MSIE 4.01"; 
    } elseif (strpos($user_OSagent, "MSIE")) { 
        $visitor_browser = "MSIE 较高版本"; 
    } elseif (strpos($user_OSagent, "NetCaptor")) { 
        $visitor_browser = "NetCaptor"; 
    } elseif (strpos($user_OSagent, "Netscape")) { 
        $visitor_browser = "Netscape"; 
    } elseif (strpos($user_OSagent, "Chrome")) { 
        $visitor_browser = "Chrome"; 
    } elseif (strpos($user_OSagent, "Lynx")) { 
        $visitor_browser = "Lynx"; 
    } elseif (strpos($user_OSagent, "Opera")) { 
        $visitor_browser = "Opera"; 
    } elseif (strpos($user_OSagent, "Konqueror")) { 
        $visitor_browser = "Konqueror"; 
    } elseif (strpos($user_OSagent, "Mozilla/5.0")) { 
        $visitor_browser = "Mozilla"; 
    } elseif (strpos($user_OSagent, "Firefox")) { 
        $visitor_browser = "Firefox"; 
    } elseif (strpos($user_OSagent, "U")) { 
        $visitor_browser = "Firefox"; 
    } else { 
        $visitor_browser = "其它"; 
    } 
    return $visitor_browser;
}
function system_log($type, $name, $remark, $level = 'info') {
    $auth = auth()->user();
    DB::table('system_log')->insert([
        'type' => $type,
        'name' => $name,
        'remark' => $remark,
        'created_id' => $auth['id'],
        'created_by' => $auth['name'],
        'created_at' => time(),
        'ip' => Request::ip(),
        'error_count' => 0,
        'browser' => userBrowser(),
        'device' => '',
        'level' => $level,
    ]);
}
function db_instr($field, $str, $prefix = ',', $suffix = ',')
{
    $db_type = env('DB_CONNECTION');
    if ($db_type == 'pgsql') {
        return "strpos(concat('$prefix', $field, '$suffix'), '".$prefix.$str.$suffix."') > 0";
    } else if($db_type == 'mysql') {
        return "instr(concat('$prefix', $field, '$suffix'), '".$prefix.$str.$suffix."') > 0";
    } else if($db_type == 'sqlsrv') {
        return "charindex('" . $prefix . $str . $suffix . "', '$prefix' + $field + '$suffix') > 0";
    }
}
function get_device_type()
{
    $agent = strtolower($_SERVER['HTTP_USER_AGENT']);
    $type = 'other';
    if (strpos($agent, 'iphone') || strpos($agent, 'ipad')) {
        $type = 'ios';
    }
    if (strpos($agent, 'android')) {
        $type = 'android';
    }
    return $type;
}
function is_weixin()
{
    if (isset($_SERVER['HTTP_USER_AGENT']) && strpos($_SERVER['HTTP_USER_AGENT'], 'MicroMessenger') !== false) {
        return true;
    }
    return false;
}
function create_token($userId, $day = 7)
{
    $payload = array(
        'sub' => $userId,
        'iat' => time(),
        // $day 天有效
        'exp' => time() + ($day * 24 * 60 * 60),
    );
    return App\Support\JWT::encode($payload, config('app.key'));
}
/**
 * 返回json数据
 */
function response_json($data, $status = false)
{
    $json = [];
    if ($status === false) {
        $json['status'] = $status;
        $json['url'] = null;
    } else {
        $json['status'] = true;
        if ($status === true) {
            $json['url'] = '';
        } else {
            $json['url'] = url_referer($status);
        }
    }
    $json['data'] = $data;
    return response()->json($json);
}
// 登录是客户
function is_customer()
{
    return auth()->user()->group_id == 2;
}
/**
 * 登录是管理员
 */
function is_admin()
{
    return auth()->user()->admin == 1;
}
// 获取生产日期
function get_batch_sn($row)
{
    if ($row['batch_sn']) {
        $batch_sn = substr($row['batch_sn'], 0, 6);
        $sn = str_split($batch_sn, 2);
        $row['batch_date'] = date("Y-m-d", mktime(0, 0, 0, $sn[1], $sn[2], $sn[0]));
    } else {
        $row['batch_date'] = '';
    }
    return $row;
}
// url编码和js encodeURIComponent保持一致
function encodeURIComponent($str)
{
    $revert = ['%7E' => '~', '%21' => '!', '%2A' => '*', '%27' => "'", '%28' => '(', '%29' => ')'];
    return strtr(rawurlencode($str), $revert);
}
function plugin_sync_api($uri, $data = [])
{
    $base_url = env('PLUGIN_SYNC_API_URL');
    if (empty($base_url)) {
        return ['success' => true];
    }
    $url = $base_url . '/' . $uri;
    $data_string = json_encode($data);
    //初使化init方法
    $ch = curl_init();
    //指定URL
    curl_setopt($ch, CURLOPT_URL, $url);
    //设定请求后返回结果
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
    if (!empty($data)) {
        //声明使用POST方式来进行发送
        curl_setopt($ch, CURLOPT_POST, 1);
        //发送什么数据呢
        curl_setopt($ch, CURLOPT_POSTFIELDS, $data_string);
        curl_setopt($ch, CURLOPT_HTTPHEADER, [
            'Content-Type: application/json',
            'Content-Length: ' . strlen($data_string)
        ]);
    } else {
        curl_setopt($ch, CURLOPT_HTTPHEADER, [
            'Content-Type: application/json'
        ]);
    }
    //忽略证书
    curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
    curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);
    //忽略header头信息
    curl_setopt($ch, CURLOPT_HEADER, 0);
    //设置超时时间
    curl_setopt($ch, CURLOPT_TIMEOUT, 30);
    //发送请求
    $output = curl_exec($ch);
    $error = '';
    if ($output === false) {
        $error = curl_error($ch);
    }
    //关闭curl
    curl_close($ch);
    if ($error) {
        return ['msg' => $error, 'success' => false];
    }
    // 返回数据
    return json_decode($output, true);
}
function print_prince($view)
{
    $viewData = $view->getData();
    try {
        $prince = new App\Support\Prince(env('PRINCE_DIR'));
        header('Content-Type:application/pdf');
        header('Content-Disposition:inline;filename="' . $viewData['form']['template']['name'] . '.pdf"');
        $prince->convert_string_to_passthru($view);
    } catch (Exception $e) {
        echo $e->getMessage();
    }
}
function get_sql($row, $type = 'insert')
{
    $sqls = [];
    foreach ($row as $k => $v) {
        if ($type == 'insert') {
            if (is_string($v)) {
                $sqls[] = "'$v'";
            } else {
                $sqls[] = "$v";
            }
        } else {
            if (is_string($v)) {
                $sqls[] = "$k = '$v'";
            } else {
                $sqls[] = "$k = $v";
            }
        }
    }
    if ($type == 'insert') {
        return join(',', $sqls);
    } else {
        return join(',', $sqls);
    }
}
// 检查日期格式是否符合
function checkDateFormat($date)
{
    // 匹配日期格式
    if (preg_match ("/^([0-9]{4})-([0-9]{2})-([0-9]{2})$/", $date, $parts)) {
        // 检测是否为日期
        return checkdate($parts[2],$parts[3],$parts[1]);
    }
    return false;
}