using Aitex.Core.Common;
using MECF.Framework.Common.Equipment;
using CyberX8_RT.Devices.EFEM;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Aitex.Core.RT.Log;
using Aitex.Core.RT.Routine;
using Aitex.Sorter.Common;
using MECF.Framework.Common.Schedulers;
using MECF.Framework.Common.SubstrateTrackings;
using System.Diagnostics;
using CyberX8_Core;
using Aitex.Core.RT.SCCore;
using System.Threading;
namespace CyberX8_RT.Modules.EFEM
{
    public class EfemVacuumRoutine : ModuleRoutineBase, IRoutine
    {
        private bool _vacuumStatus;
        private ModuleName _vacuumModule;
        private enum VacuumStep
        {
            VacuumAction,
            End,
        }
        EfemBase _efem;
        /// 
        /// 构造函数
        /// 
        /// 
        public EfemVacuumRoutine(EfemBase efem) : base(ModuleName.EFEM)
        {
            _efem = efem;
        }
        /// 
        /// 启动
        /// 
        /// 
        /// 
        public RState Start(params object[] objs)
        {
            _vacuumModule = (ModuleName)objs[0];
            _vacuumStatus = (bool)objs[1];
            return Runner.Start(Module, "Vacumm");
        }
        /// 
        /// 监控
        /// 
        /// 
        public RState Monitor()
        {
            Runner.Run(VacuumStep.VacuumAction, ()=> { return Vacuum(_vacuumModule, _vacuumStatus);}, CheckVacuumDone, 30000)
                    .End(VacuumStep.End, NullFun, 0);
            return Runner.Status;
        }
        /// 
        /// Vacuum功能
        /// 
        /// 
        private bool Vacuum(ModuleName moduleName,bool VacuumState)
        {
            return _efem.Vacuum(moduleName,VacuumState);
        }
        private bool CheckVacuumDone()
        {
            if (_efem.Status == RState.End)
            {
                return true;
            }
            else if (_efem.Status == RState.Failed)
            {
                LOG.Write(eEvent.ERR_EFEM_COMMON_FAILED, Module, $"Efem Vacuum failed: {_efem.Status}");
                return true;
            }
            return false;
        }
        public void Abort()
        {
            Runner.Stop("Manual Abort");
        }
    }
}