Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Refactor: Default form #7616

Merged
merged 26 commits into from
Dec 4, 2024
Merged
Show file tree
Hide file tree
Changes from 25 commits
Commits
Show all changes
26 commits
Select commit Hold shift + click to select a range
639b1aa
Initial commit
alaca Nov 8, 2024
241a8d5
Merge branch 'refs/heads/epic/campaigns' into refactor/default-form-G…
alaca Nov 8, 2024
f292027
refactor: form title
alaca Nov 8, 2024
bd72636
refactor: move merge campaigns logic to RegisterCampaignRoutes.php
alaca Nov 8, 2024
9a8c9f2
refactor: remove unused code
alaca Nov 8, 2024
27d8338
fix: table name
alaca Nov 8, 2024
a360628
Merge branch 'epic/campaigns' into refactor/default-form-GIVE-1949
kjohnson Nov 8, 2024
f311f3f
Merge branch 'epic/campaigns' into refactor/default-form-GIVE-1949
kjohnson Nov 8, 2024
505302a
Update src/Campaigns/Migrations/Tables/CreateCampaignFormsTable.php
kjohnson Nov 11, 2024
d1e1772
Merge branch 'refs/heads/epic/campaigns' into refactor/default-form-G…
alaca Nov 19, 2024
6cca08f
refactor: update migration test
alaca Nov 19, 2024
f86b591
refactor: add form_id
alaca Nov 20, 2024
3af63d5
refactor: prop name
alaca Nov 20, 2024
86fba72
refactor: table column
alaca Nov 20, 2024
e7ecda4
Merge branch 'epic/campaigns' into refactor/default-form-GIVE-1949
kjohnson Nov 25, 2024
4541dc0
chore: Manually add missing MergeCampaigns route
kjohnson Nov 25, 2024
cc759b0
fix: Update column name ambiguity
kjohnson Nov 25, 2024
1f3ce74
fix: Remove alias from campaigns forms join
kjohnson Nov 25, 2024
3047919
refactor: use maybe_add_column function
alaca Nov 27, 2024
688a69d
fix: query
alaca Nov 27, 2024
4909b2b
refactor: remove count test
alaca Nov 27, 2024
2a94de7
refactor: form id
alaca Nov 27, 2024
37c12fe
fix: test
alaca Nov 27, 2024
72dc0f9
refactor: update defaultFormId prop
alaca Nov 27, 2024
e26cb20
Merge branch 'epic/campaigns' into refactor/default-form-GIVE-1949
kjohnson Dec 3, 2024
33cbcb1
refactor: remove unused code
alaca Dec 4, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions src/Campaigns/Actions/ConvertQueryDataToCampaign.php
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ public function __invoke(object $queryObject): Campaign
{
return new Campaign([
'id' => (int)$queryObject->id,
'defaultFormId' => (int)$queryObject->defaultFormId,
'type' => new CampaignType($queryObject->type),
'enableCampaignPage' => (bool)$queryObject->enableCampaignPage,
'title' => $queryObject->title,
Expand Down
4 changes: 1 addition & 3 deletions src/Campaigns/Actions/LoadCampaignDetailsAssets.php
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,6 @@

use Give\Campaigns\Models\Campaign;
use Give\Framework\Support\Facades\Scripts\ScriptAsset;
use Give\Helpers\Form\Utils;

/**
* @unreleased
Expand Down Expand Up @@ -34,13 +33,12 @@ public function __invoke()
);

$defaultForm = $campaign->defaultForm();
$defaultFormTitle = Utils::isV3Form($defaultForm->id) ? $defaultForm->settings->formTitle : $defaultForm->title;
wp_localize_script($handleName, 'GiveCampaignDetails',
[
'adminUrl' => admin_url(),
'currency' => give_get_currency(),
'isRecurringEnabled' => defined('GIVE_RECURRING_VERSION') ? GIVE_RECURRING_VERSION : null,
'defaultForm' => $defaultFormTitle,
'defaultForm' => $defaultForm->title,
]
);

Expand Down
18 changes: 16 additions & 2 deletions src/Campaigns/Controllers/CampaignRequestController.php
Original file line number Diff line number Diff line change
Expand Up @@ -130,8 +130,7 @@ public function updateCampaign(WP_REST_Request $request)
$campaign->goalType = new CampaignGoalType($value);
break;
case 'defaultFormId':
give(CampaignRepository::class)->updateDefaultCampaignForm($campaign,
$request->get_param('defaultFormId'));
give(CampaignRepository::class)->updateDefaultCampaignForm($campaign, $request->get_param('defaultFormId'));
break;
default:
if ($campaign->hasProperty($key)) {
Expand All @@ -147,6 +146,21 @@ public function updateCampaign(WP_REST_Request $request)
return new WP_REST_Response($campaign->toArray());
}

/**
* @unreleased
*
* @throws Exception
*/
public function mergeCampaigns(WP_REST_Request $request): WP_REST_Response
{
$destinationCampaign = Campaign::find($request->get_param('id'));
$campaignsToMerge = Campaign::query()->whereIn('id', $request->get_param('campaignsToMergeIds'))->getAll();

$campaignsMerged = $destinationCampaign->merge(...$campaignsToMerge);

return new WP_REST_Response($campaignsMerged);
}
alaca marked this conversation as resolved.
Show resolved Hide resolved


/**
* @unreleased
Expand Down
1 change: 1 addition & 0 deletions src/Campaigns/Factories/CampaignFactory.php
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ public function definition(): array
return [
'type' => CampaignType::CORE(),
'enableCampaignPage' => true,
'defaultFormId' => 1,
'title' => __('GiveWP Campaign', 'give'),
'shortDescription' => __('Campaign short description', 'give'),
'longDescription' => __('Campaign long description', 'give'),
Expand Down
10 changes: 5 additions & 5 deletions src/Campaigns/Migrations/MigrateFormsToCampaignForms.php
Original file line number Diff line number Diff line change
Expand Up @@ -116,6 +116,7 @@ public function createCampaignForForm($formData): void

DB::table('give_campaigns')
->insert([
'form_id' => $formId,
'campaign_type' => 'core',
'campaign_title' => $formTitle,
'status' => $this->mapFormToCampaignStatus($formStatus),
Expand All @@ -134,27 +135,26 @@ public function createCampaignForForm($formData): void

$campaignId = DB::last_insert_id();

$this->addCampaignFormRelationship($formId, $campaignId, true);
$this->addCampaignFormRelationship($formId, $campaignId);
}

/**
* @param $data
*/
protected function addUpgradedFormToCampaign($data): void
{
$this->addCampaignFormRelationship($data->migratedFormId, $data->campaignId, false);
$this->addCampaignFormRelationship($data->migratedFormId, $data->campaignId);
}

/**
* @unreleased
*/
protected function addCampaignFormRelationship($formId, $campaignId, $isDefault)
protected function addCampaignFormRelationship($formId, $campaignId)
{
DB::table('give_campaign_forms')
->insert([
'form_id' => $formId,
'campaign_id' => $campaignId,
'is_default' => $isDefault,
'campaign_id' => $campaignId
]);
}

Expand Down
18 changes: 5 additions & 13 deletions src/Campaigns/Migrations/RevenueTable/AddCampaignID.php
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

namespace Give\Campaigns\Migrations\RevenueTable;

use Give\Framework\Database\Exceptions\DatabaseQueryException;
use Give\Framework\Database\DB;
use Give\Framework\Migrations\Contracts\Migration;
use Give\Framework\Migrations\Exceptions\DatabaseMigrationException;

Expand Down Expand Up @@ -41,19 +41,11 @@ public static function timestamp(): string
*/
public function run()
{
global $wpdb;
$table = DB::prefix('give_revenue');
$columnAdded = maybe_add_column($table, 'campaign_id', "ALTER TABLE $table ADD COLUMN campaign_id INT UNSIGNED NULL");

$table = $wpdb->give_revenue;

$sql = "
ALTER TABLE $table
ADD COLUMN campaign_id INT UNSIGNED NOT NULL DEFAULT '0'
";

try {
$wpdb->query($sql);
} catch (DatabaseQueryException $exception) {
throw new DatabaseMigrationException("An error occurred while updating the $table table", 0, $exception);
if ( ! $columnAdded) {
throw new DatabaseMigrationException("An error occurred while updating the $table table");
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,6 @@ public function run(): void
$sql = "CREATE TABLE $table (
campaign_id INT UNSIGNED NOT NULL,
form_id INT UNSIGNED NOT NULL,
is_default BOOLEAN NOT NULL DEFAULT 0,
KEY form_id (form_id),
KEY campaign_id (campaign_id),
PRIMARY KEY (campaign_id, form_id)
Expand Down
40 changes: 10 additions & 30 deletions src/Campaigns/Models/Campaign.php
Original file line number Diff line number Diff line change
Expand Up @@ -12,8 +12,8 @@
use Give\Campaigns\ValueObjects\CampaignGoalType;
use Give\Campaigns\ValueObjects\CampaignStatus;
use Give\Campaigns\ValueObjects\CampaignType;
use Give\DonationForms\Models\DonationForm;
use Give\DonationForms\V2\Models\DonationForm as LegacyDonationForm;
use Give\DonationForms\V2\Models\DonationForm;
use Give\DonationForms\V2\Repositories\DonationFormsRepository;
use Give\Framework\Exceptions\Primitives\InvalidArgumentException;
use Give\Framework\Models\Contracts\ModelCrud;
use Give\Framework\Models\Contracts\ModelHasFactory;
Expand All @@ -25,6 +25,7 @@
* @unreleased
*
* @property int $id
* @property int $defaultFormId
* @property CampaignType $type
* @property bool $enableCampaignPage
* @property string $title
Expand All @@ -49,6 +50,7 @@ class Campaign extends Model implements ModelCrud, ModelHasFactory
*/
protected $properties = [
'id' => 'int',
'defaultFormId' => 'int',
'type' => CampaignType::class,
'enableCampaignPage' => ['bool', true],
'title' => 'string',
Expand All @@ -68,22 +70,10 @@ class Campaign extends Model implements ModelCrud, ModelHasFactory

/**
* @unreleased
*
* @return DonationForm | LegacyDonationForm
*/
public function defaultForm()
public function defaultForm(): ?DonationForm
{
$defaultForm = $this->forms()
->where('campaign_forms.is_default', true)
->get();

if (is_null($defaultForm)) {
$defaultForm = $this->legacyForms()
->where('campaign_forms.is_default', true)
->get();
}

return $defaultForm;
return give(DonationFormsRepository::class)->getById($this->defaultFormId);
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Now we're talkin! 🙌

}

/**
Expand All @@ -93,21 +83,11 @@ public function forms(): ModelQueryBuilder
{
return DonationForm::query()
->join(function (JoinQueryBuilder $builder) {
$builder->leftJoin('give_campaign_forms', 'campaign_forms')
->on('campaign_forms.form_id', 'forms.id');
})->where('campaign_forms.campaign_id', $this->id);
}

/**
* @unreleased
*/
public function legacyForms(): ModelQueryBuilder
{
return LegacyDonationForm::query()
->join(function (JoinQueryBuilder $builder) {
$builder->leftJoin('give_campaign_forms', 'campaign_forms')
$builder
->leftJoin('give_campaign_forms', 'campaign_forms')
->on('campaign_forms.form_id', 'id');
})->where('campaign_forms.campaign_id', $this->id);
})
->where('campaign_forms.campaign_id', $this->id);
}

/**
Expand Down
46 changes: 22 additions & 24 deletions src/Campaigns/Repositories/CampaignRepository.php
Original file line number Diff line number Diff line change
Expand Up @@ -44,13 +44,13 @@ public function getById(int $id)
/**
* @unreleased
*
* Get Campaign by Form ID
* Get Campaign by Form ID using a lookup table
*/
public function getByFormId(int $formId)
{
return $this->prepareQuery()
->leftJoin('give_campaign_forms', 'campaigns.id', 'forms.campaign_id', 'forms')
->where('forms.form_id', $formId)
->leftJoin('give_campaign_forms', 'campaigns.id', 'campaignForms.campaign_id', 'campaignForms')
->where('campaignForms.form_id', $formId)
->get();
}

Expand Down Expand Up @@ -170,24 +170,21 @@ public function addCampaignForm(Campaign $campaign, int $donationFormId, bool $i
DB::query('START TRANSACTION');

try {
// Make sure we'll have only one default form
if ($isDefault) {
DB::table('give_campaign_forms')
->where('campaign_id', $campaign->id)
DB::table('give_campaigns')
->where('id', $campaign->id)
->update([
'is_default' => false,
'form_id' => $donationFormId,
]);

$campaign->defaultFormId = $donationFormId;
}

$table = DB::prefix('give_campaign_forms');
DB::query(
DB::prepare("INSERT INTO {$table} (form_id, campaign_id, is_default ) VALUES (%d, %d, %d)",
[
$donationFormId,
$campaign->id,
$isDefault,
])
);
DB::table('give_campaign_forms')
->insert([
'form_id' => $donationFormId,
'campaign_id' => $campaign->id,
]);
} catch (Exception $exception) {
DB::query('ROLLBACK');

Expand All @@ -213,13 +210,13 @@ public function updateDefaultCampaignForm(Campaign $campaign, int $donationFormI
DB::query('START TRANSACTION');

try {
DB::query(
DB::prepare('UPDATE ' . DB::prefix('give_campaign_forms') . ' SET is_default = IF(form_id = %d, 1, 0) WHERE campaign_id = %d',
[
$donationFormId,
$campaign->id,
])
);
DB::table('give_campaigns')
->where('id', $campaign->id)
->update([
'form_id' => $donationFormId
]);

$campaign->defaultFormId = $donationFormId;
} catch (Exception $exception) {
DB::query('ROLLBACK');

Expand Down Expand Up @@ -295,7 +292,7 @@ public function mergeCampaigns(Campaign $destinationCampaign, Campaign ...$campa

// Migrate forms from campaigns to merge to the destination campaign
DB::query(
DB::prepare("UPDATE " . DB::prefix('give_campaign_forms') . " SET is_default = 0, campaign_id = %d WHERE campaign_id IN ($campaignsToMergeIdsString)",
DB::prepare("UPDATE " . DB::prefix('give_campaign_forms') . " SET campaign_id = %d WHERE campaign_id IN ($campaignsToMergeIdsString)",
[
$destinationCampaign->id,
])
Expand Down Expand Up @@ -345,6 +342,7 @@ public function prepareQuery(): ModelQueryBuilder
return $builder->from('give_campaigns', 'campaigns')
->select(
'id',
['campaigns.form_id', 'defaultFormId'], // Prefix the `form_id` column to avoid conflicts with the `give_campaign_forms` table.
['campaign_type', 'type'],
['enable_campaign_page', 'enableCampaignPage'],
['campaign_title', 'title'],
Expand Down
39 changes: 39 additions & 0 deletions src/Campaigns/Routes/RegisterCampaignRoutes.php
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,7 @@ public function __invoke()
$this->registerGetCampaign();
$this->registerUpdateCampaign();
$this->registerGetCampaigns();
$this->registerMergeCampaigns();
$this->registerCreateCampaign();
}

Expand Down Expand Up @@ -130,6 +131,44 @@ public function registerUpdateCampaign()
}


/**
* Update Campaign route
*
* @unreleased
*/
public function registerMergeCampaigns()
{
register_rest_route(
CampaignRoute::NAMESPACE,
CampaignRoute::CAMPAIGN . '/merge',
[
[
'methods' => WP_REST_Server::EDITABLE,
'callback' => function (WP_REST_Request $request) {
return $this->campaignRequestController->mergeCampaigns($request);
},
'permission_callback' => function () {
return current_user_can('manage_options');
},
],
'args' => [
'id' => [
'type' => 'integer',
'required' => true,
],
'campaignsToMergeIds' => [
'type' => 'array',
'required' => true,
'items' => [
'type' => 'integer',
],
],
],
]
);
}


/**
* Create Campaign route
*
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -80,9 +80,9 @@ public function testMigratedFormsAreDefault()
$migration = new MigrateFormsToCampaignForms();
$migration->run();

$relationship = DB::table('give_campaign_forms')->where('form_id', $form->id)->get();
$campaign = Campaign::findByFormId($form->id);

$this->assertEquals(1, $relationship->is_default);
$this->assertEquals($form->id, $campaign->defaultFormId);
}

/**
Expand All @@ -99,8 +99,8 @@ public function testUpgradedFormsAreNotDefault()
$migration = new MigrateFormsToCampaignForms();
$migration->run();

$relationship = DB::table('give_campaign_forms')->where('form_id', $form1->id)->get();
$campaign = Campaign::findByFormId($form2->id);

$this->assertEquals(0, $relationship->is_default);
$this->assertNotEquals($form1->id, $campaign->defaultFormId);
}
}
Loading
Loading