116 lines
4.1 KiB
PHP
Raw Normal View History

2023-08-24 16:14:09 +02:00
<?php
2023-12-07 19:06:32 +01:00
namespace App\Livewire\Subscription;
2023-08-24 16:14:09 +02:00
use Livewire\Component;
use Stripe\Stripe;
use Stripe\Checkout\Session;
class PricingPlans extends Component
{
2023-09-12 17:24:46 +02:00
public bool $isTrial = false;
public function mount()
{
$this->isTrial = !data_get(currentTeam(), 'subscription.stripe_trial_already_ended');
2023-11-29 16:34:31 +01:00
if (config('constants.limits.trial_period') == 0) {
$this->isTrial = false;
}
2023-09-12 17:24:46 +02:00
}
2023-08-24 16:14:09 +02:00
public function subscribeStripe($type)
{
2023-09-12 11:19:21 +02:00
$team = currentTeam();
2023-08-24 16:14:09 +02:00
Stripe::setApiKey(config('subscription.stripe_api_key'));
switch ($type) {
case 'basic-monthly':
$priceId = config('subscription.stripe_price_id_basic_monthly');
break;
case 'basic-yearly':
$priceId = config('subscription.stripe_price_id_basic_yearly');
break;
case 'pro-monthly':
$priceId = config('subscription.stripe_price_id_pro_monthly');
break;
case 'pro-yearly':
$priceId = config('subscription.stripe_price_id_pro_yearly');
break;
case 'ultimate-monthly':
$priceId = config('subscription.stripe_price_id_ultimate_monthly');
break;
2023-08-24 16:14:09 +02:00
case 'ultimate-yearly':
$priceId = config('subscription.stripe_price_id_ultimate_yearly');
break;
2024-04-12 15:48:56 +02:00
case 'dynamic-monthly':
$priceId = config('subscription.stripe_price_id_dynamic_monthly');
break;
case 'dynamic-yearly':
$priceId = config('subscription.stripe_price_id_dynamic_yearly');
break;
2023-08-24 16:14:09 +02:00
default:
$priceId = config('subscription.stripe_price_id_basic_monthly');
break;
}
if (!$priceId) {
2023-12-07 19:06:32 +01:00
$this->dispatch('error', 'Price ID not found! Please contact the administrator.');
2023-08-24 16:14:09 +02:00
return;
}
$payload = [
'allow_promotion_codes' => true,
2023-09-14 20:42:12 +02:00
'billing_address_collection' => 'required',
2023-08-24 16:14:09 +02:00
'client_reference_id' => auth()->user()->id . ':' . currentTeam()->id,
'line_items' => [[
'price' => $priceId,
'quantity' => 1,
]],
2023-09-05 10:57:49 +02:00
'tax_id_collection' => [
'enabled' => true,
],
2023-09-05 10:49:17 +02:00
'automatic_tax' => [
2023-08-24 16:14:09 +02:00
'enabled' => true,
],
2023-09-12 11:19:21 +02:00
2023-08-24 16:14:09 +02:00
'mode' => 'subscription',
2023-08-30 18:23:55 +02:00
'success_url' => route('dashboard', ['success' => true]),
'cancel_url' => route('subscription.index', ['cancelled' => true]),
2023-08-24 16:14:09 +02:00
];
if (str($type)->contains('ultimate')) {
$payload['line_items'][0]['adjustable_quantity'] = [
'enabled' => true,
'minimum' => 10,
2023-09-12 11:19:21 +02:00
];
$payload['line_items'][0]['quantity'] = 10;
2023-11-29 16:34:31 +01:00
}
2024-04-12 15:48:56 +02:00
if (str($type)->contains('dynamic')) {
$payload['line_items'][0]['adjustable_quantity'] = [
'enabled' => true,
'minimum' => 2,
];
$payload['line_items'][0]['quantity'] = 2;
}
if (!data_get($team, 'subscription.stripe_trial_already_ended')) {
if (config('constants.limits.trial_period') > 0) {
$payload['subscription_data'] = [
'trial_period_days' => config('constants.limits.trial_period'),
'trial_settings' => [
'end_behavior' => [
'missing_payment_method' => 'cancel',
]
],
];
}
2023-09-12 11:19:21 +02:00
$payload['payment_method_collection'] = 'if_required';
}
2023-08-24 16:14:09 +02:00
$customer = currentTeam()->subscription?->stripe_customer_id ?? null;
if ($customer) {
$payload['customer'] = $customer;
2023-08-24 17:41:11 +02:00
$payload['customer_update'] = [
'name' => 'auto'
];
2023-08-24 16:14:09 +02:00
} else {
$payload['customer_email'] = auth()->user()->email;
}
$session = Session::create($payload);
return redirect($session->url, 303);
}
}