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

Add Support for Predefined Enum Collections in DataObject Initialization #776

Merged
merged 1 commit into from
Jun 13, 2024

Conversation

yob-yob
Copy link

@yob-yob yob-yob commented May 13, 2024

Hey there,

I encountered an issue while trying to create a DataObject that already incorporates an enum. Specifically, I found myself in situations where I needed to initialize my DataObject with a predefined enum collection.

For instance, let's consider an enum collection named SourceOfFunds:

[
  SourceOfFunds::Employment,
  1, // SourceOfFunds::Business,
  2, // SourceOfFunds::FamilySupport
]

To address this need, I've implemented changes in this pull request to support such scenarios. This enhancement will facilitate smoother integration of predefined enum collections into DataObject.

Looking forward to your feedback!

P.S. If I might be wrong on implementing this feature, could you please be able to provide me some information? Thank you.

@yob-yob yob-yob changed the title it can create data when enum is already casted Add Support for Predefined Enum Collections in DataObject Initialization May 13, 2024
@rubenvanassche
Copy link
Member

Thanks!

@rubenvanassche rubenvanassche merged commit c5bcc48 into spatie:main Jun 13, 2024
1 check passed
@rubenvanassche
Copy link
Member

I've reverted this since this is already working:

it('can create enums array with existing and non existing enums', function () {
    $dataClass = new class extends Data {
        /** @var array<int, \Spatie\LaravelData\Tests\Fakes\Enums\DummyBackedEnum>  */
        public array $prop;
    };

    $data = $dataClass::from([
        'prop' => ['foo', DummyBackedEnum::BOO],
    ]);

    dd($data);
});

Outout:

Spatie\LaravelData\Data@anonymous {#1940
  #_additional: []
  #_dataContext: null
  +prop: array:2 [
    0 => Spatie\LaravelData\Tests\Fakes\Enums\DummyBackedEnum {#1021
      +name: "FOO"
      +value: "foo"
    }
    1 => Spatie\LaravelData\Tests\Fakes\Enums\DummyBackedEnum {#1470
      +name: "BOO"
      +value: "boo"
    }
  ]
}

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants