-
Notifications
You must be signed in to change notification settings - Fork 50
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
How to add custom toggles to Esquio UI list of available toggles #187
Comments
This is the code that load toggles on the UI Basically, load all assemblies with IToggle types defined! You can add assemblies to the execution context with your toogles or override IDiscoverToggleTypesService.cs to extend default assemblies to use. _typesCache = AppDomain.CurrentDomain
.GetAssemblies()
.Intersect(IntrospectionAssemblies)
.SelectMany(a => a.GetExportedTypes())
.Where(type => typeof(IToggle).IsAssignableFrom(type) && type.IsClass); Remember use DesingType and DesignTypeParameter attributes to help the UI to understand the toggle and the parameters type to use. [DesignType(Description = "The value of the configured environment variable is in the list.", FriendlyName = "Environment Variable")]
[DesignTypeParameter(ParameterName = EnvironmentVariable, ParameterType = EsquioConstants.STRING_PARAMETER_TYPE, ParameterDescription = "The environment variable name.")]
[DesignTypeParameter(ParameterName = Values, ParameterType = EsquioConstants.SEMICOLON_LIST_PARAMETER_TYPE, ParameterDescription = "The values to activate this toggle separated by ';' character.")] |
Hi - good morning. Thanks for the advice. I have looked into this over the weekend and I am still puzzled on how to make this work. Let me explain in more detail my use case: I have a custom toggle, which I have created following your guidance by implementing the IToggle interface and I also added the DesignType and DesignTypeParameter attributes. I also have a running container of the UI host on my local kubernetes cluster. My test web app, connects to this running UI host for its HTTP based store. So far so good. I have also called (not sure if this is required but saw it in one of your examples) the
in the configure services method of my test web app. Now the part I'm not quite sure is - what API am I going to call from the UI host running on Kubernetes to let that UI host know that there is a new custom toggle on my web app? You talk about adding the assembly of my web app where the custom toggle resides to the execution context, or override IDiscoverToggleTypesService.cs to extend default assemblies to use Where do you mean I should do this? is this to be done on the configure services method? if so, is that meant to be done on the running UI host configure services? (if yes, does that mean that I need to shut it down and recompile / restart? - not what I intended to do) |
The method You need to override the IDiscoverToggleTypeService on the UI and register your new service, unfortunately is not a way to do that without create your custom image, but we are happy to get a PR on this or open a discussion about the this feature design. Hope this help! |
Ok I get it, I think... :-) - so I would need to create my own image of the UI to get it updated and running with the knowledge of the new toggle. So out of the box, I would have to 1) Put all custom toggles in some sort of class library which would be shared between my web app and the UI host 2) recompile the UI and create a new image 3) redeploy the new UI host image on Kubernetes and then finally run my new web app which makes use of those same custom toggles. It would definitely make a lot of sense to have an API on the UI host where we could call it to "feed it" the new custom toggles - that would make this long term sustainable in an enterprise environment. Can you share the dockerfile for the latest image (I believe that is 5.0?). Does that Dockerfile for 5.0 build the so called Esquio.UI.Client or the Esquio.UI.Host web app or both? |
Yeap, I'm thinking on reduce the dependencies on libraries for the UI to use custom toggles, but, i need some time to implement this! Dockerfile is here! https://github.com/Xabaril/Esquio/blob/master/build/UIDockerfile |
We are talking about this feature and our approach for this feature is:
this drop the issue of create different images for your custom toggles and I think improve the experience! What do you think on this design? |
anything that will remove the need to create a new image will definitely be a strong move towards making Esquio an even greater solution. A few questions if I may:
If the answers to these are all yes - then AWESOME! when can we expect them ? :-) |
1 Yes, that is the idea and I start the work on features/expose-custom-toggle-data-from-app :-), hope this help to decide to use this product! I try finish these feature soon! |
Hi - how can I add a custom toggle, created following instructions on this link: doc. The doc explains how to create the toggle but it doesn't explain how to add it to the list of available toggles in Esquio UI.
I will have a look at the source code later to see if I can figure it out.
I thought that one way could be to configure manually the Toggles table in the DB schema by adding a new entry for each custom toggle but, from what I can see, that is not where the list of pre-configured available toggles comes from...
The text was updated successfully, but these errors were encountered: