×
This forum has been locked. Please submit new Feature Requests on GitHub: github.com/Jensen-Technologies/component-creator-issues/issues
Handling of foreign key fields
Jonas Fagnastøl Henriksen
New Member
Posts: 15
10 anos 3 meses atrás #254
por Jonas Fagnastøl Henriksen
Handling of foreign key fields foi criado por Jonas Fagnastøl Henriksen
Hi,
I have been using the component creator extensively for a long time, and I'm generally very pleased with it, but:
Recently the handling of foreign key fields was changed, so that when the field is loaded in the model, and returning $this->item->fkey_field in the view actually gives the text-title from the foreign key table, instead of the foreign key id. While I understand this can be useful in some cases, it is very bad anytime you need to get more than just the title-field from the foreign key table.
In my opinion the best solution would be to return the whole foreign-key object (all fields in the foreign key table) as the fkey_field. This way the developer has access to everything in the foreign key object, and has the possibility to chose which fields he want to use in the template overrides. When displaying like a dropdown-list, or on the list view in the component, the display-field can still be used as an alias.
Any other views on this her at the forum?
Jonas
I have been using the component creator extensively for a long time, and I'm generally very pleased with it, but:
Recently the handling of foreign key fields was changed, so that when the field is loaded in the model, and returning $this->item->fkey_field in the view actually gives the text-title from the foreign key table, instead of the foreign key id. While I understand this can be useful in some cases, it is very bad anytime you need to get more than just the title-field from the foreign key table.
In my opinion the best solution would be to return the whole foreign-key object (all fields in the foreign key table) as the fkey_field. This way the developer has access to everything in the foreign key object, and has the possibility to chose which fields he want to use in the template overrides. When displaying like a dropdown-list, or on the list view in the component, the display-field can still be used as an alias.
Any other views on this her at the forum?
Jonas
Os seguintes usuário(s) disseram Obrigado: Pete, Andres Maeso
Por favor Acessar ou Registrar para participar da conversa.
Francisco
New Member
Posts: 2
10 anos 2 meses atrás #297
por Francisco
Respondido por Francisco no tópico Handling of foreign key fields
Im having the same issue. I have to comment the code that loads the Value of the key field instead of the ID, which is much better for me at least.
As i do extra stuff with that ID afterwards. Maybe an opt-in to select what we want to get?
As i do extra stuff with that ID afterwards. Maybe an opt-in to select what we want to get?
Por favor Acessar ou Registrar para participar da conversa.
Jonas Fagnastøl Henriksen
New Member
Posts: 15
10 anos 2 meses atrás #300
por Jonas Fagnastøl Henriksen
Respondido por Jonas Fagnastøl Henriksen no tópico Handling of foreign key fields
Thanks, Andrés, this is probably my biggest issue with the component-creator now, which I otherwise think is great! Bug-reports are handled very quickly and nicely, I've been reporting quite a few lately, and VIctor seems to be fixing them more or less as soon as they arrive. This issue is a little different, though, so I thought I'd post it here first.
Por favor Acessar ou Registrar para participar da conversa.
Walt Sorensen
Senior Member
Posts: 54
9 anos 6 meses atrás #764
por Walt Sorensen
Respondido por Walt Sorensen no tópico Handling of foreign key fields
I too would like to see an option for the whole foreign key object to be available so we can have access to all the fields. But I think this should be an option when foreign key is selected, if a developer doesn't want or doesn't need the whole object, there is no reason to load it.
Por favor Acessar ou Registrar para participar da conversa.
Tempo para a criação da página:0.050 segundos