parent
c2ae800515
commit
0b3765baa3
app
resources/js/views/home
tests/Feature/Member
|
@ -4,6 +4,7 @@ namespace App\Home;
|
|||
|
||||
use App\Efz\EfzPendingBlock;
|
||||
use App\Home\Blocks\Block;
|
||||
use App\Member\PsPendingBlock;
|
||||
use App\Membership\AgeGroupCountBlock;
|
||||
use App\Membership\TestersBlock;
|
||||
use App\Payment\MemberPaymentBlock;
|
||||
|
@ -18,6 +19,7 @@ class DashboardFactory
|
|||
MemberPaymentBlock::class,
|
||||
TestersBlock::class,
|
||||
EfzPendingBlock::class,
|
||||
PsPendingBlock::class,
|
||||
];
|
||||
|
||||
/**
|
||||
|
|
|
@ -0,0 +1,49 @@
|
|||
<?php
|
||||
|
||||
namespace App\Member;
|
||||
|
||||
use App\Home\Blocks\Block;
|
||||
use Illuminate\Database\Eloquent\Builder;
|
||||
|
||||
class PsPendingBlock extends Block
|
||||
{
|
||||
/**
|
||||
* @return Builder<Member>
|
||||
*/
|
||||
public function query(): Builder
|
||||
{
|
||||
return Member::where(function ($query) {
|
||||
$time = now()->subYears(5)->endOfYear();
|
||||
|
||||
return $query
|
||||
->orWhere(fn ($query) => $query->whereNull('ps_at')->whereNull('more_ps_at'))
|
||||
->orWhere(fn ($query) => $query->whereNull('ps_at')->where('more_ps_at', '<=', $time))
|
||||
->orWhere(fn ($query) => $query->where('ps_at', '<=', $time)->whereNull('more_ps_at'))
|
||||
->orWhere(fn ($query) => $query->where('ps_at', '>=', $time)->where('more_ps_at', '<=', $time));
|
||||
})
|
||||
->orderByRaw('lastname, firstname')
|
||||
->whereHas('memberships', fn ($builder) => $builder->isLeader());
|
||||
}
|
||||
|
||||
/**
|
||||
* @return array{members: array{fullname: string}}
|
||||
*/
|
||||
public function data(): array
|
||||
{
|
||||
return [
|
||||
'members' => $this->query()->get()->map(fn ($member) => [
|
||||
'fullname' => $member->fullname,
|
||||
])->toArray(),
|
||||
];
|
||||
}
|
||||
|
||||
public function component(): string
|
||||
{
|
||||
return 'ps-pending';
|
||||
}
|
||||
|
||||
public function title(): string
|
||||
{
|
||||
return 'Ausstehende Präventionsschulungen';
|
||||
}
|
||||
}
|
|
@ -0,0 +1,31 @@
|
|||
<template>
|
||||
<div>
|
||||
<div
|
||||
v-for="(member, index) in inner.members"
|
||||
:key="index"
|
||||
class="flex mt-2 items-center leading-none text-gray-100"
|
||||
>
|
||||
<span class="grow" v-text="`${member.fullname}`"></span>
|
||||
</div>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
export default {
|
||||
data: function () {
|
||||
return {
|
||||
inner: {
|
||||
members: [],
|
||||
},
|
||||
};
|
||||
},
|
||||
|
||||
props: {
|
||||
data: {},
|
||||
},
|
||||
|
||||
created() {
|
||||
this.inner = this.data;
|
||||
},
|
||||
};
|
||||
</script>
|
|
@ -25,6 +25,7 @@ export default {
|
|||
'VBlock': () => import('./VBlock'),
|
||||
'age-group-count': () => import('./AgeGroupCount.vue'),
|
||||
'efz-pending': () => import('./EfzPending.vue'),
|
||||
'ps-pending': () => import('./PsPending.vue'),
|
||||
'testers': () => import('./Testers.vue'),
|
||||
'member-payment': () => import('./MemberPayment.vue'),
|
||||
},
|
||||
|
|
|
@ -0,0 +1,61 @@
|
|||
<?php
|
||||
|
||||
namespace Tests\Feature\Member;
|
||||
|
||||
use App\Member\Member;
|
||||
use App\Member\Membership;
|
||||
use App\Member\PsPendingBlock;
|
||||
use Illuminate\Foundation\Testing\DatabaseTransactions;
|
||||
use Tests\TestCase;
|
||||
|
||||
class PsPendingBlockTest extends TestCase
|
||||
{
|
||||
use DatabaseTransactions;
|
||||
|
||||
public function testItRendersContent(): void
|
||||
{
|
||||
$noPsAtAll = Member::factory()
|
||||
->defaults()
|
||||
->has(Membership::factory()->in('€ LeiterIn', 5, 'Wölfling', 8))
|
||||
->create(['firstname' => 'Jane', 'lastname' => 'Doe']);
|
||||
$validPs = Member::factory()
|
||||
->defaults()
|
||||
->has(Membership::factory()->in('€ LeiterIn', 5, 'Wölfling', 8))
|
||||
->has(Membership::factory()->in('€ LeiterIn', 5, 'Wölfling', 8))
|
||||
->create(['firstname' => 'Max', 'lastname' => 'Doe', 'ps_at' => now()->subYears(4)]);
|
||||
$validMorePs = Member::factory()
|
||||
->defaults()
|
||||
->has(Membership::factory()->in('€ LeiterIn', 5, 'Wölfling', 8))
|
||||
->has(Membership::factory()->in('€ LeiterIn', 5, 'Wölfling', 8))
|
||||
->create(['firstname' => 'Joe', 'lastname' => 'Doe', 'more_ps_at' => now()->subYears(4)]);
|
||||
$invalidPs = Member::factory()
|
||||
->defaults()
|
||||
->has(Membership::factory()->in('€ LeiterIn', 5, 'Wölfling', 8))
|
||||
->has(Membership::factory()->in('€ LeiterIn', 5, 'Wölfling', 8))
|
||||
->create(['firstname' => 'Mike', 'lastname' => 'Doe', 'ps_at' => now()->subYears(5)]);
|
||||
$invalidMorePs = Member::factory()
|
||||
->defaults()
|
||||
->has(Membership::factory()->in('€ LeiterIn', 5, 'Wölfling', 8))
|
||||
->has(Membership::factory()->in('€ LeiterIn', 5, 'Wölfling', 8))
|
||||
->create(['firstname' => 'Nora', 'lastname' => 'Doe', 'more_ps_at' => now()->subYears(5)]);
|
||||
$invalidPsButValidMorePs = Member::factory()
|
||||
->defaults()
|
||||
->has(Membership::factory()->in('€ LeiterIn', 5, 'Wölfling', 8))
|
||||
->has(Membership::factory()->in('€ LeiterIn', 5, 'Wölfling', 8))
|
||||
->create(['firstname' => 'Hey', 'lastname' => 'Doe', 'ps_at' => now()->subYears(10), 'more_ps_at' => now()->subYears(3)]);
|
||||
$notALeader = Member::factory()
|
||||
->defaults()
|
||||
->has(Membership::factory()->in('€ Mitglied', 5, 'Wölfling', 8))
|
||||
->create(['firstname' => 'Mae', 'lastname' => 'Doe']);
|
||||
|
||||
$data = app(PsPendingBlock::class)->render()['data'];
|
||||
|
||||
$this->assertEquals([
|
||||
'members' => [
|
||||
['fullname' => 'Jane Doe'],
|
||||
['fullname' => 'Mike Doe'],
|
||||
['fullname' => 'Nora Doe'],
|
||||
],
|
||||
], $data);
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue