1. Wykorzystywanie Doctrine'owskiej encji w formularzu jest o tyle złe, że nagle jedna klasa zaczyna być odpowiedzialna za wiele różnego rodzaju zadań - jedno to obsługa modelu bazodanowego, drugie to obsługa jakiegoś konkretnego formularza.
2. W przypadku encji dodatkowym niebezpieczeńtwem jest to, że nawet nieprawidłowy (z punktu widzenia waildacji) formularz zmienia właściwości encji, jeżeli gdzieś dalej będziesz przypadkiem ją aktualizować (w jakimś fragemncie niezwiązanym z samym formularzem) możesz się nieciekawie zaskoczyć.
3. Nie jesteś zmuszony korzystać z komponentu formularzy. To co potrzebujesz osiągnąć można zrobić przy jego pomocy (wspomniane
form events). Jeśli jednak nie czusz się w jego ramach "na siłach" możesz sobie ręcznie wykonać obsługę takiego formularza posiłkując się np. komponentem od samej walidacji.
4. Pamiętaj, że "szybciej i łatwiej" bardzo często nie oznacza "najmniejszą ilością kodu". Utworzenie dodatkowej klasy, stricte pod reprezentację modelu formularza oraz kilka linijek na zmapowanie danych przy poprawnym wypełnieniu ów formularza to 5 minut roboty.
5. To, że klasa reprezentująca dane z formularza i klasa encji ma trochę pokrywających się pól nie sprawia, że są tożsame.
5.1. Klasa od formularza co najwyżej zawiera zapewne mały podzbiór pol encji. Na pewno nie dajesz w niej właściwości typu ID, zapewne nie wszystkie relacje można zmieniać w tym formularzu itp.
5.2. Obiekt danych z formularza nie jest w żaden sposób powiązany z EntityManagerem Doctrine'a. Nie jest przedmiotem cyklu jego pracy - tutaj patrz na punkt #2.
6. Jesteś pewien, że
data transformers podpiąłeś w odpowiednim miejscu?
http://symfony.com/doc/current/form/data_t...ew-transformers7. Pomysł zaproponowany przez @Pilsener by wykorzystać JS również nie jest najgorszy. Przy czym niezgodziłbym się ze stwierdzeniem, że z DataTransformers nie możesz korzystać nawet przy jednorazowym użyciu.