Compare commits

..

No commits in common. "9b2364bc3409fdc9406dd69444e0c48f292d3923" and "6fd16a7dfe7e312b55d534d776954358170492c9" have entirely different histories.

13 changed files with 40 additions and 107 deletions

View File

@ -48,36 +48,36 @@ class FilterScope extends Filter
*/
public function apply(Builder $query): Builder
{
return $query->where(function ($query) {
$query->orWhere(function ($query) {
if ($this->ausstand) {
$query->whereAusstand();
}
$query->orWhere(function ($query) {
if ($this->ausstand) {
$query->whereAusstand();
}
if ($this->billKind) {
$query->where('bill_kind', BillKind::fromValue($this->billKind));
}
if ($this->billKind) {
$query->where('bill_kind', BillKind::fromValue($this->billKind));
}
if (count($this->groupIds)) {
$query->whereIn('group_id', $this->groupIds);
}
if (count($this->groupIds)) {
$query->whereIn('group_id', $this->groupIds);
}
if (count($this->subactivityIds) + count($this->activityIds) > 0) {
$query->whereHas('memberships', function ($q) {
$q->active();
if (count($this->subactivityIds)) {
$q->whereIn('subactivity_id', $this->subactivityIds);
}
if (count($this->activityIds)) {
$q->whereIn('activity_id', $this->activityIds);
}
});
}
})->orWhere(function ($query) {
if (count($this->additional)) {
$query->whereIn('id', $this->additional);
}
});
if (count($this->subactivityIds) + count($this->activityIds) > 0) {
$query->whereHas('memberships', function ($q) {
$q->active();
if (count($this->subactivityIds)) {
$q->whereIn('subactivity_id', $this->subactivityIds);
}
if (count($this->activityIds)) {
$q->whereIn('activity_id', $this->activityIds);
}
});
}
})->orWhere(function ($query) {
if (count($this->additional)) {
$query->whereIn('id', $this->additional);
}
});
return $query;
}
}

View File

@ -44,8 +44,6 @@ class CreateActivitiesTable extends Migration
*/
public function down()
{
Schema::dropIfExists('activity_subactivity');
Schema::dropIfExists('subactivities');
Schema::dropIfExists('activities');
}
}

View File

@ -44,6 +44,5 @@ class CreatePaymentsTable extends Migration
public function down()
{
Schema::dropIfExists('payments');
Schema::dropIfExists('statuses');
}
}

View File

@ -37,7 +37,6 @@ class CreateCoursesTable extends Migration
*/
public function down()
{
Schema::dropIfExists('course_members');
Schema::dropIfExists('courses');
}
}

View File

@ -22,9 +22,4 @@ class CreateSettingsTable extends Migration
$table->timestamps();
});
}
public function down()
{
Schema::dropIfExists('settings');
}
}

View File

@ -26,8 +26,8 @@ class CreateGroupsParentIdColumn extends Migration
public function down()
{
Schema::table('groups', function (Blueprint $table) {
$table->dropForeign(['parent_id']);
$table->dropColumn('parent_id');
$table->dropForeign(['group_id']);
$table->dropColumn('group_id');
});
}
}

View File

@ -32,14 +32,6 @@ return new class() extends Migration {
public function down()
{
Schema::table('members', function (Blueprint $table) {
$table->dropColumn('ps_at');
$table->dropColumn('more_ps_at');
$table->dropColumn('without_education_at');
$table->dropColumn('without_efz_at');
$table->dropColumn('has_svk');
$table->dropColumn('has_vk');
$table->dropColumn('multiply_pv');
$table->dropColumn('multiply_more_pv');
});
}
};

View File

@ -27,9 +27,6 @@ return new class() extends Migration {
public function down()
{
Schema::table('users', function (Blueprint $table) {
$table->dropUnique(['email']);
$table->dropColumn('email_verified_at');
$table->dropColumn('remember_token');
});
}
};

View File

@ -24,8 +24,5 @@ return new class() extends Migration {
*/
public function down()
{
Schema::table('members', function (Blueprint $table) {
$table->dropColumn('slug');
});
}
};

View File

@ -24,8 +24,5 @@ return new class() extends Migration {
*/
public function down()
{
Schema::table('memberships', function (Blueprint $table) {
$table->dropColumn('promised_at');
});
}
};

View File

@ -1,5 +1,6 @@
<?php
use App\Payment\SubscriptionChild;
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
@ -12,6 +13,8 @@ return new class() extends Migration {
*/
public function up()
{
$subscriptions = DB::table('subscriptions')->get();
Schema::table('subscriptions', function (Blueprint $table) {
$table->dropColumn('amount');
$table->boolean('split')->default(false);
@ -24,6 +27,14 @@ return new class() extends Migration {
$table->string('name');
$table->unsignedInteger('amount');
});
foreach ($subscriptions as $subscription) {
SubscriptionChild::create([
'parent_id' => $subscription->id,
'name' => 'name',
'amount' => $subscription->amount,
]);
}
}
/**
@ -33,11 +44,5 @@ return new class() extends Migration {
*/
public function down()
{
Schema::dropIfExists('subscription_children');
Schema::table('subscriptions', function (Blueprint $table) {
$table->unsignedInteger('amount');
$table->dropColumn('split');
$table->dropColumn('for_promise');
});
}
};

View File

@ -13,9 +13,6 @@
<testsuite name="NamiUnit">
<directory suffix="Test.php">./packages/laravel-nami/tests/Unit</directory>
</testsuite>
<testsuite name="EndToEnd">
<directory suffix="Test.php">./tests/EndToEnd</directory>
</testsuite>
</testsuites>
<filter>
<whitelist processUncoveredFilesFromWhitelist="true">

View File

@ -1,43 +0,0 @@
<?php
namespace Tests\EndToEnd;
use App\Group;
use App\Member\Member;
use App\Payment\Payment;
use Illuminate\Foundation\Testing\DatabaseMigrations;
use Tests\RequestFactories\Child;
use Tests\TestCase;
class MemberIndexTest extends TestCase
{
use DatabaseMigrations;
public function testItHandlesFullTextSearch(): void
{
$this->withoutExceptionHandling()->login()->loginNami();
$group = Group::factory()->create();
Member::factory()->defaults()->for($group)->create(['firstname' => '::firstname::']);
Member::factory()->defaults()->for($group)->create(['firstname' => '::gggname::']);
$response = $this->callFilter('member.index', ['search' => '::firstname::']);
$this->assertCount(1, $this->inertia($response, 'data.data'));
}
public function testItFiltersForSearchButNotForPayments(): void
{
$this->withoutExceptionHandling()->login()->loginNami();
$group = Group::factory()->create();
Member::factory()->defaults()->for($group)
->has(Payment::factory()->notPaid()->subscription('tollerbeitrag', [
new Child('a', 5400),
]))
->create(['firstname' => '::firstname::']);
Member::factory()->defaults()->for($group)->create(['firstname' => '::firstname::']);
$response = $this->callFilter('member.index', ['search' => '::firstname::', 'ausstand' => true]);
$this->assertCount(1, $this->inertia($response, 'data.data'));
}
}