improved disable/delete with relationships
This commit is contained in:
@ -74,13 +74,27 @@ class Categories extends Controller
|
||||
*/
|
||||
public function update(Category $category, Request $request)
|
||||
{
|
||||
$category->update($request->all());
|
||||
$relationships = $this->countRelationships($category, [
|
||||
'items' => 'items',
|
||||
'revenues' => 'revenues',
|
||||
'payments' => 'payments',
|
||||
]);
|
||||
|
||||
$message = trans('messages.success.updated', ['type' => trans_choice('general.categories', 1)]);
|
||||
if (empty($relationships) || $request['enabled']) {
|
||||
$category->update($request->all());
|
||||
|
||||
flash($message)->success();
|
||||
$message = trans('messages.success.updated', ['type' => trans_choice('general.categories', 1)]);
|
||||
|
||||
return redirect('settings/categories');
|
||||
flash($message)->success();
|
||||
|
||||
return redirect('settings/categories');
|
||||
} else {
|
||||
$message = trans('messages.warning.disabled', ['name' => $category->name, 'text' => implode(', ', $relationships)]);
|
||||
|
||||
flash($message)->warning();
|
||||
|
||||
return redirect('settings/categories/' . $category->id . '/edit');
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
@ -92,30 +106,20 @@ class Categories extends Controller
|
||||
*/
|
||||
public function destroy(Category $category)
|
||||
{
|
||||
$canDelete = $category->canDelete();
|
||||
$relationships = $this->countRelationships($category, [
|
||||
'items' => 'items',
|
||||
'revenues' => 'revenues',
|
||||
'payments' => 'payments',
|
||||
]);
|
||||
|
||||
if ($canDelete === true) {
|
||||
if (empty($relationships)) {
|
||||
$category->delete();
|
||||
|
||||
$message = trans('messages.success.deleted', ['type' => trans_choice('general.categories', 1)]);
|
||||
|
||||
flash($message)->success();
|
||||
} else {
|
||||
$text = array();
|
||||
|
||||
if (isset($canDelete['items'])) {
|
||||
$text[] = '<b>' . $canDelete['items'] . '</b> ' . trans_choice('general.items', ($canDelete['items'] > 1) ? 2 : 1);
|
||||
}
|
||||
|
||||
if (isset($canDelete['payments'])) {
|
||||
$text[] = '<b>' . $canDelete['payments'] . '</b> ' . trans_choice('general.payments', ($canDelete['payments'] > 1) ? 2 : 1);
|
||||
}
|
||||
|
||||
if (isset($canDelete['revenues'])) {
|
||||
$text[] = '<b>' . $canDelete['revenues'] . '</b> ' . trans_choice('general.items', ($canDelete['revenues'] > 1) ? 2 : 1);
|
||||
}
|
||||
|
||||
$message = trans('messages.warning.deleted', ['type' => trans_choice('general.categories', 1), 'text' => implode(', ', $text)]);
|
||||
$message = trans('messages.warning.deleted', ['name' => $category->name, 'text' => implode(', ', $relationships)]);
|
||||
|
||||
flash($message)->warning();
|
||||
}
|
||||
|
@ -95,9 +95,20 @@ class Currencies extends Controller
|
||||
*/
|
||||
public function update(Currency $currency, Request $request)
|
||||
{
|
||||
$canDisable = $currency->canDisable();
|
||||
$relationships = $this->countRelationships($currency, [
|
||||
'accounts' => 'accounts',
|
||||
'customers' => 'customers',
|
||||
'invoices' => 'invoices',
|
||||
'revenues' => 'revenues',
|
||||
'bills' => 'bills',
|
||||
'payments' => 'payments',
|
||||
]);
|
||||
|
||||
if ($canDisable === true || $request['enabled']) {
|
||||
if ($currency->code == setting('general.default_currency')) {
|
||||
$relationships[] = strtolower(trans_choice('general.companies', 1));
|
||||
}
|
||||
|
||||
if (empty($relationships) || $request['enabled']) {
|
||||
$currency->update($request->all());
|
||||
|
||||
// Update default currency setting
|
||||
@ -109,43 +120,15 @@ class Currencies extends Controller
|
||||
$message = trans('messages.success.updated', ['type' => trans_choice('general.currencies', 1)]);
|
||||
|
||||
flash($message)->success();
|
||||
|
||||
return redirect('settings/currencies');
|
||||
} else {
|
||||
$text = array();
|
||||
|
||||
if (isset($canDisable['company'])) {
|
||||
$text[] = '<b>' . $canDisable['company'] . '</b> ' . trans_choice('general.companies', ($canDisable['company'] > 1) ? 2 : 1);
|
||||
}
|
||||
|
||||
if (isset($canDisable['accounts'])) {
|
||||
$text[] = '<b>' . $canDisable['accounts'] . '</b> ' . trans_choice('general.accounts', ($canDisable['accounts'] > 1) ? 2 : 1);
|
||||
}
|
||||
|
||||
if (isset($canDisable['customers'])) {
|
||||
$text[] = '<b>' . $canDisable['customers'] . '</b> ' . trans_choice('general.customers', ($canDisable['customers'] > 1) ? 2 : 1);
|
||||
}
|
||||
|
||||
if (isset($canDisable['invoices'])) {
|
||||
$text[] = '<b>' . $canDisable['invoices'] . '</b> ' . trans_choice('general.invoices', ($canDisable['invoices'] > 1) ? 2 : 1);
|
||||
}
|
||||
|
||||
if (isset($canDisable['revenues'])) {
|
||||
$text[] = '<b>' . $canDisable['revenues'] . '</b> ' . trans_choice('general.revenues', ($canDisable['revenues'] > 1) ? 2 : 1);
|
||||
}
|
||||
|
||||
if (isset($canDisable['bills'])) {
|
||||
$text[] = '<b>' . $canDisable['bills'] . '</b> ' . trans_choice('general.bills', ($canDisable['bills'] > 1) ? 2 : 1);
|
||||
}
|
||||
|
||||
if (isset($canDisable['payments'])) {
|
||||
$text[] = '<b>' . $canDisable['payments'] . '</b> ' . trans_choice('general.payments', ($canDisable['payments'] > 1) ? 2 : 1);
|
||||
}
|
||||
|
||||
$message = trans('messages.warning.disabled', ['type' => trans_choice('general.currencies', 1), 'text' => implode(', ', $text)]);
|
||||
$message = trans('messages.warning.disabled', ['name' => $currency->name, 'text' => implode(', ', $relationships)]);
|
||||
|
||||
flash($message)->warning();
|
||||
}
|
||||
|
||||
return redirect('settings/currencies');
|
||||
return redirect('settings/currencies/' . $currency->id . '/edit');
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
@ -157,11 +140,30 @@ class Currencies extends Controller
|
||||
*/
|
||||
public function destroy(Currency $currency)
|
||||
{
|
||||
$currency->delete();
|
||||
$relationships = $this->countRelationships($currency, [
|
||||
'accounts' => 'accounts',
|
||||
'customers' => 'customers',
|
||||
'invoices' => 'invoices',
|
||||
'revenues' => 'revenues',
|
||||
'bills' => 'bills',
|
||||
'payments' => 'payments',
|
||||
]);
|
||||
|
||||
$message = trans('messages.success.deleted', ['type' => trans_choice('general.currencies', 1)]);
|
||||
if ($currency->code == setting('general.default_currency')) {
|
||||
$relationships[] = strtolower(trans_choice('general.companies', 1));
|
||||
}
|
||||
|
||||
flash($message)->success();
|
||||
if (empty($relationships)) {
|
||||
$currency->delete();
|
||||
|
||||
$message = trans('messages.success.deleted', ['type' => trans_choice('general.currencies', 1)]);
|
||||
|
||||
flash($message)->success();
|
||||
} else {
|
||||
$message = trans('messages.warning.deleted', ['name' => $currency->name, 'text' => implode(', ', $relationships)]);
|
||||
|
||||
flash($message)->warning();
|
||||
}
|
||||
|
||||
return redirect('settings/currencies');
|
||||
}
|
||||
|
@ -71,13 +71,27 @@ class Taxes extends Controller
|
||||
*/
|
||||
public function update(Tax $tax, Request $request)
|
||||
{
|
||||
$tax->update($request->all());
|
||||
$relationships = $this->countRelationships($tax, [
|
||||
'items' => 'items',
|
||||
'invoice_items' => 'invoices',
|
||||
'bill_items' => 'bills',
|
||||
]);
|
||||
|
||||
$message = trans('messages.success.updated', ['type' => trans_choice('general.tax_rates', 1)]);
|
||||
if (empty($relationships) || $request['enabled']) {
|
||||
$tax->update($request->all());
|
||||
|
||||
flash($message)->success();
|
||||
$message = trans('messages.success.updated', ['type' => trans_choice('general.tax_rates', 1)]);
|
||||
|
||||
return redirect('settings/taxes');
|
||||
flash($message)->success();
|
||||
|
||||
return redirect('settings/taxes');
|
||||
} else {
|
||||
$message = trans('messages.warning.disabled', ['name' => $tax->name, 'text' => implode(', ', $relationships)]);
|
||||
|
||||
flash($message)->warning();
|
||||
|
||||
return redirect('settings/taxes/' . $tax->id . '/edit');
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
@ -89,30 +103,20 @@ class Taxes extends Controller
|
||||
*/
|
||||
public function destroy(Tax $tax)
|
||||
{
|
||||
$canDelete = $tax->canDelete();
|
||||
$relationships = $this->countRelationships($tax, [
|
||||
'items' => 'items',
|
||||
'invoice_items' => 'invoices',
|
||||
'bill_items' => 'bills',
|
||||
]);
|
||||
|
||||
if ($canDelete === true) {
|
||||
if (empty($relationships)) {
|
||||
$tax->delete();
|
||||
|
||||
$message = trans('messages.success.deleted', ['type' => trans_choice('general.taxes', 1)]);
|
||||
|
||||
flash($message)->success();
|
||||
} else {
|
||||
$text = array();
|
||||
|
||||
if (isset($canDelete['items'])) {
|
||||
$text[] = '<b>' . $canDelete['items'] . '</b> ' . trans_choice('general.items', ($canDelete['items'] > 1) ? 2 : 1);
|
||||
}
|
||||
|
||||
if (isset($canDelete['bills'])) {
|
||||
$text[] = '<b>' . $canDelete['bills'] . '</b> ' . trans_choice('general.bills', ($canDelete['bills'] > 1) ? 2 : 1);
|
||||
}
|
||||
|
||||
if (isset($canDelete['invoices'])) {
|
||||
$text[] = '<b>' . $canDelete['invoices'] . '</b> ' . trans_choice('general.items', ($canDelete['invoices'] > 1) ? 2 : 1);
|
||||
}
|
||||
|
||||
$message = trans('messages.warning.deleted', ['type' => trans_choice('general.taxes', 1), 'text' => implode(', ', $text)]);
|
||||
$message = trans('messages.warning.deleted', ['name' => $tax->name, 'text' => implode(', ', $relationships)]);
|
||||
|
||||
flash($message)->warning();
|
||||
}
|
||||
|
Reference in New Issue
Block a user