Mise à jour

This commit is contained in:
Ludovic CANDELLIER
2021-03-21 23:26:53 +01:00
parent c025dbb385
commit 083d358fbd
78 changed files with 1003 additions and 716 deletions

View File

@@ -1,132 +0,0 @@
<?php
namespace App\Console\Commands;
use Illuminate\Console\Command;
use App\Models\Botanic\Family;
use App\Models\Botanic\Genre;
use App\Models\Botanic\Specie;
use App\Models\Botanic\Variety;
class checkdb extends Command
{
/**
* The name and signature of the console command.
*
* @var string
*/
protected $signature = 'checkdb';
/**
* The console command description.
*
* @var string
*/
protected $description = 'Consistency from old version';
/**
* Create a new command instance.
*
* @return void
*/
public function __construct()
{
parent::__construct();
}
/**
* Execute the console command.
*
* @return mixed
*/
public function handle()
{
$varieties = Variety::whereNull('specie_id')->get();
foreach ($varieties as $variety) {
$specie_name = trim($variety->specie_name);
/*
$specie = Specie::firstOrCreate(['name' => $specie_name]);
if ($specie) {
$variety->specie_id = $specie->id;
$variety->save();
}
*/
dump($specie_name);
}
/*
$species = Specie::all();
foreach ($species as $specie) {
$specie->name = trim($specie->name);
$specie->save();
}
$varieties = Variety::all();
foreach ($varieties as $variety) {
$variety->name = trim($variety->name);
$variety->save();
}
*/
/*
$varieties = Variety::all();
foreach ($varieties as $variety) {
$specie_name = $variety->specie;
dump($specie_name);
if (!empty($specie_name)) {
$specie = Specie::byName($specie_name)->first();
if (isset($specie->name))
{
dump($specie->name);
$variety->specie_id = $specie->id;
$variety->save();
} else {
dump("non trouvé");
}
} else {
dump("Aucune espèce");
}
}
*/
/*
$species = Specie::all();
foreach ($species as $specie) {
$genre_name = $specie->genre;
dump($genre_name);
if (!empty($genre_name)) {
$genre = Genre::byName($genre_name)->first();
if (isset($genre->name))
{
dump($genre->name);
$specie->genre_id = $genre->id;
$specie->save();
} else {
dump("non trouvé");
}
} else {
dump("Aucun genre");
}
}
*/
/*
$genres = Genre::all();
foreach ($genres as $genre) {
$family_name = $genre->family;
dump($family_name);
if (!empty($family_name)) {
$family = Family::byName($family_name)->first();
if (isset($family->name))
{
dump($family->name);
$genre->family_id = $family->id;
$genre->save();
} else {
dump("non trouvé");
}
} else {
dump("Aucune famille");
}
}
*/
}
}

View File

@@ -1,117 +0,0 @@
<?php
namespace App\Console\Commands;
use Illuminate\Console\Command;
use App\Models\Botanic\Family;
use App\Models\Botanic\Genre;
use App\Models\Botanic\Specie;
use App\Models\Botanic\Variety;
class migrate extends Command
{
/**
* The name and signature of the console command.
*
* @var string
*/
protected $signature = 'create_relation';
/**
* The console command description.
*
* @var string
*/
protected $description = 'Migration from old version';
/**
* Create a new command instance.
*
* @return void
*/
public function __construct()
{
parent::__construct();
}
/**
* Execute the console command.
*
* @return mixed
*/
public function handle()
{
$species = Specie::all();
foreach ($species as $specie) {
$specie->name = trim($specie->name);
$specie->save();
}
$varieties = Variety::all();
foreach ($varieties as $variety) {
$variety->name = trim($variety->name);
$variety->save();
}
/*
$varieties = Variety::all();
foreach ($varieties as $variety) {
$specie_name = $variety->specie;
dump($specie_name);
if (!empty($specie_name)) {
$specie = Specie::byName($specie_name)->first();
if (isset($specie->name))
{
dump($specie->name);
$variety->specie_id = $specie->id;
$variety->save();
} else {
dump("non trouvé");
}
} else {
dump("Aucune espèce");
}
}
*/
/*
$species = Specie::all();
foreach ($species as $specie) {
$genre_name = $specie->genre;
dump($genre_name);
if (!empty($genre_name)) {
$genre = Genre::byName($genre_name)->first();
if (isset($genre->name))
{
dump($genre->name);
$specie->genre_id = $genre->id;
$specie->save();
} else {
dump("non trouvé");
}
} else {
dump("Aucun genre");
}
}
*/
/*
$genres = Genre::all();
foreach ($genres as $genre) {
$family_name = $genre->family;
dump($family_name);
if (!empty($family_name)) {
$family = Family::byName($family_name)->first();
if (isset($family->name))
{
dump($family->name);
$genre->family_id = $family->id;
$genre->save();
} else {
dump("non trouvé");
}
} else {
dump("Aucune famille");
}
}
*/
}
}

View File

@@ -1,56 +0,0 @@
<?php
namespace App\Http\Controllers\Shop\Admin;
use Illuminate\Http\Request;
use App\Http\Controllers\Controller;
use App\Repositories\Shop\ArticleAttributeFamilies;
use App\DataTables\Shop\ArticleAttributeFamiliesDataTable;
class ArticleAttributeFamilyController extends Controller
{
public function index(ArticleAttributeFamiliesDataTable $dataTable)
{
return $dataTable->render('Shop.Admin.ArticleAttributeFamilies.list');
}
public function getDatatable(Request $request)
{
return ArticleAttributeFamilies::getTables($request->all());
}
public function create()
{
return view('Shop.Admin.ArticleAttributeFamilies.create');
}
public function store(Request $request)
{
$ret = ArticleAttributeFamilies::store($request->all());
return redirect()->route('Shop.Admin.ArticleAttributeFamilies.index');
}
public function show($id)
{
$data = ArticleAttributeFamilies::get($id);
return view('Shop.Admin.ArticleAttributeFamilies.view', $data);
}
public function edit($id)
{
$data = ArticleAttributeFamilies::get($id);
return view('Shop.Admin.ArticleAttributeFamilies.edit', $data);
}
public function update(Request $request)
{
//
}
public function destroy($id)
{
return ArticleAttributeFamilies::destroy($id);
}
}

View File

@@ -1,6 +1,6 @@
<?php <?php
namespace App\Http\Controllers; namespace App\Http\Controllers\Shop\Admin;
use Illuminate\Http\Request; use Illuminate\Http\Request;
use App\Http\Controllers\Controller; use App\Http\Controllers\Controller;

View File

@@ -0,0 +1,56 @@
<?php
namespace App\Http\Controllers\Shop\Admin;
use Illuminate\Http\Request;
use App\Http\Controllers\Controller;
use App\Repositories\Shop\PriceFamilies;
use App\DataTables\Shop\PriceFamiliesDataTable;
class PriceFamilyController extends Controller
{
public function index(PriceFamiliesDataTable $dataTable)
{
return $dataTable->render('Shop.Admin.PriceFamilies.list');
}
public function getDatatable(Request $request)
{
return PriceFamilies::getTables($request->all());
}
public function create()
{
return view('Shop.Admin.PriceFamilies.create');
}
public function store(Request $request)
{
$ret = PriceFamilies::store($request->all());
return redirect()->route('Shop.Admin.PriceFamilies.index');
}
public function show($id)
{
$data = PriceFamilies::get($id);
return view('Shop.Admin.PriceFamilies.view', $data);
}
public function edit($id)
{
$data = PriceFamilies::get($id);
return view('Shop.Admin.PriceFamilies.edit', $data);
}
public function update(Request $request)
{
//
}
public function destroy($id)
{
return PriceFamilies::destroy($id);
}
}

View File

@@ -0,0 +1,64 @@
<?php
namespace App\Http\Controllers\Shop\Admin;
use Illuminate\Http\Request;
use App\Http\Controllers\Controller;
use App\Repositories\Shop\PriceFamilies;
use App\Repositories\Shop\PriceFamilyValues;
use App\DataTables\Shop\PriceFamilyValuesDataTable;
class PriceFamilyValueController extends Controller
{
public function index(PriceFamilyValuesDataTable $dataTable)
{
$data['families'] = PriceFamilies::getOptions();
return $dataTable->render('Shop.Admin.PriceFamilyValues.list', $data);
}
public function getDatatable(Request $request)
{
return PriceFamilyValues::getTables($request->all());
}
public function getOptionsByFamily(Request $request)
{
$id = $request->input('family_id');
return response()->json(PriceFamilyValues::getSelectByFamily($id));
}
public function create()
{
return view('Shop.Admin.PriceFamilyValues.create');
}
public function store(Request $request)
{
$ret = PriceFamilyValues::store($request->all());
return redirect()->route('Shop.Admin.PriceFamilyValues.index');
}
public function show($id)
{
$data = PriceFamilyValues::get($id);
return view('Shop.Admin.PriceFamilyValues.view', $data);
}
public function edit($id)
{
$data = PriceFamilyValues::get($id);
return view('Shop.Admin.PriceFamilyValues.edit', $data);
}
public function update(Request $request)
{
//
}
public function destroy($id)
{
return PriceFamilyValues::destroy($id);
}
}

View File

@@ -9,49 +9,52 @@ use App\Models\Shop\PriceGeneric;
use App\Repositories\Shop\PriceGenerics; use App\Repositories\Shop\PriceGenerics;
use App\Repositories\Shop\PriceGenericCategories; use App\Repositories\Shop\PriceGenericCategories;
use App\Repositories\Shop\Taxes; use App\Repositories\Shop\Taxes;
use App\Repositories\Shop\Unities;
use App\DataTables\Shop\PriceGenericsDataTable; use App\DataTables\Shop\PriceGenericsDataTable;
class PriceGenericController extends Controller class PriceGenericController extends Controller
{ {
public function index(PriceGenericsDataTable $dataTable) public function index(PriceGenericsDataTable $dataTable)
{ {
return $dataTable->render('Shop.Admin.PriceGenerics.list'); return $dataTable->render('Shop.Admin.PriceGenerics.list');
} }
public function getDatatable(Request $request) public function getDatatable(Request $request)
{ {
return PriceGenerics::getTables($request->all()); return PriceGenerics::getTables($request->all());
} }
public function create() public function create()
{ {
$data['taxes'] = Taxes::getOptions(); $data['unities'] = Unities::getOptions();
$data['categories'] = PriceGenericCategories::getOptions(); $data['taxes'] = Taxes::getOptions();
return view('Shop.Admin.PriceGenerics.create',$data); $data['categories'] = PriceGenericCategories::getOptions();
} return view('Shop.Admin.PriceGenerics.create',$data);
}
public function edit($id) public function edit($id)
{ {
$data['generic'] = PriceGenerics::get($id)->toArray(); $data['generic'] = PriceGenerics::get($id)->toArray();
$data['taxes'] = Taxes::getOptions(); $data['unities'] = Unities::getOptions();
$data['categories'] = PriceGenericCategories::getOptions(); $data['taxes'] = Taxes::getOptions();
return view('Shop.Admin.PriceGenerics.edit', $data); $data['categories'] = PriceGenericCategories::getOptions();
} return view('Shop.Admin.PriceGenerics.edit', $data);
}
public function store(Request $request) public function store(Request $request)
{ {
$ret = PriceGenerics::store($request->all()); $ret = PriceGenerics::store($request->all());
return redirect()->route('Shop.Admin.PriceGenerics.index'); return redirect()->route('Shop.Admin.PriceGenerics.index');
} }
public function show($id) public function show($id)
{ {
$data = PriceGenerics::get($id); $data = PriceGenerics::get($id);
return view('Shop.Admin.PriceGenerics.view', $data); return view('Shop.Admin.PriceGenerics.view', $data);
} }
public function destroy($id) public function destroy($id)
{ {
return PriceGenerics::destroy($id); return PriceGenerics::destroy($id);
} }
} }

View File

@@ -0,0 +1,64 @@
<?php
namespace App\Http\Controllers\Shop\Admin;
use Illuminate\Http\Request;
use App\Http\Controllers\Controller;
use App\Repositories\Shop\PriceFamilies;
use App\Repositories\Shop\UnityValues;
use App\DataTables\Shop\UnityValuesDataTable;
class UnityValueController extends Controller
{
public function index(UnityValuesDataTable $dataTable)
{
$data['families'] = PriceFamilies::getOptions();
return $dataTable->render('Shop.Admin.UnityValues.list', $data);
}
public function getDatatable(Request $request)
{
return UnityValues::getTables($request->all());
}
public function getOptionsByFamily(Request $request)
{
$id = $request->input('family_id');
return response()->json(UnityValues::getSelectByFamily($id));
}
public function create()
{
return view('Shop.Admin.UnityValues.create');
}
public function store(Request $request)
{
$ret = UnityValues::store($request->all());
return redirect()->route('Shop.Admin.UnityValues.index');
}
public function show($id)
{
$data = UnityValues::get($id);
return view('Shop.Admin.UnityValues.view', $data);
}
public function edit($id)
{
$data = UnityValues::get($id);
return view('Shop.Admin.UnityValues.edit', $data);
}
public function update(Request $request)
{
//
}
public function destroy($id)
{
return UnityValues::destroy($id);
}
}

View File

