zmp-vue
Version:
Build full featured iOS & Android apps using ZMP & Vue
126 lines (112 loc) • 4.26 kB
JavaScript
function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
import { resolveDynamicComponent as _resolveDynamicComponent, mergeProps as _mergeProps, openBlock as _openBlock, createBlock as _createBlock, createCommentVNode as _createCommentVNode, renderSlot as _renderSlot } from "vue";
function render(_ctx, _cache) {
var _mergeProps2;
return _openBlock(), _createBlock("div", {
ref: "elRef",
class: _ctx.classes
}, [_ctx.tabContent ? (_openBlock(), _createBlock(_resolveDynamicComponent(_ctx.getComponent(_ctx.tabContent)), _mergeProps((_mergeProps2 = {
key: 0
}, _mergeProps2["key"] = _ctx.tabContent.id, _mergeProps2), _ctx.getProps(_ctx.tabContent)), null, 16)) : _renderSlot(_ctx.$slots, "default", {
key: 1
})], 2);
}
import { computed, ref, inject, onMounted, onBeforeUnmount, onUpdated, toRaw } from 'vue';
import { classNames, getComponentId } from '../shared/utils';
import { colorClasses, colorProps } from '../shared/mixins';
import { zmpready, zmprouters, zmp, zmpevents } from '../shared/zmp';
import { useTab } from '../shared/use-tab';
export default {
name: 'zmp-tab',
render: render,
props: _extends({
tabActive: Boolean
}, colorProps),
emits: ['tab:show', 'tab:hide'],
setup: function setup(props, _ref) {
var emit = _ref.emit;
var elRef = ref(null);
var routerData = ref(null);
var route = inject('zmproute', null);
var router = inject('zmproute', null);
var initialTabContent = null;
if (!routerData.value && route && route.route && route.route.tab && route.route.tab.id === props.id) {
var _route$route$tab = route.route.tab,
component = _route$route$tab.component,
asyncComponent = _route$route$tab.asyncComponent;
if (component || asyncComponent) {
initialTabContent = {
id: getComponentId(),
component: component || asyncComponent,
isAsync: !!asyncComponent,
props: _extends({
zmprouter: router,
zmproute: route
}, route.params)
};
}
}
var tabContent = ref(initialTabContent || null);
var setTabContent = function setTabContent(newContent) {
tabContent.value = newContent;
};
if (zmp && !routerData.value) {
routerData.value = {
setTabContent: setTabContent
};
zmprouters.tabs.push(routerData.value);
}
onMounted(function () {
if (elRef.value && initialTabContent) {
elRef.value.zmpRouterTabLoaded = true;
}
zmpready(function () {
if (!routerData.value) {
routerData.value = {
el: elRef.value,
setTabContent: setTabContent
};
zmprouters.tabs.push(routerData.value);
} else {
routerData.value.el = elRef.value;
}
});
});
onBeforeUnmount(function () {
if (!routerData.value) return;
zmprouters.tabs.splice(zmprouters.tabs.indexOf(routerData.value), 1);
routerData.value = null;
});
onUpdated(function () {
if (!routerData.value || !zmp) return;
zmpevents.emit('tabRouterDidUpdate', routerData.value);
});
useTab(elRef, emit);
var classes = computed(function () {
return classNames('tab', {
'tab-active': props.tabActive
}, colorClasses(props));
});
var getComponent = function getComponent(content) {
return toRaw(content.component);
};
var getProps = function getProps(content) {
var tabComponent = content.component,
tabProps = content.props;
var keys = [];
var passProps = {};
if (tabComponent && tabComponent.props) keys = Object.keys(tabComponent.props);
keys.forEach(function (key) {
if (key in tabProps) passProps[key] = tabProps[key];
});
return passProps;
};
return {
elRef: elRef,
classes: classes,
tabContent: tabContent,
getComponent: getComponent,
getProps: getProps
};
}
};