Merge branch '3.2.1' into 'master'

3.2.1

See merge request TheGamecraft/c-cms!46
This commit is contained in:
Mathieu Lagace
2019-08-28 14:04:52 +00:00
21 changed files with 653 additions and 146 deletions

View File

@@ -53,6 +53,38 @@ deploy_736:
only: only:
- master - master
deploy_227:
stage: deploy
script:
- 'which ssh-agent || ( apt-get update -y && apt-get install openssh-client -y )'
- eval $(ssh-agent -s)
- ssh-add <(echo "$SSH_PRIVATE_KEY")
- mkdir -p ~/.ssh
- '[[ -f /.dockerenv ]] && echo -e "Host *\n\tStrictHostKeyChecking no\n\n" > ~/.ssh/config'
- ~/.composer/vendor/bin/envoy run deploy_227 --commit="$CI_COMMIT_SHA"
environment:
name: CCMRC227
url: http://227.exvps.ca
only:
- master
deploy_117:
stage: deploy
script:
- 'which ssh-agent || ( apt-get update -y && apt-get install openssh-client -y )'
- eval $(ssh-agent -s)
- ssh-add <(echo "$SSH_PRIVATE_KEY")
- mkdir -p ~/.ssh
- '[[ -f /.dockerenv ]] && echo -e "Host *\n\tStrictHostKeyChecking no\n\n" > ~/.ssh/config'
- ~/.composer/vendor/bin/envoy run deploy_117 --commit="$CI_COMMIT_SHA"
environment:
name: CCMRC117
url: http://117.exvps.ca
only:
- master
deploy_dev: deploy_dev:
stage: deploy stage: deploy
script: script:

View File

@@ -15,6 +15,14 @@
$releases_dir_dev = '/var/www/c-cms/dev/releases'; $releases_dir_dev = '/var/www/c-cms/dev/releases';
$app_dir_dev = '/var/www/c-cms/dev'; $app_dir_dev = '/var/www/c-cms/dev';
$new_release_dir_dev = $releases_dir_dev .'/'. $release; $new_release_dir_dev = $releases_dir_dev .'/'. $release;
$releases_dir_227 = '/var/www/c-cms/ccmrc227/releases';
$app_dir_227 = '/var/www/c-cms/ccmrc227';
$new_release_dir_227 = $releases_dir_227 .'/'. $release;
$releases_dir_117 = '/var/www/c-cms/ccmrc117/releases';
$app_dir_117 = '/var/www/c-cms/ccmrc117';
$new_release_dir_117 = $releases_dir_117 .'/'. $release;
@endsetup @endsetup
@story('deploy_697') @story('deploy_697')
@@ -35,6 +43,18 @@
update_symlinks_dev update_symlinks_dev
@endstory @endstory
@story('deploy_227')
clone_repository_227
run_composer_227
update_symlinks_227
@endstory
@story('deploy_177')
clone_repository_117
run_composer_117
update_symlinks_117
@endstory
@task('clone_repository_697') @task('clone_repository_697')
echo 'Cloning repository' echo 'Cloning repository'
[ -d {{ $releases_dir_697 }} ] || mkdir {{ $releases_dir_697 }} [ -d {{ $releases_dir_697 }} ] || mkdir {{ $releases_dir_697 }}
@@ -138,4 +158,74 @@
php artisan migrate php artisan migrate
php artisan db:seed --class=ConfigsTableSeeder php artisan db:seed --class=ConfigsTableSeeder
@endtask
@task('clone_repository_227')
echo 'Cloning repository'
[ -d {{ $releases_dir_227 }} ] || mkdir {{ $releases_dir_227 }}
git clone --depth 1 --single-branch -b dev {{ $repository }} {{ $new_release_dir_227 }}
cd {{ $new_release_dir_227 }}
git reset --hard {{ $commit }}
@endtask
@task('run_composer_227')
echo "Starting deployment ({{ $release }})"
cd {{ $new_release_dir_227 }}
composer install --prefer-dist --no-scripts -q -o
@endtask
@task('update_symlinks_227')
echo "Linking storage directory"
rm -rf {{ $new_release_dir_227 }}/storage
ln -nfs {{ $app_dir_227 }}/storage {{ $new_release_dir_227 }}/storage
echo 'Linking .env file'
ln -nfs {{ $app_dir_227 }}/.env {{ $new_release_dir_227 }}/.env
echo 'Linking current release'
ln -nfs {{ $new_release_dir_227 }} {{ $app_dir_227 }}/current
echo 'Setting permission'
chmod -R 777 {{ $app_dir_227 }}/current/bootstrap/
echo 'Migrate DB'
cd {{ $app_dir_227 }}/current/
php artisan migrate
php artisan db:seed --class=ConfigsTableSeeder
@endtask
@task('clone_repository_117')
echo 'Cloning repository'
[ -d {{ $releases_dir_117 }} ] || mkdir {{ $releases_dir_117 }}
git clone --depth 1 --single-branch -b dev {{ $repository }} {{ $new_release_dir_117 }}
cd {{ $new_release_dir_117 }}
git reset --hard {{ $commit }}
@endtask
@task('run_composer_117')
echo "Starting deployment ({{ $release }})"
cd {{ $new_release_dir_117 }}
composer install --prefer-dist --no-scripts -q -o
@endtask
@task('update_symlinks_117')
echo "Linking storage directory"
rm -rf {{ $new_release_dir_117 }}/storage
ln -nfs {{ $app_dir_117 }}/storage {{ $new_release_dir_117 }}/storage
echo 'Linking .env file'
ln -nfs {{ $app_dir_117 }}/.env {{ $new_release_dir_117 }}/.env
echo 'Linking current release'
ln -nfs {{ $new_release_dir_117 }} {{ $app_dir_117 }}/current
echo 'Setting permission'
chmod -R 777 {{ $app_dir_117 }}/current/bootstrap/
echo 'Migrate DB'
cd {{ $app_dir_117 }}/current/
php artisan migrate
php artisan db:seed --class=ConfigsTableSeeder
@endtask @endtask

