mirror of https://github.com/lukechilds/docs.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
9028 lines
386 KiB
9028 lines
386 KiB
(function(global, factory) {
|
|
typeof exports === "object" && typeof module !== "undefined" ? module.exports = factory() : typeof define === "function" && define.amd ? define("uikit", factory) : global.UIkit = factory();
|
|
})(this, function() {
|
|
"use strict";
|
|
function bind(fn, context) {
|
|
return function(a) {
|
|
var l = arguments.length;
|
|
return l ? l > 1 ? fn.apply(context, arguments) : fn.call(context, a) : fn.call(context);
|
|
};
|
|
}
|
|
var objPrototype = Object.prototype;
|
|
var hasOwnProperty = objPrototype.hasOwnProperty;
|
|
function hasOwn(obj, key) {
|
|
return hasOwnProperty.call(obj, key);
|
|
}
|
|
var hyphenateCache = {};
|
|
var hyphenateRe = /([a-z\d])([A-Z])/g;
|
|
function hyphenate(str) {
|
|
if (!(str in hyphenateCache)) {
|
|
hyphenateCache[str] = str.replace(hyphenateRe, "$1-$2").toLowerCase();
|
|
}
|
|
return hyphenateCache[str];
|
|
}
|
|
var camelizeRe = /-(\w)/g;
|
|
function camelize(str) {
|
|
return str.replace(camelizeRe, toUpper);
|
|
}
|
|
function toUpper(_, c) {
|
|
return c ? c.toUpperCase() : "";
|
|
}
|
|
function ucfirst(str) {
|
|
return str.length ? toUpper(null, str.charAt(0)) + str.slice(1) : "";
|
|
}
|
|
var strPrototype = String.prototype;
|
|
var startsWithFn = strPrototype.startsWith || function(search) {
|
|
return this.lastIndexOf(search, 0) === 0;
|
|
};
|
|
function startsWith(str, search) {
|
|
return startsWithFn.call(str, search);
|
|
}
|
|
var endsWithFn = strPrototype.endsWith || function(search) {
|
|
return this.substr(-search.length) === search;
|
|
};
|
|
function endsWith(str, search) {
|
|
return endsWithFn.call(str, search);
|
|
}
|
|
var includesFn = function(search) {
|
|
return ~this.indexOf(search);
|
|
};
|
|
var includesStr = strPrototype.includes || includesFn;
|
|
var includesArray = Array.prototype.includes || includesFn;
|
|
function includes(obj, search) {
|
|
return obj && (isString(obj) ? includesStr : includesArray).call(obj, search);
|
|
}
|
|
var isArray = Array.isArray;
|
|
function isFunction(obj) {
|
|
return typeof obj === "function";
|
|
}
|
|
function isObject(obj) {
|
|
return obj !== null && typeof obj === "object";
|
|
}
|
|
function isPlainObject(obj) {
|
|
return isObject(obj) && Object.getPrototypeOf(obj) === objPrototype;
|
|
}
|
|
function isWindow(obj) {
|
|
return isObject(obj) && obj === obj.window;
|
|
}
|
|
function isDocument(obj) {
|
|
return isObject(obj) && obj.nodeType === 9;
|
|
}
|
|
function isJQuery(obj) {
|
|
return isObject(obj) && !!obj.jquery;
|
|
}
|
|
function isNode(obj) {
|
|
return obj instanceof Node || isObject(obj) && obj.nodeType >= 1;
|
|
}
|
|
var toString = objPrototype.toString;
|
|
function isNodeCollection(obj) {
|
|
return toString.call(obj).match(/^\[object (NodeList|HTMLCollection)\]$/);
|
|
}
|
|
function isBoolean(value) {
|
|
return typeof value === "boolean";
|
|
}
|
|
function isString(value) {
|
|
return typeof value === "string";
|
|
}
|
|
function isNumber(value) {
|
|
return typeof value === "number";
|
|
}
|
|
function isNumeric(value) {
|
|
return isNumber(value) || isString(value) && !isNaN(value - parseFloat(value));
|
|
}
|
|
function isUndefined(value) {
|
|
return value === void 0;
|
|
}
|
|
function toBoolean(value) {
|
|
return isBoolean(value) ? value : value === "true" || value === "1" || value === "" ? true : value === "false" || value === "0" ? false : value;
|
|
}
|
|
function toNumber(value) {
|
|
var number = Number(value);
|
|
return !isNaN(number) ? number : false;
|
|
}
|
|
function toFloat(value) {
|
|
return parseFloat(value) || 0;
|
|
}
|
|
function toNode(element) {
|
|
return isNode(element) || isWindow(element) || isDocument(element) ? element : isNodeCollection(element) || isJQuery(element) ? element[0] : isArray(element) ? toNode(element[0]) : null;
|
|
}
|
|
var arrayProto = Array.prototype;
|
|
function toNodes(element) {
|
|
return isNode(element) ? [ element ] : isNodeCollection(element) ? arrayProto.slice.call(element) : isArray(element) ? element.map(toNode).filter(Boolean) : isJQuery(element) ? element.toArray() : [];
|
|
}
|
|
function toList(value) {
|
|
return isArray(value) ? value : isString(value) ? value.split(/,(?![^(]*\))/).map(function(value) {
|
|
return isNumeric(value) ? toNumber(value) : toBoolean(value.trim());
|
|
}) : [ value ];
|
|
}
|
|
function toMs(time) {
|
|
return !time ? 0 : endsWith(time, "ms") ? toFloat(time) : toFloat(time) * 1e3;
|
|
}
|
|
function swap(value, a, b) {
|
|
return value.replace(new RegExp(a + "|" + b, "mg"), function(match) {
|
|
return match === a ? b : a;
|
|
});
|
|
}
|
|
var assign = Object.assign || function(target) {
|
|
var args = [], len = arguments.length - 1;
|
|
while (len-- > 0) args[len] = arguments[len + 1];
|
|
target = Object(target);
|
|
for (var i = 0; i < args.length; i++) {
|
|
var source = args[i];
|
|
if (source !== null) {
|
|
for (var key in source) {
|
|
if (hasOwn(source, key)) {
|
|
target[key] = source[key];
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return target;
|
|
};
|
|
function each(obj, cb) {
|
|
for (var key in obj) {
|
|
cb.call(obj[key], obj[key], key);
|
|
}
|
|
}
|
|
function sortBy(collection, prop) {
|
|
return collection.sort(function(ref, ref$1) {
|
|
var propA = ref[prop];
|
|
if (propA === void 0) propA = 0;
|
|
var propB = ref$1[prop];
|
|
if (propB === void 0) propB = 0;
|
|
return propA > propB ? 1 : propB > propA ? -1 : 0;
|
|
});
|
|
}
|
|
function clamp(number, min, max) {
|
|
if (min === void 0) min = 0;
|
|
if (max === void 0) max = 1;
|
|
return Math.min(Math.max(number, min), max);
|
|
}
|
|
function noop() {}
|
|
function intersectRect(r1, r2) {
|
|
return r1.left < r2.right && r1.right > r2.left && r1.top < r2.bottom && r1.bottom > r2.top;
|
|
}
|
|
function pointInRect(point, rect) {
|
|
return point.x <= rect.right && point.x >= rect.left && point.y <= rect.bottom && point.y >= rect.top;
|
|
}
|
|
var Dimensions = {
|
|
ratio: function(dimensions, prop, value) {
|
|
var obj;
|
|
var aProp = prop === "width" ? "height" : "width";
|
|
return obj = {}, obj[aProp] = dimensions[prop] ? Math.round(value * dimensions[aProp] / dimensions[prop]) : dimensions[aProp],
|
|
obj[prop] = value, obj;
|
|
},
|
|
contain: function(dimensions, maxDimensions) {
|
|
var this$1 = this;
|
|
dimensions = assign({}, dimensions);
|
|
each(dimensions, function(_, prop) {
|
|
return dimensions = dimensions[prop] > maxDimensions[prop] ? this$1.ratio(dimensions, prop, maxDimensions[prop]) : dimensions;
|
|
});
|
|
return dimensions;
|
|
},
|
|
cover: function(dimensions, maxDimensions) {
|
|
var this$1 = this;
|
|
dimensions = this.contain(dimensions, maxDimensions);
|
|
each(dimensions, function(_, prop) {
|
|
return dimensions = dimensions[prop] < maxDimensions[prop] ? this$1.ratio(dimensions, prop, maxDimensions[prop]) : dimensions;
|
|
});
|
|
return dimensions;
|
|
}
|
|
};
|
|
function attr(element, name, value) {
|
|
if (isObject(name)) {
|
|
for (var key in name) {
|
|
attr(element, key, name[key]);
|
|
}
|
|
return;
|
|
}
|
|
if (isUndefined(value)) {
|
|
element = toNode(element);
|
|
return element && element.getAttribute(name);
|
|
} else {
|
|
toNodes(element).forEach(function(element) {
|
|
if (isFunction(value)) {
|
|
value = value.call(element, attr(element, name));
|
|
}
|
|
if (value === null) {
|
|
removeAttr(element, name);
|
|
} else {
|
|
element.setAttribute(name, value);
|
|
}
|
|
});
|
|
}
|
|
}
|
|
function hasAttr(element, name) {
|
|
return toNodes(element).some(function(element) {
|
|
return element.hasAttribute(name);
|
|
});
|
|
}
|
|
function removeAttr(element, name) {
|
|
element = toNodes(element);
|
|
name.split(" ").forEach(function(name) {
|
|
return element.forEach(function(element) {
|
|
return element.removeAttribute(name);
|
|
});
|
|
});
|
|
}
|
|
function data(element, attribute) {
|
|
for (var i = 0, attrs = [ attribute, "data-" + attribute ]; i < attrs.length; i++) {
|
|
if (hasAttr(element, attrs[i])) {
|
|
return attr(element, attrs[i]);
|
|
}
|
|
}
|
|
}
|
|
function query(selector, context) {
|
|
return toNode(selector) || find(selector, getContext(selector, context));
|
|
}
|
|
function queryAll(selector, context) {
|
|
var nodes = toNodes(selector);
|
|
return nodes.length && nodes || findAll(selector, getContext(selector, context));
|
|
}
|
|
function getContext(selector, context) {
|
|
if (context === void 0) context = document;
|
|
return isContextSelector(selector) || isDocument(context) ? context : context.ownerDocument;
|
|
}
|
|
function find(selector, context) {
|
|
return toNode(_query(selector, context, "querySelector"));
|
|
}
|
|
function findAll(selector, context) {
|
|
return toNodes(_query(selector, context, "querySelectorAll"));
|
|
}
|
|
function _query(selector, context, queryFn) {
|
|
if (context === void 0) context = document;
|
|
if (!selector || !isString(selector)) {
|
|
return null;
|
|
}
|
|
selector = selector.replace(contextSanitizeRe, "$1 *");
|
|
var removes;
|
|
if (isContextSelector(selector)) {
|
|
removes = [];
|
|
selector = selector.split(",").map(function(selector, i) {
|
|
var ctx = context;
|
|
selector = selector.trim();
|
|
if (selector[0] === "!") {
|
|
var selectors = selector.substr(1).trim().split(" ");
|
|
ctx = closest(context.parentNode, selectors[0]);
|
|
selector = selectors.slice(1).join(" ").trim();
|
|
}
|
|
if (selector[0] === "-") {
|
|
var selectors$1 = selector.substr(1).trim().split(" ");
|
|
var prev = (ctx || context).previousElementSibling;
|
|
ctx = matches(prev, selector.substr(1)) ? prev : null;
|
|
selector = selectors$1.slice(1).join(" ");
|
|
}
|
|
if (!ctx) {
|
|
return null;
|
|
}
|
|
if (!ctx.id) {
|
|
ctx.id = "uk-" + Date.now() + i;
|
|
removes.push(function() {
|
|
return removeAttr(ctx, "id");
|
|
});
|
|
}
|
|
return "#" + escape(ctx.id) + " " + selector;
|
|
}).filter(Boolean).join(",");
|
|
context = document;
|
|
}
|
|
try {
|
|
return context[queryFn](selector);
|
|
} catch (e) {
|
|
return null;
|
|
} finally {
|
|
removes && removes.forEach(function(remove) {
|
|
return remove();
|
|
});
|
|
}
|
|
}
|
|
var contextSelectorRe = /(^|,)\s*[!>+~-]/;
|
|
var contextSanitizeRe = /([!>+~-])(?=\s+[!>+~-]|\s*$)/g;
|
|
function isContextSelector(selector) {
|
|
return isString(selector) && selector.match(contextSelectorRe);
|
|
}
|
|
var elProto = Element.prototype;
|
|
var matchesFn = elProto.matches || elProto.webkitMatchesSelector || elProto.msMatchesSelector;
|
|
function matches(element, selector) {
|
|
return toNodes(element).some(function(element) {
|
|
return matchesFn.call(element, selector);
|
|
});
|
|
}
|
|
var closestFn = elProto.closest || function(selector) {
|
|
var ancestor = this;
|
|
do {
|
|
if (matches(ancestor, selector)) {
|
|
return ancestor;
|
|
}
|
|
ancestor = ancestor.parentNode;
|
|
} while (ancestor && ancestor.nodeType === 1);
|
|
};
|
|
function closest(element, selector) {
|
|
if (startsWith(selector, ">")) {
|
|
selector = selector.slice(1);
|
|
}
|
|
return isNode(element) ? element.parentNode && closestFn.call(element, selector) : toNodes(element).map(function(element) {
|
|
return element.parentNode && closestFn.call(element, selector);
|
|
}).filter(Boolean);
|
|
}
|
|
function parents(element, selector) {
|
|
var elements = [];
|
|
var parent = toNode(element).parentNode;
|
|
while (parent && parent.nodeType === 1) {
|
|
if (matches(parent, selector)) {
|
|
elements.push(parent);
|
|
}
|
|
parent = parent.parentNode;
|
|
}
|
|
return elements;
|
|
}
|
|
var escapeFn = window.CSS && CSS.escape || function(css) {
|
|
return css.replace(/([^\x7f-\uFFFF\w-])/g, function(match) {
|
|
return "\\" + match;
|
|
});
|
|
};
|
|
function escape(css) {
|
|
return isString(css) ? escapeFn.call(null, css) : "";
|
|
}
|
|
var voidElements = {
|
|
area: true,
|
|
base: true,
|
|
br: true,
|
|
col: true,
|
|
embed: true,
|
|
hr: true,
|
|
img: true,
|
|
input: true,
|
|
keygen: true,
|
|
link: true,
|
|
menuitem: true,
|
|
meta: true,
|
|
param: true,
|
|
source: true,
|
|
track: true,
|
|
wbr: true
|
|
};
|
|
function isVoidElement(element) {
|
|
return toNodes(element).some(function(element) {
|
|
return voidElements[element.tagName.toLowerCase()];
|
|
});
|
|
}
|
|
function isVisible(element) {
|
|
return toNodes(element).some(function(element) {
|
|
return element.offsetWidth || element.offsetHeight || element.getClientRects().length;
|
|
});
|
|
}
|
|
var selInput = "input,select,textarea,button";
|
|
function isInput(element) {
|
|
return toNodes(element).some(function(element) {
|
|
return matches(element, selInput);
|
|
});
|
|
}
|
|
function filter(element, selector) {
|
|
return toNodes(element).filter(function(element) {
|
|
return matches(element, selector);
|
|
});
|
|
}
|
|
function within(element, selector) {
|
|
return !isString(selector) ? element === selector || (isDocument(selector) ? selector.documentElement : toNode(selector)).contains(toNode(element)) : matches(element, selector) || closest(element, selector);
|
|
}
|
|
function on() {
|
|
var args = [], len = arguments.length;
|
|
while (len--) args[len] = arguments[len];
|
|
var ref = getArgs(args);
|
|
var targets = ref[0];
|
|
var type = ref[1];
|
|
var selector = ref[2];
|
|
var listener = ref[3];
|
|
var useCapture = ref[4];
|
|
targets = toEventTargets(targets);
|
|
if (selector) {
|
|
listener = delegate(targets, selector, listener);
|
|
}
|
|
if (listener.length > 1) {
|
|
listener = detail(listener);
|
|
}
|
|
type.split(" ").forEach(function(type) {
|
|
return targets.forEach(function(target) {
|
|
return target.addEventListener(type, listener, useCapture);
|
|
});
|
|
});
|
|
return function() {
|
|
return off(targets, type, listener, useCapture);
|
|
};
|
|
}
|
|
function off(targets, type, listener, useCapture) {
|
|
if (useCapture === void 0) useCapture = false;
|
|
targets = toEventTargets(targets);
|
|
type.split(" ").forEach(function(type) {
|
|
return targets.forEach(function(target) {
|
|
return target.removeEventListener(type, listener, useCapture);
|
|
});
|
|
});
|
|
}
|
|
function once() {
|
|
var args = [], len = arguments.length;
|
|
while (len--) args[len] = arguments[len];
|
|
var ref = getArgs(args);
|
|
var element = ref[0];
|
|
var type = ref[1];
|
|
var selector = ref[2];
|
|
var listener = ref[3];
|
|
var useCapture = ref[4];
|
|
var condition = ref[5];
|
|
var off = on(element, type, selector, function(e) {
|
|
var result = !condition || condition(e);
|
|
if (result) {
|
|
off();
|
|
listener(e, result);
|
|
}
|
|
}, useCapture);
|
|
return off;
|
|
}
|
|
function trigger(targets, event, detail) {
|
|
return toEventTargets(targets).reduce(function(notCanceled, target) {
|
|
return notCanceled && target.dispatchEvent(createEvent(event, true, true, detail));
|
|
}, true);
|
|
}
|
|
function createEvent(e, bubbles, cancelable, detail) {
|
|
if (bubbles === void 0) bubbles = true;
|
|
if (cancelable === void 0) cancelable = false;
|
|
if (isString(e)) {
|
|
var event = document.createEvent("CustomEvent");
|
|
event.initCustomEvent(e, bubbles, cancelable, detail);
|
|
e = event;
|
|
}
|
|
return e;
|
|
}
|
|
function getArgs(args) {
|
|
if (isFunction(args[2])) {
|
|
args.splice(2, 0, false);
|
|
}
|
|
return args;
|
|
}
|
|
function delegate(delegates, selector, listener) {
|
|
var this$1 = this;
|
|
return function(e) {
|
|
delegates.forEach(function(delegate) {
|
|
var current = selector[0] === ">" ? findAll(selector, delegate).reverse().filter(function(element) {
|
|
return within(e.target, element);
|
|
})[0] : closest(e.target, selector);
|
|
if (current) {
|
|
e.delegate = delegate;
|
|
e.current = current;
|
|
listener.call(this$1, e);
|
|
}
|
|
});
|
|
};
|
|
}
|
|
function detail(listener) {
|
|
return function(e) {
|
|
return isArray(e.detail) ? listener.apply(void 0, [ e ].concat(e.detail)) : listener(e);
|
|
};
|
|
}
|
|
function isEventTarget(target) {
|
|
return target && "addEventListener" in target;
|
|
}
|
|
function toEventTarget(target) {
|
|
return isEventTarget(target) ? target : toNode(target);
|
|
}
|
|
function toEventTargets(target) {
|
|
return isArray(target) ? target.map(toEventTarget).filter(Boolean) : isString(target) ? findAll(target) : isEventTarget(target) ? [ target ] : toNodes(target);
|
|
}
|
|
function preventClick() {
|
|
var timer = setTimeout(once(document, "click", function(e) {
|
|
e.preventDefault();
|
|
e.stopImmediatePropagation();
|
|
clearTimeout(timer);
|
|
}, true));
|
|
trigger(document, "touchcancel");
|
|
}
|
|
var Promise = "Promise" in window ? window.Promise : PromiseFn;
|
|
var Deferred = function() {
|
|
var this$1 = this;
|
|
this.promise = new Promise(function(resolve, reject) {
|
|
this$1.reject = reject;
|
|
this$1.resolve = resolve;
|
|
});
|
|
};
|
|
var RESOLVED = 0;
|
|
var REJECTED = 1;
|
|
var PENDING = 2;
|
|
var async = "setImmediate" in window ? setImmediate : setTimeout;
|
|
function PromiseFn(executor) {
|
|
this.state = PENDING;
|
|
this.value = undefined;
|
|
this.deferred = [];
|
|
var promise = this;
|
|
try {
|
|
executor(function(x) {
|
|
promise.resolve(x);
|
|
}, function(r) {
|
|
promise.reject(r);
|
|
});
|
|
} catch (e) {
|
|
promise.reject(e);
|
|
}
|
|
}
|
|
PromiseFn.reject = function(r) {
|
|
return new PromiseFn(function(resolve, reject) {
|
|
reject(r);
|
|
});
|
|
};
|
|
PromiseFn.resolve = function(x) {
|
|
return new PromiseFn(function(resolve, reject) {
|
|
resolve(x);
|
|
});
|
|
};
|
|
PromiseFn.all = function all(iterable) {
|
|
return new PromiseFn(function(resolve, reject) {
|
|
var result = [];
|
|
var count = 0;
|
|
if (iterable.length === 0) {
|
|
resolve(result);
|
|
}
|
|
function resolver(i) {
|
|
return function(x) {
|
|
result[i] = x;
|
|
count += 1;
|
|
if (count === iterable.length) {
|
|
resolve(result);
|
|
}
|
|
};
|
|
}
|
|
for (var i = 0; i < iterable.length; i += 1) {
|
|
PromiseFn.resolve(iterable[i]).then(resolver(i), reject);
|
|
}
|
|
});
|
|
};
|
|
PromiseFn.race = function race(iterable) {
|
|
return new PromiseFn(function(resolve, reject) {
|
|
for (var i = 0; i < iterable.length; i += 1) {
|
|
PromiseFn.resolve(iterable[i]).then(resolve, reject);
|
|
}
|
|
});
|
|
};
|
|
var p = PromiseFn.prototype;
|
|
p.resolve = function resolve(x) {
|
|
var promise = this;
|
|
if (promise.state === PENDING) {
|
|
if (x === promise) {
|
|
throw new TypeError("Promise settled with itself.");
|
|
}
|
|
var called = false;
|
|
try {
|
|
var then = x && x.then;
|
|
if (x !== null && isObject(x) && isFunction(then)) {
|
|
then.call(x, function(x) {
|
|
if (!called) {
|
|
promise.resolve(x);
|
|
}
|
|
called = true;
|
|
}, function(r) {
|
|
if (!called) {
|
|
promise.reject(r);
|
|
}
|
|
called = true;
|
|
});
|
|
return;
|
|
}
|
|
} catch (e) {
|
|
if (!called) {
|
|
promise.reject(e);
|
|
}
|
|
return;
|
|
}
|
|
promise.state = RESOLVED;
|
|
promise.value = x;
|
|
promise.notify();
|
|
}
|
|
};
|
|
p.reject = function reject(reason) {
|
|
var promise = this;
|
|
if (promise.state === PENDING) {
|
|
if (reason === promise) {
|
|
throw new TypeError("Promise settled with itself.");
|
|
}
|
|
promise.state = REJECTED;
|
|
promise.value = reason;
|
|
promise.notify();
|
|
}
|
|
};
|
|
p.notify = function notify() {
|
|
var this$1 = this;
|
|
async(function() {
|
|
if (this$1.state !== PENDING) {
|
|
while (this$1.deferred.length) {
|
|
var ref = this$1.deferred.shift();
|
|
var onResolved = ref[0];
|
|
var onRejected = ref[1];
|
|
var resolve = ref[2];
|
|
var reject = ref[3];
|
|
try {
|
|
if (this$1.state === RESOLVED) {
|
|
if (isFunction(onResolved)) {
|
|
resolve(onResolved.call(undefined, this$1.value));
|
|
} else {
|
|
resolve(this$1.value);
|
|
}
|
|
} else if (this$1.state === REJECTED) {
|
|
if (isFunction(onRejected)) {
|
|
resolve(onRejected.call(undefined, this$1.value));
|
|
} else {
|
|
reject(this$1.value);
|
|
}
|
|
}
|
|
} catch (e) {
|
|
reject(e);
|
|
}
|
|
}
|
|
}
|
|
});
|
|
};
|
|
p.then = function then(onResolved, onRejected) {
|
|
var this$1 = this;
|
|
return new PromiseFn(function(resolve, reject) {
|
|
this$1.deferred.push([ onResolved, onRejected, resolve, reject ]);
|
|
this$1.notify();
|
|
});
|
|
};
|
|
p.catch = function(onRejected) {
|
|
return this.then(undefined, onRejected);
|
|
};
|
|
function ajax(url, options) {
|
|
return new Promise(function(resolve, reject) {
|
|
var env = assign({
|
|
data: null,
|
|
method: "GET",
|
|
headers: {},
|
|
xhr: new XMLHttpRequest(),
|
|
beforeSend: noop,
|
|
responseType: ""
|
|
}, options);
|
|
env.beforeSend(env);
|
|
var xhr = env.xhr;
|
|
for (var prop in env) {
|
|
if (prop in xhr) {
|
|
try {
|
|
xhr[prop] = env[prop];
|
|
} catch (e) {}
|
|
}
|
|
}
|
|
xhr.open(env.method.toUpperCase(), url);
|
|
for (var header in env.headers) {
|
|
xhr.setRequestHeader(header, env.headers[header]);
|
|
}
|
|
on(xhr, "load", function() {
|
|
if (xhr.status === 0 || xhr.status >= 200 && xhr.status < 300 || xhr.status === 304) {
|
|
resolve(xhr);
|
|
} else {
|
|
reject(assign(Error(xhr.statusText), {
|
|
xhr: xhr,
|
|
status: xhr.status
|
|
}));
|
|
}
|
|
});
|
|
on(xhr, "error", function() {
|
|
return reject(assign(Error("Network Error"), {
|
|
xhr: xhr
|
|
}));
|
|
});
|
|
on(xhr, "timeout", function() {
|
|
return reject(assign(Error("Network Timeout"), {
|
|
xhr: xhr
|
|
}));
|
|
});
|
|
xhr.send(env.data);
|
|
});
|
|
}
|
|
function getImage(src, srcset, sizes) {
|
|
return new Promise(function(resolve, reject) {
|
|
var img = new Image();
|
|
img.onerror = reject;
|
|
img.onload = function() {
|
|
return resolve(img);
|
|
};
|
|
sizes && (img.sizes = sizes);
|
|
srcset && (img.srcset = srcset);
|
|
img.src = src;
|
|
});
|
|
}
|
|
var isIE = /msie|trident/i.test(window.navigator.userAgent);
|
|
var isRtl = attr(document.documentElement, "dir") === "rtl";
|
|
var hasTouchEvents = "ontouchstart" in window;
|
|
var hasPointerEvents = window.PointerEvent;
|
|
var hasTouch = hasTouchEvents || window.DocumentTouch && document instanceof DocumentTouch || navigator.maxTouchPoints;
|
|
var pointerDown = !hasTouch ? "mousedown" : "mousedown " + (hasTouchEvents ? "touchstart" : "pointerdown");
|
|
var pointerMove = !hasTouch ? "mousemove" : "mousemove " + (hasTouchEvents ? "touchmove" : "pointermove");
|
|
var pointerUp = !hasTouch ? "mouseup" : "mouseup " + (hasTouchEvents ? "touchend" : "pointerup");
|
|
var pointerEnter = hasTouch && hasPointerEvents ? "pointerenter" : "mouseenter";
|
|
var pointerLeave = hasTouch && hasPointerEvents ? "pointerleave" : "mouseleave";
|
|
function isReady() {
|
|
return document.readyState === "complete" || document.readyState !== "loading" && !document.documentElement.doScroll;
|
|
}
|
|
function ready(fn) {
|
|
if (isReady()) {
|
|
fn();
|
|
return;
|
|
}
|
|
var handle = function() {
|
|
unbind1();
|
|
unbind2();
|
|
fn();
|
|
};
|
|
var unbind1 = on(document, "DOMContentLoaded", handle);
|
|
var unbind2 = on(window, "load", handle);
|
|
}
|
|
function index(element, ref) {
|
|
return ref ? toNodes(element).indexOf(toNode(ref)) : toNodes((element = toNode(element)) && element.parentNode.children).indexOf(element);
|
|
}
|
|
function getIndex(i, elements, current, finite) {
|
|
if (current === void 0) current = 0;
|
|
if (finite === void 0) finite = false;
|
|
elements = toNodes(elements);
|
|
var length = elements.length;
|
|
i = isNumeric(i) ? toNumber(i) : i === "next" ? current + 1 : i === "previous" ? current - 1 : index(elements, i);
|
|
if (finite) {
|
|
return clamp(i, 0, length - 1);
|
|
}
|
|
i %= length;
|
|
return i < 0 ? i + length : i;
|
|
}
|
|
function empty(element) {
|
|
element = $(element);
|
|
element.innerHTML = "";
|
|
return element;
|
|
}
|
|
function html(parent, html) {
|
|
parent = $(parent);
|
|
return isUndefined(html) ? parent.innerHTML : append(parent.hasChildNodes() ? empty(parent) : parent, html);
|
|
}
|
|
function prepend(parent, element) {
|
|
parent = $(parent);
|
|
if (!parent.hasChildNodes()) {
|
|
return append(parent, element);
|
|
} else {
|
|
return insertNodes(element, function(element) {
|
|
return parent.insertBefore(element, parent.firstChild);
|
|
});
|
|
}
|
|
}
|
|
function append(parent, element) {
|
|
parent = $(parent);
|
|
return insertNodes(element, function(element) {
|
|
return parent.appendChild(element);
|
|
});
|
|
}
|
|
function before(ref, element) {
|
|
ref = $(ref);
|
|
return insertNodes(element, function(element) {
|
|
return ref.parentNode.insertBefore(element, ref);
|
|
});
|
|
}
|
|
function after(ref, element) {
|
|
ref = $(ref);
|
|
return insertNodes(element, function(element) {
|
|
return ref.nextSibling ? before(ref.nextSibling, element) : append(ref.parentNode, element);
|
|
});
|
|
}
|
|
function insertNodes(element, fn) {
|
|
element = isString(element) ? fragment(element) : element;
|
|
return element ? "length" in element ? toNodes(element).map(fn) : fn(element) : null;
|
|
}
|
|
function remove(element) {
|
|
toNodes(element).map(function(element) {
|
|
return element.parentNode && element.parentNode.removeChild(element);
|
|
});
|
|
}
|
|
function wrapAll(element, structure) {
|
|
structure = toNode(before(element, structure));
|
|
while (structure.firstChild) {
|
|
structure = structure.firstChild;
|
|
}
|
|
append(structure, element);
|
|
return structure;
|
|
}
|
|
function wrapInner(element, structure) {
|
|
return toNodes(toNodes(element).map(function(element) {
|
|
return element.hasChildNodes ? wrapAll(toNodes(element.childNodes), structure) : append(element, structure);
|
|
}));
|
|
}
|
|
function unwrap(element) {
|
|
toNodes(element).map(function(element) {
|
|
return element.parentNode;
|
|
}).filter(function(value, index, self) {
|
|
return self.indexOf(value) === index;
|
|
}).forEach(function(parent) {
|
|
before(parent, parent.childNodes);
|
|
remove(parent);
|
|
});
|
|
}
|
|
var fragmentRe = /^\s*<(\w+|!)[^>]*>/;
|
|
var singleTagRe = /^<(\w+)\s*\/?>(?:<\/\1>)?$/;
|
|
function fragment(html) {
|
|
var matches$$1 = singleTagRe.exec(html);
|
|
if (matches$$1) {
|
|
return document.createElement(matches$$1[1]);
|
|
}
|
|
var container = document.createElement("div");
|
|
if (fragmentRe.test(html)) {
|
|
container.insertAdjacentHTML("beforeend", html.trim());
|
|
} else {
|
|
container.textContent = html;
|
|
}
|
|
return container.childNodes.length > 1 ? toNodes(container.childNodes) : container.firstChild;
|
|
}
|
|
function apply(node, fn) {
|
|
if (!node || node.nodeType !== 1) {
|
|
return;
|
|
}
|
|
fn(node);
|
|
node = node.firstElementChild;
|
|
while (node) {
|
|
apply(node, fn);
|
|
node = node.nextElementSibling;
|
|
}
|
|
}
|
|
function $(selector, context) {
|
|
return !isString(selector) ? toNode(selector) : isHtml(selector) ? toNode(fragment(selector)) : find(selector, context);
|
|
}
|
|
function $$(selector, context) {
|
|
return !isString(selector) ? toNodes(selector) : isHtml(selector) ? toNodes(fragment(selector)) : findAll(selector, context);
|
|
}
|
|
function isHtml(str) {
|
|
return str[0] === "<" || str.match(/^\s*</);
|
|
}
|
|
function addClass(element) {
|
|
var args = [], len = arguments.length - 1;
|
|
while (len-- > 0) args[len] = arguments[len + 1];
|
|
apply$1(element, args, "add");
|
|
}
|
|
function removeClass(element) {
|
|
var args = [], len = arguments.length - 1;
|
|
while (len-- > 0) args[len] = arguments[len + 1];
|
|
apply$1(element, args, "remove");
|
|
}
|
|
function removeClasses(element, cls) {
|
|
attr(element, "class", function(value) {
|
|
return (value || "").replace(new RegExp("\\b" + cls + "\\b", "g"), "");
|
|
});
|
|
}
|
|
function replaceClass(element) {
|
|
var args = [], len = arguments.length - 1;
|
|
while (len-- > 0) args[len] = arguments[len + 1];
|
|
args[0] && removeClass(element, args[0]);
|
|
args[1] && addClass(element, args[1]);
|
|
}
|
|
function hasClass(element, cls) {
|
|
return toNodes(element).some(function(element) {
|
|
return element.classList.contains(cls);
|
|
});
|
|
}
|
|
function toggleClass(element) {
|
|
var args = [], len = arguments.length - 1;
|
|
while (len-- > 0) args[len] = arguments[len + 1];
|
|
if (!args.length) {
|
|
return;
|
|
}
|
|
args = getArgs$1(args);
|
|
var force = !isString(args[args.length - 1]) ? args.pop() : [];
|
|
args = args.filter(Boolean);
|
|
toNodes(element).forEach(function(ref) {
|
|
var classList = ref.classList;
|
|
for (var i = 0; i < args.length; i++) {
|
|
supports.Force ? classList.toggle.apply(classList, [ args[i] ].concat(force)) : classList[(!isUndefined(force) ? force : !classList.contains(args[i])) ? "add" : "remove"](args[i]);
|
|
}
|
|
});
|
|
}
|
|
function apply$1(element, args, fn) {
|
|
args = getArgs$1(args).filter(Boolean);
|
|
args.length && toNodes(element).forEach(function(ref) {
|
|
var classList = ref.classList;
|
|
supports.Multiple ? classList[fn].apply(classList, args) : args.forEach(function(cls) {
|
|
return classList[fn](cls);
|
|
});
|
|
});
|
|
}
|
|
function getArgs$1(args) {
|
|
return args.reduce(function(args, arg) {
|
|
return args.concat.call(args, isString(arg) && includes(arg, " ") ? arg.trim().split(" ") : arg);
|
|
}, []);
|
|
}
|
|
var supports = {};
|
|
(function() {
|
|
var list = document.createElement("_").classList;
|
|
if (list) {
|
|
list.add("a", "b");
|
|
list.toggle("c", false);
|
|
supports.Multiple = list.contains("b");
|
|
supports.Force = !list.contains("c");
|
|
}
|
|
list = null;
|
|
})();
|
|
var cssNumber = {
|
|
"animation-iteration-count": true,
|
|
"column-count": true,
|
|
"fill-opacity": true,
|
|
"flex-grow": true,
|
|
"flex-shrink": true,
|
|
"font-weight": true,
|
|
"line-height": true,
|
|
opacity: true,
|
|
order: true,
|
|
orphans: true,
|
|
widows: true,
|
|
"z-index": true,
|
|
zoom: true
|
|
};
|
|
function css(element, property, value) {
|
|
return toNodes(element).map(function(element) {
|
|
if (isString(property)) {
|
|
property = propName(property);
|
|
if (isUndefined(value)) {
|
|
return getStyle(element, property);
|
|
} else if (!value && value !== 0) {
|
|
element.style.removeProperty(property);
|
|
} else {
|
|
element.style[property] = isNumeric(value) && !cssNumber[property] ? value + "px" : value;
|
|
}
|
|
} else if (isArray(property)) {
|
|
var styles = getStyles(element);
|
|
return property.reduce(function(props, property) {
|
|
props[property] = styles[propName(property)];
|
|
return props;
|
|
}, {});
|
|
} else if (isObject(property)) {
|
|
each(property, function(value, property) {
|
|
return css(element, property, value);
|
|
});
|
|
}
|
|
return element;
|
|
})[0];
|
|
}
|
|
function getStyles(element, pseudoElt) {
|
|
element = toNode(element);
|
|
return element.ownerDocument.defaultView.getComputedStyle(element, pseudoElt);
|
|
}
|
|
function getStyle(element, property, pseudoElt) {
|
|
return getStyles(element, pseudoElt)[property];
|
|
}
|
|
var vars = {};
|
|
function getCssVar(name) {
|
|
var docEl = document.documentElement;
|
|
if (!isIE) {
|
|
return getStyles(docEl).getPropertyValue("--uk-" + name);
|
|
}
|
|
if (!(name in vars)) {
|
|
var element = append(docEl, document.createElement("div"));
|
|
addClass(element, "uk-" + name);
|
|
vars[name] = getStyle(element, "content", ":before").replace(/^["'](.*)["']$/, "$1");
|
|
remove(element);
|
|
}
|
|
return vars[name];
|
|
}
|
|
var cssProps = {};
|
|
function propName(name) {
|
|
var ret = cssProps[name];
|
|
if (!ret) {
|
|
ret = cssProps[name] = vendorPropName(name) || name;
|
|
}
|
|
return ret;
|
|
}
|
|
var cssPrefixes = [ "webkit", "moz", "ms" ];
|
|
var ref = document.createElement("_");
|
|
var style = ref.style;
|
|
function vendorPropName(name) {
|
|
name = hyphenate(name);
|
|
if (name in style) {
|
|
return name;
|
|
}
|
|
var i = cssPrefixes.length, prefixedName;
|
|
while (i--) {
|
|
prefixedName = "-" + cssPrefixes[i] + "-" + name;
|
|
if (prefixedName in style) {
|
|
return prefixedName;
|
|
}
|
|
}
|
|
}
|
|
function transition(element, props, duration, timing) {
|
|
if (duration === void 0) duration = 400;
|
|
if (timing === void 0) timing = "linear";
|
|
return Promise.all(toNodes(element).map(function(element) {
|
|
return new Promise(function(resolve, reject) {
|
|
for (var name in props) {
|
|
var value = css(element, name);
|
|
if (value === "") {
|
|
css(element, name, value);
|
|
}
|
|
}
|
|
var timer = setTimeout(function() {
|
|
return trigger(element, "transitionend");
|
|
}, duration);
|
|
once(element, "transitionend transitioncanceled", function(ref) {
|
|
var type = ref.type;
|
|
clearTimeout(timer);
|
|
removeClass(element, "uk-transition");
|
|
css(element, {
|
|
"transition-property": "",
|
|
"transition-duration": "",
|
|
"transition-timing-function": ""
|
|
});
|
|
type === "transitioncanceled" ? reject() : resolve();
|
|
}, false, function(ref) {
|
|
var target = ref.target;
|
|
return element === target;
|
|
});
|
|
addClass(element, "uk-transition");
|
|
css(element, assign({
|
|
"transition-property": Object.keys(props).map(propName).join(","),
|
|
"transition-duration": duration + "ms",
|
|
"transition-timing-function": timing
|
|
}, props));
|
|
});
|
|
}));
|
|
}
|
|
var Transition = {
|
|
start: transition,
|
|
stop: function(element) {
|
|
trigger(element, "transitionend");
|
|
return Promise.resolve();
|
|
},
|
|
cancel: function(element) {
|
|
trigger(element, "transitioncanceled");
|
|
},
|
|
inProgress: function(element) {
|
|
return hasClass(element, "uk-transition");
|
|
}
|
|
};
|
|
var animationPrefix = "uk-animation-";
|
|
var clsCancelAnimation = "uk-cancel-animation";
|
|
function animate(element, animation, duration, origin, out) {
|
|
var arguments$1 = arguments;
|
|
if (duration === void 0) duration = 200;
|
|
return Promise.all(toNodes(element).map(function(element) {
|
|
return new Promise(function(resolve, reject) {
|
|
if (hasClass(element, clsCancelAnimation)) {
|
|
requestAnimationFrame(function() {
|
|
return Promise.resolve().then(function() {
|
|
return animate.apply(void 0, arguments$1).then(resolve, reject);
|
|
});
|
|
});
|
|
return;
|
|
}
|
|
var cls = animation + " " + animationPrefix + (out ? "leave" : "enter");
|
|
if (startsWith(animation, animationPrefix)) {
|
|
if (origin) {
|
|
cls += " uk-transform-origin-" + origin;
|
|
}
|
|
if (out) {
|
|
cls += " " + animationPrefix + "reverse";
|
|
}
|
|
}
|
|
reset();
|
|
once(element, "animationend animationcancel", function(ref) {
|
|
var type = ref.type;
|
|
var hasReset = false;
|
|
if (type === "animationcancel") {
|
|
reject();
|
|
reset();
|
|
} else {
|
|
resolve();
|
|
Promise.resolve().then(function() {
|
|
hasReset = true;
|
|
reset();
|
|
});
|
|
}
|
|
requestAnimationFrame(function() {
|
|
if (!hasReset) {
|
|
addClass(element, clsCancelAnimation);
|
|
requestAnimationFrame(function() {
|
|
return removeClass(element, clsCancelAnimation);
|
|
});
|
|
}
|
|
});
|
|
}, false, function(ref) {
|
|
var target = ref.target;
|
|
return element === target;
|
|
});
|
|
css(element, "animationDuration", duration + "ms");
|
|
addClass(element, cls);
|
|
function reset() {
|
|
css(element, "animationDuration", "");
|
|
removeClasses(element, animationPrefix + "\\S*");
|
|
}
|
|
});
|
|
}));
|
|
}
|
|
var inProgress = new RegExp(animationPrefix + "(enter|leave)");
|
|
var Animation = {
|
|
in: function(element, animation, duration, origin) {
|
|
return animate(element, animation, duration, origin, false);
|
|
},
|
|
out: function(element, animation, duration, origin) {
|
|
return animate(element, animation, duration, origin, true);
|
|
},
|
|
inProgress: function(element) {
|
|
return inProgress.test(attr(element, "class"));
|
|
},
|
|
cancel: function(element) {
|
|
trigger(element, "animationcancel");
|
|
}
|
|
};
|
|
var dirs = {
|
|
width: [ "x", "left", "right" ],
|
|
height: [ "y", "top", "bottom" ]
|
|
};
|
|
function positionAt(element, target, elAttach, targetAttach, elOffset, targetOffset, flip, boundary) {
|
|
elAttach = getPos(elAttach);
|
|
targetAttach = getPos(targetAttach);
|
|
var flipped = {
|
|
element: elAttach,
|
|
target: targetAttach
|
|
};
|
|
if (!element || !target) {
|
|
return flipped;
|
|
}
|
|
var dim = getDimensions(element);
|
|
var targetDim = getDimensions(target);
|
|
var position = targetDim;
|
|
moveTo(position, elAttach, dim, -1);
|
|
moveTo(position, targetAttach, targetDim, 1);
|
|
elOffset = getOffsets(elOffset, dim.width, dim.height);
|
|
targetOffset = getOffsets(targetOffset, targetDim.width, targetDim.height);
|
|
elOffset["x"] += targetOffset["x"];
|
|
elOffset["y"] += targetOffset["y"];
|
|
position.left += elOffset["x"];
|
|
position.top += elOffset["y"];
|
|
boundary = getDimensions(boundary || window$1(element));
|
|
if (flip) {
|
|
each(dirs, function(ref, prop) {
|
|
var dir = ref[0];
|
|
var align = ref[1];
|
|
var alignFlip = ref[2];
|
|
if (!(flip === true || includes(flip, dir))) {
|
|
return;
|
|
}
|
|
var elemOffset = elAttach[dir] === align ? -dim[prop] : elAttach[dir] === alignFlip ? dim[prop] : 0;
|
|
var targetOffset = targetAttach[dir] === align ? targetDim[prop] : targetAttach[dir] === alignFlip ? -targetDim[prop] : 0;
|
|
if (position[align] < boundary[align] || position[align] + dim[prop] > boundary[alignFlip]) {
|
|
var centerOffset = dim[prop] / 2;
|
|
var centerTargetOffset = targetAttach[dir] === "center" ? -targetDim[prop] / 2 : 0;
|
|
elAttach[dir] === "center" && (apply(centerOffset, centerTargetOffset) || apply(-centerOffset, -centerTargetOffset)) || apply(elemOffset, targetOffset);
|
|
}
|
|
function apply(elemOffset, targetOffset) {
|
|
var newVal = position[align] + elemOffset + targetOffset - elOffset[dir] * 2;
|
|
if (newVal >= boundary[align] && newVal + dim[prop] <= boundary[alignFlip]) {
|
|
position[align] = newVal;
|
|
[ "element", "target" ].forEach(function(el) {
|
|
flipped[el][dir] = !elemOffset ? flipped[el][dir] : flipped[el][dir] === dirs[prop][1] ? dirs[prop][2] : dirs[prop][1];
|
|
});
|
|
return true;
|
|
}
|
|
}
|
|
});
|
|
}
|
|
offset(element, position);
|
|
return flipped;
|
|
}
|
|
function offset(element, coordinates) {
|
|
element = toNode(element);
|
|
if (coordinates) {
|
|
var currentOffset = offset(element);
|
|
var pos = css(element, "position");
|
|
[ "left", "top" ].forEach(function(prop) {
|
|
if (prop in coordinates) {
|
|
var value = css(element, prop);
|
|
css(element, prop, coordinates[prop] - currentOffset[prop] + toFloat(pos === "absolute" && value === "auto" ? position(element)[prop] : value));
|
|
}
|
|
});
|
|
return;
|
|
}
|
|
return getDimensions(element);
|
|
}
|
|
function getDimensions(element) {
|
|
element = toNode(element);
|
|
var ref = window$1(element);
|
|
var top = ref.pageYOffset;
|
|
var left = ref.pageXOffset;
|
|
if (isWindow(element)) {
|
|
var height = element.innerHeight;
|
|
var width = element.innerWidth;
|
|
return {
|
|
top: top,
|
|
left: left,
|
|
height: height,
|
|
width: width,
|
|
bottom: top + height,
|
|
right: left + width
|
|
};
|
|
}
|
|
var style, hidden;
|
|
if (!isVisible(element)) {
|
|
style = attr(element, "style");
|
|
hidden = attr(element, "hidden");
|
|
attr(element, {
|
|
style: (style || "") + ";display:block !important;",
|
|
hidden: null
|
|
});
|
|
}
|
|
var rect = element.getBoundingClientRect();
|
|
if (!isUndefined(style)) {
|
|
attr(element, {
|
|
style: style,
|
|
hidden: hidden
|
|
});
|
|
}
|
|
return {
|
|
height: rect.height,
|
|
width: rect.width,
|
|
top: rect.top + top,
|
|
left: rect.left + left,
|
|
bottom: rect.bottom + top,
|
|
right: rect.right + left
|
|
};
|
|
}
|
|
function position(element) {
|
|
element = toNode(element);
|
|
var parent = element.offsetParent || docEl(element);
|
|
var parentOffset = offset(parent);
|
|
var ref = [ "top", "left" ].reduce(function(props, prop) {
|
|
var propName$$1 = ucfirst(prop);
|
|
props[prop] -= parentOffset[prop] + toFloat(css(element, "margin" + propName$$1)) + toFloat(css(parent, "border" + propName$$1 + "Width"));
|
|
return props;
|
|
}, offset(element));
|
|
var top = ref.top;
|
|
var left = ref.left;
|
|
return {
|
|
top: top,
|
|
left: left
|
|
};
|
|
}
|
|
var height = dimension("height");
|
|
var width = dimension("width");
|
|
function dimension(prop) {
|
|
var propName$$1 = ucfirst(prop);
|
|
return function(element, value) {
|
|
element = toNode(element);
|
|
if (isUndefined(value)) {
|
|
if (isWindow(element)) {
|
|
return element["inner" + propName$$1];
|
|
}
|
|
if (isDocument(element)) {
|
|
var doc = element.documentElement;
|
|
return Math.max(doc["offset" + propName$$1], doc["scroll" + propName$$1]);
|
|
}
|
|
value = css(element, prop);
|
|
value = value === "auto" ? element["offset" + propName$$1] : toFloat(value) || 0;
|
|
return value - boxModelAdjust(prop, element);
|
|
} else {
|
|
css(element, prop, !value && value !== 0 ? "" : +value + boxModelAdjust(prop, element) + "px");
|
|
}
|
|
};
|
|
}
|
|
function boxModelAdjust(prop, element, sizing) {
|
|
if (sizing === void 0) sizing = "border-box";
|
|
return css(element, "boxSizing") === sizing ? dirs[prop].slice(1).map(ucfirst).reduce(function(value, prop) {
|
|
return value + toFloat(css(element, "padding" + prop)) + toFloat(css(element, "border" + prop + "Width"));
|
|
}, 0) : 0;
|
|
}
|
|
function moveTo(position, attach, dim, factor) {
|
|
each(dirs, function(ref, prop) {
|
|
var dir = ref[0];
|
|
var align = ref[1];
|
|
var alignFlip = ref[2];
|
|
if (attach[dir] === alignFlip) {
|
|
position[align] += dim[prop] * factor;
|
|
} else if (attach[dir] === "center") {
|
|
position[align] += dim[prop] * factor / 2;
|
|
}
|
|
});
|
|
}
|
|
function getPos(pos) {
|
|
var x = /left|center|right/;
|
|
var y = /top|center|bottom/;
|
|
pos = (pos || "").split(" ");
|
|
if (pos.length === 1) {
|
|
pos = x.test(pos[0]) ? pos.concat([ "center" ]) : y.test(pos[0]) ? [ "center" ].concat(pos) : [ "center", "center" ];
|
|
}
|
|
return {
|
|
x: x.test(pos[0]) ? pos[0] : "center",
|
|
y: y.test(pos[1]) ? pos[1] : "center"
|
|
};
|
|
}
|
|
function getOffsets(offsets, width, height) {
|
|
var ref = (offsets || "").split(" ");
|
|
var x = ref[0];
|
|
var y = ref[1];
|
|
return {
|
|
x: x ? toFloat(x) * (endsWith(x, "%") ? width / 100 : 1) : 0,
|
|
y: y ? toFloat(y) * (endsWith(y, "%") ? height / 100 : 1) : 0
|
|
};
|
|
}
|
|
function flipPosition(pos) {
|
|
switch (pos) {
|
|
case "left":
|
|
return "right";
|
|
|
|
case "right":
|
|
return "left";
|
|
|
|
case "top":
|
|
return "bottom";
|
|
|
|
case "bottom":
|
|
return "top";
|
|
|
|
default:
|
|
return pos;
|
|
}
|
|
}
|
|
function isInView(element, topOffset, leftOffset, relativeToViewport) {
|
|
if (topOffset === void 0) topOffset = 0;
|
|
if (leftOffset === void 0) leftOffset = 0;
|
|
if (!isVisible(element)) {
|
|
return false;
|
|
}
|
|
element = toNode(element);
|
|
var win = window$1(element);
|
|
var client, bounding;
|
|
if (relativeToViewport) {
|
|
client = element.getBoundingClientRect();
|
|
bounding = {
|
|
top: -topOffset,
|
|
left: -leftOffset,
|
|
bottom: topOffset + height(win),
|
|
right: leftOffset + width(win)
|
|
};
|
|
} else {
|
|
var ref = offsetPosition(element);
|
|
var elTop = ref[0];
|
|
var elLeft = ref[1];
|
|
var top = win.pageYOffset;
|
|
var left = win.pageXOffset;
|
|
client = {
|
|
top: elTop,
|
|
left: elLeft,
|
|
bottom: elTop + element.offsetHeight,
|
|
right: elTop + element.offsetWidth
|
|
};
|
|
bounding = {
|
|
top: top - topOffset,
|
|
left: left - leftOffset,
|
|
bottom: top + topOffset + height(win),
|
|
right: left + leftOffset + width(win)
|
|
};
|
|
}
|
|
return intersectRect(client, bounding) || pointInRect({
|
|
x: client.left,
|
|
y: client.top
|
|
}, bounding);
|
|
}
|
|
function scrolledOver(element, heightOffset) {
|
|
if (heightOffset === void 0) heightOffset = 0;
|
|
if (!isVisible(element)) {
|
|
return 0;
|
|
}
|
|
element = toNode(element);
|
|
var win = window$1(element);
|
|
var doc = document$1(element);
|
|
var elHeight = element.offsetHeight + heightOffset;
|
|
var ref = offsetPosition(element);
|
|
var top = ref[0];
|
|
var vp = height(win);
|
|
var vh = vp + Math.min(0, top - vp);
|
|
var diff = Math.max(0, vp - (height(doc) + heightOffset - (top + elHeight)));
|
|
return clamp((vh + win.pageYOffset - top) / ((vh + (elHeight - (diff < vp ? diff : 0))) / 100) / 100);
|
|
}
|
|
function scrollTop(element, top) {
|
|
element = toNode(element);
|
|
if (isWindow(element) || isDocument(element)) {
|
|
var ref = window$1(element);
|
|
var scrollTo = ref.scrollTo;
|
|
var pageXOffset = ref.pageXOffset;
|
|
scrollTo(pageXOffset, top);
|
|
} else {
|
|
element.scrollTop = top;
|
|
}
|
|
}
|
|
function offsetPosition(element) {
|
|
var offset = [ 0, 0 ];
|
|
do {
|
|
offset[0] += element.offsetTop;
|
|
offset[1] += element.offsetLeft;
|
|
if (css(element, "position") === "fixed") {
|
|
var win = window$1(element);
|
|
offset[0] += win.pageYOffset;
|
|
offset[1] += win.pageXOffset;
|
|
return offset;
|
|
}
|
|
} while (element = element.offsetParent);
|
|
return offset;
|
|
}
|
|
function window$1(element) {
|
|
return isWindow(element) ? element : document$1(element).defaultView;
|
|
}
|
|
function document$1(element) {
|
|
return toNode(element).ownerDocument;
|
|
}
|
|
function docEl(element) {
|
|
return document$1(element).documentElement;
|
|
}
|
|
var fastdom = {
|
|
reads: [],
|
|
writes: [],
|
|
read: function(task) {
|
|
this.reads.push(task);
|
|
scheduleFlush();
|
|
return task;
|
|
},
|
|
write: function(task) {
|
|
this.writes.push(task);
|
|
scheduleFlush();
|
|
return task;
|
|
},
|
|
clear: function(task) {
|
|
return remove$1(this.reads, task) || remove$1(this.writes, task);
|
|
},
|
|
flush: function() {
|
|
runTasks(this.reads);
|
|
runTasks(this.writes.splice(0, this.writes.length));
|
|
this.scheduled = false;
|
|
if (this.reads.length || this.writes.length) {
|
|
scheduleFlush();
|
|
}
|
|
}
|
|
};
|
|
function scheduleFlush() {
|
|
if (!fastdom.scheduled) {
|
|
fastdom.scheduled = true;
|
|
requestAnimationFrame(fastdom.flush.bind(fastdom));
|
|
}
|
|
}
|
|
function runTasks(tasks) {
|
|
var task;
|
|
while (task = tasks.shift()) {
|
|
task();
|
|
}
|
|
}
|
|
function remove$1(array, item) {
|
|
var index = array.indexOf(item);
|
|
return !!~index && !!array.splice(index, 1);
|
|
}
|
|
function MouseTracker() {}
|
|
MouseTracker.prototype = {
|
|
positions: [],
|
|
position: null,
|
|
init: function() {
|
|
var this$1 = this;
|
|
this.positions = [];
|
|
this.position = null;
|
|
var ticking = false;
|
|
this.unbind = on(document, "mousemove", function(e) {
|
|
if (ticking) {
|
|
return;
|
|
}
|
|
setTimeout(function() {
|
|
var time = Date.now();
|
|
var ref = this$1.positions;
|
|
var length = ref.length;
|
|
if (length && time - this$1.positions[length - 1].time > 100) {
|
|
this$1.positions.splice(0, length);
|
|
}
|
|
this$1.positions.push({
|
|
time: time,
|
|
x: e.pageX,
|
|
y: e.pageY
|
|
});
|
|
if (this$1.positions.length > 5) {
|
|
this$1.positions.shift();
|
|
}
|
|
ticking = false;
|
|
}, 5);
|
|
ticking = true;
|
|
});
|
|
},
|
|
cancel: function() {
|
|
if (this.unbind) {
|
|
this.unbind();
|
|
}
|
|
},
|
|
movesTo: function(target) {
|
|
if (this.positions.length < 2) {
|
|
return false;
|
|
}
|
|
var p = offset(target);
|
|
var position$$1 = this.positions[this.positions.length - 1];
|
|
var ref = this.positions;
|
|
var prevPos = ref[0];
|
|
if (p.left <= position$$1.x && position$$1.x <= p.right && p.top <= position$$1.y && position$$1.y <= p.bottom) {
|
|
return false;
|
|
}
|
|
var points = [ [ {
|
|
x: p.left,
|
|
y: p.top
|
|
}, {
|
|
x: p.right,
|
|
y: p.bottom
|
|
} ], [ {
|
|
x: p.right,
|
|
y: p.top
|
|
}, {
|
|
x: p.left,
|
|
y: p.bottom
|
|
} ] ];
|
|
if (p.right <= position$$1.x) ; else if (p.left >= position$$1.x) {
|
|
points[0].reverse();
|
|
points[1].reverse();
|
|
} else if (p.bottom <= position$$1.y) {
|
|
points[0].reverse();
|
|
} else if (p.top >= position$$1.y) {
|
|
points[1].reverse();
|
|
}
|
|
return !!points.reduce(function(result, point) {
|
|
return result + (slope(prevPos, point[0]) < slope(position$$1, point[0]) && slope(prevPos, point[1]) > slope(position$$1, point[1]));
|
|
}, 0);
|
|
}
|
|
};
|
|
function slope(a, b) {
|
|
return (b.y - a.y) / (b.x - a.x);
|
|
}
|
|
var strats = {};
|
|
strats.args = strats.events = strats.created = strats.beforeConnect = strats.connected = strats.beforeDisconnect = strats.disconnected = strats.destroy = function(parentVal, childVal) {
|
|
parentVal = parentVal && !isArray(parentVal) ? [ parentVal ] : parentVal;
|
|
return childVal ? parentVal ? parentVal.concat(childVal) : isArray(childVal) ? childVal : [ childVal ] : parentVal;
|
|
};
|
|
strats.update = function(parentVal, childVal) {
|
|
return sortBy(strats.args(parentVal, isFunction(childVal) ? {
|
|
read: childVal
|
|
} : childVal), "order");
|
|
};
|
|
strats.props = function(parentVal, childVal) {
|
|
if (isArray(childVal)) {
|
|
childVal = childVal.reduce(function(value, key) {
|
|
value[key] = String;
|
|
return value;
|
|
}, {});
|
|
}
|
|
return strats.methods(parentVal, childVal);
|
|
};
|
|
strats.computed = strats.methods = function(parentVal, childVal) {
|
|
return childVal ? parentVal ? assign({}, parentVal, childVal) : childVal : parentVal;
|
|
};
|
|
strats.data = function(parentVal, childVal, vm) {
|
|
if (!vm) {
|
|
if (!childVal) {
|
|
return parentVal;
|
|
}
|
|
if (!parentVal) {
|
|
return childVal;
|
|
}
|
|
return function(vm) {
|
|
return mergeFnData(parentVal, childVal, vm);
|
|
};
|
|
}
|
|
return mergeFnData(parentVal, childVal, vm);
|
|
};
|
|
function mergeFnData(parentVal, childVal, vm) {
|
|
return strats.computed(isFunction(parentVal) ? parentVal.call(vm, vm) : parentVal, isFunction(childVal) ? childVal.call(vm, vm) : childVal);
|
|
}
|
|
var defaultStrat = function(parentVal, childVal) {
|
|
return isUndefined(childVal) ? parentVal : childVal;
|
|
};
|
|
function mergeOptions(parent, child, vm) {
|
|
var options = {};
|
|
if (isFunction(child)) {
|
|
child = child.options;
|
|
}
|
|
if (child.extends) {
|
|
parent = mergeOptions(parent, child.extends, vm);
|
|
}
|
|
if (child.mixins) {
|
|
for (var i = 0, l = child.mixins.length; i < l; i++) {
|
|
parent = mergeOptions(parent, child.mixins[i], vm);
|
|
}
|
|
}
|
|
for (var key in parent) {
|
|
mergeKey(key);
|
|
}
|
|
for (var key$1 in child) {
|
|
if (!hasOwn(parent, key$1)) {
|
|
mergeKey(key$1);
|
|
}
|
|
}
|
|
function mergeKey(key) {
|
|
options[key] = (strats[key] || defaultStrat)(parent[key], child[key], vm);
|
|
}
|
|
return options;
|
|
}
|
|
function parseOptions(options, args) {
|
|
var obj;
|
|
if (args === void 0) args = [];
|
|
try {
|
|
return !options ? {} : startsWith(options, "{") ? JSON.parse(options) : args.length && !includes(options, ":") ? (obj = {},
|
|
obj[args[0]] = options, obj) : options.split(";").reduce(function(options, option) {
|
|
var ref = option.split(/:(.*)/);
|
|
var key = ref[0];
|
|
var value = ref[1];
|
|
if (key && !isUndefined(value)) {
|
|
options[key.trim()] = value.trim();
|
|
}
|
|
return options;
|
|
}, {});
|
|
} catch (e) {
|
|
return {};
|
|
}
|
|
}
|
|
var id = 0;
|
|
var Player = function(el) {
|
|
this.id = ++id;
|
|
this.el = toNode(el);
|
|
};
|
|
Player.prototype.isVideo = function() {
|
|
return this.isYoutube() || this.isVimeo() || this.isHTML5();
|
|
};
|
|
Player.prototype.isHTML5 = function() {
|
|
return this.el.tagName === "VIDEO";
|
|
};
|
|
Player.prototype.isIFrame = function() {
|
|
return this.el.tagName === "IFRAME";
|
|
};
|
|
Player.prototype.isYoutube = function() {
|
|
return this.isIFrame() && !!this.el.src.match(/\/\/.*?youtube(-nocookie)?\.[a-z]+\/(watch\?v=[^&\s]+|embed)|youtu\.be\/.*/);
|
|
};
|
|
Player.prototype.isVimeo = function() {
|
|
return this.isIFrame() && !!this.el.src.match(/vimeo\.com\/video\/.*/);
|
|
};
|
|
Player.prototype.enableApi = function() {
|
|
var this$1 = this;
|
|
if (this.ready) {
|
|
return this.ready;
|
|
}
|
|
var youtube = this.isYoutube();
|
|
var vimeo = this.isVimeo();
|
|
var poller;
|
|
if (youtube || vimeo) {
|
|
return this.ready = new Promise(function(resolve) {
|
|
once(this$1.el, "load", function() {
|
|
if (youtube) {
|
|
var listener = function() {
|
|
return post(this$1.el, {
|
|
event: "listening",
|
|
id: this$1.id
|
|
});
|
|
};
|
|
poller = setInterval(listener, 100);
|
|
listener();
|
|
}
|
|
});
|
|
listen(function(data$$1) {
|
|
return youtube && data$$1.id === this$1.id && data$$1.event === "onReady" || vimeo && Number(data$$1.player_id) === this$1.id;
|
|
}).then(function() {
|
|
resolve();
|
|
poller && clearInterval(poller);
|
|
});
|
|
attr(this$1.el, "src", "" + this$1.el.src + (includes(this$1.el.src, "?") ? "&" : "?") + (youtube ? "enablejsapi=1" : "api=1&player_id=" + this$1.id));
|
|
});
|
|
}
|
|
return Promise.resolve();
|
|
};
|
|
Player.prototype.play = function() {
|
|
var this$1 = this;
|
|
if (!this.isVideo()) {
|
|
return;
|
|
}
|
|
if (this.isIFrame()) {
|
|
this.enableApi().then(function() {
|
|
return post(this$1.el, {
|
|
func: "playVideo",
|
|
method: "play"
|
|
});
|
|
});
|
|
} else if (this.isHTML5()) {
|
|
try {
|
|
var promise = this.el.play();
|
|
if (promise) {
|
|
promise.catch(noop);
|
|
}
|
|
} catch (e) {}
|
|
}
|
|
};
|
|
Player.prototype.pause = function() {
|
|
var this$1 = this;
|
|
if (!this.isVideo()) {
|
|
return;
|
|
}
|
|
if (this.isIFrame()) {
|
|
this.enableApi().then(function() {
|
|
return post(this$1.el, {
|
|
func: "pauseVideo",
|
|
method: "pause"
|
|
});
|
|
});
|
|
} else if (this.isHTML5()) {
|
|
this.el.pause();
|
|
}
|
|
};
|
|
Player.prototype.mute = function() {
|
|
var this$1 = this;
|
|
if (!this.isVideo()) {
|
|
return;
|
|
}
|
|
if (this.isIFrame()) {
|
|
this.enableApi().then(function() {
|
|
return post(this$1.el, {
|
|
func: "mute",
|
|
method: "setVolume",
|
|
value: 0
|
|
});
|
|
});
|
|
} else if (this.isHTML5()) {
|
|
this.el.muted = true;
|
|
attr(this.el, "muted", "");
|
|
}
|
|
};
|
|
function post(el, cmd) {
|
|
try {
|
|
el.contentWindow.postMessage(JSON.stringify(assign({
|
|
event: "command"
|
|
}, cmd)), "*");
|
|
} catch (e) {}
|
|
}
|
|
function listen(cb) {
|
|
return new Promise(function(resolve) {
|
|
once(window, "message", function(_, data$$1) {
|
|
return resolve(data$$1);
|
|
}, false, function(ref) {
|
|
var data$$1 = ref.data;
|
|
if (!data$$1 || !isString(data$$1)) {
|
|
return;
|
|
}
|
|
try {
|
|
data$$1 = JSON.parse(data$$1);
|
|
} catch (e) {
|
|
return;
|
|
}
|
|
return data$$1 && cb(data$$1);
|
|
});
|
|
});
|
|
}
|
|
var touch = {}, clickTimeout, swipeTimeout, tapTimeout, clicked;
|
|
function swipeDirection(ref) {
|
|
var x1 = ref.x1;
|
|
var x2 = ref.x2;
|
|
var y1 = ref.y1;
|
|
var y2 = ref.y2;
|
|
return Math.abs(x1 - x2) >= Math.abs(y1 - y2) ? x1 - x2 > 0 ? "Left" : "Right" : y1 - y2 > 0 ? "Up" : "Down";
|
|
}
|
|
function cancelAll() {
|
|
clickTimeout && clearTimeout(clickTimeout);
|
|
swipeTimeout && clearTimeout(swipeTimeout);
|
|
tapTimeout && clearTimeout(tapTimeout);
|
|
clickTimeout = swipeTimeout = tapTimeout = null;
|
|
touch = {};
|
|
}
|
|
ready(function() {
|
|
on(document, "click", function() {
|
|
return clicked = true;
|
|
}, true);
|
|
on(document, pointerDown, function(e) {
|
|
var target = e.target;
|
|
var ref = getPos$1(e);
|
|
var x = ref.x;
|
|
var y = ref.y;
|
|
var now = Date.now();
|
|
var type = getType(e.type);
|
|
if (touch.type && touch.type !== type) {
|
|
return;
|
|
}
|
|
touch.el = "tagName" in target ? target : target.parentNode;
|
|
clickTimeout && clearTimeout(clickTimeout);
|
|
touch.x1 = x;
|
|
touch.y1 = y;
|
|
if (touch.last && now - touch.last <= 250) {
|
|
touch = {};
|
|
}
|
|
touch.type = type;
|
|
touch.last = now;
|
|
clicked = e.button > 0;
|
|
});
|
|
on(document, pointerMove, function(e) {
|
|
if (e.defaultPrevented) {
|
|
return;
|
|
}
|
|
var ref = getPos$1(e);
|
|
var x = ref.x;
|
|
var y = ref.y;
|
|
touch.x2 = x;
|
|
touch.y2 = y;
|
|
});
|
|
on(document, pointerUp, function(ref) {
|
|
var type = ref.type;
|
|
var target = ref.target;
|
|
if (touch.type !== getType(type)) {
|
|
return;
|
|
}
|
|
if (touch.x2 && Math.abs(touch.x1 - touch.x2) > 30 || touch.y2 && Math.abs(touch.y1 - touch.y2) > 30) {
|
|
swipeTimeout = setTimeout(function() {
|
|
if (touch.el) {
|
|
trigger(touch.el, "swipe");
|
|
trigger(touch.el, "swipe" + swipeDirection(touch));
|
|
}
|
|
touch = {};
|
|
});
|
|
} else if ("last" in touch) {
|
|
tapTimeout = setTimeout(function() {
|
|
return trigger(touch.el, "tap");
|
|
});
|
|
if (touch.el && type !== "mouseup" && within(target, touch.el)) {
|
|
clickTimeout = setTimeout(function() {
|
|
clickTimeout = null;
|
|
if (touch.el && !clicked) {
|
|
trigger(touch.el, "click");
|
|
}
|
|
touch = {};
|
|
}, 350);
|
|
}
|
|
} else {
|
|
touch = {};
|
|
}
|
|
});
|
|
on(document, "touchcancel", cancelAll);
|
|
on(window, "scroll", cancelAll);
|
|
});
|
|
var touching = false;
|
|
on(document, "touchstart", function() {
|
|
return touching = true;
|
|
}, true);
|
|
on(document, "click", function() {
|
|
touching = false;
|
|
});
|
|
on(document, "touchcancel", function() {
|
|
return touching = false;
|
|
}, true);
|
|
function isTouch(e) {
|
|
return touching || e.pointerType === "touch";
|
|
}
|
|
function getPos$1(e) {
|
|
var touches = e.touches;
|
|
var changedTouches = e.changedTouches;
|
|
var ref = touches && touches[0] || changedTouches && changedTouches[0] || e;
|
|
var x = ref.pageX;
|
|
var y = ref.pageY;
|
|
return {
|
|
x: x,
|
|
y: y
|
|
};
|
|
}
|
|
function getType(type) {
|
|
return type.slice(0, 5);
|
|
}
|
|
var util = Object.freeze({
|
|
ajax: ajax,
|
|
getImage: getImage,
|
|
transition: transition,
|
|
Transition: Transition,
|
|
animate: animate,
|
|
Animation: Animation,
|
|
attr: attr,
|
|
hasAttr: hasAttr,
|
|
removeAttr: removeAttr,
|
|
data: data,
|
|
addClass: addClass,
|
|
removeClass: removeClass,
|
|
removeClasses: removeClasses,
|
|
replaceClass: replaceClass,
|
|
hasClass: hasClass,
|
|
toggleClass: toggleClass,
|
|
positionAt: positionAt,
|
|
offset: offset,
|
|
position: position,
|
|
height: height,
|
|
width: width,
|
|
boxModelAdjust: boxModelAdjust,
|
|
flipPosition: flipPosition,
|
|
isInView: isInView,
|
|
scrolledOver: scrolledOver,
|
|
scrollTop: scrollTop,
|
|
isReady: isReady,
|
|
ready: ready,
|
|
index: index,
|
|
getIndex: getIndex,
|
|
empty: empty,
|
|
html: html,
|
|
prepend: prepend,
|
|
append: append,
|
|
before: before,
|
|
after: after,
|
|
remove: remove,
|
|
wrapAll: wrapAll,
|
|
wrapInner: wrapInner,
|
|
unwrap: unwrap,
|
|
fragment: fragment,
|
|
apply: apply,
|
|
$: $,
|
|
$$: $$,
|
|
isIE: isIE,
|
|
isRtl: isRtl,
|
|
hasTouch: hasTouch,
|
|
pointerDown: pointerDown,
|
|
pointerMove: pointerMove,
|
|
pointerUp: pointerUp,
|
|
pointerEnter: pointerEnter,
|
|
pointerLeave: pointerLeave,
|
|
on: on,
|
|
off: off,
|
|
once: once,
|
|
trigger: trigger,
|
|
createEvent: createEvent,
|
|
toEventTargets: toEventTargets,
|
|
preventClick: preventClick,
|
|
fastdom: fastdom,
|
|
isVoidElement: isVoidElement,
|
|
isVisible: isVisible,
|
|
selInput: selInput,
|
|
isInput: isInput,
|
|
filter: filter,
|
|
within: within,
|
|
bind: bind,
|
|
hasOwn: hasOwn,
|
|
hyphenate: hyphenate,
|
|
camelize: camelize,
|
|
ucfirst: ucfirst,
|
|
startsWith: startsWith,
|
|
endsWith: endsWith,
|
|
includes: includes,
|
|
isArray: isArray,
|
|
isFunction: isFunction,
|
|
isObject: isObject,
|
|
isPlainObject: isPlainObject,
|
|
isWindow: isWindow,
|
|
isDocument: isDocument,
|
|
isJQuery: isJQuery,
|
|
isNode: isNode,
|
|
isNodeCollection: isNodeCollection,
|
|
isBoolean: isBoolean,
|
|
isString: isString,
|
|
isNumber: isNumber,
|
|
isNumeric: isNumeric,
|
|
isUndefined: isUndefined,
|
|
toBoolean: toBoolean,
|
|
toNumber: toNumber,
|
|
toFloat: toFloat,
|
|
toNode: toNode,
|
|
toNodes: toNodes,
|
|
toList: toList,
|
|
toMs: toMs,
|
|
swap: swap,
|
|
assign: assign,
|
|
each: each,
|
|
sortBy: sortBy,
|
|
clamp: clamp,
|
|
noop: noop,
|
|
intersectRect: intersectRect,
|
|
pointInRect: pointInRect,
|
|
Dimensions: Dimensions,
|
|
MouseTracker: MouseTracker,
|
|
mergeOptions: mergeOptions,
|
|
parseOptions: parseOptions,
|
|
Player: Player,
|
|
Promise: Promise,
|
|
Deferred: Deferred,
|
|
query: query,
|
|
queryAll: queryAll,
|
|
find: find,
|
|
findAll: findAll,
|
|
matches: matches,
|
|
closest: closest,
|
|
parents: parents,
|
|
escape: escape,
|
|
css: css,
|
|
getStyles: getStyles,
|
|
getStyle: getStyle,
|
|
getCssVar: getCssVar,
|
|
propName: propName,
|
|
isTouch: isTouch,
|
|
getPos: getPos$1
|
|
});
|
|
function componentAPI(UIkit) {
|
|
var DATA = UIkit.data;
|
|
var components = {};
|
|
UIkit.component = function(name, options) {
|
|
if (!options) {
|
|
if (isPlainObject(components[name])) {
|
|
components[name] = UIkit.extend(components[name]);
|
|
}
|
|
return components[name];
|
|
}
|
|
UIkit[name] = function(element, data$$1) {
|
|
var i = arguments.length, argsArray = Array(i);
|
|
while (i--) argsArray[i] = arguments[i];
|
|
var component = UIkit.component(name);
|
|
if (isPlainObject(element)) {
|
|
return new component({
|
|
data: element
|
|
});
|
|
}
|
|
if (component.options.functional) {
|
|
return new component({
|
|
data: [].concat(argsArray)
|
|
});
|
|
}
|
|
return element && element.nodeType ? init(element) : $$(element).map(init)[0];
|
|
function init(element) {
|
|
var instance = UIkit.getComponent(element, name);
|
|
if (instance) {
|
|
if (!data$$1) {
|
|
return instance;
|
|
} else {
|
|
instance.$destroy();
|
|
}
|
|
}
|
|
return new component({
|
|
el: element,
|
|
data: data$$1
|
|
});
|
|
}
|
|
};
|
|
var opt = isPlainObject(options) ? assign({}, options) : options.options;
|
|
opt.name = name;
|
|
if (opt.install) {
|
|
opt.install(UIkit, opt, name);
|
|
}
|
|
if (UIkit._initialized && !opt.functional) {
|
|
var id = hyphenate(name);
|
|
fastdom.read(function() {
|
|
return UIkit[name]("[uk-" + id + "],[data-uk-" + id + "]");
|
|
});
|
|
}
|
|
return components[name] = isPlainObject(options) ? opt : options;
|
|
};
|
|
UIkit.getComponents = function(element) {
|
|
return element && element[DATA] || {};
|
|
};
|
|
UIkit.getComponent = function(element, name) {
|
|
return UIkit.getComponents(element)[name];
|
|
};
|
|
UIkit.connect = function(node) {
|
|
if (node[DATA]) {
|
|
for (var name in node[DATA]) {
|
|
node[DATA][name]._callConnected();
|
|
}
|
|
}
|
|
for (var i = 0; i < node.attributes.length; i++) {
|
|
var name$1 = getComponentName(node.attributes[i].name);
|
|
if (name$1 && name$1 in components) {
|
|
UIkit[name$1](node);
|
|
}
|
|
}
|
|
};
|
|
UIkit.disconnect = function(node) {
|
|
for (var name in node[DATA]) {
|
|
node[DATA][name]._callDisconnected();
|
|
}
|
|
};
|
|
}
|
|
function getComponentName(attribute) {
|
|
return startsWith(attribute, "uk-") || startsWith(attribute, "data-uk-") ? camelize(attribute.replace("data-uk-", "").replace("uk-", "")) : false;
|
|
}
|
|
function boot(UIkit) {
|
|
var connect = UIkit.connect;
|
|
var disconnect = UIkit.disconnect;
|
|
if (!("MutationObserver" in window)) {
|
|
return;
|
|
}
|
|
if (document.body) {
|
|
init();
|
|
} else {
|
|
new MutationObserver(function() {
|
|
if (document.body) {
|
|
this.disconnect();
|
|
init();
|
|
}
|
|
}).observe(document, {
|
|
childList: true,
|
|
subtree: true
|
|
});
|
|
}
|
|
function init() {
|
|
apply$$1(document.body, connect);
|
|
fastdom.flush();
|
|
new MutationObserver(function(mutations) {
|
|
return mutations.forEach(applyMutation);
|
|
}).observe(document, {
|
|
childList: true,
|
|
subtree: true,
|
|
characterData: true,
|
|
attributes: true
|
|
});
|
|
UIkit._initialized = true;
|
|
}
|
|
function applyMutation(mutation) {
|
|
var target = mutation.target;
|
|
var type = mutation.type;
|
|
var update = type !== "attributes" ? applyChildList(mutation) : applyAttribute(mutation);
|
|
update && UIkit.update(target);
|
|
}
|
|
function applyAttribute(ref) {
|
|
var target = ref.target;
|
|
var attributeName = ref.attributeName;
|
|
if (attributeName === "href") {
|
|
return true;
|
|
}
|
|
var name = getComponentName(attributeName);
|
|
if (!name || !(name in UIkit)) {
|
|
return;
|
|
}
|
|
if (hasAttr(target, attributeName)) {
|
|
UIkit[name](target);
|
|
return true;
|
|
}
|
|
var component = UIkit.getComponent(target, name);
|
|
if (component) {
|
|
component.$destroy();
|
|
return true;
|
|
}
|
|
}
|
|
function applyChildList(ref) {
|
|
var addedNodes = ref.addedNodes;
|
|
var removedNodes = ref.removedNodes;
|
|
for (var i = 0; i < addedNodes.length; i++) {
|
|
apply$$1(addedNodes[i], connect);
|
|
}
|
|
for (var i$1 = 0; i$1 < removedNodes.length; i$1++) {
|
|
apply$$1(removedNodes[i$1], disconnect);
|
|
}
|
|
return true;
|
|
}
|
|
function apply$$1(node, fn) {
|
|
if (node.nodeType !== 1 || hasAttr(node, "uk-no-boot")) {
|
|
return;
|
|
}
|
|
fn(node);
|
|
node = node.firstElementChild;
|
|
while (node) {
|
|
var next = node.nextElementSibling;
|
|
apply$$1(node, fn);
|
|
node = next;
|
|
}
|
|
}
|
|
}
|
|
function globalAPI(UIkit) {
|
|
var DATA = UIkit.data;
|
|
UIkit.use = function(plugin) {
|
|
if (plugin.installed) {
|
|
return;
|
|
}
|
|
plugin.call(null, this);
|
|
plugin.installed = true;
|
|
return this;
|
|
};
|
|
UIkit.mixin = function(mixin, component) {
|
|
component = (isString(component) ? UIkit.component(component) : component) || this;
|
|
component.options = mergeOptions(component.options, mixin);
|
|
};
|
|
UIkit.extend = function(options) {
|
|
options = options || {};
|
|
var Super = this;
|
|
var Sub = function UIkitComponent(options) {
|
|
this._init(options);
|
|
};
|
|
Sub.prototype = Object.create(Super.prototype);
|
|
Sub.prototype.constructor = Sub;
|
|
Sub.options = mergeOptions(Super.options, options);
|
|
Sub.super = Super;
|
|
Sub.extend = Super.extend;
|
|
return Sub;
|
|
};
|
|
UIkit.update = function(element, e) {
|
|
e = createEvent(e || "update");
|
|
element = element ? toNode(element) : document.body;
|
|
path(element).map(function(element) {
|
|
return update(element[DATA], e);
|
|
});
|
|
apply(element, function(element) {
|
|
return update(element[DATA], e);
|
|
});
|
|
};
|
|
var container;
|
|
Object.defineProperty(UIkit, "container", {
|
|
get: function() {
|
|
return container || document.body;
|
|
},
|
|
set: function(element) {
|
|
container = $(element);
|
|
}
|
|
});
|
|
function update(data$$1, e) {
|
|
if (!data$$1) {
|
|
return;
|
|
}
|
|
for (var name in data$$1) {
|
|
if (data$$1[name]._connected) {
|
|
data$$1[name]._callUpdate(e);
|
|
}
|
|
}
|
|
}
|
|
function path(element) {
|
|
var path = [];
|
|
while (element && element !== document.body && element.parentNode) {
|
|
element = element.parentNode;
|
|
path.unshift(element);
|
|
}
|
|
return path;
|
|
}
|
|
}
|
|
function hooksAPI(UIkit) {
|
|
UIkit.prototype._callHook = function(hook) {
|
|
var this$1 = this;
|
|
var handlers = this.$options[hook];
|
|
if (handlers) {
|
|
handlers.forEach(function(handler) {
|
|
return handler.call(this$1);
|
|
});
|
|
}
|
|
};
|
|
UIkit.prototype._callConnected = function() {
|
|
if (this._connected) {
|
|
return;
|
|
}
|
|
this._data = {};
|
|
this._initProps();
|
|
this._callHook("beforeConnect");
|
|
this._connected = true;
|
|
this._initEvents();
|
|
this._initObserver();
|
|
this._callHook("connected");
|
|
this._callUpdate();
|
|
};
|
|
UIkit.prototype._callDisconnected = function() {
|
|
if (!this._connected) {
|
|
return;
|
|
}
|
|
this._callHook("beforeDisconnect");
|
|
if (this._observer) {
|
|
this._observer.disconnect();
|
|
this._observer = null;
|
|
}
|
|
this._unbindEvents();
|
|
this._callHook("disconnected");
|
|
this._connected = false;
|
|
};
|
|
UIkit.prototype._callUpdate = function(e) {
|
|
var this$1 = this;
|
|
e = createEvent(e || "update");
|
|
var type = e.type;
|
|
if (includes([ "update", "load", "resize" ], type)) {
|
|
this._resetComputeds();
|
|
}
|
|
var updates = this.$options.update;
|
|
var ref = this._frames;
|
|
var reads = ref.reads;
|
|
var writes = ref.writes;
|
|
if (!updates) {
|
|
return;
|
|
}
|
|
updates.forEach(function(ref, i) {
|
|
var read = ref.read;
|
|
var write = ref.write;
|
|
var events = ref.events;
|
|
if (type !== "update" && !includes(events, type)) {
|
|
return;
|
|
}
|
|
if (read && !includes(fastdom.reads, reads[i])) {
|
|
reads[i] = fastdom.read(function() {
|
|
var result = this$1._connected && read.call(this$1, this$1._data, e);
|
|
if (result === false && write) {
|
|
fastdom.clear(writes[i]);
|
|
delete writes[i];
|
|
} else if (isPlainObject(result)) {
|
|
assign(this$1._data, result);
|
|
}
|
|
delete reads[i];
|
|
});
|
|
}
|
|
if (write && !includes(fastdom.writes, writes[i])) {
|
|
writes[i] = fastdom.write(function() {
|
|
this$1._connected && write.call(this$1, this$1._data, e);
|
|
delete writes[i];
|
|
});
|
|
}
|
|
});
|
|
};
|
|
}
|
|
function stateAPI(UIkit) {
|
|
var uid = 0;
|
|
UIkit.prototype._init = function(options) {
|
|
options = options || {};
|
|
options.data = normalizeData(options, this.constructor.options);
|
|
this.$options = mergeOptions(this.constructor.options, options, this);
|
|
this.$el = null;
|
|
this.$props = {};
|
|
this._frames = {
|
|
reads: {},
|
|
writes: {}
|
|
};
|
|
this._events = [];
|
|
this._uid = uid++;
|
|
this._initData();
|
|
this._initMethods();
|
|
this._initComputeds();
|
|
this._callHook("created");
|
|
if (options.el) {
|
|
this.$mount(options.el);
|
|
}
|
|
};
|
|
UIkit.prototype._initData = function() {
|
|
var this$1 = this;
|
|
var ref = this.$options;
|
|
var data$$1 = ref.data;
|
|
if (data$$1 === void 0) data$$1 = {};
|
|
for (var key in data$$1) {
|
|
this$1.$props[key] = this$1[key] = data$$1[key];
|
|
}
|
|
};
|
|
UIkit.prototype._initMethods = function() {
|
|
var this$1 = this;
|
|
var ref = this.$options;
|
|
var methods = ref.methods;
|
|
if (methods) {
|
|
for (var key in methods) {
|
|
this$1[key] = bind(methods[key], this$1);
|
|
}
|
|
}
|
|
};
|
|
UIkit.prototype._initComputeds = function() {
|
|
var this$1 = this;
|
|
var ref = this.$options;
|
|
var computed = ref.computed;
|
|
this._resetComputeds();
|
|
if (computed) {
|
|
for (var key in computed) {
|
|
registerComputed(this$1, key, computed[key]);
|
|
}
|
|
}
|
|
};
|
|
UIkit.prototype._resetComputeds = function() {
|
|
this._computeds = {};
|
|
};
|
|
UIkit.prototype._initProps = function(props) {
|
|
var this$1 = this;
|
|
var key;
|
|
this._resetComputeds();
|
|
props = props || getProps(this.$options, this.$name);
|
|
for (key in props) {
|
|
if (!isUndefined(props[key])) {
|
|
this$1.$props[key] = props[key];
|
|
}
|
|
}
|
|
var exclude = [ this.$options.computed, this.$options.methods ];
|
|
for (key in this$1.$props) {
|
|
if (key in props && notIn(exclude, key)) {
|
|
this$1[key] = this$1.$props[key];
|
|
}
|
|
}
|
|
};
|
|
UIkit.prototype._initEvents = function() {
|
|
var this$1 = this;
|
|
var ref = this.$options;
|
|
var events = ref.events;
|
|
if (events) {
|
|
events.forEach(function(event) {
|
|
if (!hasOwn(event, "handler")) {
|
|
for (var key in event) {
|
|
registerEvent(this$1, event[key], key);
|
|
}
|
|
} else {
|
|
registerEvent(this$1, event);
|
|
}
|
|
});
|
|
}
|
|
};
|
|
UIkit.prototype._unbindEvents = function() {
|
|
this._events.forEach(function(unbind) {
|
|
return unbind();
|
|
});
|
|
this._events = [];
|
|
};
|
|
UIkit.prototype._initObserver = function() {
|
|
var this$1 = this;
|
|
var ref = this.$options;
|
|
var attrs = ref.attrs;
|
|
var props = ref.props;
|
|
var el = ref.el;
|
|
if (this._observer || !props || attrs === false) {
|
|
return;
|
|
}
|
|
attrs = isArray(attrs) ? attrs : Object.keys(props);
|
|
this._observer = new MutationObserver(function() {
|
|
var data$$1 = getProps(this$1.$options, this$1.$name);
|
|
if (attrs.some(function(key) {
|
|
return !isUndefined(data$$1[key]) && data$$1[key] !== this$1.$props[key];
|
|
})) {
|
|
this$1.$reset();
|
|
}
|
|
});
|
|
var filter$$1 = attrs.map(function(key) {
|
|
return hyphenate(key);
|
|
}).concat(this.$name);
|
|
this._observer.observe(el, {
|
|
attributes: true,
|
|
attributeFilter: filter$$1.concat(filter$$1.map(function(key) {
|
|
return "data-" + key;
|
|
}))
|
|
});
|
|
};
|
|
function getProps(opts, name) {
|
|
var data$$1 = {};
|
|
var args = opts.args;
|
|
if (args === void 0) args = [];
|
|
var props = opts.props;
|
|
if (props === void 0) props = {};
|
|
var el = opts.el;
|
|
if (!props) {
|
|
return data$$1;
|
|
}
|
|
for (var key in props) {
|
|
var prop = hyphenate(key);
|
|
var value = data(el, prop);
|
|
if (!isUndefined(value)) {
|
|
value = props[key] === Boolean && value === "" ? true : coerce(props[key], value);
|
|
if (prop === "target" && (!value || startsWith(value, "_"))) {
|
|
continue;
|
|
}
|
|
data$$1[key] = value;
|
|
}
|
|
}
|
|
var options = parseOptions(data(el, name), args);
|
|
for (var key$1 in options) {
|
|
var prop$1 = camelize(key$1);
|
|
if (props[prop$1] !== undefined) {
|
|
data$$1[prop$1] = coerce(props[prop$1], options[key$1]);
|
|
}
|
|
}
|
|
return data$$1;
|
|
}
|
|
function registerComputed(component, key, cb) {
|
|
Object.defineProperty(component, key, {
|
|
enumerable: true,
|
|
get: function() {
|
|
var _computeds = component._computeds;
|
|
var $props = component.$props;
|
|
var $el = component.$el;
|
|
if (!hasOwn(_computeds, key)) {
|
|
_computeds[key] = cb.call(component, $props, $el);
|
|
}
|
|
return _computeds[key];
|
|
},
|
|
set: function(value) {
|
|
component._computeds[key] = value;
|
|
}
|
|
});
|
|
}
|
|
function registerEvent(component, event, key) {
|
|
if (!isPlainObject(event)) {
|
|
event = {
|
|
name: key,
|
|
handler: event
|
|
};
|
|
}
|
|
var name = event.name;
|
|
var el = event.el;
|
|
var handler = event.handler;
|
|
var capture = event.capture;
|
|
var passive = event.passive;
|
|
var delegate = event.delegate;
|
|
var filter$$1 = event.filter;
|
|
var self = event.self;
|
|
el = isFunction(el) ? el.call(component) : el || component.$el;
|
|
if (isArray(el)) {
|
|
el.forEach(function(el) {
|
|
return registerEvent(component, assign({}, event, {
|
|
el: el
|
|
}), key);
|
|
});
|
|
return;
|
|
}
|
|
if (!el || filter$$1 && !filter$$1.call(component)) {
|
|
return;
|
|
}
|
|
handler = detail(isString(handler) ? component[handler] : bind(handler, component));
|
|
if (self) {
|
|
handler = selfFilter(handler);
|
|
}
|
|
component._events.push(on(el, name, !delegate ? null : isString(delegate) ? delegate : delegate.call(component), handler, isBoolean(passive) ? {
|
|
passive: passive,
|
|
capture: capture
|
|
} : capture));
|
|
}
|
|
function selfFilter(handler) {
|
|
return function selfHandler(e) {
|
|
if (e.target === e.currentTarget || e.target === e.current) {
|
|
return handler.call(null, e);
|
|
}
|
|
};
|
|
}
|
|
function notIn(options, key) {
|
|
return options.every(function(arr) {
|
|
return !arr || !hasOwn(arr, key);
|
|
});
|
|
}
|
|
function detail(listener) {
|
|
return function(e) {
|
|
return isArray(e.detail) ? listener.apply(void 0, [ e ].concat(e.detail)) : listener(e);
|
|
};
|
|
}
|
|
function coerce(type, value) {
|
|
if (type === Boolean) {
|
|
return toBoolean(value);
|
|
} else if (type === Number) {
|
|
return toNumber(value);
|
|
} else if (type === "list") {
|
|
return toList(value);
|
|
}
|
|
return type ? type(value) : value;
|
|
}
|
|
function normalizeData(ref, ref$1) {
|
|
var data$$1 = ref.data;
|
|
var el = ref.el;
|
|
var args = ref$1.args;
|
|
var props = ref$1.props;
|
|
if (props === void 0) props = {};
|
|
data$$1 = isArray(data$$1) ? args && args.length ? data$$1.slice(0, args.length).reduce(function(data$$1, value, index$$1) {
|
|
if (isPlainObject(value)) {
|
|
assign(data$$1, value);
|
|
} else {
|
|
data$$1[args[index$$1]] = value;
|
|
}
|
|
return data$$1;
|
|
}, {}) : undefined : data$$1;
|
|
if (data$$1) {
|
|
for (var key in data$$1) {
|
|
if (isUndefined(data$$1[key])) {
|
|
delete data$$1[key];
|
|
} else {
|
|
data$$1[key] = props[key] ? coerce(props[key], data$$1[key], el) : data$$1[key];
|
|
}
|
|
}
|
|
}
|
|
return data$$1;
|
|
}
|
|
}
|
|
function instanceAPI(UIkit) {
|
|
var DATA = UIkit.data;
|
|
UIkit.prototype.$mount = function(el) {
|
|
var ref = this.$options;
|
|
var name = ref.name;
|
|
if (!el[DATA]) {
|
|
el[DATA] = {};
|
|
}
|
|
if (el[DATA][name]) {
|
|
return;
|
|
}
|
|
el[DATA][name] = this;
|
|
this.$el = this.$options.el = this.$options.el || el;
|
|
if (within(el, document)) {
|
|
this._callConnected();
|
|
}
|
|
};
|
|
UIkit.prototype.$emit = function(e) {
|
|
this._callUpdate(e);
|
|
};
|
|
UIkit.prototype.$reset = function() {
|
|
this._callDisconnected();
|
|
this._callConnected();
|
|
};
|
|
UIkit.prototype.$destroy = function(removeEl) {
|
|
if (removeEl === void 0) removeEl = false;
|
|
var ref = this.$options;
|
|
var el = ref.el;
|
|
var name = ref.name;
|
|
if (el) {
|
|
this._callDisconnected();
|
|
}
|
|
this._callHook("destroy");
|
|
if (!el || !el[DATA]) {
|
|
return;
|
|
}
|
|
delete el[DATA][name];
|
|
if (!Object.keys(el[DATA]).length) {
|
|
delete el[DATA];
|
|
}
|
|
if (removeEl) {
|
|
remove(this.$el);
|
|
}
|
|
};
|
|
UIkit.prototype.$create = function(component, element, data$$1) {
|
|
return UIkit[component](element, data$$1);
|
|
};
|
|
UIkit.prototype.$update = UIkit.update;
|
|
UIkit.prototype.$getComponent = UIkit.getComponent;
|
|
var names = {};
|
|
Object.defineProperties(UIkit.prototype, {
|
|
$container: Object.getOwnPropertyDescriptor(UIkit, "container"),
|
|
$name: {
|
|
get: function() {
|
|
var ref = this.$options;
|
|
var name = ref.name;
|
|
if (!names[name]) {
|
|
names[name] = UIkit.prefix + hyphenate(name);
|
|
}
|
|
return names[name];
|
|
}
|
|
}
|
|
});
|
|
}
|
|
var UIkit = function(options) {
|
|
this._init(options);
|
|
};
|
|
UIkit.util = util;
|
|
UIkit.data = "__uikit__";
|
|
UIkit.prefix = "uk-";
|
|
UIkit.options = {};
|
|
globalAPI(UIkit);
|
|
hooksAPI(UIkit);
|
|
stateAPI(UIkit);
|
|
componentAPI(UIkit);
|
|
instanceAPI(UIkit);
|
|
var Class = {
|
|
connected: function() {
|
|
addClass(this.$el, this.$name);
|
|
}
|
|
};
|
|
var Togglable = {
|
|
props: {
|
|
cls: Boolean,
|
|
animation: "list",
|
|
duration: Number,
|
|
origin: String,
|
|
transition: String,
|
|
queued: Boolean
|
|
},
|
|
data: {
|
|
cls: false,
|
|
animation: [ false ],
|
|
duration: 200,
|
|
origin: false,
|
|
transition: "linear",
|
|
queued: false,
|
|
initProps: {
|
|
overflow: "",
|
|
height: "",
|
|
paddingTop: "",
|
|
paddingBottom: "",
|
|
marginTop: "",
|
|
marginBottom: ""
|
|
},
|
|
hideProps: {
|
|
overflow: "hidden",
|
|
height: 0,
|
|
paddingTop: 0,
|
|
paddingBottom: 0,
|
|
marginTop: 0,
|
|
marginBottom: 0
|
|
}
|
|
},
|
|
computed: {
|
|
hasAnimation: function(ref) {
|
|
var animation = ref.animation;
|
|
return !!animation[0];
|
|
},
|
|
hasTransition: function(ref) {
|
|
var animation = ref.animation;
|
|
return this.hasAnimation && animation[0] === true;
|
|
}
|
|
},
|
|
methods: {
|
|
toggleElement: function(targets, show, animate$$1) {
|
|
var this$1 = this;
|
|
return new Promise(function(resolve) {
|
|
targets = toNodes(targets);
|
|
var all = function(targets) {
|
|
return Promise.all(targets.map(function(el) {
|
|
return this$1._toggleElement(el, show, animate$$1);
|
|
}));
|
|
};
|
|
var toggled = targets.filter(function(el) {
|
|
return this$1.isToggled(el);
|
|
});
|
|
var untoggled = targets.filter(function(el) {
|
|
return !includes(toggled, el);
|
|
});
|
|
var p;
|
|
if (!this$1.queued || !isUndefined(animate$$1) || !isUndefined(show) || !this$1.hasAnimation || targets.length < 2) {
|
|
p = all(untoggled.concat(toggled));
|
|
} else {
|
|
var body = document.body;
|
|
var scroll = body.scrollTop;
|
|
var el = toggled[0];
|
|
var inProgress = Animation.inProgress(el) && hasClass(el, "uk-animation-leave") || Transition.inProgress(el) && el.style.height === "0px";
|
|
p = all(toggled);
|
|
if (!inProgress) {
|
|
p = p.then(function() {
|
|
var p = all(untoggled);
|
|
body.scrollTop = scroll;
|
|
return p;
|
|
});
|
|
}
|
|
}
|
|
p.then(resolve, noop);
|
|
});
|
|
},
|
|
toggleNow: function(targets, show) {
|
|
var this$1 = this;
|
|
return new Promise(function(resolve) {
|
|
return Promise.all(toNodes(targets).map(function(el) {
|
|
return this$1._toggleElement(el, show, false);
|
|
})).then(resolve, noop);
|
|
});
|
|
},
|
|
isToggled: function(el) {
|
|
var nodes = toNodes(el || this.$el);
|
|
return this.cls ? hasClass(nodes, this.cls.split(" ")[0]) : !hasAttr(nodes, "hidden");
|
|
},
|
|
updateAria: function(el) {
|
|
if (this.cls === false) {
|
|
attr(el, "aria-hidden", !this.isToggled(el));
|
|
}
|
|
},
|
|
_toggleElement: function(el, show, animate$$1) {
|
|
var this$1 = this;
|
|
show = isBoolean(show) ? show : Animation.inProgress(el) ? hasClass(el, "uk-animation-leave") : Transition.inProgress(el) ? el.style.height === "0px" : !this.isToggled(el);
|
|
if (!trigger(el, "before" + (show ? "show" : "hide"), [ this ])) {
|
|
return Promise.reject();
|
|
}
|
|
var promise = (animate$$1 === false || !this.hasAnimation ? this._toggleImmediate : this.hasTransition ? this._toggleHeight : this._toggleAnimation)(el, show);
|
|
trigger(el, show ? "show" : "hide", [ this ]);
|
|
return promise.then(function() {
|
|
trigger(el, show ? "shown" : "hidden", [ this$1 ]);
|
|
this$1.$update(el);
|
|
});
|
|
},
|
|
_toggle: function(el, toggled) {
|
|
if (!el) {
|
|
return;
|
|
}
|
|
var changed;
|
|
if (this.cls) {
|
|
changed = includes(this.cls, " ") || Boolean(toggled) !== hasClass(el, this.cls);
|
|
changed && toggleClass(el, this.cls, includes(this.cls, " ") ? undefined : toggled);
|
|
} else {
|
|
changed = Boolean(toggled) === hasAttr(el, "hidden");
|
|
changed && attr(el, "hidden", !toggled ? "" : null);
|
|
}
|
|
$$("[autofocus]", el).some(function(el) {
|
|
return isVisible(el) && (el.focus() || true);
|
|
});
|
|
this.updateAria(el);
|
|
changed && this.$update(el);
|
|
},
|
|
_toggleImmediate: function(el, show) {
|
|
this._toggle(el, show);
|
|
return Promise.resolve();
|
|
},
|
|
_toggleHeight: function(el, show) {
|
|
var this$1 = this;
|
|
var inProgress = Transition.inProgress(el);
|
|
var inner = el.hasChildNodes ? toFloat(css(el.firstElementChild, "marginTop")) + toFloat(css(el.lastElementChild, "marginBottom")) : 0;
|
|
var currentHeight = isVisible(el) ? height(el) + (inProgress ? 0 : inner) : 0;
|
|
Transition.cancel(el);
|
|
if (!this.isToggled(el)) {
|
|
this._toggle(el, true);
|
|
}
|
|
height(el, "");
|
|
fastdom.flush();
|
|
var endHeight = height(el) + (inProgress ? 0 : inner);
|
|
height(el, currentHeight);
|
|
return (show ? Transition.start(el, assign({}, this.initProps, {
|
|
overflow: "hidden",
|
|
height: endHeight
|
|
}), Math.round(this.duration * (1 - currentHeight / endHeight)), this.transition) : Transition.start(el, this.hideProps, Math.round(this.duration * (currentHeight / endHeight)), this.transition).then(function() {
|
|
return this$1._toggle(el, false);
|
|
})).then(function() {
|
|
return css(el, this$1.initProps);
|
|
});
|
|
},
|
|
_toggleAnimation: function(el, show) {
|
|
var this$1 = this;
|
|
Animation.cancel(el);
|
|
if (show) {
|
|
this._toggle(el, true);
|
|
return Animation.in(el, this.animation[0], this.duration, this.origin);
|
|
}
|
|
return Animation.out(el, this.animation[1] || this.animation[0], this.duration, this.origin).then(function() {
|
|
return this$1._toggle(el, false);
|
|
});
|
|
}
|
|
}
|
|
};
|
|
var Accordion = {
|
|
mixins: [ Class, Togglable ],
|
|
props: {
|
|
targets: String,
|
|
active: null,
|
|
collapsible: Boolean,
|
|
multiple: Boolean,
|
|
toggle: String,
|
|
content: String,
|
|
transition: String
|
|
},
|
|
data: {
|
|
targets: "> *",
|
|
active: false,
|
|
animation: [ true ],
|
|
collapsible: true,
|
|
multiple: false,
|
|
clsOpen: "uk-open",
|
|
toggle: "> .uk-accordion-title",
|
|
content: "> .uk-accordion-content",
|
|
transition: "ease"
|
|
},
|
|
computed: {
|
|
items: function(ref, $el) {
|
|
var targets = ref.targets;
|
|
return $$(targets, $el);
|
|
}
|
|
},
|
|
events: [ {
|
|
name: "click",
|
|
delegate: function() {
|
|
return this.targets + " " + this.$props.toggle;
|
|
},
|
|
handler: function(e) {
|
|
e.preventDefault();
|
|
this.toggle(index($$(this.targets + " " + this.$props.toggle, this.$el), e.current));
|
|
}
|
|
} ],
|
|
connected: function() {
|
|
if (this.active === false) {
|
|
return;
|
|
}
|
|
var active = this.items[Number(this.active)];
|
|
if (active && !hasClass(active, this.clsOpen)) {
|
|
this.toggle(active, false);
|
|
}
|
|
},
|
|
update: function() {
|
|
var this$1 = this;
|
|
this.items.forEach(function(el) {
|
|
return this$1._toggleImmediate($(this$1.content, el), hasClass(el, this$1.clsOpen));
|
|
});
|
|
var active = !this.collapsible && !hasClass(this.items, this.clsOpen) && this.items[0];
|
|
if (active) {
|
|
this.toggle(active, false);
|
|
}
|
|
},
|
|
methods: {
|
|
toggle: function(item, animate$$1) {
|
|
var this$1 = this;
|
|
var index$$1 = getIndex(item, this.items);
|
|
var active = filter(this.items, "." + this.clsOpen);
|
|
item = this.items[index$$1];
|
|
item && [ item ].concat(!this.multiple && !includes(active, item) && active || []).forEach(function(el) {
|
|
var isItem = el === item;
|
|
var state = isItem && !hasClass(el, this$1.clsOpen);
|
|
if (!state && isItem && !this$1.collapsible && active.length < 2) {
|
|
return;
|
|
}
|
|
toggleClass(el, this$1.clsOpen, state);
|
|
var content = el._wrapper ? el._wrapper.firstElementChild : $(this$1.content, el);
|
|
if (!el._wrapper) {
|
|
el._wrapper = wrapAll(content, "<div>");
|
|
attr(el._wrapper, "hidden", state ? "" : null);
|
|
}
|
|
this$1._toggleImmediate(content, true);
|
|
this$1.toggleElement(el._wrapper, state, animate$$1).then(function() {
|
|
if (hasClass(el, this$1.clsOpen) === state) {
|
|
if (!state) {
|
|
this$1._toggleImmediate(content, false);
|
|
}
|
|
el._wrapper = null;
|
|
unwrap(content);
|
|
}
|
|
});
|
|
});
|
|
}
|
|
}
|
|
};
|
|
var Alert = {
|
|
mixins: [ Class, Togglable ],
|
|
args: "animation",
|
|
props: {
|
|
close: String
|
|
},
|
|
data: {
|
|
animation: [ true ],
|
|
selClose: ".uk-alert-close",
|
|
duration: 150,
|
|
hideProps: assign({
|
|
opacity: 0
|
|
}, Togglable.data.hideProps)
|
|
},
|
|
events: [ {
|
|
name: "click",
|
|
delegate: function() {
|
|
return this.selClose;
|
|
},
|
|
handler: function(e) {
|
|
e.preventDefault();
|
|
this.close();
|
|
}
|
|
} ],
|
|
methods: {
|
|
close: function() {
|
|
var this$1 = this;
|
|
this.toggleElement(this.$el).then(function() {
|
|
return this$1.$destroy(true);
|
|
});
|
|
}
|
|
}
|
|
};
|
|
function Core(UIkit) {
|
|
ready(function() {
|
|
UIkit.update();
|
|
var scroll = 0;
|
|
var started = 0;
|
|
on(window, "load resize", function(e) {
|
|
return UIkit.update(null, e);
|
|
});
|
|
on(window, "scroll", function(e) {
|
|
var target = e.target;
|
|
e.dir = scroll <= window.pageYOffset ? "down" : "up";
|
|
e.pageYOffset = scroll = window.pageYOffset;
|
|
UIkit.update(target.nodeType !== 1 ? document.body : target, e);
|
|
}, {
|
|
passive: true,
|
|
capture: true
|
|
});
|
|
on(document, "loadedmetadata load", function(ref) {
|
|
var target = ref.target;
|
|
return UIkit.update(target, "load");
|
|
}, true);
|
|
on(document, "animationstart", function(ref) {
|
|
var target = ref.target;
|
|
if ((css(target, "animationName") || "").match(/^uk-.*(left|right)/)) {
|
|
started++;
|
|
css(document.body, "overflowX", "hidden");
|
|
setTimeout(function() {
|
|
if (!--started) {
|
|
css(document.body, "overflowX", "");
|
|
}
|
|
}, toMs(css(target, "animationDuration")) + 100);
|
|
}
|
|
}, true);
|
|
if (!hasTouch) {
|
|
return;
|
|
}
|
|
var cls = "uk-hover";
|
|
on(document, "tap", function(ref) {
|
|
var target = ref.target;
|
|
return $$("." + cls).forEach(function(el) {
|
|
return !within(target, el) && removeClass(el, cls);
|
|
});
|
|
});
|
|
Object.defineProperty(UIkit, "hoverSelector", {
|
|
set: function(selector) {
|
|
on(document, "tap", selector, function(ref) {
|
|
var current = ref.current;
|
|
return addClass(current, cls);
|
|
});
|
|
}
|
|
});
|
|
UIkit.hoverSelector = ".uk-animation-toggle, .uk-transition-toggle, [uk-hover]";
|
|
});
|
|
}
|
|
var Video = {
|
|
args: "autoplay",
|
|
props: {
|
|
automute: Boolean,
|
|
autoplay: Boolean
|
|
},
|
|
data: {
|
|
automute: false,
|
|
autoplay: true
|
|
},
|
|
computed: {
|
|
inView: function(ref) {
|
|
var autoplay = ref.autoplay;
|
|
return autoplay === "inview";
|
|
}
|
|
},
|
|
connected: function() {
|
|
if (this.inView && !hasAttr(this.$el, "preload")) {
|
|
this.$el.preload = "none";
|
|
}
|
|
this.player = new Player(this.$el);
|
|
if (this.automute) {
|
|
this.player.mute();
|
|
}
|
|
},
|
|
update: {
|
|
read: function(_, ref) {
|
|
var type = ref.type;
|
|
return !this.player || (type === "scroll" || type === "resize") && !this.inView ? false : {
|
|
visible: isVisible(this.$el) && css(this.$el, "visibility") !== "hidden",
|
|
inView: this.inView && isInView(this.$el)
|
|
};
|
|
},
|
|
write: function(ref) {
|
|
var visible = ref.visible;
|
|
var inView = ref.inView;
|
|
if (!visible || this.inView && !inView) {
|
|
this.player.pause();
|
|
} else if (this.autoplay === true || this.inView && inView) {
|
|
this.player.play();
|
|
}
|
|
},
|
|
events: [ "load", "resize", "scroll" ]
|
|
}
|
|
};
|
|
var Cover = {
|
|
mixins: [ Class, Video ],
|
|
props: {
|
|
width: Number,
|
|
height: Number
|
|
},
|
|
data: {
|
|
automute: true
|
|
},
|
|
update: {
|
|
read: function() {
|
|
var el = this.$el;
|
|
if (!isVisible(el)) {
|
|
return false;
|
|
}
|
|
var ref = el.parentNode;
|
|
var height$$1 = ref.offsetHeight;
|
|
var width$$1 = ref.offsetWidth;
|
|
return {
|
|
height: height$$1,
|
|
width: width$$1
|
|
};
|
|
},
|
|
write: function(ref) {
|
|
var height$$1 = ref.height;
|
|
var width$$1 = ref.width;
|
|
var el = this.$el;
|
|
var elWidth = this.width || el.naturalWidth || el.videoWidth || el.clientWidth;
|
|
var elHeight = this.height || el.naturalHeight || el.videoHeight || el.clientHeight;
|
|
if (!elWidth || !elHeight) {
|
|
return;
|
|
}
|
|
css(el, Dimensions.cover({
|
|
width: elWidth,
|
|
height: elHeight
|
|
}, {
|
|
width: width$$1 + (width$$1 % 2 ? 1 : 0),
|
|
height: height$$1 + (height$$1 % 2 ? 1 : 0)
|
|
}));
|
|
},
|
|
events: [ "load", "resize" ]
|
|
}
|
|
};
|
|
var Position = {
|
|
props: {
|
|
pos: String,
|
|
offset: null,
|
|
flip: Boolean,
|
|
clsPos: String
|
|
},
|
|
data: {
|
|
pos: "bottom-" + (!isRtl ? "left" : "right"),
|
|
flip: true,
|
|
offset: false,
|
|
clsPos: ""
|
|
},
|
|
computed: {
|
|
pos: function(ref) {
|
|
var pos = ref.pos;
|
|
return (pos + (!includes(pos, "-") ? "-center" : "")).split("-");
|
|
},
|
|
dir: function() {
|
|
return this.pos[0];
|
|
},
|
|
align: function() {
|
|
return this.pos[1];
|
|
}
|
|
},
|
|
methods: {
|
|
positionAt: function(element, target, boundary) {
|
|
removeClasses(element, this.clsPos + "-(top|bottom|left|right)(-[a-z]+)?");
|
|
css(element, {
|
|
top: "",
|
|
left: ""
|
|
});
|
|
var node;
|
|
var ref = this;
|
|
var offset$$1 = ref.offset;
|
|
offset$$1 = isNumeric(offset$$1) ? offset$$1 : (node = $(offset$$1)) ? offset(node)[axis === "x" ? "left" : "top"] - offset(target)[axis === "x" ? "right" : "bottom"] : 0;
|
|
var axis = this.getAxis();
|
|
var ref$1 = positionAt(element, target, axis === "x" ? flipPosition(this.dir) + " " + this.align : this.align + " " + flipPosition(this.dir), axis === "x" ? this.dir + " " + this.align : this.align + " " + this.dir, axis === "x" ? "" + (this.dir === "left" ? -offset$$1 : offset$$1) : " " + (this.dir === "top" ? -offset$$1 : offset$$1), null, this.flip, boundary).target;
|
|
var x = ref$1.x;
|
|
var y = ref$1.y;
|
|
this.dir = axis === "x" ? x : y;
|
|
this.align = axis === "x" ? y : x;
|
|
toggleClass(element, this.clsPos + "-" + this.dir + "-" + this.align, this.offset === false);
|
|
},
|
|
getAxis: function() {
|
|
return this.dir === "top" || this.dir === "bottom" ? "y" : "x";
|
|
}
|
|
}
|
|
};
|
|
var active;
|
|
var Drop = {
|
|
mixins: [ Position, Togglable ],
|
|
args: "pos",
|
|
props: {
|
|
mode: "list",
|
|
toggle: Boolean,
|
|
boundary: Boolean,
|
|
boundaryAlign: Boolean,
|
|
delayShow: Number,
|
|
delayHide: Number,
|
|
clsDrop: String
|
|
},
|
|
data: {
|
|
mode: [ "click", "hover" ],
|
|
toggle: "- *",
|
|
boundary: window,
|
|
boundaryAlign: false,
|
|
delayShow: 0,
|
|
delayHide: 800,
|
|
clsDrop: false,
|
|
hoverIdle: 200,
|
|
animation: [ "uk-animation-fade" ],
|
|
cls: "uk-open"
|
|
},
|
|
computed: {
|
|
boundary: function(ref, $el) {
|
|
var boundary = ref.boundary;
|
|
return query(boundary, $el);
|
|
},
|
|
clsDrop: function(ref) {
|
|
var clsDrop = ref.clsDrop;
|
|
return clsDrop || "uk-" + this.$options.name;
|
|
},
|
|
clsPos: function() {
|
|
return this.clsDrop;
|
|
}
|
|
},
|
|
created: function() {
|
|
this.tracker = new MouseTracker();
|
|
},
|
|
connected: function() {
|
|
addClass(this.$el, this.clsDrop);
|
|
var ref = this.$props;
|
|
var toggle = ref.toggle;
|
|
this.toggle = toggle && this.$create("toggle", query(toggle, this.$el), {
|
|
target: this.$el,
|
|
mode: this.mode
|
|
});
|
|
this.updateAria(this.$el);
|
|
},
|
|
events: [ {
|
|
name: "click",
|
|
delegate: function() {
|
|
return "." + this.clsDrop + "-close";
|
|
},
|
|
handler: function(e) {
|
|
e.preventDefault();
|
|
this.hide(false);
|
|
}
|
|
}, {
|
|
name: "click",
|
|
delegate: function() {
|
|
return 'a[href^="#"]';
|
|
},
|
|
handler: function(e) {
|
|
if (e.defaultPrevented) {
|
|
return;
|
|
}
|
|
var id = e.target.hash;
|
|
if (!id) {
|
|
e.preventDefault();
|
|
}
|
|
if (!id || !within(id, this.$el)) {
|
|
this.hide(false);
|
|
}
|
|
}
|
|
}, {
|
|
name: "beforescroll",
|
|
handler: function() {
|
|
this.hide(false);
|
|
}
|
|
}, {
|
|
name: "toggle",
|
|
self: true,
|
|
handler: function(e, toggle) {
|
|
e.preventDefault();
|
|
if (this.isToggled()) {
|
|
this.hide(false);
|
|
} else {
|
|
this.show(toggle, false);
|
|
}
|
|
}
|
|
}, {
|
|
name: pointerEnter,
|
|
filter: function() {
|
|
return includes(this.mode, "hover");
|
|
},
|
|
handler: function(e) {
|
|
if (isTouch(e)) {
|
|
return;
|
|
}
|
|
if (active && active !== this && active.toggle && includes(active.toggle.mode, "hover") && !within(e.target, active.toggle.$el) && !pointInRect({
|
|
x: e.pageX,
|
|
y: e.pageY
|
|
}, offset(active.$el))) {
|
|
active.hide(false);
|
|
}
|
|
e.preventDefault();
|
|
this.show(this.toggle);
|
|
}
|
|
}, {
|
|
name: "toggleshow",
|
|
handler: function(e, toggle) {
|
|
if (toggle && !includes(toggle.target, this.$el)) {
|
|
return;
|
|
}
|
|
e.preventDefault();
|
|
this.show(toggle || this.toggle);
|
|
}
|
|
}, {
|
|
name: "togglehide " + pointerLeave,
|
|
handler: function(e, toggle) {
|
|
if (isTouch(e) || toggle && !includes(toggle.target, this.$el)) {
|
|
return;
|
|
}
|
|
e.preventDefault();
|
|
if (this.toggle && includes(this.toggle.mode, "hover")) {
|
|
this.hide();
|
|
}
|
|
}
|
|
}, {
|
|
name: "beforeshow",
|
|
self: true,
|
|
handler: function() {
|
|
this.clearTimers();
|
|
Animation.cancel(this.$el);
|
|
this.position();
|
|
}
|
|
}, {
|
|
name: "show",
|
|
self: true,
|
|
handler: function() {
|
|
this.tracker.init();
|
|
if (this.toggle) {
|
|
addClass(this.toggle.$el, this.cls);
|
|
attr(this.toggle.$el, "aria-expanded", "true");
|
|
}
|
|
registerEvent();
|
|
}
|
|
}, {
|
|
name: "beforehide",
|
|
self: true,
|
|
handler: function() {
|
|
this.clearTimers();
|
|
}
|
|
}, {
|
|
name: "hide",
|
|
handler: function(ref) {
|
|
var target = ref.target;
|
|
if (this.$el !== target) {
|
|
active = active === null && within(target, this.$el) && this.isToggled() ? this : active;
|
|
return;
|
|
}
|
|
active = this.isActive() ? null : active;
|
|
if (this.toggle) {
|
|
removeClass(this.toggle.$el, this.cls);
|
|
attr(this.toggle.$el, "aria-expanded", "false");
|
|
this.toggle.$el.blur();
|
|
$$("a, button", this.toggle.$el).forEach(function(el) {
|
|
return el.blur();
|
|
});
|
|
}
|
|
this.tracker.cancel();
|
|
}
|
|
} ],
|
|
update: {
|
|
write: function() {
|
|
if (this.isToggled() && !Animation.inProgress(this.$el)) {
|
|
this.position();
|
|
}
|
|
},
|
|
events: [ "resize" ]
|
|
},
|
|
methods: {
|
|
show: function(toggle, delay) {
|
|
var this$1 = this;
|
|
if (delay === void 0) delay = true;
|
|
var show = function() {
|
|
return !this$1.isToggled() && this$1.toggleElement(this$1.$el, true);
|
|
};
|
|
var tryShow = function() {
|
|
this$1.toggle = toggle || this$1.toggle;
|
|
this$1.clearTimers();
|
|
if (this$1.isActive()) {
|
|
return;
|
|
} else if (delay && active && active !== this$1 && active.isDelaying) {
|
|
this$1.showTimer = setTimeout(this$1.show, 10);
|
|
return;
|
|
} else if (this$1.isParentOf(active)) {
|
|
if (active.hideTimer) {
|
|
active.hide(false);
|
|
} else {
|
|
return;
|
|
}
|
|
} else if (active && !this$1.isChildOf(active) && !this$1.isParentOf(active)) {
|
|
var prev;
|
|
while (active && active !== prev && !this$1.isChildOf(active)) {
|
|
prev = active;
|
|
active.hide(false);
|
|
}
|
|
}
|
|
if (delay && this$1.delayShow) {
|
|
this$1.showTimer = setTimeout(show, this$1.delayShow);
|
|
} else {
|
|
show();
|
|
}
|
|
active = this$1;
|
|
};
|
|
if (toggle && this.toggle && toggle.$el !== this.toggle.$el) {
|
|
once(this.$el, "hide", tryShow);
|
|
this.hide(false);
|
|
} else {
|
|
tryShow();
|
|
}
|
|
},
|
|
hide: function(delay) {
|
|
var this$1 = this;
|
|
if (delay === void 0) delay = true;
|
|
var hide = function() {
|
|
return this$1.toggleNow(this$1.$el, false);
|
|
};
|
|
this.clearTimers();
|
|
this.isDelaying = this.tracker.movesTo(this.$el);
|
|
if (delay && this.isDelaying) {
|
|
this.hideTimer = setTimeout(this.hide, this.hoverIdle);
|
|
} else if (delay && this.delayHide) {
|
|
this.hideTimer = setTimeout(hide, this.delayHide);
|
|
} else {
|
|
hide();
|
|
}
|
|
},
|
|
clearTimers: function() {
|
|
clearTimeout(this.showTimer);
|
|
clearTimeout(this.hideTimer);
|
|
this.showTimer = null;
|
|
this.hideTimer = null;
|
|
this.isDelaying = false;
|
|
},
|
|
isActive: function() {
|
|
return active === this;
|
|
},
|
|
isChildOf: function(drop) {
|
|
return drop && drop !== this && within(this.$el, drop.$el);
|
|
},
|
|
isParentOf: function(drop) {
|
|
return drop && drop !== this && within(drop.$el, this.$el);
|
|
},
|
|
position: function() {
|
|
removeClasses(this.$el, this.clsDrop + "-(stack|boundary)");
|
|
css(this.$el, {
|
|
top: "",
|
|
left: "",
|
|
display: "block"
|
|
});
|
|
toggleClass(this.$el, this.clsDrop + "-boundary", this.boundaryAlign);
|
|
var boundary = offset(this.boundary);
|
|
var alignTo = this.boundaryAlign ? boundary : offset(this.toggle.$el);
|
|
if (this.align === "justify") {
|
|
var prop = this.getAxis() === "y" ? "width" : "height";
|
|
css(this.$el, prop, alignTo[prop]);
|
|
} else if (this.$el.offsetWidth > Math.max(boundary.right - alignTo.left, alignTo.right - boundary.left)) {
|
|
addClass(this.$el, this.clsDrop + "-stack");
|
|
}
|
|
this.positionAt(this.$el, this.boundaryAlign ? this.boundary : this.toggle.$el, this.boundary);
|
|
css(this.$el, "display", "");
|
|
}
|
|
}
|
|
};
|
|
var registered;
|
|
function registerEvent() {
|
|
if (registered) {
|
|
return;
|
|
}
|
|
registered = true;
|
|
on(document, "click", function(ref) {
|
|
var target = ref.target;
|
|
var defaultPrevented = ref.defaultPrevented;
|
|
var prev;
|
|
if (defaultPrevented) {
|
|
return;
|
|
}
|
|
while (active && active !== prev && !within(target, active.$el) && !(active.toggle && within(target, active.toggle.$el))) {
|
|
prev = active;
|
|
active.hide(false);
|
|
}
|
|
});
|
|
}
|
|
var Dropdown = {
|
|
extends: Drop
|
|
};
|
|
var FormCustom = {
|
|
mixins: [ Class ],
|
|
args: "target",
|
|
props: {
|
|
target: Boolean
|
|
},
|
|
data: {
|
|
target: false
|
|
},
|
|
computed: {
|
|
input: function(_, $el) {
|
|
return $(selInput, $el);
|
|
},
|
|
state: function() {
|
|
return this.input.nextElementSibling;
|
|
},
|
|
target: function(ref, $el) {
|
|
var target = ref.target;
|
|
return target && (target === true && this.input.parentNode === $el && this.input.nextElementSibling || query(target, $el));
|
|
}
|
|
},
|
|
update: function() {
|
|
var ref = this;
|
|
var target = ref.target;
|
|
var input = ref.input;
|
|
if (!target) {
|
|
return;
|
|
}
|
|
var option;
|
|
var prop = isInput(target) ? "value" : "textContent";
|
|
var prev = target[prop];
|
|
var value = input.files && input.files[0] ? input.files[0].name : matches(input, "select") && (option = $$("option", input).filter(function(el) {
|
|
return el.selected;
|
|
})[0]) ? option.textContent : input.value;
|
|
if (prev !== value) {
|
|
target[prop] = value;
|
|
}
|
|
},
|
|
events: [ {
|
|
name: "focusin focusout mouseenter mouseleave",
|
|
delegate: selInput,
|
|
handler: function(ref) {
|
|
var type = ref.type;
|
|
var current = ref.current;
|
|
if (current === this.input) {
|
|
toggleClass(this.state, "uk-" + (includes(type, "focus") ? "focus" : "hover"), includes([ "focusin", "mouseenter" ], type));
|
|
}
|
|
}
|
|
}, {
|
|
name: "change",
|
|
handler: function() {
|
|
this.$emit();
|
|
}
|
|
} ]
|
|
};
|
|
var Gif = {
|
|
update: {
|
|
read: function(data$$1) {
|
|
var inview = isInView(this.$el);
|
|
if (!inview || data$$1.isInView === inview) {
|
|
return false;
|
|
}
|
|
data$$1.isInView = inview;
|
|
},
|
|
write: function() {
|
|
this.$el.src = this.$el.src;
|
|
},
|
|
events: [ "scroll", "load", "resize" ]
|
|
}
|
|
};
|
|
var Margin = {
|
|
props: {
|
|
margin: String,
|
|
firstColumn: Boolean
|
|
},
|
|
data: {
|
|
margin: "uk-margin-small-top",
|
|
firstColumn: "uk-first-column"
|
|
},
|
|
update: {
|
|
read: function(data$$1) {
|
|
var items = this.$el.children;
|
|
var rows = [ [] ];
|
|
if (!items.length || !isVisible(this.$el)) {
|
|
return data$$1.rows = rows;
|
|
}
|
|
data$$1.rows = getRows(items);
|
|
data$$1.stacks = !data$$1.rows.some(function(row) {
|
|
return row.length > 1;
|
|
});
|
|
},
|
|
write: function(ref) {
|
|
var this$1 = this;
|
|
var rows = ref.rows;
|
|
rows.forEach(function(row, i) {
|
|
return row.forEach(function(el, j) {
|
|
toggleClass(el, this$1.margin, i !== 0);
|
|
toggleClass(el, this$1.firstColumn, j === 0);
|
|
});
|
|
});
|
|
},
|
|
events: [ "load", "resize" ]
|
|
}
|
|
};
|
|
function getRows(items) {
|
|
var rows = [ [] ];
|
|
for (var i = 0; i < items.length; i++) {
|
|
var el = items[i];
|
|
var dim = getOffset(el);
|
|
if (!dim.height) {
|
|
continue;
|
|
}
|
|
for (var j = rows.length - 1; j >= 0; j--) {
|
|
var row = rows[j];
|
|
if (!row[0]) {
|
|
row.push(el);
|
|
break;
|
|
}
|
|
var leftDim = getOffset(row[0]);
|
|
if (dim.top >= leftDim.bottom - 1) {
|
|
rows.push([ el ]);
|
|
break;
|
|
}
|
|
if (dim.bottom > leftDim.top) {
|
|
if (dim.left < leftDim.left && !isRtl) {
|
|
row.unshift(el);
|
|
break;
|
|
}
|
|
row.push(el);
|
|
break;
|
|
}
|
|
if (j === 0) {
|
|
rows.unshift([ el ]);
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
return rows;
|
|
}
|
|
function getOffset(element) {
|
|
var offsetTop = element.offsetTop;
|
|
var offsetLeft = element.offsetLeft;
|
|
var offsetHeight = element.offsetHeight;
|
|
return {
|
|
top: offsetTop,
|
|
left: offsetLeft,
|
|
height: offsetHeight,
|
|
bottom: offsetTop + offsetHeight
|
|
};
|
|
}
|
|
var Grid = {
|
|
extends: Margin,
|
|
mixins: [ Class ],
|
|
name: "grid",
|
|
props: {
|
|
masonry: Boolean,
|
|
parallax: Number
|
|
},
|
|
data: {
|
|
margin: "uk-grid-margin",
|
|
clsStack: "uk-grid-stack",
|
|
masonry: false,
|
|
parallax: 0
|
|
},
|
|
computed: {
|
|
length: function(_, $el) {
|
|
return $el.children.length;
|
|
},
|
|
parallax: function(ref) {
|
|
var parallax = ref.parallax;
|
|
return parallax && this.length ? Math.abs(parallax) : "";
|
|
}
|
|
},
|
|
connected: function() {
|
|
this.masonry && addClass(this.$el, "uk-flex-top uk-flex-wrap-top");
|
|
},
|
|
update: [ {
|
|
read: function(ref) {
|
|
var rows = ref.rows;
|
|
if (this.masonry || this.parallax) {
|
|
rows = rows.map(function(elements) {
|
|
return sortBy(elements, "offsetLeft");
|
|
});
|
|
}
|
|
var hasStaticContent = rows.some(function(elements) {
|
|
return elements.some(function(element) {
|
|
return css(element, "position") === "static";
|
|
});
|
|
});
|
|
var translates = false;
|
|
var elHeight = "";
|
|
if (this.masonry && this.length) {
|
|
var height$$1 = 0;
|
|
translates = rows.reduce(function(translates, row, i) {
|
|
translates[i] = row.map(function(_, j) {
|
|
return i === 0 ? 0 : toFloat(translates[i - 1][j]) + (height$$1 - toFloat(rows[i - 1][j] && rows[i - 1][j].offsetHeight));
|
|
});
|
|
height$$1 = row.reduce(function(height$$1, el) {
|
|
return Math.max(height$$1, el.offsetHeight);
|
|
}, 0);
|
|
return translates;
|
|
}, []);
|
|
elHeight = maxColumnHeight(rows) + getMarginTop(this.$el, this.margin) * (rows.length - 1);
|
|
}
|
|
return {
|
|
rows: rows,
|
|
translates: translates,
|
|
height: hasStaticContent ? elHeight : false
|
|
};
|
|
},
|
|
write: function(ref) {
|
|
var stacks = ref.stacks;
|
|
var height$$1 = ref.height;
|
|
toggleClass(this.$el, this.clsStack, stacks);
|
|
css(this.$el, "paddingBottom", this.parallax);
|
|
height$$1 !== false && css(this.$el, "height", height$$1);
|
|
},
|
|
events: [ "load", "resize" ]
|
|
}, {
|
|
read: function(ref) {
|
|
var height$$1 = ref.height;
|
|
return {
|
|
scrolled: this.parallax ? scrolledOver(this.$el, height$$1 ? height$$1 - height(this.$el) : 0) * this.parallax : false
|
|
};
|
|
},
|
|
write: function(ref) {
|
|
var rows = ref.rows;
|
|
var scrolled = ref.scrolled;
|
|
var translates = ref.translates;
|
|
if (scrolled === false && !translates) {
|
|
return;
|
|
}
|
|
rows.forEach(function(row, i) {
|
|
return row.forEach(function(el, j) {
|
|
return css(el, "transform", !scrolled && !translates ? "" : "translateY(" + ((translates && -translates[i][j]) + (scrolled ? j % 2 ? scrolled : scrolled / 8 : 0)) + "px)");
|
|
});
|
|
});
|
|
},
|
|
events: [ "scroll", "load", "resize" ]
|
|
} ]
|
|
};
|
|
function getMarginTop(root, cls) {
|
|
var nodes = toNodes(root.children);
|
|
var ref = nodes.filter(function(el) {
|
|
return hasClass(el, cls);
|
|
});
|
|
var node = ref[0];
|
|
return toFloat(node ? css(node, "marginTop") : css(nodes[0], "paddingLeft"));
|
|
}
|
|
function maxColumnHeight(rows) {
|
|
return Math.max.apply(Math, rows.reduce(function(sum, row) {
|
|
row.forEach(function(el, i) {
|
|
return sum[i] = (sum[i] || 0) + el.offsetHeight;
|
|
});
|
|
return sum;
|
|
}, []));
|
|
}
|
|
var FlexBug = isIE ? {
|
|
data: {
|
|
selMinHeight: false,
|
|
forceHeight: false
|
|
},
|
|
computed: {
|
|
elements: function(ref, $el) {
|
|
var selMinHeight = ref.selMinHeight;
|
|
return selMinHeight ? $$(selMinHeight, $el) : [ $el ];
|
|
}
|
|
},
|
|
update: [ {
|
|
read: function() {
|
|
css(this.elements, "height", "");
|
|
},
|
|
order: -5,
|
|
events: [ "load", "resize" ]
|
|
}, {
|
|
write: function() {
|
|
var this$1 = this;
|
|
this.elements.forEach(function(el) {
|
|
var height$$1 = toFloat(css(el, "minHeight"));
|
|
if (height$$1 && (this$1.forceHeight || Math.round(height$$1) >= height(el))) {
|
|
css(el, "height", height$$1);
|
|
}
|
|
});
|
|
},
|
|
order: 5,
|
|
events: [ "load", "resize" ]
|
|
} ]
|
|
} : {};
|
|
var HeightMatch = {
|
|
mixins: [ FlexBug ],
|
|
args: "target",
|
|
props: {
|
|
target: String,
|
|
row: Boolean
|
|
},
|
|
data: {
|
|
target: "> *",
|
|
row: true,
|
|
forceHeight: true
|
|
},
|
|
computed: {
|
|
elements: function(ref, $el) {
|
|
var target = ref.target;
|
|
return $$(target, $el);
|
|
}
|
|
},
|
|
update: {
|
|
read: function() {
|
|
return {
|
|
rows: (this.row ? getRows(this.elements) : [ this.elements ]).map(match)
|
|
};
|
|
},
|
|
write: function(ref) {
|
|
var rows = ref.rows;
|
|
rows.forEach(function(ref) {
|
|
var heights = ref.heights;
|
|
var elements = ref.elements;
|
|
return elements.forEach(function(el, i) {
|
|
return css(el, "minHeight", heights[i]);
|
|
});
|
|
});
|
|
},
|
|
events: [ "load", "resize" ]
|
|
}
|
|
};
|
|
function match(elements) {
|
|
var assign$$1;
|
|
if (elements.length < 2) {
|
|
return {
|
|
heights: [ "" ],
|
|
elements: elements
|
|
};
|
|
}
|
|
var ref = getHeights(elements);
|
|
var heights = ref.heights;
|
|
var max = ref.max;
|
|
var hasMinHeight = elements.some(function(el) {
|
|
return el.style.minHeight;
|
|
});
|
|
var hasShrunk = elements.some(function(el, i) {
|
|
return !el.style.minHeight && heights[i] < max;
|
|
});
|
|
if (hasMinHeight && hasShrunk) {
|
|
css(elements, "minHeight", "");
|
|
assign$$1 = getHeights(elements), heights = assign$$1.heights, max = assign$$1.max;
|
|
}
|
|
heights = elements.map(function(el, i) {
|
|
return heights[i] === max && toFloat(el.style.minHeight) !== max ? "" : max;
|
|
});
|
|
return {
|
|
heights: heights,
|
|
elements: elements
|
|
};
|
|
}
|
|
function getHeights(elements) {
|
|
var heights = elements.map(function(el) {
|
|
return offset(el).height - boxModelAdjust("height", el, "content-box");
|
|
});
|
|
var max = Math.max.apply(null, heights);
|
|
return {
|
|
heights: heights,
|
|
max: max
|
|
};
|
|
}
|
|
var HeightViewport = {
|
|
mixins: [ FlexBug ],
|
|
props: {
|
|
expand: Boolean,
|
|
offsetTop: Boolean,
|
|
offsetBottom: Boolean,
|
|
minHeight: Number
|
|
},
|
|
data: {
|
|
expand: false,
|
|
offsetTop: false,
|
|
offsetBottom: false,
|
|
minHeight: 0
|
|
},
|
|
update: {
|
|
read: function() {
|
|
var minHeight = "";
|
|
var box = boxModelAdjust("height", this.$el, "content-box");
|
|
if (this.expand) {
|
|
minHeight = height(window) - (offsetHeight(document.documentElement) - offsetHeight(this.$el)) - box || "";
|
|
} else {
|
|
minHeight = "calc(100vh";
|
|
if (this.offsetTop) {
|
|
var ref = offset(this.$el);
|
|
var top = ref.top;
|
|
minHeight += top < height(window) / 2 ? " - " + top + "px" : "";
|
|
}
|
|
if (this.offsetBottom === true) {
|
|
minHeight += " - " + offsetHeight(this.$el.nextElementSibling) + "px";
|
|
} else if (isNumeric(this.offsetBottom)) {
|
|
minHeight += " - " + this.offsetBottom + "vh";
|
|
} else if (this.offsetBottom && endsWith(this.offsetBottom, "px")) {
|
|
minHeight += " - " + toFloat(this.offsetBottom) + "px";
|
|
} else if (isString(this.offsetBottom)) {
|
|
minHeight += " - " + offsetHeight(query(this.offsetBottom, this.$el)) + "px";
|
|
}
|
|
minHeight += (box ? " - " + box + "px" : "") + ")";
|
|
}
|
|
return {
|
|
minHeight: minHeight
|
|
};
|
|
},
|
|
write: function(ref) {
|
|
var minHeight = ref.minHeight;
|
|
css(this.$el, {
|
|
minHeight: minHeight
|
|
});
|
|
if (this.minHeight && toFloat(css(this.$el, "minHeight")) < this.minHeight) {
|
|
css(this.$el, "minHeight", this.minHeight);
|
|
}
|
|
},
|
|
events: [ "load", "resize" ]
|
|
}
|
|
};
|
|
function offsetHeight(el) {
|
|
return el && el.offsetHeight || 0;
|
|
}
|
|
var svgs = {};
|
|
var SVG = {
|
|
props: {
|
|
id: String,
|
|
icon: String,
|
|
src: String,
|
|
style: String,
|
|
width: Number,
|
|
height: Number,
|
|
ratio: Number,
|
|
class: String
|
|
},
|
|
data: {
|
|
ratio: 1,
|
|
id: false,
|
|
exclude: [ "ratio", "src", "icon" ],
|
|
class: ""
|
|
},
|
|
connected: function() {
|
|
var this$1 = this;
|
|
var assign$$1;
|
|
this.class += " uk-svg";
|
|
if (!this.icon && includes(this.src, "#")) {
|
|
var parts = this.src.split("#");
|
|
if (parts.length > 1) {
|
|
assign$$1 = parts, this.src = assign$$1[0], this.icon = assign$$1[1];
|
|
}
|
|
}
|
|
this.svg = this.getSvg().then(function(svg) {
|
|
var el;
|
|
if (isString(svg)) {
|
|
if (this$1.icon && includes(svg, "<symbol")) {
|
|
svg = parseSymbols(svg, this$1.icon) || svg;
|
|
}
|
|
el = $(svg.substr(svg.indexOf("<svg")));
|
|
} else {
|
|
el = svg.cloneNode(true);
|
|
}
|
|
if (!el) {
|
|
return Promise.reject("SVG not found.");
|
|
}
|
|
var dimensions = attr(el, "viewBox");
|
|
if (dimensions) {
|
|
dimensions = dimensions.split(" ");
|
|
this$1.width = this$1.$props.width || dimensions[2];
|
|
this$1.height = this$1.$props.height || dimensions[3];
|
|
}
|
|
this$1.width *= this$1.ratio;
|
|
this$1.height *= this$1.ratio;
|
|
for (var prop in this$1.$options.props) {
|
|
if (this$1[prop] && !includes(this$1.exclude, prop)) {
|
|
attr(el, prop, this$1[prop]);
|
|
}
|
|
}
|
|
if (!this$1.id) {
|
|
removeAttr(el, "id");
|
|
}
|
|
if (this$1.width && !this$1.height) {
|
|
removeAttr(el, "height");
|
|
}
|
|
if (this$1.height && !this$1.width) {
|
|
removeAttr(el, "width");
|
|
}
|
|
var root = this$1.$el;
|
|
if (isVoidElement(root) || root.tagName === "CANVAS") {
|
|
attr(root, {
|
|
hidden: true,
|
|
id: null
|
|
});
|
|
var next = root.nextElementSibling;
|
|
if (next && el.isEqualNode(next)) {
|
|
el = next;
|
|
} else {
|
|
after(root, el);
|
|
}
|
|
} else {
|
|
var last = root.lastElementChild;
|
|
if (last && el.isEqualNode(last)) {
|
|
el = last;
|
|
} else {
|
|
append(root, el);
|
|
}
|
|
}
|
|
this$1.svgEl = el;
|
|
return el;
|
|
}, noop);
|
|
},
|
|
disconnected: function() {
|
|
var this$1 = this;
|
|
if (isVoidElement(this.$el)) {
|
|
attr(this.$el, {
|
|
hidden: null,
|
|
id: this.id || null
|
|
});
|
|
}
|
|
if (this.svg) {
|
|
this.svg.then(function(svg) {
|
|
return (!this$1._connected || svg !== this$1.svgEl) && remove(svg);
|
|
}, noop);
|
|
}
|
|
this.svg = this.svgEl = null;
|
|
},
|
|
methods: {
|
|
getSvg: function() {
|
|
var this$1 = this;
|
|
if (!this.src) {
|
|
return Promise.reject();
|
|
}
|
|
if (svgs[this.src]) {
|
|
return svgs[this.src];
|
|
}
|
|
svgs[this.src] = new Promise(function(resolve, reject) {
|
|
if (startsWith(this$1.src, "data:")) {
|
|
resolve(decodeURIComponent(this$1.src.split(",")[1]));
|
|
} else {
|
|
ajax(this$1.src).then(function(xhr) {
|
|
return resolve(xhr.response);
|
|
}, function() {
|
|
return reject("SVG not found.");
|
|
});
|
|
}
|
|
});
|
|
return svgs[this.src];
|
|
}
|
|
}
|
|
};
|
|
var symbolRe = /<symbol(.*?id=(['"])(.*?)\2[^]*?<\/)symbol>/g;
|
|
var symbols = {};
|
|
function parseSymbols(svg, icon) {
|
|
if (!symbols[svg]) {
|
|
symbols[svg] = {};
|
|
var match;
|
|
while (match = symbolRe.exec(svg)) {
|
|
symbols[svg][match[3]] = '<svg xmlns="http://www.w3.org/2000/svg"' + match[1] + "svg>";
|
|
}
|
|
symbolRe.lastIndex = 0;
|
|
}
|
|
return symbols[svg][icon];
|
|
}
|
|
var closeIcon = '<svg width="14" height="14" viewBox="0 0 14 14" xmlns="http://www.w3.org/2000/svg"><line fill="none" stroke="#000" stroke-width="1.1" x1="1" y1="1" x2="13" y2="13"/><line fill="none" stroke="#000" stroke-width="1.1" x1="13" y1="1" x2="1" y2="13"/></svg>';
|
|
var closeLarge = '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"><line fill="none" stroke="#000" stroke-width="1.4" x1="1" y1="1" x2="19" y2="19"/><line fill="none" stroke="#000" stroke-width="1.4" x1="19" y1="1" x2="1" y2="19"/></svg>';
|
|
var marker = '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"><rect x="9" y="4" width="1" height="11"/><rect x="4" y="9" width="11" height="1"/></svg>';
|
|
var navbarToggleIcon = '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"><rect y="9" width="20" height="2"/><rect y="3" width="20" height="2"/><rect y="15" width="20" height="2"/></svg>';
|
|
var overlayIcon = '<svg width="40" height="40" viewBox="0 0 40 40" xmlns="http://www.w3.org/2000/svg"><rect x="19" y="0" width="1" height="40"/><rect x="0" y="19" width="40" height="1"/></svg>';
|
|
var paginationNext = '<svg width="7" height="12" viewBox="0 0 7 12" xmlns="http://www.w3.org/2000/svg"><polyline fill="none" stroke="#000" stroke-width="1.2" points="1 1 6 6 1 11"/></svg>';
|
|
var paginationPrevious = '<svg width="7" height="12" viewBox="0 0 7 12" xmlns="http://www.w3.org/2000/svg"><polyline fill="none" stroke="#000" stroke-width="1.2" points="6 1 1 6 6 11"/></svg>';
|
|
var searchIcon = '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"><circle fill="none" stroke="#000" stroke-width="1.1" cx="9" cy="9" r="7"/><path fill="none" stroke="#000" stroke-width="1.1" d="M14,14 L18,18 L14,14 Z"/></svg>';
|
|
var searchLarge = '<svg width="40" height="40" viewBox="0 0 40 40" xmlns="http://www.w3.org/2000/svg"><circle fill="none" stroke="#000" stroke-width="1.8" cx="17.5" cy="17.5" r="16.5"/><line fill="none" stroke="#000" stroke-width="1.8" x1="38" y1="39" x2="29" y2="30"/></svg>';
|
|
var searchNavbar = '<svg width="24" height="24" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg"><circle fill="none" stroke="#000" stroke-width="1.1" cx="10.5" cy="10.5" r="9.5"/><line fill="none" stroke="#000" stroke-width="1.1" x1="23" y1="23" x2="17" y2="17"/></svg>';
|
|
var slidenavNext = '<svg width="14px" height="24px" viewBox="0 0 14 24" xmlns="http://www.w3.org/2000/svg"><polyline fill="none" stroke="#000" stroke-width="1.4" points="1.225,23 12.775,12 1.225,1 "/></svg>';
|
|
var slidenavNextLarge = '<svg width="25px" height="40px" viewBox="0 0 25 40" xmlns="http://www.w3.org/2000/svg"><polyline fill="none" stroke="#000" stroke-width="2" points="4.002,38.547 22.527,20.024 4,1.5 "/></svg>';
|
|
var slidenavPrevious = '<svg width="14px" height="24px" viewBox="0 0 14 24" xmlns="http://www.w3.org/2000/svg"><polyline fill="none" stroke="#000" stroke-width="1.4" points="12.775,1 1.225,12 12.775,23 "/></svg>';
|
|
var slidenavPreviousLarge = '<svg width="25px" height="40px" viewBox="0 0 25 40" xmlns="http://www.w3.org/2000/svg"><polyline fill="none" stroke="#000" stroke-width="2" points="20.527,1.5 2,20.024 20.525,38.547 "/></svg>';
|
|
var spinner = '<svg width="30" height="30" viewBox="0 0 30 30" xmlns="http://www.w3.org/2000/svg"><circle fill="none" stroke="#000" cx="15" cy="15" r="14"/></svg>';
|
|
var totop = '<svg width="18" height="10" viewBox="0 0 18 10" xmlns="http://www.w3.org/2000/svg"><polyline fill="none" stroke="#000" stroke-width="1.2" points="1 9 9 1 17 9 "/></svg>';
|
|
var parsed = {};
|
|
var icons = {
|
|
spinner: spinner,
|
|
totop: totop,
|
|
marker: marker,
|
|
"close-icon": closeIcon,
|
|
"close-large": closeLarge,
|
|
"navbar-toggle-icon": navbarToggleIcon,
|
|
"overlay-icon": overlayIcon,
|
|
"pagination-next": paginationNext,
|
|
"pagination-previous": paginationPrevious,
|
|
"search-icon": searchIcon,
|
|
"search-large": searchLarge,
|
|
"search-navbar": searchNavbar,
|
|
"slidenav-next": slidenavNext,
|
|
"slidenav-next-large": slidenavNextLarge,
|
|
"slidenav-previous": slidenavPrevious,
|
|
"slidenav-previous-large": slidenavPreviousLarge
|
|
};
|
|
var Icon = {
|
|
install: install,
|
|
attrs: [ "icon", "ratio" ],
|
|
mixins: [ Class, SVG ],
|
|
args: "icon",
|
|
props: [ "icon" ],
|
|
data: {
|
|
exclude: [ "id", "style", "class", "src", "icon", "ratio" ]
|
|
},
|
|
isIcon: true,
|
|
connected: function() {
|
|
addClass(this.$el, "uk-icon");
|
|
},
|
|
methods: {
|
|
getSvg: function() {
|
|
var icon = getIcon(applyRtl(this.icon));
|
|
if (!icon) {
|
|
return Promise.reject("Icon not found.");
|
|
}
|
|
return Promise.resolve(icon);
|
|
}
|
|
}
|
|
};
|
|
var IconComponent = {
|
|
extends: Icon,
|
|
data: function(vm) {
|
|
return {
|
|
icon: hyphenate(vm.constructor.options.name)
|
|
};
|
|
}
|
|
};
|
|
var Slidenav = {
|
|
extends: IconComponent,
|
|
connected: function() {
|
|
addClass(this.$el, "uk-slidenav");
|
|
},
|
|
computed: {
|
|
icon: function(ref, $el) {
|
|
var icon = ref.icon;
|
|
return hasClass($el, "uk-slidenav-large") ? icon + "-large" : icon;
|
|
}
|
|
}
|
|
};
|
|
var Search = {
|
|
extends: IconComponent,
|
|
computed: {
|
|
icon: function(ref, $el) {
|
|
var icon = ref.icon;
|
|
return hasClass($el, "uk-search-icon") && parents($el, ".uk-search-large").length ? "search-large" : parents($el, ".uk-search-navbar").length ? "search-navbar" : icon;
|
|
}
|
|
}
|
|
};
|
|
var Close = {
|
|
extends: IconComponent,
|
|
computed: {
|
|
icon: function() {
|
|
return "close-" + (hasClass(this.$el, "uk-close-large") ? "large" : "icon");
|
|
}
|
|
}
|
|
};
|
|
var Spinner = {
|
|
extends: IconComponent,
|
|
connected: function() {
|
|
var this$1 = this;
|
|
this.svg.then(function(svg) {
|
|
return this$1.ratio !== 1 && css($("circle", svg), "strokeWidth", 1 / this$1.ratio);
|
|
}, noop);
|
|
}
|
|
};
|
|
function install(UIkit) {
|
|
UIkit.icon.add = function(name, svg) {
|
|
var obj;
|
|
var added = isString(name) ? (obj = {}, obj[name] = svg, obj) : name;
|
|
each(added, function(svg, name) {
|
|
icons[name] = svg;
|
|
delete parsed[name];
|
|
});
|
|
if (UIkit._initialized) {
|
|
apply(document.body, function(el) {
|
|
return each(UIkit.getComponents(el), function(cmp) {
|
|
return cmp.$options.isIcon && cmp.icon in added && cmp.$reset();
|
|
});
|
|
});
|
|
}
|
|
};
|
|
}
|
|
function getIcon(icon) {
|
|
if (!icons[icon]) {
|
|
return null;
|
|
}
|
|
if (!parsed[icon]) {
|
|
parsed[icon] = $(icons[icon].trim());
|
|
}
|
|
return parsed[icon];
|
|
}
|
|
function applyRtl(icon) {
|
|
return isRtl ? swap(swap(icon, "left", "right"), "previous", "next") : icon;
|
|
}
|
|
var Img = {
|
|
props: {
|
|
dataSrc: String,
|
|
dataSrcset: Boolean,
|
|
sizes: String,
|
|
width: Number,
|
|
height: Number,
|
|
offsetTop: String,
|
|
offsetLeft: String,
|
|
target: String
|
|
},
|
|
data: {
|
|
dataSrc: "",
|
|
dataSrcset: false,
|
|
sizes: false,
|
|
width: false,
|
|
height: false,
|
|
offsetTop: "50vh",
|
|
offsetLeft: 0,
|
|
target: false
|
|
},
|
|
computed: {
|
|
cacheKey: function(ref) {
|
|
var dataSrc = ref.dataSrc;
|
|
return this.$name + "." + dataSrc;
|
|
},
|
|
width: function(ref) {
|
|
var width$$1 = ref.width;
|
|
var dataWidth = ref.dataWidth;
|
|
return width$$1 || dataWidth;
|
|
},
|
|
height: function(ref) {
|
|
var height$$1 = ref.height;
|
|
var dataHeight = ref.dataHeight;
|
|
return height$$1 || dataHeight;
|
|
},
|
|
sizes: function(ref) {
|
|
var sizes = ref.sizes;
|
|
var dataSizes = ref.dataSizes;
|
|
return sizes || dataSizes;
|
|
},
|
|
isImg: function(_, $el) {
|
|
return isImg($el);
|
|
},
|
|
target: function(ref) {
|
|
var target = ref.target;
|
|
return [ this.$el ].concat(queryAll(target, this.$el));
|
|
},
|
|
offsetTop: function(ref) {
|
|
var offsetTop = ref.offsetTop;
|
|
return toPx(offsetTop, "height");
|
|
},
|
|
offsetLeft: function(ref) {
|
|
var offsetLeft = ref.offsetLeft;
|
|
return toPx(offsetLeft, "width");
|
|
}
|
|
},
|
|
connected: function() {
|
|
if (storage[this.cacheKey]) {
|
|
setSrcAttrs(this.$el, storage[this.cacheKey] || this.dataSrc, this.dataSrcset, this.sizes);
|
|
} else if (this.isImg && this.width && this.height) {
|
|
setSrcAttrs(this.$el, getPlaceholderImage(this.width, this.height, this.sizes));
|
|
}
|
|
},
|
|
update: {
|
|
read: function(ref) {
|
|
var this$1 = this;
|
|
var delay = ref.delay;
|
|
var image = ref.image;
|
|
if (!delay) {
|
|
return;
|
|
}
|
|
if (image || !this.target.some(function(el) {
|
|
return isInView(el, this$1.offsetTop, this$1.offsetLeft, true);
|
|
})) {
|
|
if (!this.isImg && image) {
|
|
image.then(function(img) {
|
|
return img && setSrcAttrs(this$1.$el, currentSrc(img));
|
|
});
|
|
}
|
|
return;
|
|
}
|
|
return {
|
|
image: getImage(this.dataSrc, this.dataSrcset, this.sizes).then(function(img) {
|
|
setSrcAttrs(this$1.$el, currentSrc(img), img.srcset, img.sizes);
|
|
storage[this$1.cacheKey] = currentSrc(img);
|
|
return img;
|
|
}, noop)
|
|
};
|
|
},
|
|
write: function(data$$1) {
|
|
if (!data$$1.delay) {
|
|
this.$emit();
|
|
return data$$1.delay = true;
|
|
}
|
|
},
|
|
events: [ "scroll", "load", "resize" ]
|
|
}
|
|
};
|
|
function setSrcAttrs(el, src, srcset, sizes) {
|
|
if (isImg(el)) {
|
|
sizes && (el.sizes = sizes);
|
|
srcset && (el.srcset = srcset);
|
|
src && (el.src = src);
|
|
} else if (src) {
|
|
var change = !includes(el.style.backgroundImage, src);
|
|
css(el, "backgroundImage", "url(" + src + ")");
|
|
if (change) {
|
|
trigger(el, createEvent("load", false));
|
|
}
|
|
}
|
|
}
|
|
var sizesRe = /\s*(.*?)\s*(\w+|calc\(.*?\))\s*(?:,|$)/g;
|
|
function getPlaceholderImage(width$$1, height$$1, sizes) {
|
|
var assign$$1;
|
|
if (sizes) {
|
|
var matches$$1;
|
|
while (matches$$1 = sizesRe.exec(sizes)) {
|
|
if (!matches$$1[1] || window.matchMedia(matches$$1[1]).matches) {
|
|
matches$$1 = evaluateSize(matches$$1[2]);
|
|
break;
|
|
}
|
|
}
|
|
sizesRe.lastIndex = 0;
|
|
assign$$1 = Dimensions.ratio({
|
|
width: width$$1,
|
|
height: height$$1
|
|
}, "width", toPx(matches$$1 || "100vw")), width$$1 = assign$$1.width, height$$1 = assign$$1.height;
|
|
}
|
|
return 'data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="' + width$$1 + '" height="' + height$$1 + '"></svg>';
|
|
}
|
|
var sizeRe = /\d+(?:\w+|%)/g;
|
|
var additionRe = /[+-]?(\d+)/g;
|
|
function evaluateSize(size) {
|
|
return startsWith(size, "calc") ? size.substring(5, size.length - 1).replace(sizeRe, function(size) {
|
|
return toPx(size);
|
|
}).replace(/ /g, "").match(additionRe).reduce(function(a, b) {
|
|
return a + +b;
|
|
}, 0) : size;
|
|
}
|
|
function toPx(value, property, element) {
|
|
if (property === void 0) property = "width";
|
|
if (element === void 0) element = window;
|
|
return isNumeric(value) ? +value : endsWith(value, "vw") ? percent(element, "width", value) : endsWith(value, "vh") ? percent(element, "height", value) : endsWith(value, "%") ? percent(element, property, value) : toFloat(value);
|
|
}
|
|
var dimensions = {
|
|
height: height,
|
|
width: width
|
|
};
|
|
function percent(element, property, value) {
|
|
return dimensions[property](element) * toFloat(value) / 100;
|
|
}
|
|
function isImg(el) {
|
|
return el.tagName === "IMG";
|
|
}
|
|
function currentSrc(el) {
|
|
return el.currentSrc || el.src;
|
|
}
|
|
var key = "__test__";
|
|
var storage;
|
|
try {
|
|
storage = window.sessionStorage || {};
|
|
storage[key] = 1;
|
|
delete storage[key];
|
|
} catch (e) {
|
|
storage = {};
|
|
}
|
|
var Media = {
|
|
props: {
|
|
media: Boolean
|
|
},
|
|
data: {
|
|
media: false
|
|
},
|
|
computed: {
|
|
matchMedia: function() {
|
|
var media = toMedia(this.media);
|
|
return !media || window.matchMedia(media).matches;
|
|
}
|
|
}
|
|
};
|
|
function toMedia(value) {
|
|
if (isString(value)) {
|
|
if (value[0] === "@") {
|
|
var name = "breakpoint-" + value.substr(1);
|
|
value = toFloat(getCssVar(name));
|
|
} else if (isNaN(value)) {
|
|
return value;
|
|
}
|
|
}
|
|
return value && !isNaN(value) ? "(min-width: " + value + "px)" : false;
|
|
}
|
|
var Leader = {
|
|
mixins: [ Class, Media ],
|
|
props: {
|
|
fill: String
|
|
},
|
|
data: {
|
|
fill: "",
|
|
clsWrapper: "uk-leader-fill",
|
|
clsHide: "uk-leader-hide",
|
|
attrFill: "data-fill"
|
|
},
|
|
computed: {
|
|
fill: function(ref) {
|
|
var fill = ref.fill;
|
|
return fill || getCssVar("leader-fill-content");
|
|
}
|
|
},
|
|
connected: function() {
|
|
var assign$$1;
|
|
assign$$1 = wrapInner(this.$el, '<span class="' + this.clsWrapper + '">'), this.wrapper = assign$$1[0];
|
|
},
|
|
disconnected: function() {
|
|
unwrap(this.wrapper.childNodes);
|
|
},
|
|
update: {
|
|
read: function(ref) {
|
|
var changed = ref.changed;
|
|
var width$$1 = ref.width;
|
|
var prev = width$$1;
|
|
width$$1 = Math.floor(this.$el.offsetWidth / 2);
|
|
return {
|
|
width: width$$1,
|
|
changed: changed || prev !== width$$1,
|
|
hide: !this.matchMedia
|
|
};
|
|
},
|
|
write: function(data$$1) {
|
|
toggleClass(this.wrapper, this.clsHide, data$$1.hide);
|
|
if (data$$1.changed) {
|
|
data$$1.changed = false;
|
|
attr(this.wrapper, this.attrFill, new Array(data$$1.width).join(this.fill));
|
|
}
|
|
},
|
|
events: [ "load", "resize" ]
|
|
}
|
|
};
|
|
var Container = {
|
|
props: {
|
|
container: Boolean
|
|
},
|
|
data: {
|
|
container: true
|
|
},
|
|
computed: {
|
|
container: function(ref) {
|
|
var container = ref.container;
|
|
return container === true && this.$container || container && $(container);
|
|
}
|
|
}
|
|
};
|
|
var active$1;
|
|
var Modal = {
|
|
mixins: [ Class, Container, Togglable ],
|
|
props: {
|
|
selPanel: String,
|
|
selClose: String,
|
|
escClose: Boolean,
|
|
bgClose: Boolean,
|
|
stack: Boolean
|
|
},
|
|
data: {
|
|
cls: "uk-open",
|
|
escClose: true,
|
|
bgClose: true,
|
|
overlay: true,
|
|
stack: false
|
|
},
|
|
computed: {
|
|
panel: function(ref, $el) {
|
|
var selPanel = ref.selPanel;
|
|
return $(selPanel, $el);
|
|
},
|
|
transitionElement: function() {
|
|
return this.panel;
|
|
},
|
|
transitionDuration: function() {
|
|
return toMs(css(this.transitionElement, "transitionDuration"));
|
|
},
|
|
bgClose: function(ref) {
|
|
var bgClose = ref.bgClose;
|
|
return bgClose && this.panel;
|
|
}
|
|
},
|
|
events: [ {
|
|
name: "click",
|
|
delegate: function() {
|
|
return this.selClose;
|
|
},
|
|
handler: function(e) {
|
|
e.preventDefault();
|
|
this.hide();
|
|
}
|
|
}, {
|
|
name: "toggle",
|
|
self: true,
|
|
handler: function(e) {
|
|
if (e.defaultPrevented) {
|
|
return;
|
|
}
|
|
e.preventDefault();
|
|
this.toggle();
|
|
}
|
|
}, {
|
|
name: "beforeshow",
|
|
self: true,
|
|
handler: function(e) {
|
|
var prev = active$1 && active$1 !== this && active$1;
|
|
active$1 = this;
|
|
if (prev) {
|
|
if (this.stack) {
|
|
this.prev = prev;
|
|
} else {
|
|
prev.hide().then(this.show);
|
|
e.preventDefault();
|
|
return;
|
|
}
|
|
}
|
|
registerEvents();
|
|
}
|
|
}, {
|
|
name: "beforehide",
|
|
self: true,
|
|
handler: function() {
|
|
active$1 = active$1 && active$1 !== this && active$1 || this.prev;
|
|
if (!active$1) {
|
|
deregisterEvents();
|
|
}
|
|
}
|
|
}, {
|
|
name: "show",
|
|
self: true,
|
|
handler: function() {
|
|
if (!hasClass(document.documentElement, this.clsPage)) {
|
|
this.scrollbarWidth = width(window) - width(document);
|
|
css(document.body, "overflowY", this.scrollbarWidth && this.overlay ? "scroll" : "");
|
|
}
|
|
addClass(document.documentElement, this.clsPage);
|
|
}
|
|
}, {
|
|
name: "hidden",
|
|
self: true,
|
|
handler: function() {
|
|
var this$1 = this;
|
|
var found;
|
|
var ref = this;
|
|
var prev = ref.prev;
|
|
while (prev) {
|
|
if (prev.clsPage === this$1.clsPage) {
|
|
found = true;
|
|
break;
|
|
}
|
|
prev = prev.prev;
|
|
}
|
|
if (!found) {
|
|
removeClass(document.documentElement, this.clsPage);
|
|
}
|
|
!this.prev && css(document.body, "overflowY", "");
|
|
}
|
|
} ],
|
|
methods: {
|
|
toggle: function() {
|
|
return this.isToggled() ? this.hide() : this.show();
|
|
},
|
|
show: function() {
|
|
if (this.isToggled()) {
|
|
return Promise.resolve();
|
|
}
|
|
if (this.container && this.$el.parentNode !== this.container) {
|
|
append(this.container, this.$el);
|
|
this._callConnected();
|
|
}
|
|
return this.toggleNow(this.$el, true);
|
|
},
|
|
hide: function() {
|
|
return this.isToggled() ? this.toggleNow(this.$el, false) : Promise.resolve();
|
|
},
|
|
getActive: function() {
|
|
return active$1;
|
|
},
|
|
_toggleImmediate: function(el, show) {
|
|
var this$1 = this;
|
|
return new Promise(function(resolve) {
|
|
return requestAnimationFrame(function() {
|
|
this$1._toggle(el, show);
|
|
if (this$1.transitionDuration) {
|
|
once(this$1.transitionElement, "transitionend", resolve, false, function(e) {
|
|
return e.target === this$1.transitionElement;
|
|
});
|
|
} else {
|
|
resolve();
|
|
}
|
|
});
|
|
});
|
|
}
|
|
}
|
|
};
|
|
var events;
|
|
function registerEvents() {
|
|
if (events) {
|
|
return;
|
|
}
|
|
events = [ on(document, "click", function(ref) {
|
|
var target = ref.target;
|
|
var defaultPrevented = ref.defaultPrevented;
|
|
if (active$1 && active$1.bgClose && !defaultPrevented && (!active$1.overlay || within(target, active$1.$el)) && !within(target, active$1.panel)) {
|
|
active$1.hide();
|
|
}
|
|
}), on(document, "keydown", function(e) {
|
|
if (e.keyCode === 27 && active$1 && active$1.escClose) {
|
|
e.preventDefault();
|
|
active$1.hide();
|
|
}
|
|
}) ];
|
|
}
|
|
function deregisterEvents() {
|
|
events && events.forEach(function(unbind) {
|
|
return unbind();
|
|
});
|
|
events = null;
|
|
}
|
|
var Modal$1 = {
|
|
install: install$1,
|
|
mixins: [ Modal ],
|
|
data: {
|
|
clsPage: "uk-modal-page",
|
|
selPanel: ".uk-modal-dialog",
|
|
selClose: ".uk-modal-close, .uk-modal-close-default, .uk-modal-close-outside, .uk-modal-close-full"
|
|
},
|
|
events: [ {
|
|
name: "show",
|
|
self: true,
|
|
handler: function() {
|
|
if (hasClass(this.panel, "uk-margin-auto-vertical")) {
|
|
addClass(this.$el, "uk-flex");
|
|
} else {
|
|
css(this.$el, "display", "block");
|
|
}
|
|
height(this.$el);
|
|
}
|
|
}, {
|
|
name: "hidden",
|
|
self: true,
|
|
handler: function() {
|
|
css(this.$el, "display", "");
|
|
removeClass(this.$el, "uk-flex");
|
|
}
|
|
} ]
|
|
};
|
|
function install$1(UIkit) {
|
|
UIkit.modal.dialog = function(content, options) {
|
|
var dialog = UIkit.modal(' <div class="uk-modal"> <div class="uk-modal-dialog">' + content + "</div> </div> ", options);
|
|
dialog.show();
|
|
on(dialog.$el, "hidden", function(ref) {
|
|
var target = ref.target;
|
|
var currentTarget = ref.currentTarget;
|
|
if (target === currentTarget) {
|
|
dialog.$destroy(true);
|
|
}
|
|
});
|
|
return dialog;
|
|
};
|
|
UIkit.modal.alert = function(message, options) {
|
|
options = assign({
|
|
bgClose: false,
|
|
escClose: false,
|
|
labels: UIkit.modal.labels
|
|
}, options);
|
|
return new Promise(function(resolve) {
|
|
return on(UIkit.modal.dialog(' <div class="uk-modal-body">' + (isString(message) ? message : html(message)) + '</div> <div class="uk-modal-footer uk-text-right"> <button class="uk-button uk-button-primary uk-modal-close" autofocus>' + options.labels.ok + "</button> </div> ", options).$el, "hide", resolve);
|
|
});
|
|
};
|
|
UIkit.modal.confirm = function(message, options) {
|
|
options = assign({
|
|
bgClose: false,
|
|
escClose: true,
|
|
labels: UIkit.modal.labels
|
|
}, options);
|
|
return new Promise(function(resolve, reject) {
|
|
var confirm = UIkit.modal.dialog(' <form> <div class="uk-modal-body">' + (isString(message) ? message : html(message)) + '</div> <div class="uk-modal-footer uk-text-right"> <button class="uk-button uk-button-default uk-modal-close" type="button">' + options.labels.cancel + '</button> <button class="uk-button uk-button-primary" autofocus>' + options.labels.ok + "</button> </div> </form> ", options);
|
|
var resolved = false;
|
|
on(confirm.$el, "submit", "form", function(e) {
|
|
e.preventDefault();
|
|
resolve();
|
|
resolved = true;
|
|
confirm.hide();
|
|
});
|
|
on(confirm.$el, "hide", function() {
|
|
if (!resolved) {
|
|
reject();
|
|
}
|
|
});
|
|
});
|
|
};
|
|
UIkit.modal.prompt = function(message, value, options) {
|
|
options = assign({
|
|
bgClose: false,
|
|
escClose: true,
|
|
labels: UIkit.modal.labels
|
|
}, options);
|
|
return new Promise(function(resolve) {
|
|
var prompt = UIkit.modal.dialog(' <form class="uk-form-stacked"> <div class="uk-modal-body"> <label>' + (isString(message) ? message : html(message)) + '</label> <input class="uk-input" autofocus> </div> <div class="uk-modal-footer uk-text-right"> <button class="uk-button uk-button-default uk-modal-close" type="button">' + options.labels.cancel + '</button> <button class="uk-button uk-button-primary">' + options.labels.ok + "</button> </div> </form> ", options), input = $("input", prompt.$el);
|
|
input.value = value;
|
|
var resolved = false;
|
|
on(prompt.$el, "submit", "form", function(e) {
|
|
e.preventDefault();
|
|
resolve(input.value);
|
|
resolved = true;
|
|
prompt.hide();
|
|
});
|
|
on(prompt.$el, "hide", function() {
|
|
if (!resolved) {
|
|
resolve(null);
|
|
}
|
|
});
|
|
});
|
|
};
|
|
UIkit.modal.labels = {
|
|
ok: "Ok",
|
|
cancel: "Cancel"
|
|
};
|
|
}
|
|
var Nav = {
|
|
extends: Accordion,
|
|
data: {
|
|
targets: "> .uk-parent",
|
|
toggle: "> a",
|
|
content: "> ul"
|
|
}
|
|
};
|
|
var Navbar = {
|
|
mixins: [ Class, FlexBug ],
|
|
props: {
|
|
dropdown: String,
|
|
mode: "list",
|
|
align: String,
|
|
offset: Number,
|
|
boundary: Boolean,
|
|
boundaryAlign: Boolean,
|
|
clsDrop: String,
|
|
delayShow: Number,
|
|
delayHide: Number,
|
|
dropbar: Boolean,
|
|
dropbarMode: String,
|
|
dropbarAnchor: Boolean,
|
|
duration: Number
|
|
},
|
|
data: {
|
|
dropdown: ".uk-navbar-nav > li",
|
|
align: !isRtl ? "left" : "right",
|
|
clsDrop: "uk-navbar-dropdown",
|
|
mode: undefined,
|
|
offset: undefined,
|
|
delayShow: undefined,
|
|
delayHide: undefined,
|
|
boundaryAlign: undefined,
|
|
flip: "x",
|
|
boundary: true,
|
|
dropbar: false,
|
|
dropbarMode: "slide",
|
|
dropbarAnchor: false,
|
|
duration: 200,
|
|
forceHeight: true,
|
|
selMinHeight: ".uk-navbar-nav > li > a, .uk-navbar-item, .uk-navbar-toggle"
|
|
},
|
|
computed: {
|
|
boundary: function(ref, $el) {
|
|
var boundary = ref.boundary;
|
|
var boundaryAlign = ref.boundaryAlign;
|
|
return boundary === true || boundaryAlign ? $el : boundary;
|
|
},
|
|
dropbarAnchor: function(ref, $el) {
|
|
var dropbarAnchor = ref.dropbarAnchor;
|
|
return query(dropbarAnchor, $el);
|
|
},
|
|
pos: function(ref) {
|
|
var align = ref.align;
|
|
return "bottom-" + align;
|
|
},
|
|
dropdowns: function(ref, $el) {
|
|
var dropdown = ref.dropdown;
|
|
var clsDrop = ref.clsDrop;
|
|
return $$(dropdown + " ." + clsDrop, $el);
|
|
}
|
|
},
|
|
beforeConnect: function() {
|
|
var ref = this.$props;
|
|
var dropbar = ref.dropbar;
|
|
this.dropbar = dropbar && (query(dropbar, this.$el) || $("+ .uk-navbar-dropbar", this.$el) || $("<div></div>"));
|
|
if (this.dropbar) {
|
|
addClass(this.dropbar, "uk-navbar-dropbar");
|
|
if (this.dropbarMode === "slide") {
|
|
addClass(this.dropbar, "uk-navbar-dropbar-slide");
|
|
}
|
|
}
|
|
},
|
|
disconnected: function() {
|
|
this.dropbar && remove(this.dropbar);
|
|
},
|
|
update: function() {
|
|
var this$1 = this;
|
|
this.$create("drop", this.dropdowns.filter(function(el) {
|
|
return !this$1.getDropdown(el);
|
|
}), assign({}, this.$props, {
|
|
boundary: this.boundary,
|
|
pos: this.pos,
|
|
offset: this.dropbar || this.offset
|
|
}));
|
|
},
|
|
events: [ {
|
|
name: "mouseover",
|
|
delegate: function() {
|
|
return this.dropdown;
|
|
},
|
|
handler: function(ref) {
|
|
var current = ref.current;
|
|
var active = this.getActive();
|
|
if (active && active.toggle && !within(active.toggle.$el, current) && !active.tracker.movesTo(active.$el)) {
|
|
active.hide(false);
|
|
}
|
|
}
|
|
}, {
|
|
name: "mouseleave",
|
|
el: function() {
|
|
return this.dropbar;
|
|
},
|
|
handler: function() {
|
|
var active = this.getActive();
|
|
if (active && !matches(this.dropbar, ":hover")) {
|
|
active.hide();
|
|
}
|
|
}
|
|
}, {
|
|
name: "beforeshow",
|
|
capture: true,
|
|
filter: function() {
|
|
return this.dropbar;
|
|
},
|
|
handler: function() {
|
|
if (!this.dropbar.parentNode) {
|
|
after(this.dropbarAnchor || this.$el, this.dropbar);
|
|
}
|
|
}
|
|
}, {
|
|
name: "show",
|
|
capture: true,
|
|
filter: function() {
|
|
return this.dropbar;
|
|
},
|
|
handler: function(_, drop) {
|
|
var $el = drop.$el;
|
|
var dir = drop.dir;
|
|
this.clsDrop && addClass($el, this.clsDrop + "-dropbar");
|
|
if (dir === "bottom") {
|
|
this.transitionTo($el.offsetHeight + toFloat(css($el, "marginTop")) + toFloat(css($el, "marginBottom")), $el);
|
|
}
|
|
}
|
|
}, {
|
|
name: "beforehide",
|
|
filter: function() {
|
|
return this.dropbar;
|
|
},
|
|
handler: function(e, ref) {
|
|
var $el = ref.$el;
|
|
var active = this.getActive();
|
|
if (matches(this.dropbar, ":hover") && active && active.$el === $el) {
|
|
e.preventDefault();
|
|
}
|
|
}
|
|
}, {
|
|
name: "hide",
|
|
filter: function() {
|
|
return this.dropbar;
|
|
},
|
|
handler: function(_, ref) {
|
|
var $el = ref.$el;
|
|
var active = this.getActive();
|
|
if (!active || active && active.$el === $el) {
|
|
this.transitionTo(0);
|
|
}
|
|
}
|
|
} ],
|
|
methods: {
|
|
getActive: function() {
|
|
var ref = this.dropdowns.map(this.getDropdown).filter(function(drop) {
|
|
return drop.isActive();
|
|
});
|
|
var active = ref[0];
|
|
return active && includes(active.mode, "hover") && within(active.toggle.$el, this.$el) && active;
|
|
},
|
|
transitionTo: function(newHeight, el) {
|
|
var this$1 = this;
|
|
var ref = this;
|
|
var dropbar = ref.dropbar;
|
|
var oldHeight = isVisible(dropbar) ? height(dropbar) : 0;
|
|
el = oldHeight < newHeight && el;
|
|
css(el, "clip", "rect(0," + el.offsetWidth + "px," + oldHeight + "px,0)");
|
|
height(dropbar, oldHeight);
|
|
Transition.cancel([ el, dropbar ]);
|
|
return Promise.all([ Transition.start(dropbar, {
|
|
height: newHeight
|
|
}, this.duration), Transition.start(el, {
|
|
clip: "rect(0," + el.offsetWidth + "px," + newHeight + "px,0)"
|
|
}, this.duration) ]).catch(noop).then(function() {
|
|
css(el, {
|
|
clip: ""
|
|
});
|
|
this$1.$update(dropbar);
|
|
});
|
|
},
|
|
getDropdown: function(el) {
|
|
return this.$getComponent(el, "drop") || this.$getComponent(el, "dropdown");
|
|
}
|
|
}
|
|
};
|
|
var scroll;
|
|
var Offcanvas = {
|
|
mixins: [ Modal ],
|
|
args: "mode",
|
|
props: {
|
|
content: String,
|
|
mode: String,
|
|
flip: Boolean,
|
|
overlay: Boolean
|
|
},
|
|
data: {
|
|
content: ".uk-offcanvas-content",
|
|
mode: "slide",
|
|
flip: false,
|
|
overlay: false,
|
|
clsPage: "uk-offcanvas-page",
|
|
clsContainer: "uk-offcanvas-container",
|
|
selPanel: ".uk-offcanvas-bar",
|
|
clsFlip: "uk-offcanvas-flip",
|
|
clsContent: "uk-offcanvas-content",
|
|
clsContentAnimation: "uk-offcanvas-content-animation",
|
|
clsSidebarAnimation: "uk-offcanvas-bar-animation",
|
|
clsMode: "uk-offcanvas",
|
|
clsOverlay: "uk-offcanvas-overlay",
|
|
selClose: ".uk-offcanvas-close"
|
|
},
|
|
computed: {
|
|
content: function(ref) {
|
|
var content = ref.content;
|
|
return $(content) || document.body;
|
|
},
|
|
clsFlip: function(ref) {
|
|
var flip = ref.flip;
|
|
var clsFlip = ref.clsFlip;
|
|
return flip ? clsFlip : "";
|
|
},
|
|
clsOverlay: function(ref) {
|
|
var overlay = ref.overlay;
|
|
var clsOverlay = ref.clsOverlay;
|
|
return overlay ? clsOverlay : "";
|
|
},
|
|
clsMode: function(ref) {
|
|
var mode = ref.mode;
|
|
var clsMode = ref.clsMode;
|
|
return clsMode + "-" + mode;
|
|
},
|
|
clsSidebarAnimation: function(ref) {
|
|
var mode = ref.mode;
|
|
var clsSidebarAnimation = ref.clsSidebarAnimation;
|
|
return mode === "none" || mode === "reveal" ? "" : clsSidebarAnimation;
|
|
},
|
|
clsContentAnimation: function(ref) {
|
|
var mode = ref.mode;
|
|
var clsContentAnimation = ref.clsContentAnimation;
|
|
return mode !== "push" && mode !== "reveal" ? "" : clsContentAnimation;
|
|
},
|
|
transitionElement: function(ref) {
|
|
var mode = ref.mode;
|
|
return mode === "reveal" ? this.panel.parentNode : this.panel;
|
|
}
|
|
},
|
|
update: {
|
|
write: function() {
|
|
if (this.getActive() === this) {
|
|
if (this.overlay || this.clsContentAnimation) {
|
|
width(this.content, width(window) - this.scrollbarWidth);
|
|
}
|
|
if (this.overlay) {
|
|
height(this.content, height(window));
|
|
if (scroll) {
|
|
this.content.scrollTop = scroll.y;
|
|
}
|
|
}
|
|
}
|
|
},
|
|
events: [ "resize" ]
|
|
},
|
|
events: [ {
|
|
name: "click",
|
|
delegate: function() {
|
|
return 'a[href^="#"]';
|
|
},
|
|
handler: function(ref) {
|
|
var current = ref.current;
|
|
if (current.hash && $(current.hash, this.content)) {
|
|
scroll = null;
|
|
this.hide();
|
|
}
|
|
}
|
|
}, {
|
|
name: "beforescroll",
|
|
filter: function() {
|
|
return this.overlay;
|
|
},
|
|
handler: function(e, scroll, target) {
|
|
if (scroll && target && this.isToggled() && $(target, this.content)) {
|
|
once(this.$el, "hidden", function() {
|
|
return scroll.scrollTo(target);
|
|
});
|
|
e.preventDefault();
|
|
}
|
|
}
|
|
}, {
|
|
name: "show",
|
|
self: true,
|
|
handler: function() {
|
|
scroll = scroll || {
|
|
x: window.pageXOffset,
|
|
y: window.pageYOffset
|
|
};
|
|
if (this.mode === "reveal" && !hasClass(this.panel, this.clsMode)) {
|
|
wrapAll(this.panel, "<div>");
|
|
addClass(this.panel.parentNode, this.clsMode);
|
|
}
|
|
css(document.documentElement, "overflowY", (!this.clsContentAnimation || this.flip) && this.scrollbarWidth && this.overlay ? "scroll" : "");
|
|
addClass(document.body, this.clsContainer, this.clsFlip, this.clsOverlay);
|
|
height(document.body);
|
|
addClass(this.content, this.clsContentAnimation);
|
|
addClass(this.panel, this.clsSidebarAnimation, this.mode !== "reveal" ? this.clsMode : "");
|
|
addClass(this.$el, this.clsOverlay);
|
|
css(this.$el, "display", "block");
|
|
height(this.$el);
|
|
}
|
|
}, {
|
|
name: "hide",
|
|
self: true,
|
|
handler: function() {
|
|
removeClass(this.content, this.clsContentAnimation);
|
|
var active = this.getActive();
|
|
if (this.mode === "none" || active && active !== this && active !== this.prev) {
|
|
trigger(this.panel, "transitionend");
|
|
}
|
|
}
|
|
}, {
|
|
name: "hidden",
|
|
self: true,
|
|
handler: function() {
|
|
if (this.mode === "reveal") {
|
|
unwrap(this.panel);
|
|
}
|
|
if (!this.overlay) {
|
|
scroll = {
|
|
x: window.pageXOffset,
|
|
y: window.pageYOffset
|
|
};
|
|
} else if (!scroll) {
|
|
var ref = this.content;
|
|
var x = ref.scrollLeft;
|
|
var y = ref.scrollTop;
|
|
scroll = {
|
|
x: x,
|
|
y: y
|
|
};
|
|
}
|
|
removeClass(this.panel, this.clsSidebarAnimation, this.clsMode);
|
|
removeClass(this.$el, this.clsOverlay);
|
|
css(this.$el, "display", "");
|
|
removeClass(document.body, this.clsContainer, this.clsFlip, this.clsOverlay);
|
|
document.body.scrollTop = scroll.y;
|
|
css(document.documentElement, "overflowY", "");
|
|
width(this.content, "");
|
|
height(this.content, "");
|
|
window.scroll(scroll.x, scroll.y);
|
|
scroll = null;
|
|
}
|
|
}, {
|
|
name: "swipeLeft swipeRight",
|
|
handler: function(e) {
|
|
if (this.isToggled() && isTouch(e) && (e.type === "swipeLeft" && !this.flip || e.type === "swipeRight" && this.flip)) {
|
|
this.hide();
|
|
}
|
|
}
|
|
} ]
|
|
};
|
|
var OverflowAuto = {
|
|
mixins: [ Class ],
|
|
props: {
|
|
selContainer: String,
|
|
selContent: String
|
|
},
|
|
data: {
|
|
selContainer: ".uk-modal",
|
|
selContent: ".uk-modal-dialog"
|
|
},
|
|
computed: {
|
|
container: function(ref, $el) {
|
|
var selContainer = ref.selContainer;
|
|
return closest($el, selContainer);
|
|
},
|
|
content: function(ref, $el) {
|
|
var selContent = ref.selContent;
|
|
return closest($el, selContent);
|
|
}
|
|
},
|
|
connected: function() {
|
|
css(this.$el, "minHeight", 150);
|
|
},
|
|
update: {
|
|
read: function() {
|
|
if (!this.content || !this.container) {
|
|
return false;
|
|
}
|
|
return {
|
|
current: toFloat(css(this.$el, "maxHeight")),
|
|
max: Math.max(150, height(this.container) - (offset(this.content).height - height(this.$el)))
|
|
};
|
|
},
|
|
write: function(ref) {
|
|
var current = ref.current;
|
|
var max = ref.max;
|
|
css(this.$el, "maxHeight", max);
|
|
if (Math.round(current) !== Math.round(max)) {
|
|
trigger(this.$el, "resize");
|
|
}
|
|
},
|
|
events: [ "load", "resize" ]
|
|
}
|
|
};
|
|
var Responsive = {
|
|
props: [ "width", "height" ],
|
|
connected: function() {
|
|
addClass(this.$el, "uk-responsive-width");
|
|
},
|
|
update: {
|
|
read: function() {
|
|
return isVisible(this.$el) && this.width && this.height ? {
|
|
width: width(this.$el.parentNode),
|
|
height: this.height
|
|
} : false;
|
|
},
|
|
write: function(dim) {
|
|
height(this.$el, Dimensions.contain({
|
|
height: this.height,
|
|
width: this.width
|
|
}, dim).height);
|
|
},
|
|
events: [ "load", "resize" ]
|
|
}
|
|
};
|
|
var Scroll = {
|
|
props: {
|
|
duration: Number,
|
|
offset: Number
|
|
},
|
|
data: {
|
|
duration: 1e3,
|
|
offset: 0
|
|
},
|
|
methods: {
|
|
scrollTo: function(el) {
|
|
var this$1 = this;
|
|
el = el && $(el) || document.body;
|
|
var docHeight = height(document);
|
|
var winHeight = height(window);
|
|
var target = offset(el).top - this.offset;
|
|
if (target + winHeight > docHeight) {
|
|
target = docHeight - winHeight;
|
|
}
|
|
if (!trigger(this.$el, "beforescroll", [ this, el ])) {
|
|
return;
|
|
}
|
|
var start = Date.now();
|
|
var startY = window.pageYOffset;
|
|
var step = function() {
|
|
var currentY = startY + (target - startY) * ease(clamp((Date.now() - start) / this$1.duration));
|
|
scrollTop(window, currentY);
|
|
if (currentY !== target) {
|
|
requestAnimationFrame(step);
|
|
} else {
|
|
trigger(this$1.$el, "scrolled", [ this$1, el ]);
|
|
}
|
|
};
|
|
step();
|
|
}
|
|
},
|
|
events: {
|
|
click: function(e) {
|
|
if (e.defaultPrevented) {
|
|
return;
|
|
}
|
|
e.preventDefault();
|
|
this.scrollTo(escape(decodeURIComponent(this.$el.hash)).substr(1));
|
|
}
|
|
}
|
|
};
|
|
function ease(k) {
|
|
return .5 * (1 - Math.cos(Math.PI * k));
|
|
}
|
|
var Scrollspy = {
|
|
args: "cls",
|
|
props: {
|
|
cls: "list",
|
|
target: String,
|
|
hidden: Boolean,
|
|
offsetTop: Number,
|
|
offsetLeft: Number,
|
|
repeat: Boolean,
|
|
delay: Number
|
|
},
|
|
data: function() {
|
|
return {
|
|
cls: [],
|
|
target: false,
|
|
hidden: true,
|
|
offsetTop: 0,
|
|
offsetLeft: 0,
|
|
repeat: false,
|
|
delay: 0,
|
|
inViewClass: "uk-scrollspy-inview"
|
|
};
|
|
},
|
|
computed: {
|
|
elements: function(ref, $el) {
|
|
var target = ref.target;
|
|
return target ? $$(target, $el) : [ $el ];
|
|
}
|
|
},
|
|
update: [ {
|
|
write: function() {
|
|
if (this.hidden) {
|
|
css(filter(this.elements, ":not(." + this.inViewClass + ")"), "visibility", "hidden");
|
|
}
|
|
}
|
|
}, {
|
|
read: function(els) {
|
|
var this$1 = this;
|
|
if (!els.delay) {
|
|
return;
|
|
}
|
|
this.elements.forEach(function(el, i) {
|
|
var elData = els[i];
|
|
if (!elData || elData.el !== el) {
|
|
var cls = data(el, "uk-scrollspy-class");
|
|
elData = {
|
|
el: el,
|
|
toggles: cls && cls.split(",") || this$1.cls
|
|
};
|
|
}
|
|
elData.show = isInView(el, this$1.offsetTop, this$1.offsetLeft);
|
|
els[i] = elData;
|
|
});
|
|
},
|
|
write: function(els) {
|
|
var this$1 = this;
|
|
if (!els.delay) {
|
|
this.$emit();
|
|
return els.delay = true;
|
|
}
|
|
this.elements.forEach(function(el, i) {
|
|
var elData = els[i];
|
|
var cls = elData.toggles[i] || elData.toggles[0];
|
|
if (elData.show && !elData.inview && !elData.queued) {
|
|
var show = function() {
|
|
css(el, "visibility", "");
|
|
addClass(el, this$1.inViewClass);
|
|
toggleClass(el, cls);
|
|
trigger(el, "inview");
|
|
this$1.$update(el);
|
|
elData.inview = true;
|
|
elData.abort && elData.abort();
|
|
};
|
|
if (this$1.delay) {
|
|
elData.queued = true;
|
|
els.promise = (els.promise || Promise.resolve()).then(function() {
|
|
return !elData.inview && new Promise(function(resolve) {
|
|
var timer = setTimeout(function() {
|
|
show();
|
|
resolve();
|
|
}, els.promise || this$1.elements.length === 1 ? this$1.delay : 0);
|
|
elData.abort = function() {
|
|
clearTimeout(timer);
|
|
resolve();
|
|
elData.queued = false;
|
|
};
|
|
});
|
|
});
|
|
} else {
|
|
show();
|
|
}
|
|
} else if (!elData.show && (elData.inview || elData.queued) && this$1.repeat) {
|
|
elData.abort && elData.abort();
|
|
if (!elData.inview) {
|
|
return;
|
|
}
|
|
css(el, "visibility", this$1.hidden ? "hidden" : "");
|
|
removeClass(el, this$1.inViewClass);
|
|
toggleClass(el, cls);
|
|
trigger(el, "outview");
|
|
this$1.$update(el);
|
|
elData.inview = false;
|
|
}
|
|
});
|
|
},
|
|
events: [ "scroll", "load", "resize" ]
|
|
} ]
|
|
};
|
|
var ScrollspyNav = {
|
|
props: {
|
|
cls: String,
|
|
closest: String,
|
|
scroll: Boolean,
|
|
overflow: Boolean,
|
|
offset: Number
|
|
},
|
|
data: {
|
|
cls: "uk-active",
|
|
closest: false,
|
|
scroll: false,
|
|
overflow: true,
|
|
offset: 0
|
|
},
|
|
computed: {
|
|
links: function(_, $el) {
|
|
return $$('a[href^="#"]', $el).filter(function(el) {
|
|
return el.hash;
|
|
});
|
|
},
|
|
elements: function() {
|
|
return this.closest ? closest(this.links, this.closest) : this.links;
|
|
},
|
|
targets: function() {
|
|
return $$(this.links.map(function(el) {
|
|
return el.hash;
|
|
}).join(","));
|
|
}
|
|
},
|
|
update: [ {
|
|
read: function() {
|
|
if (this.scroll) {
|
|
this.$create("scroll", this.links, {
|
|
offset: this.offset || 0
|
|
});
|
|
}
|
|
}
|
|
}, {
|
|
read: function(data$$1) {
|
|
var this$1 = this;
|
|
var scroll = window.pageYOffset + this.offset + 1;
|
|
var max = height(document) - height(window) + this.offset;
|
|
data$$1.active = false;
|
|
this.targets.every(function(el, i) {
|
|
var ref = offset(el);
|
|
var top = ref.top;
|
|
var last = i + 1 === this$1.targets.length;
|
|
if (!this$1.overflow && (i === 0 && top > scroll || last && top + el.offsetTop < scroll)) {
|
|
return false;
|
|
}
|
|
if (!last && offset(this$1.targets[i + 1]).top <= scroll) {
|
|
return true;
|
|
}
|
|
if (scroll >= max) {
|
|
for (var j = this$1.targets.length - 1; j > i; j--) {
|
|
if (isInView(this$1.targets[j])) {
|
|
el = this$1.targets[j];
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
return !(data$$1.active = $(filter(this$1.links, '[href="#' + el.id + '"]')));
|
|
});
|
|
},
|
|
write: function(ref) {
|
|
var active = ref.active;
|
|
this.links.forEach(function(el) {
|
|
return el.blur();
|
|
});
|
|
removeClass(this.elements, this.cls);
|
|
if (active) {
|
|
trigger(this.$el, "active", [ active, addClass(this.closest ? closest(active, this.closest) : active, this.cls) ]);
|
|
}
|
|
},
|
|
events: [ "scroll", "load", "resize" ]
|
|
} ]
|
|
};
|
|
var Sticky = {
|
|
mixins: [ Class, Media ],
|
|
props: {
|
|
top: null,
|
|
bottom: Boolean,
|
|
offset: Number,
|
|
animation: String,
|
|
clsActive: String,
|
|
clsInactive: String,
|
|
clsFixed: String,
|
|
clsBelow: String,
|
|
selTarget: String,
|
|
widthElement: Boolean,
|
|
showOnUp: Boolean,
|
|
targetOffset: Number
|
|
},
|
|
data: {
|
|
top: 0,
|
|
bottom: false,
|
|
offset: 0,
|
|
animation: "",
|
|
clsActive: "uk-active",
|
|
clsInactive: "",
|
|
clsFixed: "uk-sticky-fixed",
|
|
clsBelow: "uk-sticky-below",
|
|
selTarget: "",
|
|
widthElement: false,
|
|
showOnUp: false,
|
|
targetOffset: false
|
|
},
|
|
computed: {
|
|
selTarget: function(ref, $el) {
|
|
var selTarget = ref.selTarget;
|
|
return selTarget && $(selTarget, $el) || $el;
|
|
},
|
|
widthElement: function(ref, $el) {
|
|
var widthElement = ref.widthElement;
|
|
return query(widthElement, $el) || this.placeholder;
|
|
}
|
|
},
|
|
connected: function() {
|
|
this.placeholder = $("+ .uk-sticky-placeholder", this.$el) || $('<div class="uk-sticky-placeholder"></div>');
|
|
},
|
|
disconnected: function() {
|
|
if (this.isActive) {
|
|
this.isActive = undefined;
|
|
this.hide();
|
|
removeClass(this.selTarget, this.clsInactive);
|
|
}
|
|
remove(this.placeholder);
|
|
this.placeholder = null;
|
|
this.widthElement = null;
|
|
},
|
|
events: [ {
|
|
name: "active",
|
|
self: true,
|
|
handler: function() {
|
|
replaceClass(this.selTarget, this.clsInactive, this.clsActive);
|
|
}
|
|
}, {
|
|
name: "inactive",
|
|
self: true,
|
|
handler: function() {
|
|
replaceClass(this.selTarget, this.clsActive, this.clsInactive);
|
|
}
|
|
}, {
|
|
name: "load hashchange popstate",
|
|
el: window,
|
|
handler: function() {
|
|
var this$1 = this;
|
|
if (!(this.targetOffset !== false && location.hash && window.pageYOffset > 0)) {
|
|
return;
|
|
}
|
|
var target = $(location.hash);
|
|
if (target) {
|
|
fastdom.read(function() {
|
|
var ref = offset(target);
|
|
var top = ref.top;
|
|
var elTop = offset(this$1.$el).top;
|
|
var elHeight = this$1.$el.offsetHeight;
|
|
if (this$1.isActive && elTop + elHeight >= top && elTop <= top + target.offsetHeight) {
|
|
scrollTop(window, top - elHeight - (isNumeric(this$1.targetOffset) ? this$1.targetOffset : 0) - this$1.offset);
|
|
}
|
|
});
|
|
}
|
|
}
|
|
} ],
|
|
update: [ {
|
|
read: function(ref) {
|
|
var height$$1 = ref.height;
|
|
this.topOffset = offset(this.isActive ? this.placeholder : this.$el).top;
|
|
this.bottomOffset = this.topOffset + height$$1;
|
|
var bottom = parseProp("bottom", this);
|
|
this.top = Math.max(toFloat(parseProp("top", this)), this.topOffset) - this.offset;
|
|
this.bottom = bottom && bottom - height$$1;
|
|
this.inactive = !this.matchMedia;
|
|
return {
|
|
height: !this.isActive ? this.$el.offsetHeight : height$$1,
|
|
margins: css(this.$el, [ "marginTop", "marginBottom", "marginLeft", "marginRight" ])
|
|
};
|
|
},
|
|
write: function(ref) {
|
|
var height$$1 = ref.height;
|
|
var margins = ref.margins;
|
|
var ref$1 = this;
|
|
var placeholder = ref$1.placeholder;
|
|
css(placeholder, assign({
|
|
height: height$$1
|
|
}, margins));
|
|
if (!within(placeholder, document)) {
|
|
after(this.$el, placeholder);
|
|
attr(placeholder, "hidden", "");
|
|
}
|
|
if (isUndefined(this.isActive)) {
|
|
this.hide();
|
|
}
|
|
},
|
|
events: [ "load", "resize" ]
|
|
}, {
|
|
read: function(_, ref) {
|
|
var scrollY = ref.scrollY;
|
|
if (scrollY === void 0) scrollY = window.pageYOffset;
|
|
this.width = (isVisible(this.widthElement) ? this.widthElement : this.$el).offsetWidth;
|
|
return {
|
|
scroll: this.scroll = scrollY,
|
|
visible: isVisible(this.$el)
|
|
};
|
|
},
|
|
write: function(ref, ref$1) {
|
|
var this$1 = this;
|
|
var visible = ref.visible;
|
|
var scroll = ref.scroll;
|
|
if (ref$1 === void 0) ref$1 = {};
|
|
var dir = ref$1.dir;
|
|
if (scroll < 0 || !visible || this.disabled || this.showOnUp && !dir) {
|
|
return;
|
|
}
|
|
if (this.inactive || scroll < this.top || this.showOnUp && (scroll <= this.top || dir === "down" || dir === "up" && !this.isActive && scroll <= this.bottomOffset)) {
|
|
if (!this.isActive) {
|
|
return;
|
|
}
|
|
this.isActive = false;
|
|
if (this.animation && scroll > this.topOffset) {
|
|
Animation.cancel(this.$el);
|
|
Animation.out(this.$el, this.animation).then(function() {
|
|
return this$1.hide();
|
|
}, noop);
|
|
} else {
|
|
this.hide();
|
|
}
|
|
} else if (this.isActive) {
|
|
this.update();
|
|
} else if (this.animation) {
|
|
Animation.cancel(this.$el);
|
|
this.show();
|
|
Animation.in(this.$el, this.animation).catch(noop);
|
|
} else {
|
|
this.show();
|
|
}
|
|
},
|
|
events: [ "load", "resize", "scroll" ]
|
|
} ],
|
|
methods: {
|
|
show: function() {
|
|
this.isActive = true;
|
|
this.update();
|
|
attr(this.placeholder, "hidden", null);
|
|
},
|
|
hide: function() {
|
|
if (!this.isActive || hasClass(this.selTarget, this.clsActive)) {
|
|
trigger(this.$el, "inactive");
|
|
}
|
|
removeClass(this.$el, this.clsFixed, this.clsBelow);
|
|
css(this.$el, {
|
|
position: "",
|
|
top: "",
|
|
width: ""
|
|
});
|
|
attr(this.placeholder, "hidden", "");
|
|
},
|
|
update: function() {
|
|
var active = this.top !== 0 || this.scroll > this.top;
|
|
var top = Math.max(0, this.offset);
|
|
if (this.bottom && this.scroll > this.bottom - this.offset) {
|
|
top = this.bottom - this.scroll;
|
|
}
|
|
css(this.$el, {
|
|
position: "fixed",
|
|
top: top + "px",
|
|
width: this.width
|
|
});
|
|
if (hasClass(this.selTarget, this.clsActive)) {
|
|
if (!active) {
|
|
trigger(this.$el, "inactive");
|
|
}
|
|
} else if (active) {
|
|
trigger(this.$el, "active");
|
|
}
|
|
toggleClass(this.$el, this.clsBelow, this.scroll > this.bottomOffset);
|
|
addClass(this.$el, this.clsFixed);
|
|
}
|
|
}
|
|
};
|
|
function parseProp(prop, ref) {
|
|
var $props = ref.$props;
|
|
var $el = ref.$el;
|
|
var propOffset = ref[prop + "Offset"];
|
|
var value = $props[prop];
|
|
if (!value) {
|
|
return;
|
|
}
|
|
if (isNumeric(value)) {
|
|
return propOffset + toFloat(value);
|
|
} else if (isString(value) && value.match(/^-?\d+vh$/)) {
|
|
return height(window) * toFloat(value) / 100;
|
|
} else {
|
|
var el = value === true ? $el.parentNode : query(value, $el);
|
|
if (el) {
|
|
return offset(el).top + el.offsetHeight;
|
|
}
|
|
}
|
|
}
|
|
var Switcher = {
|
|
mixins: [ Togglable ],
|
|
args: "connect",
|
|
props: {
|
|
connect: String,
|
|
toggle: String,
|
|
active: Number,
|
|
swiping: Boolean
|
|
},
|
|
data: {
|
|
connect: "~.uk-switcher",
|
|
toggle: "> *",
|
|
active: 0,
|
|
swiping: true,
|
|
cls: "uk-active",
|
|
clsContainer: "uk-switcher",
|
|
attrItem: "uk-switcher-item",
|
|
queued: true
|
|
},
|
|
computed: {
|
|
connects: function(ref, $el) {
|
|
var connect = ref.connect;
|
|
return queryAll(connect, $el);
|
|
},
|
|
toggles: function(ref, $el) {
|
|
var toggle = ref.toggle;
|
|
return $$(toggle, $el);
|
|
}
|
|
},
|
|
events: [ {
|
|
name: "click",
|
|
delegate: function() {
|
|
return this.toggle + ":not(.uk-disabled)";
|
|
},
|
|
handler: function(e) {
|
|
e.preventDefault();
|
|
this.show(e.current);
|
|
}
|
|
}, {
|
|
name: "click",
|
|
el: function() {
|
|
return this.connects;
|
|
},
|
|
delegate: function() {
|
|
return "[" + this.attrItem + "],[data-" + this.attrItem + "]";
|
|
},
|
|
handler: function(e) {
|
|
e.preventDefault();
|
|
this.show(data(e.current, this.attrItem));
|
|
}
|
|
}, {
|
|
name: "swipeRight swipeLeft",
|
|
filter: function() {
|
|
return this.swiping;
|
|
},
|
|
el: function() {
|
|
return this.connects;
|
|
},
|
|
handler: function(e) {
|
|
if (!isTouch(e)) {
|
|
return;
|
|
}
|
|
e.preventDefault();
|
|
if (!window.getSelection().toString()) {
|
|
this.show(e.type === "swipeLeft" ? "next" : "previous");
|
|
}
|
|
}
|
|
} ],
|
|
update: function() {
|
|
var this$1 = this;
|
|
this.connects.forEach(function(list) {
|
|
return this$1.updateAria(list.children);
|
|
});
|
|
this.show(filter(this.toggles, "." + this.cls)[0] || this.toggles[this.active] || this.toggles[0]);
|
|
},
|
|
methods: {
|
|
index: function() {
|
|
return !!this.connects.length && index(filter(this.connects[0].children, "." + this.cls)[0]);
|
|
},
|
|
show: function(item) {
|
|
var this$1 = this;
|
|
var ref = this.toggles;
|
|
var length = ref.length;
|
|
var prev = this.index();
|
|
var hasPrev = prev >= 0;
|
|
var dir = item === "previous" ? -1 : 1;
|
|
var toggle, next = getIndex(item, this.toggles, prev);
|
|
for (var i = 0; i < length; i++, next = (next + dir + length) % length) {
|
|
if (!matches(this$1.toggles[next], ".uk-disabled, [disabled]")) {
|
|
toggle = this$1.toggles[next];
|
|
break;
|
|
}
|
|
}
|
|
if (!toggle || prev >= 0 && hasClass(toggle, this.cls) || prev === next) {
|
|
return;
|
|
}
|
|
removeClass(this.toggles, this.cls);
|
|
attr(this.toggles, "aria-expanded", false);
|
|
addClass(toggle, this.cls);
|
|
attr(toggle, "aria-expanded", true);
|
|
this.connects.forEach(function(list) {
|
|
if (!hasPrev) {
|
|
this$1.toggleNow(list.children[next]);
|
|
} else {
|
|
this$1.toggleElement([ list.children[prev], list.children[next] ]);
|
|
}
|
|
});
|
|
}
|
|
}
|
|
};
|
|
var Tab = {
|
|
mixins: [ Class ],
|
|
extends: Switcher,
|
|
props: {
|
|
media: Boolean
|
|
},
|
|
data: {
|
|
media: 960,
|
|
attrItem: "uk-tab-item"
|
|
},
|
|
connected: function() {
|
|
var cls = hasClass(this.$el, "uk-tab-left") ? "uk-tab-left" : hasClass(this.$el, "uk-tab-right") ? "uk-tab-right" : false;
|
|
if (cls) {
|
|
this.$create("toggle", this.$el, {
|
|
cls: cls,
|
|
mode: "media",
|
|
media: this.media
|
|
});
|
|
}
|
|
}
|
|
};
|
|
var Toggle = {
|
|
mixins: [ Media, Togglable ],
|
|
args: "target",
|
|
props: {
|
|
href: String,
|
|
target: null,
|
|
mode: "list"
|
|
},
|
|
data: {
|
|
href: false,
|
|
target: false,
|
|
mode: "click",
|
|
queued: true
|
|
},
|
|
computed: {
|
|
target: function(ref, $el) {
|
|
var href = ref.href;
|
|
var target = ref.target;
|
|
target = queryAll(target || href, $el);
|
|
return target.length && target || [ $el ];
|
|
}
|
|
},
|
|
events: [ {
|
|
name: pointerEnter + " " + pointerLeave,
|
|
filter: function() {
|
|
return includes(this.mode, "hover");
|
|
},
|
|
handler: function(e) {
|
|
if (!isTouch(e)) {
|
|
this.toggle("toggle" + (e.type === pointerEnter ? "show" : "hide"));
|
|
}
|
|
}
|
|
}, {
|
|
name: "click",
|
|
filter: function() {
|
|
return includes(this.mode, "click") || hasTouch && includes(this.mode, "hover");
|
|
},
|
|
handler: function(e) {
|
|
if (!isTouch(e) && !includes(this.mode, "click")) {
|
|
return;
|
|
}
|
|
var link;
|
|
if (closest(e.target, 'a[href="#"], button') || (link = closest(e.target, "a[href]")) && (this.cls || !isVisible(this.target) || link.hash && matches(this.target, link.hash))) {
|
|
once(document, "click", function(e) {
|
|
return e.preventDefault();
|
|
});
|
|
}
|
|
this.toggle();
|
|
}
|
|
} ],
|
|
update: {
|
|
write: function() {
|
|
if (!includes(this.mode, "media") || !this.media) {
|
|
return;
|
|
}
|
|
var toggled = this.isToggled(this.target);
|
|
if (this.matchMedia ? !toggled : toggled) {
|
|
this.toggle();
|
|
}
|
|
},
|
|
events: [ "load", "resize" ]
|
|
},
|
|
methods: {
|
|
toggle: function(type) {
|
|
if (trigger(this.target, type || "toggle", [ this ])) {
|
|
this.toggleElement(this.target);
|
|
}
|
|
}
|
|
}
|
|
};
|
|
function core(UIkit) {
|
|
UIkit.component("accordion", Accordion);
|
|
UIkit.component("alert", Alert);
|
|
UIkit.component("cover", Cover);
|
|
UIkit.component("drop", Drop);
|
|
UIkit.component("dropdown", Dropdown);
|
|
UIkit.component("formCustom", FormCustom);
|
|
UIkit.component("gif", Gif);
|
|
UIkit.component("grid", Grid);
|
|
UIkit.component("heightMatch", HeightMatch);
|
|
UIkit.component("heightViewport", HeightViewport);
|
|
UIkit.component("icon", Icon);
|
|
UIkit.component("img", Img);
|
|
UIkit.component("leader", Leader);
|
|
UIkit.component("margin", Margin);
|
|
UIkit.component("modal", Modal$1);
|
|
UIkit.component("nav", Nav);
|
|
UIkit.component("navbar", Navbar);
|
|
UIkit.component("offcanvas", Offcanvas);
|
|
UIkit.component("overflowAuto", OverflowAuto);
|
|
UIkit.component("responsive", Responsive);
|
|
UIkit.component("scroll", Scroll);
|
|
UIkit.component("scrollspy", Scrollspy);
|
|
UIkit.component("scrollspyNav", ScrollspyNav);
|
|
UIkit.component("sticky", Sticky);
|
|
UIkit.component("svg", SVG);
|
|
UIkit.component("switcher", Switcher);
|
|
UIkit.component("tab", Tab);
|
|
UIkit.component("toggle", Toggle);
|
|
UIkit.component("video", Video);
|
|
UIkit.component("close", Close);
|
|
UIkit.component("marker", IconComponent);
|
|
UIkit.component("navbarToggleIcon", IconComponent);
|
|
UIkit.component("overlayIcon", IconComponent);
|
|
UIkit.component("paginationNext", IconComponent);
|
|
UIkit.component("paginationPrevious", IconComponent);
|
|
UIkit.component("searchIcon", Search);
|
|
UIkit.component("slidenavNext", Slidenav);
|
|
UIkit.component("slidenavPrevious", Slidenav);
|
|
UIkit.component("spinner", Spinner);
|
|
UIkit.component("totop", IconComponent);
|
|
UIkit.use(Core);
|
|
}
|
|
UIkit.version = "3.0.0-rc.17";
|
|
core(UIkit);
|
|
var Countdown = {
|
|
mixins: [ Class ],
|
|
props: {
|
|
date: String,
|
|
clsWrapper: String
|
|
},
|
|
data: {
|
|
date: "",
|
|
clsWrapper: ".uk-countdown-%unit%"
|
|
},
|
|
computed: {
|
|
date: function(ref) {
|
|
var date = ref.date;
|
|
return Date.parse(date);
|
|
},
|
|
days: function(ref, $el) {
|
|
var clsWrapper = ref.clsWrapper;
|
|
return $(clsWrapper.replace("%unit%", "days"), $el);
|
|
},
|
|
hours: function(ref, $el) {
|
|
var clsWrapper = ref.clsWrapper;
|
|
return $(clsWrapper.replace("%unit%", "hours"), $el);
|
|
},
|
|
minutes: function(ref, $el) {
|
|
var clsWrapper = ref.clsWrapper;
|
|
return $(clsWrapper.replace("%unit%", "minutes"), $el);
|
|
},
|
|
seconds: function(ref, $el) {
|
|
var clsWrapper = ref.clsWrapper;
|
|
return $(clsWrapper.replace("%unit%", "seconds"), $el);
|
|
},
|
|
units: function() {
|
|
var this$1 = this;
|
|
return [ "days", "hours", "minutes", "seconds" ].filter(function(unit) {
|
|
return this$1[unit];
|
|
});
|
|
}
|
|
},
|
|
connected: function() {
|
|
this.start();
|
|
},
|
|
disconnected: function() {
|
|
var this$1 = this;
|
|
this.stop();
|
|
this.units.forEach(function(unit) {
|
|
return empty(this$1[unit]);
|
|
});
|
|
},
|
|
events: [ {
|
|
name: "visibilitychange",
|
|
el: document,
|
|
handler: function() {
|
|
if (document.hidden) {
|
|
this.stop();
|
|
} else {
|
|
this.start();
|
|
}
|
|
}
|
|
} ],
|
|
update: {
|
|
write: function() {
|
|
var this$1 = this;
|
|
var timespan = getTimeSpan(this.date);
|
|
if (timespan.total <= 0) {
|
|
this.stop();
|
|
timespan.days = timespan.hours = timespan.minutes = timespan.seconds = 0;
|
|
}
|
|
this.units.forEach(function(unit) {
|
|
var digits = String(Math.floor(timespan[unit]));
|
|
digits = digits.length < 2 ? "0" + digits : digits;
|
|
var el = this$1[unit];
|
|
if (el.textContent !== digits) {
|
|
digits = digits.split("");
|
|
if (digits.length !== el.children.length) {
|
|
html(el, digits.map(function() {
|
|
return "<span></span>";
|
|
}).join(""));
|
|
}
|
|
digits.forEach(function(digit, i) {
|
|
return el.children[i].textContent = digit;
|
|
});
|
|
}
|
|
});
|
|
}
|
|
},
|
|
methods: {
|
|
start: function() {
|
|
var this$1 = this;
|
|
this.stop();
|
|
if (this.date && this.units.length) {
|
|
this.$emit();
|
|
this.timer = setInterval(function() {
|
|
return this$1.$emit();
|
|
}, 1e3);
|
|
}
|
|
},
|
|
stop: function() {
|
|
if (this.timer) {
|
|
clearInterval(this.timer);
|
|
this.timer = null;
|
|
}
|
|
}
|
|
}
|
|
};
|
|
function getTimeSpan(date) {
|
|
var total = date - Date.now();
|
|
return {
|
|
total: total,
|
|
seconds: total / 1e3 % 60,
|
|
minutes: total / 1e3 / 60 % 60,
|
|
hours: total / 1e3 / 60 / 60 % 24,
|
|
days: total / 1e3 / 60 / 60 / 24
|
|
};
|
|
}
|
|
var targetClass = "uk-animation-target";
|
|
var Animate = {
|
|
props: {
|
|
animation: Number
|
|
},
|
|
data: {
|
|
animation: 150
|
|
},
|
|
computed: {
|
|
target: function() {
|
|
return this.$el;
|
|
}
|
|
},
|
|
methods: {
|
|
animate: function(action) {
|
|
var this$1 = this;
|
|
addStyle();
|
|
var children = toNodes(this.target.children);
|
|
var propsFrom = children.map(function(el) {
|
|
return getProps(el, true);
|
|
});
|
|
var oldHeight = height(this.target);
|
|
var oldScrollY = window.pageYOffset;
|
|
action();
|
|
Transition.cancel(this.target);
|
|
children.forEach(Transition.cancel);
|
|
reset(this.target);
|
|
this.$update(this.target);
|
|
fastdom.flush();
|
|
var newHeight = height(this.target);
|
|
children = children.concat(toNodes(this.target.children).filter(function(el) {
|
|
return !includes(children, el);
|
|
}));
|
|
var propsTo = children.map(function(el, i) {
|
|
return el.parentNode && i in propsFrom ? propsFrom[i] ? isVisible(el) ? getPositionWithMargin(el) : {
|
|
opacity: 0
|
|
} : {
|
|
opacity: isVisible(el) ? 1 : 0
|
|
} : false;
|
|
});
|
|
propsFrom = propsTo.map(function(props, i) {
|
|
var from = children[i].parentNode === this$1.target ? propsFrom[i] || getProps(children[i]) : false;
|
|
if (from) {
|
|
if (!props) {
|
|
delete from.opacity;
|
|
} else if (!("opacity" in props)) {
|
|
var opacity = from.opacity;
|
|
if (opacity % 1) {
|
|
props.opacity = 1;
|
|
} else {
|
|
delete from.opacity;
|
|
}
|
|
}
|
|
}
|
|
return from;
|
|
});
|
|
addClass(this.target, targetClass);
|
|
children.forEach(function(el, i) {
|
|
return propsFrom[i] && css(el, propsFrom[i]);
|
|
});
|
|
css(this.target, "height", oldHeight);
|
|
scrollTop(window, oldScrollY);
|
|
return Promise.all(children.map(function(el, i) {
|
|
return propsFrom[i] && propsTo[i] ? Transition.start(el, propsTo[i], this$1.animation, "ease") : Promise.resolve();
|
|
}).concat(Transition.start(this.target, {
|
|
height: newHeight
|
|
}, this.animation, "ease"))).then(function() {
|
|
children.forEach(function(el, i) {
|
|
return css(el, {
|
|
display: propsTo[i].opacity === 0 ? "none" : "",
|
|
zIndex: ""
|
|
});
|
|
});
|
|
reset(this$1.target);
|
|
this$1.$update(this$1.target);
|
|
fastdom.flush();
|
|
}, noop);
|
|
}
|
|
}
|
|
};
|
|
function getProps(el, opacity) {
|
|
var zIndex = css(el, "zIndex");
|
|
return isVisible(el) ? assign({
|
|
display: "",
|
|
opacity: opacity ? css(el, "opacity") : "0",
|
|
pointerEvents: "none",
|
|
position: "absolute",
|
|
zIndex: zIndex === "auto" ? index(el) : zIndex
|
|
}, getPositionWithMargin(el)) : false;
|
|
}
|
|
function reset(el) {
|
|
css(el.children, {
|
|
height: "",
|
|
left: "",
|
|
opacity: "",
|
|
pointerEvents: "",
|
|
position: "",
|
|
top: "",
|
|
width: ""
|
|
});
|
|
removeClass(el, targetClass);
|
|
css(el, "height", "");
|
|
}
|
|
function getPositionWithMargin(el) {
|
|
var ref = el.getBoundingClientRect();
|
|
var height$$1 = ref.height;
|
|
var width$$1 = ref.width;
|
|
var ref$1 = position(el);
|
|
var top = ref$1.top;
|
|
var left = ref$1.left;
|
|
top += toFloat(css(el, "marginTop"));
|
|
return {
|
|
top: top,
|
|
left: left,
|
|
height: height$$1,
|
|
width: width$$1
|
|
};
|
|
}
|
|
var style$1;
|
|
function addStyle() {
|
|
if (!style$1) {
|
|
style$1 = append(document.head, "<style>").sheet;
|
|
style$1.insertRule("." + targetClass + " > * {\n margin-top: 0 !important;\n transform: none !important;\n }", 0);
|
|
}
|
|
}
|
|
var Filter = {
|
|
mixins: [ Animate ],
|
|
args: "target",
|
|
props: {
|
|
target: Boolean,
|
|
selActive: Boolean
|
|
},
|
|
data: {
|
|
target: null,
|
|
selActive: false,
|
|
attrItem: "uk-filter-control",
|
|
cls: "uk-active",
|
|
animation: 250
|
|
},
|
|
computed: {
|
|
toggles: function(ref, $el) {
|
|
var attrItem = ref.attrItem;
|
|
return $$("[" + this.attrItem + "],[data-" + this.attrItem + "]", $el);
|
|
},
|
|
target: function(ref, $el) {
|
|
var target = ref.target;
|
|
return $(target, $el);
|
|
}
|
|
},
|
|
events: [ {
|
|
name: "click",
|
|
delegate: function() {
|
|
return "[" + this.attrItem + "],[data-" + this.attrItem + "]";
|
|
},
|
|
handler: function(e) {
|
|
e.preventDefault();
|
|
this.apply(e.current);
|
|
}
|
|
} ],
|
|
connected: function() {
|
|
var this$1 = this;
|
|
if (this.selActive === false) {
|
|
return;
|
|
}
|
|
var actives = $$(this.selActive, this.$el);
|
|
this.toggles.forEach(function(el) {
|
|
return toggleClass(el, this$1.cls, includes(actives, el));
|
|
});
|
|
},
|
|
update: function(data$$1) {
|
|
var toggles = data$$1.toggles;
|
|
var children = data$$1.children;
|
|
if (isEqualList(toggles, this.toggles, false) && isEqualList(children, this.target.children, false)) {
|
|
return;
|
|
}
|
|
data$$1.toggles = this.toggles;
|
|
data$$1.children = this.target.children;
|
|
this.setState(this.getState(), false);
|
|
},
|
|
methods: {
|
|
apply: function(el) {
|
|
this.setState(mergeState(el, this.attrItem, this.getState()));
|
|
},
|
|
getState: function() {
|
|
var this$1 = this;
|
|
return this.toggles.filter(function(item) {
|
|
return hasClass(item, this$1.cls);
|
|
}).reduce(function(state, el) {
|
|
return mergeState(el, this$1.attrItem, state);
|
|
}, {
|
|
filter: {
|
|
"": ""
|
|
},
|
|
sort: []
|
|
});
|
|
},
|
|
setState: function(state, animate$$1) {
|
|
var this$1 = this;
|
|
if (animate$$1 === void 0) animate$$1 = true;
|
|
state = assign({
|
|
filter: {
|
|
"": ""
|
|
},
|
|
sort: []
|
|
}, state);
|
|
trigger(this.$el, "beforeFilter", [ this, state ]);
|
|
var children = toNodes(this.target.children);
|
|
this.toggles.forEach(function(el) {
|
|
return toggleClass(el, this$1.cls, matchFilter(el, this$1.attrItem, state));
|
|
});
|
|
var apply$$1 = function() {
|
|
var selector = getSelector(state);
|
|
children.forEach(function(el) {
|
|
return css(el, "display", selector && !matches(el, selector) ? "none" : "");
|
|
});
|
|
var ref = state.sort;
|
|
var sort = ref[0];
|
|
var order = ref[1];
|
|
if (sort) {
|
|
var sorted = sortItems(children, sort, order);
|
|
if (!isEqualList(sorted, children)) {
|
|
sorted.forEach(function(el) {
|
|
return append(this$1.target, el);
|
|
});
|
|
}
|
|
}
|
|
};
|
|
if (animate$$1) {
|
|
this.animate(apply$$1).then(function() {
|
|
return trigger(this$1.$el, "afterFilter", [ this$1 ]);
|
|
});
|
|
} else {
|
|
apply$$1();
|
|
trigger(this.$el, "afterFilter", [ this ]);
|
|
}
|
|
}
|
|
}
|
|
};
|
|
function getFilter(el, attr$$1) {
|
|
return parseOptions(data(el, attr$$1), [ "filter" ]);
|
|
}
|
|
function mergeState(el, attr$$1, state) {
|
|
toNodes(el).forEach(function(el) {
|
|
var filterBy = getFilter(el, attr$$1);
|
|
var filter$$1 = filterBy.filter;
|
|
var group = filterBy.group;
|
|
var sort = filterBy.sort;
|
|
var order = filterBy.order;
|
|
if (order === void 0) order = "asc";
|
|
if (filter$$1 || isUndefined(sort)) {
|
|
if (group) {
|
|
delete state.filter[""];
|
|
state.filter[group] = filter$$1;
|
|
} else {
|
|
state.filter = {
|
|
"": filter$$1
|
|
};
|
|
}
|
|
}
|
|
if (!isUndefined(sort)) {
|
|
state.sort = [ sort, order ];
|
|
}
|
|
});
|
|
return state;
|
|
}
|
|
function matchFilter(el, attr$$1, ref) {
|
|
var stateFilter = ref.filter;
|
|
var ref_sort = ref.sort;
|
|
var stateSort = ref_sort[0];
|
|
var stateOrder = ref_sort[1];
|
|
var ref$1 = getFilter(el, attr$$1);
|
|
var filter$$1 = ref$1.filter;
|
|
var group = ref$1.group;
|
|
if (group === void 0) group = "";
|
|
var sort = ref$1.sort;
|
|
var order = ref$1.order;
|
|
if (order === void 0) order = "asc";
|
|
return Boolean((filter$$1 || isUndefined(sort)) && group in stateFilter && (filter$$1 === stateFilter[group] || isUndefined(filter$$1) && !stateFilter[group]) || stateSort && sort && stateSort === sort && stateOrder === order);
|
|
}
|
|
function isEqualList(listA, listB, strict) {
|
|
if (strict === void 0) strict = true;
|
|
listA = toNodes(listA);
|
|
listB = toNodes(listB);
|
|
return listA.length === listB.length && listA.every(function(el, i) {
|
|
return strict ? el === listB[i] : ~listB.indexOf(el);
|
|
});
|
|
}
|
|
function getSelector(ref) {
|
|
var filter$$1 = ref.filter;
|
|
var selector = "";
|
|
each(filter$$1, function(value) {
|
|
return selector += value || "";
|
|
});
|
|
return selector;
|
|
}
|
|
function sortItems(nodes, sort, order) {
|
|
return toNodes(nodes).sort(function(a, b) {
|
|
return data(a, sort).localeCompare(data(b, sort), undefined, {
|
|
numeric: true
|
|
}) * (order === "asc" || -1);
|
|
});
|
|
}
|
|
var Animations = {
|
|
slide: {
|
|
show: function(dir) {
|
|
return [ {
|
|
transform: translate(dir * -100)
|
|
}, {
|
|
transform: translate()
|
|
} ];
|
|
},
|
|
percent: function(current) {
|
|
return translated(current);
|
|
},
|
|
translate: function(percent, dir) {
|
|
return [ {
|
|
transform: translate(dir * -100 * percent)
|
|
}, {
|
|
transform: translate(dir * 100 * (1 - percent))
|
|
} ];
|
|
}
|
|
}
|
|
};
|
|
function translated(el) {
|
|
return Math.abs(css(el, "transform").split(",")[4] / el.offsetWidth) || 0;
|
|
}
|
|
function translate(value, unit) {
|
|
if (value === void 0) value = 0;
|
|
if (unit === void 0) unit = "%";
|
|
return "translateX(" + value + (value ? unit : "") + ")";
|
|
}
|
|
function scale3d(value) {
|
|
return "scale3d(" + value + ", " + value + ", 1)";
|
|
}
|
|
var Animations$1 = assign({}, Animations, {
|
|
fade: {
|
|
show: function() {
|
|
return [ {
|
|
opacity: 0
|
|
}, {
|
|
opacity: 1
|
|
} ];
|
|
},
|
|
percent: function(current) {
|
|
return 1 - css(current, "opacity");
|
|
},
|
|
translate: function(percent) {
|
|
return [ {
|
|
opacity: 1 - percent
|
|
}, {
|
|
opacity: percent
|
|
} ];
|
|
}
|
|
},
|
|
scale: {
|
|
show: function() {
|
|
return [ {
|
|
opacity: 0,
|
|
transform: scale3d(1 - .2)
|
|
}, {
|
|
opacity: 1,
|
|
transform: scale3d(1)
|
|
} ];
|
|
},
|
|
percent: function(current) {
|
|
return 1 - css(current, "opacity");
|
|
},
|
|
translate: function(percent) {
|
|
return [ {
|
|
opacity: 1 - percent,
|
|
transform: scale3d(1 - .2 * percent)
|
|
}, {
|
|
opacity: percent,
|
|
transform: scale3d(1 - .2 + .2 * percent)
|
|
} ];
|
|
}
|
|
}
|
|
});
|
|
function Transitioner(prev, next, dir, ref) {
|
|
var animation = ref.animation;
|
|
var easing = ref.easing;
|
|
var percent = animation.percent;
|
|
var translate = animation.translate;
|
|
var show = animation.show;
|
|
if (show === void 0) show = noop;
|
|
var props = show(dir);
|
|
var deferred = new Deferred();
|
|
return {
|
|
dir: dir,
|
|
show: function(duration, percent, linear) {
|
|
var this$1 = this;
|
|
if (percent === void 0) percent = 0;
|
|
var timing = linear ? "linear" : easing;
|
|
duration -= Math.round(duration * clamp(percent, -1, 1));
|
|
this.translate(percent);
|
|
triggerUpdate(next, "itemin", {
|
|
percent: percent,
|
|
duration: duration,
|
|
timing: timing,
|
|
dir: dir
|
|
});
|
|
triggerUpdate(prev, "itemout", {
|
|
percent: 1 - percent,
|
|
duration: duration,
|
|
timing: timing,
|
|
dir: dir
|
|
});
|
|
Promise.all([ Transition.start(next, props[1], duration, timing), Transition.start(prev, props[0], duration, timing) ]).then(function() {
|
|
this$1.reset();
|
|
deferred.resolve();
|
|
}, noop);
|
|
return deferred.promise;
|
|
},
|
|
stop: function() {
|
|
return Transition.stop([ next, prev ]);
|
|
},
|
|
cancel: function() {
|
|
Transition.cancel([ next, prev ]);
|
|
},
|
|
reset: function() {
|
|
for (var prop in props[0]) {
|
|
css([ next, prev ], prop, "");
|
|
}
|
|
},
|
|
forward: function(duration, percent) {
|
|
if (percent === void 0) percent = this.percent();
|
|
Transition.cancel([ next, prev ]);
|
|
return this.show(duration, percent, true);
|
|
},
|
|
translate: function(percent) {
|
|
this.reset();
|
|
var props = translate(percent, dir);
|
|
css(next, props[1]);
|
|
css(prev, props[0]);
|
|
triggerUpdate(next, "itemtranslatein", {
|
|
percent: percent,
|
|
dir: dir
|
|
});
|
|
triggerUpdate(prev, "itemtranslateout", {
|
|
percent: 1 - percent,
|
|
dir: dir
|
|
});
|
|
},
|
|
percent: function() {
|
|
return percent(prev || next, next, dir);
|
|
},
|
|
getDistance: function() {
|
|
return prev.offsetWidth;
|
|
}
|
|
};
|
|
}
|
|
function triggerUpdate(el, type, data$$1) {
|
|
trigger(el, createEvent(type, false, false, data$$1));
|
|
}
|
|
var SliderAutoplay = {
|
|
props: {
|
|
autoplay: Boolean,
|
|
autoplayInterval: Number,
|
|
pauseOnHover: Boolean
|
|
},
|
|
data: {
|
|
autoplay: false,
|
|
autoplayInterval: 7e3,
|
|
pauseOnHover: true
|
|
},
|
|
connected: function() {
|
|
this.startAutoplay();
|
|
},
|
|
disconnected: function() {
|
|
this.stopAutoplay();
|
|
},
|
|
events: [ {
|
|
name: "visibilitychange",
|
|
el: document,
|
|
handler: function() {
|
|
if (document.hidden) {
|
|
this.stopAutoplay();
|
|
} else {
|
|
this.startAutoplay();
|
|
}
|
|
}
|
|
}, {
|
|
name: pointerDown,
|
|
handler: "stopAutoplay"
|
|
}, {
|
|
name: "mouseenter",
|
|
filter: function() {
|
|
return this.autoplay;
|
|
},
|
|
handler: function() {
|
|
this.isHovering = true;
|
|
}
|
|
}, {
|
|
name: "mouseleave",
|
|
filter: function() {
|
|
return this.autoplay;
|
|
},
|
|
handler: function() {
|
|
this.isHovering = false;
|
|
}
|
|
} ],
|
|
methods: {
|
|
startAutoplay: function() {
|
|
var this$1 = this;
|
|
this.stopAutoplay();
|
|
if (this.autoplay) {
|
|
this.interval = setInterval(function() {
|
|
return !(this$1.isHovering && this$1.pauseOnHover) && !this$1.stack.length && this$1.show("next");
|
|
}, this.autoplayInterval);
|
|
}
|
|
},
|
|
stopAutoplay: function() {
|
|
if (this.interval) {
|
|
clearInterval(this.interval);
|
|
}
|
|
}
|
|
}
|
|
};
|
|
var SliderDrag = {
|
|
data: {
|
|
threshold: 10,
|
|
preventCatch: false
|
|
},
|
|
created: function() {
|
|
var this$1 = this;
|
|
[ "start", "move", "end" ].forEach(function(key) {
|
|
var fn = this$1[key];
|
|
this$1[key] = function(e) {
|
|
var pos = getPos$1(e).x * (isRtl ? -1 : 1);
|
|
this$1.prevPos = pos !== this$1.pos ? this$1.pos : this$1.prevPos;
|
|
this$1.pos = pos;
|
|
fn(e);
|
|
};
|
|
});
|
|
},
|
|
events: [ {
|
|
name: pointerDown,
|
|
delegate: function() {
|
|
return this.slidesSelector;
|
|
},
|
|
handler: function(e) {
|
|
if (!isTouch(e) && hasTextNodesOnly(e.target) || e.button > 0 || this.length < 2 || this.preventCatch) {
|
|
return;
|
|
}
|
|
this.start(e);
|
|
}
|
|
}, {
|
|
name: "touchmove",
|
|
passive: false,
|
|
handler: "move",
|
|
delegate: function() {
|
|
return this.slidesSelector;
|
|
}
|
|
}, {
|
|
name: "dragstart",
|
|
handler: function(e) {
|
|
e.preventDefault();
|
|
}
|
|
} ],
|
|
methods: {
|
|
start: function() {
|
|
var this$1 = this;
|
|
this.drag = this.pos;
|
|
if (this._transitioner) {
|
|
this.percent = this._transitioner.percent();
|
|
this.drag += this._transitioner.getDistance() * this.percent * this.dir;
|
|
this._transitioner.cancel();
|
|
this._transitioner.translate(this.percent);
|
|
this.dragging = true;
|
|
this.stack = [];
|
|
} else {
|
|
this.prevIndex = this.index;
|
|
}
|
|
var off$$1 = on(document, pointerMove.replace(" touchmove", ""), this.move, {
|
|
passive: false
|
|
});
|
|
this.unbindMove = function() {
|
|
off$$1();
|
|
this$1.unbindMove = null;
|
|
};
|
|
on(window, "scroll", this.unbindMove);
|
|
on(document, pointerUp, this.end, true);
|
|
},
|
|
move: function(e) {
|
|
var this$1 = this;
|
|
if (!this.unbindMove) {
|
|
return;
|
|
}
|
|
var distance = this.pos - this.drag;
|
|
if (distance === 0 || this.prevPos === this.pos || !this.dragging && Math.abs(distance) < this.threshold) {
|
|
return;
|
|
}
|
|
e.cancelable && e.preventDefault();
|
|
this.dragging = true;
|
|
this.dir = distance < 0 ? 1 : -1;
|
|
var ref = this;
|
|
var slides = ref.slides;
|
|
var ref$1 = this;
|
|
var prevIndex = ref$1.prevIndex;
|
|
var dis = Math.abs(distance);
|
|
var nextIndex = this.getIndex(prevIndex + this.dir, prevIndex);
|
|
var width$$1 = this._getDistance(prevIndex, nextIndex) || slides[prevIndex].offsetWidth;
|
|
while (nextIndex !== prevIndex && dis > width$$1) {
|
|
this$1.drag -= width$$1 * this$1.dir;
|
|
prevIndex = nextIndex;
|
|
dis -= width$$1;
|
|
nextIndex = this$1.getIndex(prevIndex + this$1.dir, prevIndex);
|
|
width$$1 = this$1._getDistance(prevIndex, nextIndex) || slides[prevIndex].offsetWidth;
|
|
}
|
|
this.percent = dis / width$$1;
|
|
var prev = slides[prevIndex];
|
|
var next = slides[nextIndex];
|
|
var changed = this.index !== nextIndex;
|
|
var edge = prevIndex === nextIndex;
|
|
var itemShown;
|
|
[ this.index, this.prevIndex ].filter(function(i) {
|
|
return !includes([ nextIndex, prevIndex ], i);
|
|
}).forEach(function(i) {
|
|
trigger(slides[i], "itemhidden", [ this$1 ]);
|
|
if (edge) {
|
|
itemShown = true;
|
|
this$1.prevIndex = prevIndex;
|
|
}
|
|
});
|
|
if (this.index === prevIndex && this.prevIndex !== prevIndex || itemShown) {
|
|
trigger(slides[this.index], "itemshown", [ this ]);
|
|
}
|
|
if (changed) {
|
|
this.prevIndex = prevIndex;
|
|
this.index = nextIndex;
|
|
!edge && trigger(prev, "beforeitemhide", [ this ]);
|
|
trigger(next, "beforeitemshow", [ this ]);
|
|
}
|
|
this._transitioner = this._translate(Math.abs(this.percent), prev, !edge && next);
|
|
if (changed) {
|
|
!edge && trigger(prev, "itemhide", [ this ]);
|
|
trigger(next, "itemshow", [ this ]);
|
|
}
|
|
},
|
|
end: function() {
|
|
off(window, "scroll", this.unbindMove);
|
|
this.unbindMove && this.unbindMove();
|
|
off(document, pointerUp, this.end, true);
|
|
if (this.dragging) {
|
|
this.dragging = null;
|
|
if (this.index === this.prevIndex) {
|
|
this.percent = 1 - this.percent;
|
|
this.dir *= -1;
|
|
this._show(false, this.index, true);
|
|
this._transitioner = null;
|
|
} else {
|
|
var dirChange = (isRtl ? this.dir * (isRtl ? 1 : -1) : this.dir) < 0 === this.prevPos > this.pos;
|
|
this.index = dirChange ? this.index : this.prevIndex;
|
|
if (dirChange) {
|
|
this.percent = 1 - this.percent;
|
|
}
|
|
this.show(this.dir > 0 && !dirChange || this.dir < 0 && dirChange ? "next" : "previous", true);
|
|
}
|
|
preventClick();
|
|
}
|
|
this.drag = this.percent = null;
|
|
}
|
|
}
|
|
};
|
|
function hasTextNodesOnly(el) {
|
|
return !el.children.length && el.childNodes.length;
|
|
}
|
|
var SliderNav = {
|
|
data: {
|
|
selNav: false
|
|
},
|
|
computed: {
|
|
nav: function(ref, $el) {
|
|
var selNav = ref.selNav;
|
|
return $(selNav, $el);
|
|
},
|
|
navItemSelector: function(ref) {
|
|
var attrItem = ref.attrItem;
|
|
return "[" + attrItem + "],[data-" + attrItem + "]";
|
|
},
|
|
navItems: function(_, $el) {
|
|
return $$(this.navItemSelector, $el);
|
|
}
|
|
},
|
|
update: {
|
|
write: function() {
|
|
var this$1 = this;
|
|
if (this.nav && this.length !== this.nav.children.length) {
|
|
html(this.nav, this.slides.map(function(_, i) {
|
|
return "<li " + this$1.attrItem + '="' + i + '"><a href="#"></a></li>';
|
|
}).join(""));
|
|
}
|
|
toggleClass($$(this.navItemSelector, this.$el).concat(this.nav), "uk-hidden", !this.maxIndex);
|
|
this.updateNav();
|
|
},
|
|
events: [ "load", "resize" ]
|
|
},
|
|
events: [ {
|
|
name: "click",
|
|
delegate: function() {
|
|
return this.navItemSelector;
|
|
},
|
|
handler: function(e) {
|
|
e.preventDefault();
|
|
e.current.blur();
|
|
this.show(data(e.current, this.attrItem));
|
|
}
|
|
}, {
|
|
name: "itemshow",
|
|
handler: "updateNav"
|
|
} ],
|
|
methods: {
|
|
updateNav: function() {
|
|
var this$1 = this;
|
|
var i = this.getValidIndex();
|
|
this.navItems.forEach(function(el) {
|
|
var cmd = data(el, this$1.attrItem);
|
|
toggleClass(el, this$1.clsActive, toNumber(cmd) === i);
|
|
toggleClass(el, "uk-invisible", this$1.finite && (cmd === "previous" && i === 0 || cmd === "next" && i >= this$1.maxIndex));
|
|
});
|
|
}
|
|
}
|
|
};
|
|
var Slider = {
|
|
mixins: [ SliderAutoplay, SliderDrag, SliderNav ],
|
|
props: {
|
|
clsActivated: Boolean,
|
|
easing: String,
|
|
index: Number,
|
|
finite: Boolean,
|
|
velocity: Number
|
|
},
|
|
data: function() {
|
|
return {
|
|
easing: "ease",
|
|
finite: false,
|
|
velocity: 1,
|
|
index: 0,
|
|
stack: [],
|
|
percent: 0,
|
|
clsActive: "uk-active",
|
|
clsActivated: false,
|
|
Transitioner: false,
|
|
transitionOptions: {}
|
|
};
|
|
},
|
|
computed: {
|
|
duration: function(ref, $el) {
|
|
var velocity = ref.velocity;
|
|
return speedUp($el.offsetWidth / velocity);
|
|
},
|
|
length: function() {
|
|
return this.slides.length;
|
|
},
|
|
list: function(ref, $el) {
|
|
var selList = ref.selList;
|
|
return $(selList, $el);
|
|
},
|
|
maxIndex: function() {
|
|
return this.length - 1;
|
|
},
|
|
slidesSelector: function(ref) {
|
|
var selList = ref.selList;
|
|
return selList + " > *";
|
|
},
|
|
slides: function() {
|
|
return toNodes(this.list.children);
|
|
}
|
|
},
|
|
events: {
|
|
itemshown: function() {
|
|
this.$update(this.list);
|
|
}
|
|
},
|
|
methods: {
|
|
show: function(index$$1, force) {
|
|
var this$1 = this;
|
|
if (force === void 0) force = false;
|
|
if (this.dragging || !this.length) {
|
|
return;
|
|
}
|
|
var ref = this;
|
|
var stack = ref.stack;
|
|
var queueIndex = force ? 0 : stack.length;
|
|
var reset = function() {
|
|
stack.splice(queueIndex, 1);
|
|
if (stack.length) {
|
|
this$1.show(stack.shift(), true);
|
|
}
|
|
};
|
|
stack[force ? "unshift" : "push"](index$$1);
|
|
if (!force && stack.length > 1) {
|
|
if (stack.length === 2) {
|
|
this._transitioner.forward(Math.min(this.duration, 200));
|
|
}
|
|
return;
|
|
}
|
|
var prevIndex = this.index;
|
|
var prev = hasClass(this.slides, this.clsActive) && this.slides[prevIndex];
|
|
var nextIndex = this.getIndex(index$$1, this.index);
|
|
var next = this.slides[nextIndex];
|
|
if (prev === next) {
|
|
reset();
|
|
return;
|
|
}
|
|
this.dir = getDirection(index$$1, prevIndex);
|
|
this.prevIndex = prevIndex;
|
|
this.index = nextIndex;
|
|
prev && trigger(prev, "beforeitemhide", [ this ]);
|
|
if (!trigger(next, "beforeitemshow", [ this, prev ])) {
|
|
this.index = this.prevIndex;
|
|
reset();
|
|
return;
|
|
}
|
|
var promise = this._show(prev, next, force).then(function() {
|
|
prev && trigger(prev, "itemhidden", [ this$1 ]);
|
|
trigger(next, "itemshown", [ this$1 ]);
|
|
return new Promise(function(resolve) {
|
|
fastdom.write(function() {
|
|
stack.shift();
|
|
if (stack.length) {
|
|
this$1.show(stack.shift(), true);
|
|
} else {
|
|
this$1._transitioner = null;
|
|
}
|
|
resolve();
|
|
});
|
|
});
|
|
});
|
|
prev && trigger(prev, "itemhide", [ this ]);
|
|
trigger(next, "itemshow", [ this ]);
|
|
return promise;
|
|
},
|
|
getIndex: function(index$$1, prev) {
|
|
if (index$$1 === void 0) index$$1 = this.index;
|
|
if (prev === void 0) prev = this.index;
|
|
return clamp(getIndex(index$$1, this.slides, prev, this.finite), 0, this.maxIndex);
|
|
},
|
|
getValidIndex: function(index$$1, prevIndex) {
|
|
if (index$$1 === void 0) index$$1 = this.index;
|
|
if (prevIndex === void 0) prevIndex = this.prevIndex;
|
|
return this.getIndex(index$$1, prevIndex);
|
|
},
|
|
_show: function(prev, next, force) {
|
|
this._transitioner = this._getTransitioner(prev, next, this.dir, assign({
|
|
easing: force ? next.offsetWidth < 600 ? "cubic-bezier(0.25, 0.46, 0.45, 0.94)" : "cubic-bezier(0.165, 0.84, 0.44, 1)" : this.easing
|
|
}, this.transitionOptions));
|
|
if (!force && !prev) {
|
|
this._transitioner.translate(1);
|
|
return Promise.resolve();
|
|
}
|
|
var ref = this.stack;
|
|
var length = ref.length;
|
|
return this._transitioner[length > 1 ? "forward" : "show"](length > 1 ? Math.min(this.duration, 75 + 75 / (length - 1)) : this.duration, this.percent);
|
|
},
|
|
_getDistance: function(prev, next) {
|
|
return new this._getTransitioner(prev, prev !== next && next).getDistance();
|
|
},
|
|
_translate: function(percent, prev, next) {
|
|
if (prev === void 0) prev = this.prevIndex;
|
|
if (next === void 0) next = this.index;
|
|
var transitioner = this._getTransitioner(prev !== next ? prev : false, next);
|
|
transitioner.translate(percent);
|
|
return transitioner;
|
|
},
|
|
_getTransitioner: function(prev, next, dir, options) {
|
|
if (prev === void 0) prev = this.prevIndex;
|
|
if (next === void 0) next = this.index;
|
|
if (dir === void 0) dir = this.dir || 1;
|
|
if (options === void 0) options = this.transitionOptions;
|
|
return new this.Transitioner(isNumber(prev) ? this.slides[prev] : prev, isNumber(next) ? this.slides[next] : next, dir * (isRtl ? -1 : 1), options);
|
|
}
|
|
}
|
|
};
|
|
function getDirection(index$$1, prevIndex) {
|
|
return index$$1 === "next" ? 1 : index$$1 === "previous" ? -1 : index$$1 < prevIndex ? -1 : 1;
|
|
}
|
|
function speedUp(x) {
|
|
return .5 * x + 300;
|
|
}
|
|
var Slideshow = {
|
|
mixins: [ Slider ],
|
|
props: {
|
|
animation: String
|
|
},
|
|
data: {
|
|
animation: "slide",
|
|
clsActivated: "uk-transition-active",
|
|
Animations: Animations,
|
|
Transitioner: Transitioner
|
|
},
|
|
computed: {
|
|
animation: function(ref) {
|
|
var animation = ref.animation;
|
|
var Animations$$1 = ref.Animations;
|
|
return assign(animation in Animations$$1 ? Animations$$1[animation] : Animations$$1.slide, {
|
|
name: animation
|
|
});
|
|
},
|
|
transitionOptions: function() {
|
|
return {
|
|
animation: this.animation
|
|
};
|
|
}
|
|
},
|
|
events: {
|
|
"itemshow itemhide itemshown itemhidden": function(ref) {
|
|
var target = ref.target;
|
|
this.$update(target);
|
|
},
|
|
itemshow: function() {
|
|
isNumber(this.prevIndex) && fastdom.flush();
|
|
},
|
|
beforeitemshow: function(ref) {
|
|
var target = ref.target;
|
|
addClass(target, this.clsActive);
|
|
},
|
|
itemshown: function(ref) {
|
|
var target = ref.target;
|
|
addClass(target, this.clsActivated);
|
|
},
|
|
itemhidden: function(ref) {
|
|
var target = ref.target;
|
|
removeClass(target, this.clsActive, this.clsActivated);
|
|
}
|
|
}
|
|
};
|
|
var LightboxPanel = {
|
|
mixins: [ Container, Modal, Togglable, Slideshow ],
|
|
functional: true,
|
|
props: {
|
|
delayControls: Number,
|
|
preload: Number,
|
|
videoAutoplay: Boolean,
|
|
template: String
|
|
},
|
|
data: function() {
|
|
return {
|
|
preload: 1,
|
|
videoAutoplay: false,
|
|
delayControls: 3e3,
|
|
items: [],
|
|
cls: "uk-open",
|
|
clsPage: "uk-lightbox-page",
|
|
selList: ".uk-lightbox-items",
|
|
attrItem: "uk-lightbox-item",
|
|
selClose: ".uk-close-large",
|
|
pauseOnHover: false,
|
|
velocity: 2,
|
|
Animations: Animations$1,
|
|
template: '<div class="uk-lightbox uk-overflow-hidden"> <ul class="uk-lightbox-items"></ul> <div class="uk-lightbox-toolbar uk-position-top uk-text-right uk-transition-slide-top uk-transition-opaque"> <button class="uk-lightbox-toolbar-icon uk-close-large" type="button" uk-close></button> </div> <a class="uk-lightbox-button uk-position-center-left uk-position-medium uk-transition-fade" href="#" uk-slidenav-previous uk-lightbox-item="previous"></a> <a class="uk-lightbox-button uk-position-center-right uk-position-medium uk-transition-fade" href="#" uk-slidenav-next uk-lightbox-item="next"></a> <div class="uk-lightbox-toolbar uk-lightbox-caption uk-position-bottom uk-text-center uk-transition-slide-bottom uk-transition-opaque"></div> </div>'
|
|
};
|
|
},
|
|
created: function() {
|
|
var this$1 = this;
|
|
this.$mount(append(this.container, this.template));
|
|
this.caption = $(".uk-lightbox-caption", this.$el);
|
|
this.items.forEach(function() {
|
|
return append(this$1.list, "<li></li>");
|
|
});
|
|
},
|
|
events: [ {
|
|
name: pointerMove + " " + pointerDown + " keydown",
|
|
handler: "showControls"
|
|
}, {
|
|
name: "click",
|
|
self: true,
|
|
delegate: function() {
|
|
return this.slidesSelector;
|
|
},
|
|
handler: function(e) {
|
|
e.preventDefault();
|
|
this.hide();
|
|
}
|
|
}, {
|
|
name: "shown",
|
|
self: true,
|
|
handler: "showControls"
|
|
}, {
|
|
name: "hide",
|
|
self: true,
|
|
handler: function() {
|
|
this.hideControls();
|
|
removeClass(this.slides, this.clsActive);
|
|
Transition.stop(this.slides);
|
|
}
|
|
}, {
|
|
name: "keyup",
|
|
el: document,
|
|
handler: function(e) {
|
|
if (!this.isToggled(this.$el)) {
|
|
return;
|
|
}
|
|
switch (e.keyCode) {
|
|
case 37:
|
|
this.show("previous");
|
|
break;
|
|
|
|
case 39:
|
|
this.show("next");
|
|
break;
|
|
}
|
|
}
|
|
}, {
|
|
name: "beforeitemshow",
|
|
handler: function(e) {
|
|
if (this.isToggled()) {
|
|
return;
|
|
}
|
|
this.preventCatch = true;
|
|
e.preventDefault();
|
|
this.toggleNow(this.$el, true);
|
|
this.animation = Animations$1["scale"];
|
|
removeClass(e.target, this.clsActive);
|
|
this.stack.splice(1, 0, this.index);
|
|
}
|
|
}, {
|
|
name: "itemshow",
|
|
handler: function(ref) {
|
|
var this$1 = this;
|
|
var target = ref.target;
|
|
var i = index(target);
|
|
var ref$1 = this.getItem(i);
|
|
var caption = ref$1.caption;
|
|
css(this.caption, "display", caption ? "" : "none");
|
|
html(this.caption, caption);
|
|
for (var j = 0; j <= this.preload; j++) {
|
|
this$1.loadItem(this$1.getIndex(i + j));
|
|
this$1.loadItem(this$1.getIndex(i - j));
|
|
}
|
|
}
|
|
}, {
|
|
name: "itemshown",
|
|
handler: function() {
|
|
this.preventCatch = false;
|
|
}
|
|
}, {
|
|
name: "itemload",
|
|
handler: function(_, item) {
|
|
var this$1 = this;
|
|
var source = item.source;
|
|
var type = item.type;
|
|
var alt = item.alt;
|
|
this.setItem(item, "<span uk-spinner></span>");
|
|
if (!source) {
|
|
return;
|
|
}
|
|
var matches$$1;
|
|
if (type === "image" || source.match(/\.(jp(e)?g|png|gif|svg)($|\?)/i)) {
|
|
getImage(source).then(function(img) {
|
|
return this$1.setItem(item, '<img width="' + img.width + '" height="' + img.height + '" src="' + source + '" alt="' + (alt ? alt : "") + '">');
|
|
}, function() {
|
|
return this$1.setError(item);
|
|
});
|
|
} else if (type === "video" || source.match(/\.(mp4|webm|ogv)($|\?)/i)) {
|
|
var video = $("<video controls playsinline" + (item.poster ? ' poster="' + item.poster + '"' : "") + ' uk-video="' + this.videoAutoplay + '"></video>');
|
|
attr(video, "src", source);
|
|
on(video, "error", function() {
|
|
return this$1.setError(item);
|
|
});
|
|
on(video, "loadedmetadata", function() {
|
|
attr(video, {
|
|
width: video.videoWidth,
|
|
height: video.videoHeight
|
|
});
|
|
this$1.setItem(item, video);
|
|
});
|
|
} else if (type === "iframe" || source.match(/\.(html|php)($|\?)/i)) {
|
|
this.setItem(item, '<iframe class="uk-lightbox-iframe" src="' + source + '" frameborder="0" allowfullscreen></iframe>');
|
|
} else if (matches$$1 = source.match(/\/\/.*?youtube(-nocookie)?\.[a-z]+\/watch\?v=([^&\s]+)/) || source.match(/()youtu\.be\/(.*)/)) {
|
|
var id = matches$$1[2];
|
|
var setIframe = function(width$$1, height$$1) {
|
|
if (width$$1 === void 0) width$$1 = 640;
|
|
if (height$$1 === void 0) height$$1 = 450;
|
|
return this$1.setItem(item, getIframe("https://www.youtube" + (matches$$1[1] || "") + ".com/embed/" + id, width$$1, height$$1, this$1.videoAutoplay));
|
|
};
|
|
getImage("https://img.youtube.com/vi/" + id + "/maxresdefault.jpg").then(function(ref) {
|
|
var width$$1 = ref.width;
|
|
var height$$1 = ref.height;
|
|
if (width$$1 === 120 && height$$1 === 90) {
|
|
getImage("https://img.youtube.com/vi/" + id + "/0.jpg").then(function(ref) {
|
|
var width$$1 = ref.width;
|
|
var height$$1 = ref.height;
|
|
return setIframe(width$$1, height$$1);
|
|
}, setIframe);
|
|
} else {
|
|
setIframe(width$$1, height$$1);
|
|
}
|
|
}, setIframe);
|
|
} else if (matches$$1 = source.match(/(\/\/.*?)vimeo\.[a-z]+\/([0-9]+).*?/)) {
|
|
ajax("https://vimeo.com/api/oembed.json?maxwidth=1920&url=" + encodeURI(source), {
|
|
responseType: "json",
|
|
withCredentials: false
|
|
}).then(function(ref) {
|
|
var ref_response = ref.response;
|
|
var height$$1 = ref_response.height;
|
|
var width$$1 = ref_response.width;
|
|
return this$1.setItem(item, getIframe("https://player.vimeo.com/video/" + matches$$1[2], width$$1, height$$1, this$1.videoAutoplay));
|
|
}, function() {
|
|
return this$1.setError(item);
|
|
});
|
|
}
|
|
}
|
|
} ],
|
|
methods: {
|
|
loadItem: function(index$$1) {
|
|
if (index$$1 === void 0) index$$1 = this.index;
|
|
var item = this.getItem(index$$1);
|
|
if (item.content) {
|
|
return;
|
|
}
|
|
trigger(this.$el, "itemload", [ item ]);
|
|
},
|
|
getItem: function(index$$1) {
|
|
if (index$$1 === void 0) index$$1 = this.index;
|
|
return this.items[index$$1] || {};
|
|
},
|
|
setItem: function(item, content) {
|
|
assign(item, {
|
|
content: content
|
|
});
|
|
var el = html(this.slides[this.items.indexOf(item)], content);
|
|
trigger(this.$el, "itemloaded", [ this, el ]);
|
|
this.$update(el);
|
|
},
|
|
setError: function(item) {
|
|
this.setItem(item, '<span uk-icon="icon: bolt; ratio: 2"></span>');
|
|
},
|
|
showControls: function() {
|
|
clearTimeout(this.controlsTimer);
|
|
this.controlsTimer = setTimeout(this.hideControls, this.delayControls);
|
|
addClass(this.$el, "uk-active", "uk-transition-active");
|
|
},
|
|
hideControls: function() {
|
|
removeClass(this.$el, "uk-active", "uk-transition-active");
|
|
}
|
|
}
|
|
};
|
|
function getIframe(src, width$$1, height$$1, autoplay) {
|
|
return '<iframe src="' + src + '" width="' + width$$1 + '" height="' + height$$1 + '" style="max-width: 100%; box-sizing: border-box;" frameborder="0" allowfullscreen uk-video="autoplay: ' + autoplay + '" uk-responsive></iframe>';
|
|
}
|
|
var Lightbox = {
|
|
install: install$2,
|
|
props: {
|
|
toggle: String
|
|
},
|
|
data: {
|
|
toggle: "a"
|
|
},
|
|
computed: {
|
|
toggles: function(ref, $el) {
|
|
var toggle = ref.toggle;
|
|
return $$(toggle, $el);
|
|
}
|
|
},
|
|
disconnected: function() {
|
|
this._destroy();
|
|
},
|
|
events: [ {
|
|
name: "click",
|
|
delegate: function() {
|
|
return this.toggle + ":not(.uk-disabled)";
|
|
},
|
|
handler: function(e) {
|
|
e.preventDefault();
|
|
e.current.blur();
|
|
this.show(index(this.toggles, e.current));
|
|
}
|
|
} ],
|
|
update: function(data$$1) {
|
|
data$$1.toggles = this.panel && data$$1.toggles || this.toggles;
|
|
if (!this.panel || isEqualList$1(data$$1.toggles, this.toggles)) {
|
|
return;
|
|
}
|
|
data$$1.toggles = this.toggles;
|
|
this._destroy();
|
|
this._init();
|
|
},
|
|
methods: {
|
|
_init: function() {
|
|
return this.panel = this.panel || this.$create("lightboxPanel", assign({}, this.$props, {
|
|
items: this.toggles.reduce(function(items, el) {
|
|
items.push([ "href", "caption", "type", "poster", "alt" ].reduce(function(obj, attr$$1) {
|
|
obj[attr$$1 === "href" ? "source" : attr$$1] = data(el, attr$$1);
|
|
return obj;
|
|
}, {}));
|
|
return items;
|
|
}, [])
|
|
}));
|
|
},
|
|
_destroy: function() {
|
|
if (this.panel) {
|
|
this.panel.$destroy(true);
|
|
this.panel = null;
|
|
}
|
|
},
|
|
show: function(index$$1) {
|
|
if (!this.panel) {
|
|
this._init();
|
|
}
|
|
return this.panel.show(index$$1);
|
|
},
|
|
hide: function() {
|
|
return this.panel && this.panel.hide();
|
|
}
|
|
}
|
|
};
|
|
function isEqualList$1(listA, listB) {
|
|
return listA.length === listB.length && listA.every(function(el, i) {
|
|
return el === listB[i];
|
|
});
|
|
}
|
|
function install$2(UIkit, Lightbox) {
|
|
if (!UIkit.lightboxPanel) {
|
|
UIkit.component("lightboxPanel", LightboxPanel);
|
|
}
|
|
assign(Lightbox.props, UIkit.component("lightboxPanel").options.props);
|
|
}
|
|
var obj;
|
|
var containers = {};
|
|
var Notification = {
|
|
functional: true,
|
|
args: [ "message", "status" ],
|
|
data: {
|
|
message: "",
|
|
status: "",
|
|
timeout: 5e3,
|
|
group: null,
|
|
pos: "top-center",
|
|
clsClose: "uk-notification-close",
|
|
clsMsg: "uk-notification-message"
|
|
},
|
|
install: install$3,
|
|
created: function() {
|
|
if (!containers[this.pos]) {
|
|
containers[this.pos] = append(this.$container, '<div class="uk-notification uk-notification-' + this.pos + '"></div>');
|
|
}
|
|
var container = css(containers[this.pos], "display", "block");
|
|
this.$mount(append(container, '<div class="' + this.clsMsg + (this.status ? " " + this.clsMsg + "-" + this.status : "") + '"> <a href="#" class="' + this.clsClose + '" data-uk-close></a> <div>' + this.message + "</div> </div>"));
|
|
},
|
|
connected: function() {
|
|
var this$1 = this;
|
|
var marginBottom = toFloat(css(this.$el, "marginBottom"));
|
|
Transition.start(css(this.$el, {
|
|
opacity: 0,
|
|
marginTop: -this.$el.offsetHeight,
|
|
marginBottom: 0
|
|
}), {
|
|
opacity: 1,
|
|
marginTop: 0,
|
|
marginBottom: marginBottom
|
|
}).then(function() {
|
|
if (this$1.timeout) {
|
|
this$1.timer = setTimeout(this$1.close, this$1.timeout);
|
|
}
|
|
});
|
|
},
|
|
events: (obj = {
|
|
click: function(e) {
|
|
if (closest(e.target, 'a[href="#"]')) {
|
|
e.preventDefault();
|
|
}
|
|
this.close();
|
|
}
|
|
}, obj[pointerEnter] = function() {
|
|
if (this.timer) {
|
|
clearTimeout(this.timer);
|
|
}
|
|
}, obj[pointerLeave] = function() {
|
|
if (this.timeout) {
|
|
this.timer = setTimeout(this.close, this.timeout);
|
|
}
|
|
}, obj),
|
|
methods: {
|
|
close: function(immediate) {
|
|
var this$1 = this;
|
|
var removeFn = function() {
|
|
trigger(this$1.$el, "close", [ this$1 ]);
|
|
remove(this$1.$el);
|
|
if (!containers[this$1.pos].children.length) {
|
|
css(containers[this$1.pos], "display", "none");
|
|
}
|
|
};
|
|
if (this.timer) {
|
|
clearTimeout(this.timer);
|
|
}
|
|
if (immediate) {
|
|
removeFn();
|
|
} else {
|
|
Transition.start(this.$el, {
|
|
opacity: 0,
|
|
marginTop: -this.$el.offsetHeight,
|
|
marginBottom: 0
|
|
}).then(removeFn);
|
|
}
|
|
}
|
|
}
|
|
};
|
|
function install$3(UIkit) {
|
|
UIkit.notification.closeAll = function(group, immediate) {
|
|
apply(document.body, function(el) {
|
|
var notification = UIkit.getComponent(el, "notification");
|
|
if (notification && (!group || group === notification.group)) {
|
|
notification.close(immediate);
|
|
}
|
|
});
|
|
};
|
|
}
|
|
var props = [ "x", "y", "bgx", "bgy", "rotate", "scale", "color", "backgroundColor", "borderColor", "opacity", "blur", "hue", "grayscale", "invert", "saturate", "sepia", "fopacity" ];
|
|
var Parallax = {
|
|
mixins: [ Media ],
|
|
props: props.reduce(function(props, prop) {
|
|
props[prop] = "list";
|
|
return props;
|
|
}, {}),
|
|
data: props.reduce(function(data$$1, prop) {
|
|
data$$1[prop] = undefined;
|
|
return data$$1;
|
|
}, {}),
|
|
computed: {
|
|
props: function(properties, $el) {
|
|
var this$1 = this;
|
|
return props.reduce(function(props, prop) {
|
|
if (isUndefined(properties[prop])) {
|
|
return props;
|
|
}
|
|
var isColor = prop.match(/color/i);
|
|
var isCssProp = isColor || prop === "opacity";
|
|
var pos, bgPos, diff;
|
|
var steps = properties[prop].slice(0);
|
|
if (isCssProp) {
|
|
css($el, prop, "");
|
|
}
|
|
if (steps.length < 2) {
|
|
steps.unshift((prop === "scale" ? 1 : isCssProp ? css($el, prop) : 0) || 0);
|
|
}
|
|
var unit = includes(steps.join(""), "%") ? "%" : "px";
|
|
if (isColor) {
|
|
var ref = $el.style;
|
|
var color = ref.color;
|
|
steps = steps.map(function(step) {
|
|
return parseColor($el, step);
|
|
});
|
|
$el.style.color = color;
|
|
} else {
|
|
steps = steps.map(toFloat);
|
|
}
|
|
if (prop.match(/^bg/)) {
|
|
css($el, "background-position-" + prop[2], "");
|
|
bgPos = css($el, "backgroundPosition").split(" ")[prop[2] === "x" ? 0 : 1];
|
|
if (this$1.covers) {
|
|
var min = Math.min.apply(Math, steps);
|
|
var max = Math.max.apply(Math, steps);
|
|
var down = steps.indexOf(min) < steps.indexOf(max);
|
|
diff = max - min;
|
|
steps = steps.map(function(step) {
|
|
return step - (down ? min : max);
|
|
});
|
|
pos = (down ? -diff : 0) + "px";
|
|
} else {
|
|
pos = bgPos;
|
|
}
|
|
}
|
|
props[prop] = {
|
|
steps: steps,
|
|
unit: unit,
|
|
pos: pos,
|
|
bgPos: bgPos,
|
|
diff: diff
|
|
};
|
|
return props;
|
|
}, {});
|
|
},
|
|
bgProps: function() {
|
|
var this$1 = this;
|
|
return [ "bgx", "bgy" ].filter(function(bg) {
|
|
return bg in this$1.props;
|
|
});
|
|
},
|
|
covers: function(_, $el) {
|
|
return covers($el);
|
|
}
|
|
},
|
|
disconnected: function() {
|
|
delete this._image;
|
|
},
|
|
update: {
|
|
read: function(data$$1) {
|
|
var this$1 = this;
|
|
data$$1.active = this.matchMedia;
|
|
data$$1.dimEl = {
|
|
width: this.$el.offsetWidth,
|
|
height: this.$el.offsetHeight
|
|
};
|
|
if ("image" in data$$1 || !this.covers || !this.bgProps.length) {
|
|
return;
|
|
}
|
|
var src = css(this.$el, "backgroundImage").replace(/^none|url\(["']?(.+?)["']?\)$/, "$1");
|
|
if (!src) {
|
|
return;
|
|
}
|
|
var img = new Image();
|
|
img.src = src;
|
|
data$$1.image = img;
|
|
if (!img.naturalWidth) {
|
|
img.onload = function() {
|
|
return this$1.$emit();
|
|
};
|
|
}
|
|
},
|
|
write: function(ref) {
|
|
var this$1 = this;
|
|
var dimEl = ref.dimEl;
|
|
var image = ref.image;
|
|
var active = ref.active;
|
|
if (!image || !image.naturalWidth) {
|
|
return;
|
|
}
|
|
if (!active) {
|
|
css(this.$el, {
|
|
backgroundSize: "",
|
|
backgroundRepeat: ""
|
|
});
|
|
return;
|
|
}
|
|
var imageDim = {
|
|
width: image.naturalWidth,
|
|
height: image.naturalHeight
|
|
};
|
|
var dim = Dimensions.cover(imageDim, dimEl);
|
|
this.bgProps.forEach(function(prop) {
|
|
var ref = this$1.props[prop];
|
|
var diff = ref.diff;
|
|
var bgPos = ref.bgPos;
|
|
var steps = ref.steps;
|
|
var attr$$1 = prop === "bgy" ? "height" : "width";
|
|
var span = dim[attr$$1] - dimEl[attr$$1];
|
|
if (!bgPos.match(/%$|0px/)) {
|
|
return;
|
|
}
|
|
if (span < diff) {
|
|
dimEl[attr$$1] = dim[attr$$1] + diff - span;
|
|
} else if (span > diff) {
|
|
var bgPosFloat = parseFloat(bgPos);
|
|
if (bgPosFloat) {
|
|
this$1.props[prop].steps = steps.map(function(step) {
|
|
return step - (span - diff) / (100 / bgPosFloat);
|
|
});
|
|
}
|
|
}
|
|
dim = Dimensions.cover(imageDim, dimEl);
|
|
});
|
|
css(this.$el, {
|
|
backgroundSize: dim.width + "px " + dim.height + "px",
|
|
backgroundRepeat: "no-repeat"
|
|
});
|
|
},
|
|
events: [ "load", "resize" ]
|
|
},
|
|
methods: {
|
|
reset: function() {
|
|
var this$1 = this;
|
|
each(this.getCss(0), function(_, prop) {
|
|
return css(this$1.$el, prop, "");
|
|
});
|
|
},
|
|
getCss: function(percent) {
|
|
var ref = this;
|
|
var props = ref.props;
|
|
var translated = false;
|
|
return Object.keys(props).reduce(function(css$$1, prop) {
|
|
var ref = props[prop];
|
|
var steps = ref.steps;
|
|
var unit = ref.unit;
|
|
var pos = ref.pos;
|
|
var value = getValue(steps, percent);
|
|
switch (prop) {
|
|
case "x":
|
|
case "y":
|
|
if (translated) {
|
|
break;
|
|
}
|
|
var ref$1 = [ "x", "y" ].map(function(dir) {
|
|
return prop === dir ? toFloat(value).toFixed(0) + unit : props[dir] ? getValue(props[dir].steps, percent, 0) + props[dir].unit : 0;
|
|
});
|
|
var x = ref$1[0];
|
|
var y = ref$1[1];
|
|
translated = css$$1.transform += " translate3d(" + x + ", " + y + ", 0)";
|
|
break;
|
|
|
|
case "rotate":
|
|
css$$1.transform += " rotate(" + value + "deg)";
|
|
break;
|
|
|
|
case "scale":
|
|
css$$1.transform += " scale(" + value + ")";
|
|
break;
|
|
|
|
case "bgy":
|
|
case "bgx":
|
|
css$$1["background-position-" + prop[2]] = "calc(" + pos + " + " + (value + unit) + ")";
|
|
break;
|
|
|
|
case "color":
|
|
case "backgroundColor":
|
|
case "borderColor":
|
|
var ref$2 = getStep(steps, percent);
|
|
var start = ref$2[0];
|
|
var end = ref$2[1];
|
|
var p = ref$2[2];
|
|
css$$1[prop] = "rgba(" + start.map(function(value, i) {
|
|
value = value + p * (end[i] - value);
|
|
return i === 3 ? toFloat(value) : parseInt(value, 10);
|
|
}).join(",") + ")";
|
|
break;
|
|
|
|
case "blur":
|
|
css$$1.filter += " blur(" + value + "px)";
|
|
break;
|
|
|
|
case "hue":
|
|
css$$1.filter += " hue-rotate(" + value + "deg)";
|
|
break;
|
|
|
|
case "fopacity":
|
|
css$$1.filter += " opacity(" + value + "%)";
|
|
break;
|
|
|
|
case "grayscale":
|
|
case "invert":
|
|
case "saturate":
|
|
case "sepia":
|
|
css$$1.filter += " " + prop + "(" + value + "%)";
|
|
break;
|
|
|
|
default:
|
|
css$$1[prop] = value;
|
|
}
|
|
return css$$1;
|
|
}, {
|
|
transform: "",
|
|
filter: ""
|
|
});
|
|
}
|
|
}
|
|
};
|
|
function parseColor(el, color) {
|
|
return css(css(el, "color", color), "color").split(/[(),]/g).slice(1, -1).concat(1).slice(0, 4).map(function(n) {
|
|
return toFloat(n);
|
|
});
|
|
}
|
|
function getStep(steps, percent) {
|
|
var count = steps.length - 1;
|
|
var index$$1 = Math.min(Math.floor(count * percent), count - 1);
|
|
var step = steps.slice(index$$1, index$$1 + 2);
|
|
step.push(percent === 1 ? 1 : percent % (1 / count) * count);
|
|
return step;
|
|
}
|
|
function getValue(steps, percent, digits) {
|
|
if (digits === void 0) digits = 2;
|
|
var ref = getStep(steps, percent);
|
|
var start = ref[0];
|
|
var end = ref[1];
|
|
var p = ref[2];
|
|
return (isNumber(start) ? start + Math.abs(start - end) * p * (start < end ? 1 : -1) : +end).toFixed(digits);
|
|
}
|
|
function covers(el) {
|
|
var ref = el.style;
|
|
var backgroundSize = ref.backgroundSize;
|
|
var covers = css(css(el, "backgroundSize", ""), "backgroundSize") === "cover";
|
|
el.style.backgroundSize = backgroundSize;
|
|
return covers;
|
|
}
|
|
var Parallax$1 = {
|
|
mixins: [ Parallax ],
|
|
props: {
|
|
target: String,
|
|
viewport: Number,
|
|
easing: Number
|
|
},
|
|
data: {
|
|
target: false,
|
|
viewport: 1,
|
|
easing: 1
|
|
},
|
|
computed: {
|
|
target: function(ref, $el) {
|
|
var target = ref.target;
|
|
return target && query(target, $el) || $el;
|
|
}
|
|
},
|
|
update: {
|
|
read: function(ref, ref$1) {
|
|
var percent = ref.percent;
|
|
var active = ref.active;
|
|
var type = ref$1.type;
|
|
if (type !== "scroll") {
|
|
percent = false;
|
|
}
|
|
if (!active) {
|
|
return;
|
|
}
|
|
var prev = percent;
|
|
percent = ease$1(scrolledOver(this.target) / (this.viewport || 1), this.easing);
|
|
return {
|
|
percent: percent,
|
|
style: prev !== percent ? this.getCss(percent) : false
|
|
};
|
|
},
|
|
write: function(ref) {
|
|
var style = ref.style;
|
|
var active = ref.active;
|
|
if (!active) {
|
|
this.reset();
|
|
return;
|
|
}
|
|
style && css(this.$el, style);
|
|
},
|
|
events: [ "scroll", "load", "resize" ]
|
|
}
|
|
};
|
|
function ease$1(percent, easing) {
|
|
return clamp(percent * (1 - (easing - easing * percent)));
|
|
}
|
|
var SliderReactive = {
|
|
update: {
|
|
write: function() {
|
|
if (this.stack.length || this.dragging) {
|
|
return;
|
|
}
|
|
var index$$1 = this.getValidIndex();
|
|
delete this.index;
|
|
removeClass(this.slides, this.clsActive, this.clsActivated);
|
|
this.show(index$$1);
|
|
},
|
|
events: [ "load", "resize" ]
|
|
}
|
|
};
|
|
function Transitioner$1(prev, next, dir, ref) {
|
|
var center = ref.center;
|
|
var easing = ref.easing;
|
|
var list = ref.list;
|
|
var deferred = new Deferred();
|
|
var from = prev ? getLeft(prev, list, center) : getLeft(next, list, center) + bounds(next).width * dir;
|
|
var to = next ? getLeft(next, list, center) : from + bounds(prev).width * dir * (isRtl ? -1 : 1);
|
|
return {
|
|
dir: dir,
|
|
show: function(duration, percent, linear) {
|
|
if (percent === void 0) percent = 0;
|
|
var timing = linear ? "linear" : easing;
|
|
duration -= Math.round(duration * clamp(percent, -1, 1));
|
|
this.translate(percent);
|
|
prev && this.updateTranslates();
|
|
percent = prev ? percent : clamp(percent, 0, 1);
|
|
triggerUpdate$1(this.getItemIn(), "itemin", {
|
|
percent: percent,
|
|
duration: duration,
|
|
timing: timing,
|
|
dir: dir
|
|
});
|
|
prev && triggerUpdate$1(this.getItemIn(true), "itemout", {
|
|
percent: 1 - percent,
|
|
duration: duration,
|
|
timing: timing,
|
|
dir: dir
|
|
});
|
|
Transition.start(list, {
|
|
transform: translate(-to * (isRtl ? -1 : 1), "px")
|
|
}, duration, timing).then(deferred.resolve, noop);
|
|
return deferred.promise;
|
|
},
|
|
stop: function() {
|
|
return Transition.stop(list);
|
|
},
|
|
cancel: function() {
|
|
Transition.cancel(list);
|
|
},
|
|
reset: function() {
|
|
css(list, "transform", "");
|
|
},
|
|
forward: function(duration, percent) {
|
|
if (percent === void 0) percent = this.percent();
|
|
Transition.cancel(list);
|
|
return this.show(duration, percent, true);
|
|
},
|
|
translate: function(percent) {
|
|
var distance = this.getDistance() * dir * (isRtl ? -1 : 1);
|
|
css(list, "transform", translate(clamp(-to + (distance - distance * percent), -getWidth(list), bounds(list).width) * (isRtl ? -1 : 1), "px"));
|
|
this.updateTranslates();
|
|
if (prev) {
|
|
percent = clamp(percent, -1, 1);
|
|
triggerUpdate$1(this.getItemIn(), "itemtranslatein", {
|
|
percent: percent,
|
|
dir: dir
|
|
});
|
|
triggerUpdate$1(this.getItemIn(true), "itemtranslateout", {
|
|
percent: 1 - percent,
|
|
dir: dir
|
|
});
|
|
}
|
|
},
|
|
percent: function() {
|
|
return Math.abs((css(list, "transform").split(",")[4] * (isRtl ? -1 : 1) + from) / (to - from));
|
|
},
|
|
getDistance: function() {
|
|
return Math.abs(to - from);
|
|
},
|
|
getItemIn: function(out) {
|
|
if (out === void 0) out = false;
|
|
var actives = this.getActives();
|
|
var all = sortBy(slides(list), "offsetLeft");
|
|
var i = index(all, actives[dir * (out ? -1 : 1) > 0 ? actives.length - 1 : 0]);
|
|
return ~i && all[i + (prev && !out ? dir : 0)];
|
|
},
|
|
getActives: function() {
|
|
var left = getLeft(prev || next, list, center);
|
|
return sortBy(slides(list).filter(function(slide) {
|
|
var slideLeft = getElLeft(slide, list);
|
|
return slideLeft >= left && slideLeft + bounds(slide).width <= bounds(list).width + left;
|
|
}), "offsetLeft");
|
|
},
|
|
updateTranslates: function() {
|
|
var actives = this.getActives();
|
|
slides(list).forEach(function(slide) {
|
|
var isActive = includes(actives, slide);
|
|
triggerUpdate$1(slide, "itemtranslate" + (isActive ? "in" : "out"), {
|
|
percent: isActive ? 1 : 0,
|
|
dir: slide.offsetLeft <= next.offsetLeft ? 1 : -1
|
|
});
|
|
});
|
|
}
|
|
};
|
|
}
|
|
function getLeft(el, list, center) {
|
|
var left = getElLeft(el, list);
|
|
return center ? left - centerEl(el, list) : Math.min(left, getMax(list));
|
|
}
|
|
function getMax(list) {
|
|
return Math.max(0, getWidth(list) - bounds(list).width);
|
|
}
|
|
function getWidth(list) {
|
|
return slides(list).reduce(function(right, el) {
|
|
return bounds(el).width + right;
|
|
}, 0);
|
|
}
|
|
function getMaxWidth(list) {
|
|
return slides(list).reduce(function(right, el) {
|
|
return Math.max(right, bounds(el).width);
|
|
}, 0);
|
|
}
|
|
function centerEl(el, list) {
|
|
return bounds(list).width / 2 - bounds(el).width / 2;
|
|
}
|
|
function getElLeft(el, list) {
|
|
return (position(el).left + (isRtl ? bounds(el).width - bounds(list).width : 0)) * (isRtl ? -1 : 1);
|
|
}
|
|
function bounds(el) {
|
|
return el.getBoundingClientRect();
|
|
}
|
|
function triggerUpdate$1(el, type, data$$1) {
|
|
trigger(el, createEvent(type, false, false, data$$1));
|
|
}
|
|
function slides(list) {
|
|
return toNodes(list.children);
|
|
}
|
|
var Slider$1 = {
|
|
mixins: [ Class, Slider, SliderReactive ],
|
|
props: {
|
|
center: Boolean,
|
|
sets: Boolean
|
|
},
|
|
data: {
|
|
center: false,
|
|
sets: false,
|
|
attrItem: "uk-slider-item",
|
|
selList: ".uk-slider-items",
|
|
selNav: ".uk-slider-nav",
|
|
clsContainer: "uk-slider-container",
|
|
Transitioner: Transitioner$1
|
|
},
|
|
computed: {
|
|
avgWidth: function() {
|
|
return getWidth(this.list) / this.length;
|
|
},
|
|
finite: function(ref) {
|
|
var finite = ref.finite;
|
|
return finite || getWidth(this.list) < bounds(this.list).width + getMaxWidth(this.list) + this.center;
|
|
},
|
|
maxIndex: function() {
|
|
var this$1 = this;
|
|
if (!this.finite || this.center && !this.sets) {
|
|
return this.length - 1;
|
|
}
|
|
if (this.center) {
|
|
return this.sets[this.sets.length - 1];
|
|
}
|
|
css(this.slides, "order", "");
|
|
var max = getMax(this.list);
|
|
var i = this.length;
|
|
while (i--) {
|
|
if (getElLeft(this$1.list.children[i], this$1.list) < max) {
|
|
return Math.min(i + 1, this$1.length - 1);
|
|
}
|
|
}
|
|
return 0;
|
|
},
|
|
sets: function(ref) {
|
|
var this$1 = this;
|
|
var sets = ref.sets;
|
|
var width$$1 = bounds(this.list).width / (this.center ? 2 : 1);
|
|
var left = 0;
|
|
var leftCenter = width$$1;
|
|
var slideLeft = 0;
|
|
sets = sets && this.slides.reduce(function(sets, slide, i) {
|
|
var ref = bounds(slide);
|
|
var slideWidth = ref.width;
|
|
var slideRight = slideLeft + slideWidth;
|
|
if (slideRight > left) {
|
|
if (!this$1.center && i > this$1.maxIndex) {
|
|
i = this$1.maxIndex;
|
|
}
|
|
if (!includes(sets, i)) {
|
|
var cmp = this$1.slides[i + 1];
|
|
if (this$1.center && cmp && slideWidth < leftCenter - bounds(cmp).width / 2) {
|
|
leftCenter -= slideWidth;
|
|
} else {
|
|
leftCenter = width$$1;
|
|
sets.push(i);
|
|
left = slideLeft + width$$1 + (this$1.center ? slideWidth / 2 : 0);
|
|
}
|
|
}
|
|
}
|
|
slideLeft += slideWidth;
|
|
return sets;
|
|
}, []);
|
|
return sets && sets.length && sets;
|
|
},
|
|
transitionOptions: function() {
|
|
return {
|
|
center: this.center,
|
|
list: this.list
|
|
};
|
|
}
|
|
},
|
|
connected: function() {
|
|
toggleClass(this.$el, this.clsContainer, !$("." + this.clsContainer, this.$el));
|
|
},
|
|
update: {
|
|
write: function() {
|
|
var this$1 = this;
|
|
$$("[" + this.attrItem + "],[data-" + this.attrItem + "]", this.$el).forEach(function(el) {
|
|
var index$$1 = data(el, this$1.attrItem);
|
|
this$1.maxIndex && toggleClass(el, "uk-hidden", isNumeric(index$$1) && (this$1.sets && !includes(this$1.sets, toFloat(index$$1)) || index$$1 > this$1.maxIndex));
|
|
});
|
|
},
|
|
events: [ "load", "resize" ]
|
|
},
|
|
events: {
|
|
beforeitemshow: function(e) {
|
|
var this$1 = this;
|
|
if (!this.dragging && this.sets && this.stack.length < 2 && !includes(this.sets, this.index)) {
|
|
this.index = this.getValidIndex();
|
|
}
|
|
var diff = Math.abs(this.index - this.prevIndex + (this.dir > 0 && this.index < this.prevIndex || this.dir < 0 && this.index > this.prevIndex ? (this.maxIndex + 1) * this.dir : 0));
|
|
if (!this.dragging && diff > 1) {
|
|
for (var i = 0; i < diff; i++) {
|
|
this$1.stack.splice(1, 0, this$1.dir > 0 ? "next" : "previous");
|
|
}
|
|
e.preventDefault();
|
|
return;
|
|
}
|
|
this.duration = speedUp(this.avgWidth / this.velocity) * (bounds(this.dir < 0 || !this.slides[this.prevIndex] ? this.slides[this.index] : this.slides[this.prevIndex]).width / this.avgWidth);
|
|
this.reorder();
|
|
},
|
|
itemshow: function() {
|
|
!isUndefined(this.prevIndex) && addClass(this._getTransitioner().getItemIn(), this.clsActive);
|
|
},
|
|
itemshown: function() {
|
|
var this$1 = this;
|
|
var actives = this._getTransitioner(this.index).getActives();
|
|
this.slides.forEach(function(slide) {
|
|
return toggleClass(slide, this$1.clsActive, includes(actives, slide));
|
|
});
|
|
(!this.sets || includes(this.sets, toFloat(this.index))) && this.slides.forEach(function(slide) {
|
|
return toggleClass(slide, this$1.clsActivated, includes(actives, slide));
|
|
});
|
|
}
|
|
},
|
|
methods: {
|
|
reorder: function() {
|
|
var this$1 = this;
|
|
css(this.slides, "order", "");
|
|
if (this.finite) {
|
|
return;
|
|
}
|
|
var index$$1 = this.dir > 0 && this.slides[this.prevIndex] ? this.prevIndex : this.index;
|
|
this.slides.forEach(function(slide, i) {
|
|
return css(slide, "order", this$1.dir > 0 && i < index$$1 ? 1 : this$1.dir < 0 && i >= this$1.index ? -1 : "");
|
|
});
|
|
if (!this.center) {
|
|
return;
|
|
}
|
|
var next = this.slides[index$$1];
|
|
var width$$1 = bounds(this.list).width / 2 - bounds(next).width / 2;
|
|
var j = 0;
|
|
while (width$$1 > 0) {
|
|
var slideIndex = this$1.getIndex(--j + index$$1, index$$1);
|
|
var slide = this$1.slides[slideIndex];
|
|
css(slide, "order", slideIndex > index$$1 ? -2 : -1);
|
|
width$$1 -= bounds(slide).width;
|
|
}
|
|
},
|
|
getValidIndex: function(index$$1, prevIndex) {
|
|
var this$1 = this;
|
|
if (index$$1 === void 0) index$$1 = this.index;
|
|
if (prevIndex === void 0) prevIndex = this.prevIndex;
|
|
index$$1 = this.getIndex(index$$1, prevIndex);
|
|
if (!this.sets) {
|
|
return index$$1;
|
|
}
|
|
var prev;
|
|
do {
|
|
if (includes(this$1.sets, index$$1)) {
|
|
return index$$1;
|
|
}
|
|
prev = index$$1;
|
|
index$$1 = this$1.getIndex(index$$1 + this$1.dir, prevIndex);
|
|
} while (index$$1 !== prev);
|
|
return index$$1;
|
|
}
|
|
}
|
|
};
|
|
var SliderParallax = {
|
|
mixins: [ Parallax ],
|
|
data: {
|
|
selItem: "!li"
|
|
},
|
|
computed: {
|
|
item: function(ref, $el) {
|
|
var selItem = ref.selItem;
|
|
return query(selItem, $el);
|
|
}
|
|
},
|
|
events: [ {
|
|
name: "itemshown",
|
|
self: true,
|
|
el: function() {
|
|
return this.item;
|
|
},
|
|
handler: function() {
|
|
css(this.$el, this.getCss(.5));
|
|
}
|
|
}, {
|
|
name: "itemin itemout",
|
|
self: true,
|
|
el: function() {
|
|
return this.item;
|
|
},
|
|
handler: function(ref) {
|
|
var type = ref.type;
|
|
var ref_detail = ref.detail;
|
|
var percent = ref_detail.percent;
|
|
var duration = ref_detail.duration;
|
|
var timing = ref_detail.timing;
|
|
var dir = ref_detail.dir;
|
|
Transition.cancel(this.$el);
|
|
css(this.$el, this.getCss(getCurrent(type, dir, percent)));
|
|
Transition.start(this.$el, this.getCss(isIn(type) ? .5 : dir > 0 ? 1 : 0), duration, timing).catch(noop);
|
|
}
|
|
}, {
|
|
name: "transitioncanceled transitionend",
|
|
self: true,
|
|
el: function() {
|
|
return this.item;
|
|
},
|
|
handler: function() {
|
|
Transition.cancel(this.$el);
|
|
}
|
|
}, {
|
|
name: "itemtranslatein itemtranslateout",
|
|
self: true,
|
|
el: function() {
|
|
return this.item;
|
|
},
|
|
handler: function(ref) {
|
|
var type = ref.type;
|
|
var ref_detail = ref.detail;
|
|
var percent = ref_detail.percent;
|
|
var dir = ref_detail.dir;
|
|
Transition.cancel(this.$el);
|
|
css(this.$el, this.getCss(getCurrent(type, dir, percent)));
|
|
}
|
|
} ]
|
|
};
|
|
function isIn(type) {
|
|
return endsWith(type, "in");
|
|
}
|
|
function getCurrent(type, dir, percent) {
|
|
percent /= 2;
|
|
return !isIn(type) ? dir < 0 ? percent : 1 - percent : dir < 0 ? 1 - percent : percent;
|
|
}
|
|
var Animations$2 = assign({}, Animations, {
|
|
fade: {
|
|
show: function() {
|
|
return [ {
|
|
opacity: 0,
|
|
zIndex: 0
|
|
}, {
|
|
zIndex: -1
|
|
} ];
|
|
},
|
|
percent: function(current) {
|
|
return 1 - css(current, "opacity");
|
|
},
|
|
translate: function(percent) {
|
|
return [ {
|
|
opacity: 1 - percent,
|
|
zIndex: 0
|
|
}, {
|
|
zIndex: -1
|
|
} ];
|
|
}
|
|
},
|
|
scale: {
|
|
show: function() {
|
|
return [ {
|
|
opacity: 0,
|
|
transform: scale3d(1 + .5),
|
|
zIndex: 0
|
|
}, {
|
|
zIndex: -1
|
|
} ];
|
|
},
|
|
percent: function(current) {
|
|
return 1 - css(current, "opacity");
|
|
},
|
|
translate: function(percent) {
|
|
return [ {
|
|
opacity: 1 - percent,
|
|
transform: scale3d(1 + .5 * percent),
|
|
zIndex: 0
|
|
}, {
|
|
zIndex: -1
|
|
} ];
|
|
}
|
|
},
|
|
pull: {
|
|
show: function(dir) {
|
|
return dir < 0 ? [ {
|
|
transform: translate(30),
|
|
zIndex: -1
|
|
}, {
|
|
transform: translate(),
|
|
zIndex: 0
|
|
} ] : [ {
|
|
transform: translate(-100),
|
|
zIndex: 0
|
|
}, {
|
|
transform: translate(),
|
|
zIndex: -1
|
|
} ];
|
|
},
|
|
percent: function(current, next, dir) {
|
|
return dir < 0 ? 1 - translated(next) : translated(current);
|
|
},
|
|
translate: function(percent, dir) {
|
|
return dir < 0 ? [ {
|
|
transform: translate(30 * percent),
|
|
zIndex: -1
|
|
}, {
|
|
transform: translate(-100 * (1 - percent)),
|
|
zIndex: 0
|
|
} ] : [ {
|
|
transform: translate(-percent * 100),
|
|
zIndex: 0
|
|
}, {
|
|
transform: translate(30 * (1 - percent)),
|
|
zIndex: -1
|
|
} ];
|
|
}
|
|
},
|
|
push: {
|
|
show: function(dir) {
|
|
return dir < 0 ? [ {
|
|
transform: translate(100),
|
|
zIndex: 0
|
|
}, {
|
|
transform: translate(),
|
|
zIndex: -1
|
|
} ] : [ {
|
|
transform: translate(-30),
|
|
zIndex: -1
|
|
}, {
|
|
transform: translate(),
|
|
zIndex: 0
|
|
} ];
|
|
},
|
|
percent: function(current, next, dir) {
|
|
return dir > 0 ? 1 - translated(next) : translated(current);
|
|
},
|
|
translate: function(percent, dir) {
|
|
return dir < 0 ? [ {
|
|
transform: translate(percent * 100),
|
|
zIndex: 0
|
|
}, {
|
|
transform: translate(-30 * (1 - percent)),
|
|
zIndex: -1
|
|
} ] : [ {
|
|
transform: translate(-30 * percent),
|
|
zIndex: -1
|
|
}, {
|
|
transform: translate(100 * (1 - percent)),
|
|
zIndex: 0
|
|
} ];
|
|
}
|
|
}
|
|
});
|
|
var Slideshow$1 = {
|
|
mixins: [ Class, Slideshow, SliderReactive ],
|
|
props: {
|
|
ratio: String,
|
|
minHeight: Boolean,
|
|
maxHeight: Boolean
|
|
},
|
|
data: {
|
|
ratio: "16:9",
|
|
minHeight: false,
|
|
maxHeight: false,
|
|
selList: ".uk-slideshow-items",
|
|
attrItem: "uk-slideshow-item",
|
|
selNav: ".uk-slideshow-nav",
|
|
Animations: Animations$2
|
|
},
|
|
update: {
|
|
read: function() {
|
|
var ref = this.ratio.split(":").map(Number);
|
|
var width$$1 = ref[0];
|
|
var height$$1 = ref[1];
|
|
height$$1 = height$$1 * this.list.offsetWidth / width$$1;
|
|
if (this.minHeight) {
|
|
height$$1 = Math.max(this.minHeight, height$$1);
|
|
}
|
|
if (this.maxHeight) {
|
|
height$$1 = Math.min(this.maxHeight, height$$1);
|
|
}
|
|
return {
|
|
height: height$$1 - boxModelAdjust(this.list, "content-box")
|
|
};
|
|
},
|
|
write: function(ref) {
|
|
var height$$1 = ref.height;
|
|
css(this.list, "minHeight", height$$1);
|
|
},
|
|
events: [ "load", "resize" ]
|
|
}
|
|
};
|
|
var obj$1;
|
|
var Sortable = {
|
|
mixins: [ Class, Animate ],
|
|
props: {
|
|
group: String,
|
|
threshold: Number,
|
|
clsItem: String,
|
|
clsPlaceholder: String,
|
|
clsDrag: String,
|
|
clsDragState: String,
|
|
clsBase: String,
|
|
clsNoDrag: String,
|
|
clsEmpty: String,
|
|
clsCustom: String,
|
|
handle: String
|
|
},
|
|
data: {
|
|
group: false,
|
|
threshold: 5,
|
|
clsItem: "uk-sortable-item",
|
|
clsPlaceholder: "uk-sortable-placeholder",
|
|
clsDrag: "uk-sortable-drag",
|
|
clsDragState: "uk-drag",
|
|
clsBase: "uk-sortable",
|
|
clsNoDrag: "uk-sortable-nodrag",
|
|
clsEmpty: "uk-sortable-empty",
|
|
clsCustom: "",
|
|
handle: false
|
|
},
|
|
created: function() {
|
|
var this$1 = this;
|
|
[ "init", "start", "move", "end" ].forEach(function(key) {
|
|
var fn = this$1[key];
|
|
this$1[key] = function(e) {
|
|
this$1.scrollY = window.pageYOffset;
|
|
var ref = getPos$1(e);
|
|
var x = ref.x;
|
|
var y = ref.y;
|
|
this$1.pos = {
|
|
x: x,
|
|
y: y
|
|
};
|
|
fn(e);
|
|
};
|
|
});
|
|
},
|
|
events: (obj$1 = {}, obj$1[pointerDown] = "init", obj$1),
|
|
update: {
|
|
write: function() {
|
|
if (this.clsEmpty) {
|
|
toggleClass(this.$el, this.clsEmpty, !this.$el.children.length);
|
|
}
|
|
css(this.handle ? $$(this.handle, this.$el) : this.$el.children, "touchAction", "none");
|
|
if (!this.drag) {
|
|
return;
|
|
}
|
|
offset(this.drag, {
|
|
top: this.pos.y + this.origin.top,
|
|
left: this.pos.x + this.origin.left
|
|
});
|
|
var ref = offset(this.drag);
|
|
var top = ref.top;
|
|
var bottom = top + this.drag.offsetHeight;
|
|
var scroll;
|
|
if (top > 0 && top < this.scrollY) {
|
|
scroll = this.scrollY - 5;
|
|
} else if (bottom < height(document) && bottom > height(window) + this.scrollY) {
|
|
scroll = this.scrollY + 5;
|
|
}
|
|
scroll && setTimeout(function() {
|
|
return scrollTop(window, scroll);
|
|
}, 5);
|
|
}
|
|
},
|
|
methods: {
|
|
init: function(e) {
|
|
var target = e.target;
|
|
var button = e.button;
|
|
var defaultPrevented = e.defaultPrevented;
|
|
var ref = toNodes(this.$el.children).filter(function(el) {
|
|
return within(target, el);
|
|
});
|
|
var placeholder = ref[0];
|
|
if (!placeholder || isInput(e.target) || this.handle && !within(target, this.handle) || button > 0 || within(target, "." + this.clsNoDrag) || defaultPrevented) {
|
|
return;
|
|
}
|
|
e.preventDefault();
|
|
this.touched = [ this ];
|
|
this.placeholder = placeholder;
|
|
this.origin = assign({
|
|
target: target,
|
|
index: index(placeholder)
|
|
}, this.pos);
|
|
on(document, pointerMove, this.move);
|
|
on(document, pointerUp, this.end);
|
|
on(window, "scroll", this.scroll);
|
|
if (!this.threshold) {
|
|
this.start(e);
|
|
}
|
|
},
|
|
start: function(e) {
|
|
this.drag = append(this.$container, this.placeholder.outerHTML.replace(/^<li/i, "<div").replace(/li>$/i, "div>"));
|
|
css(this.drag, assign({
|
|
boxSizing: "border-box",
|
|
width: this.placeholder.offsetWidth,
|
|
height: this.placeholder.offsetHeight
|
|
}, css(this.placeholder, [ "paddingLeft", "paddingRight", "paddingTop", "paddingBottom" ])));
|
|
attr(this.drag, "uk-no-boot", "");
|
|
addClass(this.drag, this.clsDrag, this.clsCustom);
|
|
height(this.drag.firstElementChild, height(this.placeholder.firstElementChild));
|
|
var ref = offset(this.placeholder);
|
|
var left = ref.left;
|
|
var top = ref.top;
|
|
assign(this.origin, {
|
|
left: left - this.pos.x,
|
|
top: top - this.pos.y
|
|
});
|
|
addClass(this.placeholder, this.clsPlaceholder);
|
|
addClass(this.$el.children, this.clsItem);
|
|
addClass(document.documentElement, this.clsDragState);
|
|
trigger(this.$el, "start", [ this, this.placeholder ]);
|
|
this.move(e);
|
|
},
|
|
move: function(e) {
|
|
if (!this.drag) {
|
|
if (Math.abs(this.pos.x - this.origin.x) > this.threshold || Math.abs(this.pos.y - this.origin.y) > this.threshold) {
|
|
this.start(e);
|
|
}
|
|
return;
|
|
}
|
|
this.$emit();
|
|
var target = e.type === "mousemove" ? e.target : document.elementFromPoint(this.pos.x - document.body.scrollLeft, this.pos.y - document.body.scrollTop);
|
|
var sortable = this.getSortable(target);
|
|
var previous = this.getSortable(this.placeholder);
|
|
var move = sortable !== previous;
|
|
if (!sortable || within(target, this.placeholder) || move && (!sortable.group || sortable.group !== previous.group)) {
|
|
return;
|
|
}
|
|
target = sortable.$el === target.parentNode && target || toNodes(sortable.$el.children).filter(function(element) {
|
|
return within(target, element);
|
|
})[0];
|
|
if (move) {
|
|
previous.remove(this.placeholder);
|
|
} else if (!target) {
|
|
return;
|
|
}
|
|
sortable.insert(this.placeholder, target);
|
|
if (!includes(this.touched, sortable)) {
|
|
this.touched.push(sortable);
|
|
}
|
|
},
|
|
scroll: function() {
|
|
var scroll = window.pageYOffset;
|
|
if (scroll !== this.scrollY) {
|
|
this.pos.y += scroll - this.scrollY;
|
|
this.scrollY = scroll;
|
|
this.$emit();
|
|
}
|
|
},
|
|
end: function(e) {
|
|
off(document, pointerMove, this.move);
|
|
off(document, pointerUp, this.end);
|
|
off(window, "scroll", this.scroll);
|
|
if (!this.drag) {
|
|
if (e.type !== "mouseup" && within(e.target, "a[href]")) {
|
|
location.href = closest(e.target, "a[href]").href;
|
|
}
|
|
return;
|
|
}
|
|
preventClick();
|
|
var sortable = this.getSortable(this.placeholder);
|
|
if (this === sortable) {
|
|
if (this.origin.index !== index(this.placeholder)) {
|
|
trigger(this.$el, "moved", [ this, this.placeholder ]);
|
|
}
|
|
} else {
|
|
trigger(sortable.$el, "added", [ sortable, this.placeholder ]);
|
|
trigger(this.$el, "removed", [ this, this.placeholder ]);
|
|
}
|
|
trigger(this.$el, "stop", [ this, this.placeholder ]);
|
|
remove(this.drag);
|
|
this.drag = null;
|
|
var classes = this.touched.map(function(sortable) {
|
|
return sortable.clsPlaceholder + " " + sortable.clsItem;
|
|
}).join(" ");
|
|
this.touched.forEach(function(sortable) {
|
|
return removeClass(sortable.$el.children, classes);
|
|
});
|
|
removeClass(document.documentElement, this.clsDragState);
|
|
},
|
|
insert: function(element, target) {
|
|
var this$1 = this;
|
|
addClass(this.$el.children, this.clsItem);
|
|
var insert = function() {
|
|
if (target) {
|
|
if (!within(element, this$1.$el) || isPredecessor(element, target)) {
|
|
before(target, element);
|
|
} else {
|
|
after(target, element);
|
|
}
|
|
} else {
|
|
append(this$1.$el, element);
|
|
}
|
|
};
|
|
if (this.animation) {
|
|
this.animate(insert);
|
|
} else {
|
|
insert();
|
|
}
|
|
},
|
|
remove: function(element) {
|
|
if (!within(element, this.$el)) {
|
|
return;
|
|
}
|
|
if (this.animation) {
|
|
this.animate(function() {
|
|
return remove(element);
|
|
});
|
|
} else {
|
|
remove(element);
|
|
}
|
|
},
|
|
getSortable: function(element) {
|
|
return element && (this.$getComponent(element, "sortable") || this.getSortable(element.parentNode));
|
|
}
|
|
}
|
|
};
|
|
function isPredecessor(element, target) {
|
|
return element.parentNode === target.parentNode && index(element) > index(target);
|
|
}
|
|
var obj$2;
|
|
var actives = [];
|
|
var Tooltip = {
|
|
mixins: [ Container, Togglable, Position ],
|
|
args: "title",
|
|
props: {
|
|
delay: Number,
|
|
title: String
|
|
},
|
|
data: {
|
|
pos: "top",
|
|
title: "",
|
|
delay: 0,
|
|
animation: [ "uk-animation-scale-up" ],
|
|
duration: 100,
|
|
cls: "uk-active",
|
|
clsPos: "uk-tooltip"
|
|
},
|
|
beforeConnect: function() {
|
|
this._hasTitle = hasAttr(this.$el, "title");
|
|
attr(this.$el, {
|
|
title: "",
|
|
"aria-expanded": false
|
|
});
|
|
},
|
|
disconnected: function() {
|
|
this.hide();
|
|
attr(this.$el, {
|
|
title: this._hasTitle ? this.title : null,
|
|
"aria-expanded": null
|
|
});
|
|
},
|
|
methods: {
|
|
show: function() {
|
|
var this$1 = this;
|
|
if (includes(actives, this)) {
|
|
return;
|
|
}
|
|
actives.forEach(function(active) {
|
|
return active.hide();
|
|
});
|
|
actives.push(this);
|
|
this._unbind = on(document, "click", function(e) {
|
|
return !within(e.target, this$1.$el) && this$1.hide();
|
|
});
|
|
clearTimeout(this.showTimer);
|
|
this.showTimer = setTimeout(function() {
|
|
this$1._show();
|
|
this$1.hideTimer = setInterval(function() {
|
|
if (!isVisible(this$1.$el)) {
|
|
this$1.hide();
|
|
}
|
|
}, 150);
|
|
}, this.delay);
|
|
},
|
|
hide: function() {
|
|
var index$$1 = actives.indexOf(this);
|
|
if (!~index$$1 || matches(this.$el, "input") && this.$el === document.activeElement) {
|
|
return;
|
|
}
|
|
actives.splice(index$$1, 1);
|
|
clearTimeout(this.showTimer);
|
|
clearInterval(this.hideTimer);
|
|
attr(this.$el, "aria-expanded", false);
|
|
this.toggleElement(this.tooltip, false);
|
|
this.tooltip && remove(this.tooltip);
|
|
this.tooltip = false;
|
|
this._unbind();
|
|
},
|
|
_show: function() {
|
|
this.tooltip = append(this.container, '<div class="' + this.clsPos + '" aria-expanded="true" aria-hidden> <div class="' + this.clsPos + '-inner">' + this.title + "</div> </div>");
|
|
this.positionAt(this.tooltip, this.$el);
|
|
this.origin = this.getAxis() === "y" ? flipPosition(this.dir) + "-" + this.align : this.align + "-" + flipPosition(this.dir);
|
|
this.toggleElement(this.tooltip, true);
|
|
}
|
|
},
|
|
events: (obj$2 = {}, obj$2["focus " + pointerEnter + " " + pointerDown] = function(e) {
|
|
if (e.type !== pointerDown || !isTouch(e)) {
|
|
this.show();
|
|
}
|
|
}, obj$2.blur = "hide", obj$2[pointerLeave] = function(e) {
|
|
if (!isTouch(e)) {
|
|
this.hide();
|
|
}
|
|
}, obj$2)
|
|
};
|
|
var Upload = {
|
|
props: {
|
|
allow: String,
|
|
clsDragover: String,
|
|
concurrent: Number,
|
|
maxSize: Number,
|
|
method: String,
|
|
mime: String,
|
|
msgInvalidMime: String,
|
|
msgInvalidName: String,
|
|
msgInvalidSize: String,
|
|
multiple: Boolean,
|
|
name: String,
|
|
params: Object,
|
|
type: String,
|
|
url: String
|
|
},
|
|
data: {
|
|
allow: false,
|
|
clsDragover: "uk-dragover",
|
|
concurrent: 1,
|
|
maxSize: 0,
|
|
method: "POST",
|
|
mime: false,
|
|
msgInvalidMime: "Invalid File Type: %s",
|
|
msgInvalidName: "Invalid File Name: %s",
|
|
msgInvalidSize: "Invalid File Size: %s Kilobytes Max",
|
|
multiple: false,
|
|
name: "files[]",
|
|
params: {},
|
|
type: "",
|
|
url: "",
|
|
abort: noop,
|
|
beforeAll: noop,
|
|
beforeSend: noop,
|
|
complete: noop,
|
|
completeAll: noop,
|
|
error: noop,
|
|
fail: noop,
|
|
load: noop,
|
|
loadEnd: noop,
|
|
loadStart: noop,
|
|
progress: noop
|
|
},
|
|
events: {
|
|
change: function(e) {
|
|
if (!matches(e.target, 'input[type="file"]')) {
|
|
return;
|
|
}
|
|
e.preventDefault();
|
|
if (e.target.files) {
|
|
this.upload(e.target.files);
|
|
}
|
|
e.target.value = "";
|
|
},
|
|
drop: function(e) {
|
|
stop(e);
|
|
var transfer = e.dataTransfer;
|
|
if (!transfer || !transfer.files) {
|
|
return;
|
|
}
|
|
removeClass(this.$el, this.clsDragover);
|
|
this.upload(transfer.files);
|
|
},
|
|
dragenter: function(e) {
|
|
stop(e);
|
|
},
|
|
dragover: function(e) {
|
|
stop(e);
|
|
addClass(this.$el, this.clsDragover);
|
|
},
|
|
dragleave: function(e) {
|
|
stop(e);
|
|
removeClass(this.$el, this.clsDragover);
|
|
}
|
|
},
|
|
methods: {
|
|
upload: function(files) {
|
|
var this$1 = this;
|
|
if (!files.length) {
|
|
return;
|
|
}
|
|
trigger(this.$el, "upload", [ files ]);
|
|
for (var i = 0; i < files.length; i++) {
|
|
if (this$1.maxSize && this$1.maxSize * 1e3 < files[i].size) {
|
|
this$1.fail(this$1.msgInvalidSize.replace("%s", this$1.maxSize));
|
|
return;
|
|
}
|
|
if (this$1.allow && !match$1(this$1.allow, files[i].name)) {
|
|
this$1.fail(this$1.msgInvalidName.replace("%s", this$1.allow));
|
|
return;
|
|
}
|
|
if (this$1.mime && !match$1(this$1.mime, files[i].type)) {
|
|
this$1.fail(this$1.msgInvalidMime.replace("%s", this$1.mime));
|
|
return;
|
|
}
|
|
}
|
|
if (!this.multiple) {
|
|
files = [ files[0] ];
|
|
}
|
|
this.beforeAll(this, files);
|
|
var chunks = chunk(files, this.concurrent);
|
|
var upload = function(files) {
|
|
var data$$1 = new FormData();
|
|
files.forEach(function(file) {
|
|
return data$$1.append(this$1.name, file);
|
|
});
|
|
for (var key in this$1.params) {
|
|
data$$1.append(key, this$1.params[key]);
|
|
}
|
|
ajax(this$1.url, {
|
|
data: data$$1,
|
|
method: this$1.method,
|
|
responseType: this$1.type,
|
|
beforeSend: function(env) {
|
|
var xhr = env.xhr;
|
|
xhr.upload && on(xhr.upload, "progress", this$1.progress);
|
|
[ "loadStart", "load", "loadEnd", "abort" ].forEach(function(type) {
|
|
return on(xhr, type.toLowerCase(), this$1[type]);
|
|
});
|
|
this$1.beforeSend(env);
|
|
}
|
|
}).then(function(xhr) {
|
|
this$1.complete(xhr);
|
|
if (chunks.length) {
|
|
upload(chunks.shift());
|
|
} else {
|
|
this$1.completeAll(xhr);
|
|
}
|
|
}, function(e) {
|
|
return this$1.error(e);
|
|
});
|
|
};
|
|
upload(chunks.shift());
|
|
}
|
|
}
|
|
};
|
|
function match$1(pattern, path) {
|
|
return path.match(new RegExp("^" + pattern.replace(/\//g, "\\/").replace(/\*\*/g, "(\\/[^\\/]+)*").replace(/\*/g, "[^\\/]+").replace(/((?!\\))\?/g, "$1.") + "$", "i"));
|
|
}
|
|
function chunk(files, size) {
|
|
var chunks = [];
|
|
for (var i = 0; i < files.length; i += size) {
|
|
var chunk = [];
|
|
for (var j = 0; j < size; j++) {
|
|
chunk.push(files[i + j]);
|
|
}
|
|
chunks.push(chunk);
|
|
}
|
|
return chunks;
|
|
}
|
|
function stop(e) {
|
|
e.preventDefault();
|
|
e.stopPropagation();
|
|
}
|
|
UIkit.component("countdown", Countdown);
|
|
UIkit.component("filter", Filter);
|
|
UIkit.component("lightbox", Lightbox);
|
|
UIkit.component("lightboxPanel", LightboxPanel);
|
|
UIkit.component("notification", Notification);
|
|
UIkit.component("parallax", Parallax$1);
|
|
UIkit.component("slider", Slider$1);
|
|
UIkit.component("sliderParallax", SliderParallax);
|
|
UIkit.component("slideshow", Slideshow$1);
|
|
UIkit.component("slideshowParallax", SliderParallax);
|
|
UIkit.component("sortable", Sortable);
|
|
UIkit.component("tooltip", Tooltip);
|
|
UIkit.component("upload", Upload);
|
|
{
|
|
boot(UIkit);
|
|
}
|
|
return UIkit;
|
|
});
|
|
|
|
(function(global, factory) {
|
|
typeof exports === "object" && typeof module !== "undefined" ? module.exports = factory() : typeof define === "function" && define.amd ? define("uikiticons", factory) : global.UIkitIcons = factory();
|
|
})(this, function() {
|
|
"use strict";
|
|
function plugin(UIkit) {
|
|
if (plugin.installed) {
|
|
return;
|
|
}
|
|
UIkit.icon.add({
|
|
"500px": '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M9.624,11.866c-0.141,0.132,0.479,0.658,0.662,0.418c0.051-0.046,0.607-0.61,0.662-0.664c0,0,0.738,0.719,0.814,0.719\t\tc0.1,0,0.207-0.055,0.322-0.17c0.27-0.269,0.135-0.416,0.066-0.495l-0.631-0.616l0.658-0.668c0.146-0.156,0.021-0.314-0.1-0.449\t\tc-0.182-0.18-0.359-0.226-0.471-0.125l-0.656,0.654l-0.654-0.654c-0.033-0.034-0.08-0.045-0.124-0.045\t\tc-0.079,0-0.191,0.068-0.307,0.181c-0.202,0.202-0.247,0.351-0.133,0.462l0.665,0.665L9.624,11.866z" /> <path d="M11.066,2.884c-1.061,0-2.185,0.248-3.011,0.604c-0.087,0.034-0.141,0.106-0.15,0.205C7.893,3.784,7.919,3.909,7.982,4.066\t\tc0.05,0.136,0.187,0.474,0.452,0.372c0.844-0.326,1.779-0.507,2.633-0.507c0.963,0,1.9,0.191,2.781,0.564\t\tc0.695,0.292,1.357,0.719,2.078,1.34c0.051,0.044,0.105,0.068,0.164,0.068c0.143,0,0.273-0.137,0.389-0.271\t\tc0.191-0.214,0.324-0.395,0.135-0.575c-0.686-0.654-1.436-1.138-2.363-1.533C13.24,3.097,12.168,2.884,11.066,2.884z" /> <path d="M16.43,15.747c-0.092-0.028-0.242,0.05-0.309,0.119l0,0c-0.652,0.652-1.42,1.169-2.268,1.521\t\tc-0.877,0.371-1.814,0.551-2.779,0.551c-0.961,0-1.896-0.189-2.775-0.564c-0.848-0.36-1.612-0.879-2.268-1.53\t\tc-0.682-0.688-1.196-1.455-1.529-2.268c-0.325-0.799-0.471-1.643-0.471-1.643c-0.045-0.24-0.258-0.249-0.567-0.203\t\tc-0.128,0.021-0.519,0.079-0.483,0.36v0.01c0.105,0.644,0.289,1.284,0.545,1.895c0.417,0.969,1.002,1.849,1.756,2.604\t\tc0.757,0.754,1.636,1.34,2.604,1.757C8.901,18.785,9.97,19,11.088,19c1.104,0,2.186-0.215,3.188-0.645\t\tc1.838-0.896,2.604-1.757,2.604-1.757c0.182-0.204,0.227-0.317-0.1-0.643C16.779,15.956,16.525,15.774,16.43,15.747z" /> <path d="M5.633,13.287c0.293,0.71,0.723,1.341,1.262,1.882c0.54,0.54,1.172,0.971,1.882,1.264c0.731,0.303,1.509,0.461,2.298,0.461\t\tc0.801,0,1.578-0.158,2.297-0.461c0.711-0.293,1.344-0.724,1.883-1.264c0.543-0.541,0.971-1.172,1.264-1.882\t\tc0.314-0.721,0.463-1.5,0.463-2.298c0-0.79-0.148-1.569-0.463-2.289c-0.293-0.699-0.721-1.329-1.264-1.881\t\tc-0.539-0.541-1.172-0.959-1.867-1.263c-0.721-0.303-1.5-0.461-2.299-0.461c-0.802,0-1.613,0.159-2.322,0.461\t\tc-0.577,0.25-1.544,0.867-2.119,1.454v0.012V2.108h8.16C15.1,2.104,15.1,1.69,15.1,1.552C15.1,1.417,15.1,1,14.809,1H5.915\t\tC5.676,1,5.527,1.192,5.527,1.384v6.84c0,0.214,0.273,0.372,0.529,0.428c0.5,0.105,0.614-0.056,0.737-0.224l0,0\t\tc0.18-0.273,0.776-0.884,0.787-0.894c0.901-0.905,2.117-1.408,3.416-1.408c1.285,0,2.5,0.501,3.412,1.408\t\tc0.914,0.914,1.408,2.122,1.408,3.405c0,1.288-0.508,2.496-1.408,3.405c-0.9,0.896-2.152,1.406-3.438,1.406\t\tc-0.877,0-1.711-0.229-2.433-0.671v-4.158c0-0.553,0.237-1.151,0.643-1.614c0.462-0.519,1.094-0.799,1.782-0.799\t\tc0.664,0,1.293,0.253,1.758,0.715c0.459,0.459,0.709,1.071,0.709,1.723c0,1.385-1.094,2.468-2.488,2.468\t\tc-0.273,0-0.769-0.121-0.781-0.125c-0.281-0.087-0.405,0.306-0.438,0.436c-0.159,0.496,0.079,0.585,0.123,0.607\t\tc0.452,0.137,0.743,0.157,1.129,0.157c1.973,0,3.572-1.6,3.572-3.57c0-1.964-1.6-3.552-3.572-3.552c-0.97,0-1.872,0.36-2.546,1.038\t\tc-0.656,0.631-1.027,1.487-1.027,2.322v3.438v-0.011c-0.372-0.42-0.732-1.041-0.981-1.682c-0.102-0.248-0.315-0.202-0.607-0.113\t\tc-0.135,0.035-0.519,0.157-0.44,0.439C5.372,12.799,5.577,13.164,5.633,13.287z" /></svg>',
|
|
album: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <rect x="5" y="2" width="10" height="1" /> <rect x="3" y="4" width="14" height="1" /> <rect fill="none" stroke="#000" x="1.5" y="6.5" width="17" height="11" /></svg>',
|
|
"arrow-down": '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polygon points="10.5,16.08 5.63,10.66 6.37,10 10.5,14.58 14.63,10 15.37,10.66" /> <line fill="none" stroke="#000" x1="10.5" y1="4" x2="10.5" y2="15" /></svg>',
|
|
"arrow-left": '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polyline fill="none" stroke="#000" points="10 14 5 9.5 10 5" /> <line fill="none" stroke="#000" x1="16" y1="9.5" x2="5" y2="9.52" /></svg>',
|
|
"arrow-right": '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polyline fill="none" stroke="#000" points="10 5 15 9.5 10 14" /> <line fill="none" stroke="#000" x1="4" y1="9.5" x2="15" y2="9.5" /></svg>',
|
|
"arrow-up": '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polygon points="10.5,4 15.37,9.4 14.63,10.08 10.5,5.49 6.37,10.08 5.63,9.4" /> <line fill="none" stroke="#000" x1="10.5" y1="16" x2="10.5" y2="5" /></svg>',
|
|
ban: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <circle fill="none" stroke="#000" stroke-width="1.1" cx="10" cy="10" r="9" /> <line fill="none" stroke="#000" stroke-width="1.1" x1="4" y1="3.5" x2="16" y2="16.5" /></svg>',
|
|
behance: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M9.5,10.6c-0.4-0.5-0.9-0.9-1.6-1.1c1.7-1,2.2-3.2,0.7-4.7C7.8,4,6.3,4,5.2,4C3.5,4,1.7,4,0,4v12c1.7,0,3.4,0,5.2,0 c1,0,2.1,0,3.1-0.5C10.2,14.6,10.5,12.3,9.5,10.6L9.5,10.6z M5.6,6.1c1.8,0,1.8,2.7-0.1,2.7c-1,0-2,0-2.9,0V6.1H5.6z M2.6,13.8v-3.1 c1.1,0,2.1,0,3.2,0c2.1,0,2.1,3.2,0.1,3.2L2.6,13.8z" /> <path d="M19.9,10.9C19.7,9.2,18.7,7.6,17,7c-4.2-1.3-7.3,3.4-5.3,7.1c0.9,1.7,2.8,2.3,4.7,2.1c1.7-0.2,2.9-1.3,3.4-2.9h-2.2 c-0.4,1.3-2.4,1.5-3.5,0.6c-0.4-0.4-0.6-1.1-0.6-1.7H20C20,11.7,19.9,10.9,19.9,10.9z M13.5,10.6c0-1.6,2.3-2.7,3.5-1.4 c0.4,0.4,0.5,0.9,0.6,1.4H13.5L13.5,10.6z" /> <rect x="13" y="4" width="5" height="1.4" /></svg>',
|
|
bell: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path fill="none" stroke="#000" stroke-width="1.1" d="M17,15.5 L3,15.5 C2.99,14.61 3.79,13.34 4.1,12.51 C4.58,11.3 4.72,10.35 5.19,7.01 C5.54,4.53 5.89,3.2 7.28,2.16 C8.13,1.56 9.37,1.5 9.81,1.5 L9.96,1.5 C9.96,1.5 11.62,1.41 12.67,2.17 C14.08,3.2 14.42,4.54 14.77,7.02 C15.26,10.35 15.4,11.31 15.87,12.52 C16.2,13.34 17.01,14.61 17,15.5 L17,15.5 Z" /> <path fill="none" stroke="#000" d="M12.39,16 C12.39,17.37 11.35,18.43 9.91,18.43 C8.48,18.43 7.42,17.37 7.42,16" /></svg>',
|
|
bold: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M5,15.3 C5.66,15.3 5.9,15 5.9,14.53 L5.9,5.5 C5.9,4.92 5.56,4.7 5,4.7 L5,4 L8.95,4 C12.6,4 13.7,5.37 13.7,6.9 C13.7,7.87 13.14,9.17 10.86,9.59 L10.86,9.7 C13.25,9.86 14.29,11.28 14.3,12.54 C14.3,14.47 12.94,16 9,16 L5,16 L5,15.3 Z M9,9.3 C11.19,9.3 11.8,8.5 11.85,7 C11.85,5.65 11.3,4.8 9,4.8 L7.67,4.8 L7.67,9.3 L9,9.3 Z M9.185,15.22 C11.97,15 12.39,14 12.4,12.58 C12.4,11.15 11.39,10 9,10 L7.67,10 L7.67,15 L9.18,15 Z" /></svg>',
|
|
bolt: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M4.74,20 L7.73,12 L3,12 L15.43,1 L12.32,9 L17.02,9 L4.74,20 L4.74,20 L4.74,20 Z M9.18,11 L7.1,16.39 L14.47,10 L10.86,10 L12.99,4.67 L5.61,11 L9.18,11 L9.18,11 L9.18,11 Z" /></svg>',
|
|
bookmark: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polygon fill="none" stroke="#000" points="5.5 1.5 15.5 1.5 15.5 17.5 10.5 12.5 5.5 17.5" /></svg>',
|
|
calendar: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M 2,3 2,17 18,17 18,3 2,3 Z M 17,16 3,16 3,8 17,8 17,16 Z M 17,7 3,7 3,4 17,4 17,7 Z" /> <rect width="1" height="3" x="6" y="2" /> <rect width="1" height="3" x="13" y="2" /></svg>',
|
|
camera: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <circle fill="none" stroke="#000" stroke-width="1.1" cx="10" cy="10.8" r="3.8" /> <path fill="none" stroke="#000" d="M1,4.5 C0.7,4.5 0.5,4.7 0.5,5 L0.5,17 C0.5,17.3 0.7,17.5 1,17.5 L19,17.5 C19.3,17.5 19.5,17.3 19.5,17 L19.5,5 C19.5,4.7 19.3,4.5 19,4.5 L13.5,4.5 L13.5,2.9 C13.5,2.6 13.3,2.5 13,2.5 L7,2.5 C6.7,2.5 6.5,2.6 6.5,2.9 L6.5,4.5 L1,4.5 L1,4.5 Z" /></svg>',
|
|
cart: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <circle cx="7.3" cy="17.3" r="1.4" /> <circle cx="13.3" cy="17.3" r="1.4" /> <polyline fill="none" stroke="#000" points="0 2 3.2 4 5.3 12.5 16 12.5 18 6.5 8 6.5" /></svg>',
|
|
check: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polyline fill="none" stroke="#000" stroke-width="1.1" points="4,10 8,15 17,4" /></svg>',
|
|
"chevron-down": '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polyline fill="none" stroke="#000" stroke-width="1.03" points="16 7 10 13 4 7" /></svg>',
|
|
"chevron-left": '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polyline fill="none" stroke="#000" stroke-width="1.03" points="13 16 7 10 13 4" /></svg>',
|
|
"chevron-right": '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polyline fill="none" stroke="#000" stroke-width="1.03" points="7 4 13 10 7 16" /></svg>',
|
|
"chevron-up": '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polyline fill="none" stroke="#000" stroke-width="1.03" points="4 13 10 7 16 13" /></svg>',
|
|
clock: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <circle fill="none" stroke="#000" stroke-width="1.1" cx="10" cy="10" r="9" /> <rect x="9" y="4" width="1" height="7" /> <path fill="none" stroke="#000" stroke-width="1.1" d="M13.018,14.197 L9.445,10.625" /></svg>',
|
|
close: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path fill="none" stroke="#000" stroke-width="1.06" d="M16,16 L4,4" /> <path fill="none" stroke="#000" stroke-width="1.06" d="M16,4 L4,16" /></svg>',
|
|
"cloud-download": '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path fill="none" stroke="#000" stroke-width="1.1" d="M6.5,14.61 L3.75,14.61 C1.96,14.61 0.5,13.17 0.5,11.39 C0.5,9.76 1.72,8.41 3.3,8.2 C3.38,5.31 5.75,3 8.68,3 C11.19,3 13.31,4.71 13.89,7.02 C14.39,6.8 14.93,6.68 15.5,6.68 C17.71,6.68 19.5,8.45 19.5,10.64 C19.5,12.83 17.71,14.6 15.5,14.6 L12.5,14.6" /> <polyline fill="none" stroke="#000" points="11.75 16 9.5 18.25 7.25 16" /> <path fill="none" stroke="#000" d="M9.5,18 L9.5,9.5" /></svg>',
|
|
"cloud-upload": '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path fill="none" stroke="#000" stroke-width="1.1" d="M6.5,14.61 L3.75,14.61 C1.96,14.61 0.5,13.17 0.5,11.39 C0.5,9.76 1.72,8.41 3.31,8.2 C3.38,5.31 5.75,3 8.68,3 C11.19,3 13.31,4.71 13.89,7.02 C14.39,6.8 14.93,6.68 15.5,6.68 C17.71,6.68 19.5,8.45 19.5,10.64 C19.5,12.83 17.71,14.6 15.5,14.6 L12.5,14.6" /> <polyline fill="none" stroke="#000" points="7.25 11.75 9.5 9.5 11.75 11.75" /> <path fill="none" stroke="#000" d="M9.5,18 L9.5,9.5" /></svg>',
|
|
code: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polyline fill="none" stroke="#000" stroke-width="1.01" points="13,4 19,10 13,16" /> <polyline fill="none" stroke="#000" stroke-width="1.01" points="7,4 1,10 7,16" /></svg>',
|
|
cog: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <circle fill="none" stroke="#000" cx="9.997" cy="10" r="3.31" /> <path fill="none" stroke="#000" d="M18.488,12.285 L16.205,16.237 C15.322,15.496 14.185,15.281 13.303,15.791 C12.428,16.289 12.047,17.373 12.246,18.5 L7.735,18.5 C7.938,17.374 7.553,16.299 6.684,15.791 C5.801,15.27 4.655,15.492 3.773,16.237 L1.5,12.285 C2.573,11.871 3.317,10.999 3.317,9.991 C3.305,8.98 2.573,8.121 1.5,7.716 L3.765,3.784 C4.645,4.516 5.794,4.738 6.687,4.232 C7.555,3.722 7.939,2.637 7.735,1.5 L12.263,1.5 C12.072,2.637 12.441,3.71 13.314,4.22 C14.206,4.73 15.343,4.516 16.225,3.794 L18.487,7.714 C17.404,8.117 16.661,8.988 16.67,10.009 C16.672,11.018 17.415,11.88 18.488,12.285 L18.488,12.285 Z" /></svg>',
|
|
comment: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M6,18.71 L6,14 L1,14 L1,1 L19,1 L19,14 L10.71,14 L6,18.71 L6,18.71 Z M2,13 L7,13 L7,16.29 L10.29,13 L18,13 L18,2 L2,2 L2,13 L2,13 Z" /></svg>',
|
|
commenting: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polygon fill="none" stroke="#000" points="1.5,1.5 18.5,1.5 18.5,13.5 10.5,13.5 6.5,17.5 6.5,13.5 1.5,13.5" /> <circle cx="10" cy="8" r="1" /> <circle cx="6" cy="8" r="1" /> <circle cx="14" cy="8" r="1" /></svg>',
|
|
comments: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polyline fill="none" stroke="#000" points="2 0.5 19.5 0.5 19.5 13" /> <path d="M5,19.71 L5,15 L0,15 L0,2 L18,2 L18,15 L9.71,15 L5,19.71 L5,19.71 L5,19.71 Z M1,14 L6,14 L6,17.29 L9.29,14 L17,14 L17,3 L1,3 L1,14 L1,14 L1,14 Z" /></svg>',
|
|
copy: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <rect fill="none" stroke="#000" x="3.5" y="2.5" width="12" height="16" /> <polyline fill="none" stroke="#000" points="5 0.5 17.5 0.5 17.5 17" /></svg>',
|
|
"credit-card": '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <rect fill="none" stroke="#000" x="1.5" y="4.5" width="17" height="12" /> <rect x="1" y="7" width="18" height="3" /></svg>',
|
|
database: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <ellipse fill="none" stroke="#000" cx="10" cy="4.64" rx="7.5" ry="3.14" /> <path fill="none" stroke="#000" d="M17.5,8.11 C17.5,9.85 14.14,11.25 10,11.25 C5.86,11.25 2.5,9.84 2.5,8.11" /> <path fill="none" stroke="#000" d="M17.5,11.25 C17.5,12.99 14.14,14.39 10,14.39 C5.86,14.39 2.5,12.98 2.5,11.25" /> <path fill="none" stroke="#000" d="M17.49,4.64 L17.5,14.36 C17.5,16.1 14.14,17.5 10,17.5 C5.86,17.5 2.5,16.09 2.5,14.36 L2.5,4.64" /></svg>',
|
|
desktop: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <rect x="8" y="15" width="1" height="2" /> <rect x="11" y="15" width="1" height="2" /> <rect x="5" y="16" width="10" height="1" /> <rect fill="none" stroke="#000" x="1.5" y="3.5" width="17" height="11" /></svg>',
|
|
download: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polyline fill="none" stroke="#000" points="14,10 9.5,14.5 5,10" /> <rect x="3" y="17" width="13" height="1" /> <line fill="none" stroke="#000" x1="9.5" y1="13.91" x2="9.5" y2="3" /></svg>',
|
|
dribbble: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path fill="none" stroke="#000" stroke-width="1.4" d="M1.3,8.9c0,0,5,0.1,8.6-1c1.4-0.4,2.6-0.9,4-1.9 c1.4-1.1,2.5-2.5,2.5-2.5" /> <path fill="none" stroke="#000" stroke-width="1.4" d="M3.9,16.6c0,0,1.7-2.8,3.5-4.2 c1.8-1.3,4-2,5.7-2.2C16,10,19,10.6,19,10.6" /> <path fill="none" stroke="#000" stroke-width="1.4" d="M6.9,1.6c0,0,3.3,4.6,4.2,6.8 c0.4,0.9,1.3,3.1,1.9,5.2c0.6,2,0.9,4.4,0.9,4.4" /> <circle fill="none" stroke="#000" stroke-width="1.4" cx="10" cy="10" r="9" /></svg>',
|
|
expand: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polygon points="13 2 18 2 18 7 17 7 17 3 13 3" /> <polygon points="2 13 3 13 3 17 7 17 7 18 2 18" /> <path fill="none" stroke="#000" stroke-width="1.1" d="M11,9 L17,3" /> <path fill="none" stroke="#000" stroke-width="1.1" d="M3,17 L9,11" /></svg>',
|
|
facebook: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M11,10h2.6l0.4-3H11V5.3c0-0.9,0.2-1.5,1.5-1.5H14V1.1c-0.3,0-1-0.1-2.1-0.1C9.6,1,8,2.4,8,5v2H5.5v3H8v8h3V10z" /></svg>',
|
|
"file-edit": '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path fill="none" stroke="#000" d="M18.65,1.68 C18.41,1.45 18.109,1.33 17.81,1.33 C17.499,1.33 17.209,1.45 16.98,1.68 L8.92,9.76 L8,12.33 L10.55,11.41 L18.651,3.34 C19.12,2.87 19.12,2.15 18.65,1.68 L18.65,1.68 L18.65,1.68 Z" /> <polyline fill="none" stroke="#000" points="16.5 8.482 16.5 18.5 3.5 18.5 3.5 1.5 14.211 1.5" /></svg>',
|
|
file: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <rect fill="none" stroke="#000" x="3.5" y="1.5" width="13" height="17" /></svg>',
|
|
flickr: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <circle cx="5.5" cy="9.5" r="3.5" /> <circle cx="14.5" cy="9.5" r="3.5" /></svg>',
|
|
folder: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polygon fill="none" stroke="#000" points="9.5 5.5 8.5 3.5 1.5 3.5 1.5 16.5 18.5 16.5 18.5 5.5" /></svg>',
|
|
forward: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M2.47,13.11 C4.02,10.02 6.27,7.85 9.04,6.61 C9.48,6.41 10.27,6.13 11,5.91 L11,2 L18.89,9 L11,16 L11,12.13 C9.25,12.47 7.58,13.19 6.02,14.25 C3.03,16.28 1.63,18.54 1.63,18.54 C1.63,18.54 1.38,15.28 2.47,13.11 L2.47,13.11 Z M5.3,13.53 C6.92,12.4 9.04,11.4 12,10.92 L12,13.63 L17.36,9 L12,4.25 L12,6.8 C11.71,6.86 10.86,7.02 9.67,7.49 C6.79,8.65 4.58,10.96 3.49,13.08 C3.18,13.7 2.68,14.87 2.49,16 C3.28,15.05 4.4,14.15 5.3,13.53 L5.3,13.53 Z" /></svg>',
|
|
foursquare: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M15.23,2 C15.96,2 16.4,2.41 16.5,2.86 C16.57,3.15 16.56,3.44 16.51,3.73 C16.46,4.04 14.86,11.72 14.75,12.03 C14.56,12.56 14.16,12.82 13.61,12.83 C13.03,12.84 11.09,12.51 10.69,13 C10.38,13.38 7.79,16.39 6.81,17.53 C6.61,17.76 6.4,17.96 6.08,17.99 C5.68,18.04 5.29,17.87 5.17,17.45 C5.12,17.28 5.1,17.09 5.1,16.91 C5.1,12.4 4.86,7.81 5.11,3.31 C5.17,2.5 5.81,2.12 6.53,2 L15.23,2 L15.23,2 Z M9.76,11.42 C9.94,11.19 10.17,11.1 10.45,11.1 L12.86,11.1 C13.12,11.1 13.31,10.94 13.36,10.69 C13.37,10.64 13.62,9.41 13.74,8.83 C13.81,8.52 13.53,8.28 13.27,8.28 C12.35,8.29 11.42,8.28 10.5,8.28 C9.84,8.28 9.83,7.69 9.82,7.21 C9.8,6.85 10.13,6.55 10.5,6.55 C11.59,6.56 12.67,6.55 13.76,6.55 C14.03,6.55 14.23,6.4 14.28,6.14 C14.34,5.87 14.67,4.29 14.67,4.29 C14.67,4.29 14.82,3.74 14.19,3.74 L7.34,3.74 C7,3.75 6.84,4.02 6.84,4.33 C6.84,7.58 6.85,14.95 6.85,14.99 C6.87,15 8.89,12.51 9.76,11.42 L9.76,11.42 Z" /></svg>',
|
|
future: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polyline points="19 2 18 2 18 6 14 6 14 7 19 7 19 2" /> <path fill="none" stroke="#000" stroke-width="1.1" d="M18,6.548 C16.709,3.29 13.354,1 9.6,1 C4.6,1 0.6,5 0.6,10 C0.6,15 4.6,19 9.6,19 C14.6,19 18.6,15 18.6,10" /> <rect x="9" y="4" width="1" height="7" /> <path d="M13.018,14.197 L9.445,10.625" fill="none" stroke="#000" stroke-width="1.1" /></svg>',
|
|
"git-branch": '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <circle fill="none" stroke="#000" stroke-width="1.2" cx="7" cy="3" r="2" /> <circle fill="none" stroke="#000" stroke-width="1.2" cx="14" cy="6" r="2" /> <circle fill="none" stroke="#000" stroke-width="1.2" cx="7" cy="17" r="2" /> <path fill="none" stroke="#000" stroke-width="2" d="M14,8 C14,10.41 12.43,10.87 10.56,11.25 C9.09,11.54 7,12.06 7,15 L7,5" /></svg>',
|
|
"git-fork": '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <circle fill="none" stroke="#000" stroke-width="1.2" cx="5.79" cy="2.79" r="1.79" /> <circle fill="none" stroke="#000" stroke-width="1.2" cx="14.19" cy="2.79" r="1.79" /> <ellipse fill="none" stroke="#000" stroke-width="1.2" cx="10.03" cy="16.79" rx="1.79" ry="1.79" /> <path fill="none" stroke="#000" stroke-width="2" d="M5.79,4.57 L5.79,6.56 C5.79,9.19 10.03,10.22 10.03,13.31 C10.03,14.86 10.04,14.55 10.04,14.55 C10.04,14.37 10.04,14.86 10.04,13.31 C10.04,10.22 14.2,9.19 14.2,6.56 L14.2,4.57" /></svg>',
|
|
"github-alt": '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M10,0.5 C4.75,0.5 0.5,4.76 0.5,10.01 C0.5,15.26 4.75,19.51 10,19.51 C15.24,19.51 19.5,15.26 19.5,10.01 C19.5,4.76 15.25,0.5 10,0.5 L10,0.5 Z M12.81,17.69 C12.81,17.69 12.81,17.7 12.79,17.69 C12.47,17.75 12.35,17.59 12.35,17.36 L12.35,16.17 C12.35,15.45 12.09,14.92 11.58,14.56 C12.2,14.51 12.77,14.39 13.26,14.21 C13.87,13.98 14.36,13.69 14.74,13.29 C15.42,12.59 15.76,11.55 15.76,10.17 C15.76,9.25 15.45,8.46 14.83,7.8 C15.1,7.08 15.07,6.29 14.75,5.44 L14.51,5.42 C14.34,5.4 14.06,5.46 13.67,5.61 C13.25,5.78 12.79,6.03 12.31,6.35 C11.55,6.16 10.81,6.05 10.09,6.05 C9.36,6.05 8.61,6.15 7.88,6.35 C7.28,5.96 6.75,5.68 6.26,5.54 C6.07,5.47 5.9,5.44 5.78,5.44 L5.42,5.44 C5.06,6.29 5.04,7.08 5.32,7.8 C4.7,8.46 4.4,9.25 4.4,10.17 C4.4,11.94 4.96,13.16 6.08,13.84 C6.53,14.13 7.05,14.32 7.69,14.43 C8.03,14.5 8.32,14.54 8.55,14.55 C8.07,14.89 7.82,15.42 7.82,16.16 L7.82,17.51 C7.8,17.69 7.7,17.8 7.51,17.8 C4.21,16.74 1.82,13.65 1.82,10.01 C1.82,5.5 5.49,1.83 10,1.83 C14.5,1.83 18.17,5.5 18.17,10.01 C18.18,13.53 15.94,16.54 12.81,17.69 L12.81,17.69 Z" /></svg>',
|
|
github: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M10,1 C5.03,1 1,5.03 1,10 C1,13.98 3.58,17.35 7.16,18.54 C7.61,18.62 7.77,18.34 7.77,18.11 C7.77,17.9 7.76,17.33 7.76,16.58 C5.26,17.12 4.73,15.37 4.73,15.37 C4.32,14.33 3.73,14.05 3.73,14.05 C2.91,13.5 3.79,13.5 3.79,13.5 C4.69,13.56 5.17,14.43 5.17,14.43 C5.97,15.8 7.28,15.41 7.79,15.18 C7.87,14.6 8.1,14.2 8.36,13.98 C6.36,13.75 4.26,12.98 4.26,9.53 C4.26,8.55 4.61,7.74 5.19,7.11 C5.1,6.88 4.79,5.97 5.28,4.73 C5.28,4.73 6.04,4.49 7.75,5.65 C8.47,5.45 9.24,5.35 10,5.35 C10.76,5.35 11.53,5.45 12.25,5.65 C13.97,4.48 14.72,4.73 14.72,4.73 C15.21,5.97 14.9,6.88 14.81,7.11 C15.39,7.74 15.73,8.54 15.73,9.53 C15.73,12.99 13.63,13.75 11.62,13.97 C11.94,14.25 12.23,14.8 12.23,15.64 C12.23,16.84 12.22,17.81 12.22,18.11 C12.22,18.35 12.38,18.63 12.84,18.54 C16.42,17.35 19,13.98 19,10 C19,5.03 14.97,1 10,1 L10,1 Z" /></svg>',
|
|
gitter: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <rect x="3.5" y="1" width="1.531" height="11.471" /> <rect x="7.324" y="4.059" width="1.529" height="15.294" /> <rect x="11.148" y="4.059" width="1.527" height="15.294" /> <rect x="14.971" y="4.059" width="1.529" height="8.412" /></svg>',
|
|
"google-plus": '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M12.9,9c0,2.7-0.6,5-3.2,6.3c-3.7,1.8-8.1,0.2-9.4-3.6C-1.1,7.6,1.9,3.3,6.1,3c1.7-0.1,3.2,0.3,4.6,1.3 c0.1,0.1,0.3,0.2,0.4,0.4c-0.5,0.5-1.2,1-1.7,1.6c-1-0.8-2.1-1.1-3.5-0.9C5,5.6,4.2,6,3.6,6.7c-1.3,1.3-1.5,3.4-0.5,5 c1,1.7,2.6,2.3,4.6,1.9c1.4-0.3,2.4-1.2,2.6-2.6H6.9V9H12.9z" /> <polygon points="20,9 20,11 18,11 18,13 16,13 16,11 14,11 14,9 16,9 16,7 18,7 18,9 " /></svg>',
|
|
google: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M17.86,9.09 C18.46,12.12 17.14,16.05 13.81,17.56 C9.45,19.53 4.13,17.68 2.47,12.87 C0.68,7.68 4.22,2.42 9.5,2.03 C11.57,1.88 13.42,2.37 15.05,3.65 C15.22,3.78 15.37,3.93 15.61,4.14 C14.9,4.81 14.23,5.45 13.5,6.14 C12.27,5.08 10.84,4.72 9.28,4.98 C8.12,5.17 7.16,5.76 6.37,6.63 C4.88,8.27 4.62,10.86 5.76,12.82 C6.95,14.87 9.17,15.8 11.57,15.25 C13.27,14.87 14.76,13.33 14.89,11.75 L10.51,11.75 L10.51,9.09 L17.86,9.09 L17.86,9.09 Z" /></svg>',
|
|
grid: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <rect x="2" y="2" width="3" height="3" /> <rect x="8" y="2" width="3" height="3" /> <rect x="14" y="2" width="3" height="3" /> <rect x="2" y="8" width="3" height="3" /> <rect x="8" y="8" width="3" height="3" /> <rect x="14" y="8" width="3" height="3" /> <rect x="2" y="14" width="3" height="3" /> <rect x="8" y="14" width="3" height="3" /> <rect x="14" y="14" width="3" height="3" /></svg>',
|
|
happy: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <circle cx="13" cy="7" r="1" /> <circle cx="7" cy="7" r="1" /> <circle fill="none" stroke="#000" cx="10" cy="10" r="8.5" /> <path fill="none" stroke="#000" d="M14.6,11.4 C13.9,13.3 12.1,14.5 10,14.5 C7.9,14.5 6.1,13.3 5.4,11.4" /></svg>',
|
|
hashtag: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M15.431,8 L15.661,7 L12.911,7 L13.831,3 L12.901,3 L11.98,7 L9.29,7 L10.21,3 L9.281,3 L8.361,7 L5.23,7 L5,8 L8.13,8 L7.21,12 L4.23,12 L4,13 L6.98,13 L6.061,17 L6.991,17 L7.911,13 L10.601,13 L9.681,17 L10.611,17 L11.531,13 L14.431,13 L14.661,12 L11.76,12 L12.681,8 L15.431,8 Z M10.831,12 L8.141,12 L9.061,8 L11.75,8 L10.831,12 Z" /></svg>',
|
|
heart: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path fill="none" stroke="#000" stroke-width="1.03" d="M10,4 C10,4 8.1,2 5.74,2 C3.38,2 1,3.55 1,6.73 C1,8.84 2.67,10.44 2.67,10.44 L10,18 L17.33,10.44 C17.33,10.44 19,8.84 19,6.73 C19,3.55 16.62,2 14.26,2 C11.9,2 10,4 10,4 L10,4 Z" /></svg>',
|
|
history: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polyline fill="#000" points="1 2 2 2 2 6 6 6 6 7 1 7 1 2" /> <path fill="none" stroke="#000" stroke-width="1.1" d="M2.1,6.548 C3.391,3.29 6.746,1 10.5,1 C15.5,1 19.5,5 19.5,10 C19.5,15 15.5,19 10.5,19 C5.5,19 1.5,15 1.5,10" /> <rect x="9" y="4" width="1" height="7" /> <path fill="none" stroke="#000" stroke-width="1.1" d="M13.018,14.197 L9.445,10.625" id="Shape" /></svg>',
|
|
home: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polygon points="18.65 11.35 10 2.71 1.35 11.35 0.65 10.65 10 1.29 19.35 10.65" /> <polygon points="15 4 18 4 18 7 17 7 17 5 15 5" /> <polygon points="3 11 4 11 4 18 7 18 7 12 12 12 12 18 16 18 16 11 17 11 17 19 11 19 11 13 8 13 8 19 3 19" /></svg>',
|
|
image: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <circle cx="16.1" cy="6.1" r="1.1" /> <rect fill="none" stroke="#000" x="0.5" y="2.5" width="19" height="15" /> <polyline fill="none" stroke="#000" stroke-width="1.01" points="4,13 8,9 13,14" /> <polyline fill="none" stroke="#000" stroke-width="1.01" points="11,12 12.5,10.5 16,14" /></svg>',
|
|
info: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M12.13,11.59 C11.97,12.84 10.35,14.12 9.1,14.16 C6.17,14.2 9.89,9.46 8.74,8.37 C9.3,8.16 10.62,7.83 10.62,8.81 C10.62,9.63 10.12,10.55 9.88,11.32 C8.66,15.16 12.13,11.15 12.14,11.18 C12.16,11.21 12.16,11.35 12.13,11.59 C12.08,11.95 12.16,11.35 12.13,11.59 L12.13,11.59 Z M11.56,5.67 C11.56,6.67 9.36,7.15 9.36,6.03 C9.36,5 11.56,4.54 11.56,5.67 L11.56,5.67 Z" /> <circle fill="none" stroke="#000" stroke-width="1.1" cx="10" cy="10" r="9" /></svg>',
|
|
instagram: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M13.55,1H6.46C3.45,1,1,3.44,1,6.44v7.12c0,3,2.45,5.44,5.46,5.44h7.08c3.02,0,5.46-2.44,5.46-5.44V6.44 C19.01,3.44,16.56,1,13.55,1z M17.5,14c0,1.93-1.57,3.5-3.5,3.5H6c-1.93,0-3.5-1.57-3.5-3.5V6c0-1.93,1.57-3.5,3.5-3.5h8 c1.93,0,3.5,1.57,3.5,3.5V14z" /> <circle cx="14.87" cy="5.26" r="1.09" /> <path d="M10.03,5.45c-2.55,0-4.63,2.06-4.63,4.6c0,2.55,2.07,4.61,4.63,4.61c2.56,0,4.63-2.061,4.63-4.61 C14.65,7.51,12.58,5.45,10.03,5.45L10.03,5.45L10.03,5.45z M10.08,13c-1.66,0-3-1.34-3-2.99c0-1.65,1.34-2.99,3-2.99s3,1.34,3,2.99 C13.08,11.66,11.74,13,10.08,13L10.08,13L10.08,13z" /></svg>',
|
|
italic: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M12.63,5.48 L10.15,14.52 C10,15.08 10.37,15.25 11.92,15.3 L11.72,16 L6,16 L6.2,15.31 C7.78,15.26 8.19,15.09 8.34,14.53 L10.82,5.49 C10.97,4.92 10.63,4.76 9.09,4.71 L9.28,4 L15,4 L14.81,4.69 C13.23,4.75 12.78,4.91 12.63,5.48 L12.63,5.48 Z" /></svg>',
|
|
joomla: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M7.8,13.4l1.7-1.7L5.9,8c-0.6-0.5-0.6-1.5,0-2c0.6-0.6,1.4-0.6,2,0l1.7-1.7c-1-1-2.3-1.3-3.6-1C5.8,2.2,4.8,1.4,3.7,1.4 c-1.3,0-2.3,1-2.3,2.3c0,1.1,0.8,2,1.8,2.3c-0.4,1.3-0.1,2.8,1,3.8L7.8,13.4L7.8,13.4z" /> <path d="M10.2,4.3c1-1,2.5-1.4,3.8-1c0.2-1.1,1.1-2,2.3-2c1.3,0,2.3,1,2.3,2.3c0,1.2-0.9,2.2-2,2.3c0.4,1.3,0,2.8-1,3.8L13.9,8 c0.6-0.5,0.6-1.5,0-2c-0.5-0.6-1.5-0.6-2,0L8.2,9.7L6.5,8" /> <path d="M14.1,16.8c-1.3,0.4-2.8,0.1-3.8-1l1.7-1.7c0.6,0.6,1.5,0.6,2,0c0.5-0.6,0.6-1.5,0-2l-3.7-3.7L12,6.7l3.7,3.7 c1,1,1.3,2.4,1,3.6c1.1,0.2,2,1.1,2,2.3c0,1.3-1,2.3-2.3,2.3C15.2,18.6,14.3,17.8,14.1,16.8" /> <path d="M13.2,12.2l-3.7,3.7c-1,1-2.4,1.3-3.6,1c-0.2,1-1.2,1.8-2.2,1.8c-1.3,0-2.3-1-2.3-2.3c0-1.1,0.8-2,1.8-2.3 c-0.3-1.3,0-2.7,1-3.7l1.7,1.7c-0.6,0.6-0.6,1.5,0,2c0.6,0.6,1.4,0.6,2,0l3.7-3.7" /></svg>',
|
|
laptop: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <rect y="16" width="20" height="1" /> <rect fill="none" stroke="#000" x="2.5" y="4.5" width="15" height="10" /></svg>',
|
|
lifesaver: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M10,0.5 C4.76,0.5 0.5,4.76 0.5,10 C0.5,15.24 4.76,19.5 10,19.5 C15.24,19.5 19.5,15.24 19.5,10 C19.5,4.76 15.24,0.5 10,0.5 L10,0.5 Z M10,1.5 C11.49,1.5 12.89,1.88 14.11,2.56 L11.85,4.82 C11.27,4.61 10.65,4.5 10,4.5 C9.21,4.5 8.47,4.67 7.79,4.96 L5.58,2.75 C6.87,1.95 8.38,1.5 10,1.5 L10,1.5 Z M4.96,7.8 C4.67,8.48 4.5,9.21 4.5,10 C4.5,10.65 4.61,11.27 4.83,11.85 L2.56,14.11 C1.88,12.89 1.5,11.49 1.5,10 C1.5,8.38 1.95,6.87 2.75,5.58 L4.96,7.79 L4.96,7.8 L4.96,7.8 Z M10,18.5 C8.25,18.5 6.62,17.97 5.27,17.06 L7.46,14.87 C8.22,15.27 9.08,15.5 10,15.5 C10.79,15.5 11.53,15.33 12.21,15.04 L14.42,17.25 C13.13,18.05 11.62,18.5 10,18.5 L10,18.5 Z M10,14.5 C7.52,14.5 5.5,12.48 5.5,10 C5.5,7.52 7.52,5.5 10,5.5 C12.48,5.5 14.5,7.52 14.5,10 C14.5,12.48 12.48,14.5 10,14.5 L10,14.5 Z M15.04,12.21 C15.33,11.53 15.5,10.79 15.5,10 C15.5,9.08 15.27,8.22 14.87,7.46 L17.06,5.27 C17.97,6.62 18.5,8.25 18.5,10 C18.5,11.62 18.05,13.13 17.25,14.42 L15.04,12.21 L15.04,12.21 Z" /></svg>',
|
|
link: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path fill="none" stroke="#000" stroke-width="1.1" d="M10.625,12.375 L7.525,15.475 C6.825,16.175 5.925,16.175 5.225,15.475 L4.525,14.775 C3.825,14.074 3.825,13.175 4.525,12.475 L7.625,9.375" /> <path fill="none" stroke="#000" stroke-width="1.1" d="M9.325,7.375 L12.425,4.275 C13.125,3.575 14.025,3.575 14.724,4.275 L15.425,4.975 C16.125,5.675 16.125,6.575 15.425,7.275 L12.325,10.375" /> <path fill="none" stroke="#000" stroke-width="1.1" d="M7.925,11.875 L11.925,7.975" /></svg>',
|
|
linkedin: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M5.77,17.89 L5.77,7.17 L2.21,7.17 L2.21,17.89 L5.77,17.89 L5.77,17.89 Z M3.99,5.71 C5.23,5.71 6.01,4.89 6.01,3.86 C5.99,2.8 5.24,2 4.02,2 C2.8,2 2,2.8 2,3.85 C2,4.88 2.77,5.7 3.97,5.7 L3.99,5.7 L3.99,5.71 L3.99,5.71 Z" /> <path d="M7.75,17.89 L11.31,17.89 L11.31,11.9 C11.31,11.58 11.33,11.26 11.43,11.03 C11.69,10.39 12.27,9.73 13.26,9.73 C14.55,9.73 15.06,10.71 15.06,12.15 L15.06,17.89 L18.62,17.89 L18.62,11.74 C18.62,8.45 16.86,6.92 14.52,6.92 C12.6,6.92 11.75,7.99 11.28,8.73 L11.3,8.73 L11.3,7.17 L7.75,7.17 C7.79,8.17 7.75,17.89 7.75,17.89 L7.75,17.89 L7.75,17.89 Z" /></svg>',
|
|
list: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <rect x="6" y="4" width="12" height="1" /> <rect x="6" y="9" width="12" height="1" /> <rect x="6" y="14" width="12" height="1" /> <rect x="2" y="4" width="2" height="1" /> <rect x="2" y="9" width="2" height="1" /> <rect x="2" y="14" width="2" height="1" /></svg>',
|
|
location: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path fill="none" stroke="#000" stroke-width="1.01" d="M10,0.5 C6.41,0.5 3.5,3.39 3.5,6.98 C3.5,11.83 10,19 10,19 C10,19 16.5,11.83 16.5,6.98 C16.5,3.39 13.59,0.5 10,0.5 L10,0.5 Z" /> <circle fill="none" stroke="#000" cx="10" cy="6.8" r="2.3" /></svg>',
|
|
lock: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <rect fill="none" stroke="#000" height="10" width="13" y="8.5" x="3.5" /> <path fill="none" stroke="#000" d="M6.5,8 L6.5,4.88 C6.5,3.01 8.07,1.5 10,1.5 C11.93,1.5 13.5,3.01 13.5,4.88 L13.5,8" /></svg>',
|
|
mail: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polyline fill="none" stroke="#000" points="1.4,6.5 10,11 18.6,6.5" /> <path d="M 1,4 1,16 19,16 19,4 1,4 Z M 18,15 2,15 2,5 18,5 18,15 Z" /></svg>',
|
|
menu: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <rect x="2" y="4" width="16" height="1" /> <rect x="2" y="9" width="16" height="1" /> <rect x="2" y="14" width="16" height="1" /></svg>',
|
|
"minus-circle": '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <circle fill="none" stroke="#000" stroke-width="1.1" cx="9.5" cy="9.5" r="9" /> <line fill="none" stroke="#000" x1="5" y1="9.5" x2="14" y2="9.5" /></svg>',
|
|
minus: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <rect height="1" width="18" y="9" x="1" /></svg>',
|
|
"more-vertical": '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <circle cx="10" cy="3" r="2" /> <circle cx="10" cy="10" r="2" /> <circle cx="10" cy="17" r="2" /></svg>',
|
|
more: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <circle cx="3" cy="10" r="2" /> <circle cx="10" cy="10" r="2" /> <circle cx="17" cy="10" r="2" /></svg>',
|
|
move: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polygon points="4,5 1,5 1,9 2,9 2,6 4,6 " /> <polygon points="1,16 2,16 2,18 4,18 4,19 1,19 " /> <polygon points="14,16 14,19 11,19 11,18 13,18 13,16 " /> <rect fill="none" stroke="#000" x="5.5" y="1.5" width="13" height="13" /> <rect x="1" y="11" width="1" height="3" /> <rect x="6" y="18" width="3" height="1" /></svg>',
|
|
nut: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polygon fill="none" stroke="#000" points="2.5,5.7 10,1.3 17.5,5.7 17.5,14.3 10,18.7 2.5,14.3" /> <circle fill="none" stroke="#000" cx="10" cy="10" r="3.5" /></svg>',
|
|
pagekit: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polygon points="3,1 17,1 17,16 10,16 10,13 14,13 14,4 6,4 6,16 10,16 10,19 3,19 " /></svg>',
|
|
"paint-bucket": '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M10.21,1 L0,11.21 L8.1,19.31 L18.31,9.1 L10.21,1 L10.21,1 Z M16.89,9.1 L15,11 L1.7,11 L10.21,2.42 L16.89,9.1 Z" /> <path fill="none" stroke="#000" stroke-width="1.1" d="M6.42,2.33 L11.7,7.61" /> <path d="M18.49,12 C18.49,12 20,14.06 20,15.36 C20,16.28 19.24,17 18.49,17 L18.49,17 C17.74,17 17,16.28 17,15.36 C17,14.06 18.49,12 18.49,12 L18.49,12 Z" /></svg>',
|
|
pencil: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path fill="none" stroke="#000" d="M17.25,6.01 L7.12,16.1 L3.82,17.2 L5.02,13.9 L15.12,3.88 C15.71,3.29 16.66,3.29 17.25,3.88 C17.83,4.47 17.83,5.42 17.25,6.01 L17.25,6.01 Z" /> <path fill="none" stroke="#000" d="M15.98,7.268 L13.851,5.148" /></svg>',
|
|
"phone-landscape": '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path fill="none" stroke="#000" d="M17,5.5 C17.8,5.5 18.5,6.2 18.5,7 L18.5,14 C18.5,14.8 17.8,15.5 17,15.5 L3,15.5 C2.2,15.5 1.5,14.8 1.5,14 L1.5,7 C1.5,6.2 2.2,5.5 3,5.5 L17,5.5 L17,5.5 L17,5.5 Z" /> <circle cx="3.8" cy="10.5" r="0.8" /></svg>',
|
|
phone: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path fill="none" stroke="#000" d="M15.5,17 C15.5,17.8 14.8,18.5 14,18.5 L7,18.5 C6.2,18.5 5.5,17.8 5.5,17 L5.5,3 C5.5,2.2 6.2,1.5 7,1.5 L14,1.5 C14.8,1.5 15.5,2.2 15.5,3 L15.5,17 L15.5,17 L15.5,17 Z" /> <circle cx="10.5" cy="16.5" r="0.8" /></svg>',
|
|
pinterest: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M10.21,1 C5.5,1 3,4.16 3,7.61 C3,9.21 3.85,11.2 5.22,11.84 C5.43,11.94 5.54,11.89 5.58,11.69 C5.62,11.54 5.8,10.8 5.88,10.45 C5.91,10.34 5.89,10.24 5.8,10.14 C5.36,9.59 5,8.58 5,7.65 C5,5.24 6.82,2.91 9.93,2.91 C12.61,2.91 14.49,4.74 14.49,7.35 C14.49,10.3 13,12.35 11.06,12.35 C9.99,12.35 9.19,11.47 9.44,10.38 C9.75,9.08 10.35,7.68 10.35,6.75 C10.35,5.91 9.9,5.21 8.97,5.21 C7.87,5.21 6.99,6.34 6.99,7.86 C6.99,8.83 7.32,9.48 7.32,9.48 C7.32,9.48 6.24,14.06 6.04,14.91 C5.7,16.35 6.08,18.7 6.12,18.9 C6.14,19.01 6.26,19.05 6.33,18.95 C6.44,18.81 7.74,16.85 8.11,15.44 C8.24,14.93 8.79,12.84 8.79,12.84 C9.15,13.52 10.19,14.09 11.29,14.09 C14.58,14.09 16.96,11.06 16.96,7.3 C16.94,3.7 14,1 10.21,1" /></svg>',
|
|
"play-circle": '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polygon fill="none" stroke="#000" stroke-width="1.1" points="8.5 7 13.5 10 8.5 13" /> <circle fill="none" stroke="#000" stroke-width="1.1" cx="10" cy="10" r="9" /></svg>',
|
|
play: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polygon fill="none" stroke="#000" points="6.5,5 14.5,10 6.5,15" /></svg>',
|
|
"plus-circle": '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <circle fill="none" stroke="#000" stroke-width="1.1" cx="9.5" cy="9.5" r="9" /> <line fill="none" stroke="#000" x1="9.5" y1="5" x2="9.5" y2="14" /> <line fill="none" stroke="#000" x1="5" y1="9.5" x2="14" y2="9.5" /></svg>',
|
|
plus: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <rect x="9" y="1" width="1" height="17" /> <rect x="1" y="9" width="17" height="1" /></svg>',
|
|
pull: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polygon points="6.85,8 9.5,10.6 12.15,8 12.85,8.7 9.5,12 6.15,8.7" /> <line fill="none" stroke="#000" x1="9.5" y1="11" x2="9.5" y2="2" /> <polyline fill="none" stroke="#000" points="6,5.5 3.5,5.5 3.5,18.5 15.5,18.5 15.5,5.5 13,5.5" /></svg>',
|
|
push: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polygon points="12.15,4 9.5,1.4 6.85,4 6.15,3.3 9.5,0 12.85,3.3" /> <line fill="none" stroke="#000" x1="9.5" y1="10" x2="9.5" y2="1" /> <polyline fill="none" stroke="#000" points="6 5.5 3.5 5.5 3.5 18.5 15.5 18.5 15.5 5.5 13 5.5" /></svg>',
|
|
question: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <circle fill="none" stroke="#000" stroke-width="1.1" cx="10" cy="10" r="9" /> <circle cx="10.44" cy="14.42" r="1.05" /> <path fill="none" stroke="#000" stroke-width="1.2" d="M8.17,7.79 C8.17,4.75 12.72,4.73 12.72,7.72 C12.72,8.67 11.81,9.15 11.23,9.75 C10.75,10.24 10.51,10.73 10.45,11.4 C10.44,11.53 10.43,11.64 10.43,11.75" /></svg>',
|
|
"quote-right": '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M17.27,7.79 C17.27,9.45 16.97,10.43 15.99,12.02 C14.98,13.64 13,15.23 11.56,15.97 L11.1,15.08 C12.34,14.2 13.14,13.51 14.02,11.82 C14.27,11.34 14.41,10.92 14.49,10.54 C14.3,10.58 14.09,10.6 13.88,10.6 C12.06,10.6 10.59,9.12 10.59,7.3 C10.59,5.48 12.06,4 13.88,4 C15.39,4 16.67,5.02 17.05,6.42 C17.19,6.82 17.27,7.27 17.27,7.79 L17.27,7.79 Z" /> <path d="M8.68,7.79 C8.68,9.45 8.38,10.43 7.4,12.02 C6.39,13.64 4.41,15.23 2.97,15.97 L2.51,15.08 C3.75,14.2 4.55,13.51 5.43,11.82 C5.68,11.34 5.82,10.92 5.9,10.54 C5.71,10.58 5.5,10.6 5.29,10.6 C3.47,10.6 2,9.12 2,7.3 C2,5.48 3.47,4 5.29,4 C6.8,4 8.08,5.02 8.46,6.42 C8.6,6.82 8.68,7.27 8.68,7.79 L8.68,7.79 Z" /></svg>',
|
|
receiver: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path fill="none" stroke="#000" stroke-width="1.01" d="M6.189,13.611C8.134,15.525 11.097,18.239 13.867,18.257C16.47,18.275 18.2,16.241 18.2,16.241L14.509,12.551L11.539,13.639L6.189,8.29L7.313,5.355L3.76,1.8C3.76,1.8 1.732,3.537 1.7,6.092C1.667,8.809 4.347,11.738 6.189,13.611" /></svg>',
|
|
refresh: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path fill="none" stroke="#000" stroke-width="1.1" d="M17.08,11.15 C17.09,11.31 17.1,11.47 17.1,11.64 C17.1,15.53 13.94,18.69 10.05,18.69 C6.16,18.68 3,15.53 3,11.63 C3,7.74 6.16,4.58 10.05,4.58 C10.9,4.58 11.71,4.73 12.46,5" /> <polyline fill="none" stroke="#000" points="9.9 2 12.79 4.89 9.79 7.9" /></svg>',
|
|
reply: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M17.7,13.11 C16.12,10.02 13.84,7.85 11.02,6.61 C10.57,6.41 9.75,6.13 9,5.91 L9,2 L1,9 L9,16 L9,12.13 C10.78,12.47 12.5,13.19 14.09,14.25 C17.13,16.28 18.56,18.54 18.56,18.54 C18.56,18.54 18.81,15.28 17.7,13.11 L17.7,13.11 Z M14.82,13.53 C13.17,12.4 11.01,11.4 8,10.92 L8,13.63 L2.55,9 L8,4.25 L8,6.8 C8.3,6.86 9.16,7.02 10.37,7.49 C13.3,8.65 15.54,10.96 16.65,13.08 C16.97,13.7 17.48,14.86 17.68,16 C16.87,15.05 15.73,14.15 14.82,13.53 L14.82,13.53 Z" /></svg>',
|
|
rss: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <circle cx="3.12" cy="16.8" r="1.85" /> <path fill="none" stroke="#000" stroke-width="1.1" d="M1.5,8.2 C1.78,8.18 2.06,8.16 2.35,8.16 C7.57,8.16 11.81,12.37 11.81,17.57 C11.81,17.89 11.79,18.19 11.76,18.5" /> <path fill="none" stroke="#000" stroke-width="1.1" d="M1.5,2.52 C1.78,2.51 2.06,2.5 2.35,2.5 C10.72,2.5 17.5,9.24 17.5,17.57 C17.5,17.89 17.49,18.19 17.47,18.5" /></svg>',
|
|
search: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <circle fill="none" stroke="#000" stroke-width="1.1" cx="9" cy="9" r="7" /> <path fill="none" stroke="#000" stroke-width="1.1" d="M14,14 L18,18 L14,14 Z" /></svg>',
|
|
server: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <rect x="3" y="3" width="1" height="2" /> <rect x="5" y="3" width="1" height="2" /> <rect x="7" y="3" width="1" height="2" /> <rect x="16" y="3" width="1" height="1" /> <rect x="16" y="10" width="1" height="1" /> <circle fill="none" stroke="#000" cx="9.9" cy="17.4" r="1.4" /> <rect x="3" y="10" width="1" height="2" /> <rect x="5" y="10" width="1" height="2" /> <rect x="9.5" y="14" width="1" height="2" /> <rect x="3" y="17" width="6" height="1" /> <rect x="11" y="17" width="6" height="1" /> <rect fill="none" stroke="#000" x="1.5" y="1.5" width="17" height="5" /> <rect fill="none" stroke="#000" x="1.5" y="8.5" width="17" height="5" /></svg>',
|
|
settings: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <ellipse fill="none" stroke="#000" cx="6.11" cy="3.55" rx="2.11" ry="2.15" /> <ellipse fill="none" stroke="#000" cx="6.11" cy="15.55" rx="2.11" ry="2.15" /> <circle fill="none" stroke="#000" cx="13.15" cy="9.55" r="2.15" /> <rect x="1" y="3" width="3" height="1" /> <rect x="10" y="3" width="8" height="1" /> <rect x="1" y="9" width="8" height="1" /> <rect x="15" y="9" width="3" height="1" /> <rect x="1" y="15" width="3" height="1" /> <rect x="10" y="15" width="8" height="1" /></svg>',
|
|
shrink: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polygon points="11 4 12 4 12 8 16 8 16 9 11 9" /> <polygon points="4 11 9 11 9 16 8 16 8 12 4 12" /> <path fill="none" stroke="#000" stroke-width="1.1" d="M12,8 L18,2" /> <path fill="none" stroke="#000" stroke-width="1.1" d="M2,18 L8,12" /></svg>',
|
|
"sign-in": '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polygon points="7 2 17 2 17 17 7 17 7 16 16 16 16 3 7 3" /> <polygon points="9.1 13.4 8.5 12.8 11.28 10 4 10 4 9 11.28 9 8.5 6.2 9.1 5.62 13 9.5" /></svg>',
|
|
"sign-out": '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polygon points="13.1 13.4 12.5 12.8 15.28 10 8 10 8 9 15.28 9 12.5 6.2 13.1 5.62 17 9.5" /> <polygon points="13 2 3 2 3 17 13 17 13 16 4 16 4 3 13 3" /></svg>',
|
|
social: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <line fill="none" stroke="#000" stroke-width="1.1" x1="13.4" y1="14" x2="6.3" y2="10.7" /> <line fill="none" stroke="#000" stroke-width="1.1" x1="13.5" y1="5.5" x2="6.5" y2="8.8" /> <circle fill="none" stroke="#000" stroke-width="1.1" cx="15.5" cy="4.6" r="2.3" /> <circle fill="none" stroke="#000" stroke-width="1.1" cx="15.5" cy="14.8" r="2.3" /> <circle fill="none" stroke="#000" stroke-width="1.1" cx="4.5" cy="9.8" r="2.3" /></svg>',
|
|
soundcloud: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M17.2,9.4c-0.4,0-0.8,0.1-1.101,0.2c-0.199-2.5-2.399-4.5-5-4.5c-0.6,0-1.2,0.1-1.7,0.3C9.2,5.5,9.1,5.6,9.1,5.6V15h8 c1.601,0,2.801-1.2,2.801-2.8C20,10.7,18.7,9.4,17.2,9.4L17.2,9.4z" /> <rect x="6" y="6.5" width="1.5" height="8.5" /> <rect x="3" y="8" width="1.5" height="7" /> <rect y="10" width="1.5" height="5" /></svg>',
|
|
star: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polygon fill="none" stroke="#000" stroke-width="1.01" points="10 2 12.63 7.27 18.5 8.12 14.25 12.22 15.25 18 10 15.27 4.75 18 5.75 12.22 1.5 8.12 7.37 7.27" /></svg>',
|
|
strikethrough: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M6,13.02 L6.65,13.02 C7.64,15.16 8.86,16.12 10.41,16.12 C12.22,16.12 12.92,14.93 12.92,13.89 C12.92,12.55 11.99,12.03 9.74,11.23 C8.05,10.64 6.23,10.11 6.23,7.83 C6.23,5.5 8.09,4.09 10.4,4.09 C11.44,4.09 12.13,4.31 12.72,4.54 L13.33,4 L13.81,4 L13.81,7.59 L13.16,7.59 C12.55,5.88 11.52,4.89 10.07,4.89 C8.84,4.89 7.89,5.69 7.89,7.03 C7.89,8.29 8.89,8.78 10.88,9.45 C12.57,10.03 14.38,10.6 14.38,12.91 C14.38,14.75 13.27,16.93 10.18,16.93 C9.18,16.93 8.17,16.69 7.46,16.39 L6.52,17 L6,17 L6,13.02 L6,13.02 Z" /> <rect x="3" y="10" width="15" height="1" /></svg>',
|
|
table: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <rect x="1" y="3" width="18" height="1" /> <rect x="1" y="7" width="18" height="1" /> <rect x="1" y="11" width="18" height="1" /> <rect x="1" y="15" width="18" height="1" /></svg>',
|
|
"tablet-landscape": '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path fill="none" stroke="#000" d="M1.5,5 C1.5,4.2 2.2,3.5 3,3.5 L17,3.5 C17.8,3.5 18.5,4.2 18.5,5 L18.5,16 C18.5,16.8 17.8,17.5 17,17.5 L3,17.5 C2.2,17.5 1.5,16.8 1.5,16 L1.5,5 L1.5,5 L1.5,5 Z" /> <circle cx="3.7" cy="10.5" r="0.8" /></svg>',
|
|
tablet: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path fill="none" stroke="#000" d="M5,18.5 C4.2,18.5 3.5,17.8 3.5,17 L3.5,3 C3.5,2.2 4.2,1.5 5,1.5 L16,1.5 C16.8,1.5 17.5,2.2 17.5,3 L17.5,17 C17.5,17.8 16.8,18.5 16,18.5 L5,18.5 L5,18.5 L5,18.5 Z" /> <circle cx="10.5" cy="16.3" r="0.8" /></svg>',
|
|
tag: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path fill="none" stroke="#000" stroke-width="1.1" d="M17.5,3.71 L17.5,7.72 C17.5,7.96 17.4,8.2 17.21,8.39 L8.39,17.2 C7.99,17.6 7.33,17.6 6.93,17.2 L2.8,13.07 C2.4,12.67 2.4,12.01 2.8,11.61 L11.61,2.8 C11.81,2.6 12.08,2.5 12.34,2.5 L16.19,2.5 C16.52,2.5 16.86,2.63 17.11,2.88 C17.35,3.11 17.48,3.4 17.5,3.71 L17.5,3.71 Z" /> <circle cx="14" cy="6" r="1" /></svg>',
|
|
thumbnails: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <rect fill="none" stroke="#000" x="3.5" y="3.5" width="5" height="5" /> <rect fill="none" stroke="#000" x="11.5" y="3.5" width="5" height="5" /> <rect fill="none" stroke="#000" x="11.5" y="11.5" width="5" height="5" /> <rect fill="none" stroke="#000" x="3.5" y="11.5" width="5" height="5" /></svg>',
|
|
trash: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polyline fill="none" stroke="#000" points="6.5 3 6.5 1.5 13.5 1.5 13.5 3" /> <polyline fill="none" stroke="#000" points="4.5 4 4.5 18.5 15.5 18.5 15.5 4" /> <rect x="8" y="7" width="1" height="9" /> <rect x="11" y="7" width="1" height="9" /> <rect x="2" y="3" width="16" height="1" /></svg>',
|
|
"triangle-down": '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polygon points="5 7 15 7 10 12" /></svg>',
|
|
"triangle-left": '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polygon points="12 5 7 10 12 15" /></svg>',
|
|
"triangle-right": '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polygon points="8 5 13 10 8 15" /></svg>',
|
|
"triangle-up": '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polygon points="5 13 10 8 15 13" /></svg>',
|
|
tripadvisor: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M19.021,7.866C19.256,6.862,20,5.854,20,5.854h-3.346C14.781,4.641,12.504,4,9.98,4C7.363,4,4.999,4.651,3.135,5.876H0\tc0,0,0.738,0.987,0.976,1.988c-0.611,0.837-0.973,1.852-0.973,2.964c0,2.763,2.249,5.009,5.011,5.009\tc1.576,0,2.976-0.737,3.901-1.879l1.063,1.599l1.075-1.615c0.475,0.611,1.1,1.111,1.838,1.451c1.213,0.547,2.574,0.612,3.825,0.15\tc2.589-0.963,3.913-3.852,2.964-6.439c-0.175-0.463-0.4-0.876-0.675-1.238H19.021z M16.38,14.594\tc-1.002,0.371-2.088,0.328-3.06-0.119c-0.688-0.317-1.252-0.817-1.657-1.438c-0.164-0.25-0.313-0.52-0.417-0.811\tc-0.124-0.328-0.186-0.668-0.217-1.014c-0.063-0.689,0.037-1.396,0.339-2.043c0.448-0.971,1.251-1.71,2.25-2.079\tc2.075-0.765,4.375,0.3,5.14,2.366c0.762,2.066-0.301,4.37-2.363,5.134L16.38,14.594L16.38,14.594z M8.322,13.066\tc-0.72,1.059-1.935,1.76-3.309,1.76c-2.207,0-4.001-1.797-4.001-3.996c0-2.203,1.795-4.002,4.001-4.002\tc2.204,0,3.999,1.8,3.999,4.002c0,0.137-0.024,0.261-0.04,0.396c-0.067,0.678-0.284,1.313-0.648,1.853v-0.013H8.322z M2.472,10.775\tc0,1.367,1.112,2.479,2.476,2.479c1.363,0,2.472-1.11,2.472-2.479c0-1.359-1.11-2.468-2.472-2.468\tC3.584,8.306,2.473,9.416,2.472,10.775L2.472,10.775z M12.514,10.775c0,1.367,1.104,2.479,2.471,2.479\tc1.363,0,2.474-1.108,2.474-2.479c0-1.359-1.11-2.468-2.474-2.468c-1.364,0-2.477,1.109-2.477,2.468H12.514z M3.324,10.775\tc0-0.893,0.726-1.618,1.614-1.618c0.889,0,1.625,0.727,1.625,1.618c0,0.898-0.725,1.627-1.625,1.627\tc-0.901,0-1.625-0.729-1.625-1.627H3.324z M13.354,10.775c0-0.893,0.726-1.618,1.627-1.618c0.886,0,1.61,0.727,1.61,1.618\tc0,0.898-0.726,1.627-1.626,1.627s-1.625-0.729-1.625-1.627H13.354z M9.977,4.875c1.798,0,3.425,0.324,4.849,0.968\tc-0.535,0.015-1.061,0.108-1.586,0.3c-1.264,0.463-2.264,1.388-2.815,2.604c-0.262,0.551-0.398,1.133-0.448,1.72\tC9.79,7.905,7.677,5.873,5.076,5.82C6.501,5.208,8.153,4.875,9.94,4.875H9.977z" /></svg>',
|
|
tumblr: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M6.885,8.598c0,0,0,3.393,0,4.996c0,0.282,0,0.66,0.094,0.942c0.377,1.509,1.131,2.545,2.545,3.11 c1.319,0.472,2.356,0.472,3.676,0c0.565-0.188,1.132-0.659,1.132-0.659l-0.849-2.263c0,0-1.036,0.378-1.603,0.283 c-0.565-0.094-1.226-0.66-1.226-1.508c0-1.603,0-4.902,0-4.902h2.828V5.771h-2.828V2H8.205c0,0-0.094,0.66-0.188,0.942 C7.828,3.791,7.262,4.733,6.603,5.394C5.848,6.147,5,6.43,5,6.43v2.168H6.885z" /></svg>',
|
|
tv: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <rect x="7" y="16" width="6" height="1" /> <rect fill="none" stroke="#000" x="0.5" y="3.5" width="19" height="11" /></svg>',
|
|
twitter: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M19,4.74 C18.339,5.029 17.626,5.229 16.881,5.32 C17.644,4.86 18.227,4.139 18.503,3.28 C17.79,3.7 17.001,4.009 16.159,4.17 C15.485,3.45 14.526,3 13.464,3 C11.423,3 9.771,4.66 9.771,6.7 C9.771,6.99 9.804,7.269 9.868,7.539 C6.795,7.38 4.076,5.919 2.254,3.679 C1.936,4.219 1.754,4.86 1.754,5.539 C1.754,6.82 2.405,7.95 3.397,8.61 C2.79,8.589 2.22,8.429 1.723,8.149 L1.723,8.189 C1.723,9.978 2.997,11.478 4.686,11.82 C4.376,11.899 4.049,11.939 3.713,11.939 C3.475,11.939 3.245,11.919 3.018,11.88 C3.49,13.349 4.852,14.419 6.469,14.449 C5.205,15.429 3.612,16.019 1.882,16.019 C1.583,16.019 1.29,16.009 1,15.969 C2.635,17.019 4.576,17.629 6.662,17.629 C13.454,17.629 17.17,12 17.17,7.129 C17.17,6.969 17.166,6.809 17.157,6.649 C17.879,6.129 18.504,5.478 19,4.74" /></svg>',
|
|
uikit: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polygon points="14.4,3.1 11.3,5.1 15,7.3 15,12.9 10,15.7 5,12.9 5,8.5 2,6.8 2,14.8 9.9,19.5 18,14.8 18,5.3" /> <polygon points="9.8,4.2 6.7,2.4 9.8,0.4 12.9,2.3" /></svg>',
|
|
unlock: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <rect fill="none" stroke="#000" x="3.5" y="8.5" width="13" height="10" /> <path fill="none" stroke="#000" d="M6.5,8.5 L6.5,4.9 C6.5,3 8.1,1.5 10,1.5 C11.9,1.5 13.5,3 13.5,4.9" /></svg>',
|
|
upload: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polyline fill="none" stroke="#000" points="5 8 9.5 3.5 14 8 " /> <rect x="3" y="17" width="13" height="1" /> <line fill="none" stroke="#000" x1="9.5" y1="15" x2="9.5" y2="4" /></svg>',
|
|
user: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <circle fill="none" stroke="#000" stroke-width="1.1" cx="9.9" cy="6.4" r="4.4" /> <path fill="none" stroke="#000" stroke-width="1.1" d="M1.5,19 C2.3,14.5 5.8,11.2 10,11.2 C14.2,11.2 17.7,14.6 18.5,19.2" /></svg>',
|
|
users: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <circle fill="none" stroke="#000" stroke-width="1.1" cx="7.7" cy="8.6" r="3.5" /> <path fill="none" stroke="#000" stroke-width="1.1" d="M1,18.1 C1.7,14.6 4.4,12.1 7.6,12.1 C10.9,12.1 13.7,14.8 14.3,18.3" /> <path fill="none" stroke="#000" stroke-width="1.1" d="M11.4,4 C12.8,2.4 15.4,2.8 16.3,4.7 C17.2,6.6 15.7,8.9 13.6,8.9 C16.5,8.9 18.8,11.3 19.2,14.1" /></svg>',
|
|
"video-camera": '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <polygon points="18,6 18,14 12,10 " /> <rect x="2" y="5" width="12" height="10" /></svg>',
|
|
vimeo: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M2.065,7.59C1.84,7.367,1.654,7.082,1.468,6.838c-0.332-0.42-0.137-0.411,0.274-0.772c1.026-0.91,2.004-1.896,3.127-2.688 c1.017-0.713,2.365-1.173,3.286-0.039c0.849,1.045,0.869,2.629,1.084,3.891c0.215,1.309,0.421,2.648,0.88,3.901 c0.127,0.352,0.37,1.018,0.81,1.074c0.567,0.078,1.145-0.917,1.408-1.289c0.684-0.987,1.611-2.317,1.494-3.587 c-0.115-1.349-1.572-1.095-2.482-0.773c0.146-1.514,1.555-3.216,2.912-3.792c1.439-0.597,3.579-0.587,4.302,1.036 c0.772,1.759,0.078,3.802-0.763,5.396c-0.918,1.731-2.1,3.333-3.363,4.829c-1.114,1.329-2.432,2.787-4.093,3.422 c-1.897,0.723-3.021-0.686-3.667-2.318c-0.705-1.777-1.056-3.771-1.565-5.621C4.898,8.726,4.644,7.836,4.136,7.191 C3.473,6.358,2.72,7.141,2.065,7.59C1.977,7.502,2.115,7.551,2.065,7.59L2.065,7.59z" /></svg>',
|
|
warning: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <circle cx="10" cy="14" r="1" /> <circle fill="none" stroke="#000" stroke-width="1.1" cx="10" cy="10" r="9" /> <path d="M10.97,7.72 C10.85,9.54 10.56,11.29 10.56,11.29 C10.51,11.87 10.27,12 9.99,12 C9.69,12 9.49,11.87 9.43,11.29 C9.43,11.29 9.16,9.54 9.03,7.72 C8.96,6.54 9.03,6 9.03,6 C9.03,5.45 9.46,5.02 9.99,5 C10.53,5.01 10.97,5.44 10.97,6 C10.97,6 11.04,6.54 10.97,7.72 L10.97,7.72 Z" /></svg>',
|
|
whatsapp: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M16.7,3.3c-1.8-1.8-4.1-2.8-6.7-2.8c-5.2,0-9.4,4.2-9.4,9.4c0,1.7,0.4,3.3,1.3,4.7l-1.3,4.9l5-1.3c1.4,0.8,2.9,1.2,4.5,1.2 l0,0l0,0c5.2,0,9.4-4.2,9.4-9.4C19.5,7.4,18.5,5,16.7,3.3 M10.1,17.7L10.1,17.7c-1.4,0-2.8-0.4-4-1.1l-0.3-0.2l-3,0.8l0.8-2.9 l-0.2-0.3c-0.8-1.2-1.2-2.7-1.2-4.2c0-4.3,3.5-7.8,7.8-7.8c2.1,0,4.1,0.8,5.5,2.3c1.5,1.5,2.3,3.4,2.3,5.5 C17.9,14.2,14.4,17.7,10.1,17.7 M14.4,11.9c-0.2-0.1-1.4-0.7-1.6-0.8c-0.2-0.1-0.4-0.1-0.5,0.1c-0.2,0.2-0.6,0.8-0.8,0.9 c-0.1,0.2-0.3,0.2-0.5,0.1c-0.2-0.1-1-0.4-1.9-1.2c-0.7-0.6-1.2-1.4-1.3-1.6c-0.1-0.2,0-0.4,0.1-0.5C8,8.8,8.1,8.7,8.2,8.5 c0.1-0.1,0.2-0.2,0.2-0.4c0.1-0.2,0-0.3,0-0.4C8.4,7.6,7.9,6.5,7.7,6C7.5,5.5,7.3,5.6,7.2,5.6c-0.1,0-0.3,0-0.4,0 c-0.2,0-0.4,0.1-0.6,0.3c-0.2,0.2-0.8,0.8-0.8,2c0,1.2,0.8,2.3,1,2.4c0.1,0.2,1.7,2.5,4,3.5c0.6,0.2,1,0.4,1.3,0.5 c0.6,0.2,1.1,0.2,1.5,0.1c0.5-0.1,1.4-0.6,1.6-1.1c0.2-0.5,0.2-1,0.1-1.1C14.8,12.1,14.6,12,14.4,11.9" /></svg>',
|
|
wordpress: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M10,0.5c-5.2,0-9.5,4.3-9.5,9.5s4.3,9.5,9.5,9.5c5.2,0,9.5-4.3,9.5-9.5S15.2,0.5,10,0.5L10,0.5L10,0.5z M15.6,3.9h-0.1 c-0.8,0-1.4,0.7-1.4,1.5c0,0.7,0.4,1.3,0.8,1.9c0.3,0.6,0.7,1.3,0.7,2.3c0,0.7-0.3,1.5-0.6,2.7L14.1,15l-3-8.9 c0.5,0,0.9-0.1,0.9-0.1C12.5,6,12.5,5.3,12,5.4c0,0-1.3,0.1-2.2,0.1C9,5.5,7.7,5.4,7.7,5.4C7.2,5.3,7.2,6,7.6,6c0,0,0.4,0.1,0.9,0.1 l1.3,3.5L8,15L5,6.1C5.5,6.1,5.9,6,5.9,6C6.4,6,6.3,5.3,5.9,5.4c0,0-1.3,0.1-2.2,0.1c-0.2,0-0.3,0-0.5,0c1.5-2.2,4-3.7,6.9-3.7 C12.2,1.7,14.1,2.6,15.6,3.9L15.6,3.9L15.6,3.9z M2.5,6.6l3.9,10.8c-2.7-1.3-4.6-4.2-4.6-7.4C1.8,8.8,2,7.6,2.5,6.6L2.5,6.6L2.5,6.6 z M10.2,10.7l2.5,6.9c0,0,0,0.1,0.1,0.1C11.9,18,11,18.2,10,18.2c-0.8,0-1.6-0.1-2.3-0.3L10.2,10.7L10.2,10.7L10.2,10.7z M14.2,17.1 l2.5-7.3c0.5-1.2,0.6-2.1,0.6-2.9c0-0.3,0-0.6-0.1-0.8c0.6,1.2,1,2.5,1,4C18.3,13,16.6,15.7,14.2,17.1L14.2,17.1L14.2,17.1z" /></svg>',
|
|
world: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path fill="none" stroke="#000" d="M1,10.5 L19,10.5" /> <path fill="none" stroke="#000" d="M2.35,15.5 L17.65,15.5" /> <path fill="none" stroke="#000" d="M2.35,5.5 L17.523,5.5" /> <path fill="none" stroke="#000" d="M10,19.46 L9.98,19.46 C7.31,17.33 5.61,14.141 5.61,10.58 C5.61,7.02 7.33,3.83 10,1.7 C10.01,1.7 9.99,1.7 10,1.7 L10,1.7 C12.67,3.83 14.4,7.02 14.4,10.58 C14.4,14.141 12.67,17.33 10,19.46 L10,19.46 L10,19.46 L10,19.46 Z" /> <circle fill="none" stroke="#000" cx="10" cy="10.5" r="9" /></svg>',
|
|
xing: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M4.4,4.56 C4.24,4.56 4.11,4.61 4.05,4.72 C3.98,4.83 3.99,4.97 4.07,5.12 L5.82,8.16 L5.82,8.17 L3.06,13.04 C2.99,13.18 2.99,13.33 3.06,13.44 C3.12,13.55 3.24,13.62 3.4,13.62 L6,13.62 C6.39,13.62 6.57,13.36 6.71,13.12 C6.71,13.12 9.41,8.35 9.51,8.16 C9.49,8.14 7.72,5.04 7.72,5.04 C7.58,4.81 7.39,4.56 6.99,4.56 L4.4,4.56 L4.4,4.56 Z" /> <path d="M15.3,1 C14.91,1 14.74,1.25 14.6,1.5 C14.6,1.5 9.01,11.42 8.82,11.74 C8.83,11.76 12.51,18.51 12.51,18.51 C12.64,18.74 12.84,19 13.23,19 L15.82,19 C15.98,19 16.1,18.94 16.16,18.83 C16.23,18.72 16.23,18.57 16.16,18.43 L12.5,11.74 L12.5,11.72 L18.25,1.56 C18.32,1.42 18.32,1.27 18.25,1.16 C18.21,1.06 18.08,1 17.93,1 L15.3,1 L15.3,1 Z" /></svg>',
|
|
yelp: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M17.175,14.971c-0.112,0.77-1.686,2.767-2.406,3.054c-0.246,0.1-0.487,0.076-0.675-0.069\tc-0.122-0.096-2.446-3.859-2.446-3.859c-0.194-0.293-0.157-0.682,0.083-0.978c0.234-0.284,0.581-0.393,0.881-0.276\tc0.016,0.01,4.21,1.394,4.332,1.482c0.178,0.148,0.263,0.379,0.225,0.646L17.175,14.971L17.175,14.971z M11.464,10.789\tc-0.203-0.307-0.199-0.666,0.009-0.916c0,0,2.625-3.574,2.745-3.657c0.203-0.135,0.452-0.141,0.69-0.025\tc0.691,0.335,2.085,2.405,2.167,3.199v0.027c0.024,0.271-0.082,0.491-0.273,0.623c-0.132,0.083-4.43,1.155-4.43,1.155\tc-0.322,0.096-0.68-0.06-0.882-0.381L11.464,10.789z M9.475,9.563C9.32,9.609,8.848,9.757,8.269,8.817c0,0-3.916-6.16-4.007-6.351\tc-0.057-0.212,0.011-0.455,0.202-0.65C5.047,1.211,8.21,0.327,9.037,0.529c0.27,0.069,0.457,0.238,0.522,0.479\tc0.047,0.266,0.433,5.982,0.488,7.264C10.098,9.368,9.629,9.517,9.475,9.563z M9.927,19.066c-0.083,0.225-0.273,0.373-0.54,0.421\tc-0.762,0.13-3.15-0.751-3.647-1.342c-0.096-0.131-0.155-0.262-0.167-0.394c-0.011-0.095,0-0.189,0.036-0.272\tc0.061-0.155,2.917-3.538,2.917-3.538c0.214-0.272,0.595-0.355,0.952-0.213c0.345,0.13,0.56,0.428,0.536,0.749\tC10.014,14.479,9.977,18.923,9.927,19.066z M3.495,13.912c-0.235-0.009-0.444-0.148-0.568-0.382c-0.089-0.17-0.151-0.453-0.19-0.794\tC2.63,11.701,2.761,10.144,3.07,9.648c0.145-0.226,0.357-0.345,0.592-0.336c0.154,0,4.255,1.667,4.255,1.667\tc0.321,0.118,0.521,0.453,0.5,0.833c-0.023,0.37-0.236,0.655-0.551,0.738L3.495,13.912z" /></svg>',
|
|
youtube: '<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <path d="M15,4.1c1,0.1,2.3,0,3,0.8c0.8,0.8,0.9,2.1,0.9,3.1C19,9.2,19,10.9,19,12c-0.1,1.1,0,2.4-0.5,3.4c-0.5,1.1-1.4,1.5-2.5,1.6 c-1.2,0.1-8.6,0.1-11,0c-1.1-0.1-2.4-0.1-3.2-1c-0.7-0.8-0.7-2-0.8-3C1,11.8,1,10.1,1,8.9c0-1.1,0-2.4,0.5-3.4C2,4.5,3,4.3,4.1,4.2 C5.3,4.1,12.6,4,15,4.1z M8,7.5v6l5.5-3L8,7.5z" /></svg>'
|
|
});
|
|
}
|
|
if (typeof window !== "undefined" && window.UIkit) {
|
|
window.UIkit.use(plugin);
|
|
}
|
|
return plugin;
|
|
});
|
|
|
|
(function() {
|
|
"use strict";
|
|
var _$JSONLoader_2 = {
|
|
load: load
|
|
};
|
|
function load(location, callback) {
|
|
var xhr = getXHR();
|
|
xhr.open("GET", location, true);
|
|
xhr.onreadystatechange = createStateChangeListener(xhr, callback);
|
|
xhr.send();
|
|
}
|
|
function createStateChangeListener(xhr, callback) {
|
|
return function() {
|
|
if (xhr.readyState === 4 && xhr.status === 200) {
|
|
try {
|
|
callback(null, JSON.parse(xhr.responseText));
|
|
} catch (err) {
|
|
callback(err, null);
|
|
}
|
|
}
|
|
};
|
|
}
|
|
function getXHR() {
|
|
return window.XMLHttpRequest ? new window.XMLHttpRequest() : new ActiveXObject("Microsoft.XMLHTTP");
|
|
}
|
|
"use strict";
|
|
var _$OptionsValidator_3 = function OptionsValidator(params) {
|
|
if (!validateParams(params)) {
|
|
throw new Error("-- OptionsValidator: required options missing");
|
|
}
|
|
if (!(this instanceof OptionsValidator)) {
|
|
return new OptionsValidator(params);
|
|
}
|
|
var requiredOptions = params.required;
|
|
this.getRequiredOptions = function() {
|
|
return requiredOptions;
|
|
};
|
|
this.validate = function(parameters) {
|
|
var errors = [];
|
|
requiredOptions.forEach(function(requiredOptionName) {
|
|
if (typeof parameters[requiredOptionName] === "undefined") {
|
|
errors.push(requiredOptionName);
|
|
}
|
|
});
|
|
return errors;
|
|
};
|
|
function validateParams(params) {
|
|
if (!params) {
|
|
return false;
|
|
}
|
|
return typeof params.required !== "undefined" && params.required instanceof Array;
|
|
}
|
|
};
|
|
"use strict";
|
|
function fuzzysearch(needle, haystack) {
|
|
var tlen = haystack.length;
|
|
var qlen = needle.length;
|
|
if (qlen > tlen) {
|
|
return false;
|
|
}
|
|
if (qlen === tlen) {
|
|
return needle === haystack;
|
|
}
|
|
outer: for (var i = 0, j = 0; i < qlen; i++) {
|
|
var nch = needle.charCodeAt(i);
|
|
while (j < tlen) {
|
|
if (haystack.charCodeAt(j++) === nch) {
|
|
continue outer;
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
return true;
|
|
}
|
|
var _$fuzzysearch_1 = fuzzysearch;
|
|
"use strict";
|
|
var _$FuzzySearchStrategy_5 = new FuzzySearchStrategy();
|
|
function FuzzySearchStrategy() {
|
|
this.matches = function(string, crit) {
|
|
return _$fuzzysearch_1(crit.toLowerCase(), string.toLowerCase());
|
|
};
|
|
}
|
|
"use strict";
|
|
var _$LiteralSearchStrategy_6 = new LiteralSearchStrategy();
|
|
function LiteralSearchStrategy() {
|
|
this.matches = function(str, crit) {
|
|
if (typeof str !== "string") {
|
|
return false;
|
|
}
|
|
str = str.trim();
|
|
return str.toLowerCase().indexOf(crit.toLowerCase()) >= 0;
|
|
};
|
|
}
|
|
"use strict";
|
|
var _$Repository_4 = {
|
|
put: put,
|
|
clear: clear,
|
|
search: search,
|
|
setOptions: setOptions
|
|
};
|
|
function NoSort() {
|
|
return 0;
|
|
}
|
|
var data = [];
|
|
var opt = {};
|
|
opt.fuzzy = false;
|
|
opt.limit = 10;
|
|
opt.searchStrategy = opt.fuzzy ? _$FuzzySearchStrategy_5 : _$LiteralSearchStrategy_6;
|
|
opt.sort = NoSort;
|
|
function put(data) {
|
|
if (isObject(data)) {
|
|
return addObject(data);
|
|
}
|
|
if (isArray(data)) {
|
|
return addArray(data);
|
|
}
|
|
return undefined;
|
|
}
|
|
function clear() {
|
|
data.length = 0;
|
|
return data;
|
|
}
|
|
function isObject(obj) {
|
|
return Boolean(obj) && Object.prototype.toString.call(obj) === "[object Object]";
|
|
}
|
|
function isArray(obj) {
|
|
return Boolean(obj) && Object.prototype.toString.call(obj) === "[object Array]";
|
|
}
|
|
function addObject(_data) {
|
|
data.push(_data);
|
|
return data;
|
|
}
|
|
function addArray(_data) {
|
|
var added = [];
|
|
clear();
|
|
for (var i = 0, len = _data.length; i < len; i++) {
|
|
if (isObject(_data[i])) {
|
|
added.push(addObject(_data[i]));
|
|
}
|
|
}
|
|
return added;
|
|
}
|
|
function search(crit) {
|
|
if (!crit) {
|
|
return [];
|
|
}
|
|
return findMatches(data, crit, opt.searchStrategy, opt).sort(opt.sort);
|
|
}
|
|
function setOptions(_opt) {
|
|
opt = _opt || {};
|
|
opt.fuzzy = _opt.fuzzy || false;
|
|
opt.limit = _opt.limit || 10;
|
|
opt.searchStrategy = _opt.fuzzy ? _$FuzzySearchStrategy_5 : _$LiteralSearchStrategy_6;
|
|
opt.sort = _opt.sort || NoSort;
|
|
}
|
|
function findMatches(data, crit, strategy, opt) {
|
|
var matches = [];
|
|
for (var i = 0; i < data.length && matches.length < opt.limit; i++) {
|
|
var match = findMatchesInObject(data[i], crit, strategy, opt);
|
|
if (match) {
|
|
matches.push(match);
|
|
}
|
|
}
|
|
return matches;
|
|
}
|
|
function findMatchesInObject(obj, crit, strategy, opt) {
|
|
for (var key in obj) {
|
|
if (!isExcluded(obj[key], opt.exclude) && strategy.matches(obj[key], crit)) {
|
|
return obj;
|
|
}
|
|
}
|
|
}
|
|
function isExcluded(term, excludedTerms) {
|
|
var excluded = false;
|
|
excludedTerms = excludedTerms || [];
|
|
for (var i = 0, len = excludedTerms.length; i < len; i++) {
|
|
var excludedTerm = excludedTerms[i];
|
|
if (!excluded && new RegExp(term).test(excludedTerm)) {
|
|
excluded = true;
|
|
}
|
|
}
|
|
return excluded;
|
|
}
|
|
"use strict";
|
|
var _$Templater_7 = {
|
|
compile: compile,
|
|
setOptions: __setOptions_7
|
|
};
|
|
var options = {};
|
|
options.pattern = /\{(.*?)\}/g;
|
|
options.template = "";
|
|
options.middleware = function() {};
|
|
function __setOptions_7(_options) {
|
|
options.pattern = _options.pattern || options.pattern;
|
|
options.template = _options.template || options.template;
|
|
if (typeof _options.middleware === "function") {
|
|
options.middleware = _options.middleware;
|
|
}
|
|
}
|
|
function compile(data) {
|
|
return options.template.replace(options.pattern, function(match, prop) {
|
|
var value = options.middleware(prop, data[prop], options.template);
|
|
if (typeof value !== "undefined") {
|
|
return value;
|
|
}
|
|
return data[prop] || match;
|
|
});
|
|
}
|
|
"use strict";
|
|
var _$utils_9 = {
|
|
merge: merge,
|
|
isJSON: isJSON
|
|
};
|
|
function merge(defaultParams, mergeParams) {
|
|
var mergedOptions = {};
|
|
for (var option in defaultParams) {
|
|
if (Object.prototype.hasOwnProperty.call(defaultParams, option)) {
|
|
mergedOptions[option] = defaultParams[option];
|
|
if (typeof mergeParams[option] !== "undefined") {
|
|
mergedOptions[option] = mergeParams[option];
|
|
}
|
|
}
|
|
}
|
|
return mergedOptions;
|
|
}
|
|
function isJSON(json) {
|
|
try {
|
|
if (json instanceof Object && JSON.parse(JSON.stringify(json))) {
|
|
return true;
|
|
}
|
|
return false;
|
|
} catch (err) {
|
|
return false;
|
|
}
|
|
}
|
|
var _$src_8 = {};
|
|
(function(window) {
|
|
"use strict";
|
|
var options = {
|
|
searchInput: null,
|
|
resultsContainer: null,
|
|
json: [],
|
|
success: Function.prototype,
|
|
searchResultTemplate: '<li><a href="{url}" title="{desc}">{title}</a></li>',
|
|
templateMiddleware: Function.prototype,
|
|
sortMiddleware: function() {
|
|
return 0;
|
|
},
|
|
noResultsText: "No results found",
|
|
limit: 10,
|
|
fuzzy: false,
|
|
exclude: []
|
|
};
|
|
var requiredOptions = [ "searchInput", "resultsContainer", "json" ];
|
|
var optionsValidator = _$OptionsValidator_3({
|
|
required: requiredOptions
|
|
});
|
|
window.SimpleJekyllSearch = function(_options) {
|
|
var errors = optionsValidator.validate(_options);
|
|
if (errors.length > 0) {
|
|
throwError("You must specify the following required options: " + requiredOptions);
|
|
}
|
|
options = _$utils_9.merge(options, _options);
|
|
_$Templater_7.setOptions({
|
|
template: options.searchResultTemplate,
|
|
middleware: options.templateMiddleware
|
|
});
|
|
_$Repository_4.setOptions({
|
|
fuzzy: options.fuzzy,
|
|
limit: options.limit,
|
|
sort: options.sortMiddleware
|
|
});
|
|
if (_$utils_9.isJSON(options.json)) {
|
|
initWithJSON(options.json);
|
|
} else {
|
|
initWithURL(options.json);
|
|
}
|
|
return {
|
|
search: search
|
|
};
|
|
};
|
|
window.SimpleJekyllSearch.init = window.SimpleJekyllSearch;
|
|
if (typeof window.SimpleJekyllSearchInit === "function") {
|
|
window.SimpleJekyllSearchInit.call(this, window.SimpleJekyllSearch);
|
|
}
|
|
function initWithJSON(json) {
|
|
options.success(json);
|
|
_$Repository_4.put(json);
|
|
registerInput();
|
|
}
|
|
function initWithURL(url) {
|
|
_$JSONLoader_2.load(url, function(err, json) {
|
|
if (err) {
|
|
throwError("failed to get JSON (" + url + ")");
|
|
}
|
|
initWithJSON(json);
|
|
});
|
|
}
|
|
function emptyResultsContainer() {
|
|
options.resultsContainer.innerHTML = "";
|
|
}
|
|
function appendToResultsContainer(text) {
|
|
options.resultsContainer.innerHTML += text;
|
|
}
|
|
function registerInput() {
|
|
options.searchInput.addEventListener("keyup", function(e) {
|
|
if (isWhitelistedKey(e.which)) {
|
|
emptyResultsContainer();
|
|
search(e.target.value);
|
|
}
|
|
});
|
|
}
|
|
function search(query) {
|
|
if (isValidQuery(query)) {
|
|
emptyResultsContainer();
|
|
render(_$Repository_4.search(query));
|
|
}
|
|
}
|
|
function render(results) {
|
|
var len = results.length;
|
|
if (len === 0) {
|
|
return appendToResultsContainer(options.noResultsText);
|
|
}
|
|
for (var i = 0; i < len; i++) {
|
|
appendToResultsContainer(_$Templater_7.compile(results[i]));
|
|
}
|
|
}
|
|
function isValidQuery(query) {
|
|
return query && query.length > 0;
|
|
}
|
|
function isWhitelistedKey(key) {
|
|
return [ 13, 16, 20, 37, 38, 39, 40, 91 ].indexOf(key) === -1;
|
|
}
|
|
function throwError(message) {
|
|
throw new Error("SimpleJekyllSearch --- " + message);
|
|
}
|
|
})(window);
|
|
})();
|