File Controller, Booking Organisation, import Draft, old arrangements

This commit is contained in:
Kevin Adametz 2025-09-04 10:35:45 +02:00
parent 4eb83def39
commit 8fd1f4d451
289 changed files with 36649 additions and 10877 deletions

35
.env
View file

@ -15,31 +15,44 @@ APP_DOMAIN_TLD=test
LOG_CHANNEL=stack
# Standard Database Connection
DB_CONNECTION=mysql
DB_HOST=192.168.1.8
DB_HOST=mysql
DB_PORT=3306
DB_DATABASE=cmssso_db1
DB_USERNAME=kadmin
DB_PASSWORD=KT32vQ7ix
DB_DATABASE=stern_crm
DB_USERNAME=sail
DB_PASSWORD=password
DB_CONNECTION_STERN=mysql
DB_HOST_STERN=192.168.1.8
# STERN Database Connection
DB_HOST_STERN=mysql-stern
DB_PORT_STERN=3306
DB_DATABASE_STERN=relaunch1
DB_USERNAME_STERN=kadmin
DB_PASSWORD_STERN=KT32vQ7ix
DB_DATABASE_STERN=stern_db
DB_USERNAME_STERN=sail
DB_PASSWORD_STERN=password
# Docker Port Forwards
FORWARD_DB_PORT=33064
FORWARD_DB_PORT_STERN=33065
FORWARD_REDIS_PORT=6379
MYSQL_EXTRA_OPTIONS=
BROADCAST_DRIVER=log
CACHE_DRIVER=file
QUEUE_CONNECTION=sync
SESSION_DRIVER=file
SESSION_LIFETIME=120
QUEUE_DRIVER=sync
REDIS_HOST=127.0.0.1
REDIS_HOST=redis
REDIS_PASSWORD=null
REDIS_PORT=6379
# Vite Port for Development
VITE_PORT=5173
# Sail Configuration
WWWGROUP=1000
WWWUSER=1000
SAIL_XDEBUG_MODE=off
MAIL_BBC=kevin@adametz.media
MAIL_FEWO_EMPLOYEE=kevin@adametz.media

15
.gitignore vendored
View file

@ -25,11 +25,24 @@ Icon
Network Trash Folder
Temporary Items
.apdisk
.idea/
.claude/
.cursor/
.cursorrules/
.cursorrules.md/
.cursorrules.md.txt/
.cursorrules.md.txt.txt/
.cursorrules.md.txt.txt.txt/
/vendor
/node_modules
/storage/app
/storage/language
/storage/framework
/storage/logs
/public/vendor
.idea
.idea/
.vscode/
_static/
_work/
_storage/

File diff suppressed because it is too large Load diff

File diff suppressed because it is too large Load diff

View file

@ -27,11 +27,10 @@ class BookingController extends Controller
protected $custRepo;
public function __construct(BookingRepository $bookingRepo, CustomerRepository $custRepo)
{
{
$this->middleware(['admin', '2fa']);
$this->bookingRepo = $bookingRepo;
$this->custRepo = $custRepo;
}
public function index($step = false)
@ -45,11 +44,10 @@ class BookingController extends Controller
public function detail($id)
{
if($id == "new") {
if ($id == "new") {
$booking = new Booking();
$id = 'new';
}else{
} else {
$booking = Booking::findOrFail($id);
$booking->getPassolutionPDF(true);
$id = $booking->id;
@ -60,70 +58,91 @@ class BookingController extends Controller
'show_modal_quill_preview' => true,
];
return view('booking.detail', $data);
}
public function store($id)
{
// \Session()->flash('alert-save', '1');
// \Session()->flash('alert-save', '1');
$data = Request::all();
if($id === "new") {
if ($id === "new") {
$booking = new Booking();
}else{
} else {
$booking = Booking::findOrFail($id);
}
if($data['action'] === 'deleteAllChecked'){
if(!isset($data['draft_item_delete']) || !$data['draft_item_delete']){
if ($data['action'] === 'convertArrangementsToDrafts') {
if (!$booking->arrangements || $booking->arrangements->count() == 0) {
\Session()->flash('alert-warning', __('Keine Arrangements zum Konvertieren vorhanden'));
return redirect(route('booking_detail', [$booking->id]) . "#collapseBookingOrganisation");
}
$this->bookingRepo->convertArrangementsToDrafts($booking);
\Session()->flash('alert-success', __('Arrangements wurden erfolgreich in die neue Draft-Struktur übernommen'));
return redirect(route('booking_detail', [$booking->id]) . "#collapseBookingOrganisation");
}
if ($data['action'] === 'loadDraftToBooking') {
if (!isset($data['draft_id']) || !$data['draft_id']) {
\Session()->flash('alert-error', __('Keine Vorlage ausgewählt'));
return redirect(route('booking_detail', [$booking->id]) . "#collapseBookingOrganisation");
}
$this->bookingRepo->loadDraftToBooking($booking->id, $data['draft_id']);
\Session()->flash('alert-success', __('Vorlage wurde erfolgreich geladen'));
return redirect(route('booking_detail', [$booking->id]) . "#collapseBookingOrganisation");
}
if ($data['action'] === 'deleteAllChecked') {
if (!isset($data['draft_item_delete']) || !$data['draft_item_delete']) {
\Session()->flash('alert-error', 'Es wurden keine Leistungen ausgewählt');
return redirect(route('booking_detail', [$booking->id])."#collapseBookingOrganisation");
return redirect(route('booking_detail', [$booking->id]) . "#collapseBookingOrganisation");
}
foreach ($data['draft_item_delete'] as $draft_item_delete_id => $v) {
$booking_draft_item = BookingDraftItem::findOrFail($draft_item_delete_id);
if($booking_draft_item->booking_id === $booking->id){
if ($booking_draft_item->booking_id === $booking->id) {
$booking_draft_item->delete();
}
}
$booking->calculate_price_total();
return redirect(route('booking_detail', [$booking->id])."#collapseBookingOrganisation");
return redirect(route('booking_detail', [$booking->id]) . "#collapseBookingOrganisation");
}
if($data['action'] === 'save_notice'){
if ($data['action'] === 'save_notice') {
$booking = $this->bookingRepo->updateNotice($id, $data);
\Session()->flash('alert-save', '1');
return redirect(route('booking_detail', [$booking->id])."#collapseBookingNotice");
return redirect(route('booking_detail', [$booking->id]) . "#collapseBookingNotice");
}
if($data['action'] === 'edit_notice'){
if ($data['action'] === 'edit_notice') {
$booking = $this->bookingRepo->updateNotice($id, $data);
\Session()->flash('alert-save', '1');
return redirect(route('booking_detail', [$booking->id])."#collapseBookingNotice");
return redirect(route('booking_detail', [$booking->id]) . "#collapseBookingNotice");
}
if(strpos($data['action'], 'createPDF') !== false) {
if (strpos($data['action'], 'createPDF') !== false) {
$bookingPDF = new BookingPDFRepository($booking);
$bookingPDF->createPDF($id, $data);
\Session()->flash('alert-success', 'PDF Datei erstellt');
return redirect(route('booking_detail', [$booking->id])."#collapseBookingFiles");
return redirect(route('booking_detail', [$booking->id]) . "#collapseBookingFiles");
}
$redirect = route('booking_detail', [$booking->id]);
$i= 1;
if($data['action'] === 'addItemUp'){
$i = 1;
if ($data['action'] === 'addItemUp') {
$travel_program_id = null;
$request_date = null;
$comfort = 0;
if(count($booking->booking_draft_items)){
if (count($booking->booking_draft_items)) {
$first_booking_draft_item = $booking->booking_draft_items()->first();
$travel_program_id = $first_booking_draft_item->travel_program_id;
$request_date = $first_booking_draft_item->request_date;
$comfort = $first_booking_draft_item->comfort;
}
$add_draft_items_up_number = isset($data['add_draft_items_up_number']) ? intval($data['add_draft_items_up_number']) : 1;
for ($j=0; $j < $add_draft_items_up_number; $j++) {
for ($j = 0; $j < $add_draft_items_up_number; $j++) {
$booking->booking_draft_items()->create([
'booking_id' => $booking->id,
'travel_program_id' => $travel_program_id,
@ -138,7 +157,7 @@ class BookingController extends Controller
'end_date' => null,
'service' => '',
'price_adult' => null,
'adult' => null ,
'adult' => null,
'price_children' => 0,
'children' => 0,
'price' => 0,
@ -148,11 +167,11 @@ class BookingController extends Controller
]);
$i++;
}
$redirect = redirect(route('booking_detail', [$booking->id])."#collapseBookingOrganisation");
$redirect = redirect(route('booking_detail', [$booking->id]) . "#collapseBookingOrganisation");
}
if(isset($data['draft_item'])){
foreach ($data['draft_item'] as $booking_draft_item_id => $draft_item){
if (isset($data['draft_item'])) {
foreach ($data['draft_item'] as $booking_draft_item_id => $draft_item) {
$BookingDraftItem = BookingDraftItem::findOrFail($booking_draft_item_id);
$draft_item['price_adult'] = isset($draft_item['price_adult']) ? $draft_item['price_adult'] : null;
$draft_item['adult'] = isset($draft_item['adult']) ? $draft_item['adult'] : null;
@ -166,18 +185,18 @@ class BookingController extends Controller
}
}
if($data['action'] === 'addItemDown'){
if ($data['action'] === 'addItemDown') {
$travel_program_id = null;
$request_date = null;
$comfort = 0;
if(count($booking->booking_draft_items)){
if (count($booking->booking_draft_items)) {
$first_booking_draft_item = $booking->booking_draft_items()->first();
$travel_program_id = $first_booking_draft_item->travel_program_id;
$request_date = $first_booking_draft_item->request_date;
$comfort = $first_booking_draft_item->comfort;
}
$add_draft_items_up_number = isset($data['add_draft_items_down_number']) ? intval($data['add_draft_items_down_number']) : 1;
for ($j=0; $j < $add_draft_items_up_number; $j++) {
for ($j = 0; $j < $add_draft_items_up_number; $j++) {
$booking->booking_draft_items()->create([
'booking_id' => $booking->id,
'travel_program_id' => $travel_program_id,
@ -192,7 +211,7 @@ class BookingController extends Controller
'end_date' => null,
'service' => '',
'price_adult' => null,
'adult' => null ,
'adult' => null,
'price_children' => 0,
'children' => 0,
'price' => 0,
@ -202,14 +221,15 @@ class BookingController extends Controller
]);
$i++;
}
$redirect = redirect(route('booking_detail', [$booking->id])."#collapseBookingOrganisation");
$redirect = redirect(route('booking_detail', [$booking->id]) . "#collapseBookingOrganisation");
}
if($data['action'] === 'saveCustomer' || $data['action'] === 'saveAll' || $data['action'] === 'save_lead_status' || $data['action'] === 'update_booking' ||
$data['action'] === 'update_booking_services' || $data['action'] === 'update_booking_number' || $data['action'] === 'update_booking_price' ||
$data['action'] === 'update_service_provider_entry' || $data['action'] === 'update_booking_service_item' || $data['action'] === 'update_booking_participant'){
if (
$data['action'] === 'saveCustomer' || $data['action'] === 'saveAll' || $data['action'] === 'save_lead_status' || $data['action'] === 'update_booking' ||
$data['action'] === 'update_booking_services' || $data['action'] === 'update_booking_number' || $data['action'] === 'update_booking_price' ||
$data['action'] === 'update_service_provider_entry' || $data['action'] === 'update_booking_service_item' || $data['action'] === 'update_booking_participant'
) {
$customer = $this->custRepo->updateCustomerFromBooking($id, $data);
$booking = $this->bookingRepo->updateLeadStatus($id, $data);
$booking = $this->bookingRepo->updateBooking($id, $data);
@ -222,49 +242,49 @@ class BookingController extends Controller
\Session()->flash('alert-save', '1');
switch($data['action']){
switch ($data['action']) {
case 'saveCustomer':
$redirect = redirect(route('booking_detail', [$booking->id])."#collapseBookingCustomer");
$redirect = redirect(route('booking_detail', [$booking->id]) . "#collapseBookingCustomer");
break;
case 'saveAll':
$redirect = redirect(route('booking_detail', [$booking->id])."#collapseBookingOrganisation");
case 'saveAll':
$redirect = redirect(route('booking_detail', [$booking->id]) . "#collapseBookingOrganisation");
break;
case 'update_booking':
$redirect = redirect(route('booking_detail', [$booking->id])."#collapseBookingBooking");
$redirect = redirect(route('booking_detail', [$booking->id]) . "#collapseBookingBooking");
break;
case 'save_lead_status':
$redirect = redirect(route('booking_detail', [$booking->id])."#collapseBookingLead");
$redirect = redirect(route('booking_detail', [$booking->id]) . "#collapseBookingLead");
break;
case 'update_booking_services':
$redirect = redirect(route('booking_detail', [$booking->id])."#collapseBookingServices");
$redirect = redirect(route('booking_detail', [$booking->id]) . "#collapseBookingServices");
break;
case 'update_booking_number':
$redirect = redirect(route('booking_detail', [$booking->id])."#collapseBookingMyJack");
$redirect = redirect(route('booking_detail', [$booking->id]) . "#collapseBookingMyJack");
break;
case 'update_booking_price':
$redirect = redirect(route('booking_detail', [$booking->id])."#collapseBookingPrice");
$redirect = redirect(route('booking_detail', [$booking->id]) . "#collapseBookingPrice");
break;
case 'update_service_provider_entry':
$redirect = redirect(route('booking_detail', [$booking->id])."#collapseBookingProvider");
$redirect = redirect(route('booking_detail', [$booking->id]) . "#collapseBookingProvider");
break;
case 'update_booking_service_item':
$redirect = redirect(route('booking_detail', [$booking->id])."#collapseBookingCompany");
$redirect = redirect(route('booking_detail', [$booking->id]) . "#collapseBookingCompany");
break;
case 'update_booking_participant':
$redirect = redirect(route('booking_detail', [$booking->id])."#collapseBookingParticipant");
$redirect = redirect(route('booking_detail', [$booking->id]) . "#collapseBookingParticipant");
break;
}
}
}
$booking->calculate_price_total();
if(strpos($data['action'], 'up_') !== false) {
if (strpos($data['action'], 'up_') !== false) {
$reId = intval(str_replace('up_', '', $data['action']));
$d_from = BookingDraftItem::findOrFail($reId);
$d_to = $booking->findBeforeDraftItemRelation($reId);
if($d_to) {
if ($d_to) {
$t_pos = $d_from->pos;
$d_from->pos = $d_to->pos;
$d_to->pos = $t_pos;
@ -272,11 +292,11 @@ class BookingController extends Controller
$d_to->save();
}
}
if(strpos($data['action'], 'down_') !== false) {
if (strpos($data['action'], 'down_') !== false) {
$reId = intval(str_replace('down_', '', $data['action']));
$d_from = BookingDraftItem::findOrFail($reId);
$d_to = $booking->findAfterDraftItemRelation($reId);
if($d_to) {
if ($d_to) {
$t_pos = $d_from->pos;
$d_from->pos = $d_to->pos;
$d_to->pos = $t_pos;
@ -288,11 +308,12 @@ class BookingController extends Controller
return $redirect;
}
public function loadModal(){
public function loadModal()
{
$data = Request::all();
$ret = "";
if(Request::ajax()) {
if ($data['action'] === "new-customer-mail" || $data['action'] === "reply-customer-mail" || $data['action'] === "show-customer-mail" || $data['action'] === "edit-customer-mail"){
if (Request::ajax()) {
if ($data['action'] === "new-customer-mail" || $data['action'] === "reply-customer-mail" || $data['action'] === "show-customer-mail" || $data['action'] === "edit-customer-mail") {
$data['customers'] = [];
if ($data['action'] === "new-customer-mail" && isset($data['booking_id']) && $booking = Booking::find($data['booking_id'])) {
$tmp = [];
@ -305,120 +326,119 @@ class BookingController extends Controller
$ret = CustomerMailRepository::loadModal($data);
}
if($data['action'] === "modal-upload-booking-file") {
if ($data['action'] === "modal-upload-booking-file") {
$ret = view("booking.upload_modal", compact('data'))->render();
}
if($data['action'] === "edit_notice") {
if ($data['action'] === "edit_notice") {
$value = BookingNotice::findOrFail($data['id']);
$ret = view("booking.edit_notice_modal", compact('data', 'value'))->render();
}
if($data['action'] === "createPDF_Coupon") {
if ($data['action'] === "createPDF_Coupon") {
$booking = Booking::findOrFail($data['booking_id']);
$data['has_coupon'] = $booking->hasDocument('coupon');
$data['default_value'] = config('booking.coupon_default_value');
$data['default_value'] = config('booking.coupon_default_value');
$data['issue_date'] = date('d.m.Y');
$data['valid_date'] = \Carbon::now()->addMonths(config('booking.coupon_valid_date_month'))->format('d.m.Y');
$ret = view("booking.modal_create_coupon", compact('data'))->render();
}
if($data['action'] === "createPDF_Storno") {
if ($data['action'] === "createPDF_Storno") {
$booking = Booking::findOrFail($data['booking_id']);
$data['price'] = $booking->price;
if($data['has_storno'] = $booking->hasDocument('storno')){
if ($data['has_storno'] = $booking->hasDocument('storno')) {
$document_storno = $booking->getDocument('storno');
$data['storno_date'] = \Carbon::parse($document_storno->data->storno_date)->format('d.m.Y');
$data['storno_print'] = \Carbon::parse($document_storno->data->storno_print)->format('d.m.Y') ;
$data['storno_print'] = \Carbon::parse($document_storno->data->storno_print)->format('d.m.Y');
$data['storno_status_id'] = $document_storno->data->storno_status_id;
$data['storno_level'] = $document_storno->data->storno_level;
$data['storno_level_number'] = _number_format($document_storno->data->storno_level);
$data['storno_total_price'] = '';
}else{
} else {
$data['storno_date'] = date('d.m.Y');
$data['storno_print'] = date('d.m.Y');
$data['storno_status_id'] = null;
$data['storno_level'] = 100;
$data['storno_level'] = 100;
$data['storno_level_number'] = '';
$data['storno_total_price'] = '';
}
$ret = view("booking.modal_create_storno", compact('data'))->render();
}
if($data['action'] === "upload-booking-file"){
if($data['booking_id']){
if ($data['action'] === "upload-booking-file") {
if ($data['booking_id']) {
$bookingFileRepo = new BookingFileRepository(new BookingFile());
$bookingFileRepo->_set('disk', 'booking');
$bookingFileRepo->_set('booking_id', $data['booking_id']);
$bookingFileRepo->_set('dir', '/files/'.date('Y/m').'/');
$bookingFileRepo->_set('dir', '/files/' . date('Y/m') . '/');
$bookingFileRepo->_set('identifier', 'booking');
return $bookingFileRepo->uploadFile(Request::all());
}
}
}
return response()->json(['response' => $data, 'html'=>$ret]);
return response()->json(['response' => $data, 'html' => $ret]);
}
public function draftItemDelete($id){
public function draftItemDelete($id)
{
$booking_draft_item = BookingDraftItem::findOrFail($id);
$booking = $booking_draft_item->booking;
$booking_draft_item->delete();
$booking->calculate_price_total();
\Session()->flash('alert-success', __('Eintrag gelöscht'));
return redirect(route('booking_detail', [$booking->id])."#collapseBookingOrganisation");
return redirect(route('booking_detail', [$booking->id]) . "#collapseBookingOrganisation");
}
public function action($action, $id=false){
public function action($action, $id = false)
{
if(!$booking = Booking::find($id)){
if (!$booking = Booking::find($id)) {
abort(404);
}
if($action === 'change_travel_dates'){
$draftRepo = new DraftRepository($booking);
$draftRepo->change_dates_drafts_from_booking(Request::get('change_travel_start_date'));
\Session()->flash('alert-success', __('Datum der Reise wurde geändert'));
return redirect(route('booking_detail', [$booking->id])."#collapseBookingOrganisation");
if ($action === 'change_travel_dates') {
$draftRepo = new DraftRepository($booking);
$draftRepo->change_dates_drafts_from_booking(Request::get('change_travel_start_date'));
\Session()->flash('alert-success', __('Datum der Reise wurde geändert'));
return redirect(route('booking_detail', [$booking->id]) . "#collapseBookingOrganisation");
}
if($action === 'service_provider_entry_add_discount'){
$ServiceProvider = ServiceProvider::where('type', 'discount')->where('active',true)->first();
if ($action === 'service_provider_entry_add_discount') {
$ServiceProvider = ServiceProvider::where('type', 'discount')->where('active', true)->first();
ServiceProviderEntry::create([
'booking_id' => $booking->id,
'service_provider_id' => $ServiceProvider->id,
'type' => 'discount',
]);
\Session()->flash('alert-success', __('Leistungsträger neuer Rabatt hinzugefügt'));
return redirect(route('booking_detail', [$booking->id])."#collapseBookingProvider");
return redirect(route('booking_detail', [$booking->id]) . "#collapseBookingProvider");
}
if($action === 'service_provider_entry_add_payment'){
$ServiceProvider = ServiceProvider::where('type', 'payment')->where('active',true)->first();
if ($action === 'service_provider_entry_add_payment') {
$ServiceProvider = ServiceProvider::where('type', 'payment')->where('active', true)->first();
ServiceProviderEntry::create([
'booking_id' => $booking->id,
'service_provider_id' => $ServiceProvider->id,
'type' => 'payment',
]);
\Session()->flash('alert-success', __('Leistungsträger neue Zahlung hinzugefügt'));
return redirect(route('booking_detail', [$booking->id])."#collapseBookingProvider");
return redirect(route('booking_detail', [$booking->id]) . "#collapseBookingProvider");
}
if($action === 'booking_service_item_add'){
$TravelCompany = TravelCompany::where('active',true)->first();
if ($action === 'booking_service_item_add') {
$TravelCompany = TravelCompany::where('active', true)->first();
BookingServiceItem::create([
'booking_id' => $booking->id,
'travel_company_id' => $TravelCompany->id,
'travel_date' => now(),
]);
\Session()->flash('alert-success', __('Reiseveranstalter neue Leistung hinzugefügt'));
return redirect(route('booking_detail', [$booking->id])."#collapseBookingCompany");
}
return redirect(route('booking_detail', [$booking->id]) . "#collapseBookingCompany");
}
if($action === 'booking_participant_add'){
if ($action === 'booking_participant_add') {
Participant::create([
'booking_id' => $booking->id,
'nationality_id' => 1,
@ -426,129 +446,129 @@ class BookingController extends Controller
]);
\Session()->flash('alert-success', __('Neuen Teilnehmer hinzugefügt'));
return redirect(route('booking_detail', [$booking->id])."#collapseBookingParticipant");
}
return redirect(route('booking_detail', [$booking->id]) . "#collapseBookingParticipant");
}
}
public function delete($id, $del="booking"){
public function delete($id, $del = "booking")
{
if($del === 'booking_file'){
if ($del === 'booking_file') {
$booking_file = BookingFile::findOrFail($id);
$booking = $booking_file->booking;
$this->deleteBookingFile($booking_file);
\Session()->flash('alert-success', 'Datei gelöscht');
return redirect(route('booking_detail', [$booking->id])."#collapseBookingFiles");
return redirect(route('booking_detail', [$booking->id]) . "#collapseBookingFiles");
}
if($del === 'booking_notice'){
if ($del === 'booking_notice') {
$booking_notice = BookingNotice::findOrFail($id);
$booking = $booking_notice->booking;
$booking_notice->delete();
\Session()->flash('alert-success', 'Notiz gelöscht');
return redirect(route('booking_detail', [$booking->id])."#collapseBookingNotice");
return redirect(route('booking_detail', [$booking->id]) . "#collapseBookingNotice");
}
if($del === 'passolution_file'){
if ($del === 'passolution_file') {
$booking = Booking::findOrFail($id);
$booking->resyncPassolutionPDF();
\Session()->flash('alert-success', 'Passolution erneuert');
return redirect(route('booking_detail', [$booking->id])."#collapseBookingFiles");
return redirect(route('booking_detail', [$booking->id]) . "#collapseBookingFiles");
}
if($del === 'service_provider_entry'){
if ($del === 'service_provider_entry') {
$ServiceProviderEntry = ServiceProviderEntry::findOrFail($id);
$booking = $ServiceProviderEntry->booking;
$ServiceProviderEntry->delete();
\Session()->flash('alert-success', 'Leistungsträger gelöscht');
return redirect(route('booking_detail', [$booking->id])."#collapseBookingProvider");
return redirect(route('booking_detail', [$booking->id]) . "#collapseBookingProvider");
}
if($del === 'booking_service_item'){
if ($del === 'booking_service_item') {
$BookingServiceItem = BookingServiceItem::findOrFail($id);
$booking = $BookingServiceItem->booking;
$BookingServiceItem->delete();
\Session()->flash('alert-success', 'Reiseveranstalter gelöscht');
return redirect(route('booking_detail', [$booking->id])."#collapseBookingCompany");
return redirect(route('booking_detail', [$booking->id]) . "#collapseBookingCompany");
}
if($del === 'participant'){
if ($del === 'participant') {
$Participant = Participant::findOrFail($id);
$booking = $Participant->booking;
$Participant->delete();
\Session()->flash('alert-success', 'Teilnehmer gelöscht');
return redirect(route('booking_detail', [$booking->id])."#collapseBookingParticipant");
return redirect(route('booking_detail', [$booking->id]) . "#collapseBookingParticipant");
}
return redirect(route('requests'));
}
private function deleteBookingFile($booking_file){
private function deleteBookingFile($booking_file)
{
$fileRepo = new BookingFileRepository($booking_file);
$fileRepo->_set('disk', 'booking');
$fileRepo->delete();
$booking_file->delete();
$booking_file->delete();
}
private function deleteCustomerFile($customer_file){
private function deleteCustomerFile($customer_file)
{
$fileRepo = new CustomerFileRepository($customer_file);
$fileRepo->_set('disk', 'customer');
$fileRepo->delete();
$customer_file->delete();
$customer_file->delete();
}
private function deleteBookingDocument($booking_document){
private function deleteBookingDocument($booking_document)
{
$booking_document->deleteFile();
$booking_document->delete();
$booking_document->delete();
}
public function deleteComplete($id){
public function deleteComplete($id)
{
$booking = Booking::findOrFail($id);
if($booking->booking_files){
if ($booking->booking_files) {
foreach ($booking->booking_files as $booking_file) {
$this->deleteBookingFile($booking_file);
}
}
if($booking->booking_notices){
if ($booking->booking_notices) {
foreach ($booking->booking_notices as $booking_notice) {
$booking_notice->delete();
}
}
if($booking->service_provider_entries){
if ($booking->service_provider_entries) {
foreach ($booking->service_provider_entries as $service_provider_entry) {
$service_provider_entry->delete();
}
}
if($booking->booking_service_items){
if ($booking->booking_service_items) {
foreach ($booking->booking_service_items as $booking_service_item) {
$booking_service_item->delete();
}
}
if($booking->booking_provider_services){
if ($booking->booking_provider_services) {
foreach ($booking->booking_provider_services as $booking_provider_service) {
$booking_provider_service->delete();
}
}
if($booking->booking_country_services){
if ($booking->booking_country_services) {
foreach ($booking->booking_country_services as $booking_country_service) {
$booking_country_service->delete();
}
}
if($booking->participants){
if ($booking->participants) {
foreach ($booking->participants as $participant) {
$participant->delete();
}
}
if($booking->customer_mails){
if ($booking->customer_mails) {
foreach ($booking->customer_mails_reverse as $customer_mail) {
if($customer_mail->customer_files){
if ($customer_mail->customer_files) {
foreach ($customer_mail->customer_files as $customer_file) {
$this->deleteCustomerFile($customer_file);
}
@ -556,18 +576,18 @@ class BookingController extends Controller
$customer_mail->delete();
}
}
if($booking->booking_documents){
if ($booking->booking_documents) {
foreach ($booking->booking_documents as $booking_document) {
if($booking_document->identifier === 'coupon'){
if ($booking_document->identifier === 'coupon') {
//coupon set booking ID to null <- is need by the customer
$booking_document->booking_id = null;
$booking_document->save();
}else{
} else {
$this->deleteBookingDocument($booking_document);
}
}
}
if($booking->coupons){
if ($booking->coupons) {
foreach ($booking->coupons as $coupon) {
//coupon set booking ID to null <- is need by the customer
$coupon->booking_id = null;
@ -578,7 +598,4 @@ class BookingController extends Controller
\Session()->flash('alert-success', 'Buchung gelöscht');
return redirect(route('requests'));
}
}

View file

@ -13,17 +13,15 @@ class FileController extends Controller
*
* @return void
*/
public function __construct()
{
}
public function __construct() {}
public function show($id = null, $disk = null, $do='file')
public function show($id = null, $disk = null, $do = 'file')
{
$path = "";
$filename = "";
switch ($disk){
switch ($disk) {
case 'customer':
$file = \App\Models\CustomerFile::findOrFail($id);
$filename = $file->original_name;
@ -66,25 +64,33 @@ class FileController extends Controller
break;
}
if (file_exists($path)) {
// Cache-Control Header für PDFs und andere Dateien, die sich häufig ändern
$headers = [
'Cache-Control' => 'no-cache, no-store, must-revalidate',
'Pragma' => 'no-cache',
'Expires' => '0'
];
switch ($do) {
case 'file':
return Response::file($path);
return Response::file($path, $headers);
break;
case 'download':
return Response::download($path, $filename);
return Response::download($path, $filename, $headers);
break;
case 'url':
return $path.$filename;
return $path . $filename;
break;
}
}
}
public function showExpert($type = null, $class = null, $year = null, $file = null, $do = null) {
public function showExpert($type = null, $class = null, $year = null, $file = null, $do = null)
{
/*if ($type == 'xls') {
$path = storage_path("app/export/");
@ -92,35 +98,39 @@ class FileController extends Controller
}*/
$path = "";
$filename = "";
$headers = [];
$headers = [
'Cache-Control' => 'no-cache, no-store, must-revalidate',
'Pragma' => 'no-cache',
'Expires' => '0'
];
if ($class === 'invoices' || $class === 'infos'){
if ($class === 'invoices' || $class === 'infos') {
$headers = [
'Content-Type: application/pdf',
'Pragma: no-cache',
'Cache-Control: no-store,no-cache, must-revalidate, post-check=0, pre-check=0'
];
$dir = $year."/";
$dir = $year . "/";
$filename = $file;
if ($type === 'fewo') {
if(Storage::disk('fewo_invoices')->exists( $dir.$filename )){
$path = Storage::disk('fewo_invoices')->path($dir.$filename);
if (Storage::disk('fewo_invoices')->exists($dir . $filename)) {
$path = Storage::disk('fewo_invoices')->path($dir . $filename);
}
}
if ($type === 'fewo') {
if(Storage::disk('fewo_infos')->exists( $dir.$filename )){
$path = Storage::disk('fewo_infos')->path($dir.$filename);
if (Storage::disk('fewo_infos')->exists($dir . $filename)) {
$path = Storage::disk('fewo_infos')->path($dir . $filename);
}
}
}
if (file_exists($path)) {
if($do === "download"){
if ($do === "download") {
return Response::download($path, $filename, $headers);
}
if($do === "file"){
if ($do === "file") {
return Response::file($path, $headers);
}
}
}
}
}

View file

@ -27,11 +27,11 @@ class TravelCompanyController extends Controller
public function detail($id, $step = false)
{
if($id === "new") {
if ($id == "new") {
$model = new TravelCompany();
$id = 'new';
$model->active = 1;
}else{
} else {
$model = TravelCompany::findOrFail($id);
$id = $model->id;
}
@ -45,20 +45,21 @@ class TravelCompanyController extends Controller
return view('settings.travel_company.detail', $data);
}
public function update($id){
public function update($id)
{
$data = Request::all();
if(isset($data['update-action'])){
if($data['update-action'] === 'save-travel-company-service'){
$data['active'] = true;//isset($data['active']) ? true : false;
if (isset($data['update-action'])) {
if ($data['update-action'] === 'save-travel-company-service') {
$data['active'] = true; //isset($data['active']) ? true : false;
$travel_company = TravelCompany::findOrFail($id);
$data['travel_company_id'] = $travel_company->id;
if($data['travel_company_service_id'] === 'new'){
if ($data['travel_company_service_id'] === 'new') {
$model = TravelCompanyService::create($data);
}else{
} else {
$model = TravelCompanyService::find($data['travel_company_service_id']);
$model->fill($data);
$model->save();
@ -69,9 +70,9 @@ class TravelCompanyController extends Controller
}
$data['contact_emails'] = isset($data['contact_emails']) ? Util::_explodeLines($data['contact_emails']) : null;
if($id === "new"){
if ($id === "new") {
$model = TravelCompany::create($data);
}else{
} else {
$model = TravelCompany::find($id);
$model->fill($data);
$model->save();
@ -79,12 +80,12 @@ class TravelCompanyController extends Controller
\Session()->flash('alert-save', '1');
return redirect(route('admin_settings_travel_company_detail', [$model->id, $data['action']]));
}
public function delete($id, $del="travel_company"){
public function delete($id, $del = "travel_company")
{
if($del === 'travel_country') {
if ($del === 'travel_country') {
abort(404, 'Noch keine Funktion');
$model = TravelCompany::findOrFail($id);
$model->delete();
@ -92,11 +93,11 @@ class TravelCompanyController extends Controller
return redirect()->back();
}
if($del === 'company_service'){
if ($del === 'company_service') {
$service = TravelCompanyService::findOrFail($id);
$travel_company = $service->travel_company;
//check as entry
if($service->booking_company_services->count() > 0){
if ($service->booking_company_services->count() > 0) {
\Session()->flash('alert-error', 'Die Leistung kann nicht gelöscht werden, diese hat Einträge bei den Buchungen');
return redirect(route('admin_settings_travel_company_detail', [$travel_company->id, 'services']));
}
@ -105,7 +106,4 @@ class TravelCompanyController extends Controller
return redirect(route('admin_settings_travel_company_detail', [$travel_company->id, 'services']));
}
}
}

View file

@ -38,11 +38,11 @@ class TravelCountryController extends Controller
public function detail($id, $step = false)
{
if($id === "new") {
if ($id == "new") {
$model = new TravelCountry();
$id = 'new';
$model->active_backend = 1;
}else{
} else {
$model = TravelCountry::findOrFail($id);
$id = $model->id;
}
@ -62,15 +62,15 @@ class TravelCountryController extends Controller
{
$data = Request::all();
if(isset($data['update-action'])){
if($data['update-action'] === 'save-travel-county-service'){
$data['active'] = true;//isset($data['active']) ? true : false;
if (isset($data['update-action'])) {
if ($data['update-action'] === 'save-travel-county-service') {
$data['active'] = true; //isset($data['active']) ? true : false;
$travel_country = TravelCountry::findOrFail($id);
$data['travel_country_id'] = $travel_country->id;
$data['crm_travel_country_id'] = $travel_country->crm_id;
if($data['travel_county_service_id'] === 'new'){
if ($data['travel_county_service_id'] === 'new') {
$model = TravelCountryService::create($data);
}else{
} else {
$model = TravelCountryService::find($data['travel_county_service_id']);
$model->fill($data);
$model->save();
@ -81,7 +81,7 @@ class TravelCountryController extends Controller
}
$data['contact_emails'] = isset($data['contact_emails']) ? Util::_explodeLines($data['contact_emails']) : null;
if(!isset($data['contact_lands'])){
if (!isset($data['contact_lands'])) {
$data['contact_lands'] = null;
}
$data['action'] = isset($data['action']) ? $data['action'] : false;
@ -90,9 +90,9 @@ class TravelCountryController extends Controller
$data['active_frontend'] = isset($data['active_frontend']) ? true : false;
$data['active_backend'] = isset($data['active_backend']) ? true : false;
*/
if($id === "new"){
if ($id === "new") {
$model = TravelCountry::create($data);
}else{
} else {
$model = TravelCountry::find($id);
$model->fill($data);
$model->save();
@ -106,11 +106,11 @@ class TravelCountryController extends Controller
}
//TODO for this time
$tc = \App\Models\Sym\TravelCountry::find($model->crm_id);
if(!$tc){
if (!$tc) {
$tc = \App\Models\Sym\TravelCountry::create($data);
$model->crm_id = $tc->id;
$model->save();
}else {
} else {
$tc->fill($data);
$tc->save();
}
@ -119,17 +119,18 @@ class TravelCountryController extends Controller
}
public function delete($id, $del="travel_country"){
public function delete($id, $del = "travel_country")
{
if($del === 'travel_country'){
if ($del === 'travel_country') {
$model = TravelCountry::findOrFail($id);
if($model->travel_nationality_requirements){
foreach($model->travel_nationality_requirements as $travel_nationality_requirement){
if ($model->travel_nationality_requirements) {
foreach ($model->travel_nationality_requirements as $travel_nationality_requirement) {
$travel_nationality_requirement->delete();
}
}
$tc = \App\Models\Sym\TravelCountry::find($model->crm_id);
if($tc){
if ($tc) {
$tc->delete();
}
$model->delete();
@ -137,7 +138,7 @@ class TravelCountryController extends Controller
return redirect()->back();
}
if($del === 'general_file'){
if ($del === 'general_file') {
$general_file = GeneralFile::findOrFail($id);
$travel_country = $general_file->travel_country;
$fileRepo = new GeneralFileRepository($general_file);
@ -146,23 +147,18 @@ class TravelCountryController extends Controller
$general_file->delete();
\Session()->flash('alert-success', 'Datei gelöscht');
return redirect(route('admin_settings_travel_country_detail', [$travel_country->id, 'data']));
}
if($del === 'country_service'){
if ($del === 'country_service') {
$travel_country_service = TravelCountryService::findOrFail($id);
$travel_country = $travel_country_service->travel_country;
//check as entry
if($travel_country_service->booking_country_services->count() > 0){
if ($travel_country_service->booking_country_services->count() > 0) {
\Session()->flash('alert-error', 'Die Leistung kann nicht gelöscht werden, diese hat Einträge bei den Buchungen');
return redirect(route('admin_settings_travel_country_detail', [$travel_country->id, 'services']));
}
$travel_country_service->delete();
\Session()->flash('alert-success', 'Eintrag gelöscht');
return redirect(route('admin_settings_travel_country_detail', [$travel_country->id, 'services']));
}
}
}

View file

@ -1,4 +1,5 @@
<?php
namespace App\Libraries;
//use FPDI in myMerge v2
@ -10,10 +11,10 @@ class MyPDFMerger
private $_files; //['form.pdf'] ["1,2,4, 5-19"]
private $_fpdi;
public function __construct()
{
/* if(!class_exists("FPDF")) {
/* if(!class_exists("FPDF")) {
require_once(__DIR__.'/fpdf/fpdf.php');
}
if(!class_exists("FPDI")) {
@ -39,12 +40,14 @@ class MyPDFMerger
public function myMerge($outputmode = 'browser', $outputpath = 'newfile.pdf', $theme = false)
{
if (!isset($this->_files) || !is_array($this->_files)): throw new \exception("No PDFs to merge."); endif;
//$theme = false;
if (!isset($this->_files) || !is_array($this->_files)): throw new \exception("No PDFs to merge.");
endif;
$fpdi = new \setasign\Fpdi\Fpdi();
$first = 1;
//
//merger operations
foreach ($this->_files as $file) {
$filename = $file[0];
@ -60,30 +63,29 @@ class MyPDFMerger
$template = $fpdi->importPage($i);
$size = $fpdi->getTemplateSize($template);
$orientation = ($size['height'] > $size['width']) ? 'P' : 'L';
$fpdi->AddPage($orientation, array($size['width'], $size['height']));
if($theme){
$fpdi->setSourceFile(__DIR__ . '/../../public/pdf/'.$theme.'-'.$first.'.pdf');
if($first == 1){
if ($theme) {
$fpdi->setSourceFile(__DIR__ . '/../../public/pdf/' . $theme . '-' . $first . '.pdf');
if ($first == 1) {
$first = 2;
}
$backId = $fpdi->importPage(1);
$fpdi->useTemplate($backId);
}
$fpdi->useTemplate($template);
}
} else {
foreach ($filepages as $page) {
$count = $fpdi->setSourceFile($filename);
if (!$template = $fpdi->importPage($page)): throw new \exception("Could not load page '$page' in PDF '$filename'. Check that the page exists."); endif;
if (!$template = $fpdi->importPage($page)): throw new \exception("Could not load page '$page' in PDF '$filename'. Check that the page exists.");
endif;
$size = $fpdi->getTemplateSize($template);
$orientation = ($size['h'] > $size['w']) ? 'P' : 'L';
$fpdi->AddPage($orientation, array($size['w'], $size['h']));
if($theme){
$fpdi->setSourceFile(__DIR__ . '/../../public/pdf/'.$theme.'-'.$first.'.pdf');
if($first == 1){
if ($theme) {
$fpdi->setSourceFile(__DIR__ . '/../../public/pdf/' . $theme . '-' . $first . '.pdf');
if ($first == 1) {
$first = 2;
}
$backId = $fpdi->importPage(1);
@ -110,11 +112,9 @@ class MyPDFMerger
return false;
}
}
}
/**
/**
* FPDI uses single characters for specifying the output location. Change our more descriptive string into proper format.
* @param $mode
* @return Character
@ -140,7 +140,7 @@ class MyPDFMerger
}
}
/**
/**
* Takes our provided pages in the form of 1,3,4,16-50 and creates an array of all pages
* @param $pages
* @return array
@ -160,11 +160,13 @@ class MyPDFMerger
$y = $ind[1]; //end page
if ($x > $y): throw new \exception("Starting page, '$x' is greater than ending page '$y'.");
return false; endif;
return false;
endif;
//add middle pages
while ($x <= $y): $newpages[] = (int)$x;
$x++; endwhile;
$x++;
endwhile;
} else {
$newpages[] = (int)$ind[0];
}

View file

@ -207,27 +207,27 @@ class Booking extends Model
protected $table = 'booking';
protected $casts = [
'customer_id' => 'int',
'lead_id' => 'int',
'new_drafts' => 'bool',
'sf_guard_user_id' => 'int',
'branch_id' => 'int',
protected $casts = [
'customer_id' => 'int',
'lead_id' => 'int',
'new_drafts' => 'bool',
'sf_guard_user_id' => 'int',
'branch_id' => 'int',
'airport_id' => 'int',
'service_fee' => 'float',
'travel_country_id' => 'int',
'travel_category_id' => 'int',
'pax' => 'int',
'coupon_id' => 'int',
'website_id' => 'int',
'participant_salutation_id' => 'int',
'travel_company_id' => 'int',
'travel_documents' => 'bool',
'price' => 'float',
'price_total' => 'float',
'deposit_total' => 'float',
'final_payment' => 'float',
'travelagenda_id' => 'int',
'service_fee' => 'float',
'travel_country_id' => 'int',
'travel_category_id' => 'int',
'pax' => 'int',
'coupon_id' => 'int',
'website_id' => 'int',
'participant_salutation_id' => 'int',
'travel_company_id' => 'int',
'travel_documents' => 'bool',
'price' => 'float',
'price_total' => 'float',
'deposit_total' => 'float',
'final_payment' => 'float',
'travelagenda_id' => 'int',
'paying_out' => 'int',
'hold' => 'int',
//'airline_id' => 'int',
@ -240,55 +240,55 @@ class Booking extends Model
'participant_pass' => 'bool'
];
protected $dates = [
'booking_date',
'start_date',
'end_date',
'participant_birthdate',
'final_payment_date',
protected $dates = [
'booking_date',
'start_date',
'end_date',
'participant_birthdate',
'final_payment_date',
'refund_date',
'lawyer_date',
'xx_tkt_date'
];
];
protected $fillable = [
'booking_date',
'customer_id',
'lead_id',
'new_drafts',
'sf_guard_user_id',
'branch_id',
'service_fee',
'travel_country_id',
'travel_category_id',
'pax',
'coupon_id',
'title',
protected $fillable = [
'booking_date',
'customer_id',
'lead_id',
'new_drafts',
'sf_guard_user_id',
'branch_id',
'service_fee',
'travel_country_id',
'travel_category_id',
'pax',
'coupon_id',
'title',
'comfort',
'start_date',
'end_date',
'website_id',
'travel_number',
'participant_name',
'participant_firstname',
'participant_birthdate',
'participant_salutation_id',
'start_date',
'end_date',
'website_id',
'travel_number',
'participant_name',
'participant_firstname',
'participant_birthdate',
'participant_salutation_id',
'participant_pass',
'nationality_id',
'ev_number',
'merlin_knr',
'merlin_order_number',
'travel_company_id',
'travel_documents',
'price',
'ev_number',
'merlin_knr',
'merlin_order_number',
'travel_company_id',
'travel_documents',
'price',
'price_canceled',
'price_total',
'price_total',
'price_balance',
'deposit_total',
'final_payment',
'final_payment_date',
'travelagenda_id',
'deposit_total',
'final_payment',
'final_payment_date',
'travelagenda_id',
'insurance_offer',
'paying_out',
'paying_out_status',
@ -304,10 +304,10 @@ class Booking extends Model
'filekey',
'is_rail_fly',
'notice',
];
];
public static $paying_out_types = [
0 => '-',
public static $paying_out_types = [
0 => '-',
1 => 'Gutschein',
2 => 'Auszahlung',
3 => 'Umbuchung',
@ -345,8 +345,8 @@ class Booking extends Model
];
public static $customer_mail_dirs = [
11 => ['name' => 'Entwürfe', 'icon'=>'ion-md-create'],
12 => ['name' => 'Papierkorb', 'icon'=>'ion-md-trash'],
11 => ['name' => 'Entwürfe', 'icon' => 'ion-md-create'],
12 => ['name' => 'Papierkorb', 'icon' => 'ion-md-trash'],
];
protected $paying_out_colors = [
0 => '',
@ -377,47 +377,47 @@ class Booking extends Model
protected $passolutionPDFs = [];
/*public function branch()
/*public function branch()
{
return $this->belongsTo(Branch::class);
}*/
public function coupon()
{
return $this->belongsTo(Coupon::class);
}
public function coupon()
{
return $this->belongsTo(Coupon::class);
}
public function customer()
{
return $this->belongsTo(Customer::class);
}
public function customer()
{
return $this->belongsTo(Customer::class);
}
public function lead()
{
return $this->belongsTo(Lead::class);
}
public function lead()
{
return $this->belongsTo(Lead::class);
}
public function sf_guard_user()
{
return $this->belongsTo(SfGuardUser::class);
}
public function sf_guard_user()
{
return $this->belongsTo(SfGuardUser::class);
}
public function travel_category()
{
return $this->belongsTo(TravelCategory::class);
}
public function travel_category()
{
return $this->belongsTo(TravelCategory::class);
}
public function travel_company()
{
return $this->belongsTo(TravelCompany::class);
}
public function travel_company()
{
return $this->belongsTo(TravelCompany::class);
}
public function airport()
{
return $this->belongsTo(Airport::class, 'airport_id');
}
{
return $this->belongsTo(Airport::class, 'airport_id');
}
/* public function travel_country()
/* public function travel_country()
{
return $this->belongsTo(TravelCountry::class, 'travel_country_id', 'crm_id');
}*/
@ -428,64 +428,64 @@ class Booking extends Model
return $this->belongsTo(\App\Models\Sym\TravelCountry::class, 'travel_country_id', 'id');
}
public function travel_agenda()
{
return $this->belongsTo(TravelAgenda::class, 'travelagenda_id');
}
/*public function airline()
public function travel_agenda()
{
return $this->belongsTo(TravelAgenda::class, 'travelagenda_id');
}
/*public function airline()
{
return $this->belongsTo(Airline::class, 'airline_id');
}
*/
public function arrangements()
{
return $this->hasMany(Arrangement::class);
}
public function arrangements()
{
return $this->hasMany(Arrangement::class)->orderBy('view_position', 'DESC');
}
public function arrangement_types()
{
return $this->hasMany(ArrangementType::class);
}
public function arrangement_types()
{
return $this->hasMany(ArrangementType::class);
}
public function booking_draft_items()
{
return $this->hasMany(BookingDraftItem::class)->orderBy('pos', 'ASC');
}
public function booking_draft_items()
{
return $this->hasMany(BookingDraftItem::class)->orderBy('pos', 'ASC');
}
public function booking_service_items()
{
return $this->hasMany(BookingServiceItem::class);
}
public function booking_service_items()
{
return $this->hasMany(BookingServiceItem::class);
}
public function coupons()
{
return $this->hasMany(Coupon::class);
}
public function coupons()
{
return $this->hasMany(Coupon::class);
}
public function insurance_certificates()
{
return $this->hasMany(InsuranceCertificate::class);
}
public function insurance_certificates()
{
return $this->hasMany(InsuranceCertificate::class);
}
public function participants()
{
return $this->hasMany(Participant::class);
}
public function participants()
{
return $this->hasMany(Participant::class);
}
public function participant_salutation()
{
return $this->belongsTo(Salutation::class, 'participant_salutation_id');
}
{
return $this->belongsTo(Salutation::class, 'participant_salutation_id');
}
public function service_provider_entries()
{
return $this->hasMany(ServiceProviderEntry::class);
}
public function service_provider_entries()
{
return $this->hasMany(ServiceProviderEntry::class);
}
public function customer_mails()
@ -519,9 +519,9 @@ class Booking extends Model
}
public function booking_stornos()
{
return $this->hasMany(BookingStorno::class);
}
{
return $this->hasMany(BookingStorno::class);
}
/*public function booking_invoices()
{
@ -529,19 +529,19 @@ class Booking extends Model
}*/
public function booking_vouchers()
{
return $this->hasMany(BookingVoucher::class);
}
{
return $this->hasMany(BookingVoucher::class);
}
public function booking_voucher_agencys()
{
return $this->hasMany(BookingVoucherAgency::class);
}
{
return $this->hasMany(BookingVoucherAgency::class);
}
public function travel_insurances()
{
return $this->hasMany(TravelInsurance::class);
}
public function travel_insurances()
{
return $this->hasMany(TravelInsurance::class);
}
public function booking_files()
{
@ -592,17 +592,17 @@ class Booking extends Model
}
public function booking_strono()
{
return $this->hasOne(BookingStorno::class);
}
{
return $this->hasOne(BookingStorno::class);
}
public function getAirlinesAsNames()
{
$ret = "";
if($this->airline_ids){
foreach($this->airline_ids as $airline_id){
if($Airline = Airline::find($airline_id)){
$ret .= $Airline->name." ";
if ($this->airline_ids) {
foreach ($this->airline_ids as $airline_id) {
if ($Airline = Airline::find($airline_id)) {
$ret .= $Airline->name . " ";
}
}
}
@ -610,13 +610,13 @@ class Booking extends Model
}
public function getAirlinesIds()
{
if($this->airline_ids){
if ($this->airline_ids) {
return implode('', $this->airline_ids);
}
return "";
}
public function hasBookingServicesUnchecked(){
public function hasBookingServicesUnchecked()
{
$country_services = true;
$provider_services = true;
$company_services = true;
@ -625,101 +625,102 @@ class Booking extends Model
$has_provider_services = false;
$has_company_services = false;
if($this->travel_country){
foreach($this->travel_country->getContactLandsModels() as $TravelCountry){
if($TravelCountry->stern_travel_country){
if($TravelCountry->stern_travel_country->travel_country_services->count()){
if ($this->travel_country) {
foreach ($this->travel_country->getContactLandsModels() as $TravelCountry) {
if ($TravelCountry->stern_travel_country) {
if ($TravelCountry->stern_travel_country->travel_country_services->count()) {
$has_country_services = true;
}
}
}
}
if($has_country_services && !$this->booking_country_services->count() || $this->booking_country_services_checked->count() ||
($this->booking_country_services->count() !== TravelCountryService::where('crm_travel_country_id', '=', $this->travel_country_id)->count())){
$country_services = false;
if (
$has_country_services && !$this->booking_country_services->count() || $this->booking_country_services_checked->count() ||
($this->booking_country_services->count() !== TravelCountryService::where('crm_travel_country_id', '=', $this->travel_country_id)->count())
) {
$country_services = false;
}
foreach($this->service_provider_entries as $service_provider_entry){
if($service_provider_entry->service_provider && $service_provider_entry->service_provider->service_provider_services->count()){
foreach ($this->service_provider_entries as $service_provider_entry) {
if ($service_provider_entry->service_provider && $service_provider_entry->service_provider->service_provider_services->count()) {
$has_provider_services = true;
}
}
if($has_provider_services && !$this->booking_provider_services->count() || $this->booking_provider_services_checked->count()){
if($this->service_provider_entries->count()){
if ($has_provider_services && !$this->booking_provider_services->count() || $this->booking_provider_services_checked->count()) {
if ($this->service_provider_entries->count()) {
$provider_services = false;
}
}
foreach($this->booking_service_items as $booking_service_item){
if($booking_service_item->travel_company && $booking_service_item->travel_company->travel_company_services->count()){
foreach ($this->booking_service_items as $booking_service_item) {
if ($booking_service_item->travel_company && $booking_service_item->travel_company->travel_company_services->count()) {
$has_company_services = true;
}
}
if($has_company_services && !$this->booking_company_services->count() || $this->booking_company_services_checked->count()){
if($this->booking_service_items->count()){
$company_services = false;
if ($has_company_services && !$this->booking_company_services->count() || $this->booking_company_services_checked->count()) {
if ($this->booking_service_items->count()) {
$company_services = false;
}
}
if(!$has_country_services && !$has_provider_services && !$has_company_services){
if (!$has_country_services && !$has_provider_services && !$has_company_services) {
return false;
}
if($country_services && $provider_services && $company_services){
if ($country_services && $provider_services && $company_services) {
return true;
}
return false;
}
public function hasBookingParticipantsPass(){
if($this->participant_firstname){
if(!$this->participant_pass){
public function hasBookingParticipantsPass()
{
if ($this->participant_firstname) {
if (!$this->participant_pass) {
return false;
}
}
if($this->participants->count()){
foreach($this->participants as $participant){
if(!$participant->participant_pass){
if ($this->participants->count()) {
foreach ($this->participants as $participant) {
if (!$participant->participant_pass) {
return false;
}
}
}
return true;
}
public function getPassolutionPDF($create = false, $resync = false){
public function getPassolutionPDF($create = false, $resync = false)
{
$nats = [];
if(count($this->passolutionPDFs)){
return $this->passolutionPDFs;
if (count($this->passolutionPDFs)) {
return $this->passolutionPDFs;
}
if(!$this->travel_country){
return $this->passolutionPDFs;
if (!$this->travel_country) {
return $this->passolutionPDFs;
}
$destco = $this->travel_country->destco;
if($this->travel_nationality){
if ($this->travel_nationality) {
$nats[$this->travel_nationality->nat] = $this->travel_nationality->nat;
}
if($this->participants->count()){
foreach ($this->participants as $participant){
if($participant->travel_nationality){
if ($this->participants->count()) {
foreach ($this->participants as $participant) {
if ($participant->travel_nationality) {
$nats[$participant->travel_nationality->nat] = $participant->travel_nationality->nat;
}
}
}
if(empty($nats)){
$nats['de'] = 'de';
}
foreach ($nats as $nat){
if (empty($nats)) {
$nats['de'] = 'de';
}
foreach ($nats as $nat) {
$data = [
'nat' => $nat,
'destco' => $destco,
@ -728,11 +729,12 @@ class Booking extends Model
$passolution = new Passolution($data);
$this->passolutionPDFs[] = $passolution->findOrCreatePDF($create, $resync);
}
return $this->passolutionPDFs;
return $this->passolutionPDFs;
}
public function resyncPassolutionPDF(){
return $this->getPassolutionPDF(true, true);
public function resyncPassolutionPDF()
{
return $this->getPassolutionPDF(true, true);
}
public function calculate_price_total()
@ -746,13 +748,13 @@ class Booking extends Model
$travel_children = 0;
foreach ($this->booking_draft_items as $booking_draft_item) {
//24 Rundreise ist der Grundeintrag für die Reise
if($booking_draft_item->draft_type_id == 24){
if ($booking_draft_item->draft_type_id == 24) {
$travel_draft_item = $booking_draft_item;
continue;
}
$prices = $booking_draft_item->getItemPrice();
//Grundpreis Reise //pro Persopn im Zimmer
if($booking_draft_item->draft_type_id == 30){
if ($booking_draft_item->draft_type_id == 30) {
$travel_price_adult += $prices['adult'];
$travel_price_children += $prices['children'];
$travel_adult += $booking_draft_item->adult;
@ -762,9 +764,9 @@ class Booking extends Model
$total_children += $prices['children'];
}
if($travel_draft_item){
if ($travel_draft_item) {
$travel_draft_item->setPriceAdultRaw($travel_price_adult);
$travel_draft_item->setPriceChildrenRaw($travel_price_children);
$travel_draft_item->adult = $travel_adult;
@ -774,7 +776,6 @@ class Booking extends Model
$this->price = $total_adult + $total_children;
$this->price_total = $this->getPriceRaw() + $this->getServiceTotal(true);
$this->save();
}
public function getPriceAttribute()
@ -845,7 +846,7 @@ class Booking extends Model
public function findBeforeDraftItemRelation($reid)
{
$before = false;
foreach($this->booking_draft_items as $booking_draft_items) {
foreach ($this->booking_draft_items as $booking_draft_items) {
if ($booking_draft_items->id == $reid) {
return $before;
}
@ -857,8 +858,8 @@ class Booking extends Model
public function findAfterDraftItemRelation($reid)
{
$next = false;
foreach($this->booking_draft_items as $booking_draft_items) {
if($next){
foreach ($this->booking_draft_items as $booking_draft_items) {
if ($next) {
return $booking_draft_items;
}
if ($booking_draft_items->id == $reid) {
@ -868,41 +869,54 @@ class Booking extends Model
return false;
}
public function getStartDateFormat(){
if(!$this->attributes['start_date']){ return ""; }
public function getStartDateFormat()
{
if (!$this->attributes['start_date']) {
return "";
}
return Carbon::parse($this->attributes['start_date'])->format(\Util::formatDateDB());
}
public function getEndDateFormat(){
if(!$this->attributes['end_date']){ return ""; }
public function getEndDateFormat()
{
if (!$this->attributes['end_date']) {
return "";
}
return Carbon::parse($this->attributes['end_date'])->format(\Util::formatDateDB());
}
public function getBookingDateFormat(){
if(!$this->attributes['booking_date']){ return ""; }
public function getBookingDateFormat()
{
if (!$this->attributes['booking_date']) {
return "";
}
return Carbon::parse($this->attributes['booking_date'])->format(\Util::formatDateDB());
}
public function getFinalPaymentDateFormat(){
if(!$this->attributes['final_payment_date']){ return ""; }
public function getFinalPaymentDateFormat()
{
if (!$this->attributes['final_payment_date']) {
return "";
}
return Carbon::parse($this->attributes['final_payment_date'])->format(\Util::formatDateDB());
}
public function isCanceled(){
public function isCanceled()
{
return ($this->attributes['canceled'] !== null);
}
//erlös #getRevenueFactor
public function proceeds($raw = false){
public function proceeds($raw = false)
{
$proceeds = $this->attributes['price'] - $this->attributes['price_balance'] - $this->getServiceProviderPaymentsFactorTotal(true);
return $raw ? $proceeds : Util::_number_format($proceeds);
}
public function getServiceTotal($raw = false)
{
$total = 0;
foreach ($this->booking_service_items as $booking_service_item){
foreach ($this->booking_service_items as $booking_service_item) {
$total += $booking_service_item->getServicePriceRaw();
}
return $raw ? $total : Util::_number_format($total);
@ -912,7 +926,7 @@ class Booking extends Model
public function getServiceProviderPaymentsFactorTotal($raw = false)
{
$total = 0;
foreach ($this->service_provider_entries as $entry){
foreach ($this->service_provider_entries as $entry) {
$total += $entry->getAmountRaw() / $entry->getFactortRaw();
}
return $raw ? $total : Util::_number_format($total);
@ -921,15 +935,16 @@ class Booking extends Model
public function getServiceProviderPaymentsTotal($raw = false)
{
$total = 0;
foreach ($this->service_provider_entries as $entry){
foreach ($this->service_provider_entries as $entry) {
$total += $entry->getAmountRaw();
}
return $raw ? $total : Util::_number_format($total);
}
public function getKontoNumber(){
public function getKontoNumber()
{
switch ($this->ev_number){
switch ($this->ev_number) {
case 'E01':
return '4011';
break;
@ -942,44 +957,48 @@ class Booking extends Model
case 'E04':
return '4014';
break;
}
return $this->ev_number;
}
public function getBookingNumber()
{
if ($this->lead)
{
if ($this->lead) {
return $this->lead->id;
}
return null;
}
public function getPayingOutType(){
public function getPayingOutType()
{
return isset(self::$paying_out_types[$this->paying_out]) ? self::$paying_out_types[$this->paying_out] : '-';
}
public function getInsuranceOfferType(){
public function getInsuranceOfferType()
{
return isset(self::$insurance_offer_types[$this->insurance_offer]) ? self::$insurance_offer_types[$this->insurance_offer] : '-';
}
public function getPayingOutStatusType(){
public function getPayingOutStatusType()
{
return isset(self::$paying_out_status_types[$this->paying_out_status]) ? self::$paying_out_status_types[$this->paying_out_status] : '-';
}
public function getRefundType(){
public function getRefundType()
{
return isset(self::$refund_types[$this->refund]) ? self::$refund_types[$this->refund] : '-';
}
public function getXxTktType(){
public function getXxTktType()
{
return isset(self::$xx_tkt_types[$this->xx_tkt]) ? self::$xx_tkt_types[$this->xx_tkt] : '-';
}
public function getXxTktTypeList(){
if(isset(self::$xx_tkt_types[$this->xx_tkt])){
if($this->xx_tkt == 1 && $this->xx_tkt_date){
public function getXxTktTypeList()
{
if (isset(self::$xx_tkt_types[$this->xx_tkt])) {
if ($this->xx_tkt == 1 && $this->xx_tkt_date) {
return Carbon::parse($this->xx_tkt_date)->format('d.m.Y');
}
return self::$xx_tkt_types[$this->xx_tkt];
@ -987,9 +1006,10 @@ class Booking extends Model
return "-";
}
public function getRefundTypeList(){
if(isset(self::$refund_types[$this->refund])){
if($this->refund == 1 && $this->refund_date){
public function getRefundTypeList()
{
if (isset(self::$refund_types[$this->refund])) {
if ($this->refund == 1 && $this->refund_date) {
return Carbon::parse($this->refund_date)->format('d.m.Y');
}
return self::$refund_types[$this->refund];
@ -997,57 +1017,65 @@ class Booking extends Model
return "-";
}
public function getPayingOutColor(){
public function getPayingOutColor()
{
return isset($this->paying_out_colors[$this->paying_out]) ? $this->paying_out_colors[$this->paying_out] : '';
}
public function getPayingOutStatusColor(){
public function getPayingOutStatusColor()
{
return isset($this->paying_out_status_colors[$this->paying_out_status]) ? $this->paying_out_status_colors[$this->paying_out_status] : '';
}
public function getRefundColor(){
public function getRefundColor()
{
return isset($this->refund_colors[$this->refund]) ? $this->refund_colors[$this->refund] : '-';
}
public function getXxTktColor(){
public function getXxTktColor()
{
return isset($this->xx_tkt_colors[$this->xx_tkt]) ? $this->xx_tkt_colors[$this->xx_tkt] : '-';
}
public function countCustomerMailsBy($dir, $subdir=false){
public function countCustomerMailsBy($dir, $subdir = false)
{
if($dir === 11){
if ($dir === 11) {
return $this->customer_mails->where('draft', true)->where('dir', '!=', 12)->count();
}
if($subdir){
return $this->customer_mails->where('dir', $dir)->where('subdir', $subdir)->count();
if ($subdir) {
return $this->customer_mails->where('dir', $dir)->where('subdir', $subdir)->count();
}
return $this->customer_mails->where('dir', $dir)->count();
}
/*DOCUMENTS*/
public function hasDocument($identifier){
public function hasDocument($identifier)
{
return $this->booking_documents->where('identifier', $identifier)->count() ? true : false;
}
public function getDocument($identifier){
public function getDocument($identifier)
{
return $this->booking_documents->where('identifier', $identifier)->first();
}
public function isDepositPossible($maxIntervalDays = false)
{
$maxIntervalDays = $maxIntervalDays ? $maxIntervalDays : config('booking.max_interval_days');
$diffInDays = $this->booking_date->diffInDays($this->start_date, false);
return $diffInDays > $maxIntervalDays;
$maxIntervalDays = $maxIntervalDays ? $maxIntervalDays : config('booking.max_interval_days');
$diffInDays = $this->booking_date->diffInDays($this->start_date, false);
return $diffInDays > $maxIntervalDays;
}
public function getConfirmationDeposit($percentageRate = false){
public function getConfirmationDeposit($percentageRate = false)
{
$percentageRate = $percentageRate ? $percentageRate : config('booking.deposit_percentage_rate');
return ($this->isDepositPossible() ? round($this->getPriceRaw() * $percentageRate / 100) : 0);
}
public function getConfirmationFinalPayment(){
public function getConfirmationFinalPayment()
{
return $this->getPriceRaw() - $this->getConfirmationDeposit();
}
}

View file

@ -44,34 +44,34 @@ class TravelCompany extends Model
protected $connection = 'mysql';
protected $table = 'travel_company';
public $timestamps = false;
public $timestamps = false;
protected $casts = [
'percentage' => 'float',
'is_allowed_edit_commission' => 'bool',
'is_inhouse' => 'bool',
protected $casts = [
'percentage' => 'float',
'is_allowed_edit_commission' => 'bool',
'is_inhouse' => 'bool',
'active' => 'bool',
'contact_emails' => 'array'
];
protected $fillable = [
'name',
'percentage',
'is_allowed_edit_commission',
'is_inhouse',
protected $fillable = [
'name',
'percentage',
'is_allowed_edit_commission',
'is_inhouse',
'contact_emails',
'active'
];
public function bookings()
{
return $this->hasMany(Booking::class);
}
public function bookings()
{
return $this->hasMany(Booking::class);
}
public function booking_service_items()
{
return $this->hasMany(BookingServiceItem::class);
}
public function booking_service_items()
{
return $this->hasMany(BookingServiceItem::class);
}
public function travel_company_services()
{
return $this->hasMany(TravelCompanyService::class, 'travel_company_id', 'id')->orderBy('pos', 'DESC');
@ -84,7 +84,7 @@ class TravelCompany extends Model
public function getPercentageAttribute()
{
return Util::_number_format($this->attributes['percentage']);
return isset($this->attributes['percentage']) ? Util::_number_format($this->attributes['percentage']) : 0;
}
public function getPercentageRaw()

72
app/Policies/ModelPolicy.php Executable file
View file

@ -0,0 +1,72 @@
<?php
namespace App\Policies;
use App\User;
use Illuminate\Auth\Access\HandlesAuthorization;
use Illuminate\Database\Eloquent\Model;
abstract class ModelPolicy
{
use HandlesAuthorization;
abstract protected function getModelClass(): string;
public function viewAny(User $user)
{
return $user->can('view-any-' . $this->getModelClass());
}
public function view(User $user, Model $model)
{
if ($user->can('view-' . $this->getModelClass())) {
return true;
}
if ($user->can('view-self-' . $this->getModelClass())) {
return $this->isOwner($user, $model);
}
return false;
}
public function create(User $user)
{
return $user->can('create-' . $this->getModelClass());
}
public function update(User $user, Model $model)
{
if ($user->can('update-' . $this->getModelClass())) {
return true;
}
if ($user->can('update-self-' . $this->getModelClass())) {
return $this->isOwner($user, $model);
}
return false;
}
public function delete(User $user, Model $model)
{
if ($user->can('delete-' . $this->getModelClass())) {
return true;
}
if ($user->can('delete-self-' . $this->getModelClass())) {
return $this->isOwner($user, $model);
}
return false;
}
private function isOwner(User $user, Model $model): bool
{
if (!empty($user) && method_exists($model, 'user')) {
return $user->getKey() === $model->getRelation('user')->getKey();
}
return false;
}
}

View file

@ -3,6 +3,7 @@
namespace App\Providers;
use Illuminate\Support\Facades\Schema;
use Illuminate\Support\Facades\URL;
use Illuminate\Support\ServiceProvider;
class AppServiceProvider extends ServiceProvider
@ -14,6 +15,7 @@ class AppServiceProvider extends ServiceProvider
*/
public function boot()
{
URL::forceScheme('https');
Schema::defaultStringLength(191);
}

View file

@ -14,7 +14,8 @@ use App\Libraries\CreatePDFCoupon;
use Carbon;
use Illuminate\Support\Facades\Storage;
class BookingPDFRepository extends BaseRepository {
class BookingPDFRepository extends BaseRepository
{
protected $prepath;
@ -29,7 +30,8 @@ class BookingPDFRepository extends BaseRepository {
return $this->model;
}
public function createPDF($id, $data){
public function createPDF($id, $data)
{
$this->model = Booking::findOrFail($id);
@ -57,7 +59,8 @@ class BookingPDFRepository extends BaseRepository {
}
}
public function createPDF_Registration(){
public function createPDF_Registration()
{
$document = new stdClass();
$document->name = 'registration';
$document->number = $this->model->lead_id;
@ -65,22 +68,21 @@ class BookingPDFRepository extends BaseRepository {
$document->voucher = null;
$document->date = now();
$document->total = $this->model->getPriceRaw();
$dir = $this->getDirPath('pdf', 'booking', $document->date->format('Y'));
$filename = "Buchnungsauftrag-".$this->model->lead_id.".pdf";
$filename = "Buchnungsauftrag-" . $this->model->lead_id . ".pdf";
$pdf_file = new CreatePDF('pdf.booking_registration');
$data = [
'booking' => $this->model,
'document' => $document,
];
$pdf_file->create($data, $filename, 'save', $this->prepath.$dir);
$booking_document = $this->savePDF($dir, $filename, 'sterntours-template', 'registration', $document);
];
$pdf_file->create($data, $filename, 'save', $this->prepath . $dir);
$booking_document = $this->savePDF($dir, $filename, 'sterntours-template', 'registration', $document);
return $booking_document;
}
public function createPDF_Confirmation(){
public function createPDF_Confirmation()
{
$document = new stdClass();
$document->name = 'confirmation';
$document->number = $this->model->lead_id;
@ -92,32 +94,31 @@ class BookingPDFRepository extends BaseRepository {
$document->deposit = $this->model->getConfirmationDeposit();
$document->final_payment = $this->model->getConfirmationFinalPayment();
if ($this->model->isDepositPossible())
{
if ($this->model->isDepositPossible()) {
$document->deposit_payment_date = date('Y-m-d');
$maxDepositIntervalDays = config('booking.max_deposit_interval_days');
$_start_date = clone $this->model->start_date;
$_start_date->modify('-'.$maxDepositIntervalDays.' days');
$document->final_payment_date = $_start_date->format('Y-m-d');
}
else {
$_start_date->modify('-' . $maxDepositIntervalDays . ' days');
$document->final_payment_date = $_start_date->format('Y-m-d');
} else {
$document->final_payment_date = date('Y-m-d');
}
$dir = $this->getDirPath('pdf', 'booking', $document->date->format('Y'));
$filename = "Reisebestätigung-".$this->model->lead_id.".pdf";
$filename = "Reisebestätigung-" . $this->model->lead_id . ".pdf";
$pdf_file = new CreatePDF('pdf.booking_confirmation');
$data = [
'booking' => $this->model,
'document' => $document,
];
$pdf_file->create($data, $filename, 'save', $this->prepath.$dir);
$booking_document = $this->savePDF($dir, $filename, 'sterntours-template', 'confirmation', $document);
];
$pdf_file->create($data, $filename, 'save', $this->prepath . $dir);
$booking_document = $this->savePDF($dir, $filename, 'sterntours-template', 'confirmation', $document);
return $booking_document;
return $booking_document;
}
public function createPDF_Coupon($data){
public function createPDF_Coupon($data)
{
$document = new stdClass();
$document->name = 'coupon';
@ -133,7 +134,7 @@ class BookingPDFRepository extends BaseRepository {
$coupon->valid_date = $data['valid_date'];
$coupon->is_redeemed = false;
$coupon->save();
$document->number = $coupon->number;
$document->value = $coupon->value;
$document->issue_date = $coupon->issue_date;
@ -142,61 +143,63 @@ class BookingPDFRepository extends BaseRepository {
$dir = $this->getDirPath('pdf', 'coupon', $document->date->format('Y'));
$filename = "Gutschein-".$coupon->number.".pdf";
$filename = "Gutschein-" . $coupon->number . ".pdf";
$pdf_file = new CreatePDFCoupon('pdf.booking_coupon');
$data = [
$data = [
'booking' => $this->model,
'document' => $document,
'coupon' => $coupon,
];
$pdf_file->create($data, $filename, 'save', $this->prepath.$dir);
$booking_document = $this->savePDF($dir, $filename, 'sterntours-coupon', 'coupon', $document);
return $booking_document;
];
$pdf_file->create($data, $filename, 'save', $this->prepath . $dir);
$booking_document = $this->savePDF($dir, $filename, 'sterntours-coupon', 'coupon', $document);
return $booking_document;
}
public function createPDF_Voucher($agency = false){
public function createPDF_Voucher($agency = false)
{
$document = new stdClass();
$document->name = 'voucher';
$document->number = $this->model->lead_id;
$document->name = 'voucher';
$document->title = $agency ? 'VOUCHER Agentur': 'VOUCHER';
$document->voucher = $agency ? 'agency': 'client';
$document->title = $agency ? 'VOUCHER Agentur' : 'VOUCHER';
$document->voucher = $agency ? 'agency' : 'client';
$document->date = now();
$dir = $this->getDirPath('pdf', 'voucher', $document->date->format('Y'));
$filename = ($agency ? 'VoucherAgentur': 'Voucher')."-".$this->model->lead_id.".pdf";
$filename = ($agency ? 'VoucherAgentur' : 'Voucher') . "-" . $this->model->lead_id . ".pdf";
$pdf_file = new CreatePDF('pdf.booking_voucher');
$data = [
'booking' => $this->model,
'document' => $document,
];
$pdf_file->create($data, $filename, 'save', $this->prepath.$dir);
$identifier = $agency ? 'voucher_agency': 'voucher';
$booking_document = $this->savePDF($dir, $filename, 'sterntours-template', $identifier, $document);
];
$pdf_file->create($data, $filename, 'save', $this->prepath . $dir);
$identifier = $agency ? 'voucher_agency' : 'voucher';
$booking_document = $this->savePDF($dir, $filename, 'sterntours-template', $identifier, $document);
return $booking_document;
return $booking_document;
}
public function createPDF_Storno($data){
public function createPDF_Storno($data)
{
//Storno Values
$storno_status_id = (int) $data['storno_status_id'];
$storno_level = (float) $data['storno_level'];
$storno_level_number = \Util::_clean_float($data['storno_level_number']);
$storno_total_price = \Util::_clean_float($data['storno_total_price']);
$price = $this->model->getPriceRaw();
if($storno_level_number > 0 && $storno_level_number < 100 ){
if ($storno_level_number > 0 && $storno_level_number < 100) {
$storno_level = $storno_level_number;
}
//calculate price canceled
if($storno_total_price > 0){
if ($storno_total_price > 0) {
$price_canceled = $storno_total_price;
$storno_level = ((100 / $price) * $storno_total_price);
}else{
} else {
$price_canceled = round($price / 100 * $storno_level, 2);
}
//init identifier
$identifier = 'storno';
@ -210,11 +213,11 @@ class BookingPDFRepository extends BaseRepository {
'storno_print' => $data['storno_print'],
'binary_data' => NULL,
];
if($this->model->hasDocument($identifier)){
if ($this->model->hasDocument($identifier)) {
$booking_document = $this->model->getDocument($identifier);
$booking_storno = $booking_document->booking_storno;
$booking_storno->update($fill);
}else{
} else {
$booking_storno = BookingStorno::create($fill);
}
@ -233,53 +236,54 @@ class BookingPDFRepository extends BaseRepository {
$document->booking_storno_id = $booking_storno->id;
$document->storno_level = $storno_level;
//update Booking // Lead Status
if($storno_status_id){
if ($storno_status_id) {
$this->model->lead->status_id = $storno_status_id;
$this->model->lead->save();
}
$this->model->canceled = $storno_level;
$this->model->price_canceled = $price_canceled; //must pay
$this->model->price_total = $price_canceled; //is the same as Canceled( ...
$this->model->price_balance = round($price - $price_canceled, 2); //is the Rest - must not pay
$this->model->save();
$dir = $this->getDirPath('pdf', 'storno', $document->date->format('Y'));
$filename = "Reisestornierung -".$this->model->lead_id.".pdf";
$filename = "Reisestornierung -" . $this->model->lead_id . ".pdf";
$pdf_file = new CreatePDF('pdf.booking_storno');
$data = [
'booking' => $this->model,
'document' => $document,
];
$pdf_file->create($data, $filename, 'save', $this->prepath.$dir);
$this->savePDF($dir, $filename, 'sterntours-template', $identifier, $document);
];
$pdf_file->create($data, $filename, 'save', $this->prepath . $dir);
$this->savePDF($dir, $filename, 'sterntours-template', $identifier, $document);
}
//get Invoice Name / Paths / ...
private function getDirPath($file, $dir, $year){
$path = $file.'/'.$dir.'/'.$year.'/';
if(!Storage::disk('public')->exists( $path )){
//get Invoice Name / Paths / ...
private function getDirPath($file, $dir, $year)
{
$path = $file . '/' . $dir . '/' . $year . '/';
if (!Storage::disk('public')->exists($path)) {
Storage::disk('public')->makeDirectory($path); //creates directory
}
return $path;
}
private function savePDF($dir, $filename, $template, $identifier, $document = null, $status = 0){
private function savePDF($dir, $filename, $template, $identifier, $document = null, $status = 0)
{
$pdfMerger = new MyPDFMerger();
$pdfMerger->addPDF($this->prepath.$dir.$filename);
$pdfMerger->addPDF($this->prepath . $dir . $filename);
$file = $pdfMerger->myMerge('string', $filename, $template);
Storage::disk('public')->put($dir.$filename, $file);
Storage::disk('public')->put($dir . $filename, $file);
$fill = [
'booking_id' => $this->model->id,
@ -291,25 +295,23 @@ class BookingPDFRepository extends BaseRepository {
'original_name' => $filename,
'ext' => 'pdf',
'mine' => 'application/pdf',
'size' => Storage::disk('public')->size($dir.$filename),
'size' => Storage::disk('public')->size($dir . $filename),
'date' => now(),
'data' => $document,
'status' => $status,
'booking_storno_id' => isset($document->booking_storno_id) ? $document->booking_storno_id : null,
'coupon_id' => isset($document->coupon_id) ? $document->coupon_id : null,
];
if($this->model->hasDocument($identifier)){
if ($this->model->hasDocument($identifier)) {
$booking_document = $this->model->getDocument($identifier);
$booking_document->update($fill);
}else{
} else {
$booking_document = BookingDocument::create($fill);
}
return $booking_document;
//return $pdfMerger->myMerge('browser', $filename, $template);
//return $pdfMerger->myMerge('browser', $filename, $template);
}
}

View file

@ -3,19 +3,21 @@
namespace App\Repositories;
use Auth;
use App\Models\Lead;
use App\Services\Util;
use App\Models\Booking;
use App\Models\Participant;
use App\Models\BookingNotice;
use App\Models\BookingServiceItem;
use App\Models\ServiceProviderEntry;
use App\Models\BookingCompanyService;
use App\Models\BookingCountryService;
use App\Models\BookingDraftItem;
use App\Models\BookingNotice;
use App\Models\BookingProviderService;
use App\Models\BookingServiceItem;
use App\Models\Lead;
use App\Models\Participant;
use App\Models\ServiceProviderEntry;
use App\Services\Util;
use Auth;
class BookingRepository extends BaseRepository {
class BookingRepository extends BaseRepository
{
public function __construct(Booking $model)
@ -29,35 +31,38 @@ class BookingRepository extends BaseRepository {
}
public function updateNotice($id, $data){
public function updateNotice($id, $data)
{
$this->model = Booking::findOrFail($id);
if($data['action'] === 'edit_notice' && isset($data['notice_id'])){
if ($data['action'] === 'edit_notice' && isset($data['notice_id'])) {
$BookingNotice = BookingNotice::findOrFail($data['notice_id']);
$BookingNotice->message = isset($data['booking_notice']) ? $data['booking_notice'] : "";
$BookingNotice->edit_at = now();
$BookingNotice->save();
}else{
} else {
//save_notice
BookingNotice::create([
'booking_id' => $this->model->id,
'from_user_id' => Auth::user()->id,
'to_user_id' => isset($this->model->sf_guard_user->user_id) ? $this->model->sf_guard_user->user_id : null,
'message' => isset($data['booking_notice']) ? $data['booking_notice'] : "",
BookingNotice::create(
[
'booking_id' => $this->model->id,
'from_user_id' => Auth::user()->id,
'to_user_id' => isset($this->model->sf_guard_user->user_id) ? $this->model->sf_guard_user->user_id : null,
'message' => isset($data['booking_notice']) ? $data['booking_notice'] : "",
]
);
}
return $this->model;
}
public function updateLeadStatus($id, $data){
public function updateLeadStatus($id, $data)
{
$this->model = Booking::findOrFail($id);
if(isset($data['lead'])){
if (isset($data['lead'])) {
$lead = $this->model->lead;
if($lead->id != $data['lead']['id']){
if ($lead->id != $data['lead']['id']) {
abort(500);
}
$lead->status_id = $data['lead']['status_id'];
@ -68,7 +73,8 @@ class BookingRepository extends BaseRepository {
return $this->model;
}
public function updateBooking($id, $data){
public function updateBooking($id, $data)
{
$this->model = Booking::findOrFail($id);
@ -88,7 +94,7 @@ class BookingRepository extends BaseRepository {
'paying_out' => $data['paying_out'],
'paying_out_status' => $data['paying_out_status'],
'branch_id' => isset($data['branch_id']) ? $data['branch_id'] : 4,
'airport_id' => (isset($data['airport_id']) && $data['airport_id']>0) ? $data['airport_id'] : null,
'airport_id' => (isset($data['airport_id']) && $data['airport_id'] > 0) ? $data['airport_id'] : null,
'travel_company_id' => $data['travel_company_id'],
//'airline_id' => $data['airline_id'],
'airline_ids' => isset($data['airline_ids']) ? $data['airline_ids'] : null,
@ -107,8 +113,8 @@ class BookingRepository extends BaseRepository {
$this->model->fill($fill);
$this->model->save();
if($this->model->booking_draft_items){
foreach($this->model->booking_draft_items as $booking_draft_item){
if ($this->model->booking_draft_items) {
foreach ($this->model->booking_draft_items as $booking_draft_item) {
$booking_draft_item->comfort = isset($data['travel_comfort']) ? true : false;
$booking_draft_item->save();
}
@ -116,24 +122,26 @@ class BookingRepository extends BaseRepository {
return $this->model;
}
public function updateBookingServices($id, $data){
public function updateBookingServices($id, $data)
{
$this->model = Booking::findOrFail($id);
if(isset($data['country_service'])){
if (isset($data['country_service'])) {
$this->updateCountryService($data['country_service']);
}
if(isset($data['provider_service'])){
if (isset($data['provider_service'])) {
$this->updateProviderService($data['provider_service']);
}
if(isset($data['company_service'])){
if (isset($data['company_service'])) {
$this->updateCompanyService($data['company_service']);
}
return $this->model;
}
public function updateBookingNumber($id, $data){
public function updateBookingNumber($id, $data)
{
$this->model = Booking::findOrFail($id);
$fill = [
@ -145,7 +153,8 @@ class BookingRepository extends BaseRepository {
return $this->model;
}
public function updateBookingPrice($id, $data){
public function updateBookingPrice($id, $data)
{
$this->model = Booking::findOrFail($id);
$fill = [
@ -158,46 +167,48 @@ class BookingRepository extends BaseRepository {
$this->model->save();
return $this->model;
}
public function updateServiceProviderEntry($id, $data){
public function updateServiceProviderEntry($id, $data)
{
$this->model = Booking::findOrFail($id);
if(isset($data['service_provider_entry'])){
foreach($data['service_provider_entry'] as $spe_id => $fill){
$ServiceProviderEntry = ServiceProviderEntry::findOrFail($spe_id);
if($ServiceProviderEntry->booking_id !== $this->model->id){
if (isset($data['service_provider_entry'])) {
foreach ($data['service_provider_entry'] as $spe_id => $fill) {
$ServiceProviderEntry = ServiceProviderEntry::findOrFail($spe_id);
if ($ServiceProviderEntry->booking_id !== $this->model->id) {
abort(500);
}
$fill['is_cleared'] = isset($fill['is_cleared']) ? true : false;
$fill['payment_date'] = isset($fill['payment_date']) ? _reformat_date($fill['payment_date']) : null;
$ServiceProviderEntry->fill($fill);
$ServiceProviderEntry->save();
}
}
$fill['is_cleared'] = isset($fill['is_cleared']) ? true : false;
$fill['payment_date'] = isset($fill['payment_date']) ? _reformat_date($fill['payment_date']) : null;
$ServiceProviderEntry->fill($fill);
$ServiceProviderEntry->save();
}
}
return $this->model;
}
public function updateBookingServiceItem($id, $data){
public function updateBookingServiceItem($id, $data)
{
$this->model = Booking::findOrFail($id);
if(isset($data['booking_service_item'])){
foreach($data['booking_service_item'] as $bsi_id => $fill){
$BookingServiceItem = BookingServiceItem::findOrFail($bsi_id);
if($BookingServiceItem->booking_id !== $this->model->id){
if (isset($data['booking_service_item'])) {
foreach ($data['booking_service_item'] as $bsi_id => $fill) {
$BookingServiceItem = BookingServiceItem::findOrFail($bsi_id);
if ($BookingServiceItem->booking_id !== $this->model->id) {
abort(500);
}
$fill['is_commission_locked'] = isset($fill['is_commission_locked']) ? true : false;
$fill['travel_date'] = isset($fill['travel_date']) ? _reformat_date($fill['travel_date']) : now();
$BookingServiceItem->fill($fill);
$BookingServiceItem->save();
}
$fill['is_commission_locked'] = isset($fill['is_commission_locked']) ? true : false;
$fill['travel_date'] = isset($fill['travel_date']) ? _reformat_date($fill['travel_date']) : now();
$BookingServiceItem->fill($fill);
$BookingServiceItem->save();
if($fill['is_commission_locked'] === true){
if ($fill['is_commission_locked'] === true) {
$service_price_refund = 0;
if($BookingServiceItem->getServicePriceRaw() > 0){
if ($BookingServiceItem->getServicePriceRaw() > 0) {
$service_price_refund = $BookingServiceItem->getServicePriceRaw() / 100 * $BookingServiceItem->travel_company->getPercentageRaw();
}
$BookingServiceItem->setServicePriceRefundRaw($service_price_refund);
$BookingServiceItem->save();
}
}
}
}
}
$this->model->price_total = ($this->model->getPriceRaw() + $this->model->getServiceTotal(true));
$this->model->save();
@ -205,21 +216,22 @@ class BookingRepository extends BaseRepository {
return $this->model;
}
public function updateBookingParticipant($id, $data){
public function updateBookingParticipant($id, $data)
{
$this->model = Booking::findOrFail($id);
if(isset($data['participant'])){
foreach($data['participant'] as $p_id => $fill){
$Participant = Participant::findOrFail($p_id);
if($Participant->booking_id !== $this->model->id){
if (isset($data['participant'])) {
foreach ($data['participant'] as $p_id => $fill) {
$Participant = Participant::findOrFail($p_id);
if ($Participant->booking_id !== $this->model->id) {
abort(500);
}
$fill['participant_pass'] = isset($fill['participant_pass']) ? true : false;
$fill['participant_storno'] = isset($fill['participant_storno']) ? true : false;
$fill['participant_child'] = isset($fill['participant_child']) ? true : false;
$fill['participant_birthdate'] = isset($fill['participant_birthdate']) ? _reformat_date($fill['participant_birthdate']) : null;
$Participant->fill($fill);
$Participant->save();
}
}
$fill['participant_pass'] = isset($fill['participant_pass']) ? true : false;
$fill['participant_storno'] = isset($fill['participant_storno']) ? true : false;
$fill['participant_child'] = isset($fill['participant_child']) ? true : false;
$fill['participant_birthdate'] = isset($fill['participant_birthdate']) ? _reformat_date($fill['participant_birthdate']) : null;
$Participant->fill($fill);
$Participant->save();
}
}
//main
$this->model->participant_salutation_id = isset($data['participant_salutation_id']) ? $data['participant_salutation_id'] : null;
@ -229,29 +241,30 @@ class BookingRepository extends BaseRepository {
$this->model->participant_birthdate = isset($data['participant_birthdate']) ? _reformat_date($data['participant_birthdate']) : null;
$this->model->participant_pass = isset($data['participant_pass']) ? true : false;
//update pax
if($this->model->participants->count() > 0){
if ($this->model->participants->count() > 0) {
$this->model->pax = $this->model->participants->where('participant_storno', false)->count();
}
$this->model->save();
return $this->model;
}
private function updateCountryService($country_services){
foreach ($country_services as $country_service_id=>$val){
private function updateCountryService($country_services)
{
foreach ($country_services as $country_service_id => $val) {
$booking_country_service = BookingCountryService::where('travel_country_service_id', '=', $country_service_id)
->where('booking_id', '=', $this->model->id)->first();
if(!$booking_country_service){
if (!$booking_country_service) {
BookingCountryService::create([
'travel_country_service_id' => $country_service_id,
'booking_id' => $this->model->id,
'status' => $val
]);
}else{
} else {
$booking_country_service->fill([
'status' => $val
]);
@ -260,18 +273,19 @@ class BookingRepository extends BaseRepository {
}
}
private function updateProviderService($provider_service){
foreach ($provider_service as $provider_service_id=>$val){
private function updateProviderService($provider_service)
{
foreach ($provider_service as $provider_service_id => $val) {
$booking_provider_service = BookingProviderService::where('service_provider_service_id', '=', $provider_service_id)
->where('booking_id', '=', $this->model->id)->first();
if(!$booking_provider_service){
if (!$booking_provider_service) {
BookingProviderService::create([
'service_provider_service_id' => $provider_service_id,
'booking_id' => $this->model->id,
'status' => $val
]);
}else{
} else {
$booking_provider_service->fill([
'status' => $val
]);
@ -280,18 +294,19 @@ class BookingRepository extends BaseRepository {
}
}
private function updateCompanyService($company_service){
foreach ($company_service as $company_service_id=>$val){
private function updateCompanyService($company_service)
{
foreach ($company_service as $company_service_id => $val) {
$booking_company_service = BookingCompanyService::where('travel_company_service_id', '=', $company_service_id)
->where('booking_id', '=', $this->model->id)->first();
->where('booking_id', '=', $this->model->id)->first();
if(!$booking_company_service){
if (!$booking_company_service) {
BookingCompanyService::create([
'travel_company_service_id' => $company_service_id,
'booking_id' => $this->model->id,
'status' => $val
]);
}else{
} else {
$booking_company_service->fill([
'status' => $val
]);
@ -300,4 +315,135 @@ class BookingRepository extends BaseRepository {
}
}
}
public function convertArrangementsToDrafts(Booking $booking)
{
if (!$booking->arrangements || $booking->arrangements->count() == 0) {
return;
}
$nextPos = 1;
if ($booking->booking_draft_items && $booking->booking_draft_items->count() > 0) {
$nextPos = $booking->booking_draft_items->max('pos') + 1;
}
foreach ($booking->arrangements->sortByDesc('view_position') as $arrangement) {
$data = $arrangement->getDataAsMap();
// Erstelle neues BookingDraftItem aus Arrangement
$draftItem = new BookingDraftItem();
// Mappe die grundlegenden Daten
$draftItem->booking_id = $booking->id;
$draftItem->pos = $nextPos++;
// Daten von Arrangement übertragen
if ($arrangement->begin) {
$draftItem->start_date = $arrangement->begin->format('Y-m-d');
}
if ($arrangement->end) {
$draftItem->end_date = $arrangement->end->format('Y-m-d');
}
// Service/Beschreibung aus data_s generieren
$serviceText = $arrangement->getDataS();
$draftItem->service = $serviceText;
$draftItem->adult = $data['Teilnehmer'] ?? $booking->pax;
$draftItem->price_adult = $data['Preis'] ?? 0;
// PDF-Einstellung übernehmen
$draftItem->in_pdf = $arrangement->in_pdf ? 1 : 0;
// Versuche DraftType zu finden basierend auf ArrangementType
if ($arrangement->arrangement_type && isset($arrangement->arrangement_type->name)) {
$draftType = \App\Models\DraftType::where('name', 'like', '%' . $arrangement->arrangement_type->name . '%')->first();
if ($draftType) {
$draftItem->draft_type_id = $draftType->id;
}
} else {
// Fallback: Suche nach einem passenden DraftType basierend auf dem Namen
$draftType = \App\Models\DraftType::where('name', 'like', '%' . $arrangement->type_s . '%')->first();
if ($draftType) {
$draftItem->draft_type_id = $draftType->id;
}
}
// Standardwerte für neue Felder setzen
$draftItem->comfort = 0;
$draftItem->price = 0;
$draftItem->adult = 0;
$draftItem->price_children = 0;
$draftItem->children = 0;
$draftItem->save();
// Arrangement als konvertiert markieren oder löschen
// Hier löschen wir das Arrangement nach erfolgreicher Konvertierung
$arrangement->delete();
}
// Stelle sicher, dass new_drafts aktiviert ist
if (!$booking->new_drafts) {
$booking->new_drafts = true;
$booking->save();
}
// Preise neu berechnen
$booking->calculate_price_total();
}
public function loadDraftToBooking($bookingId, $draftId)
{
$booking = Booking::findOrFail($bookingId);
$draft = \App\Models\Draft::findOrFail($draftId);
if (!$booking->new_drafts) {
$booking->new_drafts = true;
$booking->save();
}
// Lösche bestehende Draft Items falls gewünscht
if ($booking->booking_draft_items && $booking->booking_draft_items->count() > 0) {
foreach ($booking->booking_draft_items as $existingItem) {
$existingItem->delete();
}
}
$pos = 1;
foreach ($draft->draft_items as $draftItem) {
$bookingDraftItem = new \App\Models\BookingDraftItem();
// Kopiere alle Daten aus der Draft Vorlage
$bookingDraftItem->booking_id = $booking->id;
$bookingDraftItem->draft_type_id = $draftItem->draft_type_id;
$bookingDraftItem->travel_program_id = null; // Wird später gesetzt wenn nötig
$bookingDraftItem->fewo_lodging_id = null;
$bookingDraftItem->travel_class_id = null;
$bookingDraftItem->draft_item_id = $draftItem->id;
$bookingDraftItem->request_date = null;
$bookingDraftItem->days_start = $draftItem->days_start;
$bookingDraftItem->days_duration = $draftItem->days_duration;
$bookingDraftItem->start_date = null; // Wird später basierend auf Reisebeginn gesetzt
$bookingDraftItem->end_date = null; // Wird später basierend auf Reiseende gesetzt
$bookingDraftItem->service = $draftItem->service;
$bookingDraftItem->price_adult = $draftItem->price_adult;
$bookingDraftItem->adult = $draftItem->adult;
$bookingDraftItem->price_children = $draftItem->price_children;
$bookingDraftItem->children = $draftItem->children;
$bookingDraftItem->price = 0; // Wird später berechnet
$bookingDraftItem->pos = $pos++;
$bookingDraftItem->in_pdf = $draftItem->in_pdf;
$bookingDraftItem->comfort = 0;
$bookingDraftItem->status = 1;
$bookingDraftItem->save();
}
// Preise neu berechnen
$booking->calculate_price_total();
return $booking;
}
}

View file

@ -14,7 +14,7 @@
}
],
"require": {
"php": "^7.3|^8.0",
"php": "^8.0|^8.2",
"bacon/bacon-qr-code": "^3.0",
"barryvdh/laravel-dompdf": "*",
"cviebrock/eloquent-sluggable": "*",

932
composer.lock generated

File diff suppressed because it is too large Load diff

113
docker-compose.yml Normal file
View file

@ -0,0 +1,113 @@
services:
laravel.test:
build:
context: ./vendor/laravel/sail/runtimes/8.2
dockerfile: Dockerfile
args:
WWWGROUP: '${WWWGROUP}'
image: sail-8.2/app
extra_hosts:
- 'host.docker.internal:host-gateway'
ports:
#- '${APP_PORT:-80}:80'
- '${VITE_PORT:-5173}:${VITE_PORT:-5173}'
environment:
WWWUSER: '${WWWUSER}'
LARAVEL_SAIL: 1
XDEBUG_MODE: '${SAIL_XDEBUG_MODE:-off}'
XDEBUG_CONFIG: '${SAIL_XDEBUG_CONFIG:-client_host=host.docker.internal}'
IGNITION_LOCAL_SITES_PATH: '${PWD}'
volumes:
- '.:/var/www/html'
networks:
- sail
- proxy
depends_on:
- mysql
- mysql-stern
- redis
labels:
- "traefik.enable=true"
# Hauptdomain
- "traefik.http.routers.meinsterntours.rule=Host(`mein.sterntours.test`)"
- "traefik.http.routers.meinsterntours.entrypoints=websecure"
- "traefik.http.routers.meinsterntours.tls=true"
- "traefik.http.routers.meinsterntours.service=meinsterntours-service"
# Service Definition - NUR EINMAL!
- "traefik.http.services.meinsterntours-service.loadbalancer.server.port=80"
- "traefik.docker.network=proxy"
mysql:
image: 'mysql/mysql-server:8.0'
ports:
- '${FORWARD_DB_PORT:-33064}:3306'
environment:
MYSQL_ROOT_PASSWORD: '${DB_PASSWORD}'
MYSQL_ROOT_HOST: '%'
MYSQL_DATABASE: '${DB_DATABASE}'
MYSQL_USER: '${DB_USERNAME}'
MYSQL_PASSWORD: '${DB_PASSWORD}'
MYSQL_ALLOW_EMPTY_PASSWORD: 1
volumes:
- 'sail-mysql:/var/lib/mysql'
- './vendor/laravel/sail/database/mysql/create-testing-database.sh:/docker-entrypoint-initdb.d/10-create-testing-database.sh'
networks:
- sail
healthcheck:
test:
- CMD
- mysqladmin
- ping
- '-p${DB_PASSWORD}'
retries: 3
timeout: 5s
mysql-stern:
image: 'mysql/mysql-server:8.0'
ports:
- '${FORWARD_DB_PORT_STERN:-33065}:3306'
environment:
MYSQL_ROOT_PASSWORD: '${DB_PASSWORD_STERN}'
MYSQL_ROOT_HOST: '%'
MYSQL_DATABASE: '${DB_DATABASE_STERN}'
MYSQL_USER: '${DB_USERNAME_STERN}'
MYSQL_PASSWORD: '${DB_PASSWORD_STERN}'
MYSQL_ALLOW_EMPTY_PASSWORD: 1
volumes:
- 'sail-mysql-stern:/var/lib/mysql'
- './vendor/laravel/sail/database/mysql/create-testing-database.sh:/docker-entrypoint-initdb.d/10-create-testing-database.sh'
networks:
- sail
healthcheck:
test:
- CMD
- mysqladmin
- ping
- '-p${DB_PASSWORD_STERN}'
retries: 3
timeout: 5s
redis:
image: 'redis:alpine'
ports:
- '${FORWARD_REDIS_PORT:-6379}:6379'
volumes:
- 'sail-redis:/data'
networks:
- sail
healthcheck:
test:
- CMD
- redis-cli
- ping
retries: 3
timeout: 5s
networks:
sail:
driver: bridge
proxy:
external: true
volumes:
sail-mysql:
driver: local
sail-mysql-stern:
driver: local
sail-redis:
driver: local

View file

@ -3,6 +3,5 @@
{
"path": "."
}
],
"settings": {}
]
}

0
public/128.jpg Normal file → Executable file
View file

Before

Width:  |  Height:  |  Size: 17 KiB

After

Width:  |  Height:  |  Size: 17 KiB

Before After
Before After

0
public/css/application-purple.css Normal file → Executable file
View file

0
public/css/application.css Normal file → Executable file
View file

0
public/css/stern_fewo_pdf.css Normal file → Executable file
View file

0
public/fonts/nunito.css Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-200.eot Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-200.svg Normal file → Executable file
View file

Before

Width:  |  Height:  |  Size: 74 KiB

After

Width:  |  Height:  |  Size: 74 KiB

Before After
Before After

0
public/fonts/nunito/nunito-v25-latin-200.ttf Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-200.woff Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-200.woff2 Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-200italic.eot Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-200italic.svg Normal file → Executable file
View file

Before

Width:  |  Height:  |  Size: 76 KiB

After

Width:  |  Height:  |  Size: 76 KiB

Before After
Before After

0
public/fonts/nunito/nunito-v25-latin-200italic.ttf Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-200italic.woff Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-200italic.woff2 Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-300.eot Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-300.svg Normal file → Executable file
View file

Before

Width:  |  Height:  |  Size: 74 KiB

After

Width:  |  Height:  |  Size: 74 KiB

Before After
Before After

0
public/fonts/nunito/nunito-v25-latin-300.ttf Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-300.woff Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-300.woff2 Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-300italic.eot Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-300italic.svg Normal file → Executable file
View file

Before

Width:  |  Height:  |  Size: 76 KiB

After

Width:  |  Height:  |  Size: 76 KiB

Before After
Before After

0
public/fonts/nunito/nunito-v25-latin-300italic.ttf Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-300italic.woff Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-300italic.woff2 Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-500.eot Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-500.svg Normal file → Executable file
View file

Before

Width:  |  Height:  |  Size: 74 KiB

After

Width:  |  Height:  |  Size: 74 KiB

Before After
Before After

0
public/fonts/nunito/nunito-v25-latin-500.ttf Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-500.woff Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-500.woff2 Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-500italic.eot Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-500italic.svg Normal file → Executable file
View file

Before

Width:  |  Height:  |  Size: 76 KiB

After

Width:  |  Height:  |  Size: 76 KiB

Before After
Before After

0
public/fonts/nunito/nunito-v25-latin-500italic.ttf Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-500italic.woff Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-500italic.woff2 Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-600.eot Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-600.svg Normal file → Executable file
View file

Before

Width:  |  Height:  |  Size: 74 KiB

After

Width:  |  Height:  |  Size: 74 KiB

Before After
Before After

0
public/fonts/nunito/nunito-v25-latin-600.ttf Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-600.woff Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-600.woff2 Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-600italic.eot Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-600italic.svg Normal file → Executable file
View file

Before

Width:  |  Height:  |  Size: 76 KiB

After

Width:  |  Height:  |  Size: 76 KiB

Before After
Before After

0
public/fonts/nunito/nunito-v25-latin-600italic.ttf Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-600italic.woff Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-600italic.woff2 Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-700.eot Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-700.svg Normal file → Executable file
View file

Before

Width:  |  Height:  |  Size: 75 KiB

After

Width:  |  Height:  |  Size: 75 KiB

Before After
Before After

0
public/fonts/nunito/nunito-v25-latin-700.ttf Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-700.woff Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-700.woff2 Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-700italic.eot Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-700italic.svg Normal file → Executable file
View file

Before

Width:  |  Height:  |  Size: 76 KiB

After

Width:  |  Height:  |  Size: 76 KiB

Before After
Before After

0
public/fonts/nunito/nunito-v25-latin-700italic.ttf Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-700italic.woff Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-700italic.woff2 Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-800.eot Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-800.svg Normal file → Executable file
View file

Before

Width:  |  Height:  |  Size: 75 KiB

After

Width:  |  Height:  |  Size: 75 KiB

Before After
Before After

0
public/fonts/nunito/nunito-v25-latin-800.ttf Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-800.woff Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-800.woff2 Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-800italic.eot Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-800italic.svg Normal file → Executable file
View file

Before

Width:  |  Height:  |  Size: 76 KiB

After

Width:  |  Height:  |  Size: 76 KiB

Before After
Before After

0
public/fonts/nunito/nunito-v25-latin-800italic.ttf Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-800italic.woff Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-800italic.woff2 Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-900.eot Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-900.svg Normal file → Executable file
View file

Before

Width:  |  Height:  |  Size: 75 KiB

After

Width:  |  Height:  |  Size: 75 KiB

Before After
Before After

0
public/fonts/nunito/nunito-v25-latin-900.ttf Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-900.woff Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-900.woff2 Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-900italic.eot Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-900italic.svg Normal file → Executable file
View file

Before

Width:  |  Height:  |  Size: 77 KiB

After

Width:  |  Height:  |  Size: 77 KiB

Before After
Before After

0
public/fonts/nunito/nunito-v25-latin-900italic.ttf Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-900italic.woff Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-900italic.woff2 Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-italic.eot Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-italic.svg Normal file → Executable file
View file

Before

Width:  |  Height:  |  Size: 76 KiB

After

Width:  |  Height:  |  Size: 76 KiB

Before After
Before After

0
public/fonts/nunito/nunito-v25-latin-italic.ttf Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-italic.woff Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-italic.woff2 Normal file → Executable file
View file

0
public/fonts/nunito/nunito-v25-latin-regular.eot Normal file → Executable file
View file

Some files were not shown because too many files have changed in this diff Show more