View File

@@ -17,6 +17,28 @@ class ConfigController extends Controller
return view ('admin.configs.general',['configs' => Config::all()]); return view ('admin.configs.general',['configs' => Config::all()]);
} }
public function customisation()
{
return view ('admin.configs.perso',['configs' => Config::all()]);
}
public function customisationUpdate()
{
$configs = [
'public_index_img_url'
];
foreach ($configs as $config) {
$c = \App\Config::all()->where('name',$config)->first();
$c->data = [request($config)];
$c->save();
}
\App\Log::saveLog('Modification de la configuration du site');
return redirect('/admin/config/customisation')->with('success','Modification sauvegarder avec succès !');
}
/** /**
* Show the form for creating a new resource. * Show the form for creating a new resource.
* *

View File

@@ -139,6 +139,17 @@ class EventController extends Controller
$course = new \App\Course(); $course = new \App\Course();
foreach ($event->courses as $c)
{
if ($c->periode == $p)
{
if ($c->level == $l)
{
$course = $c;
}
}
}
$users = \App\User::all(); $users = \App\User::all();
$instructor = 1; $instructor = 1;

View File

@@ -0,0 +1,85 @@
<?php
namespace App\Http\Controllers;
use App\ItemCategory;
use Illuminate\Http\Request;
class ItemCategoryController extends Controller
{
/**
* Display a listing of the resource.
*
* @return \Illuminate\Http\Response
*/
public function index()
{
//
}
/**
* Show the form for creating a new resource.
*
* @return \Illuminate\Http\Response
*/
public function create()
{
//
}
/**
* Store a newly created resource in storage.
*
* @param \Illuminate\Http\Request $request
* @return \Illuminate\Http\Response
*/
public function store(Request $request)
{
//
}
/**
* Display the specified resource.
*
* @param \App\ItemCategory $itemCategory
* @return \Illuminate\Http\Response
*/
public function show(ItemCategory $itemCategory)
{
//
}
/**
* Show the form for editing the specified resource.
*
* @param \App\ItemCategory $itemCategory
* @return \Illuminate\Http\Response
*/
public function edit(ItemCategory $itemCategory)
{
//
}
/**
* Update the specified resource in storage.
*
* @param \Illuminate\Http\Request $request
* @param \App\ItemCategory $itemCategory
* @return \Illuminate\Http\Response
*/
public function update(Request $request, ItemCategory $itemCategory)
{
//
}
/**
* Remove the specified resource from storage.
*
* @param \App\ItemCategory $itemCategory
* @return \Illuminate\Http\Response
*/
public function destroy(ItemCategory $itemCategory)
{
//
}
}