@@ -19,14 +19,14 @@ class Shop
->activeIfRoute(['Shop.Admin.Categories.*'])->order(2); ->activeIfRoute(['Shop.Admin.Categories.*'])->order(2);
$menu->addTo('shop', 'Familles d\'articles', [ 'route' => 'Shop.Admin.ArticleFamilies.index', 'permission' => 'backend_access' ]) $menu->addTo('shop', 'Familles d\'articles', [ 'route' => 'Shop.Admin.ArticleFamilies.index', 'permission' => 'backend_access' ])
->activeIfRoute(['Shop.Admin.ArticleFamilies.*'])->order(3); ->activeIfRoute(['Shop.Admin.ArticleFamilies.*'])->order(3);
$menu->addTo('shop', 'Familles d\'attributs', [ 'route' => 'Shop.Admin.ArticleAttributeFamilies.index', 'permission' => 'backend_access' ]) /*
->activeIfRoute(['Shop.Admin.ArticleAttributeFamilies.*'])->order(4);
$menu->addTo('shop', 'Attributs', [ 'route' => 'Shop.Admin.ArticleAttributeValues.index', 'permission' => 'backend_access' ]) $menu->addTo('shop', 'Attributs', [ 'route' => 'Shop.Admin.ArticleAttributeValues.index', 'permission' => 'backend_access' ])
->activeIfRoute(['Shop.Admin.ArticleAttributeValues.*'])->order(5); ->activeIfRoute(['Shop.Admin.ArticleAttributeValues.*'])->order(4);
*/
$menu->addTo('shop', 'Familles de tags', [ 'route' => 'Shop.Admin.TagGroups.index', 'permission' => 'backend_access' ]) $menu->addTo('shop', 'Familles de tags', [ 'route' => 'Shop.Admin.TagGroups.index', 'permission' => 'backend_access' ])
->activeIfRoute(['Shop.Admin.TagGroups.*'])->order(6); ->activeIfRoute(['Shop.Admin.TagGroups.*'])->order(5);
$menu->addTo('shop', 'Tags', [ 'route' => 'Shop.Admin.Tags.index', 'permission' => 'backend_access' ]) $menu->addTo('shop', 'Tags', [ 'route' => 'Shop.Admin.Tags.index', 'permission' => 'backend_access' ])
->activeIfRoute(['Shop.Admin.Tags.*'])->order(7); ->activeIfRoute(['Shop.Admin.Tags.*'])->order(6);
/* /*
$menu->addTo('shop', 'Réductions', [ 'route' => 'Shop.Admin.ArticleAttributeValues.index', 'permission' => 'backend_access' ]) $menu->addTo('shop', 'Réductions', [ 'route' => 'Shop.Admin.ArticleAttributeValues.index', 'permission' => 'backend_access' ])

View File

@@ -22,9 +22,14 @@ class Price extends Model
return $this->belongsTo('App\Models\Shop\PriceFamily'); return $this->belongsTo('App\Models\Shop\PriceFamily');
} }
public function price() public function generic()
{ {
return $this->morphTo(); return $this->belongsTo('App\Models\Shop\PriceGeneric', 'price_generic_id');
}
public function generic_prices()
{
} }
public function scopeByArticle($query, $id) public function scopeByArticle($query, $id)
@@ -37,4 +42,14 @@ class Price extends Model
return $query->where('price_family_id', $id); return $query->where('price_family_id', $id);
} }
public function scopeGeneric($query)
{
return $query->whereNotNull('price_generic_id');
}
public function scopeNotGeneric($query)
{
return $query->whereNull('price_generic_id');
}
} }

View File

@@ -7,7 +7,7 @@ use Illuminate\Database\Eloquent\Model;
class PriceFamilyValue extends Model class PriceFamilyValue extends Model
{ {
protected $guarded = ['id']; protected $guarded = ['id'];
protected $table = 'shop_price_familiy_values'; protected $table = 'shop_price_family_values';
public function price_family() public function price_family()
{ {

View File

@@ -7,39 +7,34 @@ use Znck\Eloquent\Traits\BelongsToThrough;
class PriceGeneric extends Model class PriceGeneric extends Model
{ {
use BelongsToThrough; use BelongsToThrough;
protected $guarded = ['id']; protected $guarded = ['id'];
protected $table = 'shop_price_generics'; protected $table = 'shop_price_generics';
public function category() public function category()
{ {
return $this->hasOne('App\Models\Shop\PriceGenericCategory','id','category_id'); return $this->hasOne('App\Models\Shop\PriceGenericCategory','id','category_id');
} }
public function prices() public function prices()
{ {
return $this->hasMany('App\Models\Shop\Price','price_id')->where('price_type','App\Models\Shop\PriceGeneric'); return $this->hasMany('App\Models\Shop\PriceGenericValue','price_generic_id')->whereNotNull('price_generic_id');
} }
public function values() public function priceByUnit()
{ {
return $this->hasMany('App\Models\Shop\PriceGenericValue'); return $this->hasOne('App\Models\Shop\PriceGenericValue')->orderBy('quantity','asc');
} }
public function priceByUnit() public function articles()
{ {
return $this->hasOne('App\Models\Shop\PriceGenericValue')->orderBy('quantity','asc'); return $this->hasManyThrough('App\Models\Shop\Article','App\Models\Shop\Price');
} }
public function articles() public function scopeByCategory($query, $id)
{ {
return $this->hasManyThrough('App\Models\Shop\Article','App\Models\Shop\Price'); return $query->where('category_id', $id);
} }
public function scopeByCategory($query, $id)
{
return $query->where('category_id', $id);
}
} }

View File

@@ -6,21 +6,21 @@ use Illuminate\Database\Eloquent\Model;
class Tag extends Model class Tag extends Model
{ {
protected $guarded = ['id']; protected $guarded = ['id'];
public function group() public function group()
{ {
return $this->hasOne('App\Models\Shop\TagGroup','id','tag_group_id'); return $this->hasOne('App\Models\Shop\TagGroup','id','tag_group_id');
} }
public function scopeByGroup($query, $id) public function scopeByGroup($query, $id)
{ {
return $query->where('tag_group_id', $id); return $query->where('tag_group_id', $id);
} }
public function getNameAttribute($value) public function getNameAttribute($value)
{ {
return json_decode($value)->fr; return json_decode($value)->fr;
} }
} }

View File

@@ -6,12 +6,11 @@ use Illuminate\Database\Eloquent\Model;
class TagGroup extends Model class TagGroup extends Model
{ {
protected $guarded = ['id']; protected $guarded = ['id'];
protected $table = 'tag_groups'; protected $table = 'tag_groups';
public function tags() public function tags()
{ {
return $this->hasMany('App\Models\Shop\Tag'); return $this->hasMany('App\Models\Shop\Tag');
} }
} }

13
app/Models/Shop/Unity.php Normal file
View File

@@ -0,0 +1,13 @@
<?php
namespace App\Models\Shop;
use Illuminate\Database\Eloquent\Model;
class Unity extends Model
{
protected $guarded = ['id'];
protected $table = 'shop_unities';
}

View File

@@ -14,62 +14,49 @@ use App\Models\Shop\Price;
class Prices class Prices
{ {
public static function getByArticle($id) public static function getByArticle($id)
{ {
$prices = Price::byArticle($id)->with('price')->get()->toArray(); $data['prices'] = Price::byArticle($id)->notGeneric()->get()->toArray();
$data = []; $data['generics'] = Price::byArticle($id)->generic()->with(['generic.prices','generic.category'])->get()->toArray();
foreach ($prices as $price) return $data;
{ }
if ($price['price_type'] == 'App\Models\Shop\ArticlePrice')
{
$data[] = $price['price'];
} else {
$values = PriceGenericValues::getByPriceGeneric($price['price']['id'])->toArray();
foreach ($values as $value)
{
$data[] = $value;
}
}
}
return $data;
}
public static function getDatatable() public static function getDatatable()
{ {
$model = Price::orderBy('name'); $model = Price::orderBy('name');
return Datatables::of($model)->make(true); return Datatables::of($model)->make(true);
} }
public static function getAll() public static function getAll()
{ {
return Price::orderBy('name','asc')->get(); return Price::orderBy('name','asc')->get();
} }
public static function get($id) public static function get($id)
{ {
return Price::find($id); return Price::find($id);
} }
public static function store($data) public static function store($data)
{ {
$id = isset($data['id']) ? $data['id'] : false; $id = isset($data['id']) ? $data['id'] : false;
$item = $id ? self::update($data) : self::create($data); $item = $id ? self::update($data) : self::create($data);
return $item->id; return $item->id;
} }
public static function create($data) public static function create($data)
{ {
return Price::create($data); return Price::create($data);
} }
public static function update($data) public static function update($data)
{ {
return Price::find($id)->update($data); return Price::find($id)->update($data);
} }
public static function destroy($id) public static function destroy($id)
{ {
return Price::destroy($id); return Price::destroy($id);
} }
} }

View File

@@ -0,0 +1,58 @@
<?php
namespace App\Repositories\Shop;
use Illuminate\Support\Facades\Storage;
use Illuminate\Support\Facades\DB;
use Illuminate\Support\Str;
use Yajra\DataTables\DataTables;
use App\Models\Shop\Unity;
class Unities
{
public static function getDatatable()
{
return Datatables::of($model)->make(true);
}
public static function getOptions()
{
return Unity::orderBy('value','asc')->get()->pluck('value','id')->toArray();
}
public static function getAll()
{
return Unity::orderBy('value','asc')->get();
}
public static function get($id)
{
return Unity::find($id);
}
public static function store($data)
{
$id = isset($data['id']) ? $data['id'] : false;
$item = $id ? self::update($data) : self::create($data);
return $item->id;
}
public static function create($data)
{
return Unity::create($data);
}
public static function update($data)
{
return Unity::find($id)->update($data);
}
public static function destroy($id)
{
return Unity::destroy($id);
}
}

View File

@@ -1,111 +0,0 @@
<?php
namespace App;
use Twig_Extension;
use Twig_SimpleFunction;
use Twig_SimpleFilter;
use function Stringy\create as s;
use App\Repositories\Languages;
use App\Repositories\Users;
class Twiggy extends Twig_Extension
{
public function getName()
{
//
}
/**
* Functions
* @return array
*/
public function getFunctions()
{
return [
new Twig_SimpleFunction('translate', [$this, 'translate']),
new Twig_SimpleFunction('hasRole', [$this, 'hasRole']),
new Twig_SimpleFunction('hasPermission', [$this, 'hasPermission']),
new Twig_SimpleFunction('showMenu', [$this, 'showMenu']),
];
}
/**
* Filters
* @return array
*/
public function getFilters()
{
return [
new Twig_SimpleFilter('pretty_date', [$this, 'pretty_date']),
];
}
public function translate($string)
{
return Languages::translate($string);
}
public function hasRole($string)
{
return Users::hasRole($string);
}
public function hasPermission($string)
{
return Users::hasPermission($string);
}
public function showMenu($menu)
{
return $menu->get('menu_admin')->asUl();
}
public function pretty_date($date)
{
$time = strtotime($date);
$now = time();
$ago = $now - $time;
$futur = 0;
if ($ago < 0) {
$ago = (-1 * $ago);
$futur = 1;
}
if ($ago < 60) {
$when = round($ago);
$s = ($when == 1) ? "seconde" : "secondes";
$txt = "$when $s";
} elseif ($ago < 3600) {
$when = round($ago / 60);
$m = ($when == 1) ? "minute" : "minutes";
$txt = "$when $m";
} elseif ($ago >= 3600 && $ago < 86400) {
$when = round($ago / 60 / 60);
$h = ($when == 1) ? "heure" : "heures";
$txt = "$when $h";
} elseif ($ago >= 86400 && $ago < 2629743.83) {
$when = round($ago / 60 / 60 / 24);
$d = ($when == 1) ? "jour" : "jours";
$txt = "$when $d";
} elseif ($ago >= 2629743.83 && $ago < 31556926) {
$when = round($ago / 60 / 60 / 24 / 30.4375);
$m = "mois";
$txt = "$when $m";
} else {
$when = round($ago / 60 / 60 / 24 / 365);
$y = ($when == 1) ? "an" : "ans";
$txt = "$when $y";
}
if ($futur) {
$txt = "dans " . $txt;
} else {
$txt = "il y a " . $txt;
}
return $txt;
}
}

