Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Config Flow: SelectSelectorConfig does not display the saved selected item inside a section #22590

Closed
3 of 4 tasks
EnzoD86 opened this issue Oct 29, 2024 · 6 comments
Closed
3 of 4 tasks

Comments

@EnzoD86
Copy link

EnzoD86 commented Oct 29, 2024

Checklist

  • I have updated to the latest available Home Assistant version.
  • I have cleared the cache of my browser.
  • I have tried a different browser to see if it is related to my browser.
  • I have tried reproducing the issue in safe mode to rule out problems with unsupported custom resources.

Describe the issue you are experiencing

Hi, I have a ConfigFlow with a section inside that contains a SelectSelectorConfig.
When I select an item and save the changes, when I reopen the configuration, the data that was selected is no longer selected (even though this was actually saved correctly).

Describe the behavior you expected

Steps to reproduce the issue

Here is an example of the saved data (including 2 BooleanSelectors).
As you can see when you reopen the config flow, the BooleanSelectors keep the selected values ​​while the SelectSelectorConfig does not.

image

What version of Home Assistant Core has the issue?

2024.10.4

What was the last working version of Home Assistant Core?

No response

In which browser are you experiencing the issue with?

No response

Which operating system are you using to run this browser?

No response

State of relevant entities

No response

Problem-relevant frontend configuration

No response

Javascript errors shown in your browser console/inspector

No response

Additional information

No response

@karwosts
Copy link
Contributor

Can you share the code of your config flow that's exhibiting this problem?

@EnzoD86
Copy link
Author

EnzoD86 commented Oct 30, 2024

Hi, thanks for the quick reply; I created a configuration flow that reproduces the problem, let me know if you need anything else.

config_flow.py

import logging
import voluptuous as vol
from homeassistant import config_entries
from homeassistant.core import callback
from homeassistant.data_entry_flow import section
from homeassistant.helpers.selector import (
    BooleanSelector,
    SelectSelector,
    SelectSelectorConfig,
    SelectSelectorMode,
    TextSelector,
    TextSelectorConfig,
    TextSelectorType
)
from homeassistant.const import CONF_NAME
from .const import DOMAIN

_LOGGER = logging.getLogger(__package__)

class ConfigFlowHandler(config_entries.ConfigFlow, domain=DOMAIN):
    async def async_step_user(self, user_input):
        if user_input is not None:
            return self.async_create_entry(title=user_input[CONF_NAME], data=user_input)
            
        data_schema = {
            vol.Required(CONF_NAME): TextSelector(
                TextSelectorConfig(type=TextSelectorType.TEXT)
            ),
            "additional_options": section(
                vol.Schema(
                    {
                        vol.Optional("test1", default="Test1"): SelectSelector(
                            SelectSelectorConfig(options=['Test1', 'Test2', 'Test3'], multiple=False, mode=SelectSelectorMode.LIST)
                        ),
                        vol.Optional("test2", default=False): BooleanSelector(),
                        vol.Optional("test3", default=False): BooleanSelector()
                    }
                ),
                {"collapsed": False},
            )
        }
        return self.async_show_form(step_id="user", data_schema=vol.Schema(data_schema))

    @staticmethod
    @callback
    def async_get_options_flow(config_entry):
        return OptionsFlowHandler(config_entry)


class OptionsFlowHandler(config_entries.OptionsFlow):
    def __init__(self, config_entry):
        self.config_entry = config_entry

    async def async_step_init(self, user_input):
        return await self.async_step_user(user_input)
        
    async def async_step_user(self, user_input):
        if user_input is not None:
            self.hass.config_entries.async_update_entry(
                self.config_entry, data=self.config_entry.data | user_input
            )
            return self.async_create_entry(title="", data={})
        
        config = {**self.config_entry.data, **self.config_entry.options}   
        additional_options = config.get("additional_options", {})
        
        data_schema = {
            "additional_options": section(
                vol.Schema(
                    {
                        vol.Optional("test1", default=additional_options.get("test1", "Test1")): SelectSelector(
                            SelectSelectorConfig(options=['Test1', 'Test2', 'Test3'], multiple=False, mode=SelectSelectorMode.LIST)
                        ),
                        vol.Optional("test2", default=additional_options.get("test2", False)): BooleanSelector(),
                        vol.Optional("test3", default=additional_options.get("test3", False)): BooleanSelector()
                    }
                ),
                {"collapsed": False},
            )
        }
        return self.async_show_form(step_id="user", data_schema=vol.Schema(data_schema))

en.json

{
  "config": {
    "step": {
      "user": {
        "title": "Test",
        "data": {
          "name": "Name"
        },
        "sections": {
          "additional_options": {
            "name": "Test section",
            "data": {
              "test1": "Test select selector",
              "test2": "Test boolean selector",
              "test3": "Test boolean selector"
            }
          }
        }
      }
    }
  },
  "options": {
    "step": {
      "user": {
        "title": "Test",
        "sections": {
          "additional_options": {
            "name": "Test section",
            "data": {
              "test1": "Test select selector",
              "test2": "Test boolean selector",
              "test3": "Test boolean selector"
            }
          }
        }
      }
    }
  }
}

@karwosts
Copy link
Contributor

So I tried this out w/ kitchen_sink integration (a dummy/testing integration), and I couldn't find a problem.

If I run options flow and select a value in the selector, and save, and run options flow again, the previously selected item is populated.

If you have a core dev environment, do you want to try running this PR (home-assistant/core#129503), and see if it's working as you would expect? Maybe you can compare the code difference between the two to see if anything is missing.

I don't see anything obviously wrong in your code, but I am not an expert in config flows.

@EnzoD86
Copy link
Author

EnzoD86 commented Oct 31, 2024

Hi, I can't do this kind of test at the moment, because I don't have a development environment.
I'll try to put it up as soon as I have some time
Thanks for looking anyway!

@dummylabs
Copy link

The working solution is given in #22419. PR to fix documentation: home-assistant/developers.home-assistant#2454

@EnzoD86
Copy link
Author

EnzoD86 commented Dec 5, 2024

The working solution is given in #22419. PR to fix documentation: home-assistant/developers.home-assistant#2454

I confirm that the suggested solution works perfectly. Thanks!

@EnzoD86 EnzoD86 closed this as completed Dec 5, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants