@aplus-frontend/antdv
Version:
Vue basic component library maintained based on ant-design-vue
104 lines (101 loc) • 3.75 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
var _vue = require("vue");
var _vcTour = _interopRequireDefault(require("../vc-tour"));
var _classNames = _interopRequireDefault(require("../_util/classNames"));
var _panelRender = _interopRequireDefault(require("./panelRender"));
var _interface = require("./interface");
var _useConfigInject = _interopRequireDefault(require("../config-provider/hooks/useConfigInject"));
var _type = require("../_util/type");
var _useMergedType = _interopRequireDefault(require("./useMergedType"));
var _style = _interopRequireDefault(require("./style"));
var _placements = _interopRequireDefault(require("../_util/placements"));
var __rest = void 0 && (void 0).__rest || function (s, e) {
var t = {};
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
}
return t;
};
// CSSINJS
const Tour = (0, _vue.defineComponent)({
name: 'ATour',
inheritAttrs: false,
props: (0, _interface.tourProps)(),
setup(props, _ref) {
let {
attrs,
emit,
slots
} = _ref;
const {
current,
type,
steps,
defaultCurrent
} = (0, _vue.toRefs)(props);
const {
prefixCls,
direction
} = (0, _useConfigInject.default)('tour', props);
// style
const [wrapSSR, hashId] = (0, _style.default)(prefixCls);
const {
currentMergedType,
updateInnerCurrent
} = (0, _useMergedType.default)({
defaultType: type,
steps,
current,
defaultCurrent
});
return () => {
const {
steps,
current,
type,
rootClassName
} = props,
restProps = __rest(props, ["steps", "current", "type", "rootClassName"]);
const customClassName = (0, _classNames.default)({
[`${prefixCls.value}-primary`]: currentMergedType.value === 'primary',
[`${prefixCls.value}-rtl`]: direction.value === 'rtl'
}, hashId.value, rootClassName);
const mergedRenderPanel = (stepProps, stepCurrent) => {
return (0, _vue.createVNode)(_panelRender.default, (0, _objectSpread2.default)((0, _objectSpread2.default)({}, stepProps), {}, {
"type": type,
"current": stepCurrent
}), {
indicatorsRender: slots.indicatorsRender
});
};
const onStepChange = stepCurrent => {
updateInnerCurrent(stepCurrent);
emit('update:current', stepCurrent);
emit('change', stepCurrent);
};
const builtinPlacements = (0, _vue.computed)(() => (0, _placements.default)({
arrowPointAtCenter: true,
autoAdjustOverflow: true
}));
return wrapSSR((0, _vue.createVNode)(_vcTour.default, (0, _objectSpread2.default)((0, _objectSpread2.default)((0, _objectSpread2.default)({}, attrs), restProps), {}, {
"rootClassName": customClassName,
"prefixCls": prefixCls.value,
"current": current,
"defaultCurrent": props.defaultCurrent,
"animated": true,
"renderPanel": mergedRenderPanel,
"onChange": onStepChange,
"steps": steps,
"builtinPlacements": builtinPlacements.value
}), null));
};
}
});
var _default = exports.default = (0, _type.withInstall)(Tour);
;