View File

@@ -44,6 +44,7 @@
"laravel/scout": "^7.2", "laravel/scout": "^7.2",
"laravel/ui": "^1.0", "laravel/ui": "^1.0",
"laravelcollective/html": "^6.0", "laravelcollective/html": "^6.0",
"lavary/laravel-menu": "1.8.1",
"league/climate": "^3.5", "league/climate": "^3.5",
"league/period": "^4.9", "league/period": "^4.9",
"lorisleiva/laravel-deployer": "^0.3.2", "lorisleiva/laravel-deployer": "^0.3.2",
@@ -74,7 +75,7 @@
"smajohusic/laravel-mail-logger": "^1.0", "smajohusic/laravel-mail-logger": "^1.0",
"soved/laravel-gdpr": "^1.5", "soved/laravel-gdpr": "^1.5",
"spatie/laravel-activitylog": "^3.6", "spatie/laravel-activitylog": "^3.6",
"spatie/laravel-backup": "^6.2", "spatie/laravel-backup": "^6.7",
"spatie/laravel-medialibrary": "^7.0", "spatie/laravel-medialibrary": "^7.0",
"staudenmeir/belongs-to-through": "^2.5", "staudenmeir/belongs-to-through": "^2.5",
"staudenmeir/eloquent-has-many-deep": "^1.8", "staudenmeir/eloquent-has-many-deep": "^1.8",
@@ -102,7 +103,6 @@
"nunomaduro/larastan": "^0.5.2", "nunomaduro/larastan": "^0.5.2",
"nunomaduro/phpinsights": "^1.13", "nunomaduro/phpinsights": "^1.13",
"phpunit/phpunit": "^8.0", "phpunit/phpunit": "^8.0",
"sayeed/custom-migrate": "^1.0",
"theseer/phpdox": "^0.12.0", "theseer/phpdox": "^0.12.0",
"wnx/laravel-stats": "^2.0" "wnx/laravel-stats": "^2.0"
}, },

View File

@@ -1,28 +0,0 @@
@extends('layout.index', [
'title' => __('article_attribute_families.title'),
'subtitle' => __('article_attribute_families.create.title'),
'breadcrumb' => [__('article_attribute_families.title'), __('article_attribute_families.create.title')]
])
@include('boilerplate::load.fileinput')
@section('content')
{{ Form::open(['route' => 'Shop.Admin.ArticleAttributeFamilies.store', 'id' => 'article-attribute-family-form', 'autocomplete' => 'off']) }}
<div class="row">
<div class="col-sm-12 mbl">
<a href="{{ route("Shop.Admin.ArticleAttributeFamilies.index") }}" class="btn btn-default">
{{ __('article_attribute_families.title') }}
</a>
<span class="btn-group pull-right">
@include('components.button-save')
</span>
</div>
</div>
@include('Shop.Admin.ArticleAttributeFamilies.form')
</form>
@endsection

View File

@@ -1,29 +0,0 @@
@extends('layout.index', [
'title' => 'Famille d\'articles',
'subtitle' => 'Edition d\'une famille d\'article',
'breadcrumb' => ['Articles']
])
@include('boilerplate::load.fileinput')
@section('content')
{{ Form::open(['route' => 'Shop.Admin.ArticleFamilies.update', 'id' => 'article-family-form', 'autocomplete' => 'off', 'files' => true]) }}
<div class="row">
<div class="col-sm-12 mbl">
<a href="{{ route("Shop.Admin.ArticleFamilies.index") }}" class="btn btn-default">
{{ __('article_families.list.title') }}
</a>
<span class="btn-group pull-right">
@include('components.button-save')
</span>
</div>
</div>
<input type="hidden" name="id" value="{{ $id }}">
@include('Shop.Admin.ArticleFamilies.form')
</form>
@endsection

View File

@@ -1,39 +0,0 @@
@extends('layout.index', [
'title' => __('Shop.article_attributes.title'),
'subtitle' => __('Shop.article_attributes.list'),
'breadcrumb' => [__('Shop.article_attributes.title')]
])
@include('boilerplate::load.select2')
@section('content')
<nav>
<div class="nav nav-tabs">
<a href="#families" data-toggle="tab" class="nav-item nav-link" role="tab" aria-controls="families" aria-selected="true">
{{ __('Shop.article_attribute_families.title') }}
</a>
<a href="#values" data-toggle="tab" class="nav-item nav-link active" role="tab" aria-controls="values" aria-selected="false">
{{ __('Shop.article_attribute_values.title') }}
</a>
</div>
</nav>
<div class="tab-content mb-0">
<div class="tab-pane fade" id="families">
@component('components.card')
@include('components.datatable', ['route' => route('Shop.Admin.ArticleAttributeFamilies.index'), 'model' => 'ArticleAttributeFamilies'])
@endcomponent
</div>
<div class="tab-pane fade show active" id="values">
@component('components.card')
@include('components.datatable', ['route' => route('Shop.Admin.ArticleAttributeValues.index'), 'model' => 'ArticleAttributeValues'])
@endcomponent
</div>
</div>
@endsection

View File

@@ -1,9 +0,0 @@
@extends('layout.index', [
'title' => __('Shop.article_attribute_families.title'),
'subtitle' => __('Shop.article_attribute_families.list'),
'breadcrumb' => [__('Shop.article_attribute_families.title')]
])
@section('content')
@include('components.datatable', ['route' => route('Shop.Admin.ArticleAttributeFamilies.index'), 'model' => 'ArticleAttributefamilies'])
@endsection

View File

@@ -52,7 +52,8 @@
</div> </div>
<div class="tab-pane" id="prices"> <div class="tab-pane" id="prices">
@include('Shop.Admin.Articles.partials.prices') @include('Shop.Admin.Articles.partials.prices', ['prices' => $prices['prices'] ?? null])
@include('Shop.Admin.Articles.partials.generic_prices', ['generics' => $prices['generics'] ?? null])
</div> </div>
<div class="tab-pane" id="shipping"> <div class="tab-pane" id="shipping">

View File

