Dynamic Choice from Dynamic Multi Choice
I have a Multi Choice Dynamic field with which multiple choices can be selected (obviously). I then want to have a Dynamic Choice field, based on that same table but that includes ONLY those choices ('records') from the DMC field.
The DC can be built by using a 'contains(…)' in the Where clause, but this is text only and although it can be made to work with Ids, it's a bit cumbersome.
I have the list of Ids that I want, but how is the best way to select from a table, only those records with the known Ids (i.e. from the original DMC field)?
Also, how can one 'copy' a D(M)C field?
So if such a field exists (populated as desired), how can exactly the same field be used in another location? Obviously the same selection criteria could be used to build the second field, but if that is changed in either, it has to be replicated to the other field.
Is there a way to simply replicate such a field so only one actual calculation is done, from which the 2 fields are created?
9 replies
-
The first part of your question can be solved with something like this in the formula part of the dChoice field:
let prevDMC := numbers(dMC); (select Table1)[(var a := this; count(prevDMC[= a])) > 0]
You would of course change:
dMC to match your dynamic multi choice field name
Table1 to match the table name from the dMultiChoice.
The thing to be aware is that under Show As, Radio buttons are not automatically updated as the dMultiChoice field is modified. Combobox and Switch are. Weird bug that Ninox is aware of.
The 2nd part I'm not sure what you are asking.
So if such a field exists (populated as desired), how can exactly the same field be used in another location?
What is another location? Another table? Another record?
-
That first part of the answer looks interesting, not a construct I have come across before. I'll need to have a play around with that.
Regarding the second part of my question:-
If I have a table and use that to build a D(M)C field in a particular table, but then want another 'choice' field (so different name) with the same options either elsewhere in that same table (e.g. a different tab) or even in another table, is it possible to create a duplicate? A regular field's data can be duplicated by using a Formula field, but doing that for a D(M)C field just gets you the IDs of what has been chosen (or text if you want that), but I was looking for a way to end up with another D(M)C field with the same list of options as the first D(M)C field.
I can create the same 'construction' formula to get the same options, but if for any reason those change, I have to update each one of these D(M)C fields to keep them the same.
It did occur to me that if I could use a global function to create the choices list, then simply use that same function for each of these D(M)C fields that need to be the same, then that would provide the 'single source' for each of these fields. But I'm not sure if that would be possible as I've not had a chance to check so need to do that. However, is there any way to achieve this?
-
UKenGB said:
That first part of the answer looks interesting, not a construct I have come across before. I'll need to have a play around with that.You can get more background from this post.
-
Playing around it looks like they have made dynamic multichoice fields a bit easier to update by code. If you create a formula field and put the following code in:
raw(dMultiChoice1)
You will see a hex decimal number that changes as you change the selection in your dMultiChoice field.
I then decided to try in the Trigger after Update of dMultiChoice1:
let xraw := raw(dMultiChoice1); dMultiChoice2 := xraw
Of course with the background that dMultiChoice2 points to the exact same table as dMultiChoice1. I guess you don't have to point it at the same table but then the selections would be unrelated.
Anyways, low and behold it works. As I change dMultiChoice1, dMultiChoice2 is updated. Hey, even as radio buttons now. I'm now running MacOS v3.6.8 and it looks like they have fixed the radio button issue.
Then I tried out modifying a dMC in another table with:
let xraw := raw(dMultiChoice1); dMultiChoice2 := xraw; Table1.(dMC1 := xraw)
And that works too. I'm using an existing reference field (called Table1). If there is no relationship between the tables then you will need to do a select.
-
Fred said:
this postThat was fascinating, but I'll need to go over it a few times. For the last few months I've been using what I had previously created with Ninox and missed some new changes.
-
I've figured out how to 'duplicate' the options list from one DMC to another.
Create the selection criteria in a (hidden) formula field. Then enter that formula field as the 'Dynamic values' of the DMC field. This works and the same list of options can then be used multiple times, but only calculated and built once. Also the code only exists in one place, making maintenance easier.
Content aside
- 2 yrs agoLast active
- 9Replies
- 522Views
-
3
Following