How to display string in property field instead of integer from database?

248 views Asked by At

Database stores gender field as smallint. Easyadmin render fields based on entity properties. I won't simply put a string eg. "Male" instead of 1.

I tried to override AdminController and override methods like createEditForm() and createEntityFormBuilder() but ended up with "Call to a member function handleRequest() on null"

easy_admin:
  entities:
    User:
      controller: App\Controller\CustomAdminController
      class: App\Entity\User
      form:
        title: "Details"
        fields:
- { property: 'userProfile.gender', type: 'text', label: 'Gender', 
type_options:{ disabled: true, required: false} }
2

There are 2 answers

1
Arleigh Hix On

You could try changing your getGender() and setGender() methods to handle the conversion in your entity.

public function getGender(): ?string
{
  if (0 === $this->gender){
    return 'Female';
  }
  if (1 === $this->gender){
    return 'Male';
  }
  if (2 === $this->gender){
    return 'Other';
  }
}
public function setGender(string $gender): self
{
  if ('female'=== strtolower($gender)){ 
    $this->gender = 0;
  } else if ('male'=== strtolower($gender)){ 
    $this->gender = 1;
  } else { 
    $this->gender = 2;
  }
  return $this;
}
0
Dave On

I switched to SonataAdmin Bundle which provides an easy way to do it right.