85 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
			
		
		
	
	
			85 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
| <?php
 | |
| 
 | |
| namespace App\Actions;
 | |
| 
 | |
| use App\Confession;
 | |
| use App\Country;
 | |
| use App\Fee;
 | |
| use App\Gender;
 | |
| use App\Group;
 | |
| use App\Member\Member;
 | |
| use App\Nationality;
 | |
| use App\Payment\Subscription;
 | |
| use App\Region;
 | |
| use Lorisleiva\Actions\Concerns\AsAction;
 | |
| use Zoomyboy\LaravelNami\Data\Member as NamiMember;
 | |
| 
 | |
| class InsertMemberAction
 | |
| {
 | |
|     use AsAction;
 | |
| 
 | |
|     public function handle(NamiMember $member): Member
 | |
|     {
 | |
|         $region = Region::firstWhere('nami_id', $member->regionId ?: -1);
 | |
| 
 | |
| 
 | |
|         $payload = [
 | |
|             'firstname' => $member->firstname,
 | |
|             'lastname' => $member->lastname,
 | |
|             'joined_at' => $member->joinedAt,
 | |
|             'birthday' => $member->birthday,
 | |
|             'send_newspaper' => $member->sendNewspaper,
 | |
|             'address' => $member->address,
 | |
|             'zip' => $member->zip,
 | |
|             'location' => $member->location,
 | |
|             'nickname' => $member->nickname,
 | |
|             'other_country' => $member->otherCountry,
 | |
|             'further_address' => $member->furtherAddress,
 | |
|             'main_phone' => $member->mainPhone,
 | |
|             'mobile_phone' => $member->mobilePhone,
 | |
|             'work_phone' => $member->workPhone,
 | |
|             'fax' => $member->fax,
 | |
|             'email' => $member->email,
 | |
|             'email_parents' => $member->emailParents,
 | |
|             'nami_id' => $member->id,
 | |
|             'group_id' => Group::firstOrCreate(['nami_id' => $member->groupId], ['nami_id' => $member->groupId, 'name' => $member->groupName])->id,
 | |
|             'gender_id' => optional(Gender::firstWhere('nami_id', $member->genderId ?: -1))->id,
 | |
|             'confession_id' => optional(Confession::firstWhere('nami_id', $member->confessionId ?: -1))->id,
 | |
|             'region_id' => $region && !$region->is_null ? $region->id : null,
 | |
|             'country_id' => optional(Country::where('nami_id', $member->countryId)->first())->id,
 | |
|             'subscription_id' => $this->getSubscription($member)?->id,
 | |
|             'nationality_id' => Nationality::where('nami_id', $member->nationalityId)->firstOrFail()->id,
 | |
|             'mitgliedsnr' => $member->memberId,
 | |
|             'version' => $member->version,
 | |
|             'keepdata' => $member->keepdata,
 | |
|         ];
 | |
| 
 | |
|         // Dont update subscription if fee id of existing member's subscription is already the same
 | |
|         if ($existing = Member::nami($member->id)) {
 | |
|             if ($existing->subscription && $existing->subscription->fee->nami_id === $member->feeId) {
 | |
|                 $payload['subscription_id'] = $existing->subscription->id;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         return Member::updateOrCreate(['nami_id' => $member->id], $payload);
 | |
|     }
 | |
| 
 | |
|     public function getSubscription(NamiMember $member): ?Subscription
 | |
|     {
 | |
|         if (is_null($member->feeId)) {
 | |
|             return null;
 | |
|         }
 | |
| 
 | |
|         $fee = Fee::nami($member->feeId);
 | |
| 
 | |
|         if (is_null($fee)) {
 | |
|             $feeName = $member->feeName ?: 'Default';
 | |
|             $fee = Fee::create(['name' => $feeName, 'nami_id' => $member->feeId]);
 | |
|             $subscription = $fee->subscriptions()->create(['name' => $feeName]);
 | |
|             $subscription->children()->create(['name' => $feeName, 'amount' => 1000]);
 | |
|         }
 | |
| 
 | |
|         return $fee->subscriptions()->first();
 | |
|     }
 | |
| }
 |