Compare commits
	
		
			58 commits
		
	
	
		
			7140796ccd
			...
			210c91f3a8
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 210c91f3a8 | |||
| 2ee7fca584 | |||
| 258bccf59b | |||
| ca42526a62 | |||
| f484bfff79 | |||
| 9384d09ff6 | |||
| f460cdd6ce | |||
| 4b4a284914 | |||
| a641247748 | |||
| 82a518fa1d | |||
| deaa65d857 | |||
| 4af9e53a50 | |||
| 8d64d85b8b | |||
| 2c720faca7 | |||
| 85fa9f1e9b | |||
| c8d1969352 | |||
| 1eb77be1d0 | |||
| 3949cf3400 | |||
| 973d099bf1 | |||
| 802d4d0c0b | |||
| 134ed0cd22 | |||
| 2bfcf59f3e | |||
| 4e197204a9 | |||
| 2075bcab0f | |||
| c0d8392f6e | |||
| ef9a296f5c | |||
| bc55b4c34f | |||
| e779111856 | |||
| d6990f8c88 | |||
| 8eb385c67e | |||
| 2970982c77 | |||
| 9e63c83126 | |||
| 439f69a30c | |||
| d0ce8e8e23 | |||
| 3b858f5b2b | |||
| 0512ea9ab2 | |||
| 8488d9d6c5 | |||
| 354045c5df | |||
| ae1f8673e7 | |||
| 4f74bf38f9 | |||
| 8a2539f207 | |||
| 04673b1754 | |||
| 88af33d998 | |||
| 23af6ccd61 | |||
| 777f442118 | |||
| 7cae00e613 | |||
| 5a61ca46c5 | |||
| e379825fd9 | |||
| 6b2da42160 | |||
| 48cf57a6d8 | |||
| aa545ff82a | |||
| b29d63ed4d | |||
| 1e91f443a7 | |||
| 6782b7f675 | |||
| 85b3f1dd0f | |||
| a006fc15fa | |||
| 37fd0fb4d3 | |||
| d794dbd2b0 | 
					 55 changed files with 1254 additions and 926 deletions
				
			
		|  | @ -43,6 +43,14 @@ class GrupoDeCompra extends Model | ||||||
|         return $total; |         return $total; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     public function totalSinDevoluciones() { | ||||||
|  |         $total = 0; | ||||||
|  |         foreach ($this->pedidosAprobados() as $subpedido) { | ||||||
|  |             $total = $total + $subpedido->totalSinDevoluciones(); | ||||||
|  |         } | ||||||
|  |         return $total; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     public function totalBarrial() |     public function totalBarrial() | ||||||
|     { |     { | ||||||
|         $total = 0; |         $total = 0; | ||||||
|  | @ -108,7 +116,7 @@ class GrupoDeCompra extends Model | ||||||
| 
 | 
 | ||||||
|     function pedidoParaPdf(): array |     function pedidoParaPdf(): array | ||||||
|     { |     { | ||||||
|         $productos = $this->productosPedidos(true, true, 'producto_id'); |         $productos = $this->productosPedidos(true, 'producto_id'); | ||||||
|         $pedido = []; |         $pedido = []; | ||||||
|         $pedido['productos'] = []; |         $pedido['productos'] = []; | ||||||
| 
 | 
 | ||||||
|  | @ -258,13 +266,12 @@ class GrupoDeCompra extends Model | ||||||
|         return $result; |         return $result; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public function productosPedidos($excluirBarriales = false, $excluirBonos = false, $orderBy = 'producto_nombre'): Collection |     public function productosPedidos($excluirBonos = false, $orderBy = 'producto_nombre'): Collection | ||||||
|     { |     { | ||||||
|         $query = DB::table('pedidos_aprobados') |         $query = DB::table('pedidos_aprobados') | ||||||
|             ->where('grupo_de_compra_id', $this->id); |             ->where('grupo_de_compra_id', $this->id) | ||||||
|  |             ->where('producto_nombre','NOT LIKE','%barrial%'); | ||||||
| 
 | 
 | ||||||
|         if ($excluirBarriales) |  | ||||||
|             $query = $query->where('producto_nombre','NOT LIKE','%barrial%'); |  | ||||||
|         if ($excluirBonos) |         if ($excluirBonos) | ||||||
|             $query = $query->where('producto_es_bono',false); |             $query = $query->where('producto_es_bono',false); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -101,7 +101,6 @@ class CanastaHelper | ||||||
|             }); |             }); | ||||||
| 
 | 
 | ||||||
|         Producto::create([ |         Producto::create([ | ||||||
|             'fila' => 420, |  | ||||||
|             'nombre' => "Bono barrial", |             'nombre' => "Bono barrial", | ||||||
|             'precio' => 20, |             'precio' => 20, | ||||||
|             'categoria' => $categoria, |             'categoria' => $categoria, | ||||||
|  |  | ||||||
|  | @ -6,6 +6,7 @@ use App\GrupoDeCompra; | ||||||
| use App\Http\Controllers\Controller; | use App\Http\Controllers\Controller; | ||||||
| use App\Http\Resources\GrupoDeCompraReducido; | use App\Http\Resources\GrupoDeCompraReducido; | ||||||
| use App\Http\Resources\GrupoDeCompraResource; | use App\Http\Resources\GrupoDeCompraResource; | ||||||
|  | use http\Env\Request; | ||||||
| 
 | 
 | ||||||
| class GrupoDeCompraController extends Controller | class GrupoDeCompraController extends Controller | ||||||
| { | { | ||||||
|  | @ -17,8 +18,18 @@ class GrupoDeCompraController extends Controller | ||||||
|     { |     { | ||||||
|         return new GrupoDeCompraResource($grupoDeCompra); |         return new GrupoDeCompraResource($grupoDeCompra); | ||||||
|     } |     } | ||||||
|     public function reducido(GrupoDeCompra $grupoDeCompra) |     public function regiones() | ||||||
|     { |     { | ||||||
|         return new GrupoDeCompraReducido($grupoDeCompra); |         return GrupoDeCompra::all()->pluck('region')->unique()->flatten(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public function region(string $region) | ||||||
|  |     { | ||||||
|  |         return GrupoDeCompra::where('region', $region)->get(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public function toggleDevoluciones(int $gdc) { | ||||||
|  |         GrupoDeCompra::find($gdc)->toggleDevoluciones(); | ||||||
|  |         return response()->noContent(); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -2,8 +2,8 @@ | ||||||
| 
 | 
 | ||||||
| namespace App\Http\Controllers\Api; | namespace App\Http\Controllers\Api; | ||||||
| 
 | 
 | ||||||
| use App\Http\Controllers\Controller; |  | ||||||
| use Illuminate\Http\Request; | use Illuminate\Http\Request; | ||||||
|  | use App\Http\Controllers\Controller; | ||||||
| use App\Filtros\FiltroDeProducto; | use App\Filtros\FiltroDeProducto; | ||||||
| use App\Http\Resources\ProductoResource; | use App\Http\Resources\ProductoResource; | ||||||
| use App\Producto; | use App\Producto; | ||||||
|  | @ -15,9 +15,8 @@ class ProductoController extends Controller | ||||||
|         return ProductoResource::collection(Producto::filtrar($filtros)->paginate(Producto::getPaginar($request))); |         return ProductoResource::collection(Producto::filtrar($filtros)->paginate(Producto::getPaginar($request))); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public function show(Producto $producto) |     public function categorias() | ||||||
|     { |     { | ||||||
|         return new ProductoResource($producto); |         return Producto::all()->pluck('categoria')->unique()->flatten(); | ||||||
|     } |     } | ||||||
| 
 |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -3,13 +3,16 @@ | ||||||
| namespace App\Http\Controllers; | namespace App\Http\Controllers; | ||||||
| 
 | 
 | ||||||
| use App\Subpedido; | use App\Subpedido; | ||||||
|  | use Illuminate\Http\JsonResponse; | ||||||
| use Illuminate\Http\Request; | use Illuminate\Http\Request; | ||||||
|  | use Illuminate\Http\Response; | ||||||
| use Illuminate\Support\Facades\Auth; | use Illuminate\Support\Facades\Auth; | ||||||
| use Illuminate\Validation\Rule; | use Illuminate\Validation\Rule; | ||||||
| 
 | 
 | ||||||
| class SessionController extends Controller | class SessionController extends Controller | ||||||
| { | { | ||||||
|     public function store(Request $request) { |     public function store(Request $request): Response | ||||||
|  |     { | ||||||
|         $grupo_de_compra_id = Auth::user()->grupo_de_compra_id; |         $grupo_de_compra_id = Auth::user()->grupo_de_compra_id; | ||||||
|         $validated = $request->validate([ |         $validated = $request->validate([ | ||||||
|             'id' => 'required', |             'id' => 'required', | ||||||
|  | @ -19,7 +22,14 @@ class SessionController extends Controller | ||||||
|         return response()->noContent(); |         return response()->noContent(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public function fetch() { |     public function fetch(): JsonResponse | ||||||
|         return session('pedido_id'); |     { | ||||||
|  |         return response()->json(['id' => session('pedido_id')]); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public function destroy(): Response | ||||||
|  |     { | ||||||
|  |         session()->forget('pedido_id'); | ||||||
|  |         return response()->noContent(); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -21,6 +21,7 @@ class GrupoDeCompraResource extends JsonResource | ||||||
|             'devoluciones_habilitadas' => $this->devoluciones_habilitadas, |             'devoluciones_habilitadas' => $this->devoluciones_habilitadas, | ||||||
|             'pedidos' => SubpedidoResource::collection($this->subpedidos), |             'pedidos' => SubpedidoResource::collection($this->subpedidos), | ||||||
|             'total_a_recaudar' => number_format($this->totalARecaudar(),2), |             'total_a_recaudar' => number_format($this->totalARecaudar(),2), | ||||||
|  |             'total_sin_devoluciones' => number_format($this->totalSinDevoluciones(),2), | ||||||
|             'total_barrial' => number_format($this->totalBarrial(),2), |             'total_barrial' => number_format($this->totalBarrial(),2), | ||||||
|             'total_devoluciones' => number_format($this->totalDevoluciones(),2), |             'total_devoluciones' => number_format($this->totalDevoluciones(),2), | ||||||
|             'total_a_transferir' => number_format($this->totalATransferir(),2), |             'total_a_transferir' => number_format($this->totalATransferir(),2), | ||||||
|  |  | ||||||
|  | @ -14,13 +14,18 @@ use Illuminate\Support\Facades\DB; | ||||||
| 
 | 
 | ||||||
| class Producto extends Model | class Producto extends Model | ||||||
| { | { | ||||||
|     protected $fillable = ["nombre", "precio", "categoria"]; |     protected $fillable = ["nombre", "precio", "categoria", "bono", "es_solidario", "requiere_notas"]; | ||||||
| 
 | 
 | ||||||
|     public function subpedidos(): BelongsToMany |     public function subpedidos(): BelongsToMany | ||||||
|     { |     { | ||||||
|         return $this->belongsToMany(Subpedido::class, 'productos_subpedidos')->withPivot(["cantidad", "notas"]); |         return $this->belongsToMany(Subpedido::class, 'productos_subpedidos')->withPivot(["cantidad", "notas"]); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     public static function noBarriales() | ||||||
|  |     { | ||||||
|  |         return self::where('nombre', 'not like', '%barrial%'); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     // Este método permite que se apliquen los filtros al hacer una request (por ejemplo, de búsqueda)
 |     // Este método permite que se apliquen los filtros al hacer una request (por ejemplo, de búsqueda)
 | ||||||
|     public function scopeFiltrar($query, FiltroDeProducto $filtros): Builder |     public function scopeFiltrar($query, FiltroDeProducto $filtros): Builder | ||||||
|     { |     { | ||||||
|  | @ -34,17 +39,17 @@ class Producto extends Model | ||||||
| 
 | 
 | ||||||
|     public static function productosFilaID() |     public static function productosFilaID() | ||||||
|     { |     { | ||||||
|         return Producto::pluck('id', 'fila')->all(); |         return self::noBarriales()->pluck('id', 'fila')->all(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public static function productosIDFila() |     public static function productosIDFila() | ||||||
|     { |     { | ||||||
|         return Producto::pluck('fila', 'id')->all(); |         return self::noBarriales()->pluck('fila', 'id')->all(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public static function productosIDNombre() |     public static function productosIDNombre() | ||||||
|     { |     { | ||||||
|         return Producto::pluck('nombre', 'id')->all(); |         return self::noBarriales()->pluck('nombre', 'id')->all(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     static public function cantidadesPorBarrio(): Collection |     static public function cantidadesPorBarrio(): Collection | ||||||
|  |  | ||||||
|  | @ -9,6 +9,7 @@ | ||||||
|     "license": "MIT", |     "license": "MIT", | ||||||
|     "require": { |     "require": { | ||||||
|         "php": "^7.4", |         "php": "^7.4", | ||||||
|  |         "doctrine/dbal": "^2.2.0", | ||||||
|         "fideloper/proxy": "^4.4", |         "fideloper/proxy": "^4.4", | ||||||
|         "fruitcake/laravel-cors": "^2.0", |         "fruitcake/laravel-cors": "^2.0", | ||||||
|         "guzzlehttp/guzzle": "^6.3.1|^7.0.1", |         "guzzlehttp/guzzle": "^6.3.1|^7.0.1", | ||||||
|  |  | ||||||
							
								
								
									
										809
									
								
								composer.lock
									
										
									
										generated
									
									
									
								
							
							
						
						
									
										809
									
								
								composer.lock
									
										
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							|  | @ -0,0 +1,32 @@ | ||||||
|  | <?php | ||||||
|  | 
 | ||||||
|  | use Illuminate\Database\Migrations\Migration; | ||||||
|  | use Illuminate\Database\Schema\Blueprint; | ||||||
|  | use Illuminate\Support\Facades\Schema; | ||||||
|  | 
 | ||||||
|  | class HacerFilaNullable extends Migration | ||||||
|  | { | ||||||
|  |     /** | ||||||
|  |      * Run the migrations. | ||||||
|  |      * | ||||||
|  |      * @return void | ||||||
|  |      */ | ||||||
|  |     public function up() | ||||||
|  |     { | ||||||
|  |         Schema::table('productos', function (Blueprint $table) { | ||||||
|  |             $table->integer('fila')->nullable()->change(); | ||||||
|  |         }); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * Reverse the migrations. | ||||||
|  |      * | ||||||
|  |      * @return void | ||||||
|  |      */ | ||||||
|  |     public function down() | ||||||
|  |     { | ||||||
|  |         Schema::table('productos', function (Blueprint $table) { | ||||||
|  |             $table->integer('fila')->nullable(false)->change(); | ||||||
|  |         }); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | @ -0,0 +1,32 @@ | ||||||
|  | <?php | ||||||
|  | 
 | ||||||
|  | use Illuminate\Database\Migrations\Migration; | ||||||
|  | use Illuminate\Database\Schema\Blueprint; | ||||||
|  | use Illuminate\Support\Facades\Schema; | ||||||
|  | 
 | ||||||
|  | class QuitarPasswordDeGrupoDeCompra extends Migration | ||||||
|  | { | ||||||
|  |     /** | ||||||
|  |      * Run the migrations. | ||||||
|  |      * | ||||||
|  |      * @return void | ||||||
|  |      */ | ||||||
|  |     public function up() | ||||||
|  |     { | ||||||
|  |         Schema::table('grupos_de_compra', function (Blueprint $table) { | ||||||
|  |             $table->dropColumn('password'); | ||||||
|  |         }); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * Reverse the migrations. | ||||||
|  |      * | ||||||
|  |      * @return void | ||||||
|  |      */ | ||||||
|  |     public function down() | ||||||
|  |     { | ||||||
|  |         Schema::table('grupos_de_compra', function (Blueprint $table) { | ||||||
|  |             $table->string('password')->nullable(); | ||||||
|  |         }); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										60
									
								
								package-lock.json
									
										
									
										generated
									
									
									
								
							
							
						
						
									
										60
									
								
								package-lock.json
									
										
									
										generated
									
									
									
								
							|  | @ -13,12 +13,8 @@ | ||||||
|             }, |             }, | ||||||
|             "devDependencies": { |             "devDependencies": { | ||||||
|                 "axios": "^0.19.2", |                 "axios": "^0.19.2", | ||||||
|                 "bootstrap": "^4.0.0", |  | ||||||
|                 "cross-env": "^7.0.3", |                 "cross-env": "^7.0.3", | ||||||
|                 "jquery": "^3.2", |  | ||||||
|                 "laravel-mix": "^5.0.1", |                 "laravel-mix": "^5.0.1", | ||||||
|                 "lodash": "^4.17.19", |  | ||||||
|                 "popper.js": "^1.12", |  | ||||||
|                 "resolve-url-loader": "^2.3.1", |                 "resolve-url-loader": "^2.3.1", | ||||||
|                 "sass": "^1.20.1", |                 "sass": "^1.20.1", | ||||||
|                 "sass-loader": "^8.0.0", |                 "sass-loader": "^8.0.0", | ||||||
|  | @ -3090,26 +3086,6 @@ | ||||||
|             "integrity": "sha512-JZOSA7Mo9sNGB8+UjSgzdLtokWAky1zbztM3WRLCbZ70/3cTANmQmOdR7y2g+J0e2WXywy1yS468tY+IruqEww==", |             "integrity": "sha512-JZOSA7Mo9sNGB8+UjSgzdLtokWAky1zbztM3WRLCbZ70/3cTANmQmOdR7y2g+J0e2WXywy1yS468tY+IruqEww==", | ||||||
|             "dev": true |             "dev": true | ||||||
|         }, |         }, | ||||||
|         "node_modules/bootstrap": { |  | ||||||
|             "version": "4.6.2", |  | ||||||
|             "resolved": "https://registry.npmjs.org/bootstrap/-/bootstrap-4.6.2.tgz", |  | ||||||
|             "integrity": "sha512-51Bbp/Uxr9aTuy6ca/8FbFloBUJZLHwnhTcnjIeRn2suQWsWzcuJhGjKDB5eppVte/8oCdOL3VuwxvZDUggwGQ==", |  | ||||||
|             "dev": true, |  | ||||||
|             "funding": [ |  | ||||||
|                 { |  | ||||||
|                     "type": "github", |  | ||||||
|                     "url": "https://github.com/sponsors/twbs" |  | ||||||
|                 }, |  | ||||||
|                 { |  | ||||||
|                     "type": "opencollective", |  | ||||||
|                     "url": "https://opencollective.com/bootstrap" |  | ||||||
|                 } |  | ||||||
|             ], |  | ||||||
|             "peerDependencies": { |  | ||||||
|                 "jquery": "1.9.1 - 3", |  | ||||||
|                 "popper.js": "^1.16.1" |  | ||||||
|             } |  | ||||||
|         }, |  | ||||||
|         "node_modules/brace-expansion": { |         "node_modules/brace-expansion": { | ||||||
|             "version": "1.1.11", |             "version": "1.1.11", | ||||||
|             "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", |             "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", | ||||||
|  | @ -7939,12 +7915,6 @@ | ||||||
|                 "node": ">=8" |                 "node": ">=8" | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
|         "node_modules/jquery": { |  | ||||||
|             "version": "3.7.1", |  | ||||||
|             "resolved": "https://registry.npmjs.org/jquery/-/jquery-3.7.1.tgz", |  | ||||||
|             "integrity": "sha512-m4avr8yL8kmFN8psrbFFFmB/If14iN5o9nw/NgnnM+kybDJpRsAynV2BsfpTYrTRysYUdADVD7CkUUizgkpLfg==", |  | ||||||
|             "dev": true |  | ||||||
|         }, |  | ||||||
|         "node_modules/js-tokens": { |         "node_modules/js-tokens": { | ||||||
|             "version": "4.0.0", |             "version": "4.0.0", | ||||||
|             "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", |             "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", | ||||||
|  | @ -9605,17 +9575,6 @@ | ||||||
|                 "node": ">=8" |                 "node": ">=8" | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
|         "node_modules/popper.js": { |  | ||||||
|             "version": "1.16.1", |  | ||||||
|             "resolved": "https://registry.npmjs.org/popper.js/-/popper.js-1.16.1.tgz", |  | ||||||
|             "integrity": "sha512-Wb4p1J4zyFTbM+u6WuO4XstYx4Ky9Cewe4DWrel7B0w6VVICvPwdOpotjzcf6eD8TsckVnIMNONQyPIUFOUbCQ==", |  | ||||||
|             "deprecated": "You can find the new Popper v2 at @popperjs/core, this package is dedicated to the legacy v1", |  | ||||||
|             "dev": true, |  | ||||||
|             "funding": { |  | ||||||
|                 "type": "opencollective", |  | ||||||
|                 "url": "https://opencollective.com/popperjs" |  | ||||||
|             } |  | ||||||
|         }, |  | ||||||
|         "node_modules/portfinder": { |         "node_modules/portfinder": { | ||||||
|             "version": "1.0.37", |             "version": "1.0.37", | ||||||
|             "resolved": "https://registry.npmjs.org/portfinder/-/portfinder-1.0.37.tgz", |             "resolved": "https://registry.npmjs.org/portfinder/-/portfinder-1.0.37.tgz", | ||||||
|  | @ -17156,13 +17115,6 @@ | ||||||
|             "integrity": "sha512-JZOSA7Mo9sNGB8+UjSgzdLtokWAky1zbztM3WRLCbZ70/3cTANmQmOdR7y2g+J0e2WXywy1yS468tY+IruqEww==", |             "integrity": "sha512-JZOSA7Mo9sNGB8+UjSgzdLtokWAky1zbztM3WRLCbZ70/3cTANmQmOdR7y2g+J0e2WXywy1yS468tY+IruqEww==", | ||||||
|             "dev": true |             "dev": true | ||||||
|         }, |         }, | ||||||
|         "bootstrap": { |  | ||||||
|             "version": "4.6.2", |  | ||||||
|             "resolved": "https://registry.npmjs.org/bootstrap/-/bootstrap-4.6.2.tgz", |  | ||||||
|             "integrity": "sha512-51Bbp/Uxr9aTuy6ca/8FbFloBUJZLHwnhTcnjIeRn2suQWsWzcuJhGjKDB5eppVte/8oCdOL3VuwxvZDUggwGQ==", |  | ||||||
|             "dev": true, |  | ||||||
|             "requires": {} |  | ||||||
|         }, |  | ||||||
|         "brace-expansion": { |         "brace-expansion": { | ||||||
|             "version": "1.1.11", |             "version": "1.1.11", | ||||||
|             "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", |             "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", | ||||||
|  | @ -20894,12 +20846,6 @@ | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
|         "jquery": { |  | ||||||
|             "version": "3.7.1", |  | ||||||
|             "resolved": "https://registry.npmjs.org/jquery/-/jquery-3.7.1.tgz", |  | ||||||
|             "integrity": "sha512-m4avr8yL8kmFN8psrbFFFmB/If14iN5o9nw/NgnnM+kybDJpRsAynV2BsfpTYrTRysYUdADVD7CkUUizgkpLfg==", |  | ||||||
|             "dev": true |  | ||||||
|         }, |  | ||||||
|         "js-tokens": { |         "js-tokens": { | ||||||
|             "version": "4.0.0", |             "version": "4.0.0", | ||||||
|             "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", |             "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", | ||||||
|  | @ -22234,12 +22180,6 @@ | ||||||
|                 "find-up": "^4.0.0" |                 "find-up": "^4.0.0" | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
|         "popper.js": { |  | ||||||
|             "version": "1.16.1", |  | ||||||
|             "resolved": "https://registry.npmjs.org/popper.js/-/popper.js-1.16.1.tgz", |  | ||||||
|             "integrity": "sha512-Wb4p1J4zyFTbM+u6WuO4XstYx4Ky9Cewe4DWrel7B0w6VVICvPwdOpotjzcf6eD8TsckVnIMNONQyPIUFOUbCQ==", |  | ||||||
|             "dev": true |  | ||||||
|         }, |  | ||||||
|         "portfinder": { |         "portfinder": { | ||||||
|             "version": "1.0.37", |             "version": "1.0.37", | ||||||
|             "resolved": "https://registry.npmjs.org/portfinder/-/portfinder-1.0.37.tgz", |             "resolved": "https://registry.npmjs.org/portfinder/-/portfinder-1.0.37.tgz", | ||||||
|  |  | ||||||
|  | @ -11,12 +11,8 @@ | ||||||
|     }, |     }, | ||||||
|     "devDependencies": { |     "devDependencies": { | ||||||
|         "axios": "^0.19.2", |         "axios": "^0.19.2", | ||||||
|         "bootstrap": "^4.0.0", |  | ||||||
|         "cross-env": "^7.0.3", |         "cross-env": "^7.0.3", | ||||||
|         "jquery": "^3.2", |  | ||||||
|         "laravel-mix": "^5.0.1", |         "laravel-mix": "^5.0.1", | ||||||
|         "lodash": "^4.17.19", |  | ||||||
|         "popper.js": "^1.12", |  | ||||||
|         "resolve-url-loader": "^2.3.1", |         "resolve-url-loader": "^2.3.1", | ||||||
|         "sass": "^1.20.1", |         "sass": "^1.20.1", | ||||||
|         "sass-loader": "^8.0.0", |         "sass-loader": "^8.0.0", | ||||||
|  |  | ||||||
							
								
								
									
										41
									
								
								resources/js/bootstrap.js
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										41
									
								
								resources/js/bootstrap.js
									
										
									
									
										vendored
									
									
								
							|  | @ -1,41 +0,0 @@ | ||||||
| window._ = require('lodash'); |  | ||||||
| 
 |  | ||||||
| /** |  | ||||||
|  * We'll load jQuery and the Bootstrap jQuery plugin which provides support |  | ||||||
|  * for JavaScript based Bootstrap features such as modals and tabs. This |  | ||||||
|  * code may be modified to fit the specific needs of your application. |  | ||||||
|  */ |  | ||||||
| 
 |  | ||||||
| try { |  | ||||||
|     window.Popper = require('popper.js').default; |  | ||||||
|     window.$ = window.jQuery = require('jquery'); |  | ||||||
| 
 |  | ||||||
|     require('bootstrap'); |  | ||||||
| } catch (e) {} |  | ||||||
| 
 |  | ||||||
| /** |  | ||||||
|  * We'll load the axios HTTP library which allows us to easily issue requests |  | ||||||
|  * to our Laravel back-end. This library automatically handles sending the |  | ||||||
|  * CSRF token as a header based on the value of the "XSRF" token cookie. |  | ||||||
|  */ |  | ||||||
| 
 |  | ||||||
| window.axios = require('axios'); |  | ||||||
| 
 |  | ||||||
| window.axios.defaults.headers.common['X-Requested-With'] = 'XMLHttpRequest'; |  | ||||||
| 
 |  | ||||||
| /** |  | ||||||
|  * Echo exposes an expressive API for subscribing to channels and listening |  | ||||||
|  * for events that are broadcast by Laravel. Echo and event broadcasting |  | ||||||
|  * allows your team to easily build robust real-time web applications. |  | ||||||
|  */ |  | ||||||
| 
 |  | ||||||
| // import Echo from 'laravel-echo';
 |  | ||||||
| 
 |  | ||||||
| // window.Pusher = require('pusher-js');
 |  | ||||||
| 
 |  | ||||||
| // window.Echo = new Echo({
 |  | ||||||
| //     broadcaster: 'pusher',
 |  | ||||||
| //     key: process.env.MIX_PUSHER_APP_KEY,
 |  | ||||||
| //     cluster: process.env.MIX_PUSHER_APP_CLUSTER,
 |  | ||||||
| //     forceTLS: true
 |  | ||||||
| // });
 |  | ||||||
|  | @ -23,7 +23,6 @@ import CaracteristicasOpcionales from "./CaracteristicasOpcionales.vue"; | ||||||
| import TabsSecciones from "../comunes/TabsSecciones.vue"; | import TabsSecciones from "../comunes/TabsSecciones.vue"; | ||||||
| import DropdownDescargar from "./DropdownDescargar.vue"; | import DropdownDescargar from "./DropdownDescargar.vue"; | ||||||
| import TablaPedidos from "./TablaPedidos.vue"; | import TablaPedidos from "./TablaPedidos.vue"; | ||||||
| import TablaBonos from "./TablaBonos.vue"; |  | ||||||
| import { mapActions, mapGetters } from "vuex"; | import { mapActions, mapGetters } from "vuex"; | ||||||
| export default { | export default { | ||||||
|     components: { |     components: { | ||||||
|  | @ -31,7 +30,6 @@ export default { | ||||||
|         TabsSecciones, |         TabsSecciones, | ||||||
|         DropdownDescargar, |         DropdownDescargar, | ||||||
|         TablaPedidos, |         TablaPedidos, | ||||||
|         TablaBonos, |  | ||||||
|     }, |     }, | ||||||
|     data() { |     data() { | ||||||
|         return { |         return { | ||||||
|  |  | ||||||
|  | @ -1,5 +1,4 @@ | ||||||
| <script> | <script> | ||||||
| import axios from "axios"; |  | ||||||
| import {mapActions, mapGetters, mapState} from "vuex"; | import {mapActions, mapGetters, mapState} from "vuex"; | ||||||
| 
 | 
 | ||||||
| export default { | export default { | ||||||
|  |  | ||||||
|  | @ -12,7 +12,9 @@ | ||||||
|         <td class="has-text-right" > |         <td class="has-text-right" > | ||||||
|             {{ devoluciones_habilitadas ? pedido.total : pedido.total_sin_devoluciones }} |             {{ devoluciones_habilitadas ? pedido.total : pedido.total_sin_devoluciones }} | ||||||
|         </td> |         </td> | ||||||
|         <td><switch-aprobacion :pedido_id="pedido_id"></switch-aprobacion></td> |         <td> | ||||||
|  |             <switch-aprobacion :pedido_id="pedido_id"/> | ||||||
|  |         </td> | ||||||
|     </tr> |     </tr> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1,97 +0,0 @@ | ||||||
| <template> |  | ||||||
|     <div class="block"> |  | ||||||
|         <div class="block" v-show="!hayBonos"> |  | ||||||
|             <p class="has-text-centered"> |  | ||||||
|                 Todavía no hay bonos pedidos. |  | ||||||
|             </p> |  | ||||||
|         </div> |  | ||||||
|         <div class="block" v-show="hayBonos"> |  | ||||||
|             <table class="table is-bordered is-striped is-hoverable is-fullwidth"> |  | ||||||
|                 <thead> |  | ||||||
|                     <tr> |  | ||||||
|                         <th><abbr title="Núcleo">Núcleo</abbr></th> |  | ||||||
|                         <td v-for="(bono,i) in bonos" :key="i" class="is-1"> |  | ||||||
|                             {{ bono.nombre }} |  | ||||||
|                         </td> |  | ||||||
|                         <th><abbr title="Total a Pagar">Total $</abbr></th> |  | ||||||
|                     </tr> |  | ||||||
|                 </thead> |  | ||||||
|                 <tbody> |  | ||||||
|                     <tr v-for="(bp, i) in bonosPorPedido" :key="i"> |  | ||||||
|                         <td> {{ bp.nucleo }} </td> |  | ||||||
|                         <td v-for="(bono,j) in bp.bonos" :key="j" class="has-text-right"> |  | ||||||
|                             {{ bono.cantidad }} |  | ||||||
|                         </td> |  | ||||||
|                         <td class="has-text-right"> {{ bp.total }} </td> |  | ||||||
|                     </tr> |  | ||||||
|                 </tbody> |  | ||||||
|                 <tfoot> |  | ||||||
|                     <tr> |  | ||||||
|                         <th></th> |  | ||||||
|                         <th :colspan="bonos.length">Total bonos</th> |  | ||||||
|                         <th class="has-text-right">$ {{ totalBonos }}</th> |  | ||||||
|                     </tr> |  | ||||||
|                 </tfoot> |  | ||||||
|             </table> |  | ||||||
|         </div> |  | ||||||
|     </div> |  | ||||||
| </template> |  | ||||||
| 
 |  | ||||||
| <script> |  | ||||||
| export default { |  | ||||||
|     props: { |  | ||||||
|         pedidos: { |  | ||||||
|             type: Array, |  | ||||||
|             required: true |  | ||||||
|         } |  | ||||||
|     }, |  | ||||||
|     data() { |  | ||||||
|         return { |  | ||||||
|             bonos: [] |  | ||||||
|         } |  | ||||||
|     }, |  | ||||||
|     computed: { |  | ||||||
|         pedidosAprobados: function() { |  | ||||||
|             return this.pedidos.filter(p => p.aprobado) |  | ||||||
|         }, |  | ||||||
|         hayBonos: function() { |  | ||||||
|             return this.pedidosAprobados.filter(p => p.subtotal_bonos != 0).length !== 0 |  | ||||||
|         }, |  | ||||||
|         bonosPorPedido: function() { |  | ||||||
|             let bonosPorPedido = this.pedidosAprobados.map(p => p = {"nucleo":p.nombre, "bonos":p.productos.filter(x => x.bono), "total":p.subtotal_bonos}); |  | ||||||
|             bonosPorPedido.forEach(bp => { |  | ||||||
|                 bp.bonos = bp.bonos.map(b => b = {"bono":b.nombre, "cantidad":b.pivot.cantidad, "total":b.pivot.total, "id":b.id}) |  | ||||||
|             }) |  | ||||||
|             return bonosPorPedido.map(bp => this.completarBonos(bp)); |  | ||||||
|         }, |  | ||||||
|         totalBonos: function() { |  | ||||||
|             let total = 0 |  | ||||||
|             this.bonosPorPedido.map(bp => total += parseInt(bp.total)) |  | ||||||
|             return total |  | ||||||
|         }, |  | ||||||
|     }, |  | ||||||
|     methods: { |  | ||||||
|         completarBonos(bonosPedido) { |  | ||||||
|             this.bonos.map(b => { |  | ||||||
|                 if (!bonosPedido.bonos.map(x => x.id).includes(b.id)) |  | ||||||
|                      bonosPedido.bonos.push({"bono":b.nombre, "cantidad":0, "total":0, "id":b.id}) |  | ||||||
|             }) |  | ||||||
|             bonosPedido.bonos = bonosPedido.bonos.sort((b1,b2) => b1.id - b2.id) |  | ||||||
|             return bonosPedido |  | ||||||
|         } |  | ||||||
|     }, |  | ||||||
|     beforeMount() { |  | ||||||
|         axios.get("../api/productos", { |  | ||||||
|             params: { |  | ||||||
|                 categoria:'TRANSPORTE, BONOS Y FINANCIAMIENTO SORORO', |  | ||||||
|             } |  | ||||||
|         }).then(response => { |  | ||||||
|             this.bonos = response.data.data; |  | ||||||
|         }); |  | ||||||
|     }, |  | ||||||
| } |  | ||||||
| </script> |  | ||||||
| 
 |  | ||||||
| <style> |  | ||||||
| 
 |  | ||||||
| </style> |  | ||||||
|  | @ -24,7 +24,7 @@ | ||||||
|             </tr> |             </tr> | ||||||
|             <tr> |             <tr> | ||||||
|                 <th>Total a recaudar:</th> |                 <th>Total a recaudar:</th> | ||||||
|                 <td class="has-text-right">$ {{ total_a_recaudar }}</td> |                 <td class="has-text-right">$ {{ devoluciones_habilitadas ? total_a_recaudar : total_sin_devoluciones }}</td> | ||||||
|             </tr> |             </tr> | ||||||
|             <tr> |             <tr> | ||||||
|                 <th>Total bonos barriales:</th> |                 <th>Total bonos barriales:</th> | ||||||
|  | @ -62,6 +62,7 @@ export default { | ||||||
|             "devoluciones_habilitadas", |             "devoluciones_habilitadas", | ||||||
|             "pedidos", |             "pedidos", | ||||||
|             "total_a_recaudar", |             "total_a_recaudar", | ||||||
|  |             "total_sin_devoluciones", | ||||||
|             "total_barrial", |             "total_barrial", | ||||||
|             "total_devoluciones", |             "total_devoluciones", | ||||||
|             "cantidad_transporte", |             "cantidad_transporte", | ||||||
|  |  | ||||||
|  | @ -4,8 +4,8 @@ | ||||||
|         <div class="block pb-6" id="pedidos-compras-seccion" |         <div class="block pb-6" id="pedidos-compras-seccion" | ||||||
|              :class="seccionActiva === 'pedidos-compras-seccion' ? 'is-active' : 'is-hidden'"> |              :class="seccionActiva === 'pedidos-compras-seccion' ? 'is-active' : 'is-hidden'"> | ||||||
|             <div class="block" id="pedidos-compras-tabla-y-dropdown"> |             <div class="block" id="pedidos-compras-tabla-y-dropdown"> | ||||||
|                 <compras-dropdown-descargar> |                 <dropdown-descargar> | ||||||
|                 </compras-dropdown-descargar> |                 </dropdown-descargar> | ||||||
|             </div> |             </div> | ||||||
|         </div> |         </div> | ||||||
|         <div class="block pb-6" id="canasta-compras-seccion" |         <div class="block pb-6" id="canasta-compras-seccion" | ||||||
|  | @ -37,7 +37,7 @@ | ||||||
|                     </div> |                     </div> | ||||||
|                 </article> |                 </article> | ||||||
|                 <div class="buttons is-right"> |                 <div class="buttons is-right"> | ||||||
|                     <compras-canasta-input></compras-canasta-input> |                     <canasta-input></canasta-input> | ||||||
|                 </div> |                 </div> | ||||||
|             </div> |             </div> | ||||||
|         </div> |         </div> | ||||||
|  |  | ||||||
|  | @ -14,7 +14,7 @@ | ||||||
|                     </span> |                     </span> | ||||||
|                     <span class="file-label">Subir canasta</span> |                     <span class="file-label">Subir canasta</span> | ||||||
|                 </span> |                 </span> | ||||||
|                 <span class="file-name" v-if="archivo"> |                 <span class="file-name" v-if="cargando"> | ||||||
|                     {{ 'Cargando ' + archivo.nombre }} |                     {{ 'Cargando ' + archivo.nombre }} | ||||||
|                 </span> |                 </span> | ||||||
|             </label> |             </label> | ||||||
|  | @ -24,6 +24,7 @@ | ||||||
| 
 | 
 | ||||||
| <script> | <script> | ||||||
| import axios from "axios"; | import axios from "axios"; | ||||||
|  | import { mapActions } from "vuex"; | ||||||
| 
 | 
 | ||||||
| export default { | export default { | ||||||
|     name: "CanastaInput", |     name: "CanastaInput", | ||||||
|  | @ -34,10 +35,11 @@ export default { | ||||||
|         }; |         }; | ||||||
|     }, |     }, | ||||||
|     methods: { |     methods: { | ||||||
|  |         ...mapActions('ui',["toast"]), | ||||||
|         async archivoSubido(event) { |         async archivoSubido(event) { | ||||||
|             const archivo = event.target.files[0]; |             const archivo = event.target.files[0]; | ||||||
|             if (archivo && archivo.type === "text/csv") { |             if (archivo && archivo.type === "text/csv") { | ||||||
|                 this.archivo = {data: archivo, nombre: archivo.name}; |                 this.archivo = { data: archivo, nombre: archivo.name }; | ||||||
|                 const formData = new FormData(); |                 const formData = new FormData(); | ||||||
|                 formData.append("data", this.archivo.data); |                 formData.append("data", this.archivo.data); | ||||||
| 
 | 
 | ||||||
|  | @ -48,15 +50,15 @@ export default { | ||||||
|                             "Content-Type": "multipart/form-data", |                             "Content-Type": "multipart/form-data", | ||||||
|                         }, |                         }, | ||||||
|                     }); |                     }); | ||||||
|                     this.$root.$toast(response.data.message || "Canasta cargada exitosamente"); |                     this.toast({ mensaje: (response.data.message || "Canasta cargada exitosamente") }); | ||||||
|                 } catch (error) { |                 } catch (error) { | ||||||
|                     this.$root.$toast(error.response?.data?.message || "Hubo errores."); |                     this.toast({ mensaje: (error.response?.data?.message || "Hubo errores.") }); | ||||||
|                 } finally { |                 } finally { | ||||||
|                     this.cargando = false; |                     this.cargando = false; | ||||||
|                     this.archivo = null; |                     this.archivo = null; | ||||||
|                 } |                 } | ||||||
|             } else { |             } else { | ||||||
|                 this.$root.$toast("La canasta debe ser .CSV") |                 this.toast("La canasta debe ser .CSV") | ||||||
|                 this.archivo = null; |                 this.archivo = null; | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
|  |  | ||||||
|  | @ -1,5 +1,5 @@ | ||||||
| <template> | <template> | ||||||
| 	<div v-if="region_elegida !== null" class="block"> | 	<div v-if="region_elegida" class="block"> | ||||||
| 		<div class="field"> | 		<div class="field"> | ||||||
| 			<label class="label" :class="adminUrl ? 'has-text-white' : ''"> | 			<label class="label" :class="adminUrl ? 'has-text-white' : ''"> | ||||||
|                 Seleccioná tu barrio o grupo de compra |                 Seleccioná tu barrio o grupo de compra | ||||||
|  |  | ||||||
|  | @ -1,5 +1,5 @@ | ||||||
| <template> | <template> | ||||||
|     <div v-if="grupo_de_compra_elegido !== null" class="block"> |     <div v-if="grupo_de_compra_elegido" class="block"> | ||||||
|         <div class="field"> |         <div class="field"> | ||||||
|             <label class="label" |             <label class="label" | ||||||
|                    :class="adminUrl ? 'has-text-white' : ''">{{ mensajes.mensaje }}</label> |                    :class="adminUrl ? 'has-text-white' : ''">{{ mensajes.mensaje }}</label> | ||||||
|  |  | ||||||
|  | @ -6,7 +6,7 @@ | ||||||
|             </a> |             </a> | ||||||
|             <div class="navbar-item" id="datos-pedido" v-if="pedidoDefinido"> |             <div class="navbar-item" id="datos-pedido" v-if="pedidoDefinido"> | ||||||
|                 <p class="hide-below-1024"> |                 <p class="hide-below-1024"> | ||||||
|                     {{ `Núcleo: ${nombre} - Barrio: ${grupo_de_compra}` }} |                     {{ `Núcleo: ${nombre} - Barrio: ${grupo_de_compra.nombre}` }} | ||||||
|                 </p> |                 </p> | ||||||
|             </div> |             </div> | ||||||
|             <chismosa-dropdown |             <chismosa-dropdown | ||||||
|  | @ -42,7 +42,6 @@ | ||||||
|                        class="text-a"> |                        class="text-a"> | ||||||
|                         Cerrar sesión |                         Cerrar sesión | ||||||
|                     </a> |                     </a> | ||||||
|                     <slot name="logout-form"></slot> |  | ||||||
|                 </div> |                 </div> | ||||||
|             </div> |             </div> | ||||||
|         </div> |         </div> | ||||||
|  | @ -63,12 +62,12 @@ export default { | ||||||
|     }, |     }, | ||||||
|     computed: { |     computed: { | ||||||
|         ...mapGetters('pedido', ["pedidoDefinido"]), |         ...mapGetters('pedido', ["pedidoDefinido"]), | ||||||
|         ...mapState('pedido',["nombre"]), |         ...mapState('pedido', ["nombre"]), | ||||||
|         ...mapState('barrio',["grupo_de_compra"]), |         ...mapState('pedido', ["grupo_de_compra"]), | ||||||
|     }, |     }, | ||||||
|     methods: { |     methods: { | ||||||
|         ...mapActions('productos', ["filtrarProductos"]), |         ...mapActions('productos', ["filtrarProductos"]), | ||||||
|         ...mapMutations('ui',["addMiga"]), |         ...mapMutations('ui', ["addMiga", "popUltimaBusqueda"]), | ||||||
|         toggleBurger() { |         toggleBurger() { | ||||||
|             this.burgerActiva = !this.burgerActiva |             this.burgerActiva = !this.burgerActiva | ||||||
|         }, |         }, | ||||||
|  | @ -76,6 +75,7 @@ export default { | ||||||
|             if (this.burgerActiva) |             if (this.burgerActiva) | ||||||
|                 this.toggleBurger(); |                 this.toggleBurger(); | ||||||
|             this.filtrarProductos({ filtro: "nombre", valor: this.searchString }); |             this.filtrarProductos({ filtro: "nombre", valor: this.searchString }); | ||||||
|  |             this.popUltimaBusqueda(); | ||||||
|             this.addMiga({ nombre: this.searchString }); |             this.addMiga({ nombre: this.searchString }); | ||||||
|         } |         } | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
|  | @ -7,7 +7,7 @@ | ||||||
| 	        <div class="control"> | 	        <div class="control"> | ||||||
| 	        	<div class="select"> | 	        	<div class="select"> | ||||||
| 	        		<select @change="selectRegion({ region })" v-model="region"> | 	        		<select @change="selectRegion({ region })" v-model="region"> | ||||||
| 			    		<option :disabled="region_elegida !== null" value=null> | 			    		<option :disabled="region_elegida" value=null> | ||||||
|                             Seleccionar |                             Seleccionar | ||||||
|                         </option> |                         </option> | ||||||
| 						<option v-for="(region, index) in regiones" | 						<option v-for="(region, index) in regiones" | ||||||
|  | @ -25,6 +25,7 @@ | ||||||
| <script> | <script> | ||||||
| import {mapActions, mapGetters, mapState} from "vuex"; | import {mapActions, mapGetters, mapState} from "vuex"; | ||||||
| export default { | export default { | ||||||
|  |     name: 'RegionSelect', | ||||||
|     async mounted() { |     async mounted() { | ||||||
|         await this.getRegiones(); |         await this.getRegiones(); | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
							
								
								
									
										27
									
								
								resources/js/components/login/Titulos.vue
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								resources/js/components/login/Titulos.vue
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,27 @@ | ||||||
|  | <script> | ||||||
|  | import { mapGetters } from "vuex"; | ||||||
|  | 
 | ||||||
|  | export default { | ||||||
|  |     name:'LoginTitulos', | ||||||
|  |     computed: { | ||||||
|  |         ...mapGetters('login',["titulos", "urlRol"]), | ||||||
|  |         whiteText() { | ||||||
|  |             console.log(this.urlRol); | ||||||
|  |             return this.urlRol === 'admin'; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | }; | ||||||
|  | </script> | ||||||
|  | 
 | ||||||
|  | <template> | ||||||
|  | <div class="block"> | ||||||
|  |     <h1 class="title" :class="{'has-text-white': whiteText}">{{ titulos.titulo }}</h1> | ||||||
|  |     <p class="subtitle" :class="{'has-text-white': whiteText}"> | ||||||
|  |         {{ `Bienvenidx a la  ${titulos.subtitlo} del ` }}<strong :class="{'has-text-white': whiteText}">Mercado Popular de Subistencia</strong> | ||||||
|  |     </p> | ||||||
|  | </div> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <style scoped> | ||||||
|  | 
 | ||||||
|  | </style> | ||||||
|  | @ -1,29 +1,40 @@ | ||||||
| <template> | <template> | ||||||
|     <div id="pedidos-body"> |     <div id="pedidos-body"> | ||||||
|         <cartel-pedido-aprobado></cartel-pedido-aprobado> |         <pedido-select v-if="!pedidoDefinido"/> | ||||||
|         <pedido-select-section v-if="!pedidoDefinido"></pedido-select-section> |         <div v-else> | ||||||
|         <pedido v-else></pedido> |             <nav-migas/> | ||||||
|  |             <div class="columns"> | ||||||
|  |                 <div class="column" :class="{ 'is-two-thirds-desktop is-hidden-touch': show_chismosa }"> | ||||||
|  |                     <cartel-pedido-aprobado/> | ||||||
|  |                     <canasta/> | ||||||
|  |                 </div> | ||||||
|  |                 <div class="column is-full-touch" v-if="show_chismosa"> | ||||||
|  |                     <chismosa/> | ||||||
|  |                 </div> | ||||||
|  |             </div> | ||||||
|  |         </div> | ||||||
|     </div> |     </div> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script> | <script> | ||||||
| import { mapActions, mapGetters } from "vuex"; | import { mapActions, mapGetters, mapState } from "vuex"; | ||||||
| import PedidoSelectSection from "./PedidoSelectSection.vue"; |  | ||||||
| import Pedido from "./Pedido.vue"; |  | ||||||
| import CartelPedidoAprobado from "./CartelPedidoAprobado.vue"; | import CartelPedidoAprobado from "./CartelPedidoAprobado.vue"; | ||||||
|  | import PedidoSelect from "./PedidoSelect.vue"; | ||||||
|  | import Canasta from "./Canasta.vue"; | ||||||
|  | import NavMigas from "./NavMigas.vue"; | ||||||
|  | import Chismosa from "./Chismosa.vue"; | ||||||
| 
 | 
 | ||||||
| export default { | export default { | ||||||
|     components: { CartelPedidoAprobado, Pedido, Productos: Pedido, PedidoSelectSection }, |     components: { Chismosa, NavMigas, CartelPedidoAprobado, PedidoSelect, Canasta }, | ||||||
|     computed: { |     computed: { | ||||||
|         ...mapGetters('pedido',["pedidoDefinido"]), |         ...mapGetters('pedido', ["pedidoDefinido"]), | ||||||
|  |         ...mapState('ui', ["show_chismosa"]), | ||||||
|     }, |     }, | ||||||
|     methods: { |     methods: { | ||||||
|         ...mapActions('productos',["init"]), |         ...mapActions('productos', ["init"]), | ||||||
|         ...mapActions('pedido',["getSesion"]), |  | ||||||
|     }, |     }, | ||||||
|     async mounted() { |     async mounted() { | ||||||
|         await this.init(); |         await this.init(); | ||||||
|         await this.getSesion(); |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
|  | @ -1,18 +1,16 @@ | ||||||
| <script > | <script > | ||||||
| import { defineComponent } from "vue"; | import { defineComponent } from "vue"; | ||||||
| import { mapActions, mapState } from "vuex"; | import { mapState } from "vuex"; | ||||||
| import SubpedidoSelect from "./SubpedidoSelect.vue"; |  | ||||||
| import CategoriasContainer from "./CategoriasContainer.vue"; | import CategoriasContainer from "./CategoriasContainer.vue"; | ||||||
| import ProductosContainer from "./ProductosContainer.vue"; | import ProductosContainer from "./ProductosContainer.vue"; | ||||||
| import Chismosa from "./Chismosa.vue"; | import Chismosa from "./Chismosa.vue"; | ||||||
| import DevolucionesModal from "./DevolucionesModal.vue"; | import DevolucionesModal from "./DevolucionesModal.vue"; | ||||||
| import CartelPedidoAprobado from "./CartelPedidoAprobado.vue"; |  | ||||||
| 
 | 
 | ||||||
| export default defineComponent({ | export default defineComponent({ | ||||||
|     components: { CartelPedidoAprobado, DevolucionesModal, SubpedidoSelect, CategoriasContainer, ProductosContainer, Chismosa }, |     components: { DevolucionesModal, CategoriasContainer, ProductosContainer, Chismosa }, | ||||||
|     computed: { |     computed: { | ||||||
|         ...mapState('ui',["show_chismosa","show_devoluciones"]) |         ...mapState('ui', ["show_chismosa", "show_devoluciones"]) | ||||||
|     }, |     } | ||||||
| }) | }) | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
|  | @ -20,7 +18,6 @@ export default defineComponent({ | ||||||
|     <div class="columns ml-3 mr-3" v-else> |     <div class="columns ml-3 mr-3" v-else> | ||||||
|         <categorias-container :class="show_chismosa ? 'hide-below-1024' : ''"></categorias-container> |         <categorias-container :class="show_chismosa ? 'hide-below-1024' : ''"></categorias-container> | ||||||
|         <productos-container :class="show_chismosa ? 'hide-below-1024' : ''"></productos-container> |         <productos-container :class="show_chismosa ? 'hide-below-1024' : ''"></productos-container> | ||||||
|         <chismosa v-show="show_chismosa"></chismosa> |  | ||||||
|         <devoluciones-modal v-show="show_devoluciones"></devoluciones-modal> |         <devoluciones-modal v-show="show_devoluciones"></devoluciones-modal> | ||||||
|     </div> |     </div> | ||||||
| </template> | </template> | ||||||
|  | @ -1,39 +1,92 @@ | ||||||
| <template> | <template> | ||||||
|     <div v-show="visible" class="column"> |     <div v-show="visible" class="column"> | ||||||
|         <div class="columns is-multiline is-mobile"> |         <div ref="categorias" | ||||||
|  |              class="columns is-multiline is-mobile" | ||||||
|  |             :class="{ 'align-last-left': isLastRowIncomplete }"> | ||||||
|             <div v-for="(categoria,i) in categorias" :key="i" |             <div v-for="(categoria,i) in categorias" :key="i" | ||||||
|                  class="block column is-one-quarter-desktop is-one-third-tablet is-half-mobile"> |                  :class="{ 'is-3-desktop is-2-fullhd': !show_chismosa }" | ||||||
|                 <div @click.capture="seleccionar(categoria)" class="card" style="height:100%"> |                  class="column is-4-tablet is-6-mobile hover-dedito"> | ||||||
|  |                 <div @click.capture="seleccionar(categoria)" class="card" style="height: 100%"> | ||||||
|                     <div class="card-content"> |                     <div class="card-content"> | ||||||
|                         <div class="media"> |                         <div class="media"> | ||||||
|                             <div class="media-content" style="overflow:hidden"> |                             <div class="media-content" style="overflow: hidden"> | ||||||
|                                 <p class="title is-6" v-text="categoria"></p> |                                 <p class="title is-size-7-mobile is-size-6-tablet has-text-centered" v-text="categoria"></p> | ||||||
|                             </div> |                             </div> | ||||||
|                         </div> |                         </div> | ||||||
|                     </div> |                     </div> | ||||||
|                 </div><!-- END CARD --> |                 </div> | ||||||
|             </div><!-- END BLOCK COLUMN --> |             </div> | ||||||
|         </div><!-- END COLUMNS --> |         </div> | ||||||
|     </div><!-- END CONTAINER --> |     </div> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
| <script> | <script> | ||||||
| import { mapActions, mapMutations, mapState } from "vuex"; | import { mapActions, mapMutations, mapState } from "vuex"; | ||||||
| export default { | export default { | ||||||
|     name: 'CategoriasContainer', |     name: 'CategoriasContainer', | ||||||
|     computed: { |     computed: { | ||||||
|         ...mapState('productos',["categorias", "filtro"]), |         ...mapState('productos', ["categorias", "filtro"]), | ||||||
|  |         ...mapState('ui', ["show_chismosa"]), | ||||||
|         visible() { |         visible() { | ||||||
|             return this.filtro === null; |             return this.filtro === null; | ||||||
|         } |         } | ||||||
|     }, |     }, | ||||||
|     methods: { |     methods: { | ||||||
|         ...mapActions('productos',["seleccionarCategoria"]), |         ...mapActions('productos', ["seleccionarCategoria"]), | ||||||
|         ...mapMutations('ui',["addMiga"]), |         ...mapMutations('ui', ["addMiga"]), | ||||||
|         seleccionar(categoria) { |         seleccionar(categoria) { | ||||||
|             this.seleccionarCategoria({ categoria: categoria }); |             this.seleccionarCategoria({ categoria: categoria }); | ||||||
|             this.addMiga({ nombre: categoria }); |             this.addMiga({ nombre: categoria, action: "productos/seleccionarCategoria", arguments: { categoria: categoria }}); | ||||||
|  |         }, | ||||||
|  |         checkIfLastRowIncomplete() { | ||||||
|  |             this.$nextTick(() => { | ||||||
|  |                 const wrapper = this.$refs.categorias; | ||||||
|  |                 if (!wrapper) return; | ||||||
|  | 
 | ||||||
|  |                 const columns = wrapper.querySelectorAll('.column'); | ||||||
|  |                 if (columns.length === 0) { | ||||||
|  |                     this.isLastRowIncomplete = false; | ||||||
|  |                     return; | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 const firstRowTop = columns[0].offsetTop; | ||||||
|  |                 let firstRowCount = 0; | ||||||
|  |                 columns.forEach(col => { | ||||||
|  |                     if (col.offsetTop === firstRowTop) firstRowCount++; | ||||||
|  |                 }); | ||||||
|  |                 this.isLastRowIncomplete = this.categorias.length % firstRowCount !== 0; | ||||||
|  |             }); | ||||||
|         } |         } | ||||||
|     } |     }, | ||||||
|  |     data() { | ||||||
|  |         return { | ||||||
|  |             isLastRowIncomplete: false | ||||||
|  |         } | ||||||
|  |     }, | ||||||
|  |     mounted() { | ||||||
|  |         this.checkIfLastRowIncomplete(); | ||||||
|  |         window.addEventListener('resize', this.checkIfLastRowIncomplete); | ||||||
|  |     }, | ||||||
|  |     beforeDestroy() { | ||||||
|  |         window.removeEventListener('resize', this.checkIfLastRowIncomplete); | ||||||
|  |     }, | ||||||
| } | } | ||||||
| </script> | </script> | ||||||
|  | 
 | ||||||
|  | <style> | ||||||
|  | .hover-dedito { | ||||||
|  |     cursor: pointer; | ||||||
|  | } | ||||||
|  | .columns.align-last-left { | ||||||
|  |     justify-content: flex-start !important; | ||||||
|  | } | ||||||
|  | .columns.align-last-left > .column:last-child:nth-child(3n), | ||||||
|  | .columns.align-last-left > .column:last-child:nth-child(2n), | ||||||
|  | .columns.align-last-left > .column:last-child { | ||||||
|  |     margin-right: auto; | ||||||
|  | } | ||||||
|  | .title { | ||||||
|  |     word-break: keep-all; | ||||||
|  | } | ||||||
|  | </style> | ||||||
|  |  | ||||||
|  | @ -1,46 +1,44 @@ | ||||||
| <template> | <template> | ||||||
|     <div class="column is-one-third"> |     <div class="fixed-right mr-3 ml-3"> | ||||||
|         <div class="fixed-right"> |         <table v-show="mostrar_tabla" class="table is-striped is-bordered tabla-chismosa is-narrow"> | ||||||
|             <table v-show="mostrar_tabla" class="table is-striped is-bordered tabla-chismosa is-narrow"> |             <thead> | ||||||
|                 <thead> |             <tr> | ||||||
|                 <tr> |                 <th>Producto</th> | ||||||
|                     <th>Producto</th> |                 <th>Cantidad</th> | ||||||
|                     <th>Cantidad</th> |                 <th><abbr title="Precio Total">$</abbr></th> | ||||||
|                     <th><abbr title="Precio Total">$</abbr></th> |             </tr> | ||||||
|                 </tr> |             </thead> | ||||||
|                 </thead> |             <tfoot> | ||||||
|                 <tfoot> |             <tr> | ||||||
|                 <tr> |                 <th><abbr title="Bonos de Transporte">B. Transporte</abbr></th> | ||||||
|                     <th><abbr title="Bonos de Transporte">B. Transporte</abbr></th> |                 <th class="has-text-right">{{ cantidad_transporte }}</th> | ||||||
|                     <th class="has-text-right">{{ cantidad_transporte }}</th> |                 <th class="has-text-right">{{ total_transporte }}</th> | ||||||
|                     <th class="has-text-right">{{ total_transporte }}</th> |             </tr> | ||||||
|                 </tr> |             <tr v-if="grupo_de_compra.devoluciones_habilitadas"> | ||||||
|                 <tr v-if="devoluciones_habilitadas"> |                 <th><p>Devoluciones</p></th> | ||||||
|                     <th><p>Devoluciones</p></th> |                 <td> | ||||||
|                     <td> |                     <abbr :title="devoluciones_notas">{{ notas_abreviadas }}</abbr> | ||||||
|                         <abbr :title="devoluciones_notas">{{ notas_abreviadas }}</abbr> |                     <button @click.capture="toggleDevoluciones()" class="button is-warning is-small"> | ||||||
|                         <button @click.capture="toggleDevoluciones()" class="button is-warning is-small"> |                         <span class="icon"> | ||||||
|                             <span class="icon"> |                             <i class="fas fa-edit"></i> | ||||||
|                                 <i class="fas fa-edit"></i> |                         </span> | ||||||
|                             </span> |                     </button> | ||||||
|                         </button> |                 </td> | ||||||
|                     </td> |                 <th class="has-text-right">-{{ devoluciones_total }}</th> | ||||||
|                     <th class="has-text-right">-{{ devoluciones_total }}</th> |             </tr> | ||||||
|                 </tr> |             <tr> | ||||||
|                 <tr> |                 <th>Total total</th> | ||||||
|                     <th>Total total</th> |                 <th></th> | ||||||
|                     <th></th> |                 <th class="has-text-right">{{ total }}</th> | ||||||
|                     <th class="has-text-right">{{ total }}</th> |             </tr> | ||||||
|                 </tr> |             </tfoot> | ||||||
|                 </tfoot> |             <tbody> | ||||||
|                 <tbody> |             <producto-row v-for="producto in productos" :producto="producto" :key="producto.id"></producto-row> | ||||||
|                 <producto-row v-for="producto in productos" :producto="producto" :key="producto.id"></producto-row> |             </tbody> | ||||||
|                 </tbody> |         </table> | ||||||
|             </table> |         <p class="has-text-centered" v-show="!mostrar_tabla"> | ||||||
|             <p class="has-text-centered" v-show="!mostrar_tabla"> |             Compa, todavía no agregaste nada a la chismosa. | ||||||
|                 Compa, todavía no agregaste nada a la chismosa. |         </p> | ||||||
|             </p> |  | ||||||
|         </div> |  | ||||||
|     </div> |     </div> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
|  | @ -51,8 +49,8 @@ import { mapMutations, mapState } from "vuex"; | ||||||
| export default { | export default { | ||||||
|     components: { ProductoRow }, |     components: { ProductoRow }, | ||||||
|     computed: { |     computed: { | ||||||
|         ...mapState('barrio',["devoluciones_habilitadas"]), |  | ||||||
|         ...mapState('pedido',[ |         ...mapState('pedido',[ | ||||||
|  |             "grupo_de_compra", | ||||||
|             "productos", |             "productos", | ||||||
|             "total", |             "total", | ||||||
|             "total_transporte", |             "total_transporte", | ||||||
|  | @ -82,6 +80,5 @@ export default { | ||||||
|     position: fixed; |     position: fixed; | ||||||
|     overflow-y: auto; |     overflow-y: auto; | ||||||
|     max-height: 81vh; |     max-height: 81vh; | ||||||
|     margin-right: 20px; |  | ||||||
| } | } | ||||||
| </style> | </style> | ||||||
|  |  | ||||||
|  | @ -1,5 +1,5 @@ | ||||||
| <template> | <template> | ||||||
|     <nav v-if="pedidoDefinido" class="breadcrumb is-centered has-background-danger-light is-fixed-top" |     <nav class="breadcrumb is-centered has-background-danger-light is-fixed-top" | ||||||
|          aria-label="breadcrumbs" v-show="visible"> |          aria-label="breadcrumbs" v-show="visible"> | ||||||
|         <ul class="mt-4"> |         <ul class="mt-4"> | ||||||
|             <li v-for="(miga, i) in migas" :key="i" :class="{'is-active': i === migaActiva}"> |             <li v-for="(miga, i) in migas" :key="i" :class="{'is-active': i === migaActiva}"> | ||||||
|  | @ -11,22 +11,25 @@ | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script> | <script> | ||||||
| import { mapActions, mapGetters, mapState } from "vuex"; | import { mapActions, mapMutations, mapState } from "vuex"; | ||||||
| 
 | 
 | ||||||
| export default { | export default { | ||||||
|     methods: { |     methods: { | ||||||
|         ...mapActions('productos',["getProductos"]), |         ...mapActions('productos', ["getProductos"]), | ||||||
|         ...mapActions('ui',["clickMiga"]), |         ...mapActions('ui', ["clickMiga"]), | ||||||
|  |         ...mapMutations('ui', ["addMiga"]), | ||||||
|     }, |     }, | ||||||
|     computed: { |     computed: { | ||||||
|         ...mapState('ui',["migas"]), |         ...mapState('ui', ["migas"]), | ||||||
|         ...mapGetters('pedido',["pedidoDefinido"]), |  | ||||||
|         visible() { |         visible() { | ||||||
|             return this.migas.length > 0 |             return this.migas.length > 0; | ||||||
|         }, |         }, | ||||||
|         migaActiva() { |         migaActiva() { | ||||||
|             return this.migas.length - 1 |             return this.migas.length - 1; | ||||||
|         } |         }, | ||||||
|  |     }, | ||||||
|  |     mounted() { | ||||||
|  |         this.addMiga({ nombre: 'Categorias', action: 'productos/getProductos' }); | ||||||
|     }, |     }, | ||||||
| } | } | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
							
								
								
									
										114
									
								
								resources/js/components/pedidos/PedidoSelect.vue
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										114
									
								
								resources/js/components/pedidos/PedidoSelect.vue
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,114 @@ | ||||||
|  | <template> | ||||||
|  |     <section class="section"> | ||||||
|  |         <div id="root" class="container"> | ||||||
|  |             <h1 class="title"> | ||||||
|  |                 Pedidos MPS | ||||||
|  |             </h1> | ||||||
|  |             <p class="subtitle"> | ||||||
|  |                 Bienvenidx a la aplicación de pedidos del <strong>Mercado Popular de Subsistencia</strong> | ||||||
|  |             </p> | ||||||
|  | 
 | ||||||
|  |             <div> | ||||||
|  |                 <label class="label">Escribí el nombre de tu familia o grupo de convivencia</label> | ||||||
|  |                 <div class="columns"> | ||||||
|  |                     <div class="column is-two-thirds"> | ||||||
|  |                         <div class="field"> | ||||||
|  |                             <div class="control"> | ||||||
|  |                                 <input class="input" @input="onType" v-model="searchString"/> | ||||||
|  |                             </div> | ||||||
|  |                             <p class="help">Debe ser claro para que tus compas del barrio te identifiquen.</p> | ||||||
|  |                         </div> | ||||||
|  |                     </div> | ||||||
|  |                     <div class="column is-one-third buttons"> | ||||||
|  |                         <button class="button is-danger" v-if="!deshabilitado" @click="submit(undefined)"> | ||||||
|  |                             Crear nuevo pedido | ||||||
|  |                         </button> | ||||||
|  |                     </div> | ||||||
|  |                 </div> | ||||||
|  |                 <div v-if="pedidos.length" class="block"> | ||||||
|  |                     <label class="label"> | ||||||
|  |                         Si ya comenzaste a hacer tu pedido este mes, elegilo en esta lista: | ||||||
|  |                     </label> | ||||||
|  |                     <p class="help"> | ||||||
|  |                         Podés seguir escribiendo en el campo de arriba para refinar la búsqueda. | ||||||
|  |                     </p> | ||||||
|  |                     <div class="columns is-mobile" | ||||||
|  |                          v-for="(subpedidoExistente, index) in pedidos" | ||||||
|  |                          :class="{'has-background-grey-lighter': index % 2}" | ||||||
|  |                          :key="index"> | ||||||
|  |                         <div class="column is-half-mobile is-two-thirds-desktop is-two-thirds-tablet"> | ||||||
|  |                             <p class="nombre"> | ||||||
|  |                                 {{ subpedidoExistente.nombre }} | ||||||
|  |                             </p> | ||||||
|  |                         </div> | ||||||
|  |                         <div class="buttons column is-half-mobile is-one-third-desktop is-one-third-tablet"> | ||||||
|  |                             <button class="button is-danger" @click="submit(subpedidoExistente)"> | ||||||
|  |                                 Continuar pedido | ||||||
|  |                             </button> | ||||||
|  |                         </div> | ||||||
|  |                     </div> | ||||||
|  |                 </div> | ||||||
|  |             </div> | ||||||
|  |         </div> | ||||||
|  |     </section> | ||||||
|  | </template><script> | ||||||
|  | import { mapActions, mapMutations, mapState } from "vuex"; | ||||||
|  | import axios from "axios"; | ||||||
|  | 
 | ||||||
|  | export default { | ||||||
|  |     name: 'PedidoSelect', | ||||||
|  |     async mounted() { | ||||||
|  |         await this.getGrupoDeCompra(); | ||||||
|  |         const sesion = await axios.get("/pedido/sesion"); | ||||||
|  |         if (sesion.data.id) { | ||||||
|  |             await this.elegirPedido({ pedido_id: sesion.data.id }); | ||||||
|  |         } | ||||||
|  |     }, | ||||||
|  |     data() { | ||||||
|  |         return { | ||||||
|  |             pedidos: [], | ||||||
|  |             searchString: null, | ||||||
|  |         } | ||||||
|  |     }, | ||||||
|  |     computed: { | ||||||
|  |         ...mapState('pedido', ["grupo_de_compra"]), | ||||||
|  |         deshabilitado: function () { | ||||||
|  |             return !this.searchString?.trim() | ||||||
|  |                 || this.pedidos.some(p => p.nombre.toLowerCase() === this.searchString.toLowerCase()) | ||||||
|  |         } | ||||||
|  |     }, | ||||||
|  |     methods: { | ||||||
|  |         ...mapActions('pedido', ["getGrupoDeCompra", "crearPedido", "elegirPedido"]), | ||||||
|  |         async getPedidos(nombre) { | ||||||
|  |             const response = await axios.get('/api/subpedidos/',{ | ||||||
|  |                 params: { | ||||||
|  |                     nombre: nombre, | ||||||
|  |                     grupo_de_compra: this.grupo_de_compra.id | ||||||
|  |                 } | ||||||
|  |             }); | ||||||
|  |             this.pedidos = response.data; | ||||||
|  |         }, | ||||||
|  |         onType() { | ||||||
|  |             if (!this.searchString) { | ||||||
|  |                 this.setPedidos([]); | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |             this.getPedidos(this.searchString); | ||||||
|  |         }, | ||||||
|  |         async submit(pedido) { | ||||||
|  |             if (pedido) | ||||||
|  |                 await this.elegirPedido({ pedido_id: pedido.id }); | ||||||
|  |             else | ||||||
|  |                 await this.crearPedido({ nombre: this.searchString, grupo_de_compra_id: this.grupo_de_compra.id }); | ||||||
|  |         }, | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | </script> | ||||||
|  | 
 | ||||||
|  | <style> | ||||||
|  | .nombre { | ||||||
|  |     padding-top: calc(.5em - 1px); | ||||||
|  |     margin-bottom: .5rem | ||||||
|  | } | ||||||
|  | </style> | ||||||
|  | 
 | ||||||
|  | @ -1,26 +0,0 @@ | ||||||
| <script> |  | ||||||
| import { defineComponent } from "vue"; |  | ||||||
| import SubpedidoSelect from "./SubpedidoSelect.vue"; |  | ||||||
| import { mapGetters } from "vuex"; |  | ||||||
| 
 |  | ||||||
| export default defineComponent({ |  | ||||||
|     components: { SubpedidoSelect }, |  | ||||||
| }) |  | ||||||
| </script> |  | ||||||
| 
 |  | ||||||
| <template> |  | ||||||
|     <section class="section"> |  | ||||||
|         <div id="root" class="container"> |  | ||||||
|             <h1 class="title"> |  | ||||||
|                 Pedidos MPS |  | ||||||
|             </h1> |  | ||||||
|             <p class="subtitle"> |  | ||||||
|                 Bienvenidx a la aplicación de pedidos del <strong>Mercado Popular de Subsistencia</strong> |  | ||||||
|             </p> |  | ||||||
|             <subpedido-select></subpedido-select> |  | ||||||
|         </div> |  | ||||||
|     </section> |  | ||||||
| </template> |  | ||||||
| 
 |  | ||||||
| <style scoped> |  | ||||||
| </style> |  | ||||||
|  | @ -1,32 +1,37 @@ | ||||||
| <template> | <template> | ||||||
|     <div> |     <div class="is-justify-content-center"> | ||||||
|         <div class="field has-addons contador"> |         <div class="field has-addons is-justify-content-center contador"> | ||||||
|             <div class="control"> |             <div class="control"> | ||||||
|                 <button class="button is-small" @click.capture="decrementar();"> |                 <button class="button is-small" :disabled="cantidadControl < 1" v-if="!aprobado"  @click.capture="decrementar();"> | ||||||
|                     <i class="fa fa-solid fa-minus"></i> |                     <i class="fa fa-solid fa-minus"></i> | ||||||
|                 </button> |                 </button> | ||||||
|             </div> |             </div> | ||||||
|             <div class="control"> |             <div class="control"> | ||||||
|                 <input id="cantidad" v-model="cantidadControl" class="input is-small" type="number" |                 <input id="cantidad" | ||||||
|                        style="text-align: center"> |                        v-model="cantidadControl" | ||||||
|  |                        class="input is-small" | ||||||
|  |                        type="number" | ||||||
|  |                        style="text-align: center" | ||||||
|  |                        :readonly="aprobado"> | ||||||
|             </div> |             </div> | ||||||
|             <div class="control" @click="incrementar();"> |             <div class="control"> | ||||||
|                 <button class="button is-small"> |                 <button class="button is-small" v-if="!aprobado" @click="incrementar();"> | ||||||
|                     <i class="fa fa-solid fa-plus"></i> |                     <i class="fa fa-solid fa-plus"></i> | ||||||
|                 </button> |                 </button> | ||||||
|             </div> |             </div> | ||||||
|             <button :disabled="!hayCambios" class="button is-small is-success ml-1" @click="confirmar()"> |             <button :disabled="!hayCambios || cantidadControl < 0" v-if="!aprobado" class="button is-small is-success ml-1" @click="confirmar()"> | ||||||
|                 <span class="icon"> |                 <span class="icon"> | ||||||
|                     <i class="fas fa-check"></i> |                     <i class="fas fa-check"></i> | ||||||
|                 </span> |                 </span> | ||||||
|             </button> |             </button> | ||||||
|             <button :disabled="!puedeBorrar" class="button is-small is-danger ml-1" @click="borrar()"> |             <button :disabled="!puedeBorrar" v-if="!aprobado"  class="button is-small is-danger ml-1" @click="borrar()"> | ||||||
|                 <span class="icon"> |                 <span class="icon"> | ||||||
|                     <i class="fas fa-trash-alt"></i> |                     <i class="fas fa-trash-alt"></i> | ||||||
|                 </span> |                 </span> | ||||||
|             </button> |             </button> | ||||||
|         </div> |         </div> | ||||||
|         <div v-if="requiere_notas" :class="{'has-icons-right': notas_warning_visible}" |         <div v-if="!aprobado && requiere_notas" | ||||||
|  |              :class="{'has-icons-right': notas_warning_visible}" | ||||||
|              class="control is-full-width has-icons-left"> |              class="control is-full-width has-icons-left"> | ||||||
|             <span class="icon is-small is-left"> |             <span class="icon is-small is-left"> | ||||||
|                 <i class="fas fa-sticky-note"></i> |                 <i class="fas fa-sticky-note"></i> | ||||||
|  | @ -45,7 +50,7 @@ | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script> | <script> | ||||||
| import { mapActions, mapGetters } from "vuex"; | import { mapActions, mapGetters, mapState } from "vuex"; | ||||||
| 
 | 
 | ||||||
| export default { | export default { | ||||||
|     props: { |     props: { | ||||||
|  | @ -77,6 +82,7 @@ export default { | ||||||
|         this.actualizar(); |         this.actualizar(); | ||||||
|     }, |     }, | ||||||
|     computed: { |     computed: { | ||||||
|  |         ...mapState('pedido', ["aprobado"]), | ||||||
|         ...mapGetters('pedido', ["enChismosa", "cantidad", "notas"]), |         ...mapGetters('pedido', ["enChismosa", "cantidad", "notas"]), | ||||||
|         cantidadEnChismosa() { |         cantidadEnChismosa() { | ||||||
|             return this.cantidad(this.producto_id); |             return this.cantidad(this.producto_id); | ||||||
|  | @ -88,7 +94,7 @@ export default { | ||||||
|             return this.cantidadControl !== this.cantidadEnChismosa || this.notasControl !== this.notasEnChismosa; |             return this.cantidadControl !== this.cantidadEnChismosa || this.notasControl !== this.notasEnChismosa; | ||||||
|         }, |         }, | ||||||
|         puedeBorrar() { |         puedeBorrar() { | ||||||
|             return this.enChismosa(this.producto_id); |             return this.enChismosa(this.producto_id) && !this.aprobado; | ||||||
|         }, |         }, | ||||||
|         faltaNotas() { |         faltaNotas() { | ||||||
|             return this.requiere_notas && this.cantidadControl > 0 && !this.notasControl; |             return this.requiere_notas && this.cantidadControl > 0 && !this.notasControl; | ||||||
|  | @ -140,7 +146,7 @@ input[type=number] { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .contador { | .contador { | ||||||
|     min-width: 178px; |     min-width: 1.5rem; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .is-danger { | .is-danger { | ||||||
|  |  | ||||||
|  | @ -1,6 +1,6 @@ | ||||||
| <script> | <script> | ||||||
| import ProductoCantidad from "./ProductoCantidad.vue"; | import ProductoCantidad from "./ProductoCantidad.vue"; | ||||||
| import { mapGetters } from "vuex"; | import { mapGetters, mapState } from "vuex"; | ||||||
| 
 | 
 | ||||||
| export default { | export default { | ||||||
|     name: "ProductoCard", |     name: "ProductoCard", | ||||||
|  | @ -12,49 +12,57 @@ export default { | ||||||
|         } |         } | ||||||
|     }, |     }, | ||||||
|     computed: { |     computed: { | ||||||
|         ...mapGetters('pedido',["enChismosa", "cantidad"]), |         ...mapState('ui', ["show_chismosa"]), | ||||||
|  |         ...mapState('pedido', ["aprobado"]), | ||||||
|  |         ...mapGetters('pedido', ["enChismosa", "cantidad"]), | ||||||
|         fuePedido() { |         fuePedido() { | ||||||
|             return this.enChismosa(this.producto.id); |             return this.enChismosa(this.producto.id); | ||||||
|         }, |         }, | ||||||
|         cantidadEnChismosa() { |         cantidadEnChismosa() { | ||||||
|             return this.cantidad(this.producto.id); |             return this.cantidad(this.producto.id); | ||||||
|  |         }, | ||||||
|  |         conIconos() { | ||||||
|  |             return this.producto.economia_solidaria || this.producto.nacional; | ||||||
|         } |         } | ||||||
|     }, |     }, | ||||||
| } | } | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
|     <div class="block column is-one-quarter-desktop is-full-mobile is-half-tablet min-width-from-desktop"> |     <div class="box" style="height:100%"> | ||||||
|         <div class="box" style="height:100%"> |         <div class="columns is-mobile"> | ||||||
|             <div class="columns"> |             <div class="column"> | ||||||
|                 <div class="column"> |                 <p class="title is-6"> | ||||||
|                     <p class="title is-6"> |                     {{ producto.nombre }} | ||||||
|                         {{ producto.nombre }} |                 </p> | ||||||
|                     </p> |  | ||||||
|                     <span class="subtitle is-7 hidden-from-tablet" v-if="fuePedido">{{ cantidadEnChismosa }}</span> |  | ||||||
|                 </div> |  | ||||||
|                 <div class="column is-one-quarter has-text-right"> |  | ||||||
|                     <p class="has-text-weight-bold has-text-primary"> |  | ||||||
|                         <span class="is-left-mobile"> |  | ||||||
|                             <img v-show="producto.economia_solidaria" height="30px" width="30px" src="/assets/solidaria.png" alt="proveedor de economía solidaria"> |  | ||||||
|                             <img v-show="producto.nacional" height="30px" width="30px" src="/assets/uruguay.png" alt="proveedor nacional"/> |  | ||||||
|                         </span> |  | ||||||
|                         $<span v-text="producto.precio"></span> |  | ||||||
|                     </p> |  | ||||||
|                 </div> |  | ||||||
|             </div> |             </div> | ||||||
|             <footer class="columns"> |             <div class="column is-one-quarter has-text-right"> | ||||||
|                 <div class="column is-three-quarters"> |                 <p class="has-text-weight-bold has-text-primary block"> | ||||||
|  |                     ${{ producto.precio }} | ||||||
|  |                 </p> | ||||||
|  |             </div> | ||||||
|  |         </div> | ||||||
|  |         <footer> | ||||||
|  |             <div class="columns is-justify-content-left is-mobile"> | ||||||
|  |                 <div v-if="conIconos" class="column has-text-left"> | ||||||
|  |                     <span> | ||||||
|  |                         <img v-show="producto.economia_solidaria" height="30px" width="30px" src="/assets/solidaria.png" alt="proveedor de economía solidaria"> | ||||||
|  |                         <img v-show="producto.nacional" height="30px" width="30px" src="/assets/uruguay.png" alt="proveedor nacional"/> | ||||||
|  |                     </span> | ||||||
|  |                 </div> | ||||||
|  |                 <div class="column" | ||||||
|  |                      :class="conIconos ? 'is-three-quarters-mobile is-two-thirds-tablet' : 'is-full'"> | ||||||
|                     <producto-cantidad |                     <producto-cantidad | ||||||
|  |                         v-if="!aprobado" | ||||||
|                         :producto_id="producto.id" |                         :producto_id="producto.id" | ||||||
|                         :requiere_notas="producto.requiere_notas"> |                         :requiere_notas="producto.requiere_notas"> | ||||||
|                     </producto-cantidad> |                     </producto-cantidad> | ||||||
|  |                     <div class="has-text-centered mt-2" v-if="fuePedido && aprobado"> | ||||||
|  |                         <p class="subtitle is-7">{{ cantidadEnChismosa }} en chismosa</p> | ||||||
|  |                     </div> | ||||||
|                 </div> |                 </div> | ||||||
|                 <div class="column"> |             </div> | ||||||
|                     <p class="subtitle is-7 is-hidden-mobile" v-if="fuePedido">{{ cantidadEnChismosa }} en chismosa</p> |         </footer> | ||||||
|                 </div> |  | ||||||
|             </footer> |  | ||||||
|         </div> |  | ||||||
|     </div> |     </div> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1,13 +1,13 @@ | ||||||
| <template> | <template> | ||||||
| 	<tr> | 	<tr> | ||||||
|             <td>{{ this.producto.nombre }}</td> |         <td>{{ this.producto.nombre }}</td> | ||||||
|             <td class="has-text-right"> |         <td class="has-text-right"> | ||||||
|                 <producto-cantidad |             <producto-cantidad | ||||||
|                     :producto_id="producto.id" |                 :producto_id="producto.id" | ||||||
|                     :requiere_notas="producto.requiere_notas"> |                 :requiere_notas="producto.requiere_notas"> | ||||||
|                 </producto-cantidad> |             </producto-cantidad> | ||||||
|             </td> |         </td> | ||||||
|             <td class="has-text-right">{{ cantidad(producto.id) }}</td> |         <td class="has-text-right">{{ cantidad(producto.id) }}</td> | ||||||
|     </tr> |     </tr> | ||||||
| </template> | </template> | ||||||
| <script> | <script> | ||||||
|  |  | ||||||
|  | @ -1,11 +1,15 @@ | ||||||
| <template> | <template> | ||||||
|     <div v-show="visible" class="column"> |     <div v-show="visible" class="column"> | ||||||
|         <div class="columns is-multiline is-mobile"> |         <div ref="productos" | ||||||
|             <producto-card |              class="columns is-multiline is-mobile" | ||||||
|                 v-for="(producto,i) in this.productos" |              :class="{ 'align-last-left': isLastRowIncomplete }"> | ||||||
|                 :key="i" |             <div v-for="(producto,i) in this.productos" | ||||||
|                 :producto="producto"> |                  class="block column is-full-mobile is-half-tablet is-one-quarter-fullhd" | ||||||
|             </producto-card> |                 :class="show_chismosa ? 'is-half-desktop' : 'is-one-third-desktop'"> | ||||||
|  |                 <producto-card :key="i" | ||||||
|  |                     :producto="producto"> | ||||||
|  |                 </producto-card> | ||||||
|  |             </div> | ||||||
|         </div> |         </div> | ||||||
|     </div> |     </div> | ||||||
| </template> | </template> | ||||||
|  | @ -18,6 +22,7 @@ export default { | ||||||
|     components: { ProductoCard }, |     components: { ProductoCard }, | ||||||
|     computed: { |     computed: { | ||||||
|         ...mapState('productos', ["productos", "filtro"]), |         ...mapState('productos', ["productos", "filtro"]), | ||||||
|  |         ...mapState('ui', ["show_chismosa"]), | ||||||
|         visible() { |         visible() { | ||||||
|             return this.filtro !== null; |             return this.filtro !== null; | ||||||
|         }, |         }, | ||||||
|  | @ -28,5 +33,49 @@ export default { | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     }, |     }, | ||||||
|  |     methods: { | ||||||
|  |         checkIfLastRowIncomplete() { | ||||||
|  |             this.$nextTick(() => { | ||||||
|  |                 const wrapper = this.$refs.productos; | ||||||
|  |                 if (!wrapper) return; | ||||||
|  | 
 | ||||||
|  |                 const columns = wrapper.querySelectorAll('.column'); | ||||||
|  |                 if (columns.length === 0) { | ||||||
|  |                     this.isLastRowIncomplete = false; | ||||||
|  |                     return; | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 const firstRowTop = columns[0].offsetTop; | ||||||
|  |                 let firstRowCount = 0; | ||||||
|  |                 columns.forEach(col => { | ||||||
|  |                     if (col.offsetTop === firstRowTop) firstRowCount++; | ||||||
|  |                 }); | ||||||
|  |                 this.isLastRowIncomplete = this.productos.length % firstRowCount !== 0; | ||||||
|  |             }); | ||||||
|  |         } | ||||||
|  |     }, | ||||||
|  |     data() { | ||||||
|  |         return { | ||||||
|  |             isLastRowIncomplete: false | ||||||
|  |         } | ||||||
|  |     }, | ||||||
|  |     mounted() { | ||||||
|  |         this.checkIfLastRowIncomplete(); | ||||||
|  |         window.addEventListener('resize', this.checkIfLastRowIncomplete); | ||||||
|  |     }, | ||||||
|  |     beforeDestroy() { | ||||||
|  |         window.removeEventListener('resize', this.checkIfLastRowIncomplete); | ||||||
|  |     }, | ||||||
| } | } | ||||||
| </script> | </script> | ||||||
|  | 
 | ||||||
|  | <style> | ||||||
|  | .columns.align-last-left { | ||||||
|  |     justify-content: flex-start !important; | ||||||
|  | } | ||||||
|  | .columns.align-last-left > .column:last-child:nth-child(3n), | ||||||
|  | .columns.align-last-left > .column:last-child:nth-child(2n), | ||||||
|  | .columns.align-last-left > .column:last-child { | ||||||
|  |     margin-right: auto; | ||||||
|  | } | ||||||
|  | </style> | ||||||
|  |  | ||||||
|  | @ -1,73 +0,0 @@ | ||||||
| <template> |  | ||||||
|     <div> |  | ||||||
|         <label class="label">Escribí el nombre de tu familia o grupo de convivencia</label> |  | ||||||
|         <div class="columns"> |  | ||||||
|             <div class="column is-two-thirds"> |  | ||||||
|                 <div class="field"> |  | ||||||
|                     <div class="control"> |  | ||||||
|                         <input class="input" @input="onType" v-model="searchString"/> |  | ||||||
|                     </div> |  | ||||||
|                     <p class="help">Debe ser claro para que tus compas del barrio te identifiquen.</p> |  | ||||||
|                 </div> |  | ||||||
|             </div> |  | ||||||
|             <div class="column is-one-third buttons"> |  | ||||||
|                 <button class="button is-danger" v-if="!deshabilitado" @click="submit">Crear nuevo pedido |  | ||||||
|                 </button> |  | ||||||
|             </div> |  | ||||||
|         </div> |  | ||||||
|         <div v-if="pedidos.length" class="block"> |  | ||||||
|             <label class="label">Si ya comenzaste a hacer tu pedido este mes, elegilo en esta lista:</label> |  | ||||||
|             <p class="help">Podés seguir escribiendo en el campo de arriba para refinar la búsqueda.</p> |  | ||||||
|             <div class="columns is-mobile" v-for="(subpedidoExistente, index) in pedidos" |  | ||||||
|                  :class="{'has-background-grey-lighter': index % 2}" :key="index"> |  | ||||||
|                 <div class="column is-half-mobile is-two-thirds-desktop is-two-thirds-tablet"> |  | ||||||
|                     <p style="padding-top: calc(.5em - 1px); margin-bottom: .5rem" |  | ||||||
|                        v-text="subpedidoExistente.nombre"></p> |  | ||||||
|                 </div> |  | ||||||
|                 <div class="buttons column is-half-mobile is-one-third-desktop is-one-third-tablet"> |  | ||||||
|                     <button class="button is-danger" @click="elegirPedido({ pedido: subpedidoExistente })">Continuar pedido |  | ||||||
|                     </button> |  | ||||||
|                 </div> |  | ||||||
|             </div> |  | ||||||
|         </div> |  | ||||||
|     </div> |  | ||||||
| </template> |  | ||||||
| 
 |  | ||||||
| <script> |  | ||||||
| import { mapActions, mapMutations, mapState } from "vuex"; |  | ||||||
| 
 |  | ||||||
| export default { |  | ||||||
|     name: 'SubpedidoSelect', |  | ||||||
|     async mounted() { |  | ||||||
|         await this.getGrupoDeCompra(); |  | ||||||
|     }, |  | ||||||
|     data() { |  | ||||||
|         return { |  | ||||||
|             searchString: null |  | ||||||
|         } |  | ||||||
|     }, |  | ||||||
|     computed: { |  | ||||||
|         ...mapState('barrio',["grupo_de_compra_id","pedidos"]), |  | ||||||
|         ...mapState('pedido',["nombre","pedido_id"]), |  | ||||||
|         deshabilitado: function () { |  | ||||||
|             return !this.searchString?.trim() |  | ||||||
|                 || this.pedidos.some(p => p.nombre.toLowerCase() === this.searchString.toLowerCase()) |  | ||||||
|         } |  | ||||||
|     }, |  | ||||||
|     methods: { |  | ||||||
|         ...mapActions('barrio',["getGrupoDeCompra","getPedidos"]), |  | ||||||
|         ...mapActions('pedido',["crearPedido","elegirPedido"]), |  | ||||||
|         ...mapMutations('barrio',["setPedidos"]), |  | ||||||
|         onType() { |  | ||||||
|             if (!this.searchString) { |  | ||||||
|                 this.setPedidos([]); |  | ||||||
|                 return; |  | ||||||
|             } |  | ||||||
|             this.getPedidos(this.searchString); |  | ||||||
|         }, |  | ||||||
|         async submit() { |  | ||||||
|             await this.crearPedido({ nombre: this.searchString, grupo_de_compra_id: this.grupo_de_compra_id }); |  | ||||||
|         }, |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| </script> |  | ||||||
							
								
								
									
										2
									
								
								resources/js/store/index.js
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								resources/js/store/index.js
									
										
									
									
										vendored
									
									
								
							|  | @ -3,7 +3,6 @@ import Vuex from 'vuex'; | ||||||
| import admin from "./modules/admin"; | import admin from "./modules/admin"; | ||||||
| import login from "./modules/login"; | import login from "./modules/login"; | ||||||
| import pedido from "./modules/pedido"; | import pedido from "./modules/pedido"; | ||||||
| import barrio from "./modules/barrio"; |  | ||||||
| import productos from "./modules/productos"; | import productos from "./modules/productos"; | ||||||
| import ui from "./modules/ui"; | import ui from "./modules/ui"; | ||||||
| 
 | 
 | ||||||
|  | @ -14,7 +13,6 @@ export default new Vuex.Store({ | ||||||
|         admin, |         admin, | ||||||
|         login, |         login, | ||||||
|         pedido, |         pedido, | ||||||
|         barrio, |  | ||||||
|         productos, |         productos, | ||||||
|         ui, |         ui, | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
							
								
								
									
										8
									
								
								resources/js/store/modules/admin.js
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								resources/js/store/modules/admin.js
									
										
									
									
										vendored
									
									
								
							|  | @ -7,6 +7,7 @@ const state = { | ||||||
|     devoluciones_habilitadas: null, |     devoluciones_habilitadas: null, | ||||||
|     pedidos: null, |     pedidos: null, | ||||||
|     total_a_recaudar: null, |     total_a_recaudar: null, | ||||||
|  |     total_sin_devoluciones: null, | ||||||
|     total_barrial: null, |     total_barrial: null, | ||||||
|     total_devoluciones: null, |     total_devoluciones: null, | ||||||
|     total_a_transferir: null, |     total_a_transferir: null, | ||||||
|  | @ -22,6 +23,7 @@ const mutations = { | ||||||
|         state.devoluciones_habilitadas = grupo_de_compra.devoluciones_habilitadas; |         state.devoluciones_habilitadas = grupo_de_compra.devoluciones_habilitadas; | ||||||
|         state.pedidos = grupo_de_compra.pedidos; |         state.pedidos = grupo_de_compra.pedidos; | ||||||
|         state.total_a_recaudar = grupo_de_compra.total_a_recaudar; |         state.total_a_recaudar = grupo_de_compra.total_a_recaudar; | ||||||
|  |         state.total_sin_devoluciones = grupo_de_compra.total_sin_devoluciones; | ||||||
|         state.total_barrial = grupo_de_compra.total_barrial; |         state.total_barrial = grupo_de_compra.total_barrial; | ||||||
|         state.total_devoluciones = grupo_de_compra.total_devoluciones; |         state.total_devoluciones = grupo_de_compra.total_devoluciones; | ||||||
|         state.total_a_transferir = grupo_de_compra.total_a_transferir; |         state.total_a_transferir = grupo_de_compra.total_a_transferir; | ||||||
|  | @ -56,16 +58,16 @@ const getters = { | ||||||
|       return state.lastFetch !== null; |       return state.lastFetch !== null; | ||||||
|     }, |     }, | ||||||
|     hayPedidos() { |     hayPedidos() { | ||||||
|         return getters.grupoDeCompraDefinido() && state.pedidos.length > 0; |         return state.pedidos?.length > 0; | ||||||
|     }, |     }, | ||||||
|     pedidosAprobados() { |     pedidosAprobados() { | ||||||
|         return getters.grupoDeCompraDefinido() ? state.pedidos.filter(p => p.aprobado) : []; |         return state.pedidos?.filter(p => p.aprobado) ?? []; | ||||||
|     }, |     }, | ||||||
|     hayAprobados() { |     hayAprobados() { | ||||||
|         return getters.pedidosAprobados().length !== 0; |         return getters.pedidosAprobados().length !== 0; | ||||||
|     }, |     }, | ||||||
|     getPedido() { |     getPedido() { | ||||||
|         return (pedido_id) => state.pedidos.find(p => p.id === pedido_id); |         return (pedido_id) => state.pedidos?.find(p => p.id === pedido_id); | ||||||
|     }, |     }, | ||||||
|     getCaracteristica() { |     getCaracteristica() { | ||||||
|         return (caracteristica) => state[`${caracteristica}_habilitadas`]; |         return (caracteristica) => state[`${caracteristica}_habilitadas`]; | ||||||
|  |  | ||||||
							
								
								
									
										42
									
								
								resources/js/store/modules/barrio.js
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										42
									
								
								resources/js/store/modules/barrio.js
									
										
									
									
										vendored
									
									
								
							|  | @ -1,42 +0,0 @@ | ||||||
| import axios from "axios"; |  | ||||||
| 
 |  | ||||||
| const state = { |  | ||||||
|     grupo_de_compra_id: null, |  | ||||||
|     grupo_de_compra: null, |  | ||||||
|     devoluciones_habilitadas: null, |  | ||||||
|     pedidos: [], |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| const mutations = { |  | ||||||
|     setGrupoDeCompra(state, { grupo_de_compra }) { |  | ||||||
|         state.grupo_de_compra_id = grupo_de_compra.id; |  | ||||||
|         state.grupo_de_compra = grupo_de_compra.nombre; |  | ||||||
|         state.devoluciones_habilitadas = grupo_de_compra.devoluciones_habilitadas; |  | ||||||
|     }, |  | ||||||
|     setPedidos(state, pedidos) { |  | ||||||
|         state.pedidos = pedidos; |  | ||||||
|     }, |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| const actions = { |  | ||||||
|     async getGrupoDeCompra({ commit }) { |  | ||||||
|         const response = await axios.get('/user/grupo_de_compra'); |  | ||||||
|         commit('setGrupoDeCompra', response.data); |  | ||||||
|     }, |  | ||||||
|     async getPedidos({ commit }, nombre) { |  | ||||||
|         const response = await axios.get('/api/subpedidos/',{ |  | ||||||
|             params: { |  | ||||||
|                 nombre: nombre, |  | ||||||
|                 grupo_de_compra: state.grupo_de_compra_id |  | ||||||
|             } |  | ||||||
|         }); |  | ||||||
|         commit('setPedidos', response.data); |  | ||||||
|     } |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| export default { |  | ||||||
|     namespaced: true, |  | ||||||
|     state, |  | ||||||
|     mutations, |  | ||||||
|     actions, |  | ||||||
| }; |  | ||||||
							
								
								
									
										25
									
								
								resources/js/store/modules/login.js
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										25
									
								
								resources/js/store/modules/login.js
									
										
									
									
										vendored
									
									
								
							|  | @ -30,8 +30,8 @@ const actions = { | ||||||
|         commit('setRegiones', { regiones: response.data }); |         commit('setRegiones', { regiones: response.data }); | ||||||
|     }, |     }, | ||||||
|     async selectRegion({ commit }, { region }) { |     async selectRegion({ commit }, { region }) { | ||||||
|         const response = await axios.get("/api/grupos-de-compra"); |         const response = await axios.get(`/api/regiones/${region}`); | ||||||
|         commit('setRegionYBarrios', { region: region, grupos_de_compra: response.data[region] }); |         commit('setRegionYBarrios', { region: region, grupos_de_compra: response.data }); | ||||||
|     }, |     }, | ||||||
|     async getRol({ commit }) { |     async getRol({ commit }) { | ||||||
|         const response = await axios.get("/user/rol"); |         const response = await axios.get("/user/rol"); | ||||||
|  | @ -49,6 +49,27 @@ const getters = { | ||||||
|             ayuda: `Si no la sabés, consultá a ${getters.adminUrl() ? 'la comisión informática ' : 'tus compañerxs'}.` |             ayuda: `Si no la sabés, consultá a ${getters.adminUrl() ? 'la comisión informática ' : 'tus compañerxs'}.` | ||||||
|         }; |         }; | ||||||
|     }, |     }, | ||||||
|  |     urlRol() { | ||||||
|  |         let split = window.location.pathname | ||||||
|  |             .replace('login', '') | ||||||
|  |             .split('/') | ||||||
|  |             .filter(x => x.length); | ||||||
|  |         return split[0] ?? 'pedido'; | ||||||
|  |     }, | ||||||
|  |     titulos() { | ||||||
|  |         let rol = getters.urlRol(); | ||||||
|  |         switch (rol) { | ||||||
|  |             case 'admin': | ||||||
|  |                 return { titulo: "Administración de Pedidos MPS", subtitlo: "administración de pedidos" }; | ||||||
|  |             case 'compras': | ||||||
|  |                 return { titulo: "Comisiones MPS", subtitlo: "página de comisiones" }; | ||||||
|  |             case 'pedido': | ||||||
|  |                 return { titulo: "Pedidos MPS", subtitlo: "aplicación de pedidos" }; | ||||||
|  |             default: | ||||||
|  |                 throw new Error("Url inválida"); | ||||||
|  |         } | ||||||
|  |     }, | ||||||
|  | 
 | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| export default { | export default { | ||||||
|  |  | ||||||
							
								
								
									
										52
									
								
								resources/js/store/modules/pedido.js
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										52
									
								
								resources/js/store/modules/pedido.js
									
										
									
									
										vendored
									
									
								
							|  | @ -2,6 +2,7 @@ import axios from "axios"; | ||||||
| 
 | 
 | ||||||
| const state = { | const state = { | ||||||
|     lastFetch: null, |     lastFetch: null, | ||||||
|  |     grupo_de_compra: null, | ||||||
|     pedido_id: null, |     pedido_id: null, | ||||||
|     nombre: null, |     nombre: null, | ||||||
|     productos: null, |     productos: null, | ||||||
|  | @ -15,7 +16,10 @@ const state = { | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| const mutations = { | const mutations = { | ||||||
|     setState(state, pedido) { |     setGrupoDeCompra(state, grupo_de_compra) { | ||||||
|  |         state.grupo_de_compra = grupo_de_compra; | ||||||
|  |     }, | ||||||
|  |     setPedido(state, pedido) { | ||||||
|         state.lastFetch = new Date(); |         state.lastFetch = new Date(); | ||||||
|         state.pedido_id = pedido.id; |         state.pedido_id = pedido.id; | ||||||
|         state.nombre = pedido.nombre; |         state.nombre = pedido.nombre; | ||||||
|  | @ -28,18 +32,28 @@ const mutations = { | ||||||
|         state.devoluciones_total = pedido.devoluciones_total; |         state.devoluciones_total = pedido.devoluciones_total; | ||||||
|         state.devoluciones_notas = pedido.devoluciones_notas; |         state.devoluciones_notas = pedido.devoluciones_notas; | ||||||
|     }, |     }, | ||||||
|  |     reset(state) { | ||||||
|  |         state.lastFetch = null; | ||||||
|  |         state.pedido_id = null; | ||||||
|  |         state.nombre = null; | ||||||
|  |         state.productos = null; | ||||||
|  |         state.aprobado = null; | ||||||
|  |         state.total = null; | ||||||
|  |         state.total_transporte = null; | ||||||
|  |         state.cantidad_transporte = null; | ||||||
|  |         state.total_sin_devoluciones = null; | ||||||
|  |         state.devoluciones_total = null; | ||||||
|  |         state.devoluciones_notas = null; | ||||||
|  |     } | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| const actions = { | const actions = { | ||||||
|     async guardarSesion(_, { pedido_id }) { |     async getGrupoDeCompra({ commit }) { | ||||||
|         await axios.post("/subpedidos/sesion", { id: pedido_id }); |         const response = await axios.get('/user/grupo_de_compra'); | ||||||
|  |         commit('setGrupoDeCompra', response.data.grupo_de_compra); | ||||||
|     }, |     }, | ||||||
|     async getSesion({ commit }) { |     async guardarSesion(_, { pedido_id }) { | ||||||
|         const sesion = await axios.get("/subpedidos/sesion"); |         await axios.post("/pedido/sesion", { id: pedido_id }); | ||||||
|         if (sesion.data) { |  | ||||||
|             const response = await axios.get(`/api/subpedidos/${sesion.data}`); |  | ||||||
|             commit('setState', response.data.data); |  | ||||||
|         } |  | ||||||
|     }, |     }, | ||||||
|     async crearPedido({ commit, dispatch }, { nombre, grupo_de_compra_id }) { |     async crearPedido({ commit, dispatch }, { nombre, grupo_de_compra_id }) { | ||||||
|         const response = await axios.post("/api/subpedidos", { |         const response = await axios.post("/api/subpedidos", { | ||||||
|  | @ -47,12 +61,12 @@ const actions = { | ||||||
|             grupo_de_compra_id: grupo_de_compra_id |             grupo_de_compra_id: grupo_de_compra_id | ||||||
|         }); |         }); | ||||||
|         dispatch("guardarSesion", { pedido_id: response.data.data.id}); |         dispatch("guardarSesion", { pedido_id: response.data.data.id}); | ||||||
|         commit('setState', response.data.data); |         commit('setPedido', response.data.data); | ||||||
|     }, |     }, | ||||||
|     async elegirPedido({ commit, dispatch }, { pedido }) { |     async elegirPedido({ commit, dispatch }, { pedido_id }) { | ||||||
|         const response = await axios.get(`/api/subpedidos/${pedido.id}`); |         const response = await axios.get(`/api/subpedidos/${pedido_id}`); | ||||||
|         dispatch("guardarSesion", { pedido_id: response.data.data.id}) |         dispatch("guardarSesion", { pedido_id: pedido_id}) | ||||||
|         commit('setState', response.data.data); |         commit('setPedido', response.data.data); | ||||||
|     }, |     }, | ||||||
|     async modificarChismosa({ commit, dispatch }, { producto_id, cantidad, notas }) { |     async modificarChismosa({ commit, dispatch }, { producto_id, cantidad, notas }) { | ||||||
|         try { |         try { | ||||||
|  | @ -61,7 +75,7 @@ const actions = { | ||||||
|                 producto_id: producto_id, |                 producto_id: producto_id, | ||||||
|                 notas: notas, |                 notas: notas, | ||||||
|             }); |             }); | ||||||
|             commit('setState', response.data.data); |             commit('setPedido', response.data.data); | ||||||
|             dispatch("ui/toast", { mensaje: 'Pedido modificado con éxito' }, { root: true }); |             dispatch("ui/toast", { mensaje: 'Pedido modificado con éxito' }, { root: true }); | ||||||
|         } catch (error) { |         } catch (error) { | ||||||
|             dispatch("ui/error", { error: error }, { root: true }); |             dispatch("ui/error", { error: error }, { root: true }); | ||||||
|  | @ -73,12 +87,18 @@ const actions = { | ||||||
|                 total: monto, |                 total: monto, | ||||||
|                 notas: notas, |                 notas: notas, | ||||||
|             }); |             }); | ||||||
|             commit('setState', response.data.data); |             commit('setPedido', response.data.data); | ||||||
|             dispatch("ui/toast", { mensaje: 'Devoluciones modificadas con éxito' }, { root: true }); |             dispatch("ui/toast", { mensaje: 'Devoluciones modificadas con éxito' }, { root: true }); | ||||||
|         } catch (error) { |         } catch (error) { | ||||||
|             dispatch("ui/error", { error: error }, { root: true }); |             dispatch("ui/error", { error: error }, { root: true }); | ||||||
|         } |         } | ||||||
|     }, |     }, | ||||||
|  |     async resetear({ commit, dispatch }) { | ||||||
|  |         await axios.delete("/pedido/sesion"); | ||||||
|  |         dispatch("productos/getProductos", null, { root: true }); | ||||||
|  |         dispatch("ui/resetear", null, { root: true }); | ||||||
|  |         commit('reset'); | ||||||
|  |     }, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| const getters = { | const getters = { | ||||||
|  |  | ||||||
							
								
								
									
										26
									
								
								resources/js/store/modules/ui.js
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										26
									
								
								resources/js/store/modules/ui.js
									
										
									
									
										vendored
									
									
								
							|  | @ -1,10 +1,7 @@ | ||||||
| import { dropWhile } from "lodash/array"; |  | ||||||
| 
 |  | ||||||
| const state = { | const state = { | ||||||
|     show_chismosa: false, |     show_chismosa: false, | ||||||
|     show_devoluciones: false, |     show_devoluciones: false, | ||||||
|     miga_inicial: { nombre: 'Categorias', action: 'productos/getProductos' }, |     migas: [{ nombre: 'Pedidos', action: 'pedido/resetear' }], | ||||||
|     migas: [{ nombre: 'Categorias', action: 'productos/getProductos' }], |  | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| const mutations = { | const mutations = { | ||||||
|  | @ -17,11 +14,27 @@ const mutations = { | ||||||
|     addMiga(state, miga) { |     addMiga(state, miga) { | ||||||
|         state.migas.push(miga); |         state.migas.push(miga); | ||||||
|     }, |     }, | ||||||
|  |     popUltimaBusqueda(state) { | ||||||
|  |         if (!state.migas.at(-1).action) | ||||||
|  |             state.migas.pop(); | ||||||
|  |     }, | ||||||
|  |     reset(state) { | ||||||
|  |         state.show_chismosa = false; | ||||||
|  |         state.show_devoluciones = false; | ||||||
|  |     } | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| const actions = { | const actions = { | ||||||
|     clickMiga({ dispatch }, { miga }) { |     clickMiga({ dispatch }, { miga }) { | ||||||
|         dispatch(miga.action, null, { root: true }); |         let dropWhile = (array, pred) => { | ||||||
|  |             let result = array.slice(0); | ||||||
|  |             while (result.length && pred(result[0])) { | ||||||
|  |                 result = result.slice(1) | ||||||
|  |             } | ||||||
|  |             return result; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         dispatch(miga.action, miga.arguments ?? null, { root: true }); | ||||||
|         state.migas = dropWhile(state.migas.reverse(),(m => m.nombre !== miga.nombre)).reverse(); |         state.migas = dropWhile(state.migas.reverse(),(m => m.nombre !== miga.nombre)).reverse(); | ||||||
|     }, |     }, | ||||||
|     toast(_, { mensaje }) { |     toast(_, { mensaje }) { | ||||||
|  | @ -38,6 +51,9 @@ const actions = { | ||||||
|             : error.message; |             : error.message; | ||||||
|         dispatch("toast", { mensaje: errorMsg }); |         dispatch("toast", { mensaje: errorMsg }); | ||||||
|     }, |     }, | ||||||
|  |     resetear({ commit }) { | ||||||
|  |         commit("reset"); | ||||||
|  |     }, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| export default { | export default { | ||||||
|  |  | ||||||
							
								
								
									
										5
									
								
								resources/sass/app.scss
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										5
									
								
								resources/sass/app.scss
									
										
									
									
										vendored
									
									
								
							|  | @ -7,6 +7,11 @@ | ||||||
| @import 'bulma'; | @import 'bulma'; | ||||||
| @import '~bulma-switch'; | @import '~bulma-switch'; | ||||||
| 
 | 
 | ||||||
|  | html, body { | ||||||
|  |     overflow-x: hidden; | ||||||
|  |     max-width: 100%; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| main.has-top-padding { | main.has-top-padding { | ||||||
| 	padding-top: 4.5rem !important; | 	padding-top: 4.5rem !important; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -10,12 +10,7 @@ | ||||||
| <body> | <body> | ||||||
| <section class="section"> | <section class="section"> | ||||||
|     <div id="root" class="container"> |     <div id="root" class="container"> | ||||||
|         <h1 class="title has-text-white"> |         <login-titulos></login-titulos> | ||||||
|             Administración de Pedidos MPS |  | ||||||
|         </h1> |  | ||||||
|         <p class="subtitle has-text-white"> |  | ||||||
|             Bienvenidx a la administración de pedidos del <strong class="has-text-white">Mercado Popular de Subsistencia</strong> |  | ||||||
|         </p> |  | ||||||
|         @error('name') |         @error('name') | ||||||
|         <div class="notification is-warning"> |         <div class="notification is-warning"> | ||||||
|             Contraseña incorrecta, intentalo nuevamente. |             Contraseña incorrecta, intentalo nuevamente. | ||||||
|  |  | ||||||
|  | @ -1,5 +0,0 @@ | ||||||
| @extends('layouts.app') |  | ||||||
| 
 |  | ||||||
| @section('content') |  | ||||||
|     <admin-body></admin-body> |  | ||||||
| @endsection |  | ||||||
|  | @ -11,13 +11,8 @@ | ||||||
|     <body> |     <body> | ||||||
|         <section class="section"> |         <section class="section"> | ||||||
|         <div id="root" class="container"> |         <div id="root" class="container"> | ||||||
|           <h1 class="title"> |             <login-titulos></login-titulos> | ||||||
|             Pedidos MPS |             @error('name') | ||||||
|           </h1> |  | ||||||
|           <p class="subtitle"> |  | ||||||
|             Bienvenidx a la sección de compras de la aplicación del <strong>Mercado Popular de Subsistencia</strong> |  | ||||||
|           </p> |  | ||||||
|           @error('name') |  | ||||||
|             <div class="notification is-danger"> |             <div class="notification is-danger"> | ||||||
|               Contraseña incorrecta, intentalo nuevamente. |               Contraseña incorrecta, intentalo nuevamente. | ||||||
|             </div> |             </div> | ||||||
|  |  | ||||||
|  | @ -1,35 +1,30 @@ | ||||||
| <!DOCTYPE html> | <!DOCTYPE html> | ||||||
| <html lang="{{ str_replace('_', '-', app()->getLocale()) }}"> | <html lang="{{ str_replace('_', '-', app()->getLocale()) }}"> | ||||||
|     <head> | <head> | ||||||
|         <meta charset="utf-8"> |     <meta charset="utf-8"> | ||||||
|         <meta name="viewport" content="width=device-width, initial-scale=1"> |     <meta name="viewport" content="width=device-width, initial-scale=1"> | ||||||
|         <title>{{ config('app.name', 'Pedidos del MPS') }}</title> |     <title>{{ config('app.name', 'Pedidos del MPS') }}</title> | ||||||
|         <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bulma@0.9.3/css/bulma.min.css"> |     <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bulma@0.9.3/css/bulma.min.css"> | ||||||
|         <link rel="stylesheet" href="{{ mix('css/app.css') }}"> |     <link rel="stylesheet" href="{{ mix('css/app.css') }}"> | ||||||
|         <script src="https://kit.fontawesome.com/9235d1c676.js" crossorigin="anonymous"></script> |     <script src="https://kit.fontawesome.com/9235d1c676.js" crossorigin="anonymous"></script> | ||||||
|     </head> | </head> | ||||||
|     <body> | <body> | ||||||
|         <section class="section"> | <section class="section"> | ||||||
|         <div id="root" class="container"> |     <div id="root" class="container"> | ||||||
|           <admin-boton-login></admin-boton-login> |         <admin-boton-login></admin-boton-login> | ||||||
|           <h1 class="title"> |         <login-titulos></login-titulos> | ||||||
|             Pedidos MPS |         @error('name') | ||||||
|           </h1> |         <div class="notification is-danger"> | ||||||
|           <p class="subtitle"> |             Contraseña incorrecta, intentalo nuevamente. | ||||||
|             Bienvenidx a la aplicación de pedidos del <strong>Mercado Popular de Subsistencia</strong> |  | ||||||
|           </p> |  | ||||||
|           @error('name') |  | ||||||
|             <div class="notification is-danger"> |  | ||||||
|               Contraseña incorrecta, intentalo nuevamente. |  | ||||||
|             </div> |  | ||||||
|           @enderror |  | ||||||
|           <comunes-region-select></comunes-region-select> |  | ||||||
|             <form method="post" action="/login"> |  | ||||||
|                 @csrf |  | ||||||
|                 <comunes-login-form></comunes-login-form> |  | ||||||
|             </form> |  | ||||||
|         </div> |         </div> | ||||||
|       </section> |         @enderror | ||||||
|       <script src="{{ mix('js/app.js') }}" defer></script> |         <comunes-region-select></comunes-region-select> | ||||||
|     </body> |         <form method="post" action="/login"> | ||||||
|  |             @csrf | ||||||
|  |             <comunes-login-form></comunes-login-form> | ||||||
|  |         </form> | ||||||
|  |     </div> | ||||||
|  | </section> | ||||||
|  | <script src="{{ mix('js/app.js') }}" defer></script> | ||||||
|  | </body> | ||||||
| </html> | </html> | ||||||
|  |  | ||||||
|  | @ -1,5 +0,0 @@ | ||||||
| @extends('layouts.app') |  | ||||||
| 
 |  | ||||||
| @section('content') |  | ||||||
|     <compras-body></compras-body> |  | ||||||
| @endsection |  | ||||||
|  | @ -17,14 +17,9 @@ | ||||||
| </head> | </head> | ||||||
| <body class="has-navbar-fixed-top"> | <body class="has-navbar-fixed-top"> | ||||||
|     <div id="root"> |     <div id="root"> | ||||||
|         <comunes-nav-bar> |         <form id="logout-form" action="{{ route('logout') }}" method="POST" class="d-none" hidden="hidden"> | ||||||
|             <template #logout-form>
 |             @csrf | ||||||
|                 <form id="logout-form" action="{{ route('logout') }}" method="POST" class="d-none"> |         </form> | ||||||
|                     @csrf |  | ||||||
|                 </form> |  | ||||||
|             </template> |  | ||||||
|         </comunes-nav-bar> |  | ||||||
|         <pedidos-nav-migas></pedidos-nav-migas> |  | ||||||
|         <main id="main" class="py-4 has-top-padding"> |         <main id="main" class="py-4 has-top-padding"> | ||||||
|             @yield('content') |             @yield('content') | ||||||
|         </main> |         </main> | ||||||
|  |  | ||||||
|  | @ -1,6 +0,0 @@ | ||||||
| @extends('layouts.app') |  | ||||||
| 
 |  | ||||||
| @section('content') |  | ||||||
| <pedidos-body></pedidos-body> |  | ||||||
| <pedidos-devoluciones-modal></pedidos-devoluciones-modal> |  | ||||||
| @endsection |  | ||||||
|  | @ -1,8 +0,0 @@ | ||||||
| @extends('layouts.app') |  | ||||||
| 
 |  | ||||||
| @section('content') |  | ||||||
|     <app-main></app-main> |  | ||||||
| @endsection |  | ||||||
| 
 |  | ||||||
| @section('scripts') |  | ||||||
| @endsection |  | ||||||
|  | @ -1,8 +1,6 @@ | ||||||
| <?php | <?php | ||||||
| 
 | 
 | ||||||
| use Illuminate\Support\Facades\Route; | use Illuminate\Support\Facades\Route; | ||||||
| use App\GrupoDeCompra; |  | ||||||
| use App\Producto; |  | ||||||
| 
 | 
 | ||||||
| /* | /* | ||||||
| |-------------------------------------------------------------------------- | |-------------------------------------------------------------------------- | ||||||
|  | @ -15,33 +13,17 @@ use App\Producto; | ||||||
| | | | | ||||||
| */ | */ | ||||||
| 
 | 
 | ||||||
| Route::middleware('api')->group(function () { | Route::middleware('api')->group(function() { | ||||||
|     Route::get('/regiones', function() { |     Route::get('/regiones', 'Api\GrupoDeCompraController@regiones'); | ||||||
|     	return GrupoDeCompra::all()->pluck('region')->unique()->flatten(); |     Route::get('/regiones/{region}', 'Api\GrupoDeCompraController@region'); | ||||||
|     }); |  | ||||||
| 
 |  | ||||||
|     Route::prefix('grupos-de-compra')->group( function(){ |  | ||||||
|     	Route::get('/', function() { |  | ||||||
| 	    	$atributos_a_ocultar = ['telefono', 'cantidad_de_nucleos', 'correo', 'referente_finanzas', 'created_at', 'updated_at']; |  | ||||||
|     		return GrupoDeCompra::all()->makeHidden($atributos_a_ocultar)->sortBy('nombre')->groupBy('region'); |  | ||||||
|     	}); |  | ||||||
| 
 | 
 | ||||||
|  |     Route::prefix('grupos-de-compra')->group(function() { | ||||||
|         Route::get('/{grupoDeCompra}', 'Api\GrupoDeCompraController@show'); |         Route::get('/{grupoDeCompra}', 'Api\GrupoDeCompraController@show'); | ||||||
| 
 |         Route::post('/{gdc}/devoluciones', 'Api\GrupoDeCompraController@toggleDevoluciones'); | ||||||
|         Route::get('/{gdc}/devoluciones', function($gdc) { |  | ||||||
|             $habilitadas = GrupoDeCompra::find($gdc)->devoluciones_habilitadas; |  | ||||||
|             return ['devoluciones' => $habilitadas]; |  | ||||||
|         }); |  | ||||||
| 
 |  | ||||||
|         Route::post('/{gdc}/devoluciones', function($gdc) { |  | ||||||
|             GrupoDeCompra::find($gdc)->toggleDevoluciones(); |  | ||||||
|             return response()->noContent(); |  | ||||||
|         }); |  | ||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
|     Route::prefix('subpedidos')->group(function () { |     Route::prefix('subpedidos')->group(function () { | ||||||
|         Route::get('/','Api\SubpedidoController@index'); |         Route::get('/','Api\SubpedidoController@index'); | ||||||
|         Route::get('/resources', 'Api\SubpedidoController@indexResources'); |  | ||||||
|         Route::get('{subpedido}','Api\SubpedidoController@show'); |         Route::get('{subpedido}','Api\SubpedidoController@show'); | ||||||
|         Route::post('/','Api\SubpedidoController@store'); |         Route::post('/','Api\SubpedidoController@store'); | ||||||
|         Route::post('/{subpedido}/sync', 'Api\SubpedidoController@syncProductos'); |         Route::post('/{subpedido}/sync', 'Api\SubpedidoController@syncProductos'); | ||||||
|  | @ -55,13 +37,10 @@ Route::middleware('api')->group(function () { | ||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
|     //@TO DO -> esta ruta debe estar en middleware de auth y/o subpedido
 |     //@TO DO -> esta ruta debe estar en middleware de auth y/o subpedido
 | ||||||
|     Route::get('/categorias', function() { |     Route::get('/categorias', 'Api\ProductoController@categorias'); | ||||||
| 		return Producto::all()->pluck('categoria')->unique()->flatten(); |  | ||||||
| 	}); |  | ||||||
| 
 | 
 | ||||||
|     //@TO DO -> esta ruta debe estar en middleware de auth y/o subpedido
 |     //@TO DO -> esta ruta debe estar en middleware de auth y/o subpedido
 | ||||||
| 	Route::prefix('productos')->group(function () { | 	Route::prefix('productos')->group(function () { | ||||||
|         Route::get('/','Api\ProductoController@index'); |         Route::get('/','Api\ProductoController@index'); | ||||||
| 		Route::get('{producto}','Api\ProductoController@show'); |  | ||||||
| 	}); | 	}); | ||||||
| }); | }); | ||||||
|  |  | ||||||
|  | @ -4,7 +4,6 @@ use Illuminate\Support\Facades\App; | ||||||
| use Illuminate\Support\Facades\Auth; | use Illuminate\Support\Facades\Auth; | ||||||
| use Illuminate\Support\Facades\Route; | use Illuminate\Support\Facades\Route; | ||||||
| use Illuminate\Support\Facades\URL; | use Illuminate\Support\Facades\URL; | ||||||
| use Symfony\Component\HttpKernel\Exception\HttpException; |  | ||||||
| /* | /* | ||||||
| |-------------------------------------------------------------------------- | |-------------------------------------------------------------------------- | ||||||
| | Web Routes | | Web Routes | ||||||
|  | @ -31,42 +30,9 @@ Route::middleware(['auth'])->group(function () { | ||||||
| 
 | 
 | ||||||
| Route::middleware(['auth', 'role:barrio'])->group(function() { | Route::middleware(['auth', 'role:barrio'])->group(function() { | ||||||
|     Route::get('/pedido', 'RouteController@main')->name('pedido'); |     Route::get('/pedido', 'RouteController@main')->name('pedido'); | ||||||
| 
 |     Route::get('/pedido/sesion', 'SessionController@fetch'); | ||||||
|     Route::get('/productos', 'ProductoController@index')->name('productos.index'); |     Route::post('/pedido/sesion', 'SessionController@store'); | ||||||
| 
 |     Route::delete('/pedido/sesion', 'SessionController@destroy'); | ||||||
|     Route::name('subpedidos.')->prefix("subpedidos")->group(function() { |  | ||||||
|         Route::get('/', function() { |  | ||||||
|             return view('subpedidos_create'); |  | ||||||
|         })->name('create'); |  | ||||||
| 
 |  | ||||||
|         Route::post('guardar_sesion', function() { |  | ||||||
|             $r = request(); |  | ||||||
|             if (!isset($r["subpedido"])) { |  | ||||||
|                 throw new HttpException(400, "La request necesita un subpedido para guardar en sesión"); |  | ||||||
|             } |  | ||||||
|             if (!isset($r["grupo_de_compra_id"])) { |  | ||||||
|                 throw new HttpException(400, "La request necesita un grupo de compra para guardar en sesión"); |  | ||||||
|             } |  | ||||||
|             session(["subpedido_nombre" => $r["subpedido"]["nombre"]]); |  | ||||||
|             session(["subpedido_id" => $r["subpedido"]["id"]]); |  | ||||||
|             session(["gdc" => $r["grupo_de_compra_id"]]); |  | ||||||
|             return "Subpedido guardado en sesión"; |  | ||||||
|         })->name('guardarSesion'); |  | ||||||
| 
 |  | ||||||
|         Route::get('obtener_sesion', function() { |  | ||||||
|             return [ |  | ||||||
|                 'subpedido' => [ |  | ||||||
|                     'nombre' => session("subpedido_nombre"), |  | ||||||
|                     'id' => session("subpedido_id") |  | ||||||
|                 ], |  | ||||||
|                 'gdc' => session("gdc") |  | ||||||
|             ]; |  | ||||||
|         })->name('obtenerSesion'); |  | ||||||
| 
 |  | ||||||
|         Route::post('sesion', 'SessionController@store'); |  | ||||||
| 
 |  | ||||||
|         Route::get('sesion', 'SessionController@fetch'); |  | ||||||
|     }); |  | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| Route::get('/admin/login', 'AdminController@show')->name('admin.login'); | Route::get('/admin/login', 'AdminController@show')->name('admin.login'); | ||||||
|  | @ -75,9 +41,7 @@ Route::middleware(['auth', 'role:admin_barrio'])->group(function () { | ||||||
| 	Route::get('/admin', 'RouteController@main')->name('admin'); | 	Route::get('/admin', 'RouteController@main')->name('admin'); | ||||||
| 
 | 
 | ||||||
| 	Route::get('/admin/exportar-planillas-a-pdf/{gdc}', 'AdminController@exportarPedidosAPdf'); | 	Route::get('/admin/exportar-planillas-a-pdf/{gdc}', 'AdminController@exportarPedidosAPdf'); | ||||||
| 
 |  | ||||||
| 	Route::get('/admin/exportar-pedido-a-csv/{gdc}', 'AdminController@exportarPedidoACSV'); | 	Route::get('/admin/exportar-pedido-a-csv/{gdc}', 'AdminController@exportarPedidoACSV'); | ||||||
| 
 |  | ||||||
| 	Route::get('/admin/exportar-pedido-con-nucleos-a-csv/{gdc}', 'AdminController@exportarPedidoConNucleosACSV'); | 	Route::get('/admin/exportar-pedido-con-nucleos-a-csv/{gdc}', 'AdminController@exportarPedidoConNucleosACSV'); | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
|  | @ -88,6 +52,6 @@ Route::middleware(['auth', 'role:comision'])->group( function() { | ||||||
|     Route::get('/compras/pedidos/descargar', 'ComprasController@descargarPedidos')->name('compras.pedidos.descargar'); |     Route::get('/compras/pedidos/descargar', 'ComprasController@descargarPedidos')->name('compras.pedidos.descargar'); | ||||||
|     Route::get('/compras/pedidos/notas', 'ComprasController@descargarNotas')->name('compras.pedidos.descargar'); |     Route::get('/compras/pedidos/notas', 'ComprasController@descargarNotas')->name('compras.pedidos.descargar'); | ||||||
|     Route::get('/compras/pedidos/pdf', 'ComprasController@pdf')->name('compras.pedidos.pdf'); |     Route::get('/compras/pedidos/pdf', 'ComprasController@pdf')->name('compras.pedidos.pdf'); | ||||||
|     Route::post('/compras/canasta', 'ComprasController@cargarCanasta')->name('compras.canasta'); |  | ||||||
|     Route::get('/compras/canasta/ejemplo', 'ComprasController@descargarCanastaEjemplo')->name('compras.canasta.ejemplo'); |     Route::get('/compras/canasta/ejemplo', 'ComprasController@descargarCanastaEjemplo')->name('compras.canasta.ejemplo'); | ||||||
|  |     Route::post('/compras/canasta', 'ComprasController@cargarCanasta')->name('compras.canasta'); | ||||||
| }); | }); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue