UNPKG

zmp-vue

Version:

Build full featured iOS & Android apps using ZMP & Vue

90 lines (72 loc) 3.1 kB
"use strict"; exports.__esModule = true; exports.default = void 0; var _vue = require("vue"); var _utils = require("../shared/utils"); var _mixins = require("../shared/mixins"); var _useTheme = require("../shared/use-theme"); 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); } var _hoisted_1 = { key: 0, class: "preloader-inner" }; var _hoisted_2 = /*#__PURE__*/(0, _vue.createVNode)("svg", { viewBox: "0 0 36 36" }, [/*#__PURE__*/(0, _vue.createVNode)("circle", { cx: "18", cy: "18", r: "16" })], -1); var _hoisted_3 = { key: 1, class: "preloader-inner" }; var _hoisted_4 = /*#__PURE__*/(0, _vue.createStaticVNode)("<span class=\"preloader-inner-line\"></span><span class=\"preloader-inner-line\"></span><span class=\"preloader-inner-line\"></span><span class=\"preloader-inner-line\"></span><span class=\"preloader-inner-line\"></span><span class=\"preloader-inner-line\"></span><span class=\"preloader-inner-line\"></span><span class=\"preloader-inner-line\"></span>", 8); var _hoisted_12 = { key: 2, class: "preloader-inner" }; var _hoisted_13 = /*#__PURE__*/(0, _vue.createVNode)("span", { class: "preloader-inner-circle" }, null, -1); var _hoisted_14 = { key: 3, class: "preloader-inner" }; function render(_ctx, _cache) { return (0, _vue.openBlock)(), (0, _vue.createBlock)("div", { class: _ctx.classes }, [_ctx.theme && _ctx.theme.md ? ((0, _vue.openBlock)(), (0, _vue.createBlock)("span", _hoisted_1, [_hoisted_2])) : _ctx.theme && _ctx.theme.ios ? ((0, _vue.openBlock)(), (0, _vue.createBlock)("span", _hoisted_3, [_hoisted_4])) : _ctx.theme && _ctx.theme.aurora ? ((0, _vue.openBlock)(), (0, _vue.createBlock)("span", _hoisted_12, [_hoisted_13])) : !_ctx.theme ? ((0, _vue.openBlock)(), (0, _vue.createBlock)("span", _hoisted_14)) : (0, _vue.createCommentVNode)("", true)], 2); } var _default = { name: 'zmp-preloader', render: render, props: _extends({ size: [Number, String] }, _mixins.colorProps), setup: function setup(props) { var theme = (0, _useTheme.useTheme)(); var classes = (0, _vue.computed)(function () { return (0, _utils.classNames)('preloader', (0, _mixins.colorClasses)(props)); }); var style = (0, _vue.computed)(function () { var preloaderStyle = {}; var sizeComputed = props.size; if (sizeComputed && typeof sizeComputed === 'string' && sizeComputed.indexOf('px') >= 0) { sizeComputed = sizeComputed.replace('px', ''); } if (sizeComputed) { preloaderStyle.width = sizeComputed + "px"; preloaderStyle.height = sizeComputed + "px"; preloaderStyle['--zmp-preloader-size'] = sizeComputed + "px"; } return preloaderStyle; }); return { classes: classes, style: style, theme: theme }; } }; exports.default = _default;