@@ -0,0 +1,119 @@
@include('Shop.Admin.Articles.partials.generic_prices.block_generic_price_new')
<div id="append_generic_price" class="row">
@include('Shop.Admin.Articles.partials.generic_prices.list-generic_prices')
</div>
<button type="button" class="btn btn-sm btn-primary add-new-generic_price">Associer un tarif générique<i class="fa fa-plus"></i></button>
@include('components.select-tree', ['name' => "article_price_generic_id", 'value' => $price['article_price_generic_id'] ?? null, 'list' => $price_generics ?? null, 'required' => false, 'class' => 'form-control-sm w-100'])
@push('js')
<script>
function append_generic_price() {
// handle_append_attribute();
$('.select2').select2();
handle_change_attribute();
load_attribute_values($('.attributes-value'), $('.attributes-family').val());
}
$("#append_generic_price").appender({
rowSection: '.row-new-generic_price',
type: '.row-generic_price',
addBtn: '.add-new-generic_price',
appendEffect: 'slide',
addClass: 'animated bounceInLeft',
rowNumber: '.row-generic_price-number',
deleteBtn: '.delete-new-generic_price-btn',
callback: append_generic_price,
rowNumberStart: 2,
hideSection: true
});
function append_attribute() {
}
function handle_append_attribute(selector) {
console.log('handle_append_attribute');
$(".append_attribute").appender({
rowSection: '.row-new-attribute',
type: '.row-attribute',
addBtn: '.add-new-attribute',
appendEffect: 'slide',
addClass: 'animated bounceInLeft',
rowNumber: '.row-attribute-number',
deleteBtn: '.delete-new-attribute-btn',
callback: append_attribute,
rowNumberStart: 2,
hideSection: true
});
}
function handle_change_attribute() {
$('.attributes-family').change( function() {
var family_id = $(this).val();
var $family = $(this);
var $parent = $family.parent().parent();
var $selector = $parent.find('.attributes-value');
load_attribute_values($selector, family_id);
});
}
function init_attribute_values() {
$('.attributes-family').each( function() {
var family_id = $(this).val();
var $family = $(this);
var $parent = $family.parent().parent();
var $selector = $parent.find('.attributes-value');
load_attribute_values($selector, family_id);
value_id = $selector.data('id');
$selector.val(value_id).trigger('change');
});
}
function load_attribute_values($selector, family_id) {
$.ajax({
url : "{{ route('Shop.Admin.PriceFamilyValues.getOptionsByFamily') }}",
method : 'POST',
data: { family_id: family_id },
success : function(data) {
$selector.empty().select2({data: data});
}
});
}
function handle_delete_generic_price() {
$('.delete-generic_price-btn').click(function() {
var $selector = $(this).parents('.row-generic_price');
var id = $selector.find('.generic_price_id').val();
confirm_delete(id, laroute.route('Shop.Admin.ArticlePrices.destroy', {id : id}), function() {
$selector.remove();
});
});
}
function handle_generic_prices() {
$('.generic_price-item').change(function() {
tax_selected = $(this).parent().prev().find('select option:selected').text();
generic_price_taxed = $(this).val() * (1 + (tax_selected / 100));
$(this).parent().parent().find('.generic_price-taxed-item').val(generic_price_taxed);
})
}
function handle_generic_prices_taxed() {
$('.generic_price-taxed-item').change(function() {
tax_selected = $(this).parent().prev().find('select option:selected').text();
console.log($(this).parent().prev());
generic_price = $(this).val() / (1 + (tax_selected / 100));
$(this).parent().parent().find('.generic_price-item').val(generic_price);
})
}
</script>
@endpush

View File

@@ -0,0 +1,4 @@
<div id="attributes" class="appender" data-id="">
@include('Shop.Admin.Articles.partials.prices.block_attribute_new')
<div class="append_attribute"></div>
</div>

View File

@@ -0,0 +1,28 @@
<div class="row row-attribute">
<input type="hidden" name="prices[{{ $key }}][article_attribute][quantity]" value="1">
<input type="hidden" name="prices[{{ $key }}][article_attribute][id]" value="{{ (isset($attribute['id'])) ? $attribute['id'] : null }}">
<div class="col-12 col-lg-7">
{{ Form::label('attribute_family_id', 'Attributs') }}<br/>
@include('components.select', [
'name' => "prices[$key][attribute][attribute_family_id]",
'value' => $attribute['attribute_value']['article_attribute_family_id'] ?? null,
'list' => $attribute_families_options,
'required' => true,
'class' => 'select2 form-control-sm attributes-family'
])
</div>
<div class="col-12 col-lg-5">
{{ Form::label('attribute_value_id', 'Valeur') }}<br/>
@include('components.select', [
'name' => "prices[$key][attribute][attribute_value_id]",
'value' => $attribute['article_attribute_value_id'] ?? null,
'list' => $attribute_values ?? null,
'required' => true,
'class' => 'select2 form-control-sm attributes-value w-100',
'meta' => (isset($attribute['article_attribute_value_id'])) ? 'data-id="' . $attribute['article_attribute_value_id'] . '"' : ''
])
</div>
</div>

View File

@@ -0,0 +1,24 @@
<div class="row row-new-attribute row-attribute">
<input type="hidden" name="prices[][attribute][quantity]" value="1">
<div class="col-12 col-lg-6 1">
{{ Form::label('attribute_family_id', 'Attributs') }}<br/>
@include('components.select', [
'name' => 'prices[][attribute][attribute_family_id]',
'value' => $attribute_value['article_attribute_family_id'] ?? null,
'list' => $attribute_families_options,
'required' => true,
'class' => 'select2 form-control-sm attributes-family'
])
</div>
<div class="col-12 col-lg-6 2">
{{ Form::label('attribute_value_id', 'Valeur') }}<br/>
@include('components.select', [
'name' => 'prices[][attribute][attribute_value_id]',
'value' => $attribute_value['id'] ?? null,
'list' => $attribute_values ?? null,
'required' => true,
'class' => 'select2 form-control-sm attributes-value'
])
</div>
</div>

View File

@@ -0,0 +1,12 @@
<div class="col-12 row-generic">
<input type="hidden" name="generics[id][]" value="{{ $generic['id'] ?? null }}">
<input type="hidden" name="generics[price_generic_id][]" value="{{ $generic['price_generic_id'] ?? null }}">
<button type="button" class="btn btn-xs btn-danger delete-price-btn mt-2" data-card-widget="collapse" data-toggle="tooltip" title="supprimer">
<i class="fas fa-trash"></i>
</button>
@include('Shop.Admin.PriceGenerics.partials.table-prices', ['generic' => $generic['generic'] ?? null ])
</div>

View File

@@ -0,0 +1,54 @@
<div class="col-12 row-new-price row-price">
<input type="hidden" name="prices[][id]" value="">
<div class="card card-light">
<div class="card-body pt-2">
<div class="row">
<div class="col-lg-3">
{{ Form::label('price_generic_id', 'Générique') }}<br/>
@include('components.select-tree', ['name' => "prices[0][article_price_generic_id]", 'value' => $price['article_price_generic_id'] ?? null, 'list' => $price_generics ?? null, 'required' => false, 'class' => 'form-control-sm'])
</div>
<div class="col-lg-1">
{{ Form::label('quantity', 'Quantité') }}<br/>
@include('components.number', ['name' => 'prices[0][quantity]', 'value' => $quantity ?? 1, 'required' => true, 'class' => 'form-control-sm'])
</div>
<div class="col-lg-4">
@include('Shop.Admin.Articles.partials.prices.block_attribute_new')
</div>
<div class="col-lg-6">
<div class="col-2">
{{ Form::label('tax_id', 'TVA') }}<br/>
@include('components.select', ['name' => 'prices[0][tax_id]', 'value' => $tax_id ?? null, 'list' => $taxes_options ?? null, 'required' => true, 'class' => 'form-control form-control-sm'])
</div>
<div class="col-3">
{{ Form::label('price', 'Prix HT') }}
@include('components.money', ['name' => 'prices[0][price]', 'value' => $price ?? 0, 'required' => true, 'class' => 'form-control-sm price-item'])
</div>
<div class="col-3">
{{ Form::label('price_taxed', 'Prix TTC') }}
@include('components.money', ['name' => 'prices[0][price_taxed]', 'value' => $price_taxed ?? 0, 'required' => true, 'class' => 'form-control-sm price-taxed-item'])
</div>
</div>
<div class="col-lg-1 text-right">
<br/>
<button type="button" class="btn btn-xs btn-danger delete-new-price-btn mt-2" data-card-widget="collapse" data-toggle="tooltip" title="supprimer">
<i class="fas fa-trash"></i>
</button>
</div>
</div>
</div>
</div>
</div>

View File

@@ -0,0 +1,14 @@
@if (isset($generics) && (count($generics)))
@foreach ($generics as $generic)
@include('Shop.Admin.Articles.partials.generic_prices.block_generic_price')
@endforeach
@endif
@push('js')
<script>
$(function () {
handle_delete_generic_price();
});
</script>
@endpush

View File

