﻿using JLGames.RocketDriver.Actions.Utils;
using JLGames.RocketDriver.Games.PanelManager;
using UnityEngine;

namespace JLGames.RocketDriver.Samples.PanelDemo
{
    public class PanelExtend : MonoBehaviour, IInitPanel, IDisposePanel, IParamsPanel, IRefreshPanel
    {
        public class PanelExtendParams
        {
            public int Param1;
            public string Param2;

            public override string ToString()
            {
                return $"JsonParams{{Param1={Param1}, Param2={Param2}}}";
            }

            public static PanelExtendParams ParseFromJson(string jsonStr)
            {
                return JsonUtility.FromJson<PanelExtendParams>(jsonStr);
            }
        }

        private void Awake()
        {
            DebugUtil.LogWarning("PanelExtend.Awake");
        }

        private void OnEnable()
        {
            DebugUtil.LogWarning("PanelExtend.OnEnable");
        }

        public void InitPanel(IPanelInstance instance)
        {
            DebugUtil.LogWarning($"PanelExtend[{instance.InstanceId}].InitPanel");
        }

        public void SetPanelStringParams(IPanelInstance instance, string str)
        {
            var @params = PanelExtendParams.ParseFromJson(str);
            DebugUtil.LogWarning($"PanelExtend[{instance.InstanceId}].SetPanelStringParams:", @params);
        }

        public void SetPanelObjectParams(IPanelInstance instance, object @params)
        {
            DebugUtil.LogWarning($"PanelExtend[{instance.InstanceId}].SetPanelObjectParams:", @params);
        }

        public void RefreshPanel(IPanelInstance instance)
        {
            DebugUtil.LogWarning($"PanelExtend[{instance.InstanceId}].RefreshPanel");
        }

        private void Start()
        {
            DebugUtil.LogWarning("PanelExtend.Start");
        }

        public void DisposePanel(IPanelInstance instance)
        {
            DebugUtil.LogWarning($"PanelExtend[{instance.InstanceId}].DisposePanel");
        }

        private void OnDisable()
        {
            DebugUtil.LogWarning("PanelExtend.OnDisable");
        }

        private void OnDestroy()
        {
            DebugUtil.LogWarning("PanelExtend.OnDestroy");
        }
    }
}