����JFIF��x�x����'
| Server IP : 78.140.185.180  /  Your IP : 216.73.216.168 Web Server : LiteSpeed System : Linux cpanel13.v.fozzy.com 4.18.0-513.11.1.lve.el8.x86_64 #1 SMP Thu Jan 18 16:21:02 UTC 2024 x86_64 User : builderbox ( 1072) PHP Version : 7.3.33 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /proc/thread-self/root/home/builderbox/././www/common/Core/Values/ | 
| Upload File : | 
<?php namespace Common\Core\Values;
use Arr;
use Auth;
use Common\Admin\Appearance\Themes\CssTheme;
use Common\Auth\Permissions\Permission;
use Common\Auth\Roles\Role;
use Common\Domains\CustomDomain;
use Common\Files\FileEntry;
use Common\Localizations\Localization;
use Common\Pages\CustomPage;
use Illuminate\Contracts\Auth\Access\Gate;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Filesystem\Filesystem;
use Illuminate\Support\Collection;
use Str;
use const App\Providers\WORKSPACED_RESOURCES;
class ValueLists
{
    /**
     * @var Filesystem
     */
    private $fs;
    /**
     * @var Localization
     */
    private $localization;
    public function __construct(Filesystem $fs, Localization $localization)
    {
        $this->fs = $fs;
        $this->localization = $localization;
    }
    /**
     * @param string $names
     * @param array $params
     * @return Collection
     */
    public function get($names, $params = [])
    {
        return collect(explode(',', $names))
            ->mapWithKeys(function($name) use($params) {
                $methodName = Str::studly($name);
                $value = method_exists($this, $methodName) ?
                    $this->$methodName($params) :
                    $this->loadAppValueFile($name, $params);
                return [$name => $value];
            })->filter();
    }
    /**
     * @return Permission[]|Collection
     */
    public function permissions()
    {
        $query = app(Permission::class)->where('type', 'sitewide');
        if ( ! config('common.site.enable_custom_domains')) {
            $query->where('group', '!=', 'custom_domains');
        }
        if ( ! config('common.site.notifications_integrated')) {
            $query->where('group', '!=', 'notifications');
        }
        // TODO: fetch and merge advanced and description from config files here
        // instead of storing in db. Then can override workspace descriptions and
        // advanced state easily here from separate config file
        if ( ! config('common.site.workspaces_integrated')) {
            $query->where('group', '!=', 'workspaces')
                ->where('group', '!=', 'workspace_members');
        }
        if ( ! config('common.site.billing_integrated')) {
            $query->where('group', '!=', 'plans')
                ->where('group', '!=', 'invoices');
        }
        if ( ! Auth::user() || ! Auth::user()->hasExactPermission('admin')) {
            $query->where('name', '!=', 'admin');
        }
        return $query->get();
    }
    /**
     * @return Collection|Role[]
     */
    public function workspaceRoles()
    {
        return app(Role::class)->where('type', 'workspace')->get();
    }
    public function workspacePermissions($params = [])
    {
        $filters = array_map(function($resource) {
            if (is_subclass_of($resource, FileEntry::class)) {
                return 'files';
            } else if (is_subclass_of($resource, CustomDomain::class)) {
                return 'custom_domains';
            } else {
                return Str::snake(Str::pluralStudly(class_basename($resource)));
            }
        }, WORKSPACED_RESOURCES);
        return app(Permission::class)
            ->where('type', 'workspace')
            ->orWhere(function(Builder $builder) use($filters) {
                $builder->where('type', 'sitewide')->whereIn('group', $filters);
            })
            // don't return restrictions for workspace permissions so they
            // are not shown when creating workspace role from admin area
            ->get(['id', 'name', 'display_name', 'description', 'group', 'type'])
            ->map(function(Permission $permission) {
                $permission->description = str_replace('ALL', 'all workspace', $permission->description);
                $permission->description = str_replace('creating new', 'creating new workspace', $permission->description);
                return $permission;
            });
    }
    public function currencies()
    {
        return json_decode($this->fs->get(__DIR__ . '/../../resources/lists/currencies.json'), true);
    }
    public function timezones()
    {
        return json_decode($this->fs->get(__DIR__ . '/../../resources/lists/timezones.json'), true);
    }
    public function countries()
    {
        return json_decode($this->fs->get(__DIR__ . '/../../resources/lists/countries.json'), true);
    }
    public function languages()
    {
        return json_decode($this->fs->get(__DIR__ . '/../../resources/lists/languages.json'), true);
    }
    public function localizations()
    {
        return $this->localization->get(['id', 'name', 'language']);
    }
    public function googleFonts() {
        $googleFonts= json_decode($this->fs->get(__DIR__ . '/../../resources/lists/google-fonts.json'), true);
        return array_map(function($font) {
            return [
                'family' => $font['family'],
                'category' => $font['category'],
                'google' => true,
            ];
        }, $googleFonts);
    }
    public function menuItemCategories()
    {
        return array_map(function($category) {
            $category['items'] = app($category['itemsLoader'])->execute();
            unset($category['itemsLoader']);
            return $category;
        }, config('common.menus'));
    }
    public function pages($params = [])
    {
        if ( ! isset($params['userId'])) {
            app(Gate::class)->authorize('index', CustomPage::class);
        }
        $query = app(CustomPage::class)
            ->select(['id', 'title'])
            ->where('type', Arr::get($params, 'pageType') ?: CustomPage::PAGE_TYPE);
        if ($userId = Arr::get($params, 'userId')) {
            $query ->where('user_id', $userId);
        }
        return $query->get();
    }
    /**
     * @param $params
     * @return Collection
     */
    public function domains($params)
    {
        return app(CustomDomain::class)
            ->select(['host', 'id'])
            ->where('user_id', Arr::get($params, 'userId'))
            ->orWhere('global', true)
            ->get();
    }
    /**
     * @param $params
     * @return Collection
     */
    public function themes($params)
    {
        app(Gate::class)->authorize('index', CssTheme::class);
        return app(CssTheme::class)
            ->select(['name', 'id'])
            ->get();
    }
    /**
     * @param string $name
     * @param array $params
     * @return array|null
     */
    private function loadAppValueFile($name, $params)
    {
        $fileName = Str::kebab($name);
        $path = resource_path("lists/$fileName.json");
        if (file_exists($path)) {
            return json_decode(file_get_contents($path), true);
        }
        return null;
    }
}