Does optionsPair support notation "table.field" or just "field"?
Does optionsPair support notation "table.field" or just "field"?
Looking to use field type "datatable", and have optionsPair with only field name working fine. When trying to address with table prefix it seems not to be working.
optionsPair: { value: 'docID' } is OK
optionsPair: { value: 'persons.ID' } is not OK
KR,
Bjørn Hasselberg
PS, managed to create an empty discussion with question "Hello", by misstake, but seems I can not remove it myself.
This question has accepted answers - jump to:
This discussion has been closed.
Answers
Hi Bjørn,
Empty conversation gone now .
What does the JSON you are using to populate the options look like. Is
persons
an object? At the moment theoptionsPair
option doesn't do nesting support, so it would be looking for something likeobj['persons.ID]
there, rather thanobj.persons.ID
.Allan
The nested editing of persons works fine, it is only the correlation between the original DT table and the first level editor that is a problem.
The Json for where persons is on the top level looks like:
Server side php:
Realising this was a bad example as persons.ID is not in the json... stupid example
Have another with companies ... where the ID is included.
Tried now to see if including persons.ID would resolve anything, but didn't.
Hi Allan,
Many thanks for your reply yesterday (and for removing the empty question ).
After some more investigations and realising that I have issues with options from the first layer of editor to the second, I will simplify the ajax response to one dimensional and not move on with nested editing at this point.
That resolves the issue with optionsPair for me as of now.
(It seems the options from ajax/JSON response in field type "datatable" does not appear at nested editor, data is fine, same ajax works with options in a "basic" datatable/editor setup, but this might be my usage of course)
KR,
Bjørn Hasselberg
Hi Bjørn,
Thanks for your extra details on this - I'm afraid I don't have an immediate answer. I know you said you've moved on, but if you come back to this, let me know and if possible send me an example and I'll look into it.
Thanks,
Allan
Hi Allan,
The option for nested editing part I can gladly give you input on, with code example of what works and what doesn't for me. I can also give you URLs for ajax functionality for GET in our testsystem so you can see data/option that works for a normal setup, but not in a nested version.
OK if I send it over in a PM?
KR,
Bjørn H
Hi Bjørn,
That would be ideal - yes please. If you click my user name and then the "Send message" button, that will come straight to me.
Allan
It looks like the following line on 5894 of dataTables.editor.js does not support nesting:
return val.indexOf(data[valueProp]) !== -1;
valueProp can only be somethuing like 'id', not 'company.id'
@ideaxme - You are absolutely correct. Is that a problem for how you are using this? I can add that ability.
Allan
Yes, that would be great; thank you Allan!
That's it committed in and it will be in Editor 2.0.5, which I don't expect to be too far away!
Regards,
Allan
Hi @allan , thank you for making that change in 2.0.5. Now the "set" in theDatatables as input control selects the currently selected item(s). However, I'm afraid the "get" on that control is not working for "table.field" notation in the optionsPair. Line 5890 of datatables.editor.js says
The .pluck() does not support "table.field" notation. However, I was able to come up with a hacky patch by copying the fetchData function from elsewhere in the jquery.datatables.js and using it on line 7172 of jquery.datatables.js
You are right - the
pluck
option doesn't do dotted object notation at the moment. I do have an enhancement bug to add that ability, but I'm afraid it isn't implemented yet.Allan
If it is possible to upVote Pluck for table.field notation, I would do so. It limits the usage quite a bit, only dealing with one dimensional table sets.
/björn h
Thanks for the upvote . I've marked it has higher priority.
Allan
Seems like can work around it by loading select options in controller instead of getting them by ajax.
->options( Options::inst()
->table( 'order_header' )
->value( 'id' )
->label( 'sales_order_number' ) )
->validator( Validate::dbValues() ),
Is the Pluck enhancement far away? (table.field notation)
It will likely come in DataTables 2, but that is a "it will ship when it is ready" type of release rather than a planned data.
For the moment, for nested data you can call
pluck()
multiple times - e.g.:Allan
OK, I thought this was to get the optionsPair working for that same syntax 'table.field', waiting for that in nested DataTables
KR,
Bjørn Hasselberg
Hi Bjørn,
Ah! Sorry - I missed the context that this is for the
datatable
field type. Yes, that does bump it up the priority list. I'll get back to you on this oneAllan
Hi - little update on this. I've committed the change and I'm going to do a DataTables 1.12 release which will include this feature. I don't expect that release to be too far away.
Allan
Many thanks,
On a side note, the issue regarding options and file information that did not populate in nested datatable fields, is that on its way as well?
As you provided me with good workarounds, this is not a problem as such for me.
KR,
Björn H
Hi Björn,
Apologies, you are going to have to remind me about that one. I found this discussion but can't recall what the outcome was!
Allan
Hi Allan,
I will mail the latest mail I have on that subject, I think it contains the history.
KR;
Björn H