UNPKG

@cuterajat26/framework7

Version:

Full featured mobile HTML framework for building iOS & Android apps

1,531 lines (1,463 loc) 452 kB
/** * Framework7 4.3.0 * Full featured mobile HTML framework for building iOS & Android apps * http://framework7.io/ * * Copyright 2014-2019 Vladimir Kharlampidi * * Released under the MIT License * * Released on: April 20, 2019 */ (function (global, factory) { typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() : typeof define === 'function' && define.amd ? define(factory) : (global = global || self, global.Framework7 = factory()); }(this, function () { 'use strict'; /** * Template7 1.4.1 * Mobile-first HTML template engine * * http://www.idangero.us/template7/ * * Copyright 2019, Vladimir Kharlampidi * The iDangero.us * http://www.idangero.us/ * * Licensed under MIT * * Released on: February 5, 2019 */ var t7ctx; if (typeof window !== 'undefined') { t7ctx = window; } else if (typeof global !== 'undefined') { t7ctx = global; } else { t7ctx = undefined; } var Template7Context = t7ctx; var Template7Utils = { quoteSingleRexExp: new RegExp('\'', 'g'), quoteDoubleRexExp: new RegExp('"', 'g'), isFunction: function isFunction(func) { return typeof func === 'function'; }, escape: function escape(string) { if ( string === void 0 ) string = ''; return string .replace(/&/g, '&amp;') .replace(/</g, '&lt;') .replace(/>/g, '&gt;') .replace(/"/g, '&quot;') .replace(/'/g, '&#039;'); }, helperToSlices: function helperToSlices(string) { var quoteDoubleRexExp = Template7Utils.quoteDoubleRexExp; var quoteSingleRexExp = Template7Utils.quoteSingleRexExp; var helperParts = string.replace(/[{}#}]/g, '').trim().split(' '); var slices = []; var shiftIndex; var i; var j; for (i = 0; i < helperParts.length; i += 1) { var part = helperParts[i]; var blockQuoteRegExp = (void 0); var openingQuote = (void 0); if (i === 0) { slices.push(part); } else if (part.indexOf('"') === 0 || part.indexOf('\'') === 0) { blockQuoteRegExp = part.indexOf('"') === 0 ? quoteDoubleRexExp : quoteSingleRexExp; openingQuote = part.indexOf('"') === 0 ? '"' : '\''; // Plain String if (part.match(blockQuoteRegExp).length === 2) { // One word string slices.push(part); } else { // Find closed Index shiftIndex = 0; for (j = i + 1; j < helperParts.length; j += 1) { part += " " + (helperParts[j]); if (helperParts[j].indexOf(openingQuote) >= 0) { shiftIndex = j; slices.push(part); break; } } if (shiftIndex) { i = shiftIndex; } } } else if (part.indexOf('=') > 0) { // Hash var hashParts = part.split('='); var hashName = hashParts[0]; var hashContent = hashParts[1]; if (!blockQuoteRegExp) { blockQuoteRegExp = hashContent.indexOf('"') === 0 ? quoteDoubleRexExp : quoteSingleRexExp; openingQuote = hashContent.indexOf('"') === 0 ? '"' : '\''; } if (hashContent.match(blockQuoteRegExp).length !== 2) { shiftIndex = 0; for (j = i + 1; j < helperParts.length; j += 1) { hashContent += " " + (helperParts[j]); if (helperParts[j].indexOf(openingQuote) >= 0) { shiftIndex = j; break; } } if (shiftIndex) { i = shiftIndex; } } var hash = [hashName, hashContent.replace(blockQuoteRegExp, '')]; slices.push(hash); } else { // Plain variable slices.push(part); } } return slices; }, stringToBlocks: function stringToBlocks(string) { var blocks = []; var i; var j; if (!string) { return []; } var stringBlocks = string.split(/({{[^{^}]*}})/); for (i = 0; i < stringBlocks.length; i += 1) { var block = stringBlocks[i]; if (block === '') { continue; } if (block.indexOf('{{') < 0) { blocks.push({ type: 'plain', content: block, }); } else { if (block.indexOf('{/') >= 0) { continue; } block = block .replace(/{{([#/])*([ ])*/, '{{$1') .replace(/([ ])*}}/, '}}'); if (block.indexOf('{#') < 0 && block.indexOf(' ') < 0 && block.indexOf('else') < 0) { // Simple variable blocks.push({ type: 'variable', contextName: block.replace(/[{}]/g, ''), }); continue; } // Helpers var helperSlices = Template7Utils.helperToSlices(block); var helperName = helperSlices[0]; var isPartial = helperName === '>'; var helperContext = []; var helperHash = {}; for (j = 1; j < helperSlices.length; j += 1) { var slice = helperSlices[j]; if (Array.isArray(slice)) { // Hash helperHash[slice[0]] = slice[1] === 'false' ? false : slice[1]; } else { helperContext.push(slice); } } if (block.indexOf('{#') >= 0) { // Condition/Helper var helperContent = ''; var elseContent = ''; var toSkip = 0; var shiftIndex = (void 0); var foundClosed = false; var foundElse = false; var depth = 0; for (j = i + 1; j < stringBlocks.length; j += 1) { if (stringBlocks[j].indexOf('{{#') >= 0) { depth += 1; } if (stringBlocks[j].indexOf('{{/') >= 0) { depth -= 1; } if (stringBlocks[j].indexOf(("{{#" + helperName)) >= 0) { helperContent += stringBlocks[j]; if (foundElse) { elseContent += stringBlocks[j]; } toSkip += 1; } else if (stringBlocks[j].indexOf(("{{/" + helperName)) >= 0) { if (toSkip > 0) { toSkip -= 1; helperContent += stringBlocks[j]; if (foundElse) { elseContent += stringBlocks[j]; } } else { shiftIndex = j; foundClosed = true; break; } } else if (stringBlocks[j].indexOf('else') >= 0 && depth === 0) { foundElse = true; } else { if (!foundElse) { helperContent += stringBlocks[j]; } if (foundElse) { elseContent += stringBlocks[j]; } } } if (foundClosed) { if (shiftIndex) { i = shiftIndex; } if (helperName === 'raw') { blocks.push({ type: 'plain', content: helperContent, }); } else { blocks.push({ type: 'helper', helperName: helperName, contextName: helperContext, content: helperContent, inverseContent: elseContent, hash: helperHash, }); } } } else if (block.indexOf(' ') > 0) { if (isPartial) { helperName = '_partial'; if (helperContext[0]) { if (helperContext[0].indexOf('[') === 0) { helperContext[0] = helperContext[0].replace(/[[\]]/g, ''); } else { helperContext[0] = "\"" + (helperContext[0].replace(/"|'/g, '')) + "\""; } } } blocks.push({ type: 'helper', helperName: helperName, contextName: helperContext, hash: helperHash, }); } } } return blocks; }, parseJsVariable: function parseJsVariable(expression, replace, object) { return expression.split(/([+ \-*/^()&=|<>!%:?])/g).reduce(function (arr, part) { if (!part) { return arr; } if (part.indexOf(replace) < 0) { arr.push(part); return arr; } if (!object) { arr.push(JSON.stringify('')); return arr; } var variable = object; if (part.indexOf((replace + ".")) >= 0) { part.split((replace + "."))[1].split('.').forEach(function (partName) { if (partName in variable) { variable = variable[partName]; } else { variable = undefined; } }); } if (typeof variable === 'string') { variable = JSON.stringify(variable); } if (variable === undefined) { variable = 'undefined'; } arr.push(variable); return arr; }, []).join(''); }, parseJsParents: function parseJsParents(expression, parents) { return expression.split(/([+ \-*^()&=|<>!%:?])/g).reduce(function (arr, part) { if (!part) { return arr; } if (part.indexOf('../') < 0) { arr.push(part); return arr; } if (!parents || parents.length === 0) { arr.push(JSON.stringify('')); return arr; } var levelsUp = part.split('../').length - 1; var parentData = levelsUp > parents.length ? parents[parents.length - 1] : parents[levelsUp - 1]; var variable = parentData; var parentPart = part.replace(/..\//g, ''); parentPart.split('.').forEach(function (partName) { if (typeof variable[partName] !== 'undefined') { variable = variable[partName]; } else { variable = 'undefined'; } }); if (variable === false || variable === true) { arr.push(JSON.stringify(variable)); return arr; } if (variable === null || variable === 'undefined') { arr.push(JSON.stringify('')); return arr; } arr.push(JSON.stringify(variable)); return arr; }, []).join(''); }, getCompileVar: function getCompileVar(name, ctx, data) { if ( data === void 0 ) data = 'data_1'; var variable = ctx; var parts; var levelsUp = 0; var newDepth; if (name.indexOf('../') === 0) { levelsUp = name.split('../').length - 1; newDepth = variable.split('_')[1] - levelsUp; variable = "ctx_" + (newDepth >= 1 ? newDepth : 1); parts = name.split('../')[levelsUp].split('.'); } else if (name.indexOf('@global') === 0) { variable = 'Template7.global'; parts = name.split('@global.')[1].split('.'); } else if (name.indexOf('@root') === 0) { variable = 'root'; parts = name.split('@root.')[1].split('.'); } else { parts = name.split('.'); } for (var i = 0; i < parts.length; i += 1) { var part = parts[i]; if (part.indexOf('@') === 0) { var dataLevel = data.split('_')[1]; if (levelsUp > 0) { dataLevel = newDepth; } if (i > 0) { variable += "[(data_" + dataLevel + " && data_" + dataLevel + "." + (part.replace('@', '')) + ")]"; } else { variable = "(data_" + dataLevel + " && data_" + dataLevel + "." + (part.replace('@', '')) + ")"; } } else if (Number.isFinite ? Number.isFinite(part) : Template7Context.isFinite(part)) { variable += "[" + part + "]"; } else if (part === 'this' || part.indexOf('this.') >= 0 || part.indexOf('this[') >= 0 || part.indexOf('this(') >= 0) { variable = part.replace('this', ctx); } else { variable += "." + part; } } return variable; }, getCompiledArguments: function getCompiledArguments(contextArray, ctx, data) { var arr = []; for (var i = 0; i < contextArray.length; i += 1) { if (/^['"]/.test(contextArray[i])) { arr.push(contextArray[i]); } else if (/^(true|false|\d+)$/.test(contextArray[i])) { arr.push(contextArray[i]); } else { arr.push(Template7Utils.getCompileVar(contextArray[i], ctx, data)); } } return arr.join(', '); }, }; /* eslint no-eval: "off" */ var Template7Helpers = { _partial: function _partial(partialName, options) { var ctx = this; var p = Template7Class.partials[partialName]; if (!p || (p && !p.template)) { return ''; } if (!p.compiled) { p.compiled = new Template7Class(p.template).compile(); } Object.keys(options.hash).forEach(function (hashName) { ctx[hashName] = options.hash[hashName]; }); return p.compiled(ctx, options.data, options.root); }, escape: function escape(context) { if (typeof context !== 'string') { throw new Error('Template7: Passed context to "escape" helper should be a string'); } return Template7Utils.escape(context); }, if: function if$1(context, options) { var ctx = context; if (Template7Utils.isFunction(ctx)) { ctx = ctx.call(this); } if (ctx) { return options.fn(this, options.data); } return options.inverse(this, options.data); }, unless: function unless(context, options) { var ctx = context; if (Template7Utils.isFunction(ctx)) { ctx = ctx.call(this); } if (!ctx) { return options.fn(this, options.data); } return options.inverse(this, options.data); }, each: function each(context, options) { var ctx = context; var ret = ''; var i = 0; if (Template7Utils.isFunction(ctx)) { ctx = ctx.call(this); } if (Array.isArray(ctx)) { if (options.hash.reverse) { ctx = ctx.reverse(); } for (i = 0; i < ctx.length; i += 1) { ret += options.fn(ctx[i], { first: i === 0, last: i === ctx.length - 1, index: i }); } if (options.hash.reverse) { ctx = ctx.reverse(); } } else { // eslint-disable-next-line for (var key in ctx) { i += 1; ret += options.fn(ctx[key], { key: key }); } } if (i > 0) { return ret; } return options.inverse(this); }, with: function with$1(context, options) { var ctx = context; if (Template7Utils.isFunction(ctx)) { ctx = context.call(this); } return options.fn(ctx); }, join: function join(context, options) { var ctx = context; if (Template7Utils.isFunction(ctx)) { ctx = ctx.call(this); } return ctx.join(options.hash.delimiter || options.hash.delimeter); }, js: function js(expression, options) { var data = options.data; var func; var execute = expression; ('index first last key').split(' ').forEach(function (prop) { if (typeof data[prop] !== 'undefined') { var re1 = new RegExp(("this.@" + prop), 'g'); var re2 = new RegExp(("@" + prop), 'g'); execute = execute .replace(re1, JSON.stringify(data[prop])) .replace(re2, JSON.stringify(data[prop])); } }); if (options.root && execute.indexOf('@root') >= 0) { execute = Template7Utils.parseJsVariable(execute, '@root', options.root); } if (execute.indexOf('@global') >= 0) { execute = Template7Utils.parseJsVariable(execute, '@global', Template7Context.Template7.global); } if (execute.indexOf('../') >= 0) { execute = Template7Utils.parseJsParents(execute, options.parents); } if (execute.indexOf('return') >= 0) { func = "(function(){" + execute + "})"; } else { func = "(function(){return (" + execute + ")})"; } return eval(func).call(this); }, js_if: function js_if(expression, options) { var data = options.data; var func; var execute = expression; ('index first last key').split(' ').forEach(function (prop) { if (typeof data[prop] !== 'undefined') { var re1 = new RegExp(("this.@" + prop), 'g'); var re2 = new RegExp(("@" + prop), 'g'); execute = execute .replace(re1, JSON.stringify(data[prop])) .replace(re2, JSON.stringify(data[prop])); } }); if (options.root && execute.indexOf('@root') >= 0) { execute = Template7Utils.parseJsVariable(execute, '@root', options.root); } if (execute.indexOf('@global') >= 0) { execute = Template7Utils.parseJsVariable(execute, '@global', Template7Context.Template7.global); } if (execute.indexOf('../') >= 0) { execute = Template7Utils.parseJsParents(execute, options.parents); } if (execute.indexOf('return') >= 0) { func = "(function(){" + execute + "})"; } else { func = "(function(){return (" + execute + ")})"; } var condition = eval(func).call(this); if (condition) { return options.fn(this, options.data); } return options.inverse(this, options.data); }, }; Template7Helpers.js_compare = Template7Helpers.js_if; var Template7Options = {}; var Template7Partials = {}; var Template7Class = function Template7Class(template) { var t = this; t.template = template; }; var staticAccessors = { options: { configurable: true },partials: { configurable: true },helpers: { configurable: true } }; Template7Class.prototype.compile = function compile (template, depth) { if ( template === void 0 ) template = this.template; if ( depth === void 0 ) depth = 1; var t = this; if (t.compiled) { return t.compiled; } if (typeof template !== 'string') { throw new Error('Template7: Template must be a string'); } var stringToBlocks = Template7Utils.stringToBlocks; var getCompileVar = Template7Utils.getCompileVar; var getCompiledArguments = Template7Utils.getCompiledArguments; var blocks = stringToBlocks(template); var ctx = "ctx_" + depth; var data = "data_" + depth; if (blocks.length === 0) { return function empty() { return ''; }; } function getCompileFn(block, newDepth) { if (block.content) { return t.compile(block.content, newDepth); } return function empty() { return ''; }; } function getCompileInverse(block, newDepth) { if (block.inverseContent) { return t.compile(block.inverseContent, newDepth); } return function empty() { return ''; }; } var resultString = ''; if (depth === 1) { resultString += "(function (" + ctx + ", " + data + ", root) {\n"; } else { resultString += "(function (" + ctx + ", " + data + ") {\n"; } if (depth === 1) { resultString += 'function isArray(arr){return Array.isArray(arr);}\n'; resultString += 'function isFunction(func){return (typeof func === \'function\');}\n'; resultString += 'function c(val, ctx) {if (typeof val !== "undefined" && val !== null) {if (isFunction(val)) {return val.call(ctx);} else return val;} else return "";}\n'; resultString += 'root = root || ctx_1 || {};\n'; } resultString += 'var r = \'\';\n'; var i; for (i = 0; i < blocks.length; i += 1) { var block = blocks[i]; // Plain block if (block.type === 'plain') { // eslint-disable-next-line resultString += "r +='" + ((block.content).replace(/\r/g, '\\r').replace(/\n/g, '\\n').replace(/'/g, '\\' + '\'')) + "';"; continue; } var variable = (void 0); var compiledArguments = (void 0); // Variable block if (block.type === 'variable') { variable = getCompileVar(block.contextName, ctx, data); resultString += "r += c(" + variable + ", " + ctx + ");"; } // Helpers block if (block.type === 'helper') { var parents = (void 0); if (ctx !== 'ctx_1') { var level = ctx.split('_')[1]; var parentsString = "ctx_" + (level - 1); for (var j = level - 2; j >= 1; j -= 1) { parentsString += ", ctx_" + j; } parents = "[" + parentsString + "]"; } else { parents = "[" + ctx + "]"; } var dynamicHelper = (void 0); if (block.helperName.indexOf('[') === 0) { block.helperName = getCompileVar(block.helperName.replace(/[[\]]/g, ''), ctx, data); dynamicHelper = true; } if (dynamicHelper || block.helperName in Template7Helpers) { compiledArguments = getCompiledArguments(block.contextName, ctx, data); resultString += "r += (Template7Helpers" + (dynamicHelper ? ("[" + (block.helperName) + "]") : ("." + (block.helperName))) + ").call(" + ctx + ", " + (compiledArguments && ((compiledArguments + ", "))) + "{hash:" + (JSON.stringify(block.hash)) + ", data: " + data + " || {}, fn: " + (getCompileFn(block, depth + 1)) + ", inverse: " + (getCompileInverse(block, depth + 1)) + ", root: root, parents: " + parents + "});"; } else if (block.contextName.length > 0) { throw new Error(("Template7: Missing helper: \"" + (block.helperName) + "\"")); } else { variable = getCompileVar(block.helperName, ctx, data); resultString += "if (" + variable + ") {"; resultString += "if (isArray(" + variable + ")) {"; resultString += "r += (Template7Helpers.each).call(" + ctx + ", " + variable + ", {hash:" + (JSON.stringify(block.hash)) + ", data: " + data + " || {}, fn: " + (getCompileFn(block, depth + 1)) + ", inverse: " + (getCompileInverse(block, depth + 1)) + ", root: root, parents: " + parents + "});"; resultString += '}else {'; resultString += "r += (Template7Helpers.with).call(" + ctx + ", " + variable + ", {hash:" + (JSON.stringify(block.hash)) + ", data: " + data + " || {}, fn: " + (getCompileFn(block, depth + 1)) + ", inverse: " + (getCompileInverse(block, depth + 1)) + ", root: root, parents: " + parents + "});"; resultString += '}}'; } } } resultString += '\nreturn r;})'; if (depth === 1) { // eslint-disable-next-line t.compiled = eval(resultString); return t.compiled; } return resultString; }; staticAccessors.options.get = function () { return Template7Options; }; staticAccessors.partials.get = function () { return Template7Partials; }; staticAccessors.helpers.get = function () { return Template7Helpers; }; Object.defineProperties( Template7Class, staticAccessors ); function Template7() { var args = [], len = arguments.length; while ( len-- ) args[ len ] = arguments[ len ]; var template = args[0]; var data = args[1]; if (args.length === 2) { var instance = new Template7Class(template); var rendered = instance.compile()(data); instance = null; return (rendered); } return new Template7Class(template); } Template7.registerHelper = function registerHelper(name, fn) { Template7Class.helpers[name] = fn; }; Template7.unregisterHelper = function unregisterHelper(name) { Template7Class.helpers[name] = undefined; delete Template7Class.helpers[name]; }; Template7.registerPartial = function registerPartial(name, template) { Template7Class.partials[name] = { template: template }; }; Template7.unregisterPartial = function unregisterPartial(name) { if (Template7Class.partials[name]) { Template7Class.partials[name] = undefined; delete Template7Class.partials[name]; } }; Template7.compile = function compile(template, options) { var instance = new Template7Class(template, options); return instance.compile(); }; Template7.options = Template7Class.options; Template7.helpers = Template7Class.helpers; Template7.partials = Template7Class.partials; /** * SSR Window 1.0.1 * Better handling for window object in SSR environment * https://github.com/nolimits4web/ssr-window * * Copyright 2018, Vladimir Kharlampidi * * Licensed under MIT * * Released on: July 18, 2018 */ var doc = (typeof document === 'undefined') ? { body: {}, addEventListener: function addEventListener() {}, removeEventListener: function removeEventListener() {}, activeElement: { blur: function blur() {}, nodeName: '', }, querySelector: function querySelector() { return null; }, querySelectorAll: function querySelectorAll() { return []; }, getElementById: function getElementById() { return null; }, createEvent: function createEvent() { return { initEvent: function initEvent() {}, }; }, createElement: function createElement() { return { children: [], childNodes: [], style: {}, setAttribute: function setAttribute() {}, getElementsByTagName: function getElementsByTagName() { return []; }, }; }, location: { hash: '' }, } : document; // eslint-disable-line var win = (typeof window === 'undefined') ? { document: doc, navigator: { userAgent: '', }, location: {}, history: {}, CustomEvent: function CustomEvent() { return this; }, addEventListener: function addEventListener() {}, removeEventListener: function removeEventListener() {}, getComputedStyle: function getComputedStyle() { return { getPropertyValue: function getPropertyValue() { return ''; }, }; }, Image: function Image() {}, Date: function Date() {}, screen: {}, setTimeout: function setTimeout() {}, clearTimeout: function clearTimeout() {}, } : window; // eslint-disable-line /** * Dom7 2.1.3 * Minimalistic JavaScript library for DOM manipulation, with a jQuery-compatible API * http://framework7.io/docs/dom.html * * Copyright 2019, Vladimir Kharlampidi * The iDangero.us * http://www.idangero.us/ * * Licensed under MIT * * Released on: February 11, 2019 */ var Dom7 = function Dom7(arr) { var self = this; // Create array-like object for (var i = 0; i < arr.length; i += 1) { self[i] = arr[i]; } self.length = arr.length; // Return collection with methods return this; }; function $(selector, context) { var arr = []; var i = 0; if (selector && !context) { if (selector instanceof Dom7) { return selector; } } if (selector) { // String if (typeof selector === 'string') { var els; var tempParent; var html = selector.trim(); if (html.indexOf('<') >= 0 && html.indexOf('>') >= 0) { var toCreate = 'div'; if (html.indexOf('<li') === 0) { toCreate = 'ul'; } if (html.indexOf('<tr') === 0) { toCreate = 'tbody'; } if (html.indexOf('<td') === 0 || html.indexOf('<th') === 0) { toCreate = 'tr'; } if (html.indexOf('<tbody') === 0) { toCreate = 'table'; } if (html.indexOf('<option') === 0) { toCreate = 'select'; } tempParent = doc.createElement(toCreate); tempParent.innerHTML = html; for (i = 0; i < tempParent.childNodes.length; i += 1) { arr.push(tempParent.childNodes[i]); } } else { if (!context && selector[0] === '#' && !selector.match(/[ .<>:~]/)) { // Pure ID selector els = [doc.getElementById(selector.trim().split('#')[1])]; } else { // Other selectors els = (context || doc).querySelectorAll(selector.trim()); } for (i = 0; i < els.length; i += 1) { if (els[i]) { arr.push(els[i]); } } } } else if (selector.nodeType || selector === win || selector === doc) { // Node/element arr.push(selector); } else if (selector.length > 0 && selector[0].nodeType) { // Array of elements or instance of Dom for (i = 0; i < selector.length; i += 1) { arr.push(selector[i]); } } } return new Dom7(arr); } $.fn = Dom7.prototype; $.Class = Dom7; $.Dom7 = Dom7; function unique(arr) { var uniqueArray = []; for (var i = 0; i < arr.length; i += 1) { if (uniqueArray.indexOf(arr[i]) === -1) { uniqueArray.push(arr[i]); } } return uniqueArray; } function toCamelCase(string) { return string.toLowerCase().replace(/-(.)/g, function (match, group1) { return group1.toUpperCase(); }); } function requestAnimationFrame(callback) { if (win.requestAnimationFrame) { return win.requestAnimationFrame(callback); } else if (win.webkitRequestAnimationFrame) { return win.webkitRequestAnimationFrame(callback); } return win.setTimeout(callback, 1000 / 60); } function cancelAnimationFrame(id) { if (win.cancelAnimationFrame) { return win.cancelAnimationFrame(id); } else if (win.webkitCancelAnimationFrame) { return win.webkitCancelAnimationFrame(id); } return win.clearTimeout(id); } // Classes and attributes function addClass(className) { if (typeof className === 'undefined') { return this; } var classes = className.split(' '); for (var i = 0; i < classes.length; i += 1) { for (var j = 0; j < this.length; j += 1) { if (typeof this[j] !== 'undefined' && typeof this[j].classList !== 'undefined') { this[j].classList.add(classes[i]); } } } return this; } function removeClass(className) { var classes = className.split(' '); for (var i = 0; i < classes.length; i += 1) { for (var j = 0; j < this.length; j += 1) { if (typeof this[j] !== 'undefined' && typeof this[j].classList !== 'undefined') { this[j].classList.remove(classes[i]); } } } return this; } function hasClass(className) { if (!this[0]) { return false; } return this[0].classList.contains(className); } function toggleClass(className) { var classes = className.split(' '); for (var i = 0; i < classes.length; i += 1) { for (var j = 0; j < this.length; j += 1) { if (typeof this[j] !== 'undefined' && typeof this[j].classList !== 'undefined') { this[j].classList.toggle(classes[i]); } } } return this; } function attr(attrs, value) { var arguments$1 = arguments; if (arguments.length === 1 && typeof attrs === 'string') { // Get attr if (this[0]) { return this[0].getAttribute(attrs); } return undefined; } // Set attrs for (var i = 0; i < this.length; i += 1) { if (arguments$1.length === 2) { // String this[i].setAttribute(attrs, value); } else { // Object // eslint-disable-next-line for (var attrName in attrs) { this[i][attrName] = attrs[attrName]; this[i].setAttribute(attrName, attrs[attrName]); } } } return this; } // eslint-disable-next-line function removeAttr(attr) { for (var i = 0; i < this.length; i += 1) { this[i].removeAttribute(attr); } return this; } // eslint-disable-next-line function prop(props, value) { var arguments$1 = arguments; if (arguments.length === 1 && typeof props === 'string') { // Get prop if (this[0]) { return this[0][props]; } } else { // Set props for (var i = 0; i < this.length; i += 1) { if (arguments$1.length === 2) { // String this[i][props] = value; } else { // Object // eslint-disable-next-line for (var propName in props) { this[i][propName] = props[propName]; } } } return this; } } function data(key, value) { var el; if (typeof value === 'undefined') { el = this[0]; // Get value if (el) { if (el.dom7ElementDataStorage && (key in el.dom7ElementDataStorage)) { return el.dom7ElementDataStorage[key]; } var dataKey = el.getAttribute(("data-" + key)); if (dataKey) { return dataKey; } return undefined; } return undefined; } // Set value for (var i = 0; i < this.length; i += 1) { el = this[i]; if (!el.dom7ElementDataStorage) { el.dom7ElementDataStorage = {}; } el.dom7ElementDataStorage[key] = value; } return this; } function removeData(key) { for (var i = 0; i < this.length; i += 1) { var el = this[i]; if (el.dom7ElementDataStorage && el.dom7ElementDataStorage[key]) { el.dom7ElementDataStorage[key] = null; delete el.dom7ElementDataStorage[key]; } } } function dataset() { var el = this[0]; if (!el) { return undefined; } var dataset = {}; // eslint-disable-line if (el.dataset) { // eslint-disable-next-line for (var dataKey in el.dataset) { dataset[dataKey] = el.dataset[dataKey]; } } else { for (var i = 0; i < el.attributes.length; i += 1) { // eslint-disable-next-line var attr = el.attributes[i]; if (attr.name.indexOf('data-') >= 0) { dataset[toCamelCase(attr.name.split('data-')[1])] = attr.value; } } } // eslint-disable-next-line for (var key in dataset) { if (dataset[key] === 'false') { dataset[key] = false; } else if (dataset[key] === 'true') { dataset[key] = true; } else if (parseFloat(dataset[key]) === dataset[key] * 1) { dataset[key] *= 1; } } return dataset; } function val(value) { var dom = this; if (typeof value === 'undefined') { if (dom[0]) { if (dom[0].multiple && dom[0].nodeName.toLowerCase() === 'select') { var values = []; for (var i = 0; i < dom[0].selectedOptions.length; i += 1) { values.push(dom[0].selectedOptions[i].value); } return values; } return dom[0].value; } return undefined; } for (var i$1 = 0; i$1 < dom.length; i$1 += 1) { var el = dom[i$1]; if (Array.isArray(value) && el.multiple && el.nodeName.toLowerCase() === 'select') { for (var j = 0; j < el.options.length; j += 1) { el.options[j].selected = value.indexOf(el.options[j].value) >= 0; } } else { el.value = value; } } return dom; } // Transforms // eslint-disable-next-line function transform(transform) { for (var i = 0; i < this.length; i += 1) { var elStyle = this[i].style; elStyle.webkitTransform = transform; elStyle.transform = transform; } return this; } function transition(duration) { if (typeof duration !== 'string') { duration = duration + "ms"; // eslint-disable-line } for (var i = 0; i < this.length; i += 1) { var elStyle = this[i].style; elStyle.webkitTransitionDuration = duration; elStyle.transitionDuration = duration; } return this; } // Events function on() { var assign; var args = [], len = arguments.length; while ( len-- ) args[ len ] = arguments[ len ]; var eventType = args[0]; var targetSelector = args[1]; var listener = args[2]; var capture = args[3]; if (typeof args[1] === 'function') { (assign = args, eventType = assign[0], listener = assign[1], capture = assign[2]); targetSelector = undefined; } if (!capture) { capture = false; } function handleLiveEvent(e) { var target = e.target; if (!target) { return; } var eventData = e.target.dom7EventData || []; if (eventData.indexOf(e) < 0) { eventData.unshift(e); } if ($(target).is(targetSelector)) { listener.apply(target, eventData); } else { var parents = $(target).parents(); // eslint-disable-line for (var k = 0; k < parents.length; k += 1) { if ($(parents[k]).is(targetSelector)) { listener.apply(parents[k], eventData); } } } } function handleEvent(e) { var eventData = e && e.target ? e.target.dom7EventData || [] : []; if (eventData.indexOf(e) < 0) { eventData.unshift(e); } listener.apply(this, eventData); } var events = eventType.split(' '); var j; for (var i = 0; i < this.length; i += 1) { var el = this[i]; if (!targetSelector) { for (j = 0; j < events.length; j += 1) { var event = events[j]; if (!el.dom7Listeners) { el.dom7Listeners = {}; } if (!el.dom7Listeners[event]) { el.dom7Listeners[event] = []; } el.dom7Listeners[event].push({ listener: listener, proxyListener: handleEvent, }); el.addEventListener(event, handleEvent, capture); } } else { // Live events for (j = 0; j < events.length; j += 1) { var event$1 = events[j]; if (!el.dom7LiveListeners) { el.dom7LiveListeners = {}; } if (!el.dom7LiveListeners[event$1]) { el.dom7LiveListeners[event$1] = []; } el.dom7LiveListeners[event$1].push({ listener: listener, proxyListener: handleLiveEvent, }); el.addEventListener(event$1, handleLiveEvent, capture); } } } return this; } function off() { var assign; var args = [], len = arguments.length; while ( len-- ) args[ len ] = arguments[ len ]; var eventType = args[0]; var targetSelector = args[1]; var listener = args[2]; var capture = args[3]; if (typeof args[1] === 'function') { (assign = args, eventType = assign[0], listener = assign[1], capture = assign[2]); targetSelector = undefined; } if (!capture) { capture = false; } var events = eventType.split(' '); for (var i = 0; i < events.length; i += 1) { var event = events[i]; for (var j = 0; j < this.length; j += 1) { var el = this[j]; var handlers = (void 0); if (!targetSelector && el.dom7Listeners) { handlers = el.dom7Listeners[event]; } else if (targetSelector && el.dom7LiveListeners) { handlers = el.dom7LiveListeners[event]; } if (handlers && handlers.length) { for (var k = handlers.length - 1; k >= 0; k -= 1) { var handler = handlers[k]; if (listener && handler.listener === listener) { el.removeEventListener(event, handler.proxyListener, capture); handlers.splice(k, 1); } else if (listener && handler.listener && handler.listener.dom7proxy && handler.listener.dom7proxy === listener) { el.removeEventListener(event, handler.proxyListener, capture); handlers.splice(k, 1); } else if (!listener) { el.removeEventListener(event, handler.proxyListener, capture); handlers.splice(k, 1); } } } } } return this; } function once() { var assign; var args = [], len = arguments.length; while ( len-- ) args[ len ] = arguments[ len ]; var dom = this; var eventName = args[0]; var targetSelector = args[1]; var listener = args[2]; var capture = args[3]; if (typeof args[1] === 'function') { (assign = args, eventName = assign[0], listener = assign[1], capture = assign[2]); targetSelector = undefined; } function onceHandler() { var eventArgs = [], len = arguments.length; while ( len-- ) eventArgs[ len ] = arguments[ len ]; listener.apply(this, eventArgs); dom.off(eventName, targetSelector, onceHandler, capture); if (onceHandler.dom7proxy) { delete onceHandler.dom7proxy; } } onceHandler.dom7proxy = listener; return dom.on(eventName, targetSelector, onceHandler, capture); } function trigger() { var args = [], len = arguments.length; while ( len-- ) args[ len ] = arguments[ len ]; var events = args[0].split(' '); var eventData = args[1]; for (var i = 0; i < events.length; i += 1) { var event = events[i]; for (var j = 0; j < this.length; j += 1) { var el = this[j]; var evt = (void 0); try { evt = new win.CustomEvent(event, { detail: eventData, bubbles: true, cancelable: true, }); } catch (e) { evt = doc.createEvent('Event'); evt.initEvent(event, true, true); evt.detail = eventData; } // eslint-disable-next-line el.dom7EventData = args.filter(function (data, dataIndex) { return dataIndex > 0; }); el.dispatchEvent(evt); el.dom7EventData = []; delete el.dom7EventData; } } return this; } function transitionEnd(callback) { var events = ['webkitTransitionEnd', 'transitionend']; var dom = this; var i; function fireCallBack(e) { /* jshint validthis:true */ if (e.target !== this) { return; } callback.call(this, e); for (i = 0; i < events.length; i += 1) { dom.off(events[i], fireCallBack); } } if (callback) { for (i = 0; i < events.length; i += 1) { dom.on(events[i], fireCallBack); } } return this; } function animationEnd(callback) { var events = ['webkitAnimationEnd', 'animationend']; var dom = this; var i; function fireCallBack(e) { if (e.target !== this) { return; } callback.call(this, e); for (i = 0; i < events.length; i += 1) { dom.off(events[i], fireCallBack); } } if (callback) { for (i = 0; i < events.length; i += 1) { dom.on(events[i], fireCallBack); } } return this; } // Sizing/Styles function width() { if (this[0] === win) { return win.innerWidth; } if (this.length > 0) { return parseFloat(this.css('width')); } return null; } function outerWidth(includeMargins) { if (this.length > 0) { if (includeMargins) { // eslint-disable-next-line var styles = this.styles(); return this[0].offsetWidth + parseFloat(styles.getPropertyValue('margin-right')) + parseFloat(styles.getPropertyValue('margin-left')); } return this[0].offsetWidth; } return null; } function height() { if (this[0] === win) { return win.innerHeight; } if (this.length > 0) { return parseFloat(this.css('height')); } return null; } function outerHeight(includeMargins) { if (this.length > 0) { if (includeMargins) { // eslint-disable-next-line var styles = this.styles(); return this[0].offsetHeight + parseFloat(styles.getPropertyValue('margin-top')) + parseFloat(styles.getPropertyValue('margin-bottom')); } return this[0].offsetHeight; } return null; } function offset() { if (this.length > 0) { var el = this[0]; var box = el.getBoundingClientRect(); var body = doc.body; var clientTop = el.clientTop || body.clientTop || 0; var clientLeft = el.clientLeft || body.clientLeft || 0; var scrollTop = el === win ? win.scrollY : el.scrollTop; var scrollLeft = el === win ? win.scrollX : el.scrollLeft; return { top: (box.top + scrollTop) - clientTop, left: (box.left + scrollLeft) - clientLeft, }; } return null; } function hide() { for (var i = 0; i < this.length; i += 1) { this[i].style.display = 'none'; } return this; } function show() { for (var i = 0; i < this.length; i += 1) { var el = this[i]; if (el.style.display === 'none') { el.style.display = ''; } if (win.getComputedStyle(el, null).getPropertyValue('display') === 'none') { // Still not visible el.style.display = 'block'; } } return this; } function styles() { if (this[0]) { return win.getComputedStyle(this[0], null); } return {}; } function css(props, value) { var i; if (arguments.length === 1) { if (typeof props === 'string') { if (this[0]) { return win.getComputedStyle(this[0], null).getPropertyValue(props); } } else { for (i = 0; i < this.length; i += 1) { // eslint-disable-next-line for (var prop in props) { this[i].style[prop] = props[prop]; } } return this; } } if (arguments.length === 2 && typeof props === 'string') { for (i = 0; i < this.length; i += 1) { this[i].style[props] = value; } return this; } return this; } // Dom manipulation function toArray() { var arr = []; for (var i = 0; i < this.length; i += 1) { arr.push(this[i]); } return arr; } // Iterate over the collection passing elements to `callback` function each(callback) { // Don't bother continuing without a callback if (!callback) { return this; } // Iterate over the current collection for (var i = 0; i < this.length; i += 1) { // If the callback returns false if (callback.call(this[i], i, this[i]) === false) { // End the loop early return this; } } // Return `this` to allow chained DOM operations return this; } function forEach(callback) { // Don't bother continuing without a callback if (!callback) { return this; } // Iterate over the current collection for (var i = 0; i < this.length; i += 1) { // If the callback returns false if (callback.call(this[i], this[i], i) === false) { // End the loop early return this; } } // Return `this` to allow chained DOM operations return this; } function filter(callback) { var matchedItems = []; var dom = this; for (var i = 0; i < dom.length; i += 1) { if (callback.call(dom[i], i, dom[i])) { matchedItems.push(dom[i]); } } return new Dom7(matchedItems); } function map(callback) { var modifiedItems = []; var dom = this; for (var i = 0; i < dom.length; i += 1) { modifiedItems.push(callback.call(dom[i], i, dom[i])); } return new Dom7(modifiedItems); } // eslint-disable-next-line function html(html) { if (typeof html === 'undefined') { return this[0] ? this[0].innerHTML : undefined; } for (var i = 0; i < this.length; i += 1) { this[i].innerHTML = html; } return this; } // eslint-disable-next-line function text(text) { if (typeof text === 'undefined') { if (this[0]) { return this[0].textContent.trim(); } return null; } for (var i = 0; i < this.length; i += 1) { this[i].textContent = text; } return this; } function is(selector) { var el = this[0]; var compareWith; var i; if (!el || typeof selector === 'undefined') { return false; } if (typeof selector === 'string') { if (el.matches) { return el.matches(selector); } else if (el.webkitMatchesSelector) { return el.webkitMatchesSelector(selector); } else if (el.msMatchesSelector) { return el.msMatchesSelector(selector); } compareWith = $(selector); for (i = 0; i < compareWith.length; i += 1) { if (compareWith[i] === el) { return true; } } return false; } else if (selector === doc) { return el === doc; } else if (selector === win) { return el === win; } if (selector.nodeType || selector instanceof Dom7) { compareWith = selector.nodeType ? [selector] : selector; for (i = 0; i < compareWith.length; i += 1) { if (compareWith[i] === el) { return true; } } return false; } return false; } function indexOf(el) { for (var i = 0; i < this.length; i += 1) { if (this[i] === el) { return i; } } return -1; } function index() { var child = this[0]; var i; if (child) { i = 0; // eslint-disable-next-line while ((child = child.previousSibling) !== null) { if (child.nodeType === 1) { i += 1; } } return i; } return undefined; } // eslint-disable-next-line function eq(index) { if (typeof index === 'undefined') { return this; } var length = this.length; var returnIndex; if (index > length - 1) { return new Dom7([]); } if (index < 0) { returnIndex = length + index; if (returnIndex < 0) { return new Dom7([]); } return new Dom7([this[returnIndex]]); } return new Dom7([this[index]]); } function append() { var args = [], len = arguments.length; while ( len-- ) args[ len ] = arguments[ len ]; var newChild; for (var k = 0; k < args.length; k += 1) { newChild = args[k]; for (var i = 0; i < this.length; i += 1) { if (typeof newChild === 'string') { var tempDiv = doc.createElement('div'); tempDiv.innerHTML = newChild; while (tempDiv.firstChild) { this[i].appendChild(tempDiv.firstChild); } } else if (newChild instanceof Dom7) { for (var j = 0; j < newChild.length; j += 1) { this[i].appendChild(newChild[j]); } } else { this[i].appendChild(newChild); } } } return this; } // eslint-disable-next-line function appendTo(parent) { $(pa