View File

@@ -24,7 +24,7 @@ class ItemController extends Controller
*/ */
public function create() public function create()
{ {
return view('admin.item.add'); return view('admin.item.add',['categories' => \App\ItemCategory::all()]);
} }
/** /**
@@ -33,17 +33,20 @@ class ItemController extends Controller
* @param \Illuminate\Http\Request $request * @param \Illuminate\Http\Request $request
* @return \Illuminate\Http\Response * @return \Illuminate\Http\Response
*/ */
public function store(Request $request) public function store()
{ {
$item = new Item; $item = new Item;
$item->name = request('name'); $item->name = request('name');
$item->desc = request('desc'); $item->desc = request('desc');
$item->quantiy = request('qt'); $item->quantity = request('quantity');
$item->official_number = request('official_number');
$item->metadata = ['size' => request('metadata-size')];
$item->category_id = request('category_id');
$item->save(); $item->save();
return redirect('/admin/inventory'); return redirect('/admin/inventory')->with('success','Item sauvegardé avec succès');
} }
/** /**
@@ -67,7 +70,7 @@ class ItemController extends Controller
{ {
$item = Item::find($id); $item = Item::find($id);
return view('admin.item.edit',['item' => $item]); return view('admin.item.edit',['item' => $item,'categories' => \App\ItemCategory::all()]);
} }
/** /**
@@ -83,11 +86,14 @@ class ItemController extends Controller
$item->name = request('name'); $item->name = request('name');
$item->desc = request('desc'); $item->desc = request('desc');
$item->quantity = request('qt'); $item->quantity = request('quantity');
$item->official_number = request('official_number');
$item->metadata = ['size' => request('metadata-size')];
$item->category_id = request('category_id');
$item->save(); $item->save();
return redirect('/admin/inventory'); return redirect('/admin/inventory')->with('success','Item sauvegardé avec succès');
} }
/** /**

View File

@@ -113,9 +113,9 @@ class UserController extends Controller
* @param int $id * @param int $id
* @return \Illuminate\Http\Response * @return \Illuminate\Http\Response
*/ */
public function update(Request $request) public function update($id)
{ {
$user = User::where('email', request('email'))->first(); $user = User::find($id);
$user->firstname = request('firstname'); $user->firstname = request('firstname');
$user->lastname = request('lastname'); $user->lastname = request('lastname');

View File

@@ -18,8 +18,17 @@ class Item extends Model
return $col_items; return $col_items;
} }
protected $casts = [
'metadata' => 'array',
];
public function bookings() public function bookings()
{ {
return $this->hasMany('App\Booking'); return $this->hasMany('App\Booking');
} }
public function category()
{
return \App\ItemCategory::find($this->category_id);
}
} }

13
app/ItemCategory.php Normal file
View File

@@ -0,0 +1,13 @@
<?php
namespace App;
use Illuminate\Database\Eloquent\Model;
class ItemCategory extends Model
{
public function items()
{
return $this->hasMany('App\Item','category_id');
}
}

View File

@@ -15,9 +15,12 @@ class CreateItemsTable extends Migration
{ {
Schema::create('items', function (Blueprint $table) { Schema::create('items', function (Blueprint $table) {
$table->increments('id'); $table->increments('id');
$table->integer('category_id');
$table->integer('quantity'); $table->integer('quantity');
$table->string('name'); $table->string('name');
$table->string('official_number');
$table->string('desc'); $table->string('desc');
$table->text('metadata');
$table->timestamps(); $table->timestamps();
}); });
} }

View File

