Skip to content

Commit

Permalink
Restore prefab state after instantiation
Browse files Browse the repository at this point in the history
  • Loading branch information
cooloon committed Feb 11, 2021
1 parent 7e7f229 commit 8927468
Show file tree
Hide file tree
Showing 2 changed files with 4 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -114,6 +114,7 @@ Component FindComponent(IObjectResolver resolver)
Component InstantiatePrefab(IObjectResolver resolver)
{
var parent = destination.GetParent();
var wasActive = destination.Prefab.gameObject.activeSelf;
if (destination.Prefab.gameObject.activeSelf)
{
destination.Prefab.gameObject.SetActive(false);
Expand All @@ -123,6 +124,7 @@ Component InstantiatePrefab(IObjectResolver resolver)
? UnityEngine.Object.Instantiate(destination.Prefab, parent)
: UnityEngine.Object.Instantiate(destination.Prefab);

destination.Prefab.gameObject.SetActive(wasActive);
injector.Inject(component, resolver, Parameters);
component.gameObject.SetActive(true);
return component;
Expand Down
2 changes: 2 additions & 0 deletions VContainer/Assets/VContainer/Runtime/Unity/LifetimeScope.cs
Original file line number Diff line number Diff line change
Expand Up @@ -203,12 +203,14 @@ public LifetimeScope CreateChild(Action<IContainerBuilder> installation)

public LifetimeScope CreateChildFromPrefab(LifetimeScope prefab, IInstaller installer = null)
{
var wasActive = prefab.gameObject.activeSelf;
if (prefab.gameObject.activeSelf && prefab.autoRun)
{
prefab.gameObject.SetActive(false);
}

var child = Instantiate(prefab, transform, false);
prefab.gameObject.SetActive(wasActive);
if (installer != null)
{
child.extraInstallers.Add(installer);
Expand Down

0 comments on commit 8927468

Please sign in to comment.