Skip to content

Commit

Permalink
Merge pull request #95 from fleetbase/dev-v1.4.24
Browse files Browse the repository at this point in the history
dev-v1.4.24
  • Loading branch information
roncodes authored May 17, 2024
2 parents 7b7693a + 12deee3 commit 48e3464
Show file tree
Hide file tree
Showing 10 changed files with 157 additions and 38 deletions.
2 changes: 1 addition & 1 deletion composer.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "fleetbase/core-api",
"version": "1.4.23",
"version": "1.4.24",
"description": "Core Framework and Resources for Fleetbase API",
"keywords": [
"fleetbase",
Expand Down
25 changes: 18 additions & 7 deletions src/Exports/ApiCredentialExport.php
Original file line number Diff line number Diff line change
Expand Up @@ -4,24 +4,31 @@

use Fleetbase\Models\ApiCredential;
use Maatwebsite\Excel\Concerns\FromCollection;
use Maatwebsite\Excel\Concerns\ShouldAutoSize;
use Maatwebsite\Excel\Concerns\WithColumnFormatting;
use Maatwebsite\Excel\Concerns\WithHeadings;
use Maatwebsite\Excel\Concerns\WithMapping;
use PhpOffice\PhpSpreadsheet\Shared\Date;
use PhpOffice\PhpSpreadsheet\Style\NumberFormat;

class ApiCredentialExport implements FromCollection, WithHeadings, WithMapping, WithColumnFormatting
class ApiCredentialExport implements FromCollection, WithHeadings, WithMapping, WithColumnFormatting, ShouldAutoSize
{
protected array $selections = [];

public function __construct(array $selections = [])
{
$this->selections = $selections;
}

public function map($apiCredential): array
{
return [
$apiCredential->name,
$apiCredential->key,
$apiCredential->secret,
$apiCredential->test_mode ? 'Test' : 'Live',
$apiCredential->expires_at ? Date::dateTimeToExcel($apiCredential->expires_at) : 'Never',
$apiCredential->last_used_at ? Date::dateTimeToExcel($apiCredential->last_used_at) : 'Never',
Date::dateTimeToExcel($apiCredential->created_at),
$apiCredential->expires_at ? $apiCredential->expires_at : 'Never',
$apiCredential->last_used_at ? $apiCredential->last_used_at : 'Never',
$apiCredential->created_at,
];
}

Expand All @@ -32,9 +39,9 @@ public function headings(): array
'Public Key',
'Secret Key',
'Environment',
'Expiry',
'Expiry Date',
'Last Used',
'Created',
'Date Created',
];
}

Expand All @@ -52,6 +59,10 @@ public function columnFormats(): array
*/
public function collection()
{
if ($this->selections) {
return ApiCredential::whereIn('uuid', $this->selections)->get();
}

return ApiCredential::where('company_uuid', session('company'))->get();
}
}
65 changes: 65 additions & 0 deletions src/Exports/CompanyExport.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,65 @@
<?php

namespace Fleetbase\Exports;

use Fleetbase\Models\Company;
use Maatwebsite\Excel\Concerns\FromCollection;
use Maatwebsite\Excel\Concerns\ShouldAutoSize;
use Maatwebsite\Excel\Concerns\WithColumnFormatting;
use Maatwebsite\Excel\Concerns\WithHeadings;
use Maatwebsite\Excel\Concerns\WithMapping;
use PhpOffice\PhpSpreadsheet\Style\NumberFormat;

class CompanyExport implements FromCollection, WithHeadings, WithMapping, WithColumnFormatting, ShouldAutoSize
{
protected array $selections = [];

public function __construct(array $selections = [])
{
$this->selections = $selections;
}

public function map($company): array
{
return [
$company->name,
data_get($company, 'owner.name'),
data_get($company, 'owner.email'),
data_get($company, 'owner.phone'),
$company->companyUsers ? $company->companyUsers->count() : $company->companyUsers()->count(),
$company->created_at,
];
}

public function headings(): array
{
return [
'Name',
'Owner',
'Email',
'Phone',
'Users Count',
'Created',
];
}

public function columnFormats(): array
{
return [
'D' => '+#',
'F' => NumberFormat::FORMAT_DATE_DDMMYYYY,
];
}

/**
* @return \Illuminate\Support\Collection
*/
public function collection()
{
if ($this->selections) {
return Company::whereIn('uuid', $this->selections)->with(['companyUsers'])->get();
}

return Company::with(['companyUsers'])->get();
}
}
29 changes: 16 additions & 13 deletions src/Exports/GroupExport.php
Original file line number Diff line number Diff line change
Expand Up @@ -4,42 +4,41 @@

use Fleetbase\Models\Group;
use Maatwebsite\Excel\Concerns\FromCollection;
use Maatwebsite\Excel\Concerns\ShouldAutoSize;
use Maatwebsite\Excel\Concerns\WithColumnFormatting;
use Maatwebsite\Excel\Concerns\WithHeadings;
use Maatwebsite\Excel\Concerns\WithMapping;
use PhpOffice\PhpSpreadsheet\Shared\Date;
use PhpOffice\PhpSpreadsheet\Style\NumberFormat;

class GroupExport implements FromCollection, WithHeadings, WithMapping, WithColumnFormatting
class GroupExport implements FromCollection, WithHeadings, WithMapping, WithColumnFormatting, ShouldAutoSize
{
protected array $selections = [];

public function __construct(array $selections = [])
{
$this->selections = $selections;
}

public function map($group): array
{
return [
$group->name,
$group->company_name,
$group->last_login,
$group->email_verified_at ? Date::dateTimeToExcel($group->email_verified_at) : 'Never',
Date::dateTimeToExcel($group->created_at),
$group->created_at,
];
}

public function headings(): array
{
return [
'Name',
'Company',
'Last Login',
'Email Verified At',
'Created',
'Date Created',
];
}

public function columnFormats(): array
{
return [
'E' => NumberFormat::FORMAT_DATE_DDMMYYYY,
'F' => NumberFormat::FORMAT_DATE_DDMMYYYY,
'G' => NumberFormat::FORMAT_DATE_DDMMYYYY,
'B' => NumberFormat::FORMAT_DATE_DDMMYYYY,
];
}

Expand All @@ -48,6 +47,10 @@ public function columnFormats(): array
*/
public function collection()
{
if ($this->selections) {
return Group::whereIn('uuid', $this->selections)->get();
}

return Group::where('company_uuid', session('company'))->get();
}
}
38 changes: 30 additions & 8 deletions src/Exports/UserExport.php
Original file line number Diff line number Diff line change
Expand Up @@ -4,22 +4,34 @@

use Fleetbase\Models\User;
use Maatwebsite\Excel\Concerns\FromCollection;
use Maatwebsite\Excel\Concerns\ShouldAutoSize;
use Maatwebsite\Excel\Concerns\WithColumnFormatting;
use Maatwebsite\Excel\Concerns\WithHeadings;
use Maatwebsite\Excel\Concerns\WithMapping;
use PhpOffice\PhpSpreadsheet\Shared\Date;
use PhpOffice\PhpSpreadsheet\Style\NumberFormat;

class UserExport implements FromCollection, WithHeadings, WithMapping, WithColumnFormatting
class UserExport implements FromCollection, WithHeadings, WithMapping, WithColumnFormatting, ShouldAutoSize
{
protected array $selections = [];

public function __construct(array $selections = [])
{
$this->selections = $selections;
}

public function map($user): array
{
return [
$user->name,
$user->company_name,
$user->email,
$user->phone,
$user->country,
$user->timezone,
$user->ip_address,
$user->last_login,
$user->email_verified_at ? Date::dateTimeToExcel($user->email_verified_at) : 'Never',
Date::dateTimeToExcel($user->created_at),
$user->email_verified_at ? $user->email_verified_at : 'Never',
$user->created_at,
];
}

Expand All @@ -28,18 +40,24 @@ public function headings(): array
return [
'Name',
'Company',
'Email',
'Phone',
'Country',
'Timezone',
'IP Address',
'Last Login',
'Email Verified At',
'Created',
'Date Created',
];
}

public function columnFormats(): array
{
return [
'E' => NumberFormat::FORMAT_DATE_DDMMYYYY,
'F' => NumberFormat::FORMAT_DATE_DDMMYYYY,
'G' => NumberFormat::FORMAT_DATE_DDMMYYYY,
'D' => '+#',
'H' => NumberFormat::FORMAT_DATE_DDMMYYYY,
'I' => NumberFormat::FORMAT_DATE_DDMMYYYY,
'J' => NumberFormat::FORMAT_DATE_DDMMYYYY,
];
}

Expand All @@ -48,6 +66,10 @@ public function columnFormats(): array
*/
public function collection()
{
if (!empty($this->selections)) {
return User::where('company_uuid', session('company'))->whereIn('uuid', $this->selections)->get();
}

return User::where('company_uuid', session('company'))->get();
}
}
18 changes: 17 additions & 1 deletion src/Http/Controllers/Internal/v1/CompanyController.php
Original file line number Diff line number Diff line change
Expand Up @@ -2,16 +2,18 @@

namespace Fleetbase\Http\Controllers\Internal\v1;

use Fleetbase\Exports\CompanyExport;
use Fleetbase\Http\Controllers\FleetbaseController;
use Fleetbase\Http\Requests\ExportRequest;
use Fleetbase\Http\Resources\Organization;
use Fleetbase\Models\Company;
use Fleetbase\Models\CompanyUser;
use Fleetbase\Models\Invite;
use Fleetbase\Models\User;
use Fleetbase\Support\Auth;
use Fleetbase\Support\TwoFactorAuth;
use Illuminate\Http\Request;
use Illuminate\Support\Str;
use Maatwebsite\Excel\Facades\Excel;

class CompanyController extends FleetbaseController
{
Expand Down Expand Up @@ -151,4 +153,18 @@ public function users(string $id, Request $request)

return response()->json(['users' => $users]);
}

/**
* Export the users to excel or csv.
*
* @return \Illuminate\Http\Response
*/
public function export(ExportRequest $request)
{
$format = $request->input('format', 'xlsx');
$selections = $request->array('selections');
$fileName = trim(Str::slug('company-' . date('Y-m-d-H:i')) . '.' . $format);

return Excel::download(new CompanyExport($selections), $fileName);
}
}
9 changes: 5 additions & 4 deletions src/Http/Controllers/Internal/v1/UserController.php
Original file line number Diff line number Diff line change
Expand Up @@ -432,12 +432,13 @@ public function searchRecords(Request $request)
*
* @return \Illuminate\Http\Response
*/
public static function export(ExportRequest $request)
public function export(ExportRequest $request)
{
$format = $request->input('format', 'xlsx');
$fileName = trim(Str::slug('users-' . date('Y-m-d-H:i')) . '.' . $format);
$format = $request->input('format', 'xlsx');
$selections = $request->array('selections');
$fileName = trim(Str::slug('users-' . date('Y-m-d-H:i')) . '.' . $format);

return Excel::download(new UserExport(), $fileName);
return Excel::download(new UserExport($selections), $fileName);
}

/**
Expand Down
1 change: 1 addition & 0 deletions src/Http/Resources/User.php
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@ public function toArray($request)
'is_admin' => $this->when(Http::isInternalRequest(), $this->is_admin),
'is_online' => $this->is_online,
'last_seen_at' => $this->last_seen_at,
'last_login' => $this->last_login,
'updated_at' => $this->updated_at,
'created_at' => $this->created_at,
];
Expand Down
5 changes: 2 additions & 3 deletions src/Support/Utils.php
Original file line number Diff line number Diff line change
Expand Up @@ -703,13 +703,12 @@ public static function removeSpecialCharacters($string, $except = [])
*
* @param float $amount amount to format
* @param string $currency the currency to format into
* @param bool $cents whether if amount is in cents, this will auto divide by 100
*
* @return string
*/
public static function moneyFormat($amount, $currency = 'USD', $cents = true)
public static function moneyFormat($amount, $currency = 'USD')
{
$amount = $cents === true ? static::numbersOnly($amount) / 100 : $amount;
$amount = static::numbersOnly($amount);
$money = new \Cknow\Money\Money($amount, $currency);

return $money->format();
Expand Down
3 changes: 2 additions & 1 deletion src/routes.php
Original file line number Diff line number Diff line change
Expand Up @@ -208,13 +208,14 @@ function ($router, $controller) {
$router->fleetbaseRoutes('companies', function ($router, $controller) {
$router->get('two-fa', $controller('getTwoFactorSettings'))->middleware([Spatie\ResponseCache\Middlewares\DoNotCacheResponse::class]);
$router->post('two-fa', $controller('saveTwoFactorSettings'));
$router->match(['get', 'post'], 'export', $controller('export'))->middleware([Spatie\ResponseCache\Middlewares\DoNotCacheResponse::class]);
$router->get('{id}/users', $controller('users'))->middleware([Spatie\ResponseCache\Middlewares\DoNotCacheResponse::class]);
})->middleware([Spatie\ResponseCache\Middlewares\DoNotCacheResponse::class]);
$router->fleetbaseRoutes(
'users',
function ($router, $controller) {
$router->get('me', $controller('current'))->middleware([Spatie\ResponseCache\Middlewares\DoNotCacheResponse::class]);
$router->get('export', $controller('export'))->middleware([Spatie\ResponseCache\Middlewares\DoNotCacheResponse::class]);
$router->match(['get', 'post'], 'export', $controller('export'))->middleware([Spatie\ResponseCache\Middlewares\DoNotCacheResponse::class]);
$router->patch('deactivate/{id}', $controller('deactivate'));
$router->patch('activate/{id}', $controller('activate'));
$router->delete('remove-from-company/{id}', $controller('removeFromCompany'));
Expand Down

0 comments on commit 48e3464

Please sign in to comment.