@@ -1,13 +1,10 @@
<div class="row row-attribute"> <div class="row row-attribute">
<input type="hidden" name="prices[{{ $key }}][article_attribute][quantity]" value="1">
<input type="hidden" name="prices[{{ $key }}][article_attribute][id]" value="{{ (isset($attribute['id'])) ? $attribute['id'] : null }}">
<div class="col-12 col-lg-7"> <div class="col-12 col-lg-7">
{{ Form::label('attribute_family_id', 'Attributs') }}<br/> {{ Form::label('attribute_family_id', 'Type') }}<br/>
@include('components.select', [ @include('components.select', [
'name' => "prices[$key][attribute][attribute_family_id]", 'name' => "prices[$key][price_family_id]",
'value' => $attribute['attribute_value']['article_attribute_family_id'] ?? null, 'value' => $price['price_family_id'] ?? null,
'list' => $attribute_families_options, 'list' => $attribute_families_options,
'required' => true, 'required' => true,
'class' => 'select2 form-control-sm attributes-family' 'class' => 'select2 form-control-sm attributes-family'
@@ -15,14 +12,13 @@
</div> </div>
<div class="col-12 col-lg-5"> <div class="col-12 col-lg-5">
{{ Form::label('attribute_value_id', 'Valeur') }}<br/> {{ Form::label('attribute_value_id', 'Unité') }}<br/>
@include('components.select', [ @include('components.select', [
'name' => "prices[$key][attribute][attribute_value_id]", 'name' => "prices[$key][unity_id]",
'value' => $attribute['article_attribute_value_id'] ?? null, 'value' => $price['unity_id'] ?? null,
'list' => $attribute_values ?? null, 'list' => $unities ?? null,
'required' => true, 'required' => true,
'class' => 'select2 form-control-sm attributes-value', 'class' => 'select2 form-control-sm attributes-value w-100',
'meta' => (isset($attribute['article_attribute_value_id'])) ? 'data-id="' . $attribute['article_attribute_value_id'] . '"' : ''
]) ])
</div> </div>
</div> </div>

View File

@@ -7,12 +7,7 @@
<div class="row"> <div class="row">
<div class="col-lg-3"> <div class="col-lg-11">
{{ Form::label('price_generic_id', 'Générique') }}<br/>
@include('components.select-tree', ['name' => "prices[$key][article_price_generic_id]", 'value' => $price['article_price_generic_id'] ?? null, 'list' => $price_generics ?? null, 'required' => false, 'class' => 'form-control-sm'])
</div>
<div class="col-lg-8">
<div class="row"> <div class="row">
<div class="col-lg-1"> <div class="col-lg-1">
{{ Form::label('quantity', 'Qté.') }}<br/> {{ Form::label('quantity', 'Qté.') }}<br/>
@@ -20,7 +15,7 @@
</div> </div>
<div class="col-lg-6"> <div class="col-lg-6">
@include('Shop.Admin.Articles.partials.prices.block_attribute', ['attribute' => $price['article_attribute'] ?? null]) @include('Shop.Admin.Articles.partials.prices.block_attribute')
</div> </div>
<div class="col-lg-5"> <div class="col-lg-5">

View File

@@ -1,4 +1,4 @@
<div class="col-6 row-price"> <div class="col-12 row-price">
<input type="hidden" name="prices[{{ $key }}][id]" value="@if (isset($price['id'])){{ $price['id'] }}@endif" class="price_id"> <input type="hidden" name="prices[{{ $key }}][id]" value="@if (isset($price['id'])){{ $price['id'] }}@endif" class="price_id">
@@ -13,16 +13,21 @@
</div> </div>
<div class="col-3"> <div class="col-3">
{{ Form::label('unity_id', 'Unité') }}<br/>
@include('components.select', ['name' => 'prices[0][unity_id]', 'value' => $unity_id ?? null, 'list' => $unities ?? null, 'required' => true, 'class' => 'form-control-sm'])
</div>
<div class="col-2">
{{ Form::label('tax_id', 'TVA') }}<br/> {{ Form::label('tax_id', 'TVA') }}<br/>
@include('components.select', ['name' => "prices[$key][tax_id]", 'value' => $price['tax_id'] ?? null, 'list' => $taxes ?? null, 'required' => true, 'class' => 'form-control-sm']) @include('components.select', ['name' => "prices[$key][tax_id]", 'value' => $price['tax_id'] ?? null, 'list' => $taxes ?? null, 'required' => true, 'class' => 'form-control-sm'])
</div> </div>
<div class="col-3"> <div class="col-2">
{{ Form::label('price', 'Prix HT') }} {{ Form::label('price', 'Prix HT') }}
@include('components.money', ['name' => "prices[$key][price]", 'value' => $price['price'] ?? 0, 'required' => true, 'class' => 'form-control-sm price-item']) @include('components.money', ['name' => "prices[$key][price]", 'value' => $price['price'] ?? 0, 'required' => true, 'class' => 'form-control-sm price-item'])
</div> </div>
<div class="col-3"> <div class="col-2">
{{ Form::label('price_taxed', 'Prix TTC') }} {{ Form::label('price_taxed', 'Prix TTC') }}
@include('components.money', ['name' => "prices[$key][price_taxed]", 'value' => $price['price_taxed'] ?? 0, 'required' => true, 'class' => 'form-control-sm price-taxed-item']) @include('components.money', ['name' => "prices[$key][price_taxed]", 'value' => $price['price_taxed'] ?? 0, 'required' => true, 'class' => 'form-control-sm price-taxed-item'])
</div> </div>

View File

@@ -1,4 +1,4 @@
<div class="col-6 row-new-price row-price"> <div class="col-12 row-new-price row-price">
<input type="hidden" name="prices[][id]" value=""> <input type="hidden" name="prices[][id]" value="">
@@ -12,18 +12,22 @@
@include('components.number', ['name' => 'prices[0][quantity]', 'value' => $quantity ?? 1, 'required' => true, 'class' => 'form-control-sm']) @include('components.number', ['name' => 'prices[0][quantity]', 'value' => $quantity ?? 1, 'required' => true, 'class' => 'form-control-sm'])
</div> </div>
<div class="col-3"> <div class="col-3">
{{ Form::label('unity_id', 'Unité') }}<br/>
@include('components.select', ['name' => 'prices[0][unity_id]', 'value' => $unity_id ?? null, 'list' => $unities ?? null, 'required' => true, 'class' => 'form-control-sm'])
</div>
<div class="col-2">
{{ Form::label('tax_id', 'TVA') }}<br/> {{ Form::label('tax_id', 'TVA') }}<br/>
@include('components.select', ['name' => 'prices[0][tax_id]', 'value' => $tax_id ?? null, 'list' => $taxes ?? null, 'required' => true, 'class' => 'form-control-sm']) @include('components.select', ['name' => 'prices[0][tax_id]', 'value' => $tax_id ?? null, 'list' => $taxes ?? null, 'required' => true, 'class' => 'form-control-sm'])
</div> </div>
<div class="col-3"> <div class="col-2">
{{ Form::label('price', 'Prix HT') }} {{ Form::label('price', 'Prix HT') }}
@include('components.money', ['name' => 'prices[0][price]', 'value' => $price ?? 0, 'required' => true, 'class' => 'form-control-sm price-item']) @include('components.money', ['name' => 'prices[0][price]', 'value' => $price ?? 0, 'required' => true, 'class' => 'form-control-sm price-item'])
</div> </div>
<div class="col-3"> <div class="col-2">
{{ Form::label('price_taxed', 'Prix TTC') }} {{ Form::label('price_taxed', 'Prix TTC') }}
@include('components.money', ['name' => 'prices[0][price_taxed]', 'value' => $price_taxed ?? 0, 'required' => true, 'class' => 'form-control-sm price-taxed-item']) @include('components.money', ['name' => 'prices[0][price_taxed]', 'value' => $price_taxed ?? 0, 'required' => true, 'class' => 'form-control-sm price-taxed-item'])
</div> </div>

View File

@@ -0,0 +1,23 @@
<table class="table table-bordered table-hover table-striped w-100 mb-0 dataTable">
<thead>
<th>
{{ $generic['category']['name'] ?? null }}
</th>
@foreach ($generic['prices'] as $price)
<th>
{{ $price['quantity'] ?? null }} {{ $price['unity_id'] ?? null }}
</th>
@endforeach
</thead>
<tr>
<td>
{{ $generic['name'] ?? null }}
</td>
@foreach ($generic['prices'] as $price)
<td>
{{ $price['price_taxed'] ?? null }}
</td>
@endforeach
</tr>
</table>

View File

@@ -0,0 +1,28 @@
@extends('layout.index', [
'title' => __('article_attributes.title'),
'subtitle' => __('article_attributes.create.title'),
'breadcrumb' => [__('article_attributes.title'), __('article_attributes.create.title')]
])
@include('boilerplate::load.fileinput')
@section('content')
{{ Form::open(['route' => 'Shop.Admin.ArticleAttributes.store', 'id' => 'article-attribute-form', 'autocomplete' => 'off', 'files' => true]) }}
<div class="row">
<div class="col-sm-12 mbl">
<a href="{{ route("Shop.Admin.ArticleAttributes.index") }}" class="btn btn-default">
{{ __('article_attributes.list.title') }}
</a>
<span class="btn-group pull-right">
@include('components.button-save')
</span>
</div>
</div>
@include('Shop.Admin.ArticleAttributeValues.form')
</form>
@endsection

View File

@@ -0,0 +1,29 @@
@extends('layout.index', [
'title' => 'Attributs d\'articles',
'subtitle' => 'Edition d\'un attribut d\'article',
'breadcrumb' => ['Articles']
])
@include('boilerplate::load.fileinput')
@section('content')
{{ Form::open(['route' => 'Shop.Admin.ArticleAttributeValues.update', 'id' => 'article-attribute-form', 'autocomplete' => 'off', 'files' => true]) }}
<div class="row">
<div class="col-sm-12 mbl">
<a href="{{ route("Shop.Admin.ArticleAttributeValues.index") }}" class="btn btn-default">
{{ __('article_attributes.list.title') }}
</a>
<span class="btn-group pull-right">
@include('components.button-save')
</span>
</div>
</div>
<input type="hidden" name="id" value="{{ $id }}">
@include('Shop.Admin.ArticleAttributeValues.form')
</form>
@endsection

View File

@@ -0,0 +1,48 @@
@extends('layout.index', [
'title' => __('Shop.unities.title'),
'subtitle' => __('Shop.unities.list'),
'breadcrumb' => [__('Shop.unities.title')]
])
@include('boilerplate::load.select2')
@section('content')
<nav>
<div class="nav nav-tabs">
<a href="#families" data-toggle="tab" class="nav-item nav-link" role="tab" aria-controls="families" aria-selected="true">
{{ __('Shop.unities.title') }}
</a>
<a href="#values" data-toggle="tab" class="nav-item nav-link active" role="tab" aria-controls="values" aria-selected="false">
{{ __('Shop.unities.title') }}
</a>
</div>
</nav>
<div class="tab-content mb-0">
<div class="tab-pane fade" id="families">
@section('content')
@include('components.datatable', ['route' => route('Shop.Admin.Unities.index'), 'model' => 'ArticleAttributefamilies'])
@endsection
</div>
<div class="tab-pane fade show active" id="values">
@section('content')
@component('components.card')
@include('components.datatable', ['route' => route('Shop.Admin.ArticleAttributeValues.index'), 'model' => 'Unities'])
@endcomponent
@component('components.layout.modal', ['title' => 'Filtres', 'id' => 'modal-filters'])
@include('Shop.Admin.Unities.partials.filters')
@endcomponent
@endsection
</div>
</div>
@endsection
@push('scripts')
@include('components.js.datatable', ['route' => route('Shop.Admin.Unities.index'), 'model' => 'Unities'])
@endpush

View File

@@ -0,0 +1,16 @@
@extends('layout.index', [
'title' => __('Shop.article_attribute_values.title'),
'subtitle' => __('Shop.article_attribute_values.list'),
'breadcrumb' => [__('Shop.article_attribute_values.title')]
])
@section('content')
@component('components.card')
@include('components.datatable', ['route' => route('Shop.Admin.ArticleAttributeValues.index'), 'model' => 'ArticleAttributeValues'])
@endcomponent
@component('components.layout.modal', ['title' => 'Filtres', 'id' => 'modal-filters'])
@include('Shop.Admin.ArticleAttributeValues.partials.filters')
@endcomponent
@endsection

View File

@@ -0,0 +1,9 @@
<form id="filters">
<div class="row">
<label class="col-4">Familles d'attributs</label>
<div class="col-8">
@include('components.select', ['name' => 'article_attribute_family_id', 'list' => (isset($families)) ? $families : [], 'value' => (isset($filters['article_attribute_family_id'])) ? $filters['article_attribute_family_id'] : null, 'class' => 'form-control-sm select2', 'with_empty' => ' '])
</div>
</div>
</form>

View File

@@ -4,7 +4,6 @@
]) ])
@section('content') @section('content')
@component('auth.loginbox')
{!! Form::open(['route' => 'boilerplate.login', 'method' => 'post', 'autocomplete'=> 'off']) !!} {!! Form::open(['route' => 'boilerplate.login', 'method' => 'post', 'autocomplete'=> 'off']) !!}
<div class="form-group has-feedback"> <div class="form-group has-feedback">
<div class="form-group {{ $errors->has('email') ? 'has-error' : '' }}"> <div class="form-group {{ $errors->has('email') ? 'has-error' : '' }}">
@@ -38,5 +37,4 @@
@if(config('boilerplate.auth.register')) @if(config('boilerplate.auth.register'))
<a href="{{ route('boilerplate.register') }}" class="text-center">{{ __('boilerplate::auth.login.register') }}</a> <a href="{{ route('boilerplate.register') }}" class="text-center">{{ __('boilerplate::auth.login.register') }}</a>
@endif @endif
@endcomponent
@endsection @endsection

