2017 lines
		
	
	
		
			55 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			2017 lines
		
	
	
		
			55 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
/**
 | 
						|
* @vue/reactivity v3.5.21
 | 
						|
* (c) 2018-present Yuxi (Evan) You and Vue contributors
 | 
						|
* @license MIT
 | 
						|
**/
 | 
						|
var VueReactivity = (function (exports) {
 | 
						|
  'use strict';
 | 
						|
 | 
						|
  // @__NO_SIDE_EFFECTS__
 | 
						|
  function makeMap(str) {
 | 
						|
    const map = /* @__PURE__ */ Object.create(null);
 | 
						|
    for (const key of str.split(",")) map[key] = 1;
 | 
						|
    return (val) => val in map;
 | 
						|
  }
 | 
						|
 | 
						|
  const EMPTY_OBJ = Object.freeze({}) ;
 | 
						|
  const NOOP = () => {
 | 
						|
  };
 | 
						|
  const extend = Object.assign;
 | 
						|
  const remove = (arr, el) => {
 | 
						|
    const i = arr.indexOf(el);
 | 
						|
    if (i > -1) {
 | 
						|
      arr.splice(i, 1);
 | 
						|
    }
 | 
						|
  };
 | 
						|
  const hasOwnProperty$1 = Object.prototype.hasOwnProperty;
 | 
						|
  const hasOwn = (val, key) => hasOwnProperty$1.call(val, key);
 | 
						|
  const isArray = Array.isArray;
 | 
						|
  const isMap = (val) => toTypeString(val) === "[object Map]";
 | 
						|
  const isSet = (val) => toTypeString(val) === "[object Set]";
 | 
						|
  const isFunction = (val) => typeof val === "function";
 | 
						|
  const isString = (val) => typeof val === "string";
 | 
						|
  const isSymbol = (val) => typeof val === "symbol";
 | 
						|
  const isObject = (val) => val !== null && typeof val === "object";
 | 
						|
  const objectToString = Object.prototype.toString;
 | 
						|
  const toTypeString = (value) => objectToString.call(value);
 | 
						|
  const toRawType = (value) => {
 | 
						|
    return toTypeString(value).slice(8, -1);
 | 
						|
  };
 | 
						|
  const isPlainObject = (val) => toTypeString(val) === "[object Object]";
 | 
						|
  const isIntegerKey = (key) => isString(key) && key !== "NaN" && key[0] !== "-" && "" + parseInt(key, 10) === key;
 | 
						|
  const cacheStringFunction = (fn) => {
 | 
						|
    const cache = /* @__PURE__ */ Object.create(null);
 | 
						|
    return ((str) => {
 | 
						|
      const hit = cache[str];
 | 
						|
      return hit || (cache[str] = fn(str));
 | 
						|
    });
 | 
						|
  };
 | 
						|
  const capitalize = cacheStringFunction((str) => {
 | 
						|
    return str.charAt(0).toUpperCase() + str.slice(1);
 | 
						|
  });
 | 
						|
  const hasChanged = (value, oldValue) => !Object.is(value, oldValue);
 | 
						|
  const def = (obj, key, value, writable = false) => {
 | 
						|
    Object.defineProperty(obj, key, {
 | 
						|
      configurable: true,
 | 
						|
      enumerable: false,
 | 
						|
      writable,
 | 
						|
      value
 | 
						|
    });
 | 
						|
  };
 | 
						|
 | 
						|
  function warn(msg, ...args) {
 | 
						|
    console.warn(`[Vue warn] ${msg}`, ...args);
 | 
						|
  }
 | 
						|
 | 
						|
  let activeEffectScope;
 | 
						|
  class EffectScope {
 | 
						|
    constructor(detached = false) {
 | 
						|
      this.detached = detached;
 | 
						|
      /**
 | 
						|
       * @internal
 | 
						|
       */
 | 
						|
      this._active = true;
 | 
						|
      /**
 | 
						|
       * @internal track `on` calls, allow `on` call multiple times
 | 
						|
       */
 | 
						|
      this._on = 0;
 | 
						|
      /**
 | 
						|
       * @internal
 | 
						|
       */
 | 
						|
      this.effects = [];
 | 
						|
      /**
 | 
						|
       * @internal
 | 
						|
       */
 | 
						|
      this.cleanups = [];
 | 
						|
      this._isPaused = false;
 | 
						|
      this.parent = activeEffectScope;
 | 
						|
      if (!detached && activeEffectScope) {
 | 
						|
        this.index = (activeEffectScope.scopes || (activeEffectScope.scopes = [])).push(
 | 
						|
          this
 | 
						|
        ) - 1;
 | 
						|
      }
 | 
						|
    }
 | 
						|
    get active() {
 | 
						|
      return this._active;
 | 
						|
    }
 | 
						|
    pause() {
 | 
						|
      if (this._active) {
 | 
						|
        this._isPaused = true;
 | 
						|
        let i, l;
 | 
						|
        if (this.scopes) {
 | 
						|
          for (i = 0, l = this.scopes.length; i < l; i++) {
 | 
						|
            this.scopes[i].pause();
 | 
						|
          }
 | 
						|
        }
 | 
						|
        for (i = 0, l = this.effects.length; i < l; i++) {
 | 
						|
          this.effects[i].pause();
 | 
						|
        }
 | 
						|
      }
 | 
						|
    }
 | 
						|
    /**
 | 
						|
     * Resumes the effect scope, including all child scopes and effects.
 | 
						|
     */
 | 
						|
    resume() {
 | 
						|
      if (this._active) {
 | 
						|
        if (this._isPaused) {
 | 
						|
          this._isPaused = false;
 | 
						|
          let i, l;
 | 
						|
          if (this.scopes) {
 | 
						|
            for (i = 0, l = this.scopes.length; i < l; i++) {
 | 
						|
              this.scopes[i].resume();
 | 
						|
            }
 | 
						|
          }
 | 
						|
          for (i = 0, l = this.effects.length; i < l; i++) {
 | 
						|
            this.effects[i].resume();
 | 
						|
          }
 | 
						|
        }
 | 
						|
      }
 | 
						|
    }
 | 
						|
    run(fn) {
 | 
						|
      if (this._active) {
 | 
						|
        const currentEffectScope = activeEffectScope;
 | 
						|
        try {
 | 
						|
          activeEffectScope = this;
 | 
						|
          return fn();
 | 
						|
        } finally {
 | 
						|
          activeEffectScope = currentEffectScope;
 | 
						|
        }
 | 
						|
      } else {
 | 
						|
        warn(`cannot run an inactive effect scope.`);
 | 
						|
      }
 | 
						|
    }
 | 
						|
    /**
 | 
						|
     * This should only be called on non-detached scopes
 | 
						|
     * @internal
 | 
						|
     */
 | 
						|
    on() {
 | 
						|
      if (++this._on === 1) {
 | 
						|
        this.prevScope = activeEffectScope;
 | 
						|
        activeEffectScope = this;
 | 
						|
      }
 | 
						|
    }
 | 
						|
    /**
 | 
						|
     * This should only be called on non-detached scopes
 | 
						|
     * @internal
 | 
						|
     */
 | 
						|
    off() {
 | 
						|
      if (this._on > 0 && --this._on === 0) {
 | 
						|
        activeEffectScope = this.prevScope;
 | 
						|
        this.prevScope = void 0;
 | 
						|
      }
 | 
						|
    }
 | 
						|
    stop(fromParent) {
 | 
						|
      if (this._active) {
 | 
						|
        this._active = false;
 | 
						|
        let i, l;
 | 
						|
        for (i = 0, l = this.effects.length; i < l; i++) {
 | 
						|
          this.effects[i].stop();
 | 
						|
        }
 | 
						|
        this.effects.length = 0;
 | 
						|
        for (i = 0, l = this.cleanups.length; i < l; i++) {
 | 
						|
          this.cleanups[i]();
 | 
						|
        }
 | 
						|
        this.cleanups.length = 0;
 | 
						|
        if (this.scopes) {
 | 
						|
          for (i = 0, l = this.scopes.length; i < l; i++) {
 | 
						|
            this.scopes[i].stop(true);
 | 
						|
          }
 | 
						|
          this.scopes.length = 0;
 | 
						|
        }
 | 
						|
        if (!this.detached && this.parent && !fromParent) {
 | 
						|
          const last = this.parent.scopes.pop();
 | 
						|
          if (last && last !== this) {
 | 
						|
            this.parent.scopes[this.index] = last;
 | 
						|
            last.index = this.index;
 | 
						|
          }
 | 
						|
        }
 | 
						|
        this.parent = void 0;
 | 
						|
      }
 | 
						|
    }
 | 
						|
  }
 | 
						|
  function effectScope(detached) {
 | 
						|
    return new EffectScope(detached);
 | 
						|
  }
 | 
						|
  function getCurrentScope() {
 | 
						|
    return activeEffectScope;
 | 
						|
  }
 | 
						|
  function onScopeDispose(fn, failSilently = false) {
 | 
						|
    if (activeEffectScope) {
 | 
						|
      activeEffectScope.cleanups.push(fn);
 | 
						|
    } else if (!failSilently) {
 | 
						|
      warn(
 | 
						|
        `onScopeDispose() is called when there is no active effect scope to be associated with.`
 | 
						|
      );
 | 
						|
    }
 | 
						|
  }
 | 
						|
 | 
						|
  let activeSub;
 | 
						|
  const EffectFlags = {
 | 
						|
    "ACTIVE": 1,
 | 
						|
    "1": "ACTIVE",
 | 
						|
    "RUNNING": 2,
 | 
						|
    "2": "RUNNING",
 | 
						|
    "TRACKING": 4,
 | 
						|
    "4": "TRACKING",
 | 
						|
    "NOTIFIED": 8,
 | 
						|
    "8": "NOTIFIED",
 | 
						|
    "DIRTY": 16,
 | 
						|
    "16": "DIRTY",
 | 
						|
    "ALLOW_RECURSE": 32,
 | 
						|
    "32": "ALLOW_RECURSE",
 | 
						|
    "PAUSED": 64,
 | 
						|
    "64": "PAUSED",
 | 
						|
    "EVALUATED": 128,
 | 
						|
    "128": "EVALUATED"
 | 
						|
  };
 | 
						|
  const pausedQueueEffects = /* @__PURE__ */ new WeakSet();
 | 
						|
  class ReactiveEffect {
 | 
						|
    constructor(fn) {
 | 
						|
      this.fn = fn;
 | 
						|
      /**
 | 
						|
       * @internal
 | 
						|
       */
 | 
						|
      this.deps = void 0;
 | 
						|
      /**
 | 
						|
       * @internal
 | 
						|
       */
 | 
						|
      this.depsTail = void 0;
 | 
						|
      /**
 | 
						|
       * @internal
 | 
						|
       */
 | 
						|
      this.flags = 1 | 4;
 | 
						|
      /**
 | 
						|
       * @internal
 | 
						|
       */
 | 
						|
      this.next = void 0;
 | 
						|
      /**
 | 
						|
       * @internal
 | 
						|
       */
 | 
						|
      this.cleanup = void 0;
 | 
						|
      this.scheduler = void 0;
 | 
						|
      if (activeEffectScope && activeEffectScope.active) {
 | 
						|
        activeEffectScope.effects.push(this);
 | 
						|
      }
 | 
						|
    }
 | 
						|
    pause() {
 | 
						|
      this.flags |= 64;
 | 
						|
    }
 | 
						|
    resume() {
 | 
						|
      if (this.flags & 64) {
 | 
						|
        this.flags &= -65;
 | 
						|
        if (pausedQueueEffects.has(this)) {
 | 
						|
          pausedQueueEffects.delete(this);
 | 
						|
          this.trigger();
 | 
						|
        }
 | 
						|
      }
 | 
						|
    }
 | 
						|
    /**
 | 
						|
     * @internal
 | 
						|
     */
 | 
						|
    notify() {
 | 
						|
      if (this.flags & 2 && !(this.flags & 32)) {
 | 
						|
        return;
 | 
						|
      }
 | 
						|
      if (!(this.flags & 8)) {
 | 
						|
        batch(this);
 | 
						|
      }
 | 
						|
    }
 | 
						|
    run() {
 | 
						|
      if (!(this.flags & 1)) {
 | 
						|
        return this.fn();
 | 
						|
      }
 | 
						|
      this.flags |= 2;
 | 
						|
      cleanupEffect(this);
 | 
						|
      prepareDeps(this);
 | 
						|
      const prevEffect = activeSub;
 | 
						|
      const prevShouldTrack = shouldTrack;
 | 
						|
      activeSub = this;
 | 
						|
      shouldTrack = true;
 | 
						|
      try {
 | 
						|
        return this.fn();
 | 
						|
      } finally {
 | 
						|
        if (activeSub !== this) {
 | 
						|
          warn(
 | 
						|
            "Active effect was not restored correctly - this is likely a Vue internal bug."
 | 
						|
          );
 | 
						|
        }
 | 
						|
        cleanupDeps(this);
 | 
						|
        activeSub = prevEffect;
 | 
						|
        shouldTrack = prevShouldTrack;
 | 
						|
        this.flags &= -3;
 | 
						|
      }
 | 
						|
    }
 | 
						|
    stop() {
 | 
						|
      if (this.flags & 1) {
 | 
						|
        for (let link = this.deps; link; link = link.nextDep) {
 | 
						|
          removeSub(link);
 | 
						|
        }
 | 
						|
        this.deps = this.depsTail = void 0;
 | 
						|
        cleanupEffect(this);
 | 
						|
        this.onStop && this.onStop();
 | 
						|
        this.flags &= -2;
 | 
						|
      }
 | 
						|
    }
 | 
						|
    trigger() {
 | 
						|
      if (this.flags & 64) {
 | 
						|
        pausedQueueEffects.add(this);
 | 
						|
      } else if (this.scheduler) {
 | 
						|
        this.scheduler();
 | 
						|
      } else {
 | 
						|
        this.runIfDirty();
 | 
						|
      }
 | 
						|
    }
 | 
						|
    /**
 | 
						|
     * @internal
 | 
						|
     */
 | 
						|
    runIfDirty() {
 | 
						|
      if (isDirty(this)) {
 | 
						|
        this.run();
 | 
						|
      }
 | 
						|
    }
 | 
						|
    get dirty() {
 | 
						|
      return isDirty(this);
 | 
						|
    }
 | 
						|
  }
 | 
						|
  let batchDepth = 0;
 | 
						|
  let batchedSub;
 | 
						|
  let batchedComputed;
 | 
						|
  function batch(sub, isComputed = false) {
 | 
						|
    sub.flags |= 8;
 | 
						|
    if (isComputed) {
 | 
						|
      sub.next = batchedComputed;
 | 
						|
      batchedComputed = sub;
 | 
						|
      return;
 | 
						|
    }
 | 
						|
    sub.next = batchedSub;
 | 
						|
    batchedSub = sub;
 | 
						|
  }
 | 
						|
  function startBatch() {
 | 
						|
    batchDepth++;
 | 
						|
  }
 | 
						|
  function endBatch() {
 | 
						|
    if (--batchDepth > 0) {
 | 
						|
      return;
 | 
						|
    }
 | 
						|
    if (batchedComputed) {
 | 
						|
      let e = batchedComputed;
 | 
						|
      batchedComputed = void 0;
 | 
						|
      while (e) {
 | 
						|
        const next = e.next;
 | 
						|
        e.next = void 0;
 | 
						|
        e.flags &= -9;
 | 
						|
        e = next;
 | 
						|
      }
 | 
						|
    }
 | 
						|
    let error;
 | 
						|
    while (batchedSub) {
 | 
						|
      let e = batchedSub;
 | 
						|
      batchedSub = void 0;
 | 
						|
      while (e) {
 | 
						|
        const next = e.next;
 | 
						|
        e.next = void 0;
 | 
						|
        e.flags &= -9;
 | 
						|
        if (e.flags & 1) {
 | 
						|
          try {
 | 
						|
            ;
 | 
						|
            e.trigger();
 | 
						|
          } catch (err) {
 | 
						|
            if (!error) error = err;
 | 
						|
          }
 | 
						|
        }
 | 
						|
        e = next;
 | 
						|
      }
 | 
						|
    }
 | 
						|
    if (error) throw error;
 | 
						|
  }
 | 
						|
  function prepareDeps(sub) {
 | 
						|
    for (let link = sub.deps; link; link = link.nextDep) {
 | 
						|
      link.version = -1;
 | 
						|
      link.prevActiveLink = link.dep.activeLink;
 | 
						|
      link.dep.activeLink = link;
 | 
						|
    }
 | 
						|
  }
 | 
						|
  function cleanupDeps(sub) {
 | 
						|
    let head;
 | 
						|
    let tail = sub.depsTail;
 | 
						|
    let link = tail;
 | 
						|
    while (link) {
 | 
						|
      const prev = link.prevDep;
 | 
						|
      if (link.version === -1) {
 | 
						|
        if (link === tail) tail = prev;
 | 
						|
        removeSub(link);
 | 
						|
        removeDep(link);
 | 
						|
      } else {
 | 
						|
        head = link;
 | 
						|
      }
 | 
						|
      link.dep.activeLink = link.prevActiveLink;
 | 
						|
      link.prevActiveLink = void 0;
 | 
						|
      link = prev;
 | 
						|
    }
 | 
						|
    sub.deps = head;
 | 
						|
    sub.depsTail = tail;
 | 
						|
  }
 | 
						|
  function isDirty(sub) {
 | 
						|
    for (let link = sub.deps; link; link = link.nextDep) {
 | 
						|
      if (link.dep.version !== link.version || link.dep.computed && (refreshComputed(link.dep.computed) || link.dep.version !== link.version)) {
 | 
						|
        return true;
 | 
						|
      }
 | 
						|
    }
 | 
						|
    if (sub._dirty) {
 | 
						|
      return true;
 | 
						|
    }
 | 
						|
    return false;
 | 
						|
  }
 | 
						|
  function refreshComputed(computed) {
 | 
						|
    if (computed.flags & 4 && !(computed.flags & 16)) {
 | 
						|
      return;
 | 
						|
    }
 | 
						|
    computed.flags &= -17;
 | 
						|
    if (computed.globalVersion === globalVersion) {
 | 
						|
      return;
 | 
						|
    }
 | 
						|
    computed.globalVersion = globalVersion;
 | 
						|
    if (!computed.isSSR && computed.flags & 128 && (!computed.deps && !computed._dirty || !isDirty(computed))) {
 | 
						|
      return;
 | 
						|
    }
 | 
						|
    computed.flags |= 2;
 | 
						|
    const dep = computed.dep;
 | 
						|
    const prevSub = activeSub;
 | 
						|
    const prevShouldTrack = shouldTrack;
 | 
						|
    activeSub = computed;
 | 
						|
    shouldTrack = true;
 | 
						|
    try {
 | 
						|
      prepareDeps(computed);
 | 
						|
      const value = computed.fn(computed._value);
 | 
						|
      if (dep.version === 0 || hasChanged(value, computed._value)) {
 | 
						|
        computed.flags |= 128;
 | 
						|
        computed._value = value;
 | 
						|
        dep.version++;
 | 
						|
      }
 | 
						|
    } catch (err) {
 | 
						|
      dep.version++;
 | 
						|
      throw err;
 | 
						|
    } finally {
 | 
						|
      activeSub = prevSub;
 | 
						|
      shouldTrack = prevShouldTrack;
 | 
						|
      cleanupDeps(computed);
 | 
						|
      computed.flags &= -3;
 | 
						|
    }
 | 
						|
  }
 | 
						|
  function removeSub(link, soft = false) {
 | 
						|
    const { dep, prevSub, nextSub } = link;
 | 
						|
    if (prevSub) {
 | 
						|
      prevSub.nextSub = nextSub;
 | 
						|
      link.prevSub = void 0;
 | 
						|
    }
 | 
						|
    if (nextSub) {
 | 
						|
      nextSub.prevSub = prevSub;
 | 
						|
      link.nextSub = void 0;
 | 
						|
    }
 | 
						|
    if (dep.subsHead === link) {
 | 
						|
      dep.subsHead = nextSub;
 | 
						|
    }
 | 
						|
    if (dep.subs === link) {
 | 
						|
      dep.subs = prevSub;
 | 
						|
      if (!prevSub && dep.computed) {
 | 
						|
        dep.computed.flags &= -5;
 | 
						|
        for (let l = dep.computed.deps; l; l = l.nextDep) {
 | 
						|
          removeSub(l, true);
 | 
						|
        }
 | 
						|
      }
 | 
						|
    }
 | 
						|
    if (!soft && !--dep.sc && dep.map) {
 | 
						|
      dep.map.delete(dep.key);
 | 
						|
    }
 | 
						|
  }
 | 
						|
  function removeDep(link) {
 | 
						|
    const { prevDep, nextDep } = link;
 | 
						|
    if (prevDep) {
 | 
						|
      prevDep.nextDep = nextDep;
 | 
						|
      link.prevDep = void 0;
 | 
						|
    }
 | 
						|
    if (nextDep) {
 | 
						|
      nextDep.prevDep = prevDep;
 | 
						|
      link.nextDep = void 0;
 | 
						|
    }
 | 
						|
  }
 | 
						|
  function effect(fn, options) {
 | 
						|
    if (fn.effect instanceof ReactiveEffect) {
 | 
						|
      fn = fn.effect.fn;
 | 
						|
    }
 | 
						|
    const e = new ReactiveEffect(fn);
 | 
						|
    if (options) {
 | 
						|
      extend(e, options);
 | 
						|
    }
 | 
						|
    try {
 | 
						|
      e.run();
 | 
						|
    } catch (err) {
 | 
						|
      e.stop();
 | 
						|
      throw err;
 | 
						|
    }
 | 
						|
    const runner = e.run.bind(e);
 | 
						|
    runner.effect = e;
 | 
						|
    return runner;
 | 
						|
  }
 | 
						|
  function stop(runner) {
 | 
						|
    runner.effect.stop();
 | 
						|
  }
 | 
						|
  let shouldTrack = true;
 | 
						|
  const trackStack = [];
 | 
						|
  function pauseTracking() {
 | 
						|
    trackStack.push(shouldTrack);
 | 
						|
    shouldTrack = false;
 | 
						|
  }
 | 
						|
  function enableTracking() {
 | 
						|
    trackStack.push(shouldTrack);
 | 
						|
    shouldTrack = true;
 | 
						|
  }
 | 
						|
  function resetTracking() {
 | 
						|
    const last = trackStack.pop();
 | 
						|
    shouldTrack = last === void 0 ? true : last;
 | 
						|
  }
 | 
						|
  function onEffectCleanup(fn, failSilently = false) {
 | 
						|
    if (activeSub instanceof ReactiveEffect) {
 | 
						|
      activeSub.cleanup = fn;
 | 
						|
    } else if (!failSilently) {
 | 
						|
      warn(
 | 
						|
        `onEffectCleanup() was called when there was no active effect to associate with.`
 | 
						|
      );
 | 
						|
    }
 | 
						|
  }
 | 
						|
  function cleanupEffect(e) {
 | 
						|
    const { cleanup } = e;
 | 
						|
    e.cleanup = void 0;
 | 
						|
    if (cleanup) {
 | 
						|
      const prevSub = activeSub;
 | 
						|
      activeSub = void 0;
 | 
						|
      try {
 | 
						|
        cleanup();
 | 
						|
      } finally {
 | 
						|
        activeSub = prevSub;
 | 
						|
      }
 | 
						|
    }
 | 
						|
  }
 | 
						|
 | 
						|
  let globalVersion = 0;
 | 
						|
  class Link {
 | 
						|
    constructor(sub, dep) {
 | 
						|
      this.sub = sub;
 | 
						|
      this.dep = dep;
 | 
						|
      this.version = dep.version;
 | 
						|
      this.nextDep = this.prevDep = this.nextSub = this.prevSub = this.prevActiveLink = void 0;
 | 
						|
    }
 | 
						|
  }
 | 
						|
  class Dep {
 | 
						|
    // TODO isolatedDeclarations "__v_skip"
 | 
						|
    constructor(computed) {
 | 
						|
      this.computed = computed;
 | 
						|
      this.version = 0;
 | 
						|
      /**
 | 
						|
       * Link between this dep and the current active effect
 | 
						|
       */
 | 
						|
      this.activeLink = void 0;
 | 
						|
      /**
 | 
						|
       * Doubly linked list representing the subscribing effects (tail)
 | 
						|
       */
 | 
						|
      this.subs = void 0;
 | 
						|
      /**
 | 
						|
       * For object property deps cleanup
 | 
						|
       */
 | 
						|
      this.map = void 0;
 | 
						|
      this.key = void 0;
 | 
						|
      /**
 | 
						|
       * Subscriber counter
 | 
						|
       */
 | 
						|
      this.sc = 0;
 | 
						|
      /**
 | 
						|
       * @internal
 | 
						|
       */
 | 
						|
      this.__v_skip = true;
 | 
						|
      {
 | 
						|
        this.subsHead = void 0;
 | 
						|
      }
 | 
						|
    }
 | 
						|
    track(debugInfo) {
 | 
						|
      if (!activeSub || !shouldTrack || activeSub === this.computed) {
 | 
						|
        return;
 | 
						|
      }
 | 
						|
      let link = this.activeLink;
 | 
						|
      if (link === void 0 || link.sub !== activeSub) {
 | 
						|
        link = this.activeLink = new Link(activeSub, this);
 | 
						|
        if (!activeSub.deps) {
 | 
						|
          activeSub.deps = activeSub.depsTail = link;
 | 
						|
        } else {
 | 
						|
          link.prevDep = activeSub.depsTail;
 | 
						|
          activeSub.depsTail.nextDep = link;
 | 
						|
          activeSub.depsTail = link;
 | 
						|
        }
 | 
						|
        addSub(link);
 | 
						|
      } else if (link.version === -1) {
 | 
						|
        link.version = this.version;
 | 
						|
        if (link.nextDep) {
 | 
						|
          const next = link.nextDep;
 | 
						|
          next.prevDep = link.prevDep;
 | 
						|
          if (link.prevDep) {
 | 
						|
            link.prevDep.nextDep = next;
 | 
						|
          }
 | 
						|
          link.prevDep = activeSub.depsTail;
 | 
						|
          link.nextDep = void 0;
 | 
						|
          activeSub.depsTail.nextDep = link;
 | 
						|
          activeSub.depsTail = link;
 | 
						|
          if (activeSub.deps === link) {
 | 
						|
            activeSub.deps = next;
 | 
						|
          }
 | 
						|
        }
 | 
						|
      }
 | 
						|
      if (activeSub.onTrack) {
 | 
						|
        activeSub.onTrack(
 | 
						|
          extend(
 | 
						|
            {
 | 
						|
              effect: activeSub
 | 
						|
            },
 | 
						|
            debugInfo
 | 
						|
          )
 | 
						|
        );
 | 
						|
      }
 | 
						|
      return link;
 | 
						|
    }
 | 
						|
    trigger(debugInfo) {
 | 
						|
      this.version++;
 | 
						|
      globalVersion++;
 | 
						|
      this.notify(debugInfo);
 | 
						|
    }
 | 
						|
    notify(debugInfo) {
 | 
						|
      startBatch();
 | 
						|
      try {
 | 
						|
        if (true) {
 | 
						|
          for (let head = this.subsHead; head; head = head.nextSub) {
 | 
						|
            if (head.sub.onTrigger && !(head.sub.flags & 8)) {
 | 
						|
              head.sub.onTrigger(
 | 
						|
                extend(
 | 
						|
                  {
 | 
						|
                    effect: head.sub
 | 
						|
                  },
 | 
						|
                  debugInfo
 | 
						|
                )
 | 
						|
              );
 | 
						|
            }
 | 
						|
          }
 | 
						|
        }
 | 
						|
        for (let link = this.subs; link; link = link.prevSub) {
 | 
						|
          if (link.sub.notify()) {
 | 
						|
            ;
 | 
						|
            link.sub.dep.notify();
 | 
						|
          }
 | 
						|
        }
 | 
						|
      } finally {
 | 
						|
        endBatch();
 | 
						|
      }
 | 
						|
    }
 | 
						|
  }
 | 
						|
  function addSub(link) {
 | 
						|
    link.dep.sc++;
 | 
						|
    if (link.sub.flags & 4) {
 | 
						|
      const computed = link.dep.computed;
 | 
						|
      if (computed && !link.dep.subs) {
 | 
						|
        computed.flags |= 4 | 16;
 | 
						|
        for (let l = computed.deps; l; l = l.nextDep) {
 | 
						|
          addSub(l);
 | 
						|
        }
 | 
						|
      }
 | 
						|
      const currentTail = link.dep.subs;
 | 
						|
      if (currentTail !== link) {
 | 
						|
        link.prevSub = currentTail;
 | 
						|
        if (currentTail) currentTail.nextSub = link;
 | 
						|
      }
 | 
						|
      if (link.dep.subsHead === void 0) {
 | 
						|
        link.dep.subsHead = link;
 | 
						|
      }
 | 
						|
      link.dep.subs = link;
 | 
						|
    }
 | 
						|
  }
 | 
						|
  const targetMap = /* @__PURE__ */ new WeakMap();
 | 
						|
  const ITERATE_KEY = Symbol(
 | 
						|
    "Object iterate" 
 | 
						|
  );
 | 
						|
  const MAP_KEY_ITERATE_KEY = Symbol(
 | 
						|
    "Map keys iterate" 
 | 
						|
  );
 | 
						|
  const ARRAY_ITERATE_KEY = Symbol(
 | 
						|
    "Array iterate" 
 | 
						|
  );
 | 
						|
  function track(target, type, key) {
 | 
						|
    if (shouldTrack && activeSub) {
 | 
						|
      let depsMap = targetMap.get(target);
 | 
						|
      if (!depsMap) {
 | 
						|
        targetMap.set(target, depsMap = /* @__PURE__ */ new Map());
 | 
						|
      }
 | 
						|
      let dep = depsMap.get(key);
 | 
						|
      if (!dep) {
 | 
						|
        depsMap.set(key, dep = new Dep());
 | 
						|
        dep.map = depsMap;
 | 
						|
        dep.key = key;
 | 
						|
      }
 | 
						|
      {
 | 
						|
        dep.track({
 | 
						|
          target,
 | 
						|
          type,
 | 
						|
          key
 | 
						|
        });
 | 
						|
      }
 | 
						|
    }
 | 
						|
  }
 | 
						|
  function trigger(target, type, key, newValue, oldValue, oldTarget) {
 | 
						|
    const depsMap = targetMap.get(target);
 | 
						|
    if (!depsMap) {
 | 
						|
      globalVersion++;
 | 
						|
      return;
 | 
						|
    }
 | 
						|
    const run = (dep) => {
 | 
						|
      if (dep) {
 | 
						|
        {
 | 
						|
          dep.trigger({
 | 
						|
            target,
 | 
						|
            type,
 | 
						|
            key,
 | 
						|
            newValue,
 | 
						|
            oldValue,
 | 
						|
            oldTarget
 | 
						|
          });
 | 
						|
        }
 | 
						|
      }
 | 
						|
    };
 | 
						|
    startBatch();
 | 
						|
    if (type === "clear") {
 | 
						|
      depsMap.forEach(run);
 | 
						|
    } else {
 | 
						|
      const targetIsArray = isArray(target);
 | 
						|
      const isArrayIndex = targetIsArray && isIntegerKey(key);
 | 
						|
      if (targetIsArray && key === "length") {
 | 
						|
        const newLength = Number(newValue);
 | 
						|
        depsMap.forEach((dep, key2) => {
 | 
						|
          if (key2 === "length" || key2 === ARRAY_ITERATE_KEY || !isSymbol(key2) && key2 >= newLength) {
 | 
						|
            run(dep);
 | 
						|
          }
 | 
						|
        });
 | 
						|
      } else {
 | 
						|
        if (key !== void 0 || depsMap.has(void 0)) {
 | 
						|
          run(depsMap.get(key));
 | 
						|
        }
 | 
						|
        if (isArrayIndex) {
 | 
						|
          run(depsMap.get(ARRAY_ITERATE_KEY));
 | 
						|
        }
 | 
						|
        switch (type) {
 | 
						|
          case "add":
 | 
						|
            if (!targetIsArray) {
 | 
						|
              run(depsMap.get(ITERATE_KEY));
 | 
						|
              if (isMap(target)) {
 | 
						|
                run(depsMap.get(MAP_KEY_ITERATE_KEY));
 | 
						|
              }
 | 
						|
            } else if (isArrayIndex) {
 | 
						|
              run(depsMap.get("length"));
 | 
						|
            }
 | 
						|
            break;
 | 
						|
          case "delete":
 | 
						|
            if (!targetIsArray) {
 | 
						|
              run(depsMap.get(ITERATE_KEY));
 | 
						|
              if (isMap(target)) {
 | 
						|
                run(depsMap.get(MAP_KEY_ITERATE_KEY));
 | 
						|
              }
 | 
						|
            }
 | 
						|
            break;
 | 
						|
          case "set":
 | 
						|
            if (isMap(target)) {
 | 
						|
              run(depsMap.get(ITERATE_KEY));
 | 
						|
            }
 | 
						|
            break;
 | 
						|
        }
 | 
						|
      }
 | 
						|
    }
 | 
						|
    endBatch();
 | 
						|
  }
 | 
						|
  function getDepFromReactive(object, key) {
 | 
						|
    const depMap = targetMap.get(object);
 | 
						|
    return depMap && depMap.get(key);
 | 
						|
  }
 | 
						|
 | 
						|
  function reactiveReadArray(array) {
 | 
						|
    const raw = toRaw(array);
 | 
						|
    if (raw === array) return raw;
 | 
						|
    track(raw, "iterate", ARRAY_ITERATE_KEY);
 | 
						|
    return isShallow(array) ? raw : raw.map(toReactive);
 | 
						|
  }
 | 
						|
  function shallowReadArray(arr) {
 | 
						|
    track(arr = toRaw(arr), "iterate", ARRAY_ITERATE_KEY);
 | 
						|
    return arr;
 | 
						|
  }
 | 
						|
  const arrayInstrumentations = {
 | 
						|
    __proto__: null,
 | 
						|
    [Symbol.iterator]() {
 | 
						|
      return iterator(this, Symbol.iterator, toReactive);
 | 
						|
    },
 | 
						|
    concat(...args) {
 | 
						|
      return reactiveReadArray(this).concat(
 | 
						|
        ...args.map((x) => isArray(x) ? reactiveReadArray(x) : x)
 | 
						|
      );
 | 
						|
    },
 | 
						|
    entries() {
 | 
						|
      return iterator(this, "entries", (value) => {
 | 
						|
        value[1] = toReactive(value[1]);
 | 
						|
        return value;
 | 
						|
      });
 | 
						|
    },
 | 
						|
    every(fn, thisArg) {
 | 
						|
      return apply(this, "every", fn, thisArg, void 0, arguments);
 | 
						|
    },
 | 
						|
    filter(fn, thisArg) {
 | 
						|
      return apply(this, "filter", fn, thisArg, (v) => v.map(toReactive), arguments);
 | 
						|
    },
 | 
						|
    find(fn, thisArg) {
 | 
						|
      return apply(this, "find", fn, thisArg, toReactive, arguments);
 | 
						|
    },
 | 
						|
    findIndex(fn, thisArg) {
 | 
						|
      return apply(this, "findIndex", fn, thisArg, void 0, arguments);
 | 
						|
    },
 | 
						|
    findLast(fn, thisArg) {
 | 
						|
      return apply(this, "findLast", fn, thisArg, toReactive, arguments);
 | 
						|
    },
 | 
						|
    findLastIndex(fn, thisArg) {
 | 
						|
      return apply(this, "findLastIndex", fn, thisArg, void 0, arguments);
 | 
						|
    },
 | 
						|
    // flat, flatMap could benefit from ARRAY_ITERATE but are not straight-forward to implement
 | 
						|
    forEach(fn, thisArg) {
 | 
						|
      return apply(this, "forEach", fn, thisArg, void 0, arguments);
 | 
						|
    },
 | 
						|
    includes(...args) {
 | 
						|
      return searchProxy(this, "includes", args);
 | 
						|
    },
 | 
						|
    indexOf(...args) {
 | 
						|
      return searchProxy(this, "indexOf", args);
 | 
						|
    },
 | 
						|
    join(separator) {
 | 
						|
      return reactiveReadArray(this).join(separator);
 | 
						|
    },
 | 
						|
    // keys() iterator only reads `length`, no optimization required
 | 
						|
    lastIndexOf(...args) {
 | 
						|
      return searchProxy(this, "lastIndexOf", args);
 | 
						|
    },
 | 
						|
    map(fn, thisArg) {
 | 
						|
      return apply(this, "map", fn, thisArg, void 0, arguments);
 | 
						|
    },
 | 
						|
    pop() {
 | 
						|
      return noTracking(this, "pop");
 | 
						|
    },
 | 
						|
    push(...args) {
 | 
						|
      return noTracking(this, "push", args);
 | 
						|
    },
 | 
						|
    reduce(fn, ...args) {
 | 
						|
      return reduce(this, "reduce", fn, args);
 | 
						|
    },
 | 
						|
    reduceRight(fn, ...args) {
 | 
						|
      return reduce(this, "reduceRight", fn, args);
 | 
						|
    },
 | 
						|
    shift() {
 | 
						|
      return noTracking(this, "shift");
 | 
						|
    },
 | 
						|
    // slice could use ARRAY_ITERATE but also seems to beg for range tracking
 | 
						|
    some(fn, thisArg) {
 | 
						|
      return apply(this, "some", fn, thisArg, void 0, arguments);
 | 
						|
    },
 | 
						|
    splice(...args) {
 | 
						|
      return noTracking(this, "splice", args);
 | 
						|
    },
 | 
						|
    toReversed() {
 | 
						|
      return reactiveReadArray(this).toReversed();
 | 
						|
    },
 | 
						|
    toSorted(comparer) {
 | 
						|
      return reactiveReadArray(this).toSorted(comparer);
 | 
						|
    },
 | 
						|
    toSpliced(...args) {
 | 
						|
      return reactiveReadArray(this).toSpliced(...args);
 | 
						|
    },
 | 
						|
    unshift(...args) {
 | 
						|
      return noTracking(this, "unshift", args);
 | 
						|
    },
 | 
						|
    values() {
 | 
						|
      return iterator(this, "values", toReactive);
 | 
						|
    }
 | 
						|
  };
 | 
						|
  function iterator(self, method, wrapValue) {
 | 
						|
    const arr = shallowReadArray(self);
 | 
						|
    const iter = arr[method]();
 | 
						|
    if (arr !== self && !isShallow(self)) {
 | 
						|
      iter._next = iter.next;
 | 
						|
      iter.next = () => {
 | 
						|
        const result = iter._next();
 | 
						|
        if (result.value) {
 | 
						|
          result.value = wrapValue(result.value);
 | 
						|
        }
 | 
						|
        return result;
 | 
						|
      };
 | 
						|
    }
 | 
						|
    return iter;
 | 
						|
  }
 | 
						|
  const arrayProto = Array.prototype;
 | 
						|
  function apply(self, method, fn, thisArg, wrappedRetFn, args) {
 | 
						|
    const arr = shallowReadArray(self);
 | 
						|
    const needsWrap = arr !== self && !isShallow(self);
 | 
						|
    const methodFn = arr[method];
 | 
						|
    if (methodFn !== arrayProto[method]) {
 | 
						|
      const result2 = methodFn.apply(self, args);
 | 
						|
      return needsWrap ? toReactive(result2) : result2;
 | 
						|
    }
 | 
						|
    let wrappedFn = fn;
 | 
						|
    if (arr !== self) {
 | 
						|
      if (needsWrap) {
 | 
						|
        wrappedFn = function(item, index) {
 | 
						|
          return fn.call(this, toReactive(item), index, self);
 | 
						|
        };
 | 
						|
      } else if (fn.length > 2) {
 | 
						|
        wrappedFn = function(item, index) {
 | 
						|
          return fn.call(this, item, index, self);
 | 
						|
        };
 | 
						|
      }
 | 
						|
    }
 | 
						|
    const result = methodFn.call(arr, wrappedFn, thisArg);
 | 
						|
    return needsWrap && wrappedRetFn ? wrappedRetFn(result) : result;
 | 
						|
  }
 | 
						|
  function reduce(self, method, fn, args) {
 | 
						|
    const arr = shallowReadArray(self);
 | 
						|
    let wrappedFn = fn;
 | 
						|
    if (arr !== self) {
 | 
						|
      if (!isShallow(self)) {
 | 
						|
        wrappedFn = function(acc, item, index) {
 | 
						|
          return fn.call(this, acc, toReactive(item), index, self);
 | 
						|
        };
 | 
						|
      } else if (fn.length > 3) {
 | 
						|
        wrappedFn = function(acc, item, index) {
 | 
						|
          return fn.call(this, acc, item, index, self);
 | 
						|
        };
 | 
						|
      }
 | 
						|
    }
 | 
						|
    return arr[method](wrappedFn, ...args);
 | 
						|
  }
 | 
						|
  function searchProxy(self, method, args) {
 | 
						|
    const arr = toRaw(self);
 | 
						|
    track(arr, "iterate", ARRAY_ITERATE_KEY);
 | 
						|
    const res = arr[method](...args);
 | 
						|
    if ((res === -1 || res === false) && isProxy(args[0])) {
 | 
						|
      args[0] = toRaw(args[0]);
 | 
						|
      return arr[method](...args);
 | 
						|
    }
 | 
						|
    return res;
 | 
						|
  }
 | 
						|
  function noTracking(self, method, args = []) {
 | 
						|
    pauseTracking();
 | 
						|
    startBatch();
 | 
						|
    const res = toRaw(self)[method].apply(self, args);
 | 
						|
    endBatch();
 | 
						|
    resetTracking();
 | 
						|
    return res;
 | 
						|
  }
 | 
						|
 | 
						|
  const isNonTrackableKeys = /* @__PURE__ */ makeMap(`__proto__,__v_isRef,__isVue`);
 | 
						|
  const builtInSymbols = new Set(
 | 
						|
    /* @__PURE__ */ Object.getOwnPropertyNames(Symbol).filter((key) => key !== "arguments" && key !== "caller").map((key) => Symbol[key]).filter(isSymbol)
 | 
						|
  );
 | 
						|
  function hasOwnProperty(key) {
 | 
						|
    if (!isSymbol(key)) key = String(key);
 | 
						|
    const obj = toRaw(this);
 | 
						|
    track(obj, "has", key);
 | 
						|
    return obj.hasOwnProperty(key);
 | 
						|
  }
 | 
						|
  class BaseReactiveHandler {
 | 
						|
    constructor(_isReadonly = false, _isShallow = false) {
 | 
						|
      this._isReadonly = _isReadonly;
 | 
						|
      this._isShallow = _isShallow;
 | 
						|
    }
 | 
						|
    get(target, key, receiver) {
 | 
						|
      if (key === "__v_skip") return target["__v_skip"];
 | 
						|
      const isReadonly2 = this._isReadonly, isShallow2 = this._isShallow;
 | 
						|
      if (key === "__v_isReactive") {
 | 
						|
        return !isReadonly2;
 | 
						|
      } else if (key === "__v_isReadonly") {
 | 
						|
        return isReadonly2;
 | 
						|
      } else if (key === "__v_isShallow") {
 | 
						|
        return isShallow2;
 | 
						|
      } else if (key === "__v_raw") {
 | 
						|
        if (receiver === (isReadonly2 ? isShallow2 ? shallowReadonlyMap : readonlyMap : isShallow2 ? shallowReactiveMap : reactiveMap).get(target) || // receiver is not the reactive proxy, but has the same prototype
 | 
						|
        // this means the receiver is a user proxy of the reactive proxy
 | 
						|
        Object.getPrototypeOf(target) === Object.getPrototypeOf(receiver)) {
 | 
						|
          return target;
 | 
						|
        }
 | 
						|
        return;
 | 
						|
      }
 | 
						|
      const targetIsArray = isArray(target);
 | 
						|
      if (!isReadonly2) {
 | 
						|
        let fn;
 | 
						|
        if (targetIsArray && (fn = arrayInstrumentations[key])) {
 | 
						|
          return fn;
 | 
						|
        }
 | 
						|
        if (key === "hasOwnProperty") {
 | 
						|
          return hasOwnProperty;
 | 
						|
        }
 | 
						|
      }
 | 
						|
      const res = Reflect.get(
 | 
						|
        target,
 | 
						|
        key,
 | 
						|
        // if this is a proxy wrapping a ref, return methods using the raw ref
 | 
						|
        // as receiver so that we don't have to call `toRaw` on the ref in all
 | 
						|
        // its class methods
 | 
						|
        isRef(target) ? target : receiver
 | 
						|
      );
 | 
						|
      if (isSymbol(key) ? builtInSymbols.has(key) : isNonTrackableKeys(key)) {
 | 
						|
        return res;
 | 
						|
      }
 | 
						|
      if (!isReadonly2) {
 | 
						|
        track(target, "get", key);
 | 
						|
      }
 | 
						|
      if (isShallow2) {
 | 
						|
        return res;
 | 
						|
      }
 | 
						|
      if (isRef(res)) {
 | 
						|
        return targetIsArray && isIntegerKey(key) ? res : res.value;
 | 
						|
      }
 | 
						|
      if (isObject(res)) {
 | 
						|
        return isReadonly2 ? readonly(res) : reactive(res);
 | 
						|
      }
 | 
						|
      return res;
 | 
						|
    }
 | 
						|
  }
 | 
						|
  class MutableReactiveHandler extends BaseReactiveHandler {
 | 
						|
    constructor(isShallow2 = false) {
 | 
						|
      super(false, isShallow2);
 | 
						|
    }
 | 
						|
    set(target, key, value, receiver) {
 | 
						|
      let oldValue = target[key];
 | 
						|
      if (!this._isShallow) {
 | 
						|
        const isOldValueReadonly = isReadonly(oldValue);
 | 
						|
        if (!isShallow(value) && !isReadonly(value)) {
 | 
						|
          oldValue = toRaw(oldValue);
 | 
						|
          value = toRaw(value);
 | 
						|
        }
 | 
						|
        if (!isArray(target) && isRef(oldValue) && !isRef(value)) {
 | 
						|
          if (isOldValueReadonly) {
 | 
						|
            {
 | 
						|
              warn(
 | 
						|
                `Set operation on key "${String(key)}" failed: target is readonly.`,
 | 
						|
                target[key]
 | 
						|
              );
 | 
						|
            }
 | 
						|
            return true;
 | 
						|
          } else {
 | 
						|
            oldValue.value = value;
 | 
						|
            return true;
 | 
						|
          }
 | 
						|
        }
 | 
						|
      }
 | 
						|
      const hadKey = isArray(target) && isIntegerKey(key) ? Number(key) < target.length : hasOwn(target, key);
 | 
						|
      const result = Reflect.set(
 | 
						|
        target,
 | 
						|
        key,
 | 
						|
        value,
 | 
						|
        isRef(target) ? target : receiver
 | 
						|
      );
 | 
						|
      if (target === toRaw(receiver)) {
 | 
						|
        if (!hadKey) {
 | 
						|
          trigger(target, "add", key, value);
 | 
						|
        } else if (hasChanged(value, oldValue)) {
 | 
						|
          trigger(target, "set", key, value, oldValue);
 | 
						|
        }
 | 
						|
      }
 | 
						|
      return result;
 | 
						|
    }
 | 
						|
    deleteProperty(target, key) {
 | 
						|
      const hadKey = hasOwn(target, key);
 | 
						|
      const oldValue = target[key];
 | 
						|
      const result = Reflect.deleteProperty(target, key);
 | 
						|
      if (result && hadKey) {
 | 
						|
        trigger(target, "delete", key, void 0, oldValue);
 | 
						|
      }
 | 
						|
      return result;
 | 
						|
    }
 | 
						|
    has(target, key) {
 | 
						|
      const result = Reflect.has(target, key);
 | 
						|
      if (!isSymbol(key) || !builtInSymbols.has(key)) {
 | 
						|
        track(target, "has", key);
 | 
						|
      }
 | 
						|
      return result;
 | 
						|
    }
 | 
						|
    ownKeys(target) {
 | 
						|
      track(
 | 
						|
        target,
 | 
						|
        "iterate",
 | 
						|
        isArray(target) ? "length" : ITERATE_KEY
 | 
						|
      );
 | 
						|
      return Reflect.ownKeys(target);
 | 
						|
    }
 | 
						|
  }
 | 
						|
  class ReadonlyReactiveHandler extends BaseReactiveHandler {
 | 
						|
    constructor(isShallow2 = false) {
 | 
						|
      super(true, isShallow2);
 | 
						|
    }
 | 
						|
    set(target, key) {
 | 
						|
      {
 | 
						|
        warn(
 | 
						|
          `Set operation on key "${String(key)}" failed: target is readonly.`,
 | 
						|
          target
 | 
						|
        );
 | 
						|
      }
 | 
						|
      return true;
 | 
						|
    }
 | 
						|
    deleteProperty(target, key) {
 | 
						|
      {
 | 
						|
        warn(
 | 
						|
          `Delete operation on key "${String(key)}" failed: target is readonly.`,
 | 
						|
          target
 | 
						|
        );
 | 
						|
      }
 | 
						|
      return true;
 | 
						|
    }
 | 
						|
  }
 | 
						|
  const mutableHandlers = /* @__PURE__ */ new MutableReactiveHandler();
 | 
						|
  const readonlyHandlers = /* @__PURE__ */ new ReadonlyReactiveHandler();
 | 
						|
  const shallowReactiveHandlers = /* @__PURE__ */ new MutableReactiveHandler(true);
 | 
						|
  const shallowReadonlyHandlers = /* @__PURE__ */ new ReadonlyReactiveHandler(true);
 | 
						|
 | 
						|
  const toShallow = (value) => value;
 | 
						|
  const getProto = (v) => Reflect.getPrototypeOf(v);
 | 
						|
  function createIterableMethod(method, isReadonly2, isShallow2) {
 | 
						|
    return function(...args) {
 | 
						|
      const target = this["__v_raw"];
 | 
						|
      const rawTarget = toRaw(target);
 | 
						|
      const targetIsMap = isMap(rawTarget);
 | 
						|
      const isPair = method === "entries" || method === Symbol.iterator && targetIsMap;
 | 
						|
      const isKeyOnly = method === "keys" && targetIsMap;
 | 
						|
      const innerIterator = target[method](...args);
 | 
						|
      const wrap = isShallow2 ? toShallow : isReadonly2 ? toReadonly : toReactive;
 | 
						|
      !isReadonly2 && track(
 | 
						|
        rawTarget,
 | 
						|
        "iterate",
 | 
						|
        isKeyOnly ? MAP_KEY_ITERATE_KEY : ITERATE_KEY
 | 
						|
      );
 | 
						|
      return {
 | 
						|
        // iterator protocol
 | 
						|
        next() {
 | 
						|
          const { value, done } = innerIterator.next();
 | 
						|
          return done ? { value, done } : {
 | 
						|
            value: isPair ? [wrap(value[0]), wrap(value[1])] : wrap(value),
 | 
						|
            done
 | 
						|
          };
 | 
						|
        },
 | 
						|
        // iterable protocol
 | 
						|
        [Symbol.iterator]() {
 | 
						|
          return this;
 | 
						|
        }
 | 
						|
      };
 | 
						|
    };
 | 
						|
  }
 | 
						|
  function createReadonlyMethod(type) {
 | 
						|
    return function(...args) {
 | 
						|
      {
 | 
						|
        const key = args[0] ? `on key "${args[0]}" ` : ``;
 | 
						|
        warn(
 | 
						|
          `${capitalize(type)} operation ${key}failed: target is readonly.`,
 | 
						|
          toRaw(this)
 | 
						|
        );
 | 
						|
      }
 | 
						|
      return type === "delete" ? false : type === "clear" ? void 0 : this;
 | 
						|
    };
 | 
						|
  }
 | 
						|
  function createInstrumentations(readonly, shallow) {
 | 
						|
    const instrumentations = {
 | 
						|
      get(key) {
 | 
						|
        const target = this["__v_raw"];
 | 
						|
        const rawTarget = toRaw(target);
 | 
						|
        const rawKey = toRaw(key);
 | 
						|
        if (!readonly) {
 | 
						|
          if (hasChanged(key, rawKey)) {
 | 
						|
            track(rawTarget, "get", key);
 | 
						|
          }
 | 
						|
          track(rawTarget, "get", rawKey);
 | 
						|
        }
 | 
						|
        const { has } = getProto(rawTarget);
 | 
						|
        const wrap = shallow ? toShallow : readonly ? toReadonly : toReactive;
 | 
						|
        if (has.call(rawTarget, key)) {
 | 
						|
          return wrap(target.get(key));
 | 
						|
        } else if (has.call(rawTarget, rawKey)) {
 | 
						|
          return wrap(target.get(rawKey));
 | 
						|
        } else if (target !== rawTarget) {
 | 
						|
          target.get(key);
 | 
						|
        }
 | 
						|
      },
 | 
						|
      get size() {
 | 
						|
        const target = this["__v_raw"];
 | 
						|
        !readonly && track(toRaw(target), "iterate", ITERATE_KEY);
 | 
						|
        return target.size;
 | 
						|
      },
 | 
						|
      has(key) {
 | 
						|
        const target = this["__v_raw"];
 | 
						|
        const rawTarget = toRaw(target);
 | 
						|
        const rawKey = toRaw(key);
 | 
						|
        if (!readonly) {
 | 
						|
          if (hasChanged(key, rawKey)) {
 | 
						|
            track(rawTarget, "has", key);
 | 
						|
          }
 | 
						|
          track(rawTarget, "has", rawKey);
 | 
						|
        }
 | 
						|
        return key === rawKey ? target.has(key) : target.has(key) || target.has(rawKey);
 | 
						|
      },
 | 
						|
      forEach(callback, thisArg) {
 | 
						|
        const observed = this;
 | 
						|
        const target = observed["__v_raw"];
 | 
						|
        const rawTarget = toRaw(target);
 | 
						|
        const wrap = shallow ? toShallow : readonly ? toReadonly : toReactive;
 | 
						|
        !readonly && track(rawTarget, "iterate", ITERATE_KEY);
 | 
						|
        return target.forEach((value, key) => {
 | 
						|
          return callback.call(thisArg, wrap(value), wrap(key), observed);
 | 
						|
        });
 | 
						|
      }
 | 
						|
    };
 | 
						|
    extend(
 | 
						|
      instrumentations,
 | 
						|
      readonly ? {
 | 
						|
        add: createReadonlyMethod("add"),
 | 
						|
        set: createReadonlyMethod("set"),
 | 
						|
        delete: createReadonlyMethod("delete"),
 | 
						|
        clear: createReadonlyMethod("clear")
 | 
						|
      } : {
 | 
						|
        add(value) {
 | 
						|
          if (!shallow && !isShallow(value) && !isReadonly(value)) {
 | 
						|
            value = toRaw(value);
 | 
						|
          }
 | 
						|
          const target = toRaw(this);
 | 
						|
          const proto = getProto(target);
 | 
						|
          const hadKey = proto.has.call(target, value);
 | 
						|
          if (!hadKey) {
 | 
						|
            target.add(value);
 | 
						|
            trigger(target, "add", value, value);
 | 
						|
          }
 | 
						|
          return this;
 | 
						|
        },
 | 
						|
        set(key, value) {
 | 
						|
          if (!shallow && !isShallow(value) && !isReadonly(value)) {
 | 
						|
            value = toRaw(value);
 | 
						|
          }
 | 
						|
          const target = toRaw(this);
 | 
						|
          const { has, get } = getProto(target);
 | 
						|
          let hadKey = has.call(target, key);
 | 
						|
          if (!hadKey) {
 | 
						|
            key = toRaw(key);
 | 
						|
            hadKey = has.call(target, key);
 | 
						|
          } else {
 | 
						|
            checkIdentityKeys(target, has, key);
 | 
						|
          }
 | 
						|
          const oldValue = get.call(target, key);
 | 
						|
          target.set(key, value);
 | 
						|
          if (!hadKey) {
 | 
						|
            trigger(target, "add", key, value);
 | 
						|
          } else if (hasChanged(value, oldValue)) {
 | 
						|
            trigger(target, "set", key, value, oldValue);
 | 
						|
          }
 | 
						|
          return this;
 | 
						|
        },
 | 
						|
        delete(key) {
 | 
						|
          const target = toRaw(this);
 | 
						|
          const { has, get } = getProto(target);
 | 
						|
          let hadKey = has.call(target, key);
 | 
						|
          if (!hadKey) {
 | 
						|
            key = toRaw(key);
 | 
						|
            hadKey = has.call(target, key);
 | 
						|
          } else {
 | 
						|
            checkIdentityKeys(target, has, key);
 | 
						|
          }
 | 
						|
          const oldValue = get ? get.call(target, key) : void 0;
 | 
						|
          const result = target.delete(key);
 | 
						|
          if (hadKey) {
 | 
						|
            trigger(target, "delete", key, void 0, oldValue);
 | 
						|
          }
 | 
						|
          return result;
 | 
						|
        },
 | 
						|
        clear() {
 | 
						|
          const target = toRaw(this);
 | 
						|
          const hadItems = target.size !== 0;
 | 
						|
          const oldTarget = isMap(target) ? new Map(target) : new Set(target) ;
 | 
						|
          const result = target.clear();
 | 
						|
          if (hadItems) {
 | 
						|
            trigger(
 | 
						|
              target,
 | 
						|
              "clear",
 | 
						|
              void 0,
 | 
						|
              void 0,
 | 
						|
              oldTarget
 | 
						|
            );
 | 
						|
          }
 | 
						|
          return result;
 | 
						|
        }
 | 
						|
      }
 | 
						|
    );
 | 
						|
    const iteratorMethods = [
 | 
						|
      "keys",
 | 
						|
      "values",
 | 
						|
      "entries",
 | 
						|
      Symbol.iterator
 | 
						|
    ];
 | 
						|
    iteratorMethods.forEach((method) => {
 | 
						|
      instrumentations[method] = createIterableMethod(method, readonly, shallow);
 | 
						|
    });
 | 
						|
    return instrumentations;
 | 
						|
  }
 | 
						|
  function createInstrumentationGetter(isReadonly2, shallow) {
 | 
						|
    const instrumentations = createInstrumentations(isReadonly2, shallow);
 | 
						|
    return (target, key, receiver) => {
 | 
						|
      if (key === "__v_isReactive") {
 | 
						|
        return !isReadonly2;
 | 
						|
      } else if (key === "__v_isReadonly") {
 | 
						|
        return isReadonly2;
 | 
						|
      } else if (key === "__v_raw") {
 | 
						|
        return target;
 | 
						|
      }
 | 
						|
      return Reflect.get(
 | 
						|
        hasOwn(instrumentations, key) && key in target ? instrumentations : target,
 | 
						|
        key,
 | 
						|
        receiver
 | 
						|
      );
 | 
						|
    };
 | 
						|
  }
 | 
						|
  const mutableCollectionHandlers = {
 | 
						|
    get: /* @__PURE__ */ createInstrumentationGetter(false, false)
 | 
						|
  };
 | 
						|
  const shallowCollectionHandlers = {
 | 
						|
    get: /* @__PURE__ */ createInstrumentationGetter(false, true)
 | 
						|
  };
 | 
						|
  const readonlyCollectionHandlers = {
 | 
						|
    get: /* @__PURE__ */ createInstrumentationGetter(true, false)
 | 
						|
  };
 | 
						|
  const shallowReadonlyCollectionHandlers = {
 | 
						|
    get: /* @__PURE__ */ createInstrumentationGetter(true, true)
 | 
						|
  };
 | 
						|
  function checkIdentityKeys(target, has, key) {
 | 
						|
    const rawKey = toRaw(key);
 | 
						|
    if (rawKey !== key && has.call(target, rawKey)) {
 | 
						|
      const type = toRawType(target);
 | 
						|
      warn(
 | 
						|
        `Reactive ${type} contains both the raw and reactive versions of the same object${type === `Map` ? ` as keys` : ``}, which can lead to inconsistencies. Avoid differentiating between the raw and reactive versions of an object and only use the reactive version if possible.`
 | 
						|
      );
 | 
						|
    }
 | 
						|
  }
 | 
						|
 | 
						|
  const reactiveMap = /* @__PURE__ */ new WeakMap();
 | 
						|
  const shallowReactiveMap = /* @__PURE__ */ new WeakMap();
 | 
						|
  const readonlyMap = /* @__PURE__ */ new WeakMap();
 | 
						|
  const shallowReadonlyMap = /* @__PURE__ */ new WeakMap();
 | 
						|
  function targetTypeMap(rawType) {
 | 
						|
    switch (rawType) {
 | 
						|
      case "Object":
 | 
						|
      case "Array":
 | 
						|
        return 1 /* COMMON */;
 | 
						|
      case "Map":
 | 
						|
      case "Set":
 | 
						|
      case "WeakMap":
 | 
						|
      case "WeakSet":
 | 
						|
        return 2 /* COLLECTION */;
 | 
						|
      default:
 | 
						|
        return 0 /* INVALID */;
 | 
						|
    }
 | 
						|
  }
 | 
						|
  function getTargetType(value) {
 | 
						|
    return value["__v_skip"] || !Object.isExtensible(value) ? 0 /* INVALID */ : targetTypeMap(toRawType(value));
 | 
						|
  }
 | 
						|
  function reactive(target) {
 | 
						|
    if (isReadonly(target)) {
 | 
						|
      return target;
 | 
						|
    }
 | 
						|
    return createReactiveObject(
 | 
						|
      target,
 | 
						|
      false,
 | 
						|
      mutableHandlers,
 | 
						|
      mutableCollectionHandlers,
 | 
						|
      reactiveMap
 | 
						|
    );
 | 
						|
  }
 | 
						|
  function shallowReactive(target) {
 | 
						|
    return createReactiveObject(
 | 
						|
      target,
 | 
						|
      false,
 | 
						|
      shallowReactiveHandlers,
 | 
						|
      shallowCollectionHandlers,
 | 
						|
      shallowReactiveMap
 | 
						|
    );
 | 
						|
  }
 | 
						|
  function readonly(target) {
 | 
						|
    return createReactiveObject(
 | 
						|
      target,
 | 
						|
      true,
 | 
						|
      readonlyHandlers,
 | 
						|
      readonlyCollectionHandlers,
 | 
						|
      readonlyMap
 | 
						|
    );
 | 
						|
  }
 | 
						|
  function shallowReadonly(target) {
 | 
						|
    return createReactiveObject(
 | 
						|
      target,
 | 
						|
      true,
 | 
						|
      shallowReadonlyHandlers,
 | 
						|
      shallowReadonlyCollectionHandlers,
 | 
						|
      shallowReadonlyMap
 | 
						|
    );
 | 
						|
  }
 | 
						|
  function createReactiveObject(target, isReadonly2, baseHandlers, collectionHandlers, proxyMap) {
 | 
						|
    if (!isObject(target)) {
 | 
						|
      {
 | 
						|
        warn(
 | 
						|
          `value cannot be made ${isReadonly2 ? "readonly" : "reactive"}: ${String(
 | 
						|
          target
 | 
						|
        )}`
 | 
						|
        );
 | 
						|
      }
 | 
						|
      return target;
 | 
						|
    }
 | 
						|
    if (target["__v_raw"] && !(isReadonly2 && target["__v_isReactive"])) {
 | 
						|
      return target;
 | 
						|
    }
 | 
						|
    const targetType = getTargetType(target);
 | 
						|
    if (targetType === 0 /* INVALID */) {
 | 
						|
      return target;
 | 
						|
    }
 | 
						|
    const existingProxy = proxyMap.get(target);
 | 
						|
    if (existingProxy) {
 | 
						|
      return existingProxy;
 | 
						|
    }
 | 
						|
    const proxy = new Proxy(
 | 
						|
      target,
 | 
						|
      targetType === 2 /* COLLECTION */ ? collectionHandlers : baseHandlers
 | 
						|
    );
 | 
						|
    proxyMap.set(target, proxy);
 | 
						|
    return proxy;
 | 
						|
  }
 | 
						|
  function isReactive(value) {
 | 
						|
    if (isReadonly(value)) {
 | 
						|
      return isReactive(value["__v_raw"]);
 | 
						|
    }
 | 
						|
    return !!(value && value["__v_isReactive"]);
 | 
						|
  }
 | 
						|
  function isReadonly(value) {
 | 
						|
    return !!(value && value["__v_isReadonly"]);
 | 
						|
  }
 | 
						|
  function isShallow(value) {
 | 
						|
    return !!(value && value["__v_isShallow"]);
 | 
						|
  }
 | 
						|
  function isProxy(value) {
 | 
						|
    return value ? !!value["__v_raw"] : false;
 | 
						|
  }
 | 
						|
  function toRaw(observed) {
 | 
						|
    const raw = observed && observed["__v_raw"];
 | 
						|
    return raw ? toRaw(raw) : observed;
 | 
						|
  }
 | 
						|
  function markRaw(value) {
 | 
						|
    if (!hasOwn(value, "__v_skip") && Object.isExtensible(value)) {
 | 
						|
      def(value, "__v_skip", true);
 | 
						|
    }
 | 
						|
    return value;
 | 
						|
  }
 | 
						|
  const toReactive = (value) => isObject(value) ? reactive(value) : value;
 | 
						|
  const toReadonly = (value) => isObject(value) ? readonly(value) : value;
 | 
						|
 | 
						|
  function isRef(r) {
 | 
						|
    return r ? r["__v_isRef"] === true : false;
 | 
						|
  }
 | 
						|
  function ref(value) {
 | 
						|
    return createRef(value, false);
 | 
						|
  }
 | 
						|
  function shallowRef(value) {
 | 
						|
    return createRef(value, true);
 | 
						|
  }
 | 
						|
  function createRef(rawValue, shallow) {
 | 
						|
    if (isRef(rawValue)) {
 | 
						|
      return rawValue;
 | 
						|
    }
 | 
						|
    return new RefImpl(rawValue, shallow);
 | 
						|
  }
 | 
						|
  class RefImpl {
 | 
						|
    constructor(value, isShallow2) {
 | 
						|
      this.dep = new Dep();
 | 
						|
      this["__v_isRef"] = true;
 | 
						|
      this["__v_isShallow"] = false;
 | 
						|
      this._rawValue = isShallow2 ? value : toRaw(value);
 | 
						|
      this._value = isShallow2 ? value : toReactive(value);
 | 
						|
      this["__v_isShallow"] = isShallow2;
 | 
						|
    }
 | 
						|
    get value() {
 | 
						|
      {
 | 
						|
        this.dep.track({
 | 
						|
          target: this,
 | 
						|
          type: "get",
 | 
						|
          key: "value"
 | 
						|
        });
 | 
						|
      }
 | 
						|
      return this._value;
 | 
						|
    }
 | 
						|
    set value(newValue) {
 | 
						|
      const oldValue = this._rawValue;
 | 
						|
      const useDirectValue = this["__v_isShallow"] || isShallow(newValue) || isReadonly(newValue);
 | 
						|
      newValue = useDirectValue ? newValue : toRaw(newValue);
 | 
						|
      if (hasChanged(newValue, oldValue)) {
 | 
						|
        this._rawValue = newValue;
 | 
						|
        this._value = useDirectValue ? newValue : toReactive(newValue);
 | 
						|
        {
 | 
						|
          this.dep.trigger({
 | 
						|
            target: this,
 | 
						|
            type: "set",
 | 
						|
            key: "value",
 | 
						|
            newValue,
 | 
						|
            oldValue
 | 
						|
          });
 | 
						|
        }
 | 
						|
      }
 | 
						|
    }
 | 
						|
  }
 | 
						|
  function triggerRef(ref2) {
 | 
						|
    if (ref2.dep) {
 | 
						|
      {
 | 
						|
        ref2.dep.trigger({
 | 
						|
          target: ref2,
 | 
						|
          type: "set",
 | 
						|
          key: "value",
 | 
						|
          newValue: ref2._value
 | 
						|
        });
 | 
						|
      }
 | 
						|
    }
 | 
						|
  }
 | 
						|
  function unref(ref2) {
 | 
						|
    return isRef(ref2) ? ref2.value : ref2;
 | 
						|
  }
 | 
						|
  function toValue(source) {
 | 
						|
    return isFunction(source) ? source() : unref(source);
 | 
						|
  }
 | 
						|
  const shallowUnwrapHandlers = {
 | 
						|
    get: (target, key, receiver) => key === "__v_raw" ? target : unref(Reflect.get(target, key, receiver)),
 | 
						|
    set: (target, key, value, receiver) => {
 | 
						|
      const oldValue = target[key];
 | 
						|
      if (isRef(oldValue) && !isRef(value)) {
 | 
						|
        oldValue.value = value;
 | 
						|
        return true;
 | 
						|
      } else {
 | 
						|
        return Reflect.set(target, key, value, receiver);
 | 
						|
      }
 | 
						|
    }
 | 
						|
  };
 | 
						|
  function proxyRefs(objectWithRefs) {
 | 
						|
    return isReactive(objectWithRefs) ? objectWithRefs : new Proxy(objectWithRefs, shallowUnwrapHandlers);
 | 
						|
  }
 | 
						|
  class CustomRefImpl {
 | 
						|
    constructor(factory) {
 | 
						|
      this["__v_isRef"] = true;
 | 
						|
      this._value = void 0;
 | 
						|
      const dep = this.dep = new Dep();
 | 
						|
      const { get, set } = factory(dep.track.bind(dep), dep.trigger.bind(dep));
 | 
						|
      this._get = get;
 | 
						|
      this._set = set;
 | 
						|
    }
 | 
						|
    get value() {
 | 
						|
      return this._value = this._get();
 | 
						|
    }
 | 
						|
    set value(newVal) {
 | 
						|
      this._set(newVal);
 | 
						|
    }
 | 
						|
  }
 | 
						|
  function customRef(factory) {
 | 
						|
    return new CustomRefImpl(factory);
 | 
						|
  }
 | 
						|
  function toRefs(object) {
 | 
						|
    if (!isProxy(object)) {
 | 
						|
      warn(`toRefs() expects a reactive object but received a plain one.`);
 | 
						|
    }
 | 
						|
    const ret = isArray(object) ? new Array(object.length) : {};
 | 
						|
    for (const key in object) {
 | 
						|
      ret[key] = propertyToRef(object, key);
 | 
						|
    }
 | 
						|
    return ret;
 | 
						|
  }
 | 
						|
  class ObjectRefImpl {
 | 
						|
    constructor(_object, _key, _defaultValue) {
 | 
						|
      this._object = _object;
 | 
						|
      this._key = _key;
 | 
						|
      this._defaultValue = _defaultValue;
 | 
						|
      this["__v_isRef"] = true;
 | 
						|
      this._value = void 0;
 | 
						|
    }
 | 
						|
    get value() {
 | 
						|
      const val = this._object[this._key];
 | 
						|
      return this._value = val === void 0 ? this._defaultValue : val;
 | 
						|
    }
 | 
						|
    set value(newVal) {
 | 
						|
      this._object[this._key] = newVal;
 | 
						|
    }
 | 
						|
    get dep() {
 | 
						|
      return getDepFromReactive(toRaw(this._object), this._key);
 | 
						|
    }
 | 
						|
  }
 | 
						|
  class GetterRefImpl {
 | 
						|
    constructor(_getter) {
 | 
						|
      this._getter = _getter;
 | 
						|
      this["__v_isRef"] = true;
 | 
						|
      this["__v_isReadonly"] = true;
 | 
						|
      this._value = void 0;
 | 
						|
    }
 | 
						|
    get value() {
 | 
						|
      return this._value = this._getter();
 | 
						|
    }
 | 
						|
  }
 | 
						|
  function toRef(source, key, defaultValue) {
 | 
						|
    if (isRef(source)) {
 | 
						|
      return source;
 | 
						|
    } else if (isFunction(source)) {
 | 
						|
      return new GetterRefImpl(source);
 | 
						|
    } else if (isObject(source) && arguments.length > 1) {
 | 
						|
      return propertyToRef(source, key, defaultValue);
 | 
						|
    } else {
 | 
						|
      return ref(source);
 | 
						|
    }
 | 
						|
  }
 | 
						|
  function propertyToRef(source, key, defaultValue) {
 | 
						|
    const val = source[key];
 | 
						|
    return isRef(val) ? val : new ObjectRefImpl(source, key, defaultValue);
 | 
						|
  }
 | 
						|
 | 
						|
  class ComputedRefImpl {
 | 
						|
    constructor(fn, setter, isSSR) {
 | 
						|
      this.fn = fn;
 | 
						|
      this.setter = setter;
 | 
						|
      /**
 | 
						|
       * @internal
 | 
						|
       */
 | 
						|
      this._value = void 0;
 | 
						|
      /**
 | 
						|
       * @internal
 | 
						|
       */
 | 
						|
      this.dep = new Dep(this);
 | 
						|
      /**
 | 
						|
       * @internal
 | 
						|
       */
 | 
						|
      this.__v_isRef = true;
 | 
						|
      // TODO isolatedDeclarations "__v_isReadonly"
 | 
						|
      // A computed is also a subscriber that tracks other deps
 | 
						|
      /**
 | 
						|
       * @internal
 | 
						|
       */
 | 
						|
      this.deps = void 0;
 | 
						|
      /**
 | 
						|
       * @internal
 | 
						|
       */
 | 
						|
      this.depsTail = void 0;
 | 
						|
      /**
 | 
						|
       * @internal
 | 
						|
       */
 | 
						|
      this.flags = 16;
 | 
						|
      /**
 | 
						|
       * @internal
 | 
						|
       */
 | 
						|
      this.globalVersion = globalVersion - 1;
 | 
						|
      /**
 | 
						|
       * @internal
 | 
						|
       */
 | 
						|
      this.next = void 0;
 | 
						|
      // for backwards compat
 | 
						|
      this.effect = this;
 | 
						|
      this["__v_isReadonly"] = !setter;
 | 
						|
      this.isSSR = isSSR;
 | 
						|
    }
 | 
						|
    /**
 | 
						|
     * @internal
 | 
						|
     */
 | 
						|
    notify() {
 | 
						|
      this.flags |= 16;
 | 
						|
      if (!(this.flags & 8) && // avoid infinite self recursion
 | 
						|
      activeSub !== this) {
 | 
						|
        batch(this, true);
 | 
						|
        return true;
 | 
						|
      }
 | 
						|
    }
 | 
						|
    get value() {
 | 
						|
      const link = this.dep.track({
 | 
						|
        target: this,
 | 
						|
        type: "get",
 | 
						|
        key: "value"
 | 
						|
      }) ;
 | 
						|
      refreshComputed(this);
 | 
						|
      if (link) {
 | 
						|
        link.version = this.dep.version;
 | 
						|
      }
 | 
						|
      return this._value;
 | 
						|
    }
 | 
						|
    set value(newValue) {
 | 
						|
      if (this.setter) {
 | 
						|
        this.setter(newValue);
 | 
						|
      } else {
 | 
						|
        warn("Write operation failed: computed value is readonly");
 | 
						|
      }
 | 
						|
    }
 | 
						|
  }
 | 
						|
  function computed(getterOrOptions, debugOptions, isSSR = false) {
 | 
						|
    let getter;
 | 
						|
    let setter;
 | 
						|
    if (isFunction(getterOrOptions)) {
 | 
						|
      getter = getterOrOptions;
 | 
						|
    } else {
 | 
						|
      getter = getterOrOptions.get;
 | 
						|
      setter = getterOrOptions.set;
 | 
						|
    }
 | 
						|
    const cRef = new ComputedRefImpl(getter, setter, isSSR);
 | 
						|
    if (debugOptions && !isSSR) {
 | 
						|
      cRef.onTrack = debugOptions.onTrack;
 | 
						|
      cRef.onTrigger = debugOptions.onTrigger;
 | 
						|
    }
 | 
						|
    return cRef;
 | 
						|
  }
 | 
						|
 | 
						|
  const TrackOpTypes = {
 | 
						|
    "GET": "get",
 | 
						|
    "HAS": "has",
 | 
						|
    "ITERATE": "iterate"
 | 
						|
  };
 | 
						|
  const TriggerOpTypes = {
 | 
						|
    "SET": "set",
 | 
						|
    "ADD": "add",
 | 
						|
    "DELETE": "delete",
 | 
						|
    "CLEAR": "clear"
 | 
						|
  };
 | 
						|
  const ReactiveFlags = {
 | 
						|
    "SKIP": "__v_skip",
 | 
						|
    "IS_REACTIVE": "__v_isReactive",
 | 
						|
    "IS_READONLY": "__v_isReadonly",
 | 
						|
    "IS_SHALLOW": "__v_isShallow",
 | 
						|
    "RAW": "__v_raw",
 | 
						|
    "IS_REF": "__v_isRef"
 | 
						|
  };
 | 
						|
 | 
						|
  const WatchErrorCodes = {
 | 
						|
    "WATCH_GETTER": 2,
 | 
						|
    "2": "WATCH_GETTER",
 | 
						|
    "WATCH_CALLBACK": 3,
 | 
						|
    "3": "WATCH_CALLBACK",
 | 
						|
    "WATCH_CLEANUP": 4,
 | 
						|
    "4": "WATCH_CLEANUP"
 | 
						|
  };
 | 
						|
  const INITIAL_WATCHER_VALUE = {};
 | 
						|
  const cleanupMap = /* @__PURE__ */ new WeakMap();
 | 
						|
  let activeWatcher = void 0;
 | 
						|
  function getCurrentWatcher() {
 | 
						|
    return activeWatcher;
 | 
						|
  }
 | 
						|
  function onWatcherCleanup(cleanupFn, failSilently = false, owner = activeWatcher) {
 | 
						|
    if (owner) {
 | 
						|
      let cleanups = cleanupMap.get(owner);
 | 
						|
      if (!cleanups) cleanupMap.set(owner, cleanups = []);
 | 
						|
      cleanups.push(cleanupFn);
 | 
						|
    } else if (!failSilently) {
 | 
						|
      warn(
 | 
						|
        `onWatcherCleanup() was called when there was no active watcher to associate with.`
 | 
						|
      );
 | 
						|
    }
 | 
						|
  }
 | 
						|
  function watch(source, cb, options = EMPTY_OBJ) {
 | 
						|
    const { immediate, deep, once, scheduler, augmentJob, call } = options;
 | 
						|
    const warnInvalidSource = (s) => {
 | 
						|
      (options.onWarn || warn)(
 | 
						|
        `Invalid watch source: `,
 | 
						|
        s,
 | 
						|
        `A watch source can only be a getter/effect function, a ref, a reactive object, or an array of these types.`
 | 
						|
      );
 | 
						|
    };
 | 
						|
    const reactiveGetter = (source2) => {
 | 
						|
      if (deep) return source2;
 | 
						|
      if (isShallow(source2) || deep === false || deep === 0)
 | 
						|
        return traverse(source2, 1);
 | 
						|
      return traverse(source2);
 | 
						|
    };
 | 
						|
    let effect;
 | 
						|
    let getter;
 | 
						|
    let cleanup;
 | 
						|
    let boundCleanup;
 | 
						|
    let forceTrigger = false;
 | 
						|
    let isMultiSource = false;
 | 
						|
    if (isRef(source)) {
 | 
						|
      getter = () => source.value;
 | 
						|
      forceTrigger = isShallow(source);
 | 
						|
    } else if (isReactive(source)) {
 | 
						|
      getter = () => reactiveGetter(source);
 | 
						|
      forceTrigger = true;
 | 
						|
    } else if (isArray(source)) {
 | 
						|
      isMultiSource = true;
 | 
						|
      forceTrigger = source.some((s) => isReactive(s) || isShallow(s));
 | 
						|
      getter = () => source.map((s) => {
 | 
						|
        if (isRef(s)) {
 | 
						|
          return s.value;
 | 
						|
        } else if (isReactive(s)) {
 | 
						|
          return reactiveGetter(s);
 | 
						|
        } else if (isFunction(s)) {
 | 
						|
          return call ? call(s, 2) : s();
 | 
						|
        } else {
 | 
						|
          warnInvalidSource(s);
 | 
						|
        }
 | 
						|
      });
 | 
						|
    } else if (isFunction(source)) {
 | 
						|
      if (cb) {
 | 
						|
        getter = call ? () => call(source, 2) : source;
 | 
						|
      } else {
 | 
						|
        getter = () => {
 | 
						|
          if (cleanup) {
 | 
						|
            pauseTracking();
 | 
						|
            try {
 | 
						|
              cleanup();
 | 
						|
            } finally {
 | 
						|
              resetTracking();
 | 
						|
            }
 | 
						|
          }
 | 
						|
          const currentEffect = activeWatcher;
 | 
						|
          activeWatcher = effect;
 | 
						|
          try {
 | 
						|
            return call ? call(source, 3, [boundCleanup]) : source(boundCleanup);
 | 
						|
          } finally {
 | 
						|
            activeWatcher = currentEffect;
 | 
						|
          }
 | 
						|
        };
 | 
						|
      }
 | 
						|
    } else {
 | 
						|
      getter = NOOP;
 | 
						|
      warnInvalidSource(source);
 | 
						|
    }
 | 
						|
    if (cb && deep) {
 | 
						|
      const baseGetter = getter;
 | 
						|
      const depth = deep === true ? Infinity : deep;
 | 
						|
      getter = () => traverse(baseGetter(), depth);
 | 
						|
    }
 | 
						|
    const scope = getCurrentScope();
 | 
						|
    const watchHandle = () => {
 | 
						|
      effect.stop();
 | 
						|
      if (scope && scope.active) {
 | 
						|
        remove(scope.effects, effect);
 | 
						|
      }
 | 
						|
    };
 | 
						|
    if (once && cb) {
 | 
						|
      const _cb = cb;
 | 
						|
      cb = (...args) => {
 | 
						|
        _cb(...args);
 | 
						|
        watchHandle();
 | 
						|
      };
 | 
						|
    }
 | 
						|
    let oldValue = isMultiSource ? new Array(source.length).fill(INITIAL_WATCHER_VALUE) : INITIAL_WATCHER_VALUE;
 | 
						|
    const job = (immediateFirstRun) => {
 | 
						|
      if (!(effect.flags & 1) || !effect.dirty && !immediateFirstRun) {
 | 
						|
        return;
 | 
						|
      }
 | 
						|
      if (cb) {
 | 
						|
        const newValue = effect.run();
 | 
						|
        if (deep || forceTrigger || (isMultiSource ? newValue.some((v, i) => hasChanged(v, oldValue[i])) : hasChanged(newValue, oldValue))) {
 | 
						|
          if (cleanup) {
 | 
						|
            cleanup();
 | 
						|
          }
 | 
						|
          const currentWatcher = activeWatcher;
 | 
						|
          activeWatcher = effect;
 | 
						|
          try {
 | 
						|
            const args = [
 | 
						|
              newValue,
 | 
						|
              // pass undefined as the old value when it's changed for the first time
 | 
						|
              oldValue === INITIAL_WATCHER_VALUE ? void 0 : isMultiSource && oldValue[0] === INITIAL_WATCHER_VALUE ? [] : oldValue,
 | 
						|
              boundCleanup
 | 
						|
            ];
 | 
						|
            oldValue = newValue;
 | 
						|
            call ? call(cb, 3, args) : (
 | 
						|
              // @ts-expect-error
 | 
						|
              cb(...args)
 | 
						|
            );
 | 
						|
          } finally {
 | 
						|
            activeWatcher = currentWatcher;
 | 
						|
          }
 | 
						|
        }
 | 
						|
      } else {
 | 
						|
        effect.run();
 | 
						|
      }
 | 
						|
    };
 | 
						|
    if (augmentJob) {
 | 
						|
      augmentJob(job);
 | 
						|
    }
 | 
						|
    effect = new ReactiveEffect(getter);
 | 
						|
    effect.scheduler = scheduler ? () => scheduler(job, false) : job;
 | 
						|
    boundCleanup = (fn) => onWatcherCleanup(fn, false, effect);
 | 
						|
    cleanup = effect.onStop = () => {
 | 
						|
      const cleanups = cleanupMap.get(effect);
 | 
						|
      if (cleanups) {
 | 
						|
        if (call) {
 | 
						|
          call(cleanups, 4);
 | 
						|
        } else {
 | 
						|
          for (const cleanup2 of cleanups) cleanup2();
 | 
						|
        }
 | 
						|
        cleanupMap.delete(effect);
 | 
						|
      }
 | 
						|
    };
 | 
						|
    {
 | 
						|
      effect.onTrack = options.onTrack;
 | 
						|
      effect.onTrigger = options.onTrigger;
 | 
						|
    }
 | 
						|
    if (cb) {
 | 
						|
      if (immediate) {
 | 
						|
        job(true);
 | 
						|
      } else {
 | 
						|
        oldValue = effect.run();
 | 
						|
      }
 | 
						|
    } else if (scheduler) {
 | 
						|
      scheduler(job.bind(null, true), true);
 | 
						|
    } else {
 | 
						|
      effect.run();
 | 
						|
    }
 | 
						|
    watchHandle.pause = effect.pause.bind(effect);
 | 
						|
    watchHandle.resume = effect.resume.bind(effect);
 | 
						|
    watchHandle.stop = watchHandle;
 | 
						|
    return watchHandle;
 | 
						|
  }
 | 
						|
  function traverse(value, depth = Infinity, seen) {
 | 
						|
    if (depth <= 0 || !isObject(value) || value["__v_skip"]) {
 | 
						|
      return value;
 | 
						|
    }
 | 
						|
    seen = seen || /* @__PURE__ */ new Map();
 | 
						|
    if ((seen.get(value) || 0) >= depth) {
 | 
						|
      return value;
 | 
						|
    }
 | 
						|
    seen.set(value, depth);
 | 
						|
    depth--;
 | 
						|
    if (isRef(value)) {
 | 
						|
      traverse(value.value, depth, seen);
 | 
						|
    } else if (isArray(value)) {
 | 
						|
      for (let i = 0; i < value.length; i++) {
 | 
						|
        traverse(value[i], depth, seen);
 | 
						|
      }
 | 
						|
    } else if (isSet(value) || isMap(value)) {
 | 
						|
      value.forEach((v) => {
 | 
						|
        traverse(v, depth, seen);
 | 
						|
      });
 | 
						|
    } else if (isPlainObject(value)) {
 | 
						|
      for (const key in value) {
 | 
						|
        traverse(value[key], depth, seen);
 | 
						|
      }
 | 
						|
      for (const key of Object.getOwnPropertySymbols(value)) {
 | 
						|
        if (Object.prototype.propertyIsEnumerable.call(value, key)) {
 | 
						|
          traverse(value[key], depth, seen);
 | 
						|
        }
 | 
						|
      }
 | 
						|
    }
 | 
						|
    return value;
 | 
						|
  }
 | 
						|
 | 
						|
  exports.ARRAY_ITERATE_KEY = ARRAY_ITERATE_KEY;
 | 
						|
  exports.EffectFlags = EffectFlags;
 | 
						|
  exports.EffectScope = EffectScope;
 | 
						|
  exports.ITERATE_KEY = ITERATE_KEY;
 | 
						|
  exports.MAP_KEY_ITERATE_KEY = MAP_KEY_ITERATE_KEY;
 | 
						|
  exports.ReactiveEffect = ReactiveEffect;
 | 
						|
  exports.ReactiveFlags = ReactiveFlags;
 | 
						|
  exports.TrackOpTypes = TrackOpTypes;
 | 
						|
  exports.TriggerOpTypes = TriggerOpTypes;
 | 
						|
  exports.WatchErrorCodes = WatchErrorCodes;
 | 
						|
  exports.computed = computed;
 | 
						|
  exports.customRef = customRef;
 | 
						|
  exports.effect = effect;
 | 
						|
  exports.effectScope = effectScope;
 | 
						|
  exports.enableTracking = enableTracking;
 | 
						|
  exports.getCurrentScope = getCurrentScope;
 | 
						|
  exports.getCurrentWatcher = getCurrentWatcher;
 | 
						|
  exports.isProxy = isProxy;
 | 
						|
  exports.isReactive = isReactive;
 | 
						|
  exports.isReadonly = isReadonly;
 | 
						|
  exports.isRef = isRef;
 | 
						|
  exports.isShallow = isShallow;
 | 
						|
  exports.markRaw = markRaw;
 | 
						|
  exports.onEffectCleanup = onEffectCleanup;
 | 
						|
  exports.onScopeDispose = onScopeDispose;
 | 
						|
  exports.onWatcherCleanup = onWatcherCleanup;
 | 
						|
  exports.pauseTracking = pauseTracking;
 | 
						|
  exports.proxyRefs = proxyRefs;
 | 
						|
  exports.reactive = reactive;
 | 
						|
  exports.reactiveReadArray = reactiveReadArray;
 | 
						|
  exports.readonly = readonly;
 | 
						|
  exports.ref = ref;
 | 
						|
  exports.resetTracking = resetTracking;
 | 
						|
  exports.shallowReactive = shallowReactive;
 | 
						|
  exports.shallowReadArray = shallowReadArray;
 | 
						|
  exports.shallowReadonly = shallowReadonly;
 | 
						|
  exports.shallowRef = shallowRef;
 | 
						|
  exports.stop = stop;
 | 
						|
  exports.toRaw = toRaw;
 | 
						|
  exports.toReactive = toReactive;
 | 
						|
  exports.toReadonly = toReadonly;
 | 
						|
  exports.toRef = toRef;
 | 
						|
  exports.toRefs = toRefs;
 | 
						|
  exports.toValue = toValue;
 | 
						|
  exports.track = track;
 | 
						|
  exports.traverse = traverse;
 | 
						|
  exports.trigger = trigger;
 | 
						|
  exports.triggerRef = triggerRef;
 | 
						|
  exports.unref = unref;
 | 
						|
  exports.watch = watch;
 | 
						|
 | 
						|
  return exports;
 | 
						|
 | 
						|
})({});
 |