@@ -15,7 +15,7 @@ class CreatePicturesTable extends Migration
{ {
Schema::create('pictures', function (Blueprint $table) { Schema::create('pictures', function (Blueprint $table) {
$table->increments('id'); $table->increments('id');
$table->string('url'); $table->text('url');
$table->string('title'); $table->string('title');
$table->text('desc'); $table->text('desc');
$table->integer('pictureable_id'); $table->integer('pictureable_id');

View File

@@ -0,0 +1,35 @@
<?php
use Illuminate\Support\Facades\Schema;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;
class CreateItemCategoriesTable extends Migration
{
/**
* Run the migrations.
*
* @return void
*/
public function up()
{
Schema::create('item_categories', function (Blueprint $table) {
$table->increments('id');
$table->string('name');
$table->text('desc');
$table->boolean('is_training');
$table->boolean('is_op_appro');
$table->timestamps();
});
}
/**
* Reverse the migrations.
*
* @return void
*/
public function down()
{
Schema::dropIfExists('item_categories');
}
}

View File

@@ -100,6 +100,8 @@
<small id="emailHelp" class="form-text text-muted">Email du CC. Laisser vide si aucun</small> <small id="emailHelp" class="form-text text-muted">Email du CC. Laisser vide si aucun</small>
</div> </div>
</div> </div>
</div>
<div class="ml-2 row">
<div class="col-md-6 p-2"> <div class="col-md-6 p-2">
<div class="form-check"> <div class="form-check">
<label class="form-check-label"> <label class="form-check-label">

View File

@@ -0,0 +1,69 @@
@extends('layouts.admin.main')
@section('content')
<div class="col-md-12">
<div class="card">
<div class="card-header card-header-primary">
<h4>Configuration Générale</h4>
</div>
<div class="card-body mt-5">
<form action="/admin/config/customisation" method="POST">
@csrf
<div class="row ml-2">
<div class="col-md-6 p-2">
<div class="form-group">
<label for="exampleInputEmail1">Photo page publique</label>
<input type="text" class="form-control" id="escadron_name_full" name="public_index_img_url" aria-describedby="emailHelp" value="{{\App\Config::getData('public_index_img_url')}}">
<small id="emailHelp" class="form-text text-muted">URL vers la photo a afficher dans l'en tête de la page publique.</small>
</div>
</div>
<div class="col-md-12 p-2">
<button type="submit" class="btn btn-primary">Sauvegarder</button>
</div>
</div>
</form>
</div>
</div>
</div>
@endsection
@section('breadcrumb')
<div class="breadcrumbs">
<div class="col-sm-4">
<div class="page-header float-left">
<div class="page-title">
<h1>Configuration Générale</h1>
</div>
</div>
</div>
<div class="col-sm-8">
<div class="page-header float-right">
<div class="page-title">
<ol class="breadcrumb text-right">
<li class="active">Configuration/Générale</li>
</ol>
</div>
</div>
</div>
</div>
@endsection
@section('custom_scripts')
<script>
function saveChange(pPerm) {
(function($) {
var myswitch = document.getElementById(pPerm);
$.post('/api/config/general/save?api_token='+api_token, { value: myswitch.checked,perm: pPerm } , function(data) {
swal({
title: 'Modification enregistré !',
type: 'success',
}).then((result) => {
if (result.value) {
location.reload();
}
})
});
})(jQuery);
}
</script>
@endsection

View File

@@ -0,0 +1,86 @@
@extends('layouts.admin.main')
@section('content')
<div class="col-md-12">
<div class="card">
<div class="card-header card-header-primary">
<h4>Ajouter un item à l'inventaire</h4>
</div>
<div class="card-body mt-5">
<form action="/admin/item/add" method="post">
@csrf
<div class="row">
<div class="col-md-6">
<div class="form-group">
<label>Numéro d'article</label>
<input name="official_number" type="text" class="form-control" required>
</div>
</div>
<div class="col-md-6">
<div class="form-group">
<label>Nom de l'article</label>
<input name="name" type="text" class="form-control" required>
</div>
</div>
<div class="col-md-6">
<div class="form-group">
<label>Taille de l'article</label>
<input name="metadata-size" type="text" class="form-control" required>
</div>
</div>
<div class="col-md-6">
<div class="form-group">
<label>Quantité disponible</label>
<input name="quantity" type="number" class="form-control" required>
</div>
</div>
<div class="col-md-6">
<div class="form-group">
<label>Catégorie</label>
<select name="category_id" class="form-control selectpicker" required>
@foreach($categories as $category)
<option value="{{$category->id}}">{{$category->name}}</option>
@endforeach
</select>
</div>
</div>
<div class="col-lg-12 mt-4">
<label for="desc">Description de l'image</label>
<div class="form-group">
<textarea name="desc" id="desc" class="form-control" required></textarea>
</div>
</div>
<div class="col-lg-12">
<button type="submit" class="btn btn-primary">Sauvegarder</button>
</div>
</div>
</form>
</div>
</div>
</div>
@endsection
@section('custom_scripts')
<script>
$('#desc').trumbowyg({
lang: 'fr'
});
function saveChange(pPerm) {
(function($) {
var myswitch = document.getElementById(pPerm);
$.post('/api/config/general/save?api_token='+api_token, { value: myswitch.checked,perm: pPerm } , function(data) {
swal({
title: 'Modification enregistré !',
type: 'success',
}).then((result) => {
if (result.value) {
location.reload();
}
})
});
})(jQuery);
}
</script>
@endsection

View File

@@ -13,19 +13,26 @@
<table id="log-data" class="table table-striped table-bordered"> <table id="log-data" class="table table-striped table-bordered">
<thead> <thead>
<tr> <tr>
<th>Quantité</th> <th>#</th>
<th>Nom</th> <th>Nom</th>
<th>Categorie</th>
<th>Description</th> <th>Description</th>
<th></th> <th>Action</th>
</tr> </tr>
</thead> </thead>
<tbody> <tbody>
@foreach ($items as $item) @foreach ($items as $item)
<tr> <tr>
<td style="width:5%;">{{$item->quantity}}</td> <td>{{$item->official_number}}</td>
<td>{{$item->name}}</td> <td>{{$item->name}}</td>
<td>{{$item->desc}}</td> <td>{{$item->category()->name}}</td>
<td style="width: 12%;"><a href="/admin/item/edit/{{$item->id}}" type="button" class="btn btn-secondary"><i class="fa fa-cog"></i>&nbsp; Modifier</a><a type="button" class="btn btn-danger" onclick="deleteEvent({{$item->id}});"><i class="fa fa-times-circle" style="color:white;"></i></a></td> <td>{!! $item->desc !!}</td>
<td style="width: 12%;">
<div class="btn-group">
<a href="/admin/item/edit/{{$item->id}}" type="button" class="btn btn-secondary"><i class="fa fa-cog"></i>&nbsp; Modifier</a>
<a type="button" class="btn btn-danger" onclick="deleteEvent({{$item->id}});"><i class="fa fa-times-circle" style="color:white;"></i></a>
</div>
</td>
</tr> </tr>
@endforeach @endforeach
@@ -58,13 +65,16 @@
@endsection @endsection
@section('custom_scripts') @section('custom_scripts')
<script src="https://cdn.datatables.net/rowgroup/1.1.0/js/dataTables.rowGroup.min.js"></script>
<script type="text/javascript"> <script type="text/javascript">
(function($) { (function($) {
$(document).ready(function() { $(document).ready(function() {
$('#log-data').DataTable({ $('#log-data').DataTable({
"order": [[ 0, "desc" ]], "order": [[ 2, "asc" ]],
"lengthMenu": [[25, 50, -1], [25, 50, "All"]], "lengthMenu": [[25, 50, -1], [25, 50, "All"]],
"rowGroup": {
dataSrc: 2
}
}); });
} ); } );
})(jQuery); })(jQuery);

View File

@@ -1,73 +1,86 @@
@extends('layouts.admin.main') @extends('layouts.admin.main')
@section('content') @section('content')
<div class="col-md-12"> <div class="col-md-12">
<div class="card"> <div class="card">
<div class="card-header"> <div class="card-header card-header-primary">
<strong class="card-title">Ajouter un item dans l'inventaire</strong> <h4>Ajouter un item à l'inventaire</h4>
</div> </div>
<div class="card-body"> <div class="card-body mt-5">
<form action="/admin/item/add" method="post"> <form action="/admin/item/add" method="post">
@csrf
<div class="row"> @csrf
<div class="col-12"> <div class="row">
<div class="form-group"> <div class="col-md-6">
<label for="name">Nom</label> <div class="form-group">
<input type="text" class="form-control" name="name" id="name" aria-describedby="helpname" placeholder="Projecteur" required> <label>Numéro d'article</label>
<small id="helpname" class="form-text text-muted">Nom</small> <input name="official_number" type="text" class="form-control" required>
</div>
</div>
<div class="col-md-6">
<div class="form-group">
<label>Nom de l'article</label>
<input name="name" type="text" class="form-control" required>
</div>
</div>
<div class="col-md-6">
<div class="form-group">
<label>Taille de l'article</label>
<input name="metadata-size" type="text" class="form-control" required>
</div>
</div>
<div class="col-md-6">
<div class="form-group">
<label>Quantité disponible</label>
<input name="quantity" type="number" class="form-control" required>
</div>
</div>
<div class="col-md-6">
<div class="form-group">
<label>Catégorie</label>
<select name="category_id" class="form-control selectpicker" required>
@foreach($categories as $category)
<option value="{{$category->id}}">{{$category->name}}</option>
@endforeach
</select>
</div>
</div>
<div class="col-lg-12 mt-4">
<label for="desc">Description de l'image</label>
<div class="form-group">
<textarea name="desc" id="desc" class="form-control" required></textarea>
</div>
</div>
<div class="col-lg-12">
<button type="submit" class="btn btn-primary">Sauvegarder</button>
</div> </div>
</div> </div>
</div> </form>
<div class="row"> </div>
<div class="col-12">
<div class="form-group">
<label for="qt">Quantité</label>
<input type="number" class="form-control" name="qt" id="qt" aria-describedby="qthelp" placeholder="" required>
<small id="qthelp" class="form-text text-muted">Quantité disponible</small>
</div>
</div>
</div>
<div class="row">
<div class="col-12">
<div class="form-group">
<label for="desc">Description</label>
<textarea class="form-control" name="desc" id="desc" rows="5" required></textarea>
<small id="helpname" class="form-text text-muted">Description de l'item</small>
</div>
</div>
</div>
<div class="row">
<div class="col-12">
<button type="submit" class="btn btn-primary">Submit</button>
</div>
</div>
</form>
</div> </div>
</div> </div>
</div>
@endsection @endsection
@section('breadcrumb')
<div class="breadcrumbs">
<div class="col-sm-4">
<div class="page-header float-left">
<div class="page-title">
<h1>Inventaire</h1>
</div>
</div>
</div>
<div class="col-sm-8">
<div class="page-header float-right">
<div class="page-title">
<ol class="breadcrumb text-right">
<li class="active">Inventaire</li>
</ol>
</div>
</div>
</div>
</div>
@endsection
@section('custom_scripts') @section('custom_scripts')
<script>
$('#desc').trumbowyg({
lang: 'fr'
});
function saveChange(pPerm) {
(function($) {
var myswitch = document.getElementById(pPerm);
$.post('/api/config/general/save?api_token='+api_token, { value: myswitch.checked,perm: pPerm } , function(data) {
swal({
title: 'Modification enregistré !',
type: 'success',
}).then((result) => {
if (result.value) {
location.reload();
}
})
});
})(jQuery);
}
</script>
@endsection @endsection

View File

@@ -1,73 +1,87 @@
@extends('layouts.admin.main') @extends('layouts.admin.main')
@section('content') @section('content')
<div class="col-md-12"> <div class="col-md-12">
<div class="card"> <div class="card">
<div class="card-header"> <div class="card-header card-header-primary">
<strong class="card-title">Ajouter un item dans l'inventaire</strong> <h4>Ajouter un item à l'inventaire</h4>
</div> </div>
<div class="card-body"> <div class="card-body mt-5">
<form action="/admin/item/edit/{{$item->id}}" method="post"> <form action="/admin/item/edit/{{$item->id}}" method="post">
@csrf
<div class="row"> @csrf
<div class="col-12"> <div class="row">
<div class="form-group"> <div class="col-md-6">
<label for="name">Nom</label> <div class="form-group">
<input type="text" class="form-control" name="name" id="name" aria-describedby="helpname" placeholder="Projecteur" value="{{$item->name}}" required> <label>Numéro d'article</label>
<small id="helpname" class="form-text text-muted">Nom</small> <input name="official_number" type="text" class="form-control" value="{{$item->official_number}}" required>
</div>
</div>
<div class="col-md-6">
<div class="form-group">
<label>Nom de l'article</label>
<input name="name" type="text" class="form-control" value="{{$item->name}}" required>
</div>
</div>
<div class="col-md-6">
<div class="form-group">
<label>Taille de l'article</label>
<input name="metadata-size" type="text" class="form-control" value="{{$item->metadata['size']}}" required>
</div>
</div>
<div class="col-md-6">
<div class="form-group">
<label>Quantité disponible</label>
<input name="quantity" type="number" class="form-control" value="{{$item->quantity}}" required>
</div>
</div>
<div class="col-md-6">
<div class="form-group">
<label>Catégorie</label>
<select name="category_id" class="form-control selectpicker" required>
@foreach($categories as $category)
<option value="{{$category->id}}"
@if($item->category_id = $category->id) selected @endif>{{$category->name}}</option>
@endforeach
</select>
</div>
</div>
<div class="col-lg-12 mt-4">
<label for="desc">Description de l'image</label>
<div class="form-group">
<textarea name="desc" id="desc" class="form-control" required>{!! $item->desc !!}</textarea>
</div>
</div>
<div class="col-lg-12">
<button type="submit" class="btn btn-primary">Sauvegarder</button>
</div> </div>
</div> </div>
</div> </form>
<div class="row"> </div>
<div class="col-12">
<div class="form-group">
<label for="qt">Quantité</label>
<input type="number" class="form-control" name="qt" id="qt" aria-describedby="qthelp" placeholder="" required value="{{$item->quantity}}">
<small id="qthelp" class="form-text text-muted">Quantité disponible</small>
</div>
</div>
</div>
<div class="row">
<div class="col-12">
<div class="form-group">
<label for="desc">Description</label>
<textarea class="form-control" name="desc" id="desc" rows="5" required>{{$item->desc}}</textarea>
<small id="helpname" class="form-text text-muted">Description de l'item</small>
</div>
</div>
</div>
<div class="row">
<div class="col-12">
<button type="submit" class="btn btn-primary">Submit</button>
</div>
</div>
</form>
</div> </div>
</div> </div>
</div>
@endsection @endsection
@section('breadcrumb')
<div class="breadcrumbs">
<div class="col-sm-4">
<div class="page-header float-left">
<div class="page-title">
<h1>Inventaire</h1>
</div>
</div>
</div>
<div class="col-sm-8">
<div class="page-header float-right">
<div class="page-title">
<ol class="breadcrumb text-right">
<li class="active">Inventaire</li>
</ol>
</div>
</div>
</div>
</div>
@endsection
@section('custom_scripts') @section('custom_scripts')
<script>
$('#desc').trumbowyg({
lang: 'fr'
});
function saveChange(pPerm) {
(function($) {
var myswitch = document.getElementById(pPerm);
$.post('/api/config/general/save?api_token='+api_token, { value: myswitch.checked,perm: pPerm } , function(data) {
swal({
title: 'Modification enregistré !',
type: 'success',
}).then((result) => {
if (result.value) {
location.reload();
}
})
});
})(jQuery);
}
</script>
@endsection @endsection

View File

@@ -8,7 +8,7 @@
</a></strong> </a></strong>
</div> </div>
<div class="card-body"> <div class="card-body">
<form action="/admin/user/edit" method="post"> <form action="/admin/user/edit/{{$user->id}}" method="post">
@csrf @csrf
<div class="row"> <div class="row">
<div class="col-6"> <div class="col-6">

View File

@@ -69,7 +69,6 @@
<p> Horaire</p> <p> Horaire</p>
</a> </a>
</li> </li>
<!--
<li class="nav-item "> <li class="nav-item ">
<a class="nav-link" data-toggle="collapse" href="#inventory"> <a class="nav-link" data-toggle="collapse" href="#inventory">
<i class="material-icons">shopping_basket</i> <i class="material-icons">shopping_basket</i>
@@ -86,20 +85,20 @@
</a> </a>
</li> </li>
<li class="nav-item "> <li class="nav-item ">
<a class="nav-link" href="/admin/inventory/add"> <a class="nav-link" href="/admin/item/add">
<span class="sidebar-mini"> <i class="fas fa-plus"></i> </span> <span class="sidebar-mini"> <i class="fas fa-plus"></i> </span>
<span class="sidebar-normal"> Ajouter un item </span> <span class="sidebar-normal"> Ajouter un item </span>
</a> </a>
</li> </li>
<li class="nav-item "> <!--<li class="nav-item ">
<a class="nav-link" href="/admin/inventory/booking"> <a class="nav-link" href="/admin/inventory/booking">
<span class="sidebar-mini"> <i class="fas fa-bookmark"></i> </span> <span class="sidebar-mini"> <i class="fas fa-bookmark"></i> </span>
<span class="sidebar-normal"> Réservation</span> <span class="sidebar-normal"> Réservation</span>
</a> </a>
</li> </li>-->
</ul> </ul>
</div> </div>
</li>--> </li>
<li class="nav-item "> <li class="nav-item ">
<a class="nav-link" data-toggle="collapse" href="#inventory"> <a class="nav-link" data-toggle="collapse" href="#inventory">
<i class="material-icons">image</i> <i class="material-icons">image</i>
@@ -193,6 +192,12 @@
<span class="sidebar-normal"> Activités </span> <span class="sidebar-normal"> Activités </span>
</a> </a>
</li> </li>
<li class="nav-item ">
<a class="nav-link" href="/admin/config/customisation">
<span class="sidebar-mini"> <i class="fas fa-palette"></i> </span>
<span class="sidebar-normal"> Apparence </span>
</a>
</li>
</ul> </ul>
</div> </div>
</li> </li>

View File

@@ -64,7 +64,7 @@ Route::middleware(['auth','admin'])->group(function () {
Route::get('/admin/user/add' , 'UserController@create'); Route::get('/admin/user/add' , 'UserController@create');
Route::post('/admin/user/add' , 'UserController@store'); Route::post('/admin/user/add' , 'UserController@store');
Route::get('/admin/user/edit/{id}' , 'UserController@edit'); Route::get('/admin/user/edit/{id}' , 'UserController@edit');
Route::post('/admin/user/edit' , 'UserController@update'); Route::post('/admin/user/edit/{id}' , 'UserController@update');
/** Config */ /** Config */
Route::get('/admin/config/job' , 'JobController@index'); Route::get('/admin/config/job' , 'JobController@index');
@@ -80,6 +80,8 @@ Route::middleware(['auth','admin'])->group(function () {
Route::post('/admin/config/activity/edit/{id}' , 'ComplementaryActivityController@update'); Route::post('/admin/config/activity/edit/{id}' , 'ComplementaryActivityController@update');
Route::post('/admin/config/general/edit','ConfigController@update'); Route::post('/admin/config/general/edit','ConfigController@update');
Route::get('/admin/config/' , 'ConfigController@index'); Route::get('/admin/config/' , 'ConfigController@index');
Route::get('/admin/config/customisation','ConfigController@customisation');
Route::post('/admin/config/customisation','ConfigController@customisationUpdate');
/** Public page */ /** Public page */
Route::get('/admin/public/edit/{config}', 'PublicController@edit'); Route::get('/admin/public/edit/{config}', 'PublicController@edit');