Merge pull request #1959 from denisdulici/master
Delete dashboard/report after module uninstall
This commit is contained in:
commit
10fd8570d9
@ -62,7 +62,7 @@ class Dashboards extends Controller
|
|||||||
$dashboard = $this->dispatch(new CreateDashboard([
|
$dashboard = $this->dispatch(new CreateDashboard([
|
||||||
'company_id' => session('company_id'),
|
'company_id' => session('company_id'),
|
||||||
'name' => trans_choice('general.dashboards', 1),
|
'name' => trans_choice('general.dashboards', 1),
|
||||||
'default_widgets' => true,
|
'default_widgets' => 'core',
|
||||||
]));
|
]));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -16,7 +16,7 @@ class Widgets extends Controller
|
|||||||
*/
|
*/
|
||||||
public function index()
|
public function index()
|
||||||
{
|
{
|
||||||
$widgets = Utility::getClasses();
|
$widgets = Utility::getClasses('all');
|
||||||
|
|
||||||
return response()->json($widgets);
|
return response()->json($widgets);
|
||||||
}
|
}
|
||||||
|
@ -4,6 +4,7 @@ namespace App\Jobs\Common;
|
|||||||
|
|
||||||
use App\Abstracts\Job;
|
use App\Abstracts\Job;
|
||||||
use App\Models\Auth\User;
|
use App\Models\Auth\User;
|
||||||
|
use App\Models\Common\Company;
|
||||||
use App\Models\Common\Dashboard;
|
use App\Models\Common\Dashboard;
|
||||||
use App\Models\Common\Widget;
|
use App\Models\Common\Widget;
|
||||||
use App\Utilities\Widgets;
|
use App\Utilities\Widgets;
|
||||||
@ -55,7 +56,15 @@ class CreateDashboard extends Job
|
|||||||
{
|
{
|
||||||
$list = [];
|
$list = [];
|
||||||
|
|
||||||
if ($this->request->has('users')) {
|
if ($this->request->has('all_users')) {
|
||||||
|
Company::find($this->request->get('company_id'))->users()->each(function ($user) use (&$list) {
|
||||||
|
if (!$this->shouldCreateDashboardFor($user)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$list[] = $user->id;
|
||||||
|
});
|
||||||
|
} elseif ($this->request->has('users')) {
|
||||||
$user_ids = Arr::wrap($this->request->get('users'));
|
$user_ids = Arr::wrap($this->request->get('users'));
|
||||||
|
|
||||||
foreach($user_ids as $user_id) {
|
foreach($user_ids as $user_id) {
|
||||||
@ -97,7 +106,7 @@ class CreateDashboard extends Job
|
|||||||
$sort = 1;
|
$sort = 1;
|
||||||
|
|
||||||
if ($this->request->has('default_widgets')) {
|
if ($this->request->has('default_widgets')) {
|
||||||
$widgets = Widgets::getClasses(false);
|
$widgets = Widgets::getClasses($this->request->get('default_widgets'), false);
|
||||||
|
|
||||||
$this->createWidgets($widgets, $sort);
|
$this->createWidgets($widgets, $sort);
|
||||||
}
|
}
|
||||||
@ -118,10 +127,11 @@ class CreateDashboard extends Job
|
|||||||
$name = (new $class())->getDefaultName();
|
$name = (new $class())->getDefaultName();
|
||||||
}
|
}
|
||||||
|
|
||||||
Widget::create([
|
Widget::firstOrCreate([
|
||||||
'company_id' => $this->dashboard->company_id,
|
'company_id' => $this->dashboard->company_id,
|
||||||
'dashboard_id' => $this->dashboard->id,
|
'dashboard_id' => $this->dashboard->id,
|
||||||
'class' => $class,
|
'class' => $class,
|
||||||
|
], [
|
||||||
'name' => $name,
|
'name' => $name,
|
||||||
'sort' => $sort,
|
'sort' => $sort,
|
||||||
'settings' => (new $class())->getDefaultSettings(),
|
'settings' => (new $class())->getDefaultSettings(),
|
||||||
|
62
app/Listeners/Module/FinishUninstallation.php
Normal file
62
app/Listeners/Module/FinishUninstallation.php
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Listeners\Module;
|
||||||
|
|
||||||
|
use App\Events\Module\Uninstalled as Event;
|
||||||
|
use App\Jobs\Common\DeleteDashboard;
|
||||||
|
use App\Jobs\Common\DeleteReport;
|
||||||
|
use App\Models\Common\Dashboard;
|
||||||
|
use App\Models\Common\Report;
|
||||||
|
use App\Traits\Jobs;
|
||||||
|
use App\Traits\Relationships;
|
||||||
|
|
||||||
|
class FinishUninstallation
|
||||||
|
{
|
||||||
|
use Jobs, Relationships;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Handle the event.
|
||||||
|
*
|
||||||
|
* @param Event $event
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function handle(Event $event)
|
||||||
|
{
|
||||||
|
$this->deleteDashboards($event->alias);
|
||||||
|
$this->deleteReports($event->alias);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Delete any dashboard created by the module.
|
||||||
|
*
|
||||||
|
* @param string $alias
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
protected function deleteDashboards($alias)
|
||||||
|
{
|
||||||
|
Dashboard::alias($alias)->get()->each(function ($dashboard) {
|
||||||
|
try {
|
||||||
|
$this->dispatch(new DeleteDashboard($dashboard));
|
||||||
|
} catch (\Exception | \Throwable $e) {
|
||||||
|
report($e);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Delete any report created by the module.
|
||||||
|
*
|
||||||
|
* @param string $alias
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
protected function deleteReports($alias)
|
||||||
|
{
|
||||||
|
Report::alias($alias)->get()->each(function ($report) {
|
||||||
|
try {
|
||||||
|
$this->dispatch(new DeleteReport($report));
|
||||||
|
} catch (\Exception | \Throwable $e) {
|
||||||
|
report($e);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
@ -5,6 +5,7 @@ namespace App\Models\Common;
|
|||||||
use App\Abstracts\Model;
|
use App\Abstracts\Model;
|
||||||
use Bkwld\Cloner\Cloneable;
|
use Bkwld\Cloner\Cloneable;
|
||||||
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
||||||
|
use Illuminate\Support\Str;
|
||||||
|
|
||||||
class Dashboard extends Model
|
class Dashboard extends Model
|
||||||
{
|
{
|
||||||
@ -59,6 +60,60 @@ class Dashboard extends Model
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Scope to only include dashboards of a given alias.
|
||||||
|
*
|
||||||
|
* @param \Illuminate\Database\Eloquent\Builder $query
|
||||||
|
* @param string $alias
|
||||||
|
* @return \Illuminate\Database\Eloquent\Builder
|
||||||
|
*/
|
||||||
|
public function scopeAlias($query, $alias)
|
||||||
|
{
|
||||||
|
$class = ($alias == 'core') ? 'App\\\\' : 'Modules\\\\' . Str::studly($alias) . '\\\\';
|
||||||
|
|
||||||
|
return $query->whereHas('widgets', function ($query) use ($class) {
|
||||||
|
// Must have widgets of module
|
||||||
|
$query->where('class', 'like', $class . '%');
|
||||||
|
})->whereDoesntHave('widgets', function ($query) use ($class) {
|
||||||
|
// Must not have widgets from other modules
|
||||||
|
$query->where('class', 'not like', $class . '%');
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the alias based on class.
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function getAliasAttribute()
|
||||||
|
{
|
||||||
|
$alias = '';
|
||||||
|
|
||||||
|
foreach ($this->widgets as $widget) {
|
||||||
|
if (Str::startsWith($widget->class, 'App\\')) {
|
||||||
|
$tmp_alias = 'core';
|
||||||
|
} else {
|
||||||
|
$arr = explode('\\', $widget->class);
|
||||||
|
|
||||||
|
$tmp_alias = Str::kebab($arr[1]);
|
||||||
|
}
|
||||||
|
|
||||||
|
// First time set
|
||||||
|
if ($alias == '') {
|
||||||
|
$alias = $tmp_alias;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Must not have widgets from different modules
|
||||||
|
if ($alias != $tmp_alias) {
|
||||||
|
$alias = '';
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $alias;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create a new factory instance for the model.
|
* Create a new factory instance for the model.
|
||||||
*
|
*
|
||||||
|
@ -4,6 +4,7 @@ namespace App\Models\Common;
|
|||||||
|
|
||||||
use App\Abstracts\Model;
|
use App\Abstracts\Model;
|
||||||
use Bkwld\Cloner\Cloneable;
|
use Bkwld\Cloner\Cloneable;
|
||||||
|
use Illuminate\Support\Str;
|
||||||
|
|
||||||
class Report extends Model
|
class Report extends Model
|
||||||
{
|
{
|
||||||
@ -26,4 +27,34 @@ class Report extends Model
|
|||||||
protected $casts = [
|
protected $casts = [
|
||||||
'settings' => 'object',
|
'settings' => 'object',
|
||||||
];
|
];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Scope to only include reports of a given alias.
|
||||||
|
*
|
||||||
|
* @param \Illuminate\Database\Eloquent\Builder $query
|
||||||
|
* @param string $alias
|
||||||
|
* @return \Illuminate\Database\Eloquent\Builder
|
||||||
|
*/
|
||||||
|
public function scopeAlias($query, $alias)
|
||||||
|
{
|
||||||
|
$class = ($alias == 'core') ? 'App\\\\' : 'Modules\\\\' . Str::studly($alias) . '\\\\';
|
||||||
|
|
||||||
|
return $query->where('class', 'like', $class . '%');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the alias based on class.
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function getAliasAttribute()
|
||||||
|
{
|
||||||
|
if (Str::startsWith($this->class, 'App\\')) {
|
||||||
|
return 'core';
|
||||||
|
}
|
||||||
|
|
||||||
|
$arr = explode('\\', $this->class);
|
||||||
|
|
||||||
|
return Str::kebab($arr[1]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -82,6 +82,9 @@ class Event extends Provider
|
|||||||
'App\Listeners\Module\InstallExtraModules',
|
'App\Listeners\Module\InstallExtraModules',
|
||||||
'App\Listeners\Module\FinishInstallation',
|
'App\Listeners\Module\FinishInstallation',
|
||||||
],
|
],
|
||||||
|
'App\Events\Module\Uninstalled' => [
|
||||||
|
'App\Listeners\Module\FinishUninstallation',
|
||||||
|
],
|
||||||
];
|
];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -46,7 +46,7 @@ trait Users
|
|||||||
$user = user();
|
$user = user();
|
||||||
|
|
||||||
if (empty($user)) {
|
if (empty($user)) {
|
||||||
return false;
|
return app()->runningInConsole() ? true : false;
|
||||||
}
|
}
|
||||||
|
|
||||||
$dashboard = $user->dashboards()->where('id', $id)->first();
|
$dashboard = $user->dashboards()->where('id', $id)->first();
|
||||||
|
@ -8,24 +8,30 @@ use Illuminate\Support\Str;
|
|||||||
|
|
||||||
class Widgets
|
class Widgets
|
||||||
{
|
{
|
||||||
public static function getClasses($check_permission = true)
|
public static function getClasses($alias = 'core', $check_permission = true)
|
||||||
{
|
{
|
||||||
$classes = [];
|
$classes = $list = [];
|
||||||
|
|
||||||
$list = [
|
if (in_array($alias, ['core', 'all'])) {
|
||||||
'App\Widgets\TotalIncome',
|
$list = [
|
||||||
'App\Widgets\TotalExpenses',
|
'App\Widgets\TotalIncome',
|
||||||
'App\Widgets\TotalProfit',
|
'App\Widgets\TotalExpenses',
|
||||||
'App\Widgets\CashFlow',
|
'App\Widgets\TotalProfit',
|
||||||
'App\Widgets\IncomeByCategory',
|
'App\Widgets\CashFlow',
|
||||||
'App\Widgets\ExpensesByCategory',
|
'App\Widgets\IncomeByCategory',
|
||||||
'App\Widgets\AccountBalance',
|
'App\Widgets\ExpensesByCategory',
|
||||||
'App\Widgets\LatestIncome',
|
'App\Widgets\AccountBalance',
|
||||||
'App\Widgets\LatestExpenses',
|
'App\Widgets\LatestIncome',
|
||||||
'App\Widgets\Currencies',
|
'App\Widgets\LatestExpenses',
|
||||||
];
|
'App\Widgets\Currencies',
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
Module::enabled()->each(function ($module) use (&$list, $alias) {
|
||||||
|
if (!in_array($alias, [$module->alias, 'all'])) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
Module::enabled()->each(function ($module) use (&$list) {
|
|
||||||
$m = module($module->alias);
|
$m = module($module->alias);
|
||||||
|
|
||||||
if (!$m || empty($m->get('widgets'))) {
|
if (!$m || empty($m->get('widgets'))) {
|
||||||
|
@ -33,7 +33,7 @@ class Dashboards extends Seeder
|
|||||||
$this->dispatch(new CreateDashboard([
|
$this->dispatch(new CreateDashboard([
|
||||||
'company_id' => $company_id,
|
'company_id' => $company_id,
|
||||||
'name' => trans_choice('general.dashboards', 1),
|
'name' => trans_choice('general.dashboards', 1),
|
||||||
'default_widgets' => true,
|
'default_widgets' => 'core',
|
||||||
'users' => $user_id,
|
'users' => $user_id,
|
||||||
]));
|
]));
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user