View File

@@ -0,0 +1,4 @@
<button type="{{ $type ?? 'button' }}" class="btn {{ $class ?? ''}}" @if (isset($id)) id="{{ $id }}"@endif>
<i class="fa fa-fw {{ $icon ?? '' }}"></i>
{{ $txt ?? '' }}
</button>

View File

@@ -1,4 +1,4 @@
<div class="card mb-0 {{ isset($tabs) ? ($outline ?? config('boilerplate.theme.card.outline', false)) ? 'card-outline-tabs' : 'card-tabs' : ''}} {{ ($outline ?? config('boilerplate.theme.card.outline', false)) ? 'card-outline' : '' }} card-{{ $color ?? config('boilerplate.theme.card.default_color', 'info') }}"> <div class="card {{ $class ?? 'mb-0' }} {{ isset($tabs) ? ($outline ?? config('boilerplate.theme.card.outline', false)) ? 'card-outline-tabs' : 'card-tabs' : ''}} {{ ($outline ?? config('boilerplate.theme.card.outline', false)) ? 'card-outline' : '' }} card-{{ $color ?? config('boilerplate.theme.card.default_color', 'info') }}">
@if($title ?? $header ?? false) @if($title ?? $header ?? false)
<div class="card-header {{ isset($tabs) ? ($outline ?? config('boilerplate.theme.card.outline', false)) ? 'p-0' : 'p-0 pt-1' : '' }} border-bottom-0"> <div class="card-header {{ isset($tabs) ? ($outline ?? config('boilerplate.theme.card.outline', false)) ? 'p-0' : 'p-0 pt-1' : '' }} border-bottom-0">
@isset($header) @isset($header)
@@ -13,7 +13,7 @@
@endisset @endisset
</div> </div>
@endif @endif
<div class="card-body {{ $title ?? false ? ($outline ?? config('boilerplate.theme.card.outline', false)) ? 'pt-0' : '' : '' }}"> <div class="card-body {{ $title ?? false ? ($outline ?? config('boilerplate.theme.card.outline', false)) ? 'pt-0' : '' : '' }} {{ $class_body ?? '' }}">
{{ $slot }} {{ $slot }}
</div> </div>
@isset($footer) @isset($footer)

View File

@@ -0,0 +1,4 @@
@include('load.autocomplete')
<input type="hidden" name="{{ $name }}_id" id="{{ $name }}_id" value="{{ $data['id'] ?? null }}">
<input type="text" name="{{ $name }}_name" class="form-control autocomplete" value="{{ $data['name'] ?? ''}}" data-url="{{ $url ?? ''}}" data-field="{{ $name }}_id" autocomplete="off">

View File

@@ -0,0 +1,3 @@
<input type="checkbox" name="{{ $name }}" id="{{ $id_name ?? $name }}" class="{{ $class ?? ''}}" value="{{ $val ?? ''}}"
@if (isset($value) && isset($val) && ($value == $val)) checked @endif
>

View File

@@ -0,0 +1,4 @@
@include('load.form.color')
@include('components.input', ['class' => 'color'])

View File

@@ -0,0 +1,8 @@
@include('load.datepicker')
<div class="input-group date" data-target-input="nearest">
@include('components.input', ['class' => 'datepicker', 'meta' => 'data-target="#'.str_slug($name).'"', 'placeholder' => App\Repositories\Core\DateTime::getLocaleFormatDate() ])
<div class="input-group-append" data-target="#{{ str_slug($name) }}" data-toggle="datetimepicker">
<div class="input-group-text"><i class="fa fa-calendar"></i></div>
</div>
</div>

View File

