Commit 1fd43ab5 authored by Nicolas Widart's avatar Nicolas Widart

Merge commit '499751b0'

* commit '499751b0':
  Squashed 'Modules/Setting/' changes from 0f32e1e..20d1cdb
parents b8103f2c 499751b0
rules:
php.interface_has_no_interface_suffix:
enabled: false
language: php
php:
- 5.6
- 5.5
- 5.4
- hhvm
...@@ -3,7 +3,8 @@ ...@@ -3,7 +3,8 @@
use Illuminate\Database\Seeder; use Illuminate\Database\Seeder;
use Illuminate\Database\Eloquent\Model; use Illuminate\Database\Eloquent\Model;
class SettingDatabaseSeeder extends Seeder { class SettingDatabaseSeeder extends Seeder
{
/** /**
* Run the database seeds. * Run the database seeds.
...@@ -13,8 +14,6 @@ class SettingDatabaseSeeder extends Seeder { ...@@ -13,8 +14,6 @@ class SettingDatabaseSeeder extends Seeder {
public function run() public function run()
{ {
Model::unguard(); Model::unguard();
// $this->call("OthersTableSeeder");
} }
} }
<?php <?php
$router->group(['prefix' => LaravelLocalization::setLocale(), 'before' => 'LaravelLocalizationRedirectFilter|auth.admin'], function($router) { use Illuminate\Routing\Router;
$router->group(['prefix' => Config::get('core::core.admin-prefix'), 'namespace' => 'Modules\Setting\Http\Controllers'], function($router)
$router->group(['prefix' => LaravelLocalization::setLocale(), 'before' => 'LaravelLocalizationRedirectFilter|auth.admin'], function(Router $router) {
$router->group(['prefix' => Config::get('core::core.admin-prefix'), 'namespace' => 'Modules\Setting\Http\Controllers'], function(Router $router)
{ {
$router->get('settings/{module}', ['as' => 'dashboard.module.settings', 'uses' => 'Admin\SettingController@getModuleSettings']); $router->get('settings/{module}', ['as' => 'dashboard.module.settings', 'uses' => 'Admin\SettingController@getModuleSettings']);
$router->resource('settings', 'Admin\SettingController', ['except' => ['show', 'edit', 'update', 'destroy', 'create'], 'names' => [ $router->resource('settings', 'Admin\SettingController', ['except' => ['show', 'edit', 'update', 'destroy', 'create'], 'names' => [
......
...@@ -28,7 +28,7 @@ class SettingServiceProvider extends ServiceProvider { ...@@ -28,7 +28,7 @@ class SettingServiceProvider extends ServiceProvider {
$this->app['setting.settings'] = $this->app->share(function($app) $this->app['setting.settings'] = $this->app->share(function($app)
{ {
return new Settings($app['Modules\Setting\Repositories\SettingRepository']); return new Settings($app['Modules\Setting\Repositories\SettingRepository'], $app['cache']);
}); });
$this->app->booting(function() $this->app->booting(function()
......
<?php $settingName = strtolower($currentModule) . '::' . $setting; ?>
<div class="checkbox"> <div class="checkbox">
<label for="{{ $settingName }}"> <label for="{{ $settingName }}">
<input id="{{ $settingName }}" <input id="{{ $settingName }}"
name="{{ $settingName }}" name="{{ $settingName }}"
type="checkbox" type="checkbox"
class="flat-blue" class="flat-blue"
{{ isset($dbSettings[$settingName]) && (bool)$dbSettings[$settingName]->value == true ? 'checked' : '' }} {{ isset($dbSettings[$settingName]) && (bool)$dbSettings[$settingName]->plainValue == true ? 'checked' : '' }}
value="1" /> value="1" />
{{ $moduleInfo['description'] }} {{ $moduleInfo['description'] }}
</label> </label>
......
<?php $settingName = strtolower($currentModule) . '::' . $setting; ?>
<div class='form-group'> <div class='form-group'>
{!! Form::label($settingName, $moduleInfo['description']) !!} {!! Form::label($settingName, $moduleInfo['description']) !!}
<?php if (isset($dbSettings[$settingName])): ?> <?php if (isset($dbSettings[$settingName])): ?>
{!! Form::input('number', $settingName, Input::old($settingName, $dbSettings[$settingName]->translate($lang)->value), ['class' => 'form-control', 'placeholder' => $moduleInfo['description']]) !!} {!! Form::input('number', $settingName, Input::old($settingName, $dbSettings[$settingName]->plainValue), ['class' => 'form-control', 'placeholder' => $moduleInfo['description']]) !!}
<?php else: ?> <?php else: ?>
{!! Form::input('number', $settingName, Input::old($settingName), ['class' => 'form-control', 'placeholder' => $moduleInfo['description']]) !!} {!! Form::input('number', $settingName, Input::old($settingName), ['class' => 'form-control', 'placeholder' => $moduleInfo['description']]) !!}
<?php endif; ?> <?php endif; ?>
......
<?php $settingName = strtolower($currentModule) . '::' . $setting; ?>
<div class="checkbox"> <div class="checkbox">
<?php foreach($moduleInfo['options'] as $value => $optionName): ?> <?php foreach($moduleInfo['options'] as $value => $optionName): ?>
<label for="{{ $optionName }}"> <label for="{{ $optionName }}">
...@@ -6,7 +5,7 @@ ...@@ -6,7 +5,7 @@
name="{{ $settingName }}" name="{{ $settingName }}"
type="radio" type="radio"
class="flat-blue" class="flat-blue"
{{ isset($dbSettings[$settingName]) && (bool)$dbSettings[$settingName]->value == $value ? 'checked' : '' }} {{ isset($dbSettings[$settingName]) && (bool)$dbSettings[$settingName]->plainValue == $value ? 'checked' : '' }}
value="{{ $value }}" /> value="{{ $value }}" />
{{ $optionName }} {{ $optionName }}
</label> </label>
......
<?php $settingName = strtolower($currentModule) . '::' . $setting; ?>
<div class='form-group'> <div class='form-group'>
{!! Form::label($settingName, $moduleInfo['description']) !!} {!! Form::label($settingName, $moduleInfo['description']) !!}
<?php if (isset($dbSettings[$settingName])): ?> <?php if (isset($dbSettings[$settingName])): ?>
......
<?php $settingName = strtolower($currentModule) . '::' . $setting; ?>
<div class='form-group'> <div class='form-group'>
{!! Form::label($settingName", $moduleInfo['description']) !!} {!! Form::label($settingName, $moduleInfo['description']) !!}
<?php if (isset($dbSettings[$settingName])): ?> <?php if (isset($dbSettings[$settingName])): ?>
{!! Form::textarea($settingName", Input::old($settingName", $dbSettings[$settingName]->translate($lang)->value), ['class' => 'form-control', 'placeholder' => $moduleInfo['description']]) !!} {!! Form::textarea($settingName, Input::old($settingName, $dbSettings[$settingName]->plainValue), ['class' => 'form-control', 'placeholder' => $moduleInfo['description']]) !!}
<?php else: ?> <?php else: ?>
{!! Form::textarea($settingName", Input::old($settingName"), ['class' => 'form-control', 'placeholder' => $moduleInfo['description']]) !!} {!! Form::textarea($settingName, Input::old($settingName), ['class' => 'form-control', 'placeholder' => $moduleInfo['description']]) !!}
<?php endif; ?> <?php endif; ?>
</div> </div>
<?php $settingName = strtolower($currentModule) . '::' . $setting; ?>
<div class="checkbox"> <div class="checkbox">
<label for="{{ $settingName . "[$lang]" }}"> <label for="{{ $settingName . "[$lang]" }}">
<input id="{{ $settingName . "[$lang]" }}" <input id="{{ $settingName . "[$lang]" }}"
......
<?php $settingName = strtolower($currentModule) . '::' . $setting; ?>
<div class='form-group'> <div class='form-group'>
{!! Form::label($settingName . "[$lang]", $moduleInfo['description']) !!} {!! Form::label($settingName . "[$lang]", $moduleInfo['description']) !!}
<?php if (isset($dbSettings[$settingName])): ?> <?php if (isset($dbSettings[$settingName])): ?>
......
<?php $settingName = strtolower($currentModule) . '::' . $setting; ?>
<div class="checkbox"> <div class="checkbox">
<?php foreach($moduleInfo['options'] as $value => $optionName): ?> <?php foreach($moduleInfo['options'] as $value => $optionName): ?>
<label for="{{ $optionName . "[$lang]" }}"> <label for="{{ $optionName . "[$lang]" }}">
......
<?php $settingName = strtolower($currentModule) . '::' . $setting; ?>
<div class='form-group'> <div class='form-group'>
{!! Form::label($settingName . "[$lang]", $moduleInfo['description']) !!} {!! Form::label($settingName . "[$lang]", $moduleInfo['description']) !!}
<?php if (isset($dbSettings[$settingName])): ?> <?php if (isset($dbSettings[$settingName])): ?>
......
<?php $settingName = strtolower($currentModule) . '::' . $setting; ?>
<div class='form-group'> <div class='form-group'>
{!! Form::label($settingName . "[$lang]", $moduleInfo['description']) !!} {!! Form::label($settingName . "[$lang]", $moduleInfo['description']) !!}
<?php if (isset($dbSettings[$settingName])): ?> <?php if (isset($dbSettings[$settingName])): ?>
......
...@@ -12,11 +12,10 @@ ...@@ -12,11 +12,10 @@
@stop @stop
@section('styles') @section('styles')
<link href="{{{ Module::asset('core', 'css/vendor/iCheck/flat/blue.css') }}}" rel="stylesheet" type="text/css" /> <link href="{!! Module::asset('core', 'css/vendor/iCheck/flat/blue.css') !!}" rel="stylesheet" type="text/css" />
@stop @stop
@section('content') @section('content')
@include('flash::message')
{!! Form::open(['route' => ['dashboard.setting.store'], 'method' => 'post']) !!} {!! Form::open(['route' => ['dashboard.setting.store'], 'method' => 'post']) !!}
<div class="row"> <div class="row">
<div class="sidebar-nav col-sm-2"> <div class="sidebar-nav col-sm-2">
...@@ -83,7 +82,7 @@ ...@@ -83,7 +82,7 @@
</div> </div>
<?php endif; ?> <?php endif; ?>
<div class="box-footer"> <div class="box-footer">
<button type="submit" class="btn btn-primary btn-flat">{{ trans('core::core.button.create') }}</button> <button type="submit" class="btn btn-primary btn-flat">{{ trans('core::core.button.update') }}</button>
<a class="btn btn-danger pull-right btn-flat" href="{{ URL::route('dashboard.setting.index')}}"><i class="fa fa-times"></i> {{ trans('core::core.button.cancel') }}</a> <a class="btn btn-danger pull-right btn-flat" href="{{ URL::route('dashboard.setting.index')}}"><i class="fa fa-times"></i> {{ trans('core::core.button.cancel') }}</a>
</div> </div>
</div> </div>
......
...@@ -6,5 +6,6 @@ ...@@ -6,5 +6,6 @@
'settings' => $settings, 'settings' => $settings,
'setting' => $settingName, 'setting' => $settingName,
'moduleInfo' => $moduleInfo, 'moduleInfo' => $moduleInfo,
'settingName' => strtolower($currentModule) . '::' . $settingName
]) ])
<?php endforeach; <?php endforeach;
<?php namespace Modules\Setting\Support; <?php namespace Modules\Setting\Support;
use Illuminate\Contracts\Cache\Repository;
use Modules\Core\Contracts\Setting; use Modules\Core\Contracts\Setting;
use Modules\Setting\Repositories\SettingRepository; use Modules\Setting\Repositories\SettingRepository;
...@@ -9,13 +10,19 @@ class Settings implements Setting ...@@ -9,13 +10,19 @@ class Settings implements Setting
* @var SettingRepository * @var SettingRepository
*/ */
private $setting; private $setting;
/**
* @var Repository
*/
private $cache;
/** /**
* @param SettingRepository $setting * @param SettingRepository $setting
* @param Repository $cache
*/ */
public function __construct(SettingRepository $setting) public function __construct(SettingRepository $setting, Repository $cache)
{ {
$this->setting = $setting; $this->setting = $setting;
$this->cache = $cache;
} }
/** /**
...@@ -27,7 +34,11 @@ class Settings implements Setting ...@@ -27,7 +34,11 @@ class Settings implements Setting
*/ */
public function get($name, $locale = null, $default = null) public function get($name, $locale = null, $default = null)
{ {
if (!$this->cache->has("setting.$name")) {
$setting = $this->setting->get($name); $setting = $this->setting->get($name);
$this->cache->put("setting.$name", $setting, '3600');
}
$setting = $this->cache->get("setting.$name");
if ($setting) { if ($setting) {
if ($setting->isTranslatable) { if ($setting->isTranslatable) {
......
...@@ -2,3 +2,4 @@ ...@@ -2,3 +2,4 @@
[![SensioLabsInsight](https://insight.sensiolabs.com/projects/92d544b4-a3ca-4c2a-9ffd-0741c521cb14/mini.png)](https://insight.sensiolabs.com/projects/92d544b4-a3ca-4c2a-9ffd-0741c521cb14) [![SensioLabsInsight](https://insight.sensiolabs.com/projects/92d544b4-a3ca-4c2a-9ffd-0741c521cb14/mini.png)](https://insight.sensiolabs.com/projects/92d544b4-a3ca-4c2a-9ffd-0741c521cb14)
[![Scrutinizer Code Quality](https://scrutinizer-ci.com/g/nWidart-Modules/Setting/badges/quality-score.png?b=master)](https://scrutinizer-ci.com/g/nWidart-Modules/Setting/?branch=master) [![Scrutinizer Code Quality](https://scrutinizer-ci.com/g/nWidart-Modules/Setting/badges/quality-score.png?b=master)](https://scrutinizer-ci.com/g/nWidart-Modules/Setting/?branch=master)
[![Code Climate](https://codeclimate.com/github/nWidart-Modules/Setting/badges/gpa.svg)](https://codeclimate.com/github/nWidart-Modules/Setting)
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment