Skip to content

Commit

Permalink
Import notification file and updated other file..
Browse files Browse the repository at this point in the history
  • Loading branch information
cuneytsenturk committed Jun 19, 2021
1 parent 4687185 commit 5c5b890
Show file tree
Hide file tree
Showing 12 changed files with 182 additions and 27 deletions.
67 changes: 63 additions & 4 deletions app/Http/Livewire/Common/Notifications/Imports.php
Original file line number Diff line number Diff line change
Expand Up @@ -4,23 +4,82 @@

use Livewire\Component;
use Livewire\WithPagination;
use Illuminate\Support\Collection;
use Illuminate\Notifications\DatabaseNotification;
use Illuminate\Support\Str;

class Imports extends Component
{
use WithPagination;

protected $listeners = [
'refreshParent' => '$notifications',
];

public function markRead($notification_id)
{
$notification = DatabaseNotification::find($notification_id);
$data = $notification->getAttribute('data');

$notification->markAsRead();

$this->dispatchBrowserEvent('mark-read', [
'type' => 'import',
'message' => trans('notifications.messages.mark_read', ['type' => $data['translation']]),
]);
}

public function markReadAll()
{
$notifications = $this->getNotifications();

foreach ($notifications as $notification) {
$notification->markAsRead();
}

$this->dispatchBrowserEvent('mark-read-all', [
'type' => 'import',
'message' => trans('notifications.messages.mark_read_all', ['type' => trans('import.import')]),
]);
}

public function render()
{
$limit = 5;

$notifications = user()->notifications()->unread()
->where('type', 'App\Notifications\Common\ImportCompleted')
->orWhere('type', 'App\Notifications\Common\ImportFailed')
->paginate($limit);
$notifications = $this->getNotifications($limit);

return view('livewire.common.notifications.imports', compact('notifications'));
}

protected function getNotifications($limit = false)
{
$query = user()->notifications()->unread()
->where('type', 'App\Notifications\Common\ImportCompleted')
->orWhere('type', 'App\Notifications\Common\ImportFailed');

if ($limit) {
$notifications = $query->paginate($limit);
} else {
$notifications = $query->get();
}

if ($notifications->items()) {
$items = [];

foreach ($notifications->items() as $key => $notification) {
$data = (object) $notification->getAttribute('data');
$data->notification_id = $notification->getAttribute('id');

$items[] = $data;
}

$notifications->setCollection(Collection::make($items));
}

return $notifications;
}

public function paginationView()
{
return 'vendor.livewire.default';
Expand Down
7 changes: 6 additions & 1 deletion app/Http/Livewire/Common/Notifications/NewApps.php
Original file line number Diff line number Diff line change
Expand Up @@ -2,12 +2,17 @@

namespace App\Http\Livewire\Common\Notifications;

use App\Traits\Modules;
use Livewire\Component;

class NewApps extends Component
{
use Modules;

public function render()
{
return view('livewire.common.notifications.new-apps');
$notifications = $this->getNotifications('new-apps');

return view('livewire.common.notifications.new-apps', compact('notifications'));
}
}
3 changes: 2 additions & 1 deletion app/Http/Livewire/Common/Notifications/Reminder.php
Original file line number Diff line number Diff line change
Expand Up @@ -46,12 +46,13 @@ public function markReadAll()

public function render()
{
$limit = 10;
$limit = 5;

$type = config('type.' . $this->type . '.notification.class');

$documents = user()->notifications()->unread()
->where('type', $type)
->where('data', 'like', '%template_alias:{$this->type}_remind_admin%')
->paginate($limit);

$items = [];
Expand Down
13 changes: 10 additions & 3 deletions app/Http/ViewComposers/Header.php
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ public function compose(View $view)
{
$user = user();

$invoices = $bills = $exports = $imports = [];
$new_apps = $invoices = $bills = $exports = $imports = [];
$updates = $notifications = 0;
$company = null;

Expand Down Expand Up @@ -51,11 +51,11 @@ public function compose(View $view)
$notifications++;
break;
case 'App\Notifications\Common\ImportCompleted':
$import_completed[$data['bill_id']] = $data['amount'];
$imports['completed'][] = $data['translation'];
$notifications++;
break;
case 'App\Notifications\Common\ImportFailed':
$import_failed[$data['bill_id']] = $data['amount'];
$imports['failed'][] = '';
$notifications++;
break;
case 'App\Notifications\Purchase\Bill':
Expand All @@ -68,6 +68,12 @@ public function compose(View $view)
break;
}
}

$new_apps = $this->getNotifications('new-apps');

foreach ($new_apps as $new_app) {
$notifications++;
}
}

if ($user->can('read-install-updates')) {
Expand All @@ -80,6 +86,7 @@ public function compose(View $view)
$view->with([
'user' => $user,
'notifications' => $notifications,
'new_apps' => $new_apps,
'exports' => $exports,
'imports' => $imports,
'bills' => $bills,
Expand Down
25 changes: 23 additions & 2 deletions app/Notifications/Common/ImportCompleted.php
Original file line number Diff line number Diff line change
Expand Up @@ -11,11 +11,18 @@ class ImportCompleted extends Notification implements ShouldQueue
{
use Queueable;

protected $translation;

protected $total_rows;

/**
* Create a notification instance.
*/
public function __construct()
public function __construct($translation, $total_rows)
{
$this->translation = $translation;
$this->total_rows = $total_rows;

$this->onQueue('notifications');
}

Expand All @@ -27,7 +34,7 @@ public function __construct()
*/
public function via($notifiable)
{
return ['mail'];
return ['mail', 'database'];
}

/**
Expand All @@ -45,4 +52,18 @@ public function toMail($notifiable)
->line(trans('notifications.import.completed.description'))
->action(trans_choice('general.dashboards', 1), $dashboard_url);
}

/**
* Get the array representation of the notification.
*
* @param mixed $notifiable
* @return array
*/
public function toArray($notifiable)
{
return [
'translation' => $this->translation,
'total_rows' => $this->total_rows,
];
}
}
19 changes: 16 additions & 3 deletions app/Notifications/Common/ImportFailed.php
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ public function __construct($errors)
*/
public function via($notifiable)
{
return ['mail'];
return ['mail', 'database'];
}

/**
Expand All @@ -50,13 +50,26 @@ public function via($notifiable)
public function toMail($notifiable)
{
$message = (new MailMessage)
->subject(trans('notifications.import.failed.subject'))
->line(trans('notifications.import.failed.description'));
->subject(trans('notifications.import.failed.subject'))
->line(trans('notifications.import.failed.description'));

foreach ($this->errors as $error) {
$message->line($error);
}

return $message;
}

/**
* Get the array representation of the notification.
*
* @param mixed $notifiable
* @return array
*/
public function toArray($notifiable)
{
return [
'errors' => $this->errors,
];
}
}
9 changes: 8 additions & 1 deletion app/Utilities/Import.php
Original file line number Diff line number Diff line change
Expand Up @@ -24,8 +24,15 @@ public static function fromExcel($class, $request, $translation)
$file = $request->file('import');

if (should_queue()) {
$rows = $class->toArray($file);

$total_rows = 0;
if (!empty($rows[0])) {
$total_rows = count($rows[0]);
}

$class->queue($file)->onQueue('imports')->chain([
new NotifyUser(user(), new ImportCompleted),
new NotifyUser(user(), new ImportCompleted($translation, $total_rows)),
]);

$message = trans('messages.success.import_queued', ['type' => $translation]);
Expand Down
1 change: 1 addition & 0 deletions resources/lang/en-GB/header.php
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@

'notifications' => [
'counter' => '{0} You have no notification|{1} You have :count notification|[2,*] You have :count notifications',
'new_apps' => '{1} :count published app|[2,*] :count published apps',
'overdue_invoices' => '{1} :count overdue invoice|[2,*] :count overdue invoices',
'upcoming_bills' => '{1} :count upcoming bill|[2,*] :count upcoming bills',
'view_all' => 'View All',
Expand Down
5 changes: 4 additions & 1 deletion resources/lang/en-GB/notifications.php
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
'read_all' => 'Read All',
'mark_read' => 'Mark Read',
'mark_read_all' => 'Mark Read All',
'new_apps' => 'New App|New Apps',
'upcoming_bills' => 'Upcoming Bills',
'recurring_invoices' => 'Recurring Invoices',
'recurring_bills' => 'Recurring Bills',
Expand Down Expand Up @@ -61,6 +62,8 @@
'messages' => [
'mark_read' => ':type is read this notification!',
'mark_read_all' => ':type is read all notification!',
'export' => ':type export is ready! The export file is ready to download from the following <a href=":url" target="_blank">:file_name</a>'
'new_app' => ':type app published.',
'export' => ':type export is ready! The export file is ready to download from the following <a href=":url" target="_blank">:file_name</a>',
'import' => ':type import finished! Added :count :type rows.'
],
];
11 changes: 5 additions & 6 deletions resources/views/livewire/common/notifications/imports.blade.php
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
@if ($notifications->total())
<div class="card" id="export">
<div class="card" id="import">
<div class="card-header">
<div class="row align-items-center">
<div class="col-8">
<h5 class="h3 mb-0">{{ trans('general.export') }}</h5>
<h5 class="h3 mb-0">{{ trans('import.import') }}</h5>
</div>

<div class="col-4 text-right">
Expand All @@ -20,16 +20,15 @@
</div>

<div class="table-responsive">
<table class="table table-flush table-hover" id="tbl-export">
<table class="table table-flush table-hover" id="tbl-import">
<tbody>
@foreach ($notifications as $notification)
<tr class="row align-items-center border-top-1">
<td class="col-xs-8 col-sm-10 col-md-10 col-lg-11 col-xl-11 text-left">
@if (empty($notification->message))
{!! trans('notifications.messages.export', [
{!! trans('notifications.messages.import', [
'type' => $notification->translation,
'file_name' => $notification->file_name,
'url' => $notification->download_url
'count' => $notification->total_rows
]) !!}
@else
{!! $notification->message !!}
Expand Down
30 changes: 25 additions & 5 deletions resources/views/livewire/common/notifications/new-apps.blade.php
Original file line number Diff line number Diff line change
@@ -1,7 +1,27 @@
<div class="card">
<div class="card-header"></div>

<div class="card-body">
@if ($notifications)
<div class="accordion" id="new-apps">
<div class="card">
<div class="card-header" id="heading-new-apps" data-toggle="collapse" data-target="#collapse-new-apps" aria-expanded="true" aria-controls="collapse-new-apps">
<div class="align-items-center">
<h4 class="mb-0">{{ trans_choice('notifications.new_apps', 2) }}</h4>
</div>
</div>

<div id="collapse-new-apps" class="collapse show" aria-labelledby="heading-new-apps" data-parent="#new-apps">
<div class="table-responsive">
<table class="table table-flush table-hover" id="tbl-export">
<tbody>
@foreach ($notifications as $notification)
<tr class="row align-items-center border-top-1">
<td class="col-xs-12 col-sm-12 col-md-12 col-lg-12 col-xl-12 text-left">
{!! $notification->message !!}
</td>
</tr>
@endforeach
</tbody>
</table>
</div>
</div>
</div>
</div>
</div>
@endif
19 changes: 19 additions & 0 deletions resources/views/partials/admin/navbar.blade.php
Original file line number Diff line number Diff line change
Expand Up @@ -127,6 +127,25 @@
@endif

<div class="list-group list-group-flush">
@stack('notification_new_apps_start')

@if (!empty($new_apps) && count($new_apps))
<a href="{{ route('notifications.index') . '#new-apps' }}" class="list-group-item list-group-item-action">
<div class="row align-items-center">
<div class="col-auto">
<i class="fa fa-rocket"></i>
</div>
<div class="col ml--2">
<div class="d-flex justify-content-between align-items-center">
<h4 class="mb-0 text-sm">{{ trans_choice('header.notifications.new_apps', count($new_apps), ['count' => count($new_apps)]) }}</h4>
</div>
</div>
</div>
</a>
@endif

@stack('notification_new_apps_end')

@stack('notification_exports_completed_start')

@if (!empty($exports['completed']) && count($exports['completed']))
Expand Down

0 comments on commit 5c5b890

Please sign in to comment.