This website uses cookies. By clicking Accept, you consent to the use of cookies. Click Here to learn more about how we use cookies.
Turn on suggestions
Auto-suggest helps you quickly narrow down your search results by suggesting possible matches as you type.
- Revenera Community
- :
- InstallShield
- :
- InstallShield Forum
- :
- Disabling checkboxes in suite
Subscribe
- Mark Topic as New
- Mark Topic as Read
- Float this Topic for Current User
- Subscribe
- Mute
- Printer Friendly Page
‎Sep 26, 2011
11:17 AM
Disabling checkboxes in suite
I have created a Suite that contains a 64 bit setup and a 32 bit setup.
Things I would like to be able to do:
1. Allow only 1 checkbox to be checked.
2. If 32 bit, not allow 64 bit checkbox to be checked.
Clues on how to do this?
:confused:
Things I would like to be able to do:
1. Allow only 1 checkbox to be checked.
2. If 32 bit, not allow 64 bit checkbox to be checked.
Clues on how to do this?
:confused:
(7) Replies
‎Sep 26, 2011
01:15 PM
I'm not sure exactly what you want here; it sounds like you're describing a use case for radio buttons instead of checkboxes. If you need to allow one, the other, or none, consider three radio buttons. However setting the check boxes' Property setting to different values (MyProp==value1 and MyProp==value2 respectively) may yield the mutually exclusive behavior you desire.
As for conditionally disabling one of them, see the Enable setting of your check box or radio button. I'll have to get back with more information on what you can use here to implement the 32-bit vs 64-bit OS condition.
As for conditionally disabling one of them, see the Enable setting of your check box or radio button. I'll have to get back with more information on what you can use here to implement the 32-bit vs 64-bit OS condition.
‎Sep 26, 2011
01:20 PM
I understand the above and can do that in a Basic MSI, but this is in a Suite. In the Custom Setup dialog it displays my two Features.
1. Feature1 64 bit
2. Feature2 32 bit
I want to be able to disable #1 if #2 is checked, etc. They should be able to install only one or the other, not both.
1. Feature1 64 bit
2. Feature2 32 bit
I want to be able to disable #1 if #2 is checked, etc. They should be able to install only one or the other, not both.
‎Sep 27, 2011
10:58 AM
Oh, it sounds like I misunderstood. Are you trying to implement this in the feature tree (InstallationFeatures page)? While there is something you can put in the XML to make a feature unselectable, it currently it's an all or nothing option - you can't specify a condition for this.
I think I would suggest an alternative approach, along the lines of an InstallationType dialog where you have multiple buttons that branch your installation. For example you could have an "Install the 32-bit version" and an "Install the 64-bit version" command link button, and disable the latter on a 32-bit system. Would this suit your needs? If so I'll try to work out how we can make that possible.
I think I would suggest an alternative approach, along the lines of an InstallationType dialog where you have multiple buttons that branch your installation. For example you could have an "Install the 32-bit version" and an "Install the 64-bit version" command link button, and disable the latter on a 32-bit system. Would this suit your needs? If so I'll try to work out how we can make that possible.
‎Oct 13, 2011
04:56 PM
I was looking to implement this for an upcoming release, but it turns out we actually do have something in place you can use, so long as you don't have to tie more than one feature to a button. So for what I understand of what you want to do, create two command link buttons. Set the text and note appropriately. Then specify a Property setting on each button along the lines of:
FEATURE[feature name].actionState==install
where feature name is replaced with each feature's name. Then when the button is clicked, the associated feature will be set for installation.
If you'd rather put these on checkboxes and have them enable and disable like you mentioned before, specify the Property setting as above, and also specify an Enabled setting similarly:
{Binding FEATURE[other feature name].actionState==}
where other feature name is the name of the feature that should cause this feature's checkbox to be disabled. Watch out though; with this condition, if both features get enabled, neither can be disabled.
FEATURE[feature name].actionState==install
where feature name is replaced with each feature's name. Then when the button is clicked, the associated feature will be set for installation.
If you'd rather put these on checkboxes and have them enable and disable like you mentioned before, specify the Property setting as above, and also specify an Enabled setting similarly:
{Binding FEATURE[other feature name].actionState==}
where other feature name is the name of the feature that should cause this feature's checkbox to be disabled. Watch out though; with this condition, if both features get enabled, neither can be disabled.
‎Jan 31, 2012
02:12 PM
What is the difference between doing
FEATURE[feature name].actionState==install
for Property versus doing
{SetProperty FEATURE[feature name].actionState=install}
for Action?
It is a bit annoying that the syntax is not consistent.
I REALLY would have expected that there would be more documentation available about Suites from Flexera by now. I don't think that anyone can argue that those of us that have used the Suite feature have struggled with A LOT of trial and error! Yes, yes, I know... standard answer is read the blogs. And when that does not contain the info you need?????
FEATURE[feature name].actionState==install
for Property versus doing
{SetProperty FEATURE[feature name].actionState=install}
for Action?
It is a bit annoying that the syntax is not consistent.
I REALLY would have expected that there would be more documentation available about Suites from Flexera by now. I don't think that anyone can argue that those of us that have used the Suite feature have struggled with A LOT of trial and error! Yes, yes, I know... standard answer is read the blogs. And when that does not contain the info you need?????
‎Feb 01, 2012
11:17 AM
Oh, whoops, here's the question I thought was asked elsewhere. Got my email notifications miswired. 🙂
{Binding P==V} functions differently on, say, a check box. It shows the check box as checked if the property P has the value V. Clicking the check box when checked will reset the property to empty; when unchecked, it will set the property to V. On a pushbutton, it will merely set P to V whenever it is clicked.
{SetProperty P=V} as an action works just like the pushbutton case, although I'm unclear off the top of my head if it also fires when the radio button is clicked to clear the check box. Note that, particularly in a check box or radio box, you can have both; {Binding P==V} and {SetProperty Q=R}, so two properties can get set in one click.
{Binding P==V} functions differently on, say, a check box. It shows the check box as checked if the property P has the value V. Clicking the check box when checked will reset the property to empty; when unchecked, it will set the property to V. On a pushbutton, it will merely set P to V whenever it is clicked.
{SetProperty P=V} as an action works just like the pushbutton case, although I'm unclear off the top of my head if it also fires when the radio button is clicked to clear the check box. Note that, particularly in a check box or radio box, you can have both; {Binding P==V} and {SetProperty Q=R}, so two properties can get set in one click.