jiuyiUniapp/jiuyi2/node_modules/@vue/composition-api/dist/vue-composition-api.common.js

2295 lines
70 KiB
JavaScript

'use strict';
Object.defineProperty(exports, '__esModule', { value: true });
/******************************************************************************
Copyright (c) Microsoft Corporation.
Permission to use, copy, modify, and/or distribute this software for any
purpose with or without fee is hereby granted.
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
PERFORMANCE OF THIS SOFTWARE.
***************************************************************************** */
/* global Reflect, Promise */
var extendStatics = function(d, b) {
extendStatics = Object.setPrototypeOf ||
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
return extendStatics(d, b);
};
function __extends(d, b) {
if (typeof b !== "function" && b !== null)
throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
extendStatics(d, b);
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
}
var __assign = function() {
__assign = Object.assign || function __assign(t) {
for (var s, i = 1, n = arguments.length; i < n; i++) {
s = arguments[i];
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];
}
return t;
};
return __assign.apply(this, arguments);
};
function __values(o) {
var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
if (m) return m.call(o);
if (o && typeof o.length === "number") return {
next: function () {
if (o && i >= o.length) o = void 0;
return { value: o && o[i++], done: !o };
}
};
throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
}
function __read(o, n) {
var m = typeof Symbol === "function" && o[Symbol.iterator];
if (!m) return o;
var i = m.call(o), r, ar = [], e;
try {
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
}
catch (error) { e = { error: error }; }
finally {
try {
if (r && !r.done && (m = i["return"])) m.call(i);
}
finally { if (e) throw e.error; }
}
return ar;
}
function __spreadArray(to, from, pack) {
if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
if (ar || !(i in from)) {
if (!ar) ar = Array.prototype.slice.call(from, 0, i);
ar[i] = from[i];
}
}
return to.concat(ar || Array.prototype.slice.call(from));
}
/**
* Displays a warning message (using console.error) with a stack trace if the
* function is called inside of active component.
*
* @param message warning message to be displayed
*/
function warn$1(message) {
var _a;
warn(message, (_a = getCurrentInstance()) === null || _a === void 0 ? void 0 : _a.proxy);
}
var activeEffectScope;
var effectScopeStack = [];
var EffectScopeImpl = /** @class */ (function () {
function EffectScopeImpl(vm) {
this.active = true;
this.effects = [];
this.cleanups = [];
this.vm = vm;
}
EffectScopeImpl.prototype.run = function (fn) {
if (this.active) {
try {
this.on();
return fn();
}
finally {
this.off();
}
}
else {
warn$1("cannot run an inactive effect scope.");
}
return;
};
EffectScopeImpl.prototype.on = function () {
if (this.active) {
effectScopeStack.push(this);
activeEffectScope = this;
}
};
EffectScopeImpl.prototype.off = function () {
if (this.active) {
effectScopeStack.pop();
activeEffectScope = effectScopeStack[effectScopeStack.length - 1];
}
};
EffectScopeImpl.prototype.stop = function () {
if (this.active) {
this.vm.$destroy();
this.effects.forEach(function (e) { return e.stop(); });
this.cleanups.forEach(function (cleanup) { return cleanup(); });
this.active = false;
}
};
return EffectScopeImpl;
}());
var EffectScope = /** @class */ (function (_super) {
__extends(EffectScope, _super);
function EffectScope(detached) {
if (detached === void 0) { detached = false; }
var _this = this;
var vm = undefined;
withCurrentInstanceTrackingDisabled(function () {
vm = defineComponentInstance(getVueConstructor());
});
_this = _super.call(this, vm) || this;
if (!detached) {
recordEffectScope(_this);
}
return _this;
}
return EffectScope;
}(EffectScopeImpl));
function recordEffectScope(effect, scope) {
var _a;
scope = scope || activeEffectScope;
if (scope && scope.active) {
scope.effects.push(effect);
return;
}
// destroy on parent component unmounted
var vm = (_a = getCurrentInstance()) === null || _a === void 0 ? void 0 : _a.proxy;
vm && vm.$on('hook:destroyed', function () { return effect.stop(); });
}
function effectScope(detached) {
return new EffectScope(detached);
}
function getCurrentScope() {
return activeEffectScope;
}
function onScopeDispose(fn) {
if (activeEffectScope) {
activeEffectScope.cleanups.push(fn);
}
else {
warn$1("onScopeDispose() is called when there is no active effect scope" +
" to be associated with.");
}
}
/**
* @internal
**/
function getCurrentScopeVM() {
var _a, _b;
return ((_a = getCurrentScope()) === null || _a === void 0 ? void 0 : _a.vm) || ((_b = getCurrentInstance()) === null || _b === void 0 ? void 0 : _b.proxy);
}
/**
* @internal
**/
function bindCurrentScopeToVM(vm) {
if (!vm.scope) {
var scope_1 = new EffectScopeImpl(vm.proxy);
vm.scope = scope_1;
vm.proxy.$on('hook:destroyed', function () { return scope_1.stop(); });
}
return vm.scope;
}
var vueDependency = undefined;
try {
var requiredVue = require('vue');
if (requiredVue && isVue(requiredVue)) {
vueDependency = requiredVue;
}
else if (requiredVue &&
'default' in requiredVue &&
isVue(requiredVue.default)) {
vueDependency = requiredVue.default;
}
}
catch (_a) {
// not available
}
var vueConstructor = null;
var currentInstance = null;
var currentInstanceTracking = true;
var PluginInstalledFlag = '__composition_api_installed__';
function isVue(obj) {
return obj && isFunction(obj) && obj.name === 'Vue';
}
function isVueRegistered(Vue) {
// resolve issue: https://github.com/vuejs/composition-api/issues/876#issue-1087619365
return vueConstructor && hasOwn(Vue, PluginInstalledFlag);
}
function getVueConstructor() {
{
assert(vueConstructor, "must call Vue.use(VueCompositionAPI) before using any function.");
}
return vueConstructor;
}
// returns registered vue or `vue` dependency
function getRegisteredVueOrDefault() {
var constructor = vueConstructor || vueDependency;
{
assert(constructor, "No vue dependency found.");
}
return constructor;
}
function setVueConstructor(Vue) {
// @ts-ignore
if (vueConstructor && Vue.__proto__ !== vueConstructor.__proto__) {
warn('[vue-composition-api] another instance of Vue installed');
}
vueConstructor = Vue;
Object.defineProperty(Vue, PluginInstalledFlag, {
configurable: true,
writable: true,
value: true,
});
}
/**
* For `effectScope` to create instance without populate the current instance
* @internal
**/
function withCurrentInstanceTrackingDisabled(fn) {
var prev = currentInstanceTracking;
currentInstanceTracking = false;
try {
fn();
}
finally {
currentInstanceTracking = prev;
}
}
function setCurrentInstance(instance) {
if (!currentInstanceTracking)
return;
var prev = currentInstance;
prev === null || prev === void 0 ? void 0 : prev.scope.off();
currentInstance = instance;
currentInstance === null || currentInstance === void 0 ? void 0 : currentInstance.scope.on();
}
function getCurrentInstance() {
return currentInstance;
}
var instanceMapCache = new WeakMap();
function toVue3ComponentInstance(vm) {
if (instanceMapCache.has(vm)) {
return instanceMapCache.get(vm);
}
var instance = {
proxy: vm,
update: vm.$forceUpdate,
type: vm.$options,
uid: vm._uid,
// $emit is defined on prototype and it expected to be bound
emit: vm.$emit.bind(vm),
parent: null,
root: null, // to be immediately set
};
bindCurrentScopeToVM(instance);
// map vm.$props =
var instanceProps = [
'data',
'props',
'attrs',
'refs',
'vnode',
'slots',
];
instanceProps.forEach(function (prop) {
proxy(instance, prop, {
get: function () {
return vm["$".concat(prop)];
},
});
});
proxy(instance, 'isMounted', {
get: function () {
// @ts-expect-error private api
return vm._isMounted;
},
});
proxy(instance, 'isUnmounted', {
get: function () {
// @ts-expect-error private api
return vm._isDestroyed;
},
});
proxy(instance, 'isDeactivated', {
get: function () {
// @ts-expect-error private api
return vm._inactive;
},
});
proxy(instance, 'emitted', {
get: function () {
// @ts-expect-error private api
return vm._events;
},
});
instanceMapCache.set(vm, instance);
if (vm.$parent) {
instance.parent = toVue3ComponentInstance(vm.$parent);
}
if (vm.$root) {
instance.root = toVue3ComponentInstance(vm.$root);
}
return instance;
}
var toString = function (x) { return Object.prototype.toString.call(x); };
function isNative(Ctor) {
return typeof Ctor === 'function' && /native code/.test(Ctor.toString());
}
var hasSymbol = typeof Symbol !== 'undefined' &&
isNative(Symbol) &&
typeof Reflect !== 'undefined' &&
isNative(Reflect.ownKeys);
var noopFn = function (_) { return _; };
function proxy(target, key, _a) {
var get = _a.get, set = _a.set;
Object.defineProperty(target, key, {
enumerable: true,
configurable: true,
get: get || noopFn,
set: set || noopFn,
});
}
function def(obj, key, val, enumerable) {
Object.defineProperty(obj, key, {
value: val,
enumerable: !!enumerable,
writable: true,
configurable: true,
});
}
function hasOwn(obj, key) {
return Object.hasOwnProperty.call(obj, key);
}
function assert(condition, msg) {
if (!condition) {
throw new Error("[vue-composition-api] ".concat(msg));
}
}
function isPrimitive(value) {
return (typeof value === 'string' ||
typeof value === 'number' ||
// $flow-disable-line
typeof value === 'symbol' ||
typeof value === 'boolean');
}
function isArray(x) {
return Array.isArray(x);
}
var objectToString = Object.prototype.toString;
var toTypeString = function (value) {
return objectToString.call(value);
};
var isMap = function (val) {
return toTypeString(val) === '[object Map]';
};
var isSet = function (val) {
return toTypeString(val) === '[object Set]';
};
var MAX_VALID_ARRAY_LENGTH = 4294967295; // Math.pow(2, 32) - 1
function isValidArrayIndex(val) {
var n = parseFloat(String(val));
return (n >= 0 &&
Math.floor(n) === n &&
isFinite(val) &&
n <= MAX_VALID_ARRAY_LENGTH);
}
function isObject(val) {
return val !== null && typeof val === 'object';
}
function isPlainObject(x) {
return toString(x) === '[object Object]';
}
function isFunction(x) {
return typeof x === 'function';
}
function isUndef(v) {
return v === undefined || v === null;
}
function warn(msg, vm) {
var Vue = getRegisteredVueOrDefault();
if (!Vue || !Vue.util)
console.warn("[vue-composition-api] ".concat(msg));
else
Vue.util.warn(msg, vm);
}
function logError(err, vm, info) {
{
warn("Error in ".concat(info, ": \"").concat(err.toString(), "\""), vm);
}
if (typeof window !== 'undefined' && typeof console !== 'undefined') {
console.error(err);
}
else {
throw err;
}
}
/**
* Object.is polyfill
* https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is
* */
function isSame(value1, value2) {
if (value1 === value2) {
return value1 !== 0 || 1 / value1 === 1 / value2;
}
else {
return value1 !== value1 && value2 !== value2;
}
}
function getCurrentInstanceForFn(hook, target) {
target = target || getCurrentInstance();
if (!target) {
warn("".concat(hook, " is called when there is no active component instance to be ") +
"associated with. " +
"Lifecycle injection APIs can only be used during execution of setup().");
}
return target;
}
function defineComponentInstance(Ctor, options) {
if (options === void 0) { options = {}; }
var silent = Ctor.config.silent;
Ctor.config.silent = true;
var vm = new Ctor(options);
Ctor.config.silent = silent;
return vm;
}
function isComponentInstance(obj) {
var Vue = getVueConstructor();
return Vue && obj instanceof Vue;
}
function createSlotProxy(vm, slotName) {
return (function () {
var args = [];
for (var _i = 0; _i < arguments.length; _i++) {
args[_i] = arguments[_i];
}
if (!vm.$scopedSlots[slotName]) {
return warn("slots.".concat(slotName, "() got called outside of the \"render()\" scope"), vm);
}
return vm.$scopedSlots[slotName].apply(vm, args);
});
}
function resolveSlots(slots, normalSlots) {
var res;
if (!slots) {
res = {};
}
else if (slots._normalized) {
// fast path 1: child component re-render only, parent did not change
return slots._normalized;
}
else {
res = {};
for (var key in slots) {
if (slots[key] && key[0] !== '$') {
res[key] = true;
}
}
}
// expose normal slots on scopedSlots
for (var key in normalSlots) {
if (!(key in res)) {
res[key] = true;
}
}
return res;
}
var vueInternalClasses;
var getVueInternalClasses = function () {
if (!vueInternalClasses) {
var vm = defineComponentInstance(getVueConstructor(), {
computed: {
value: function () {
return 0;
},
},
});
// to get Watcher class
var Watcher = vm._computedWatchers.value.constructor;
// to get Dep class
var Dep = vm._data.__ob__.dep.constructor;
vueInternalClasses = {
Watcher: Watcher,
Dep: Dep,
};
vm.$destroy();
}
return vueInternalClasses;
};
function createSymbol(name) {
return hasSymbol ? Symbol.for(name) : name;
}
var WatcherPreFlushQueueKey = createSymbol('composition-api.preFlushQueue');
var WatcherPostFlushQueueKey = createSymbol('composition-api.postFlushQueue');
// must be a string, symbol key is ignored in reactive
var RefKey = 'composition-api.refKey';
var accessModifiedSet = new WeakMap();
var rawSet = new WeakMap();
var readonlySet = new WeakMap();
/**
* Set a property on an object. Adds the new property, triggers change
* notification and intercept it's subsequent access if the property doesn't
* already exist.
*/
function set$1(target, key, val) {
var Vue = getVueConstructor();
// @ts-expect-error https://github.com/vuejs/vue/pull/12132
var _a = Vue.util, warn = _a.warn, defineReactive = _a.defineReactive;
if ((isUndef(target) || isPrimitive(target))) {
warn("Cannot set reactive property on undefined, null, or primitive value: ".concat(target));
}
var ob = target.__ob__;
function ssrMockReactivity() {
// in SSR, there is no __ob__. Mock for reactivity check
if (ob && isObject(val) && !hasOwn(val, '__ob__')) {
mockReactivityDeep(val);
}
}
if (isArray(target)) {
if (isValidArrayIndex(key)) {
target.length = Math.max(target.length, key);
target.splice(key, 1, val);
ssrMockReactivity();
return val;
}
else if (key === 'length' && val !== target.length) {
target.length = val;
ob === null || ob === void 0 ? void 0 : ob.dep.notify();
return val;
}
}
if (key in target && !(key in Object.prototype)) {
target[key] = val;
ssrMockReactivity();
return val;
}
if (target._isVue || (ob && ob.vmCount)) {
warn('Avoid adding reactive properties to a Vue instance or its root $data ' +
'at runtime - declare it upfront in the data option.');
return val;
}
if (!ob) {
target[key] = val;
return val;
}
defineReactive(ob.value, key, val);
// IMPORTANT: define access control before trigger watcher
defineAccessControl(target, key, val);
ssrMockReactivity();
ob.dep.notify();
return val;
}
var _isForceTrigger = false;
function isForceTrigger() {
return _isForceTrigger;
}
function setForceTrigger(v) {
_isForceTrigger = v;
}
var RefImpl = /** @class */ (function () {
function RefImpl(_a) {
var get = _a.get, set = _a.set;
proxy(this, 'value', {
get: get,
set: set,
});
}
return RefImpl;
}());
function createRef(options, isReadonly, isComputed) {
if (isReadonly === void 0) { isReadonly = false; }
if (isComputed === void 0) { isComputed = false; }
var r = new RefImpl(options);
// add effect to differentiate refs from computed
if (isComputed)
r.effect = true;
// seal the ref, this could prevent ref from being observed
// It's safe to seal the ref, since we really shouldn't extend it.
// related issues: #79
var sealed = Object.seal(r);
if (isReadonly)
readonlySet.set(sealed, true);
return sealed;
}
function ref(raw) {
var _a;
if (isRef(raw)) {
return raw;
}
var value = reactive((_a = {}, _a[RefKey] = raw, _a));
return createRef({
get: function () { return value[RefKey]; },
set: function (v) { return (value[RefKey] = v); },
});
}
function isRef(value) {
return value instanceof RefImpl;
}
function unref(ref) {
return isRef(ref) ? ref.value : ref;
}
function toRefs(obj) {
if (!isReactive(obj)) {
warn("toRefs() expects a reactive object but received a plain one.");
}
if (!isPlainObject(obj))
return obj;
var ret = {};
for (var key in obj) {
ret[key] = toRef(obj, key);
}
return ret;
}
function customRef(factory) {
var version = ref(0);
return createRef(factory(function () { return void version.value; }, function () {
++version.value;
}));
}
function toRef(object, key) {
if (!(key in object))
set$1(object, key, undefined);
var v = object[key];
if (isRef(v))
return v;
return createRef({
get: function () { return object[key]; },
set: function (v) { return (object[key] = v); },
});
}
function shallowRef(raw) {
var _a;
if (isRef(raw)) {
return raw;
}
var value = shallowReactive((_a = {}, _a[RefKey] = raw, _a));
return createRef({
get: function () { return value[RefKey]; },
set: function (v) { return (value[RefKey] = v); },
});
}
function triggerRef(value) {
if (!isRef(value))
return;
setForceTrigger(true);
value.value = value.value;
setForceTrigger(false);
}
function proxyRefs(objectWithRefs) {
var _a, e_1, _b;
if (isReactive(objectWithRefs)) {
return objectWithRefs;
}
var value = reactive((_a = {}, _a[RefKey] = objectWithRefs, _a));
def(value, RefKey, value[RefKey], false);
var _loop_1 = function (key) {
proxy(value, key, {
get: function () {
if (isRef(value[RefKey][key])) {
return value[RefKey][key].value;
}
return value[RefKey][key];
},
set: function (v) {
if (isRef(value[RefKey][key])) {
return (value[RefKey][key].value = unref(v));
}
value[RefKey][key] = unref(v);
},
});
};
try {
for (var _c = __values(Object.keys(objectWithRefs)), _d = _c.next(); !_d.done; _d = _c.next()) {
var key = _d.value;
_loop_1(key);
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (_d && !_d.done && (_b = _c.return)) _b.call(_c);
}
finally { if (e_1) throw e_1.error; }
}
return value;
}
var SKIPFLAG = '__v_skip';
function isRaw(obj) {
var _a;
return Boolean(obj &&
hasOwn(obj, '__ob__') &&
typeof obj.__ob__ === 'object' &&
((_a = obj.__ob__) === null || _a === void 0 ? void 0 : _a[SKIPFLAG]));
}
function isReactive(obj) {
var _a;
return Boolean(obj &&
hasOwn(obj, '__ob__') &&
typeof obj.__ob__ === 'object' &&
!((_a = obj.__ob__) === null || _a === void 0 ? void 0 : _a[SKIPFLAG]));
}
/**
* Proxing property access of target.
* We can do unwrapping and other things here.
*/
function setupAccessControl(target) {
if (!isPlainObject(target) ||
isRaw(target) ||
isArray(target) ||
isRef(target) ||
isComponentInstance(target) ||
accessModifiedSet.has(target))
return;
accessModifiedSet.set(target, true);
var keys = Object.keys(target);
for (var i = 0; i < keys.length; i++) {
defineAccessControl(target, keys[i]);
}
}
/**
* Auto unwrapping when access property
*/
function defineAccessControl(target, key, val) {
if (key === '__ob__')
return;
if (isRaw(target[key]))
return;
var getter;
var setter;
var property = Object.getOwnPropertyDescriptor(target, key);
if (property) {
if (property.configurable === false) {
return;
}
getter = property.get;
setter = property.set;
if ((!getter || setter) /* not only have getter */ &&
arguments.length === 2) {
val = target[key];
}
}
setupAccessControl(val);
proxy(target, key, {
get: function getterHandler() {
var value = getter ? getter.call(target) : val;
// if the key is equal to RefKey, skip the unwrap logic
if (key !== RefKey && isRef(value)) {
return value.value;
}
else {
return value;
}
},
set: function setterHandler(newVal) {
if (getter && !setter)
return;
// If the key is equal to RefKey, skip the unwrap logic
// If and only if "value" is ref and "newVal" is not a ref,
// the assignment should be proxied to "value" ref.
if (key !== RefKey && isRef(val) && !isRef(newVal)) {
val.value = newVal;
}
else if (setter) {
setter.call(target, newVal);
val = newVal;
}
else {
val = newVal;
}
setupAccessControl(newVal);
},
});
}
function observe(obj) {
var Vue = getRegisteredVueOrDefault();
var observed;
if (Vue.observable) {
observed = Vue.observable(obj);
}
else {
var vm = defineComponentInstance(Vue, {
data: {
$$state: obj,
},
});
observed = vm._data.$$state;
}
// in SSR, there is no __ob__. Mock for reactivity check
if (!hasOwn(observed, '__ob__')) {
mockReactivityDeep(observed);
}
return observed;
}
/**
* Mock __ob__ for object recursively
*/
function mockReactivityDeep(obj, seen) {
var e_1, _a;
if (seen === void 0) { seen = new Set(); }
if (seen.has(obj) || hasOwn(obj, '__ob__') || !Object.isExtensible(obj))
return;
def(obj, '__ob__', mockObserver(obj));
seen.add(obj);
try {
for (var _b = __values(Object.keys(obj)), _c = _b.next(); !_c.done; _c = _b.next()) {
var key = _c.value;
var value = obj[key];
if (!(isPlainObject(value) || isArray(value)) ||
isRaw(value) ||
!Object.isExtensible(value)) {
continue;
}
mockReactivityDeep(value, seen);
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_1) throw e_1.error; }
}
}
function mockObserver(value) {
if (value === void 0) { value = {}; }
return {
value: value,
dep: {
notify: noopFn,
depend: noopFn,
addSub: noopFn,
removeSub: noopFn,
},
};
}
function createObserver() {
return observe({}).__ob__;
}
function shallowReactive(obj) {
var e_2, _a;
if (!isObject(obj)) {
{
warn('"shallowReactive()" must be called on an object.');
}
return obj;
}
if (!(isPlainObject(obj) || isArray(obj)) ||
isRaw(obj) ||
!Object.isExtensible(obj)) {
return obj;
}
var observed = observe(isArray(obj) ? [] : {});
var ob = observed.__ob__;
var _loop_1 = function (key) {
var val = obj[key];
var getter;
var setter;
var property = Object.getOwnPropertyDescriptor(obj, key);
if (property) {
if (property.configurable === false) {
return "continue";
}
getter = property.get;
setter = property.set;
}
proxy(observed, key, {
get: function getterHandler() {
var _a;
(_a = ob.dep) === null || _a === void 0 ? void 0 : _a.depend();
return val;
},
set: function setterHandler(newVal) {
var _a;
if (getter && !setter)
return;
if (!isForceTrigger() && val === newVal)
return;
if (setter) {
setter.call(obj, newVal);
}
else {
val = newVal;
}
(_a = ob.dep) === null || _a === void 0 ? void 0 : _a.notify();
},
});
};
try {
for (var _b = __values(Object.keys(obj)), _c = _b.next(); !_c.done; _c = _b.next()) {
var key = _c.value;
_loop_1(key);
}
}
catch (e_2_1) { e_2 = { error: e_2_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_2) throw e_2.error; }
}
return observed;
}
/**
* Make obj reactivity
*/
function reactive(obj) {
if (!isObject(obj)) {
{
warn('"reactive()" must be called on an object.');
}
return obj;
}
if (!(isPlainObject(obj) || isArray(obj)) ||
isRaw(obj) ||
!Object.isExtensible(obj)) {
return obj;
}
var observed = observe(obj);
setupAccessControl(observed);
return observed;
}
/**
* Make sure obj can't be a reactive
*/
function markRaw(obj) {
if (!(isPlainObject(obj) || isArray(obj)) || !Object.isExtensible(obj)) {
return obj;
}
// set the vue observable flag at obj
var ob = createObserver();
ob[SKIPFLAG] = true;
def(obj, '__ob__', ob);
// mark as Raw
rawSet.set(obj, true);
return obj;
}
function toRaw(observed) {
var _a;
if (isRaw(observed) || !Object.isExtensible(observed)) {
return observed;
}
return ((_a = observed === null || observed === void 0 ? void 0 : observed.__ob__) === null || _a === void 0 ? void 0 : _a.value) || observed;
}
function isReadonly(obj) {
return readonlySet.has(obj);
}
/**
* **In @vue/composition-api, `reactive` only provides type-level readonly check**
*
* Creates a readonly copy of the original object. Note the returned copy is not
* made reactive, but `readonly` can be called on an already reactive object.
*/
function readonly(target) {
if (!isObject(target)) {
warn("value cannot be made reactive: ".concat(String(target)));
}
else {
readonlySet.set(target, true);
}
return target;
}
function shallowReadonly(obj) {
var e_1, _a;
if (!isObject(obj)) {
{
warn("value cannot be made reactive: ".concat(String(obj)));
}
return obj;
}
if (!(isPlainObject(obj) || isArray(obj)) ||
(!Object.isExtensible(obj) && !isRef(obj))) {
return obj;
}
var readonlyObj = isRef(obj)
? new RefImpl({})
: isReactive(obj)
? observe({})
: {};
var source = reactive({});
var ob = source.__ob__;
var _loop_1 = function (key) {
var val = obj[key];
var getter;
var property = Object.getOwnPropertyDescriptor(obj, key);
if (property) {
if (property.configurable === false && !isRef(obj)) {
return "continue";
}
getter = property.get;
}
proxy(readonlyObj, key, {
get: function getterHandler() {
var value = getter ? getter.call(obj) : val;
ob.dep.depend();
return value;
},
set: function (v) {
{
warn("Set operation on key \"".concat(key, "\" failed: target is readonly."));
}
},
});
};
try {
for (var _b = __values(Object.keys(obj)), _c = _b.next(); !_c.done; _c = _b.next()) {
var key = _c.value;
_loop_1(key);
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_1) throw e_1.error; }
}
readonlySet.set(readonlyObj, true);
return readonlyObj;
}
/**
* Delete a property and trigger change if necessary.
*/
function del(target, key) {
var Vue = getVueConstructor();
var warn = Vue.util.warn;
if ((isUndef(target) || isPrimitive(target))) {
warn("Cannot delete reactive property on undefined, null, or primitive value: ".concat(target));
}
if (isArray(target) && isValidArrayIndex(key)) {
target.splice(key, 1);
return;
}
var ob = target.__ob__;
if (target._isVue || (ob && ob.vmCount)) {
warn('Avoid deleting properties on a Vue instance or its root $data ' +
'- just set it to null.');
return;
}
if (!hasOwn(target, key)) {
return;
}
delete target[key];
if (!ob) {
return;
}
ob.dep.notify();
}
var genName = function (name) { return "on".concat(name[0].toUpperCase() + name.slice(1)); };
function createLifeCycle(lifeCyclehook) {
return function (callback, target) {
var instance = getCurrentInstanceForFn(genName(lifeCyclehook), target);
return (instance &&
injectHookOption(getVueConstructor(), instance, lifeCyclehook, callback));
};
}
function injectHookOption(Vue, instance, hook, val) {
var options = instance.proxy.$options;
var mergeFn = Vue.config.optionMergeStrategies[hook];
var wrappedHook = wrapHookCall(instance, val);
options[hook] = mergeFn(options[hook], wrappedHook);
return wrappedHook;
}
function wrapHookCall(instance, fn) {
return function () {
var args = [];
for (var _i = 0; _i < arguments.length; _i++) {
args[_i] = arguments[_i];
}
var prev = getCurrentInstance();
setCurrentInstance(instance);
try {
return fn.apply(void 0, __spreadArray([], __read(args), false));
}
finally {
setCurrentInstance(prev);
}
};
}
var onBeforeMount = createLifeCycle('beforeMount');
var onMounted = createLifeCycle('mounted');
var onBeforeUpdate = createLifeCycle('beforeUpdate');
var onUpdated = createLifeCycle('updated');
var onBeforeUnmount = createLifeCycle('beforeDestroy');
var onUnmounted = createLifeCycle('destroyed');
var onErrorCaptured = createLifeCycle('errorCaptured');
var onActivated = createLifeCycle('activated');
var onDeactivated = createLifeCycle('deactivated');
var onServerPrefetch = createLifeCycle('serverPrefetch');
var fallbackVM;
function flushPreQueue() {
flushQueue(this, WatcherPreFlushQueueKey);
}
function flushPostQueue() {
flushQueue(this, WatcherPostFlushQueueKey);
}
function hasWatchEnv(vm) {
return vm[WatcherPreFlushQueueKey] !== undefined;
}
function installWatchEnv(vm) {
vm[WatcherPreFlushQueueKey] = [];
vm[WatcherPostFlushQueueKey] = [];
vm.$on('hook:beforeUpdate', flushPreQueue);
vm.$on('hook:updated', flushPostQueue);
}
function getWatcherOption(options) {
return __assign({
immediate: false,
deep: false,
flush: 'pre',
}, options);
}
function getWatchEffectOption(options) {
return __assign({
flush: 'pre',
}, options);
}
function getWatcherVM() {
var vm = getCurrentScopeVM();
if (!vm) {
if (!fallbackVM) {
fallbackVM = defineComponentInstance(getVueConstructor());
}
vm = fallbackVM;
}
else if (!hasWatchEnv(vm)) {
installWatchEnv(vm);
}
return vm;
}
function flushQueue(vm, key) {
var queue = vm[key];
for (var index = 0; index < queue.length; index++) {
queue[index]();
}
queue.length = 0;
}
function queueFlushJob(vm, fn, mode) {
// flush all when beforeUpdate and updated are not fired
var fallbackFlush = function () {
vm.$nextTick(function () {
if (vm[WatcherPreFlushQueueKey].length) {
flushQueue(vm, WatcherPreFlushQueueKey);
}
if (vm[WatcherPostFlushQueueKey].length) {
flushQueue(vm, WatcherPostFlushQueueKey);
}
});
};
switch (mode) {
case 'pre':
fallbackFlush();
vm[WatcherPreFlushQueueKey].push(fn);
break;
case 'post':
fallbackFlush();
vm[WatcherPostFlushQueueKey].push(fn);
break;
default:
assert(false, "flush must be one of [\"post\", \"pre\", \"sync\"], but got ".concat(mode));
break;
}
}
function createVueWatcher(vm, getter, callback, options) {
var index = vm._watchers.length;
// @ts-ignore: use undocumented options
vm.$watch(getter, callback, {
immediate: options.immediateInvokeCallback,
deep: options.deep,
lazy: options.noRun,
sync: options.sync,
before: options.before,
});
return vm._watchers[index];
}
// We have to monkeypatch the teardown function so Vue will run
// runCleanup() when it tears down the watcher on unmounted.
function patchWatcherTeardown(watcher, runCleanup) {
var _teardown = watcher.teardown;
watcher.teardown = function () {
var args = [];
for (var _i = 0; _i < arguments.length; _i++) {
args[_i] = arguments[_i];
}
_teardown.apply(watcher, args);
runCleanup();
};
}
function createWatcher(vm, source, cb, options) {
var _a;
if (!cb) {
if (options.immediate !== undefined) {
warn("watch() \"immediate\" option is only respected when using the " +
"watch(source, callback, options?) signature.");
}
if (options.deep !== undefined) {
warn("watch() \"deep\" option is only respected when using the " +
"watch(source, callback, options?) signature.");
}
}
var flushMode = options.flush;
var isSync = flushMode === 'sync';
var cleanup;
var registerCleanup = function (fn) {
cleanup = function () {
try {
fn();
}
catch (
// FIXME: remove any
error) {
logError(error, vm, 'onCleanup()');
}
};
};
// cleanup before running getter again
var runCleanup = function () {
if (cleanup) {
cleanup();
cleanup = null;
}
};
var createScheduler = function (fn) {
if (isSync ||
/* without a current active instance, ignore pre|post mode */ vm ===
fallbackVM) {
return fn;
}
return (function () {
var args = [];
for (var _i = 0; _i < arguments.length; _i++) {
args[_i] = arguments[_i];
}
return queueFlushJob(vm, function () {
fn.apply(void 0, __spreadArray([], __read(args), false));
}, flushMode);
});
};
// effect watch
if (cb === null) {
var running_1 = false;
var getter_1 = function () {
// preventing the watch callback being call in the same execution
if (running_1) {
return;
}
try {
running_1 = true;
source(registerCleanup);
}
finally {
running_1 = false;
}
};
var watcher_1 = createVueWatcher(vm, getter_1, noopFn, {
deep: options.deep || false,
sync: isSync,
before: runCleanup,
});
patchWatcherTeardown(watcher_1, runCleanup);
// enable the watcher update
watcher_1.lazy = false;
var originGet = watcher_1.get.bind(watcher_1);
// always run watchEffect
watcher_1.get = createScheduler(originGet);
return function () {
watcher_1.teardown();
};
}
var deep = options.deep;
var isMultiSource = false;
var getter;
if (isRef(source)) {
getter = function () { return source.value; };
}
else if (isReactive(source)) {
getter = function () { return source; };
deep = true;
}
else if (isArray(source)) {
isMultiSource = true;
getter = function () {
return source.map(function (s) {
if (isRef(s)) {
return s.value;
}
else if (isReactive(s)) {
return traverse(s);
}
else if (isFunction(s)) {
return s();
}
else {
warn("Invalid watch source: ".concat(JSON.stringify(s), ".\n A watch source can only be a getter/effect function, a ref, a reactive object, or an array of these types."), vm);
return noopFn;
}
});
};
}
else if (isFunction(source)) {
getter = source;
}
else {
getter = noopFn;
warn("Invalid watch source: ".concat(JSON.stringify(source), ".\n A watch source can only be a getter/effect function, a ref, a reactive object, or an array of these types."), vm);
}
if (deep) {
var baseGetter_1 = getter;
getter = function () { return traverse(baseGetter_1()); };
}
var applyCb = function (n, o) {
if (!deep &&
isMultiSource &&
n.every(function (v, i) { return isSame(v, o[i]); }))
return;
// cleanup before running cb again
runCleanup();
return cb(n, o, registerCleanup);
};
var callback = createScheduler(applyCb);
if (options.immediate) {
var originalCallback_1 = callback;
// `shiftCallback` is used to handle the first sync effect run.
// The subsequent callbacks will redirect to `callback`.
var shiftCallback_1 = function (n, o) {
shiftCallback_1 = originalCallback_1;
// o is undefined on the first call
return applyCb(n, isArray(n) ? [] : o);
};
callback = function (n, o) {
return shiftCallback_1(n, o);
};
}
// @ts-ignore: use undocumented option "sync"
var stop = vm.$watch(getter, callback, {
immediate: options.immediate,
deep: deep,
sync: isSync,
});
// Once again, we have to hack the watcher for proper teardown
var watcher = vm._watchers[vm._watchers.length - 1];
// if the return value is reactive and deep:true
// watch for changes, this might happen when new key is added
if (isReactive(watcher.value) && ((_a = watcher.value.__ob__) === null || _a === void 0 ? void 0 : _a.dep) && deep) {
watcher.value.__ob__.dep.addSub({
update: function () {
// this will force the source to be reevaluated and the callback
// executed if needed
watcher.run();
},
});
}
patchWatcherTeardown(watcher, runCleanup);
return function () {
stop();
};
}
function watchEffect(effect, options) {
var opts = getWatchEffectOption(options);
var vm = getWatcherVM();
return createWatcher(vm, effect, null, opts);
}
function watchPostEffect(effect) {
return watchEffect(effect, { flush: 'post' });
}
function watchSyncEffect(effect) {
return watchEffect(effect, { flush: 'sync' });
}
// implementation
function watch(source, cb, options) {
var callback = null;
if (isFunction(cb)) {
// source watch
callback = cb;
}
else {
// effect watch
{
warn("`watch(fn, options?)` signature has been moved to a separate API. " +
"Use `watchEffect(fn, options?)` instead. `watch` now only " +
"supports `watch(source, cb, options?) signature.");
}
options = cb;
callback = null;
}
var opts = getWatcherOption(options);
var vm = getWatcherVM();
return createWatcher(vm, source, callback, opts);
}
function traverse(value, seen) {
if (seen === void 0) { seen = new Set(); }
if (!isObject(value) || seen.has(value) || rawSet.has(value)) {
return value;
}
seen.add(value);
if (isRef(value)) {
traverse(value.value, seen);
}
else if (isArray(value)) {
for (var i = 0; i < value.length; i++) {
traverse(value[i], seen);
}
}
else if (isSet(value) || isMap(value)) {
value.forEach(function (v) {
traverse(v, seen);
});
}
else if (isPlainObject(value)) {
for (var key in value) {
traverse(value[key], seen);
}
}
return value;
}
// implement
function computed(getterOrOptions) {
var vm = getCurrentScopeVM();
var getter;
var setter;
if (isFunction(getterOrOptions)) {
getter = getterOrOptions;
}
else {
getter = getterOrOptions.get;
setter = getterOrOptions.set;
}
var computedSetter;
var computedGetter;
if (vm && !vm.$isServer) {
var _a = getVueInternalClasses(), Watcher_1 = _a.Watcher, Dep_1 = _a.Dep;
var watcher_1;
computedGetter = function () {
if (!watcher_1) {
watcher_1 = new Watcher_1(vm, getter, noopFn, { lazy: true });
}
if (watcher_1.dirty) {
watcher_1.evaluate();
}
if (Dep_1.target) {
watcher_1.depend();
}
return watcher_1.value;
};
computedSetter = function (v) {
if (!setter) {
warn('Write operation failed: computed value is readonly.', vm);
return;
}
if (setter) {
setter(v);
}
};
}
else {
// fallback
var computedHost_1 = defineComponentInstance(getVueConstructor(), {
computed: {
$$state: {
get: getter,
set: setter,
},
},
});
vm && vm.$on('hook:destroyed', function () { return computedHost_1.$destroy(); });
computedGetter = function () { return computedHost_1.$$state; };
computedSetter = function (v) {
if (!setter) {
warn('Write operation failed: computed value is readonly.', vm);
return;
}
computedHost_1.$$state = v;
};
}
return createRef({
get: computedGetter,
set: computedSetter,
}, !setter, true);
}
var NOT_FOUND = {};
function resolveInject(provideKey, vm) {
var source = vm;
while (source) {
if (source._provided && hasOwn(source._provided, provideKey)) {
return source._provided[provideKey];
}
source = source.$parent;
}
return NOT_FOUND;
}
function provide(key, value) {
var _a;
var vm = (_a = getCurrentInstanceForFn('provide')) === null || _a === void 0 ? void 0 : _a.proxy;
if (!vm)
return;
if (!vm._provided) {
var provideCache_1 = {};
proxy(vm, '_provided', {
get: function () { return provideCache_1; },
set: function (v) { return Object.assign(provideCache_1, v); },
});
}
vm._provided[key] = value;
}
function inject(key, defaultValue, treatDefaultAsFactory) {
var _a;
if (treatDefaultAsFactory === void 0) { treatDefaultAsFactory = false; }
var vm = (_a = getCurrentInstance()) === null || _a === void 0 ? void 0 : _a.proxy;
if (!vm) {
warn("inject() can only be used inside setup() or functional components.");
return;
}
if (!key) {
warn("injection \"".concat(String(key), "\" not found."), vm);
return defaultValue;
}
var val = resolveInject(key, vm);
if (val !== NOT_FOUND) {
return val;
}
else if (arguments.length > 1) {
return treatDefaultAsFactory && isFunction(defaultValue)
? defaultValue()
: defaultValue;
}
else {
warn("Injection \"".concat(String(key), "\" not found."), vm);
}
}
var EMPTY_OBJ = Object.freeze({})
;
var useCssModule = function (name) {
var _a;
if (name === void 0) { name = '$style'; }
var instance = getCurrentInstance();
if (!instance) {
warn("useCssModule must be called inside setup()");
return EMPTY_OBJ;
}
var mod = (_a = instance.proxy) === null || _a === void 0 ? void 0 : _a[name];
if (!mod) {
warn("Current instance does not have CSS module named \"".concat(name, "\"."));
return EMPTY_OBJ;
}
return mod;
};
/**
* @deprecated use `useCssModule` instead.
*/
var useCSSModule = useCssModule;
function createApp(rootComponent, rootProps) {
if (rootProps === void 0) { rootProps = undefined; }
var V = getVueConstructor();
var mountedVM = undefined;
var provide = {};
var app = {
config: V.config,
use: V.use.bind(V),
mixin: V.mixin.bind(V),
component: V.component.bind(V),
provide: function (key, value) {
provide[key] = value;
return this;
},
directive: function (name, dir) {
if (dir) {
V.directive(name, dir);
return app;
}
else {
return V.directive(name);
}
},
mount: function (el, hydrating) {
if (!mountedVM) {
mountedVM = new V(__assign(__assign({ propsData: rootProps }, rootComponent), { provide: __assign(__assign({}, provide), rootComponent.provide) }));
mountedVM.$mount(el, hydrating);
return mountedVM;
}
else {
{
warn("App has already been mounted.\n" +
"If you want to remount the same app, move your app creation logic " +
"into a factory function and create fresh app instances for each " +
"mount - e.g. `const createMyApp = () => createApp(App)`");
}
return mountedVM;
}
},
unmount: function () {
if (mountedVM) {
mountedVM.$destroy();
mountedVM = undefined;
}
else {
warn("Cannot unmount an app that is not mounted.");
}
},
};
return app;
}
var nextTick = function nextTick() {
var _a;
var args = [];
for (var _i = 0; _i < arguments.length; _i++) {
args[_i] = arguments[_i];
}
return (_a = getVueConstructor()) === null || _a === void 0 ? void 0 : _a.nextTick.apply(this, args);
};
var fallbackCreateElement;
var createElement = function createElement() {
var _a;
var args = [];
for (var _i = 0; _i < arguments.length; _i++) {
args[_i] = arguments[_i];
}
var instance = (this === null || this === void 0 ? void 0 : this.proxy) || ((_a = getCurrentInstance()) === null || _a === void 0 ? void 0 : _a.proxy);
if (!instance) {
warn('`createElement()` has been called outside of render function.');
if (!fallbackCreateElement) {
fallbackCreateElement = defineComponentInstance(getVueConstructor()).$createElement;
}
return fallbackCreateElement.apply(fallbackCreateElement, args);
}
return instance.$createElement.apply(instance, args);
};
function useSlots() {
return getContext().slots;
}
function useAttrs() {
return getContext().attrs;
}
function getContext() {
var i = getCurrentInstance();
if (!i) {
warn("useContext() called without active instance.");
}
return i.setupContext;
}
function set(vm, key, value) {
var state = (vm.__composition_api_state__ =
vm.__composition_api_state__ || {});
state[key] = value;
}
function get(vm, key) {
return (vm.__composition_api_state__ || {})[key];
}
var vmStateManager = {
set: set,
get: get,
};
function asVmProperty(vm, propName, propValue) {
var props = vm.$options.props;
if (!(propName in vm) && !(props && hasOwn(props, propName))) {
if (isRef(propValue)) {
proxy(vm, propName, {
get: function () { return propValue.value; },
set: function (val) {
propValue.value = val;
},
});
}
else {
proxy(vm, propName, {
get: function () {
if (isReactive(propValue)) {
propValue.__ob__.dep.depend();
}
return propValue;
},
set: function (val) {
propValue = val;
},
});
}
{
// expose binding to Vue Devtool as a data property
// delay this until state has been resolved to prevent repeated works
vm.$nextTick(function () {
if (Object.keys(vm._data).indexOf(propName) !== -1) {
return;
}
if (isRef(propValue)) {
proxy(vm._data, propName, {
get: function () { return propValue.value; },
set: function (val) {
propValue.value = val;
},
});
}
else {
proxy(vm._data, propName, {
get: function () { return propValue; },
set: function (val) {
propValue = val;
},
});
}
});
}
}
else {
if (props && hasOwn(props, propName)) {
warn("The setup binding property \"".concat(propName, "\" is already declared as a prop."), vm);
}
else {
warn("The setup binding property \"".concat(propName, "\" is already declared."), vm);
}
}
}
function updateTemplateRef(vm) {
var rawBindings = vmStateManager.get(vm, 'rawBindings') || {};
if (!rawBindings || !Object.keys(rawBindings).length)
return;
var refs = vm.$refs;
var oldRefKeys = vmStateManager.get(vm, 'refs') || [];
for (var index = 0; index < oldRefKeys.length; index++) {
var key = oldRefKeys[index];
var setupValue = rawBindings[key];
if (!refs[key] && setupValue && isRef(setupValue)) {
setupValue.value = null;
}
}
var newKeys = Object.keys(refs);
var validNewKeys = [];
for (var index = 0; index < newKeys.length; index++) {
var key = newKeys[index];
var setupValue = rawBindings[key];
if (refs[key] && setupValue && isRef(setupValue)) {
setupValue.value = refs[key];
validNewKeys.push(key);
}
}
vmStateManager.set(vm, 'refs', validNewKeys);
}
function afterRender(vm) {
var stack = [vm._vnode];
while (stack.length) {
var vnode = stack.pop();
if (vnode) {
if (vnode.context)
updateTemplateRef(vnode.context);
if (vnode.children) {
for (var i = 0; i < vnode.children.length; ++i) {
stack.push(vnode.children[i]);
}
}
}
}
}
function updateVmAttrs(vm, ctx) {
var e_1, _a;
if (!vm) {
return;
}
var attrBindings = vmStateManager.get(vm, 'attrBindings');
if (!attrBindings && !ctx) {
// fix 840
return;
}
if (!attrBindings) {
var observedData = reactive({});
attrBindings = { ctx: ctx, data: observedData };
vmStateManager.set(vm, 'attrBindings', attrBindings);
proxy(ctx, 'attrs', {
get: function () {
return attrBindings === null || attrBindings === void 0 ? void 0 : attrBindings.data;
},
set: function () {
warn("Cannot assign to '$attrs' because it is a read-only property", vm);
},
});
}
var source = vm.$attrs;
var _loop_1 = function (attr) {
if (!hasOwn(attrBindings.data, attr)) {
proxy(attrBindings.data, attr, {
get: function () {
// to ensure it always return the latest value
return vm.$attrs[attr];
},
});
}
};
try {
for (var _b = __values(Object.keys(source)), _c = _b.next(); !_c.done; _c = _b.next()) {
var attr = _c.value;
_loop_1(attr);
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_1) throw e_1.error; }
}
}
function resolveScopedSlots(vm, slotsProxy) {
var parentVNode = vm.$options._parentVnode;
if (!parentVNode)
return;
var prevSlots = vmStateManager.get(vm, 'slots') || [];
var curSlots = resolveSlots(parentVNode.data.scopedSlots, vm.$slots);
// remove staled slots
for (var index = 0; index < prevSlots.length; index++) {
var key = prevSlots[index];
if (!curSlots[key]) {
delete slotsProxy[key];
}
}
// proxy fresh slots
var slotNames = Object.keys(curSlots);
for (var index = 0; index < slotNames.length; index++) {
var key = slotNames[index];
if (!slotsProxy[key]) {
slotsProxy[key] = createSlotProxy(vm, key);
}
}
vmStateManager.set(vm, 'slots', slotNames);
}
function activateCurrentInstance(instance, fn, onError) {
var preVm = getCurrentInstance();
setCurrentInstance(instance);
try {
return fn(instance);
}
catch (
// FIXME: remove any
err) {
if (onError) {
onError(err);
}
else {
throw err;
}
}
finally {
setCurrentInstance(preVm);
}
}
function mixin(Vue) {
Vue.mixin({
beforeCreate: functionApiInit,
mounted: function () {
afterRender(this);
},
beforeUpdate: function () {
updateVmAttrs(this);
},
updated: function () {
afterRender(this);
},
});
/**
* Vuex init hook, injected into each instances init hooks list.
*/
function functionApiInit() {
var vm = this;
var $options = vm.$options;
var setup = $options.setup, render = $options.render;
if (render) {
// keep currentInstance accessible for createElement
$options.render = function () {
var _this = this;
var args = [];
for (var _i = 0; _i < arguments.length; _i++) {
args[_i] = arguments[_i];
}
return activateCurrentInstance(toVue3ComponentInstance(vm), function () {
return render.apply(_this, args);
});
};
}
if (!setup) {
return;
}
if (!isFunction(setup)) {
{
warn('The "setup" option should be a function that returns a object in component definitions.', vm);
}
return;
}
var data = $options.data;
// wrapper the data option, so we can invoke setup before data get resolved
$options.data = function wrappedData() {
initSetup(vm, vm.$props);
return isFunction(data)
? data.call(vm, vm)
: data || {};
};
}
function initSetup(vm, props) {
if (props === void 0) { props = {}; }
var setup = vm.$options.setup;
var ctx = createSetupContext(vm);
var instance = toVue3ComponentInstance(vm);
instance.setupContext = ctx;
// fake reactive for `toRefs(props)`
def(props, '__ob__', createObserver());
// resolve scopedSlots and slots to functions
resolveScopedSlots(vm, ctx.slots);
var binding;
activateCurrentInstance(instance, function () {
// make props to be fake reactive, this is for `toRefs(props)`
binding = setup(props, ctx);
});
if (!binding)
return;
if (isFunction(binding)) {
// keep typescript happy with the binding type.
var bindingFunc_1 = binding;
// keep currentInstance accessible for createElement
vm.$options.render = function () {
resolveScopedSlots(vm, ctx.slots);
return activateCurrentInstance(instance, function () { return bindingFunc_1(); });
};
return;
}
else if (isObject(binding)) {
if (isReactive(binding)) {
binding = toRefs(binding);
}
vmStateManager.set(vm, 'rawBindings', binding);
var bindingObj_1 = binding;
Object.keys(bindingObj_1).forEach(function (name) {
var bindingValue = bindingObj_1[name];
if (!isRef(bindingValue)) {
if (!isReactive(bindingValue)) {
if (isFunction(bindingValue)) {
var copy_1 = bindingValue;
bindingValue = bindingValue.bind(vm);
Object.keys(copy_1).forEach(function (ele) {
bindingValue[ele] = copy_1[ele];
});
}
else if (!isObject(bindingValue)) {
bindingValue = ref(bindingValue);
}
else if (hasReactiveArrayChild(bindingValue)) {
// creates a custom reactive properties without make the object explicitly reactive
// NOTE we should try to avoid this, better implementation needed
customReactive(bindingValue);
}
}
else if (isArray(bindingValue)) {
bindingValue = ref(bindingValue);
}
}
asVmProperty(vm, name, bindingValue);
});
return;
}
{
assert(false, "\"setup\" must return a \"Object\" or a \"Function\", got \"".concat(Object.prototype.toString
.call(binding)
.slice(8, -1), "\""));
}
}
function customReactive(target, seen) {
if (seen === void 0) { seen = new Set(); }
if (seen.has(target))
return;
if (!isPlainObject(target) ||
isRef(target) ||
isReactive(target) ||
isRaw(target))
return;
var Vue = getVueConstructor();
// @ts-expect-error https://github.com/vuejs/vue/pull/12132
var defineReactive = Vue.util.defineReactive;
Object.keys(target).forEach(function (k) {
var val = target[k];
defineReactive(target, k, val);
if (val) {
seen.add(val);
customReactive(val, seen);
}
return;
});
}
function hasReactiveArrayChild(target, visited) {
if (visited === void 0) { visited = new Map(); }
if (visited.has(target)) {
return visited.get(target);
}
visited.set(target, false);
if (isArray(target) && isReactive(target)) {
visited.set(target, true);
return true;
}
if (!isPlainObject(target) || isRaw(target) || isRef(target)) {
return false;
}
return Object.keys(target).some(function (x) {
return hasReactiveArrayChild(target[x], visited);
});
}
function createSetupContext(vm) {
var ctx = { slots: {} };
var propsPlain = [
'root',
'parent',
'refs',
'listeners',
'isServer',
'ssrContext',
];
var methodReturnVoid = ['emit'];
propsPlain.forEach(function (key) {
var srcKey = "$".concat(key);
proxy(ctx, key, {
get: function () { return vm[srcKey]; },
set: function () {
warn("Cannot assign to '".concat(key, "' because it is a read-only property"), vm);
},
});
});
updateVmAttrs(vm, ctx);
methodReturnVoid.forEach(function (key) {
var srcKey = "$".concat(key);
proxy(ctx, key, {
get: function () {
return function () {
var args = [];
for (var _i = 0; _i < arguments.length; _i++) {
args[_i] = arguments[_i];
}
var fn = vm[srcKey];
fn.apply(vm, args);
};
},
});
});
return ctx;
}
}
/**
* Helper that recursively merges two data objects together.
*/
function mergeData(from, to) {
if (!from)
return to;
if (!to)
return from;
var key;
var toVal;
var fromVal;
var keys = hasSymbol ? Reflect.ownKeys(from) : Object.keys(from);
for (var i = 0; i < keys.length; i++) {
key = keys[i];
// in case the object is already observed...
if (key === '__ob__')
continue;
toVal = to[key];
fromVal = from[key];
if (!hasOwn(to, key)) {
to[key] = fromVal;
}
else if (toVal !== fromVal &&
isPlainObject(toVal) &&
!isRef(toVal) &&
isPlainObject(fromVal) &&
!isRef(fromVal)) {
mergeData(fromVal, toVal);
}
}
return to;
}
function install(Vue) {
if (isVueRegistered(Vue)) {
{
warn('[vue-composition-api] already installed. Vue.use(VueCompositionAPI) should be called only once.');
}
return;
}
{
if (Vue.version) {
if (Vue.version[0] !== '2' || Vue.version[1] !== '.') {
warn("[vue-composition-api] only works with Vue 2, v".concat(Vue.version, " found."));
}
}
else {
warn('[vue-composition-api] no Vue version found');
}
}
Vue.config.optionMergeStrategies.setup = function (parent, child) {
return function mergedSetupFn(props, context) {
return mergeData(isFunction(parent) ? parent(props, context) || {} : undefined, isFunction(child) ? child(props, context) || {} : undefined);
};
};
setVueConstructor(Vue);
mixin(Vue);
}
var Plugin = {
install: function (Vue) { return install(Vue); },
};
// implementation, close to no-op
function defineComponent(options) {
return options;
}
function defineAsyncComponent(source) {
if (isFunction(source)) {
source = { loader: source };
}
var loader = source.loader, loadingComponent = source.loadingComponent, errorComponent = source.errorComponent, _a = source.delay, delay = _a === void 0 ? 200 : _a, timeout = source.timeout, // undefined = never times out
_b = source.suspensible, // undefined = never times out
suspensible = _b === void 0 ? false : _b, // in Vue 3 default is true
userOnError = source.onError;
if (suspensible) {
warn("The suspensiblbe option for async components is not supported in Vue2. It is ignored.");
}
var pendingRequest = null;
var retries = 0;
var retry = function () {
retries++;
pendingRequest = null;
return load();
};
var load = function () {
var thisRequest;
return (pendingRequest ||
(thisRequest = pendingRequest =
loader()
.catch(function (err) {
err = err instanceof Error ? err : new Error(String(err));
if (userOnError) {
return new Promise(function (resolve, reject) {
var userRetry = function () { return resolve(retry()); };
var userFail = function () { return reject(err); };
userOnError(err, userRetry, userFail, retries + 1);
});
}
else {
throw err;
}
})
.then(function (comp) {
if (thisRequest !== pendingRequest && pendingRequest) {
return pendingRequest;
}
if (!comp) {
warn("Async component loader resolved to undefined. " +
"If you are using retry(), make sure to return its return value.");
}
// interop module default
if (comp &&
(comp.__esModule || comp[Symbol.toStringTag] === 'Module')) {
comp = comp.default;
}
if (comp && !isObject(comp) && !isFunction(comp)) {
throw new Error("Invalid async component load result: ".concat(comp));
}
return comp;
})));
};
return function () {
var component = load();
return {
component: component,
delay: delay,
timeout: timeout,
error: errorComponent,
loading: loadingComponent,
};
};
}
var version = "1.7.2";
// auto install when using CDN
if (typeof window !== 'undefined' && window.Vue) {
window.Vue.use(Plugin);
}
exports.EffectScope = EffectScope;
exports.computed = computed;
exports.createApp = createApp;
exports.createRef = createRef;
exports.customRef = customRef;
exports["default"] = Plugin;
exports.defineAsyncComponent = defineAsyncComponent;
exports.defineComponent = defineComponent;
exports.del = del;
exports.effectScope = effectScope;
exports.getCurrentInstance = getCurrentInstance;
exports.getCurrentScope = getCurrentScope;
exports.h = createElement;
exports.inject = inject;
exports.isRaw = isRaw;
exports.isReactive = isReactive;
exports.isReadonly = isReadonly;
exports.isRef = isRef;
exports.markRaw = markRaw;
exports.nextTick = nextTick;
exports.onActivated = onActivated;
exports.onBeforeMount = onBeforeMount;
exports.onBeforeUnmount = onBeforeUnmount;
exports.onBeforeUpdate = onBeforeUpdate;
exports.onDeactivated = onDeactivated;
exports.onErrorCaptured = onErrorCaptured;
exports.onMounted = onMounted;
exports.onScopeDispose = onScopeDispose;
exports.onServerPrefetch = onServerPrefetch;
exports.onUnmounted = onUnmounted;
exports.onUpdated = onUpdated;
exports.provide = provide;
exports.proxyRefs = proxyRefs;
exports.reactive = reactive;
exports.readonly = readonly;
exports.ref = ref;
exports.set = set$1;
exports.shallowReactive = shallowReactive;
exports.shallowReadonly = shallowReadonly;
exports.shallowRef = shallowRef;
exports.toRaw = toRaw;
exports.toRef = toRef;
exports.toRefs = toRefs;
exports.triggerRef = triggerRef;
exports.unref = unref;
exports.useAttrs = useAttrs;
exports.useCSSModule = useCSSModule;
exports.useCssModule = useCssModule;
exports.useSlots = useSlots;
exports.version = version;
exports.warn = warn$1;
exports.watch = watch;
exports.watchEffect = watchEffect;
exports.watchPostEffect = watchPostEffect;
exports.watchSyncEffect = watchSyncEffect;