@@ -0,0 +1,13 @@
@include('components.input', ['class' => 'datetimepicker'])
@if(!defined('LOAD_DATETIMEPICKER'))
@include('boilerplate::load.datetimepicker')
@push('js')
<script>
$(function() {
$('.datetimepicker').datetimepicker({});
});
</script>
@endpush
@endif

View File

@@ -0,0 +1,19 @@
<textarea
name="{{ $name }}"
@if (isset($id_name))id="{{ $id_name }}"@endif
class="editor form-control @if (isset($class)){{ $class }}@endif"
@if (isset($rows)) rows="{{ $rows }}"@endif
>@if (isset($value)){{ $value }}@endif</textarea>
@if(!defined('LOAD_EDITOR'))
@include('load.editor')
@push('js')
<script>
$(function() {
initEditor();
});
</script>
@endpush
@endif

View File

@@ -0,0 +1,13 @@
<div class="input-group">
@include('components.input')
<div class="input-group-append">
<button class="btn btn-outline-secondary">
<i class="fa fa-unlock"></i>
</button>
<button class="btn btn-outline-secondary">
<i class="fa fa-sync-alt"></i>
</button>
</div>
</div>

View File

@@ -0,0 +1,10 @@
<div class="input-group">
@include('components.input', ['type' => 'number', 'meta' => "step = '.01'"])
<div class="input-group-append">
<button class="btn btn-outline-secondary" type="button" aria-haspopup="true" aria-expanded="false">
%
</button>
</div>
</div>

View File

@@ -0,0 +1,12 @@
<div class="form-group clearfix pt-2">
@foreach ($list as $key => $item)
<div class="{{ $item['class'] ?? '' }} d-inline">
<input type="radio" id="{{ $name }}{{ $key }}" name="{{ $name }}" value="{{ $key }}" @if (isset($value) && ($key == $value)) checked @endif>
@if ($with_label ?? true)
<label for="{{ $name }}{{ $key}}" class="pr-2">{{ $item['txt'] ?? $item }}</label>
@else
<label for="{{ $name }}{{ $key}}"></label>
@endif
</div>
@endforeach
</div>

View File

@@ -0,0 +1 @@
@include('components.select', ['class' => 'duallist', 'multiple' => true])

View File

@@ -0,0 +1,19 @@
<select
name="{{ $name }}"
@if (isset($id_name))id="{{ $id_name }}"@endif
class="form-control @if (isset($class)){{ $class }} @endif"
@if (isset($style))style="{{ $style }}" @endif
@if (isset($required))required="required"@endif
@if (isset($multiple))multiple="multiple"@endif
>
@if (isset($with_empty))
<option value=''>{{ $with_empty }}</option>
@endif
@include('components.options')
</select>
@if(!defined('LOAD_SELECT2'))
@include('load.select2')
@endif

View File

@@ -0,0 +1,3 @@
<input type="checkbox" name="{{ $name ?? ''}}" id="{{ $id_name ?? $name ?? '' }}" class="{{ $class ?? 'toggle'}}" value="{{ $val ?? 1}}" data-toggle="toggle" data-on="{{ $on ?? __('yes') }}" data-off="{{ $off ?? __('no') }}" data-onstyle="{{ $onstyle ?? 'outline-success'}}" data-offstyle="{{ $offstyle ?? 'outline-danger'}}" data-size="{{ $size ?? 'sm' }}" @if ( (isset($value) && isset($val) && ($value == $val)) || (!isset($val) && isset($value) && $value)) checked @endif {{ $disabled ?? ''}} {{ $meta ?? ''}} >
@include('load.toggle')

View File

@@ -0,0 +1 @@
@include('components.form.toggle')

View File

@@ -0,0 +1,11 @@
<div class="input-group">
@include('components.input', ['class' => 'url'])
<div class="input-group-append">
@if (isset($with_download) && $with_download)
<div class="input-group-text btn btn-web" role="button"><i class="fa {{ (isset($status) && $status) ? 'fa-check green' : 'fa-download' }}"></i></div>
@endif
@if (isset($with_web) && $with_web)
<div class="input-group-text btn btn-web" role="button"><i class="fa fa-search"></i></div>
@endif
</div>
</div>

View File

@@ -1,12 +1,25 @@
<div class="card"> <div class="card {{ $class ?? '' }}">
<div class="card-header p-0"> <div class="card-header p-0">
<button class="btn btn-link pull-right collapsed" type="button" data-toggle="collapse" data-target="#{{ $id }}" aria-expanded="true" aria-controls="collapseOne"> <div class="row">
<i class="fa fa-plus"></i> <div class="col-6">
</button> <button class="btn btn-link collapsed" type="button" data-toggle="collapse" data-target="#{{ $id }}" aria-expanded="false" aria-controls="{{ $id }}">
{{ $title }} @if(isset($required) && $required)<sup>*</sup>@endif <i class="fa fa-chevron-right"></i>
<span class="check ml-5 error"></span> </button>
{!! $title !!}
@if (isset($required) && $required)
<sup>*</sup>
@endif
{!! $collapse_left ?? '' !!}
<span class="check ml-5 error"></span>
</div>
<div class="col-6">
{!! $collapse_right ?? '' !!}
</div>
</div>
</div> </div>
<div id="{{ $id }}" class="card-body collapse"> <div id="{{ $id }}" class="card-body collapse {{ $class_body ?? '' }}">
{{ $slot }} {{ $slot }}
</div> </div>
</div> </div>

View File

@@ -0,0 +1,20 @@
<div class="modal fade" id="{{ $id }}" tabindex="-1" role="dialog" aria-labelledby="{{ $id }}" aria-hidden="true">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title">{{ $title }}</h5>
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<div class="modal-body">
{{ $slot }}
</div>
<div class="modal-footer">
<button type="button" class="btn bg-yellow reset">{{ __('reset') }}</button>
<button type="button" class="btn btn-secondary" data-dismiss="modal">{{ __('close') }}</button>
<button type="button" class="btn bg-primary apply">{{ __('apply') }}</button>
</div>
</div>
</div>
</div>

View File

@@ -11,6 +11,9 @@
{{ $slot }} {{ $slot }}
</div> </div>
<div class="modal-footer"> <div class="modal-footer">
@if (isset($buttons))
{{ $buttons }}
@endif
<button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button> <button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button>
<button type="button" class="btn btn-info apply">Apply</button> <button type="button" class="btn btn-info apply">Apply</button>
</div> </div>

View File

@@ -1,4 +0,0 @@
<?php
Route::resource('ArticleAttributeFamilies', 'ArticleAttributeFamilyController');

View File

@@ -1,7 +0,0 @@
<?php
Route::resource('ArticleAttributeValues', 'ArticleAttributeValueController');
Route::prefix('ArticleAttributeValues')->name('ArticleAttributeValues.')->group(function () {
Route::post('getOptionsByFamily', 'ArticleAttributeValueController@getOptionsByFamily')->name('getOptionsByFamily');
});

View File

@@ -1,7 +1,7 @@
<?php <?php
Route::resource('PriceFamilyValues', 'PriceFamilyValueController');
Route::prefix('PriceFamilyValues')->name('PriceFamilyValues.')->group(function () { Route::prefix('PriceFamilyValues')->name('PriceFamilyValues.')->group(function () {
Route::post('getOptionsByFamily', 'PriceFamilyValueController@getOptionsByFamily')->name('getOptionsByFamily'); Route::any('getOptionsByFamily', 'PriceFamilyValueController@getOptionsByFamily')->name('getOptionsByFamily');
}); });
Route::resource('PriceFamilyValues', 'PriceFamilyValueController');

View File

@@ -2,9 +2,6 @@
Route::middleware('auth')->prefix('Admin')->namespace('Admin')->name('Admin.')->group(function () { Route::middleware('auth')->prefix('Admin')->namespace('Admin')->name('Admin.')->group(function () {
Route::get('dashboard', 'DashboardController@index')->name('dashboard'); Route::get('dashboard', 'DashboardController@index')->name('dashboard');
include __DIR__ . '/ArticleAttributeFamilies.php';
include __DIR__ . '/ArticleAttributeValues.php';
include __DIR__ . '/ArticleAttributes.php';
include __DIR__ . '/ArticleFamilies.php'; include __DIR__ . '/ArticleFamilies.php';
include __DIR__ . '/ArticlePrices.php'; include __DIR__ . '/ArticlePrices.php';
include __DIR__ . '/Articles.php'; include __DIR__ . '/Articles.php';