using Newtonsoft.Json.Linq;
using ReactNative.Bridge;
using ReactNative.UIManager;
using System;
using System.IO;
using System.Collections.Generic;
namespace RNViewShot
{
    /// 
    /// A module that allows JS to share data.
    /// 
    class RNViewShotModule : ReactContextNativeModuleBase
    {
        private const string ErrorUnableToSnapshot = "E_UNABLE_TO_SNAPSHOT";
        private readonly ReactContext _reactContext;
        /// 
        /// Instantiates the .
        /// 
        public RNViewShotModule(ReactContext reactContext) : base(reactContext)
        {
            this._reactContext = reactContext;
        }
        /// 
        /// The name of the native module.
        /// 
        public override string Name
        {
            get
            {
                return "RNViewShot";
            }
        }
        [ReactMethod]
        public void takeSnapshot(int tag, JObject options, IPromise promise)
        {
            string format = options["format"] != null ? options.Value("format") : "png";
            double quality = options["quality"] != null ? options.Value("quality") : 1.0;
            int? width = options["width"] != null ? options.Value("width") : null;
            int? height = options["height"] != null ? options.Value("height") : null;
            string result = options["result"] != null ? options.Value("result") : "file";
            string path = options["path"] != null ? options.Value("path") : null;
            if (format != "png" && format != "jpg" && format != "jpeg")
            {
                promise.Reject(ViewShot.ErrorUnableToSnapshot, "Unsupported image format: " + format + ". Try one of: png | jpg | jpeg");
                return;
            }
            UIManagerModule uiManager = this._reactContext.GetNativeModule();
            var viewShot = new ViewShot(tag, format, quality, width, height, path, result, promise);
            uiManager.AddUIBlock(viewShot);
        }
    }
}