| (this.nativeLog || function(s) {console.log(s)})('START WEEX HTML5: 0.2.6'); |
| /******/ (function(modules) { // webpackBootstrap |
| /******/ // The module cache |
| /******/ var installedModules = {}; |
| /******/ |
| /******/ // The require function |
| /******/ function __webpack_require__(moduleId) { |
| /******/ |
| /******/ // Check if module is in cache |
| /******/ if(installedModules[moduleId]) |
| /******/ return installedModules[moduleId].exports; |
| /******/ |
| /******/ // Create a new module (and put it into the cache) |
| /******/ var module = installedModules[moduleId] = { |
| /******/ exports: {}, |
| /******/ id: moduleId, |
| /******/ loaded: false |
| /******/ }; |
| /******/ |
| /******/ // Execute the module function |
| /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); |
| /******/ |
| /******/ // Flag the module as loaded |
| /******/ module.loaded = true; |
| /******/ |
| /******/ // Return the exports of the module |
| /******/ return module.exports; |
| /******/ } |
| /******/ |
| /******/ |
| /******/ // expose the modules object (__webpack_modules__) |
| /******/ __webpack_require__.m = modules; |
| /******/ |
| /******/ // expose the module cache |
| /******/ __webpack_require__.c = installedModules; |
| /******/ |
| /******/ // __webpack_public_path__ |
| /******/ __webpack_require__.p = ""; |
| /******/ |
| /******/ // Load entry module and return exports |
| /******/ return __webpack_require__(0); |
| /******/ }) |
| /************************************************************************/ |
| /******/ ([ |
| /* 0 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| /* WEBPACK VAR INJECTION */(function(global) {'use strict' |
| |
| __webpack_require__(1) |
| |
| var config = __webpack_require__(5) |
| var Loader = __webpack_require__(6) |
| var utils = __webpack_require__(7) |
| var protocol = __webpack_require__(8) |
| var ComponentManager = __webpack_require__(9) |
| var Component = __webpack_require__(16) |
| var Sender = __webpack_require__(19) |
| var receiver = __webpack_require__(20) |
| |
| // Components and apis. |
| var components = __webpack_require__(21) |
| var api = __webpack_require__(66) |
| __webpack_require__(96) |
| |
| var WEAPP_STYLE_ID = 'weapp-style' |
| |
| var DEFAULT_DESIGN_WIDTH = 750 |
| var DEFAULT_ROOT_ID = 'weex' |
| var DEFAULT_JSON_CALLBACK_NAME = 'weexJsonpCallback' |
| |
| // config.scale = window.innerWidth / DEFAULT_DESIGN_WIDTH |
| |
| window.WXEnvironment = { |
| weexVersion: config.weexVersion, |
| appName: lib.env.aliapp ? lib.env.aliapp.appname : null, |
| appVersion: lib.env.aliapp ? lib.env.aliapp.version.val : null, |
| platform: lib.env.os ? lib.env.os.name : null, |
| osVersion: lib.env.os ? lib.env.os.version.val : null, |
| deviceHeight: window.innerHeight / config.scale |
| } |
| |
| var _instanceMap = {} |
| |
| function Weex(options) { |
| |
| if (!(this instanceof Weex)) { |
| return new Weex(options) |
| } |
| |
| // Width of the root container. Default is window.innerWidth. |
| this.width = options.width || window.innerWidth |
| this.bundleUrl = options.bundleUrl || location.href |
| this.instanceId = options.appId |
| this.rootId = options.rootId || (DEFAULT_ROOT_ID + utils.getRandom(10)) |
| this.designWidth = options.designWidth || DEFAULT_DESIGN_WIDTH |
| this.jsonpCallback = options.jsonpCallback || DEFAULT_JSON_CALLBACK_NAME |
| this.source = options.source |
| this.loader = options.loader |
| |
| this.data = options.data |
| |
| this.initScale() |
| this.initComponentManager() |
| this.initBridge() |
| Weex.addInstance(this) |
| |
| protocol.injectWeexInstance(this) |
| |
| this.loadBundle(function (err, appCode) { |
| if (!err) { |
| this.createApp(config, appCode) |
| } else { |
| console.error('load bundle err:', err) |
| } |
| }.bind(this)) |
| |
| } |
| |
| Weex.init = function (options) { |
| if (utils.isArray(options)) { |
| options.forEach(function (config) { |
| new Weex(config) |
| }) |
| } else if ( |
| Object.prototype.toString.call(options).slice(8, -1) === 'Object' |
| ) { |
| new Weex(options) |
| } |
| } |
| |
| Weex.addInstance = function (instance) { |
| _instanceMap[instance.instanceId] = instance |
| } |
| |
| Weex.getInstance = function (instanceId) { |
| return _instanceMap[instanceId] |
| } |
| |
| Weex.prototype = { |
| |
| initBridge: function () { |
| receiver.init(this) |
| this.sender = new Sender(this) |
| }, |
| |
| loadBundle: function (cb) { |
| Loader.load({ |
| jsonpCallback: this.jsonpCallback, |
| source: this.source, |
| loader: this.loader |
| }, cb) |
| }, |
| |
| createApp: function (config, appCode) { |
| var root = document.querySelector('#' + this.rootId) |
| if (!root) { |
| root = document.createElement('div') |
| root.id = this.rootId |
| document.body.appendChild(root) |
| } |
| |
| var promise = window.createInstance( |
| this.instanceId |
| , appCode |
| , { |
| bundleUrl: this.bundleUrl, |
| debug: config.debug |
| } |
| , this.data |
| ) |
| |
| if (Promise && promise instanceof Promise) { |
| promise.then(function () { |
| // Weex._instances[this.instanceId] = this.root |
| }.bind(this)).catch(function (err) { |
| if (err && config.debug) { |
| console.error(err) |
| } |
| }) |
| } |
| |
| // Do not destroy instance here, because in most browser |
| // press back button to back to this page will not refresh |
| // the window and the instance will not be recreated then. |
| // window.addEventListener('beforeunload', function (e) { |
| // }) |
| |
| }, |
| |
| initScale: function () { |
| this.scale = this.width / this.designWidth |
| }, |
| |
| initComponentManager: function () { |
| this._componentManager = new ComponentManager(this) |
| }, |
| |
| getComponentManager: function () { |
| return this._componentManager |
| } |
| } |
| |
| Weex.appendStyle = function (css) { |
| utils.appendStyle(css, WEAPP_STYLE_ID) |
| }, |
| |
| // Register a new component with the specified name. |
| Weex.registerComponent = function (name, comp) { |
| ComponentManager.registerComponent(name, comp) |
| }, |
| |
| // Register a new api module. |
| // If the module already exists, just add methods from the |
| // new module to the old one. |
| Weex.registerApiModule = function (name, module, meta) { |
| if (!protocol.apiModule[name]) { |
| protocol.apiModule[name] = module |
| } else { |
| for (var key in module) { |
| if (module.hasOwnProperty(key)) { |
| protocol.apiModule[name][key] = module[key] |
| } |
| } |
| } |
| // register API module's meta info to jsframework |
| if (meta) { |
| protocol.setApiModuleMeta(meta) |
| window.registerModules(protocol.getApiModuleMeta(name), true) |
| } |
| }, |
| |
| // Register a new api method for the specified module. |
| // opts: |
| // - args: type of arguments the API method takes such |
| // as ['string', 'function'] |
| Weex.registerApi = function (moduleName, name, method, args) { |
| if (typeof method !== 'function') { |
| return |
| } |
| if (!protocol.apiModule[moduleName]) { |
| protocol.apiModule[moduleName] = {} |
| protocol._meta[moduleName] = [] |
| } |
| protocol.apiModule[moduleName][name] = method |
| if (!args) { |
| return |
| } |
| // register API meta info to jsframework |
| protocol.setApiMeta(moduleName, { |
| name: name, |
| args: args |
| }) |
| window.registerModules(protocol.getApiModuleMeta(moduleName, meta), true) |
| }, |
| |
| // Register a new weex-bundle-loader. |
| Weex.registerLoader = function (name, loaderFunc) { |
| Loader.registerLoader(name, loaderFunc) |
| } |
| |
| // To install components and plugins. |
| Weex.install = function (mod) { |
| mod.init(Weex) |
| } |
| |
| Weex.stopTheWorld = function () { |
| for (var instanceId in _instanceMap) { |
| if (_instanceMap.hasOwnProperty(instanceId)) { |
| window.destroyInstance(instanceId) |
| } |
| } |
| } |
| |
| (function startRefreshController() { |
| if (location.search.indexOf('hot-reload_controller') === -1) { |
| return |
| } |
| if (!window.WebSocket) { |
| console.info('auto refresh need WebSocket support') |
| return |
| } |
| var host = location.hostname |
| var port = 8082 |
| var client = new WebSocket('ws://' + host + ':' + port + '/', |
| 'echo-protocol' |
| ) |
| client.onerror = function () { |
| console.log('refresh controller websocket connection error') |
| } |
| client.onmessage = function (e) { |
| console.log('Received: \'' + e.data + '\'') |
| if (e.data === 'refresh') { |
| location.reload() |
| } |
| } |
| }()) |
| |
| // Weex.install(require('weex-components')) |
| Weex.install(components) |
| Weex.install(api) |
| |
| Weex.Component = Component |
| Weex.ComponentManager = ComponentManager |
| Weex.utils = utils |
| Weex.config = config |
| |
| global.weex = Weex |
| module.exports = Weex |
| |
| /* WEBPACK VAR INJECTION */}.call(exports, (function() { return this; }()))) |
| |
| /***/ }, |
| /* 1 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| // style-loader: Adds some css to the DOM by adding a <style> tag |
| |
| // load the styles |
| var content = __webpack_require__(2); |
| if(typeof content === 'string') content = [[module.id, content, '']]; |
| // add the styles to the DOM |
| var update = __webpack_require__(4)(content, {}); |
| if(content.locals) module.exports = content.locals; |
| // Hot Module Replacement |
| if(false) { |
| // When the styles change, update the <style> tags |
| if(!content.locals) { |
| module.hot.accept("!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./base.scss", function() { |
| var newContent = require("!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./base.scss"); |
| if(typeof newContent === 'string') newContent = [[module.id, newContent, '']]; |
| update(newContent); |
| }); |
| } |
| // When the module is disposed, remove the <style> tags |
| module.hot.dispose(function() { update(); }); |
| } |
| |
| /***/ }, |
| /* 2 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| exports = module.exports = __webpack_require__(3)(); |
| // imports |
| |
| |
| // module |
| exports.push([module.id, "* {\n margin: 0;\n padding: 0;\n text-size-adjust: none; }\n\nul, ol {\n list-style: none; }\n", "", {"version":3,"sources":["/./src/src/styles/base.scss"],"names":[],"mappings":"AAAA;EACE,UAAS;EACT,WAAU;EACV,uBACD,EAAC;;AACF;EACE,iBACD,EAAC","file":"base.scss","sourcesContent":["* {\n margin:0;\n padding:0;\n text-size-adjust:none\n}\nul,ol {\n list-style:none\n}"],"sourceRoot":"webpack://"}]); |
| |
| // exports |
| |
| |
| /***/ }, |
| /* 3 */ |
| /***/ function(module, exports) { |
| |
| /* |
| MIT License http://www.opensource.org/licenses/mit-license.php |
| Author Tobias Koppers @sokra |
| */ |
| // css base code, injected by the css-loader |
| module.exports = function() { |
| var list = []; |
| |
| // return the list of modules as css string |
| list.toString = function toString() { |
| var result = []; |
| for(var i = 0; i < this.length; i++) { |
| var item = this[i]; |
| if(item[2]) { |
| result.push("@media " + item[2] + "{" + item[1] + "}"); |
| } else { |
| result.push(item[1]); |
| } |
| } |
| return result.join(""); |
| }; |
| |
| // import a list of modules into the list |
| list.i = function(modules, mediaQuery) { |
| if(typeof modules === "string") |
| modules = [[null, modules, ""]]; |
| var alreadyImportedModules = {}; |
| for(var i = 0; i < this.length; i++) { |
| var id = this[i][0]; |
| if(typeof id === "number") |
| alreadyImportedModules[id] = true; |
| } |
| for(i = 0; i < modules.length; i++) { |
| var item = modules[i]; |
| // skip already imported module |
| // this implementation is not 100% perfect for weird media query combinations |
| // when a module is imported multiple times with different media queries. |
| // I hope this will never occur (Hey this way we have smaller bundles) |
| if(typeof item[0] !== "number" || !alreadyImportedModules[item[0]]) { |
| if(mediaQuery && !item[2]) { |
| item[2] = mediaQuery; |
| } else if(mediaQuery) { |
| item[2] = "(" + item[2] + ") and (" + mediaQuery + ")"; |
| } |
| list.push(item); |
| } |
| } |
| }; |
| return list; |
| }; |
| |
| |
| /***/ }, |
| /* 4 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| /* |
| MIT License http://www.opensource.org/licenses/mit-license.php |
| Author Tobias Koppers @sokra |
| */ |
| var stylesInDom = {}, |
| memoize = function(fn) { |
| var memo; |
| return function () { |
| if (typeof memo === "undefined") memo = fn.apply(this, arguments); |
| return memo; |
| }; |
| }, |
| isOldIE = memoize(function() { |
| return /msie [6-9]\b/.test(window.navigator.userAgent.toLowerCase()); |
| }), |
| getHeadElement = memoize(function () { |
| return document.head || document.getElementsByTagName("head")[0]; |
| }), |
| singletonElement = null, |
| singletonCounter = 0, |
| styleElementsInsertedAtTop = []; |
| |
| module.exports = function(list, options) { |
| if(false) { |
| if(typeof document !== "object") throw new Error("The style-loader cannot be used in a non-browser environment"); |
| } |
| |
| options = options || {}; |
| // Force single-tag solution on IE6-9, which has a hard limit on the # of <style> |
| // tags it will allow on a page |
| if (typeof options.singleton === "undefined") options.singleton = isOldIE(); |
| |
| // By default, add <style> tags to the bottom of <head>. |
| if (typeof options.insertAt === "undefined") options.insertAt = "bottom"; |
| |
| var styles = listToStyles(list); |
| addStylesToDom(styles, options); |
| |
| return function update(newList) { |
| var mayRemove = []; |
| for(var i = 0; i < styles.length; i++) { |
| var item = styles[i]; |
| var domStyle = stylesInDom[item.id]; |
| domStyle.refs--; |
| mayRemove.push(domStyle); |
| } |
| if(newList) { |
| var newStyles = listToStyles(newList); |
| addStylesToDom(newStyles, options); |
| } |
| for(var i = 0; i < mayRemove.length; i++) { |
| var domStyle = mayRemove[i]; |
| if(domStyle.refs === 0) { |
| for(var j = 0; j < domStyle.parts.length; j++) |
| domStyle.parts[j](); |
| delete stylesInDom[domStyle.id]; |
| } |
| } |
| }; |
| } |
| |
| function addStylesToDom(styles, options) { |
| for(var i = 0; i < styles.length; i++) { |
| var item = styles[i]; |
| var domStyle = stylesInDom[item.id]; |
| if(domStyle) { |
| domStyle.refs++; |
| for(var j = 0; j < domStyle.parts.length; j++) { |
| domStyle.parts[j](item.parts[j]); |
| } |
| for(; j < item.parts.length; j++) { |
| domStyle.parts.push(addStyle(item.parts[j], options)); |
| } |
| } else { |
| var parts = []; |
| for(var j = 0; j < item.parts.length; j++) { |
| parts.push(addStyle(item.parts[j], options)); |
| } |
| stylesInDom[item.id] = {id: item.id, refs: 1, parts: parts}; |
| } |
| } |
| } |
| |
| function listToStyles(list) { |
| var styles = []; |
| var newStyles = {}; |
| for(var i = 0; i < list.length; i++) { |
| var item = list[i]; |
| var id = item[0]; |
| var css = item[1]; |
| var media = item[2]; |
| var sourceMap = item[3]; |
| var part = {css: css, media: media, sourceMap: sourceMap}; |
| if(!newStyles[id]) |
| styles.push(newStyles[id] = {id: id, parts: [part]}); |
| else |
| newStyles[id].parts.push(part); |
| } |
| return styles; |
| } |
| |
| function insertStyleElement(options, styleElement) { |
| var head = getHeadElement(); |
| var lastStyleElementInsertedAtTop = styleElementsInsertedAtTop[styleElementsInsertedAtTop.length - 1]; |
| if (options.insertAt === "top") { |
| if(!lastStyleElementInsertedAtTop) { |
| head.insertBefore(styleElement, head.firstChild); |
| } else if(lastStyleElementInsertedAtTop.nextSibling) { |
| head.insertBefore(styleElement, lastStyleElementInsertedAtTop.nextSibling); |
| } else { |
| head.appendChild(styleElement); |
| } |
| styleElementsInsertedAtTop.push(styleElement); |
| } else if (options.insertAt === "bottom") { |
| head.appendChild(styleElement); |
| } else { |
| throw new Error("Invalid value for parameter 'insertAt'. Must be 'top' or 'bottom'."); |
| } |
| } |
| |
| function removeStyleElement(styleElement) { |
| styleElement.parentNode.removeChild(styleElement); |
| var idx = styleElementsInsertedAtTop.indexOf(styleElement); |
| if(idx >= 0) { |
| styleElementsInsertedAtTop.splice(idx, 1); |
| } |
| } |
| |
| function createStyleElement(options) { |
| var styleElement = document.createElement("style"); |
| styleElement.type = "text/css"; |
| insertStyleElement(options, styleElement); |
| return styleElement; |
| } |
| |
| function createLinkElement(options) { |
| var linkElement = document.createElement("link"); |
| linkElement.rel = "stylesheet"; |
| insertStyleElement(options, linkElement); |
| return linkElement; |
| } |
| |
| function addStyle(obj, options) { |
| var styleElement, update, remove; |
| |
| if (options.singleton) { |
| var styleIndex = singletonCounter++; |
| styleElement = singletonElement || (singletonElement = createStyleElement(options)); |
| update = applyToSingletonTag.bind(null, styleElement, styleIndex, false); |
| remove = applyToSingletonTag.bind(null, styleElement, styleIndex, true); |
| } else if(obj.sourceMap && |
| typeof URL === "function" && |
| typeof URL.createObjectURL === "function" && |
| typeof URL.revokeObjectURL === "function" && |
| typeof Blob === "function" && |
| typeof btoa === "function") { |
| styleElement = createLinkElement(options); |
| update = updateLink.bind(null, styleElement); |
| remove = function() { |
| removeStyleElement(styleElement); |
| if(styleElement.href) |
| URL.revokeObjectURL(styleElement.href); |
| }; |
| } else { |
| styleElement = createStyleElement(options); |
| update = applyToTag.bind(null, styleElement); |
| remove = function() { |
| removeStyleElement(styleElement); |
| }; |
| } |
| |
| update(obj); |
| |
| return function updateStyle(newObj) { |
| if(newObj) { |
| if(newObj.css === obj.css && newObj.media === obj.media && newObj.sourceMap === obj.sourceMap) |
| return; |
| update(obj = newObj); |
| } else { |
| remove(); |
| } |
| }; |
| } |
| |
| var replaceText = (function () { |
| var textStore = []; |
| |
| return function (index, replacement) { |
| textStore[index] = replacement; |
| return textStore.filter(Boolean).join('\n'); |
| }; |
| })(); |
| |
| function applyToSingletonTag(styleElement, index, remove, obj) { |
| var css = remove ? "" : obj.css; |
| |
| if (styleElement.styleSheet) { |
| styleElement.styleSheet.cssText = replaceText(index, css); |
| } else { |
| var cssNode = document.createTextNode(css); |
| var childNodes = styleElement.childNodes; |
| if (childNodes[index]) styleElement.removeChild(childNodes[index]); |
| if (childNodes.length) { |
| styleElement.insertBefore(cssNode, childNodes[index]); |
| } else { |
| styleElement.appendChild(cssNode); |
| } |
| } |
| } |
| |
| function applyToTag(styleElement, obj) { |
| var css = obj.css; |
| var media = obj.media; |
| |
| if(media) { |
| styleElement.setAttribute("media", media) |
| } |
| |
| if(styleElement.styleSheet) { |
| styleElement.styleSheet.cssText = css; |
| } else { |
| while(styleElement.firstChild) { |
| styleElement.removeChild(styleElement.firstChild); |
| } |
| styleElement.appendChild(document.createTextNode(css)); |
| } |
| } |
| |
| function updateLink(linkElement, obj) { |
| var css = obj.css; |
| var sourceMap = obj.sourceMap; |
| |
| if(sourceMap) { |
| // http://stackoverflow.com/a/26603875 |
| css += "\n/*# sourceMappingURL=data:application/json;base64," + btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap)))) + " */"; |
| } |
| |
| var blob = new Blob([css], { type: "text/css" }); |
| |
| var oldSrc = linkElement.href; |
| |
| linkElement.href = URL.createObjectURL(blob); |
| |
| if(oldSrc) |
| URL.revokeObjectURL(oldSrc); |
| } |
| |
| |
| /***/ }, |
| /* 5 */ |
| /***/ function(module, exports) { |
| |
| 'use strict' |
| |
| var config = { |
| |
| weexVersion: '1.4.0', |
| |
| debug: true |
| |
| } |
| |
| module.exports = config |
| |
| /***/ }, |
| /* 6 */ |
| /***/ function(module, exports) { |
| |
| 'use strict' |
| |
| function loadByXHR(config, callback) { |
| if (!config.source) { |
| callback(new Error('xhr loader: missing config.source.')) |
| } |
| var xhr = new XMLHttpRequest() |
| xhr.open('GET', config.source) |
| xhr.onload = function () { |
| callback(null, this.responseText) |
| } |
| xhr.onerror = function (error) { |
| callback(error) |
| } |
| xhr.send() |
| } |
| |
| function loadByJsonp(config, callback) { |
| if (!config.source) { |
| callback(new Error('jsonp loader: missing config.source.')) |
| } |
| var callbackName = config.jsonpCallback || 'weexJsonpCallback' |
| window[callbackName] = function (code) { |
| if (code) { |
| callback(null, code) |
| } else { |
| callback(new Error('load by jsonp error')) |
| } |
| } |
| var script = document.createElement('script') |
| script.src = decodeURIComponent(config.source) |
| script.type = 'text/javascript' |
| document.body.appendChild(script) |
| } |
| |
| function loadBySourceCode(config, callback) { |
| // src is the jsbundle. |
| // no need to fetch from anywhere. |
| if (config.source) { |
| callback(null, config.source) |
| } else { |
| callback(new Error('source code laoder: missing config.source.')) |
| } |
| } |
| |
| var callbackMap = { |
| xhr: loadByXHR, |
| jsonp: loadByJsonp, |
| source: loadBySourceCode |
| } |
| |
| function load(options, callback) { |
| var loadFn = callbackMap[options.loader] |
| loadFn(options, callback) |
| } |
| |
| function registerLoader(name, loaderFunc) { |
| if (typeof loaderFunc === 'function') { |
| callbackMap[name] = loaderFunc |
| } |
| } |
| |
| module.exports = { |
| load: load, |
| registerLoader: registerLoader |
| } |
| |
| |
| /***/ }, |
| /* 7 */ |
| /***/ function(module, exports) { |
| |
| 'use strict' |
| |
| var WEAPP_STYLE_ID = 'weapp-style' |
| |
| var _isWebpSupported = false |
| |
| ; (function isSupportWebp() { |
| try { |
| var webP = new Image() |
| webP.src = 'data:image/webp;base64,UklGRjoAAABXRUJQVlA4IC4AAACyAgCdA' |
| + 'SoCAAIALmk0mk0iIiIiIgBoSygABc6WWgAA/veff/0PP8bA//LwYAAA' |
| webP.onload = function () { |
| if (webP.height === 2) { |
| _isWebpSupported = true |
| } |
| } |
| } catch (e) { |
| // do nothing. |
| } |
| })() |
| |
| function extend(to, from) { |
| for (var key in from) { |
| to[key] = from[key] |
| } |
| return to |
| } |
| |
| function isArray(arr) { |
| return Array.isArray |
| ? Array.isArray(arr) |
| : (Object.prototype.toString.call(arr) === '[object Array]') |
| } |
| |
| function appendStyle(css, styleId, replace) { |
| var style = document.getElementById(styleId) |
| if (style && replace) { |
| style.parentNode.removeChild(style) |
| style = null |
| } |
| if (!style) { |
| style = document.createElement('style') |
| style.type = 'text/css' |
| styleId && (style.id = styleId) |
| document.getElementsByTagName('head')[0].appendChild(style) |
| } |
| style.appendChild(document.createTextNode(css)) |
| } |
| |
| function getUniqueFromArray(arr) { |
| if (!isArray(arr)) { |
| return [] |
| } |
| var res = [] |
| var unique = {} |
| var val |
| for (var i = 0, l = arr.length; i < l; i++) { |
| val = arr[i] |
| if (unique[val]) { |
| continue |
| } |
| unique[val] = true |
| res.push(val) |
| } |
| return res |
| } |
| |
| function transitionize(element, props) { |
| var transitions = [] |
| for (var key in props) { |
| transitions.push(key + ' ' + props[key]) |
| } |
| element.style.transition = transitions.join(', ') |
| element.style.webkitTransition = transitions.join(', ') |
| } |
| |
| function detectWebp() { |
| return _isWebpSupported |
| } |
| |
| function getRandom(num) { |
| var _defaultNum = 10 |
| if (typeof num !== 'number' || num <= 0) { |
| num = _defaultNum |
| } |
| var _max = Math.pow(10, num) |
| return Math.floor(Date.now() + Math.random() * _max) % _max |
| } |
| |
| module.exports = { |
| extend: extend, |
| isArray: isArray, |
| appendStyle: appendStyle, |
| getUniqueFromArray: getUniqueFromArray, |
| transitionize: transitionize, |
| detectWebp: detectWebp, |
| getRandom: getRandom |
| } |
| |
| /***/ }, |
| /* 8 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| var extend = __webpack_require__(7).extend |
| var isArray = __webpack_require__(7).isArray |
| var ComponentManager = __webpack_require__(9) |
| |
| // for jsframework to register modules. |
| var _registerModules = function (config) { |
| if (isArray(config)) { |
| for (var i = 0, l = config.length; i < l; i++) { |
| window.registerModules(config[i]) |
| } |
| } else { |
| window.registerModules(config) |
| } |
| } |
| |
| var protocol = { |
| |
| // weex instances |
| _instances: [], |
| |
| // api meta info |
| _meta: [], |
| |
| apiModule: {}, |
| |
| injectWeexInstance: function (instance) { |
| this._instances[instance.instanceId] = instance |
| }, |
| |
| getWeexInstance: function (instanceId) { |
| return this._instances[instanceId] |
| }, |
| |
| // get the api method meta info array for the module. |
| getApiModuleMeta: function (moduleName) { |
| var metaObj = {} |
| metaObj[moduleName] = this._meta[moduleName] |
| return metaObj |
| }, |
| |
| // Set meta info for a api module. |
| // If there is a same named api, just replace it. |
| // opts: |
| // - metaObj: meta object like |
| // { |
| // dom: [{ |
| // name: 'addElement', |
| // args: ['string', 'object'] |
| // }] |
| // } |
| setApiModuleMeta: function (metaObj) { |
| var moduleName |
| for (var k in metaObj) { |
| if (metaObj.hasOwnProperty(k)) { |
| moduleName = k |
| } |
| } |
| var metaArray = this._meta[moduleName] |
| if (!metaArray) { |
| this._meta[moduleName] = metaObj[moduleName] |
| } else { |
| var nameObj = {} |
| metaObj[moduleName].forEach(function (api) { |
| nameObj[api.name] = api |
| }) |
| metaArray.forEach(function (api, i) { |
| if (nameObj[api.name]) { |
| metaArray[i] = nameObj[api.name] |
| delete nameObj[api.name] |
| } |
| }) |
| for (var k in metaObj) { |
| if (metaObj.hasOwnProperty(k)) { |
| metaArray.push(metaObj[k]) |
| } |
| } |
| } |
| this._meta[moduleName] = metaObj[moduleName] |
| }, |
| |
| // Set meta info for a single api. |
| // opts: |
| // - moduleName: api module name. |
| // - meta: a meta object like: |
| // { |
| // name: 'addElement', |
| // args: ['string', 'object'] |
| // } |
| setApiMeta: function (moduleName, meta) { |
| var metaArray = this._meta[moduleName] |
| if (!metaArray) { |
| this._meta[moduleName] = [meta] |
| } else { |
| var metaIdx = -1 |
| metaArray.forEach(function (api, i) { |
| if (meta.name === name) { |
| metaIdx = i |
| } |
| }) |
| if (metaIdx !== -1) { |
| metaArray[metaIdx] = meta |
| } else { |
| metaArray.push(meta) |
| } |
| } |
| } |
| } |
| |
| _registerModules([{ |
| modal: [{ |
| name: 'toast', |
| args: ['object', 'function'] |
| }, { |
| name: 'alert', |
| args: ['object', 'function'] |
| }, { |
| name: 'confirm', |
| args: ['object', 'function'] |
| }, { |
| name: 'prompt', |
| args: ['object', 'function'] |
| }] |
| }, { |
| animation: [{ |
| name: 'transition', |
| args: ['string', 'object', 'function'] |
| }] |
| }]) |
| |
| module.exports = protocol |
| |
| |
| /***/ }, |
| /* 9 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| var config = __webpack_require__(5) |
| var FrameUpdater = __webpack_require__(10) |
| var AppearWatcher = __webpack_require__(11) |
| var utils = __webpack_require__(7) |
| var LazyLoad = __webpack_require__(12) |
| var animation = __webpack_require__(15) |
| |
| var RENDERING_INDENT = 800 |
| |
| var _instanceMap = {} |
| var typeMap = {} |
| var scrollableTypes = ['scroller', 'list'] |
| |
| function ComponentManager(instance) { |
| this.instanceId = instance.instanceId |
| this.weexInstance = instance |
| this.componentMap = {} |
| _instanceMap[this.instanceId] = this |
| } |
| |
| ComponentManager.getInstance = function (instanceId) { |
| return _instanceMap[instanceId] |
| } |
| |
| ComponentManager.getWeexInstance = function (instanceId) { |
| return _instanceMap[instanceId].weexInstance |
| } |
| |
| ComponentManager.registerComponent = function (type, definition) { |
| typeMap[type] = definition |
| } |
| |
| ComponentManager.getScrollableTypes = function () { |
| return scrollableTypes |
| } |
| |
| ComponentManager.prototype = { |
| |
| // Fire a event 'renderbegin'/'renderend' on body element. |
| rendering: function () { |
| function _renderingEnd() { |
| // get weex instance root |
| window.dispatchEvent(new Event('renderend')) |
| this._renderingTimer = null |
| } |
| if (this._renderingTimer) { |
| clearTimeout(this._renderingTimer) |
| this._renderingTimer = setTimeout( |
| _renderingEnd.bind(this), |
| RENDERING_INDENT |
| ) |
| } else { |
| window.dispatchEvent(new Event('renderbegin')) |
| this._renderingTimer = setTimeout( |
| _renderingEnd.bind(this), |
| RENDERING_INDENT |
| ) |
| } |
| }, |
| |
| getElementByRef: function (ref) { |
| return this.componentMap[ref] |
| }, |
| |
| removeElementByRef: function (ref) { |
| var cmp |
| var self = this |
| if (!ref || !(cmp = this.componentMap[ref])) { |
| return |
| } |
| // remove from this.componentMap cursively |
| (function _removeCursively(_ref) { |
| var child = self.componentMap[_ref] |
| var listeners = child._listeners |
| var children = child.data.children |
| if (children && children.length) { |
| for (var i = 0, l = children.length; i < l; i++) { |
| _removeCursively(children[i].ref) |
| } |
| } |
| // remove events from _ref component |
| if (listeners) { |
| for (var type in listeners) { |
| child.node.removeEventListener(type, listeners[type]) |
| } |
| } |
| delete child._listeners |
| delete child.node._listeners |
| // remove _ref component |
| delete self.componentMap[_ref] |
| })(ref) |
| |
| }, |
| |
| createElement: function (data, nodeType) { |
| var ComponentType = typeMap[data.type] |
| if (!ComponentType) { |
| ComponentType = typeMap['container'] |
| } |
| |
| var ref = data.ref |
| var component = new ComponentType(data, nodeType) |
| |
| this.componentMap[ref] = component |
| component.node.setAttribute('data-ref', ref) |
| |
| return component |
| }, |
| |
| /** |
| * createBody: generate root component |
| * @param {object} element |
| */ |
| createBody: function (element) { |
| |
| // TODO: creatbody on document.body |
| // no need to create a extra div |
| var root, body, nodeType |
| if (this.componentMap['_root']) { |
| return |
| } |
| |
| nodeType = element.type |
| element.type = 'root' |
| element.rootId = this.weexInstance.rootId |
| element.ref = '_root' |
| |
| var root = this.createElement(element, nodeType) |
| body = document.querySelector('#' + this.weexInstance.rootId) |
| || document.body |
| body.appendChild(root.node) |
| root._appended = true |
| }, |
| |
| appendChild: function (parentRef, data) { |
| var parent = this.componentMap[parentRef] |
| |
| if (this.componentMap[data.ref] || !parent) { |
| return |
| } |
| |
| if (parentRef === '_root' && !parent) { |
| parent = this.createElement({ |
| type: 'root', |
| rootId: this.weexInstance.rootId, |
| ref: '_root' |
| }) |
| parent._appended = true |
| } |
| |
| var child = parent.appendChild(data) |
| |
| // In some parent component the implementation of method |
| // appendChild didn't return the component at all, therefor |
| // child maybe a undefined object. |
| if (child) { |
| child.parentRef = parentRef |
| } |
| |
| if (child && parent._appended) { |
| this.handleAppend(child) |
| } |
| }, |
| |
| appendChildren: function (ref, elements) { |
| for (var i = 0; i < elements.length; i++) { |
| this.appendChild(ref, elements[i]) |
| } |
| }, |
| |
| removeElement: function (ref) { |
| var component = this.componentMap[ref] |
| |
| // fire event for rendering dom on body elment. |
| this.rendering() |
| |
| if (component && component.parentRef) { |
| var parent = this.componentMap[component.parentRef] |
| component.onRemove && component.onRemove() |
| parent.removeChild(component) |
| } else { |
| console.warn('ref: ', ref) |
| } |
| }, |
| |
| moveElement: function (ref, parentRef, index) { |
| var component = this.componentMap[ref] |
| var newParent = this.componentMap[parentRef] |
| var oldParentRef = component.parentRef |
| var children, before, i, l |
| if (!component || !newParent) { |
| console.warn('ref: ', ref) |
| return |
| } |
| |
| // fire event for rendering dom on body elment. |
| this.rendering() |
| |
| // remove from oldParent.data.children |
| if (oldParentRef && this.componentMap[oldParentRef]) { |
| children = this.componentMap[oldParentRef].data.children |
| if (children && children.length) { |
| for (i = 0, l = children.length; i < l; i++) { |
| if (children[i].ref === ref) { |
| break |
| } |
| } |
| if (l > i) { |
| children.splice(i, 1) |
| } |
| } |
| } |
| |
| if (index < -1) { |
| index = -1 |
| console.warn('index cannot be less than -1.') |
| } |
| |
| children = newParent.data.children |
| if (children |
| && children.length |
| && index !== -1 |
| && index < children.length) { |
| before = this.componentMap[newParent.data.children[index].ref] |
| newParent.insertBefore(component, before) |
| } else { // append |
| newParent.insertBefore(component) |
| } |
| |
| component.onMove && component.onMove(parentRef, index) |
| |
| }, |
| |
| insertBefore: function (ref, data) { |
| var child, before, parent |
| before = this.componentMap[ref] |
| child = this.componentMap[data.ref] |
| before && (parent = this.componentMap[before.parentRef]) |
| if (child || !parent || !before) { |
| return |
| } |
| |
| child = this.createElement(data) |
| if (child) { |
| child.parentRef = before.parentRef |
| parent.insertBefore(child, before) |
| } else { |
| return |
| } |
| |
| if (this.componentMap[before.parentRef]._appended) { |
| this.handleAppend(child) |
| } |
| }, |
| |
| /** |
| * addElement |
| * If index is larget than any child's index, the |
| * element will be appended behind. |
| * @param {string} parentRef |
| * @param {obj} element (data of the component) |
| * @param {number} index |
| */ |
| addElement: function (parentRef, element, index) { |
| var parent, children, before |
| |
| // fire event for rendering dom on body elment. |
| this.rendering() |
| |
| parent = this.componentMap[parentRef] |
| if (!parent) { |
| return |
| } |
| children = parent.data.children |
| // -1 means append as the last. |
| if (index < -1) { |
| index = -1 |
| console.warn('index cannot be less than -1.') |
| } |
| if (children && children.length |
| && children.length > index |
| && index !== -1) { |
| this.insertBefore(children[index].ref, element) |
| } else { |
| this.appendChild(parentRef, element) |
| } |
| }, |
| |
| clearChildren: function (ref) { |
| var component = this.componentMap[ref] |
| if (component) { |
| component.node.innerHTML = '' |
| if (component.data) { |
| component.data.children = null |
| } |
| } |
| }, |
| |
| addEvent: function (ref, type) { |
| var component |
| if (typeof ref === 'string' || typeof ref === 'number') { |
| component = this.componentMap[ref] |
| } else if (Object.prototype.toString.call(ref).slice(8, -1) === 'Object') { |
| component = ref |
| ref = component.data.ref |
| } |
| if (component && component.node) { |
| var sender = this.weexInstance.sender |
| var listener = sender.fireEvent.bind(sender, ref, type) |
| var listeners = component._listeners |
| component.node.addEventListener(type, listener, false, false) |
| if (!listeners) { |
| listeners = component._listeners = {} |
| component.node._listeners = {} |
| } |
| listeners[type] = listener |
| component.node._listeners[type] = listener |
| } |
| }, |
| |
| removeEvent: function (ref, type) { |
| var component = this.componentMap[ref] |
| var listener = component._listeners[type] |
| if (component && listener) { |
| component.node.removeEventListener(type, listener) |
| component._listeners[type] = null |
| component.node._listeners[type] = null |
| } |
| }, |
| |
| updateAttrs: function (ref, attr) { |
| var component = this.componentMap[ref] |
| if (component) { |
| component.updateAttrs(attr) |
| if (component.data.type === 'image' && attr.src) { |
| LazyLoad.startIfNeeded(component) |
| } |
| } |
| }, |
| |
| updateStyle: function (ref, style) { |
| var component = this.componentMap[ref] |
| if (component) { |
| component.updateStyle(style) |
| } |
| }, |
| |
| updateFullAttrs: function (ref, attr) { |
| var component = this.componentMap[ref] |
| if (component) { |
| component.clearAttr() |
| component.updateAttrs(attr) |
| if (component.data.type === 'image' && attr.src) { |
| LazyLoad.startIfNeeded(component) |
| } |
| } |
| }, |
| |
| updateFullStyle: function (ref, style) { |
| var component = this.componentMap[ref] |
| if (component) { |
| component.clearStyle() |
| component.updateStyle(style) |
| } |
| }, |
| |
| handleAppend: function (component) { |
| component._appended = true |
| component.onAppend && component.onAppend() |
| |
| // invoke onAppend on children recursively |
| var children = component.data.children |
| if (children) { |
| for (var i = 0; i < children.length; i++) { |
| var child = this.componentMap[children[i].ref] |
| if (child) { |
| this.handleAppend(child) |
| } |
| } |
| } |
| |
| // watch appear/disappear of the component if needed |
| AppearWatcher.watchIfNeeded(component) |
| |
| // do lazyload if needed |
| LazyLoad.startIfNeeded(component) |
| }, |
| |
| transition: function (ref, config, callback) { |
| var component = this.componentMap[ref] |
| animation.transitionOnce(component, config, callback) |
| }, |
| |
| renderFinish: function () { |
| FrameUpdater.pause() |
| } |
| } |
| |
| module.exports = ComponentManager |
| |
| |
| /***/ }, |
| /* 10 */ |
| /***/ function(module, exports) { |
| |
| 'use strict' |
| |
| var raf = window.requestAnimationFrame || |
| window.webkitRequestAnimationFrame || |
| function (calllback) { |
| setTimeout(calllback, 16) |
| } |
| |
| var rafId |
| var observers = [] |
| var paused = false |
| |
| var FrameUpdater = { |
| start: function () { |
| if (rafId) { |
| return |
| } |
| |
| rafId = raf(function runLoop() { |
| if (!paused) { |
| for (var i = 0; i < observers.length; i++) { |
| observers[i]() |
| } |
| raf(runLoop) |
| } |
| }) |
| }, |
| |
| isActive: function () { |
| return !paused |
| }, |
| |
| pause: function () { |
| paused = true |
| rafId = undefined |
| }, |
| |
| resume: function () { |
| paused = false |
| this.start() |
| }, |
| |
| addUpdateObserver: function (observeMethod) { |
| observers.push(observeMethod) |
| } |
| } |
| |
| module.exports = FrameUpdater |
| |
| |
| /***/ }, |
| /* 11 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| var utils = __webpack_require__(7) |
| |
| var componentsInScroller = [] |
| var componentsOutOfScroller = [] |
| var listened = false |
| var direction = 'up' |
| var scrollY = 0 |
| |
| var AppearWatcher = { |
| watchIfNeeded: function (component) { |
| if (needWatch(component)) { |
| if (component.isInScrollable()) { |
| componentsInScroller.push(component) |
| } else { |
| componentsOutOfScroller.push(component) |
| } |
| if (!listened) { |
| listened = true |
| // var handler = throttle(onScroll, 25) |
| var handler = throttle(onScroll, 100) |
| window.addEventListener('scroll', handler, false) |
| } |
| } |
| } |
| } |
| |
| function needWatch(component) { |
| var events = component.data.event |
| if (events |
| && (events.indexOf('appear') != -1 |
| || events.indexOf('disappear') != -1)) { |
| return true |
| } |
| return false |
| } |
| |
| function onScroll(e) { |
| // If the scroll event is dispatched from a scrollable component |
| // implemented through scrollerjs, then the appear/disappear events |
| // should be treated specially by handleScrollerScroll. |
| if (e.originalType === 'scrolling') { |
| handleScrollerScroll() |
| } else { |
| handleWindowScroll() |
| } |
| } |
| |
| function handleScrollerScroll() { |
| var cmps = componentsInScroller |
| var len = cmps.length |
| for (var i = 0; i < len; i++) { |
| var component = cmps[i] |
| var appear = isComponentInScrollerAppear(component) |
| if (appear && !component._appear) { |
| component._appear = true |
| fireEvent(component, 'appear') |
| } else if (!appear && component._appear) { |
| component._appear = false |
| fireEvent(component, 'disappear') |
| } |
| } |
| } |
| |
| function handleWindowScroll() { |
| var y = window.scrollY |
| direction = y >= scrollY ? 'up' : 'down' |
| scrollY = y |
| |
| var len = componentsOutOfScroller.length |
| if (len === 0) { |
| return |
| } |
| for (var i = 0; i < len; i++) { |
| var component = componentsOutOfScroller[i] |
| var appear = isComponentInWindow(component) |
| if (appear && !component._appear) { |
| component._appear = true |
| fireEvent(component, 'appear') |
| } else if (!appear && component._appear) { |
| component._appear = false |
| fireEvent(component, 'disappear') |
| } |
| } |
| } |
| |
| function isComponentInScrollerAppear(component) { |
| var parentScroller = component._parentScroller |
| var cmpRect = component.node.getBoundingClientRect() |
| if (!isComponentInWindow(component)) { |
| return false |
| } |
| while (parentScroller) { |
| var parentRect = parentScroller.node.getBoundingClientRect() |
| if (!(cmpRect.right > parentRect.left |
| && cmpRect.left < parentRect.right |
| && cmpRect.bottom > parentRect.top |
| && cmpRect.top < parentRect.bottom)) { |
| return false |
| } |
| parentScroller = parentScroller._parentScroller |
| } |
| return true |
| } |
| |
| function isComponentInWindow(component) { |
| var rect = component.node.getBoundingClientRect() |
| return rect.right > 0 && rect.left < window.innerWidth && |
| rect.bottom > 0 && rect.top < window.innerHeight |
| } |
| |
| function fireEvent(component, type) { |
| var evt = document.createEvent('HTMLEvents') |
| var data = { direction: direction } |
| evt.initEvent(type, false, false) |
| evt.data = data |
| utils.extend(evt, data) |
| component.node.dispatchEvent(evt) |
| } |
| |
| function throttle(func, wait) { |
| var context, args, result |
| var timeout = null |
| var previous = 0 |
| var later = function () { |
| previous = Date.now() |
| timeout = null |
| result = func.apply(context, args) |
| } |
| return function () { |
| var now = Date.now() |
| var remaining = wait - (now - previous) |
| context = this |
| args = arguments |
| if (remaining <= 0) { |
| clearTimeout(timeout) |
| timeout = null |
| previous = now |
| result = func.apply(context, args) |
| } else if (!timeout) { |
| timeout = setTimeout(later, remaining) |
| } |
| return result |
| } |
| } |
| |
| module.exports = AppearWatcher |
| |
| /***/ }, |
| /* 12 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| __webpack_require__(13) |
| |
| var lazyloadTimer |
| |
| var LazyLoad = { |
| makeImageLazy: function (image, src) { |
| image.removeAttribute('img-src') |
| image.removeAttribute('i-lazy-src') |
| image.removeAttribute('src') |
| image.setAttribute('img-src', src) |
| // should replace 'src' with 'img-src'. but for now lib.img.fire is |
| // not working for the situation that the appear event has been |
| // already triggered. |
| // image.setAttribute('src', src) |
| // image.setAttribute('img-src', src) |
| this.fire() |
| }, |
| |
| // we don't know when all image are appended |
| // just use setTimeout to do delay lazyload |
| // |
| // -- actually everytime we add a element or update styles, |
| // the component manager will call startIfNeed to fire |
| // lazyload once again in the handleAppend function. so there |
| // is no way that any image element can miss it. See source |
| // code in componentMangager.js. |
| startIfNeeded: function (component) { |
| var that = this |
| if (component.data.type === 'image') { |
| if (!lazyloadTimer) { |
| lazyloadTimer = setTimeout(function () { |
| that.fire() |
| clearTimeout(lazyloadTimer) |
| lazyloadTimer = null |
| }, 16) |
| } |
| } |
| }, |
| |
| loadIfNeeded: function (elementScope) { |
| var notPreProcessed = elementScope.querySelectorAll('[img-src]') |
| var that = this |
| // image elements which have attribute 'i-lazy-src' were elements |
| // that had been preprocessed by lib-img-core, but not loaded yet, and |
| // must be loaded when 'appear' events were fired. It turns out the |
| // 'appear' event was not fired correctly in the css-translate-transition |
| // situation, so 'i-lazy-src' must be checked and lazyload must be |
| // fired manually. |
| var preProcessed = elementScope.querySelectorAll('[i-lazy-src]') |
| if (notPreProcessed.length > 0 || preProcessed.length > 0) { |
| that.fire() |
| } |
| }, |
| |
| // fire lazyload. |
| fire: function () { |
| lib.img.fire() |
| } |
| |
| } |
| |
| module.exports = LazyLoad |
| |
| |
| /***/ }, |
| /* 13 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| "undefined"==typeof window&&(window={ctrl:{},lib:{}}),!window.ctrl&&(window.ctrl={}),!window.lib&&(window.lib={}),function(t,i){function e(t,i){i&&("IMG"==t.nodeName.toUpperCase()?t.setAttribute("src",i):t.style.backgroundImage='url("'+i+'")')}function a(){r=i.appear.init({cls:"imgtmp",once:!0,x:o.lazyWidth,y:o.lazyHeight,onAppear:function(t){var i=this;e(i,i.getAttribute("i-lazy-src")),i.removeAttribute("i-lazy-src")}})}__webpack_require__(14);var r,A={},o={dataSrc:"img-src",lazyHeight:0,lazyWidth:0};A.logConfig=function(){console.log("lib-img Config\n",o)},A.fire=function(){r||a();var t="i_"+Date.now()%1e5,i=document.querySelectorAll("["+o.dataSrc+"]");[].forEach.call(i,function(i){"false"==i.dataset.lazy&&"true"!=i.dataset.lazy?e(i,processSrc(i,i.getAttribute(o.dataSrc))):(i.classList.add(t),i.setAttribute("i-lazy-src",i.getAttribute(o.dataSrc))),i.removeAttribute(o.dataSrc)}),r.bind("."+t),r.fire()},A.defaultSrc="data:image/gif;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAADUlEQVQImWNgYGBgAAAABQABh6FO1AAAAABJRU5ErkJggg==",i.img=A,module.exports=A}(window,window.lib||(window.lib={})); |
| |
| /***/ }, |
| /* 14 */ |
| /***/ function(module, exports) { |
| |
| "undefined"==typeof window&&(window={ctrl:{},lib:{}}),!window.ctrl&&(window.ctrl={}),!window.lib&&(window.lib={}),function(n,e){function i(){d=w.createEvent("HTMLEvents"),v=w.createEvent("HTMLEvents"),d.initEvent("_appear",!1,!0),v.initEvent("_disappear",!1,!0)}function a(t,n){var e,i,a,s=(Date.now(),0),o=null,r=function(){s=Date.now(),o=null,t.apply(e,i)};return function(){var l=Date.now();e=this,i=arguments;var c=n-(l-s);return 0>=c||c>=n?(clearTimeout(o),o=null,a=t.apply(e,i)):null==o&&(o=setTimeout(r,c)),a}}function s(n,e){var n,i,a,s;if(n)return e||(e={x:0,y:0}),n!=window?(n=n.getBoundingClientRect(),i=n.left,t=n.top,a=n.right,s=n.bottom):(i=0,t=0,a=i+n.innerWidth,s=t+n.innerHeight),{left:i,top:t,right:a+e.x,bottom:s+e.y}}function o(t,n){var e=n.right>t.left&&n.left<t.right,i=n.bottom>t.top&&n.top<t.bottom;return e&&i}function r(t,n){var e="none",i=t.left-n.left,a=t.top-n.top;return 0==a&&(e=0!=i?i>0?"left":"right":"none"),0==i&&(e=0!=a?a>0?"up":"down":"none"),e}function l(t,n){for(var e in n)n.hasOwnProperty(e)&&(t[e]=n[e]);return t}function c(){var t=this,n=a(function(){f.apply(t,arguments)},this.options.wait);this.__handle&&(this.container.removeEventListener("scroll",this.__handle),this.__handle=null),this.__handle=n,this.container.addEventListener("scroll",n,!1),this.container.addEventListener("resize",function(n){f.apply(t,arguments)},!1),this.container.addEventListener("animationEnd",function(){f.apply(t,arguments)},!1),this.container.addEventListener("webkitAnimationEnd",function(){f.apply(t,arguments)},!1),this.container.addEventListener("transitionend",function(){f.apply(t,arguments)},!1)}function p(t){var n=this,e=this.options.container;if("string"==typeof e?this.container=w.querySelector(e):this.container=e,this.container==window)var i=w.querySelectorAll(t);else var i=this.container.querySelectorAll(t);var i=[].slice.call(i,null);return i=i.filter(function(t){return"1"==t.dataset.bind?(delete t._hasAppear,delete t._hasDisAppear,delete t._appear,t.classList.remove(n.options.cls),!1):!0})}function h(t){var n=this;t&&t.length>0&&[].forEach.call(t,function(t){t._eleOffset=s(t),t.classList.remove(n.options.cls),t.dataset.bind=1})}function f(){var t=this.container,n=this.appearWatchElements,e=this.options.onAppear,i=this.options.onDisappear,a=s(t,{x:this.options.x,y:this.options.y}),l=this.options.once,c=arguments[0]||{};n&&n.length>0&&[].forEach.call(n,function(t,n){var p=s(t),h=r(t._eleOffset,p);t._eleOffset=p;var f=o(a,p),u=t._appear,w=t._hasAppear,E=t._hasDisAppear;d.data={direction:h},v.data={direction:h},f&&!u?(l&&!w||!l)&&(e&&e.call(t,c),t.dispatchEvent(d),t._hasAppear=!0,t._appear=!0):!f&&u&&(l&&!E||!l)&&(i&&i.call(t,c),t.dispatchEvent(v),t._hasDisAppear=!0,t._appear=!1)})}function u(t){l(this.options,t||(t={})),this.appearWatchElements=this.appearWatchElements||p.call(this,"."+this.options.cls),h.call(this,this.appearWatchElements),c.call(this)}var d,v,w=document,E=function(){u.apply(this,arguments)},_={instances:[],init:function(t){var n={options:{container:window,wait:100,x:0,y:0,cls:"lib-appear",once:!1,onReset:function(){},onAppear:function(){},onDisappear:function(){}},container:null,appearWatchElements:null,bind:function(t){var n=this.options.cls;if("string"==typeof t){var e=p.call(this,t);[].forEach.call(e,function(t,e){t.classList.contains(n)||t.classList.add(n)})}else{if(1!=t.nodeType||!this.container.contains(t))return this;t.classList.contains(n)||t.classList.add(n)}var i=p.call(this,"."+this.options.cls);return this.appearWatchElements=this.appearWatchElements.concat(i),h.call(this,i),this},reset:function(t){return u.call(this,t),this.appearWatchElements.forEach(function(t){delete t._hasAppear,delete t._hasDisAppear,delete t._appear}),this},fire:function(){this.appearWatchElements||(this.appearWatchElements=[]);var t=p.call(this,"."+this.options.cls);return this.appearWatchElements=this.appearWatchElements.concat(t),h.call(this,t),f.call(this),this}};E.prototype=n;var e=new E(t);return this.instances.push(e),e},fireAll:function(){var t=this.instances;t.forEach(function(t){t.fire()})}};i(),e.appear=_}(window,window.lib||(window.lib={})); |
| |
| /***/ }, |
| /* 15 */ |
| /***/ function(module, exports) { |
| |
| 'use strict' |
| |
| module.exports = { |
| |
| /** |
| * config: |
| * - styles |
| * - duration [Number] milliseconds(ms) |
| * - timingFunction [string] |
| * - dealy [Number] milliseconds(ms) |
| */ |
| transitionOnce: function (comp, config, callback) { |
| var styles = config.styles || {} |
| var duration = config.duration || 1000 // ms |
| var timingFunction = config.timingFunction || 'ease' |
| var delay = config.delay || 0 // ms |
| var transitionValue = 'all ' + duration + 'ms ' |
| + timingFunction + ' ' + delay + 'ms' |
| var dom = comp.node |
| var transitionEndHandler = function (e) { |
| e.stopPropagation() |
| dom.removeEventListener('webkitTransitionEnd', transitionEndHandler) |
| dom.removeEventListener('transitionend', transitionEndHandler) |
| dom.style.transition = '' |
| dom.style.webkitTransition = '' |
| callback() |
| } |
| dom.style.transition = transitionValue |
| dom.style.webkitTransition = transitionValue |
| dom.addEventListener('webkitTransitionEnd', transitionEndHandler) |
| dom.addEventListener('transitionend', transitionEndHandler) |
| comp.updateStyle(styles) |
| } |
| |
| } |
| |
| /***/ }, |
| /* 16 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| var config = __webpack_require__(5) |
| var utils = __webpack_require__(7) |
| var ComponentManager = __webpack_require__(9) |
| var flexbox = __webpack_require__(17) |
| __webpack_require__(18) |
| |
| function Component(data, nodeType) { |
| this.data = data |
| this.node = this.create(nodeType) |
| |
| this.createChildren() |
| this.updateAttrs(this.data.attr) |
| // issue: when add element to a list in lifetime hook 'ready', the |
| // styles is set to the classStyle, not style. This is a issue |
| // that jsframework should do something about. |
| var classStyle = this.data.classStyle |
| classStyle && this.updateStyle(this.data.classStyle) |
| this.updateStyle(this.data.style) |
| this.bindEvents(this.data.event) |
| } |
| |
| Component.prototype = { |
| |
| create: function (nodeType) { |
| var node = document.createElement(nodeType || 'div') |
| return node |
| }, |
| |
| getComponentManager: function () { |
| return ComponentManager.getInstance(this.data.instanceId) |
| }, |
| |
| getParent: function () { |
| return this.getComponentManager().componentMap[this.parentRef] |
| }, |
| |
| isScrollable: function () { |
| var t = this.data.type |
| return ComponentManager.getScrollableTypes().indexOf(t) !== -1 |
| }, |
| |
| isInScrollable: function () { |
| if (typeof this._isInScrollable === 'boolean') { |
| return this._isInScrollable |
| } |
| var parent = this.getParent() |
| if (parent |
| && (typeof parent._isInScrollable !== 'boolean') |
| && !parent.isScrollable()) { |
| if (parent.data.type === 'root') { |
| this._isInScrollable = false |
| return false |
| } |
| this._isInScrollable = parent.isInScrollable() |
| this._parentScroller = parent._parentScroller |
| return this._isInScrollable |
| } |
| if (typeof parent._isInScrollable === 'boolean') { |
| this._isInScrollable = parent._isInScrollable |
| this._parentScroller = parent._parentScroller |
| return this._isInScrollable |
| } |
| if (parent.isScrollable()) { |
| this._isInScrollable = true |
| this._parentScroller = parent |
| return true |
| } |
| if (!parent) { |
| console && console.error('isInScrollable - parent not exist.') |
| } |
| }, |
| |
| createChildren: function () { |
| var children = this.data.children |
| var parentRef = this.data.ref |
| var componentManager = this.getComponentManager() |
| if (children && children.length) { |
| var fragment = document.createDocumentFragment() |
| var isFlex = false |
| for (var i = 0; i < children.length; i++) { |
| children[i].instanceId = this.data.instanceId |
| children[i].scale = this.data.scale |
| var child = componentManager.createElement(children[i]) |
| fragment.appendChild(child.node) |
| child.parentRef = parentRef |
| if (!isFlex |
| && child.data.style |
| && child.data.style.hasOwnProperty('flex') |
| ) { |
| isFlex = true |
| } |
| } |
| this.node.appendChild(fragment) |
| } |
| }, |
| |
| // @todo: changed param data to child |
| appendChild: function (data) { |
| var children = this.data.children |
| var componentManager = this.getComponentManager() |
| var child = componentManager.createElement(data) |
| this.node.appendChild(child.node) |
| // update this.data.children |
| if (!children || !children.length) { |
| this.data.children = [data] |
| } else { |
| children.push(data) |
| } |
| |
| return child |
| }, |
| |
| insertBefore: function (child, before) { |
| var children = this.data.children |
| var i = 0 |
| var l |
| var isAppend = false |
| |
| // update this.data.children |
| if (!children || !children.length || !before) { |
| isAppend = true |
| } else { |
| for (l = children.length; i < l; i++) { |
| if (children[i].ref === before.data.ref) { |
| break |
| } |
| } |
| if (i === l) { |
| isAppend = true |
| } |
| } |
| |
| |
| if (isAppend) { |
| this.node.appendChild(child.node) |
| children.push(child.data) |
| } else { |
| this.node.insertBefore(child.node, before.node) |
| children.splice(i, 0, child.data) |
| } |
| |
| }, |
| |
| removeChild: function (child) { |
| var children = this.data.children |
| // remove from this.data.children |
| var i = 0 |
| var componentManager = this.getComponentManager() |
| if (children && children.length) { |
| for (var l = children.length; i < l; i++) { |
| if (children[i].ref === child.data.ref) { |
| break |
| } |
| } |
| if (i < l) { |
| children.splice(i, 1) |
| } |
| } |
| // remove from componentMap recursively |
| componentManager.removeElementByRef(child.data.ref) |
| this.node.removeChild(child.node) |
| }, |
| |
| updateAttrs: function (attrs) { |
| // Note:attr must be injected into the dom element because |
| // it will be accessed from the outside developer by event.target.attr. |
| if (!this.node.attr) { |
| this.node.attr = {} |
| } |
| for (var key in attrs) { |
| var value = attrs[key] |
| var attrSetter = this.attr[key] |
| if (typeof attrSetter === 'function') { |
| attrSetter.call(this, value) |
| } else { |
| if (typeof value === 'boolean') { |
| this.node[key] = value |
| } else { |
| this.node.setAttribute(key, value) |
| } |
| this.node.attr[key] = value |
| } |
| } |
| }, |
| |
| updateStyle: function (style) { |
| for (var key in style) { |
| var value = style[key] |
| var styleSetter = this.style[key] |
| |
| if (typeof styleSetter === 'function') { |
| styleSetter.call(this, value) |
| } else { |
| if (typeof value === 'number' |
| && (key !== 'flex' && key !== 'opacity' && key !== 'zIndex') |
| ) { |
| value = value * this.data.scale + 'px' |
| } |
| this.node.style[key] = value |
| } |
| } |
| }, |
| |
| bindEvents: function (evts) { |
| var componentManager = this.getComponentManager() |
| if (evts |
| && Object.prototype.toString.call(evts).slice(8, -1) === 'Array' |
| ) { |
| for (var i = 0, l = evts.length; i < l; i++) { |
| componentManager.addEvent(this, evts[i]) |
| } |
| } |
| }, |
| |
| // dispatch a specified event on this.node |
| // - type: event type |
| // - data: event data |
| // - config: event config object |
| // - bubbles |
| // - cancelable |
| dispatchEvent: function (type, data, config) { |
| var event = document.createEvent('HTMLEvents') |
| config = config || {} |
| event.initEvent(type, config.bubbles || false, config.cancelable || false) |
| !data && (data = {}) |
| event.data = utils.extend({}, data) |
| utils.extend(event, data) |
| if (type === 'appear') { |
| console.log('appear', data) |
| } |
| this.node.dispatchEvent(event) |
| }, |
| |
| updateRecursiveAttr: function (data) { |
| this.updateAttrs(data.attr) |
| var componentManager = this.getComponentManager() |
| var children = this.data.children |
| if (children) { |
| for (var i = 0; i < children.length; i++) { |
| var child = componentManager.getElementByRef(children[i].ref) |
| if (child) { |
| child.updateRecursiveAttr(data.children[i]) |
| } |
| } |
| } |
| }, |
| |
| updateRecursiveStyle: function (data) { |
| this.updateStyle(data.style) |
| var componentManager = this.getComponentManager() |
| var children = this.data.children |
| if (children) { |
| for (var i = 0; i < children.length; i++) { |
| var child = componentManager.getElementByRef(children[i].ref) |
| if (child) { |
| child.updateRecursiveStyle(data.children[i]) |
| } |
| } |
| } |
| }, |
| |
| updateRecursiveAll: function (data) { |
| this.updateAttrs(data.attr) |
| this.updateStyle(data.style) |
| var componentManager = this.getComponentManager() |
| |
| // var oldRef = this.data.ref |
| // if (componentMap[oldRef]) { |
| // delete componentMap[oldRef] |
| // } |
| // this.data.ref = data.ref |
| // componentMap[data.ref] = this |
| |
| var children = this.data.children |
| if (children) { |
| for (var i = 0; i < children.length; i++) { |
| var child = componentManager.getElementByRef(children[i].ref) |
| if (child) { |
| child.updateRecursiveAll(data.children[i]) |
| } |
| } |
| } |
| }, |
| |
| attr: {}, // attr setters |
| |
| style: Object.create(flexbox), // style setters |
| |
| clearAttr: function () { |
| }, |
| |
| clearStyle: function () { |
| this.node.cssText = '' |
| } |
| } |
| |
| Component.prototype.style.position = function (value) { |
| // TODO: make it in a decent implementation |
| if (value === 'sticky') { |
| this.node.style.zIndex = 100 |
| setTimeout(function () { |
| this.sticky = new lib.sticky(this.node, { |
| top: 0 |
| }) |
| }.bind(this), 0) |
| } else { |
| this.node.style.position = value |
| } |
| } |
| |
| module.exports = Component |
| |
| |
| /***/ }, |
| /* 17 */ |
| /***/ function(module, exports) { |
| |
| 'use strict' |
| |
| // Flexbox polyfill |
| var flexboxSetters = (function () { |
| var BOX_ALIGN = { |
| stretch: 'stretch', |
| 'flex-start': 'start', |
| 'flex-end': 'end', |
| center: 'center' |
| } |
| var BOX_ORIENT = { |
| row: 'horizontal', |
| column: 'vertical' |
| } |
| var BOX_PACK = { |
| 'flex-start': 'start', |
| 'flex-end': 'end', |
| center: 'center', |
| 'space-between': 'justify', |
| 'space-around': 'justify' // Just same as `space-between` |
| } |
| return { |
| flex: function (value) { |
| this.node.style.webkitBoxFlex = value |
| this.node.style.webkitFlex = value |
| this.node.style.flex = value |
| }, |
| alignItems: function (value) { |
| this.node.style.webkitBoxAlign = BOX_ALIGN[value] |
| this.node.style.webkitAlignItems = value |
| this.node.style.alignItems = value |
| }, |
| alignSelf: function (value) { |
| this.node.style.webkitAlignSelf = value |
| this.node.style.alignSelf = value |
| }, |
| flexDirection: function (value) { |
| this.node.style.webkitBoxOrient = BOX_ORIENT[value] |
| this.node.style.webkitFlexDirection = value |
| this.node.style.flexDirection = value |
| }, |
| justifyContent: function (value) { |
| this.node.style.webkitBoxPack = BOX_PACK[value] |
| this.node.style.webkitJustifyContent = value |
| this.node.style.justifyContent = value |
| } |
| } |
| })() |
| |
| module.exports = flexboxSetters |
| |
| |
| /***/ }, |
| /* 18 */ |
| /***/ function(module, exports) { |
| |
| (typeof window === 'undefined') && (window = {ctrl: {}, lib: {}});!window.ctrl && (window.ctrl = {});!window.lib && (window.lib = {});!function(a,b,c){function d(a){return null!=a&&"object"==typeof a&&Object.getPrototypeOf(a)==Object.prototype}function e(a,b){var c,d,e,f=null,g=0,h=function(){g=Date.now(),f=null,e=a.apply(c,d)};return function(){var i=Date.now(),j=b-(i-g);return c=this,d=arguments,0>=j?(clearTimeout(f),f=null,g=i,e=a.apply(c,d)):f||(f=setTimeout(h,j)),e}}function f(a){var b="";return Object.keys(a).forEach(function(c){b+=c+":"+a[c]+";"}),b}function g(a,c){!c&&d(a)&&(c=a,a=c.element),c=c||{},a.nodeType!=b.ELEMENT_NODE&&"string"==typeof a&&(a=b.querySelector(a));var e=this;e.element=a,e.top=c.top||0,e.withinParent=void 0==c.withinParent?!1:c.withinParent,e.init()}var h=a.parseInt,i=navigator.userAgent,j=!!i.match(/Firefox/i),k=!!i.match(/IEMobile/i),l=j?"-moz-":k?"-ms-":"-webkit-",m=j?"Moz":k?"ms":"webkit",n=function(){var a=b.createElement("div"),c=a.style;return c.cssText="position:"+l+"sticky;position:sticky;",-1!=c.position.indexOf("sticky")}();g.prototype={constructor:g,init:function(){var a=this,b=a.element,c=b.style;c[m+"Transform"]="translateZ(0)",c.transform="translateZ(0)",a._originCssText=c.cssText,n?(c.position=l+"sticky",c.position="sticky",c.top=a.top+"px"):(a._simulateSticky(),a._bindResize())},_bindResize:function(){var b=this,c=/android/gi.test(navigator.appVersion),d=b._resizeEvent="onorientationchange"in a?"orientationchange":"resize",e=b._resizeHandler=function(){setTimeout(function(){b.refresh()},c?200:0)};a.addEventListener(d,e,!1)},refresh:function(){var a=this;n||(a._detach(),a._simulateSticky())},_addPlaceholder:function(a){var c,d=this,e=d.element,g=a.position;if(-1!=["static","relative"].indexOf(g)){c=d._placeholderElement=b.createElement("div");var i=h(a.width)+h(a.marginLeft)+h(a.marginRight),j=h(a.height);"border-box"!=a.boxSizing&&(i+=h(a.borderLeftWidth)+h(a.borderRightWidth)+h(a.paddingLeft)+h(a.paddingRight),j+=h(a.borderTopWidth)+h(a.borderBottomWidth)+h(a.paddingTop)+h(a.paddingBottom)),c.style.cssText=f({display:"none",visibility:"hidden",width:i+"px",height:j+"px",margin:0,"margin-top":a.marginTop,"margin-bottom":a.marginBottom,border:0,padding:0,"float":a["float"]||a.cssFloat}),e.parentNode.insertBefore(c,e)}return c},_simulateSticky:function(){var c=this,d=c.element,g=c.top,i=d.style,j=d.getBoundingClientRect(),k=getComputedStyle(d,""),l=d.parentNode,m=getComputedStyle(l,""),n=c._addPlaceholder(k),o=c.withinParent,p=c._originCssText,q=j.top-g+a.pageYOffset,r=l.getBoundingClientRect().bottom-h(m.paddingBottom)-h(m.borderBottomWidth)-h(k.marginBottom)-j.height-g+a.pageYOffset,s=p+f({position:"fixed",top:g+"px",width:k.width,"margin-top":0}),t=p+f({position:"absolute",top:r+"px",width:k.width}),u=1,v=c._scrollHandler=e(function(){var b=a.pageYOffset;q>b?1!=u&&(i.cssText=p,n&&(n.style.display="none"),u=1):!o&&b>=q||o&&b>=q&&r>b?2!=u&&(i.cssText=s,n&&3!=u&&(n.style.display="block"),u=2):o&&3!=u&&(i.cssText=t,n&&2!=u&&(n.style.display="block"),u=3)},100);if(a.addEventListener("scroll",v,!1),a.pageYOffset>=q){var w=b.createEvent("HTMLEvents");w.initEvent("scroll",!0,!0),a.dispatchEvent(w)}},_detach:function(){var b=this,c=b.element;if(c.style.cssText=b._originCssText,!n){var d=b._placeholderElement;d&&c.parentNode.removeChild(d),a.removeEventListener("scroll",b._scrollHandler,!1)}},destroy:function(){var b=this;b._detach();var c=b.element.style;c.removeProperty(l+"transform"),c.removeProperty("transform"),n||a.removeEventListener(b._resizeEvent,b._resizeHandler,!1)}},c.sticky=g}(window,document,window.lib||(window.lib={}));;module.exports = window.lib['sticky']; |
| |
| /***/ }, |
| /* 19 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| var utils = __webpack_require__(7) |
| |
| var _senderMap = {} |
| |
| function Sender(instance) { |
| if (!(this instanceof Sender)) { |
| return new Sender(instance) |
| } |
| this.instanceId = instance.instanceId |
| this.weexInstance = instance |
| _senderMap[this.instanceId] = this |
| } |
| |
| function _send(instanceId, msg) { |
| callJS(instanceId, [msg]) |
| } |
| |
| Sender.getSender = function (instanceId) { |
| return _senderMap[instanceId] |
| } |
| |
| Sender.prototype = { |
| |
| // perform a callback to jsframework. |
| performCallback: function (callbackId, data) { |
| var args = [callbackId] |
| data && args.push(data) |
| _send(this.instanceId, { |
| method: 'callback', |
| args: args |
| }) |
| }, |
| |
| fireEvent: function (ref, type, event) { |
| // Note that the event.target must be the standard event's |
| // currentTarget. Therefor a process for replacing target must |
| // be done when a event is fired. |
| var evt = utils.extend({}, event) |
| evt.target = evt.currentTarget |
| evt.value = event.target.value |
| evt.timestamp = Date.now() |
| _send(this.instanceId, { |
| method: 'fireEvent', |
| args: [ref, type, evt] |
| }) |
| } |
| |
| } |
| |
| module.exports = Sender |
| |
| /***/ }, |
| /* 20 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| /* WEBPACK VAR INJECTION */(function(global) {'use strict' |
| |
| var config = __webpack_require__(5) |
| var protocol = __webpack_require__(8) |
| var utils = __webpack_require__(7) |
| var FrameUpdater = __webpack_require__(10) |
| var Sender = __webpack_require__(19) |
| |
| var callQueue = [] |
| // Need a task counter? |
| // When FrameUpdater is not activated, tasks will not be push |
| // into callQueue and there will be no trace for situation of |
| // execution of tasks. |
| |
| // give 10ms for call handling, and rest 6ms for others |
| var MAX_TIME_FOR_EACH_FRAME = 10 |
| |
| // callNative: jsFramework will call this method to talk to |
| // this renderer. |
| // params: |
| // - instanceId: string. |
| // - tasks: array of object. |
| // - callbackId: number. |
| function callNative(instanceId, tasks, callbackId) { |
| var calls = [] |
| if (typeof tasks === 'string') { |
| try { |
| calls = JSON.parse(tasks) |
| } catch (e) { |
| console.error('invalid tasks:', tasks) |
| } |
| } else if (Object.prototype.toString.call(tasks).slice(8, -1) === 'Array') { |
| calls = tasks |
| } |
| var len = calls.length |
| calls[len - 1].callbackId = (!callbackId && callbackId !== 0) |
| ? -1 |
| : callbackId |
| // To solve the problem of callapp, the two-way time loop rule must |
| // be replaced by calling directly except the situation of page loading. |
| // 2015-11-03 |
| for (var i = 0; i < len; i++) { |
| if (FrameUpdater.isActive()) { |
| callQueue.push({ |
| instanceId: instanceId, |
| call: calls[i] |
| }) |
| } |
| else { |
| processCall(instanceId, calls[i]) |
| } |
| } |
| |
| } |
| |
| function processCallQueue() { |
| var len = callQueue.length |
| if (len === 0) { |
| return |
| } |
| var start = Date.now() |
| var elapsed = 0 |
| |
| while (--len >= 0 && elapsed < MAX_TIME_FOR_EACH_FRAME) { |
| var callObj = callQueue.shift() |
| processCall(callObj.instanceId, callObj.call) |
| elapsed = Date.now() - start |
| } |
| } |
| |
| function processCall(instanceId, call) { |
| var moduleName = call.module |
| var methodName = call.method |
| var module, method |
| var args = call.args || call.arguments || [] |
| |
| if (!(module = protocol.apiModule[moduleName])) { |
| return |
| } |
| if (!(method = module[methodName])) { |
| return |
| } |
| |
| method.apply(protocol.getWeexInstance(instanceId), args) |
| |
| var callbackId = call.callbackId |
| if ((callbackId |
| || callbackId === 0 |
| || callbackId === '0') |
| && callbackId !== '-1' |
| && callbackId !== -1) { |
| performNextTick(instanceId, callbackId) |
| } |
| } |
| |
| function performNextTick(instanceId, callbackId) { |
| Sender.getSender(instanceId).performCallback(callbackId) |
| } |
| |
| function nativeLog() { |
| if (config.debug) { |
| if (arguments[0].match(/^perf/)) { |
| console.info.apply(console, arguments) |
| return |
| } |
| console.debug.apply(console, arguments) |
| } |
| } |
| |
| function exportsBridgeMethodsToGlobal() { |
| global.callNative = callNative |
| global.nativeLog = nativeLog |
| } |
| |
| module.exports = { |
| |
| init: function () { |
| |
| // process callQueue every 16 milliseconds. |
| FrameUpdater.addUpdateObserver(processCallQueue) |
| FrameUpdater.start() |
| |
| // exports methods to global(window). |
| exportsBridgeMethodsToGlobal() |
| } |
| |
| } |
| |
| /* WEBPACK VAR INJECTION */}.call(exports, (function() { return this; }()))) |
| |
| /***/ }, |
| /* 21 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| var RootComponent = __webpack_require__(22) |
| var Container = __webpack_require__(23) |
| var Image = __webpack_require__(26) |
| var Text = __webpack_require__(28) |
| var List = __webpack_require__(29) |
| var Countdown = __webpack_require__(37) |
| var Marquee = __webpack_require__(39) |
| var Slider = __webpack_require__(40) |
| var Indicator = __webpack_require__(44) |
| var Tabheader = __webpack_require__(47) |
| var Scroller = __webpack_require__(51) |
| var Input = __webpack_require__(54) |
| var Select = __webpack_require__(55) |
| var Datepicker = __webpack_require__(56) |
| var Timepicker = __webpack_require__(57) |
| var Video = __webpack_require__(58) |
| var Switch = __webpack_require__(61) |
| var A = __webpack_require__(64) |
| var Embed = __webpack_require__(65) |
| |
| var components = { |
| init: function (Weex) { |
| Weex.registerComponent('root', RootComponent) |
| Weex.registerComponent('root', RootComponent) |
| Weex.registerComponent('container', Container) |
| Weex.registerComponent('image', Image) |
| Weex.registerComponent('text', Text) |
| Weex.registerComponent('list', List) |
| Weex.registerComponent('countdown', Countdown) |
| Weex.registerComponent('marquee', Marquee) |
| Weex.registerComponent('slider', Slider) |
| Weex.registerComponent('indicator', Indicator) |
| Weex.registerComponent('tabheader', Tabheader) |
| Weex.registerComponent('scroller', Scroller) |
| Weex.registerComponent('input', Input) |
| Weex.registerComponent('select', Select) |
| Weex.registerComponent('datepicker', Datepicker) |
| Weex.registerComponent('timepicker', Timepicker) |
| Weex.registerComponent('video', Video) |
| Weex.registerComponent('switch', Switch) |
| Weex.registerComponent('a', A) |
| Weex.registerComponent('embed', Embed) |
| } |
| } |
| |
| module.exports = components |
| |
| /***/ }, |
| /* 22 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| var ComponentManager = __webpack_require__(9) |
| var Component = __webpack_require__(16) |
| |
| // If nodeType is in this WHITE_LIST, just ignore it and |
| // replace it with a div element. |
| var WHITE_LIST = [] |
| |
| function RootComponent(data, nodeType) { |
| var id = data.rootId + '-root' |
| var componentManager = ComponentManager.getInstance(data.instanceId) |
| |
| // Return a NodeType instance. |
| if (nodeType && nodeType !== 'div' && WHITE_LIST.indexOf(nodeType) === -1) { |
| data.type = nodeType |
| var cmp = componentManager.createElement(data) |
| cmp.node.id = id |
| return cmp |
| } |
| |
| // Otherwise return a common weex-container component, |
| // whose node is a div element. |
| var node = document.createElement('div') |
| this.data = data |
| this.node = node |
| |
| this.createChildren() |
| this.updateAttrs(this.data.attr) |
| // issue: when add element to a list in lifetime hook 'ready', the |
| // styles is set to the classStyle, not style. This is a issue |
| // that jsframework should do something about. |
| var classStyle = this.data.classStyle |
| classStyle && this.updateStyle(this.data.classStyle) |
| this.updateStyle(this.data.style) |
| this.bindEvents(this.data.event) |
| } |
| |
| RootComponent.prototype = Object.create(Component.prototype) |
| |
| module.exports = RootComponent |
| |
| |
| /***/ }, |
| /* 23 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| __webpack_require__(24) |
| |
| var Component = __webpack_require__(16) |
| |
| function Container (data, nodeType) { |
| Component.call(this, data, nodeType) |
| this.node.classList.add('weex-container') |
| } |
| |
| Container.prototype = Object.create(Component.prototype) |
| |
| module.exports = Container |
| |
| |
| /***/ }, |
| /* 24 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| // style-loader: Adds some css to the DOM by adding a <style> tag |
| |
| // load the styles |
| var content = __webpack_require__(25); |
| if(typeof content === 'string') content = [[module.id, content, '']]; |
| // add the styles to the DOM |
| var update = __webpack_require__(4)(content, {}); |
| if(content.locals) module.exports = content.locals; |
| // Hot Module Replacement |
| if(false) { |
| // When the styles change, update the <style> tags |
| if(!content.locals) { |
| module.hot.accept("!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./container.scss", function() { |
| var newContent = require("!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./container.scss"); |
| if(typeof newContent === 'string') newContent = [[module.id, newContent, '']]; |
| update(newContent); |
| }); |
| } |
| // When the module is disposed, remove the <style> tags |
| module.hot.dispose(function() { update(); }); |
| } |
| |
| /***/ }, |
| /* 25 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| exports = module.exports = __webpack_require__(3)(); |
| // imports |
| |
| |
| // module |
| exports.push([module.id, ".weex-container {\n box-sizing: border-box;\n display: -webkit-box;\n display: -webkit-flex;\n display: flex;\n -webkit-box-orient: vertical;\n -webkit-flex-direction: column;\n flex-direction: column;\n position: relative;\n border: 0 solid black;\n margin: 0;\n padding: 0; }\n\n.weex-element {\n box-sizing: border-box;\n position: relative; }\n", "", {"version":3,"sources":["/./src/src/styles/container.scss"],"names":[],"mappings":"AAAA;EACE,uBAAsB;EACtB,qBAAoB;EACpB,sBAAqB;EACrB,cAAa;EACb,6BAA4B;EAC5B,+BAA8B;EAC9B,uBAAsB;EACtB,mBAAkB;EAClB,sBAAqB;EACrB,UAAS;EACT,WACD,EAAC;;AAEF;EACE,uBAAuB;EACvB,mBAAmB,EACpB","file":"container.scss","sourcesContent":[".weex-container {\n box-sizing:border-box;\n display:-webkit-box;\n display:-webkit-flex;\n display:flex;\n -webkit-box-orient:vertical;\n -webkit-flex-direction:column;\n flex-direction:column;\n position:relative;\n border:0 solid black;\n margin:0;\n padding:0\n}\n\n.weex-element {\n box-sizing: border-box;\n position: relative;\n}"],"sourceRoot":"webpack://"}]); |
| |
| // exports |
| |
| |
| /***/ }, |
| /* 26 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| var Atomic = __webpack_require__(27) |
| var LazyLoad = __webpack_require__(12) |
| var config = __webpack_require__(5) |
| |
| var DEFAULT_SIZE = 200 |
| var RESIZE_MODES = ['cover', 'contain'] // not temporarily supported |
| |
| /** |
| * resize=cover|contain|stretch v1.4 temporarily not supported |
| * src=url |
| */ |
| |
| function Image (data) { |
| this.width = data.style && data.style.width |
| ? (data.style.width + '').replace(/[^\d]/g, '') |
| : DEFAULT_SIZE |
| this.height = data.style && data.style.height |
| ? (data.style.height + '').replace(/[^\d]/g, '') |
| : DEFAULT_SIZE |
| this.width *= data.scale |
| this.height *= data.scale |
| var mode |
| var attr = data.attr |
| attr && (mode = attr.resize || attr.resizeMode) |
| if (RESIZE_MODES.indexOf(mode) !== -1) { |
| this.mode = mode |
| // TODO: resize-mode is not temporarily supported. |
| } |
| Atomic.call(this, data) |
| } |
| |
| Image.prototype = Object.create(Atomic.prototype) |
| |
| Image.prototype.create = function () { |
| var node = document.createElement('img') |
| node.classList.add('weex-element') |
| node.style.display = 'block' |
| node.style.outline = 'none' |
| return node |
| } |
| |
| Image.prototype.attr = { |
| src: function (value) { |
| if (!this.node.src) { |
| this.node.src = lib.img.defaultSrc |
| } |
| LazyLoad.makeImageLazy(this.node, value) |
| } |
| } |
| |
| Image.prototype.clearAttr = function () { |
| this.node.src = '' |
| } |
| |
| module.exports = Image |
| |
| |
| /***/ }, |
| /* 27 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| var Component = __webpack_require__(16) |
| |
| // Component which can have no subcomponents. |
| // This component should not be instantiated directly, since |
| // it is designed to be used as a base class to extend from. |
| function Atomic (data) { |
| Component.call(this, data) |
| } |
| |
| Atomic.prototype = Object.create(Component.prototype) |
| |
| Atomic.prototype.appendChild = function (data) { |
| // do nothing |
| return |
| } |
| |
| Atomic.prototype.insertBefore = function (child, before) { |
| // do nothing |
| return |
| } |
| |
| Atomic.prototype.removeChild = function (child) { |
| // do nothing |
| return |
| } |
| |
| module.exports = Atomic |
| |
| |
| /***/ }, |
| /* 28 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| var Atomic = __webpack_require__(16) |
| var utils = __webpack_require__(7) |
| |
| var DEFAULT_FONT_SIZE = 32 |
| |
| // attr |
| // - value: text content. |
| // - lines: maximum lines of the text. |
| function Text (data) { |
| Atomic.call(this, data) |
| } |
| |
| Text.prototype = Object.create(Atomic.prototype) |
| |
| Text.prototype.create = function () { |
| var node = document.createElement('div') |
| node.classList.add('weex-container') |
| node.style.fontSize = DEFAULT_FONT_SIZE * this.data.scale + 'px' |
| this.textNode = document.createElement('span') |
| // Give the developers the ability to control space |
| // and line-breakers. |
| this.textNode.style.whiteSpace = 'pre-wrap' |
| this.textNode.style.display = '-webkit-box' |
| this.textNode.style.webkitBoxOrient = 'vertical' |
| this.style.lines.call(this, this.data.style.lines) |
| node.appendChild(this.textNode) |
| return node |
| } |
| |
| Text.prototype.attr = { |
| value: function (value) { |
| var span = this.node.firstChild |
| span.innerHTML = '' |
| if (!value) { |
| return |
| } |
| span.textContent = value |
| /** |
| * Developers are supposed to have the ability to break text |
| * lines manually. Using `` `` to replace text space is |
| * not compatible with the ``-webkit-line-clamp``. Therefor |
| * we use ``white-space: no-wrap`` instead (instead of the |
| * code bellow). |
| |
| var frag = document.createDocumentFragment() |
| text.split(' ').forEach(function(str) { |
| var textNode = document.createTextNode(str) |
| var space = document.createElement('i') |
| space.innerHTML = ' ' |
| frag.appendChild(space) |
| frag.appendChild(textNode) |
| }) |
| frag.removeChild(frag.firstChild) |
| span.appendChild(document.createElement('br')) |
| span.appendChild(frag) |
| }) |
| span.removeChild(span.firstChild) |
| */ |
| } |
| } |
| |
| Text.prototype.clearAttr = function () { |
| this.node.firstChild.textContent = '' |
| } |
| |
| Text.prototype.style = utils.extend(Object.create(Atomic.prototype.style), { |
| |
| lines: function (val) { |
| val = parseInt(val) |
| if (val !== val) { // NaN |
| return |
| } |
| if (val <= 0) { |
| this.textNode.style.textOverflow = '' |
| this.textNode.style.overflow = 'visible' |
| this.textNode.style.webkitLineClamp = '' |
| } else { |
| this.textNode.style.overflow = 'hidden' |
| this.textNode.style.textOverflow = 'ellipsis' |
| this.textNode.style.webkitLineClamp = lines |
| } |
| } |
| |
| }) |
| |
| module.exports = Text |
| |
| |
| /***/ }, |
| /* 29 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| __webpack_require__(30) |
| __webpack_require__(32) |
| |
| var Component = __webpack_require__(16) |
| var LazyLoad = __webpack_require__(12) |
| |
| var DEFAULT_LOAD_MORE_OFFSET = 500 |
| |
| function List(data, nodeType) { |
| // this.loadmoreOffset = Number(data.attr.loadmoreoffset) |
| // this.isAvailableToFireloadmore = true |
| Component.call(this, data, nodeType) |
| } |
| |
| List.prototype = Object.create(Component.prototype) |
| |
| List.prototype.create = function (nodeType) { |
| var Scroll = lib.scroll |
| var node = Component.prototype.create.call(this, nodeType) |
| node.classList.add('weex-container', 'list-wrap') |
| this.listElement = document.createElement('div') |
| this.listElement.classList.add( |
| 'weex-container' |
| , 'list-element' |
| ) |
| node.appendChild(this.listElement) |
| this.scroller = new Scroll({ |
| scrollElement: this.listElement |
| , direction: 'y' |
| }) |
| this.scroller.init() |
| return node |
| } |
| |
| List.prototype.bindEvents = function (evts) { |
| Component.prototype.bindEvents.call(this, evts) |
| // to enable lazyload for Images. |
| this.scroller.addEventListener('scrolling', function (e) { |
| var so = e.scrollObj |
| this.dispatchEvent('scroll', { |
| originalType: 'scrolling', |
| scrollTop: so.getScrollTop(), |
| scrollLeft: so.getScrollLeft() |
| }, { |
| bubbles: true |
| }) |
| }.bind(this)) |
| |
| this.scroller.addEventListener('pullupend', function (e) { |
| this.dispatchEvent('loadmore') |
| }.bind(this)) |
| } |
| |
| List.prototype.appendChild = function (data) { |
| var children = this.data.children |
| var componentManager = this.getComponentManager() |
| var child = componentManager.createElement(data) |
| this.listElement.appendChild(child.node) |
| |
| // update this.data.children |
| if (!children || !children.length) { |
| this.data.children = [data] |
| } else { |
| children.push(data) |
| } |
| |
| return child |
| } |
| |
| List.prototype.insertBefore = function (child, before) { |
| var children = this.data.children |
| var i = 0 |
| var isAppend = false |
| |
| // update this.data.children |
| if (!children || !children.length || !before) { |
| isAppend = true |
| } else { |
| for (var l = children.length; i < l; i++) { |
| if (children[i].ref === child.data.ref) { |
| break |
| } |
| } |
| if (i === l) { |
| isAppend = true |
| } |
| } |
| |
| if (isAppend) { |
| this.listElement.appendChild(child.node) |
| children.push(child.data) |
| } else { |
| this.listElement.insertBefore(child.node, before.node) |
| children.splice(i, 0, child.data) |
| } |
| } |
| |
| List.prototype.removeChild = function (child) { |
| var children = this.data.children |
| // remove from this.data.children |
| var i = 0 |
| var componentManager = this.getComponentManager() |
| if (children && children.length) { |
| for (var l = children.length; i < l; i++) { |
| if (children[i].ref === child.data.ref) { |
| break |
| } |
| } |
| if (i < l) { |
| children.splice(i, 1) |
| } |
| } |
| // remove from componentMap recursively |
| componentManager.removeElementByRef(child.data.ref) |
| this.listElement.removeChild(child.node) |
| } |
| |
| module.exports = List |
| |
| |
| /***/ }, |
| /* 30 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| // style-loader: Adds some css to the DOM by adding a <style> tag |
| |
| // load the styles |
| var content = __webpack_require__(31); |
| if(typeof content === 'string') content = [[module.id, content, '']]; |
| // add the styles to the DOM |
| var update = __webpack_require__(4)(content, {}); |
| if(content.locals) module.exports = content.locals; |
| // Hot Module Replacement |
| if(false) { |
| // When the styles change, update the <style> tags |
| if(!content.locals) { |
| module.hot.accept("!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./list.scss", function() { |
| var newContent = require("!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./list.scss"); |
| if(typeof newContent === 'string') newContent = [[module.id, newContent, '']]; |
| update(newContent); |
| }); |
| } |
| // When the module is disposed, remove the <style> tags |
| module.hot.dispose(function() { update(); }); |
| } |
| |
| /***/ }, |
| /* 31 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| exports = module.exports = __webpack_require__(3)(); |
| // imports |
| |
| |
| // module |
| exports.push([module.id, ".list-wrap {\n display: block;\n overflow: hidden; }\n\n.list-element {\n -webkit-box-orient: vertical;\n -webkit-flex-direction: column;\n flex-direction: column; }\n", "", {"version":3,"sources":["/./src/src/styles/list.scss"],"names":[],"mappings":"AAAA;EACC,eAAe;EACf,iBAAiB,EACjB;;AAED;EACE,6BAA6B;EAC7B,+BAA+B;EAC/B,uBAAuB,EACxB","file":"list.scss","sourcesContent":[".list-wrap {\n\tdisplay: block;\n\toverflow: hidden;\n}\n\n.list-element {\n -webkit-box-orient: vertical;\n -webkit-flex-direction: column;\n flex-direction: column;\n}"],"sourceRoot":"webpack://"}]); |
| |
| // exports |
| |
| |
| /***/ }, |
| /* 32 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| (typeof window === 'undefined') && (window = {ctrl: {}, lib: {}});!window.ctrl && (window.ctrl = {});!window.lib && (window.lib = {});__webpack_require__(33);__webpack_require__(34);__webpack_require__(35);__webpack_require__(36);!function(a,b,c){function d(){b.scroll.outputDebugLog&&console.debug.apply(console,arguments)}function e(a){var b=a.getBoundingClientRect();if(!b){b={},b.width=a.offsetWidth,b.height=a.offsetHeight,b.left=a.offsetLeft,b.top=a.offsetTop;for(var c=a.offsetParent;c;)b.left+=c.offsetLeft,b.top+=c.offsetTop,c=c.offsetParent;b.right=b.left+b.width,b.bottom=b.top+b.height}return b}function f(a){return 0-a.options[a.axis+"PaddingTop"]}function g(a){var b=e(a.element),c=e(a.viewport),d=f(a);if("y"===a.axis)var g=0-b.height+c.height;else var g=0-b.width+c.width;return Math.min(g+a.options[a.axis+"PaddingBottom"],d)}function h(a,b){return b>a.minScrollOffset?b-a.minScrollOffset:b<a.maxScrollOffset?b-a.maxScrollOffset:void 0}function i(a,b){return b>a.minScrollOffset?b=a.minScrollOffset:b<a.maxScrollOffset&&(b=a.maxScrollOffset),b}function j(a,b,c){d(a.element.scrollId,b,c);var e=p.createEvent("HTMLEvents");if(e.initEvent(b,!1,!0),e.scrollObj=a,c)for(var f in c)e[f]=c[f];a.element.dispatchEvent(e),a.viewport.dispatchEvent(e)}function k(a){var b,c={x:0,y:0},d=getComputedStyle(a.element)[y+"Transform"];return"none"!==d&&(b=d.match(/^matrix3d\((?:[-\d.]+,\s*){12}([-\d.]+),\s*([-\d.]+)(?:,\s*[-\d.]+){2}\)/)||d.match(/^matrix\((?:[-\d.]+,\s*){4}([-\d.]+),\s*([-\d.]+)\)$/))&&(c.x=parseFloat(b[1])||0,c.y=parseFloat(b[2])||0),c}function l(a,b){return a=parseFloat(a),b=parseFloat(b),0!=a&&(a+="px"),0!=b&&(b+="px"),A?"translate3d("+a+", "+b+", 0)":"translate("+a+", "+b+")"}function m(a,b,c){""===b&&""===c?a.element.style[y+"Transition"]="":a.element.style[y+"Transition"]=x+"transform "+b+" "+c+" 0s"}function n(a,b){var c=0,d=0;"object"==typeof b?(c=b.x,d=b.y):"y"===a.axis?d=b:c=b,a.element.style[y+"Transform"]=l(c,d)}function o(a,c){function l(a){return F||L?(a.preventDefault(),a.stopPropagation(),!1):!0}function o(a){F||L||setTimeout(function(){var b=document.createEvent("HTMLEvents");b.initEvent("niceclick",!0,!0),a.target.dispatchEvent(b)},300)}function p(a,c){I=null,clearTimeout(J),J=setTimeout(function(){I&&(I=null,b.animation.requestFrame(a))},c||400),I=a}function q(a){if(!E.enabled)return!1;if("undefined"!=typeof a.isVertical){if(!("y"===E.axis&&a.isVertical||"x"===E.axis&&!a.isVertical))return!1;a.stopPropagation()}return!0}function t(a){if(q(a))if(L&&D(),c.useFrameAnimation)H&&H.stop(),H=null;else{var b=k(E);n(E,b),m(E,"",""),I=null,clearTimeout(J)}}function w(a){if(q(a)){var d=k(E)[E.axis],e=h(E,d);if(e){var f=i(E,d);if(c.useFrameAnimation){var g=f-d;H=new b.animation(400,b.cubicbezier.ease,0,function(a,b){var c=(d+g*b).toFixed(2);n(E,c),j(E,"scrolling")}),H.onend(D),H.play()}else{var l=f.toFixed(0);m(E,"0.4s","ease"),n(E,l),p(D,400),b.animation.requestFrame(function(){L&&E.enabled&&(j(E,"scrolling"),b.animation.requestFrame(arguments.callee))})}e>0?j(E,"y"===E.axis?"pulldownend":"pullrightend"):0>e&&j(E,"y"===E.axis?"pullupend":"pullleftend")}else L&&D()}}function x(a){q(a)&&(E.transformOffset=k(E),E.minScrollOffset=f(E),E.maxScrollOffset=g(E),K=2.5,N=!0,L=!0,M=!1,j(E,"scrollstart"),O=a["displacement"+E.axis.toUpperCase()])}function z(a){if(q(a)){var b=a["displacement"+E.axis.toUpperCase()];if(Math.abs(b-O)<5)return void a.stopPropagation();O=b;var c=E.transformOffset[E.axis]+b;c>E.minScrollOffset?(c=E.minScrollOffset+(c-E.minScrollOffset)/K,K*=1.003):c<E.maxScrollOffset&&(c=E.maxScrollOffset-(E.maxScrollOffset-c)/K,K*=1.003),K>4&&(K=4);var d=h(E,c);d&&(j(E,d>0?"y"===E.axis?"pulldown":"pullright":"y"===E.axis?"pullup":"pullleft",{boundaryOffset:Math.abs(d)}),E.options.noBounce&&(c=i(E,c))),n(E,c.toFixed(2)),j(E,"scrolling")}}function A(a){q(a)&&a.isflick&&C(a)}function C(a){N=!0;var e,f,g,i,l,o,q,r,s,t,v,w,x,y,z,A,B;i=k(E)[E.axis];var C=h(E,i);if(!C){e=a["velocity"+E.axis.toUpperCase()];var F=2,G=.0015;c.inertia&&u[c.inertia]&&(F=u[c.inertia][0],G=u[c.inertia][1]),e>F&&(e=F),-F>e&&(e=-F),f=G*(e/Math.abs(e)),o=new b.motion({v:e,a:-f}),g=o.t,l=i+o.s;var I=h(E,l);if(I){d("惯性计算超出了边缘",I),q=e,r=f,I>0?(t=E.minScrollOffset,w=1):(t=E.maxScrollOffset,w=-1),v=new b.motion({v:w*q,a:-w*r,s:Math.abs(t-i)}),s=v.t;var J=v.generateCubicBezier();x=q-r*s,y=.03*(x/Math.abs(x)),B=new b.motion({v:x,a:-y}),z=B.t,A=t+B.s;B.generateCubicBezier();if(c.noBounce)if(d("没有回弹效果"),i!==t)if(c.useFrameAnimation){var K=t-i,O=b.cubicbezier(J[0][0],J[0][1],J[1][0],J[1][1]);H=new b.animation(s.toFixed(0),O,0,function(a,b){var c=i+K*b;k(E,c.toFixed(2)),j(E,"scrolling",{afterFlick:!0})}),H.onend(D),H.play()}else{var P=t.toFixed(0);m(E,(s/1e3).toFixed(2)+"s","cubic-bezier("+J+")"),n(E,P),p(D,1e3*(s/1e3).toFixed(2))}else D();else if(i!==A)if(d("惯性滚动","s="+A.toFixed(0),"t="+((s+z)/1e3).toFixed(2)),c.useFrameAnimation){var K=A-i,O=b.cubicbezier.easeOut;H=new b.animation((s+z).toFixed(0),O,0,function(a,b){var c=i+K*b;n(E,c.toFixed(2)),j(E,"scrolling",{afterFlick:!0})}),H.onend(function(){if(E.enabled){var a=t-A,c=b.cubicbezier.ease;H=new b.animation(400,c,0,function(b,c){var d=A+a*c;n(E,d.toFixed(2)),j(E,"scrolling",{afterFlick:!0})}),H.onend(D),H.play()}}),H.play()}else{var P=A.toFixed(0);m(E,((s+z)/1e3).toFixed(2)+"s","ease-out"),n(E,P),p(function(a){if(E.enabled)if(d("惯性回弹","s="+t.toFixed(0),"t=400"),A!==t){var b=t.toFixed(0);m(E,"0.4s","ease"),n(E,b),p(D,400)}else D()},1e3*((s+z)/1e3).toFixed(2))}else D()}else{d("惯性计算没有超出边缘");var Q=o.generateCubicBezier();if(c.useFrameAnimation){var K=l-i,O=b.cubicbezier(Q[0][0],Q[0][1],Q[1][0],Q[1][1]);H=new b.animation(g.toFixed(0),O,0,function(a,b){var c=(i+K*b).toFixed(2);n(E,c),j(E,"scrolling",{afterFlick:!0})}),H.onend(D),H.play()}else{var P=l.toFixed(0);m(E,(g/1e3).toFixed(2)+"s","cubic-bezier("+Q+")"),n(E,P),p(D,1e3*(g/1e3).toFixed(2))}}M=!0,c.useFrameAnimation||b.animation.requestFrame(function(){L&&M&&E.enabled&&(j(E,"scrolling",{afterFlick:!0}),b.animation.requestFrame(arguments.callee))})}}function D(){E.enabled&&(N=!1,setTimeout(function(){!N&&L&&(L=!1,M=!1,c.useFrameAnimation?(H&&H.stop(),H=null):m(E,"",""),j(E,"scrollend"))},50))}var E=this;if(c=c||{},c.noBounce=!!c.noBounce,c.padding=c.padding||{},null==c.isPrevent?c.isPrevent=!0:c.isPrevent=!!c.isPrevent,null==c.isFixScrollendClick?c.isFixScrollendClick=!0:c.isFixScrollendClick=!!c.isFixScrollendClick,c.padding?(c.yPaddingTop=-c.padding.top||0,c.yPaddingBottom=-c.padding.bottom||0,c.xPaddingTop=-c.padding.left||0,c.xPaddingBottom=-c.padding.right||0):(c.yPaddingTop=0,c.yPaddingBottom=0,c.xPaddingTop=0,c.xPaddingBottom=0),c.direction=c.direction||"y",c.inertia=c.inertia||"normal",this.options=c,E.axis=c.direction,this.element=a,this.viewport=a.parentNode,this.plugins={},this.element.scrollId=setTimeout(function(){r[E.element.scrollId+""]=E},1),this.viewport.addEventListener("touchstart",t,!1),this.viewport.addEventListener("touchend",w,!1),this.viewport.addEventListener("touchcancel",w,!1),this.viewport.addEventListener("panstart",x,!1),this.viewport.addEventListener("panmove",z,!1),this.viewport.addEventListener("panend",A,!1),c.isPrevent&&(this.viewport.addEventListener("touchstart",function(a){B=!0},!1),E.viewport.addEventListener("touchend",function(a){B=!1},!1)),c.isFixScrollendClick){var F,G;this.viewport.addEventListener("scrolling",function(){F=!0,G&&clearTimeout(G),G=setTimeout(function(a){F=!1},400)},!1),this.viewport.addEventListener("click",l,!1),this.viewport.addEventListener("tap",o,!1)}if(c.useFrameAnimation){var H;Object.defineProperty(this,"animation",{get:function(){return H}})}else{var I,J=0;a.addEventListener(v?"transitionend":y+"TransitionEnd",function(a){if(I){var c=I;I=null,clearTimeout(J),b.animation.requestFrame(function(){c(a)})}},!1)}var K,L,M,N;Object.defineProperty(this,"isScrolling",{get:function(){return!!L}});var O,P={init:function(){return this.enable(),this.refresh(),this.scrollTo(0),this},enable:function(){return this.enabled=!0,this},disable:function(){var a=this.element;return this.enabled=!1,this.options.useFrameAnimation?H&&H.stop():b.animation.requestFrame(function(){a.style[y+"Transform"]=getComputedStyle(a)[y+"Transform"]}),this},getScrollWidth:function(){return e(this.element).width},getScrollHeight:function(){return e(this.element).height},getScrollLeft:function(){return-k(this).x-this.options.xPaddingTop},getScrollTop:function(){return-k(this).y-this.options.yPaddingTop},getMaxScrollLeft:function(){return-E.maxScrollOffset-this.options.xPaddingTop},getMaxScrollTop:function(){return-E.maxScrollOffset-this.options.yPaddingTop},getBoundaryOffset:function(){return Math.abs(h(this,k(this)[this.axis])||0)},refresh:function(){var a=this.element,b="y"===this.axis,c=b?"height":"width";if(null!=this.options[c])a.style[c]=this.options[c]+"px";else if(this.options.useElementRect)a.style[c]="auto",a.style[c]=e(a)[c]+"px";else if(a.childElementCount>0){var d,h,i=a.firstElementChild,l=a.lastElementChild;if(document.createRange&&!this.options.ignoreOverflow&&(d=document.createRange(),d.selectNodeContents(a),h=e(d)),h)a.style[c]=h[c]+"px";else{for(;i&&0===e(i)[c]&&i.nextElementSibling;)i=i.nextElementSibling;for(;l&&l!==i&&0===e(l)[c]&&l.previousElementSibling;)l=l.previousElementSibling;a.style[c]=e(l)[b?"bottom":"right"]-e(i)[b?"top":"left"]+"px"}}return this.transformOffset=k(this),this.minScrollOffset=f(this),this.maxScrollOffset=g(this),this.scrollTo(-this.transformOffset[this.axis]-this.options[this.axis+"PaddingTop"]),j(this,"contentrefresh"),this},offset:function(a){var b=e(this.element),c=e(a);if("y"===this.axis){var d={top:c.top-b.top-this.options.yPaddingTop,left:c.left-b.left,right:b.right-c.right,width:c.width,height:c.height};d.bottom=d.top+d.height}else{var d={top:c.top-b.top,bottom:b.bottom-c.bottom,left:c.left-b.left-this.options.xPaddingTop,width:c.width,height:c.height};d.right=d.left+d.width}return d},getRect:function(a){var b=e(this.viewport),c=e(a);if("y"===this.axis){var d={top:c.top-b.top,left:c.left-b.left,right:b.right-c.right,width:c.width,height:c.height};d.bottom=d.top+d.height}else{var d={top:c.top-b.top,bottom:b.bottom-c.bottom,left:c.left-b.left,width:c.width,height:c.height};d.right=d.left+d.width}return d},isInView:function(a){var b=this.getRect(this.viewport),c=this.getRect(a);return"y"===this.axis?b.top<c.bottom&&b.bottom>c.top:b.left<c.right&&b.right>c.left},scrollTo:function(a,c){var d=this;this.element;if(a=-a-this.options[this.axis+"PaddingTop"],a=i(this,a),L=!0,c===!0)if(this.options.useFrameAnimation){var e=k(d)[this.axis],f=a-e;H=new b.animation(400,b.cubicbezier.ease,0,function(a,b){var c=(e+f*b).toFixed(2);n(d,c),j(d,"scrolling")}),H.onend(D),H.play()}else m(d,"0.4s","ease"),n(d,a),p(D,400),b.animation.requestFrame(function(){L&&d.enabled&&(j(d,"scrolling"),b.animation.requestFrame(arguments.callee))});else this.options.useFrameAnimation||m(d,"",""),n(d,a),D();return this},scrollToElement:function(a,b){var c=this.offset(a);return c=c["y"===this.axis?"top":"left"],this.scrollTo(c,b)},getViewWidth:function(){return e(this.viewport).width},getViewHeight:function(){return e(this.viewport).height},addPulldownHandler:function(a){var b=this;return this.element.addEventListener("pulldownend",function(c){b.disable(),a.call(b,c,function(){b.scrollTo(0,!0),b.refresh(),b.enable()})},!1),this},addPullupHandler:function(a){var b=this;return this.element.addEventListener("pullupend",function(c){b.disable(),a.call(b,c,function(){b.scrollTo(b.getScrollHeight(),!0),b.refresh(),b.enable()})},!1),this},addScrollstartHandler:function(a){var b=this;return this.element.addEventListener("scrollstart",function(c){a.call(b,c)},!1),this},addScrollingHandler:function(a){var b=this;return this.element.addEventListener("scrolling",function(c){a.call(b,c)},!1),this},addScrollendHandler:function(a){var b=this;return this.element.addEventListener("scrollend",function(c){a.call(b,c)},!1),this},addContentrenfreshHandler:function(a){var b=this;this.element.addEventListener("contentrefresh",function(c){a.call(b,c)},!1)},addEventListener:function(a,b,c){var d=this;this.element.addEventListener(a,function(a){b.call(d,a)},!!c)},removeEventListener:function(a,b){var c=this;this.element.removeEventListener(a,function(a){b.call(c,a)})},enablePlugin:function(a,b){var c=s[a];return c&&!this.plugins[a]&&(this.plugins[a]=!0,b=b||{},c.call(this,a,b)),this}};for(var Q in P)this[Q]=P[Q];delete P}var p=a.document,q=a.navigator.userAgent,r={},s={},t=a.dpr||(a.navigator.userAgent.match(/iPhone|iPad|iPod/)?document.documentElement.clientWidth/a.screen.availWidth:1),u={normal:[2*t,.0015*t],slow:[1.5*t,.003*t],veryslow:[1.5*t,.005*t]},v=!!q.match(/Firefox/i),w=!!q.match(/IEMobile/i),x=v?"-moz-":w?"-ms-":"-webkit-",y=v?"Moz":w?"ms":"webkit",z=w?"MSCSSMatrix":"WebKitCSSMatrix",A=!!v||z in a&&"m11"in new a[z],B=!1;p.addEventListener("touchmove",function(a){return B?(a.preventDefault(),!1):!0},!1),b.scroll=function(a,c){if(1===arguments.length&&!(arguments[0]instanceof HTMLElement))if(c=arguments[0],c.scrollElement)a=c.scrollElement;else{if(!c.scrollWrap)throw new Error("no scroll element");a=c.scrollWrap.firstElementChild}if(!a.parentNode)throw new Error("wrong dom tree");if(c&&c.direction&&["x","y"].indexOf(c.direction)<0)throw new Error("wrong direction");var d;return d=c.downgrade===!0&&b.scroll.downgrade?b.scroll.downgrade(a,c):a.scrollId?r[a.scrollId]:new o(a,c)},b.scroll.plugin=function(a,b){return b?(a=a.split(","),void a.forEach(function(a){s[a]=b})):s[a]}}(window,window.lib||(window.lib={}));;module.exports = window.lib['scroll']; |
| |
| /***/ }, |
| /* 33 */ |
| /***/ function(module, exports) { |
| |
| (typeof window === 'undefined') && (window = {ctrl: {}, lib: {}});!window.ctrl && (window.ctrl = {});!window.lib && (window.lib = {});!function(a,b){function c(a){return setTimeout(a,l)}function d(a){clearTimeout(a)}function e(){var a={},b=new m(function(b,c){a.resolve=b,a.reject=c});return a.promise=b,a}function f(a,b){return["then","catch"].forEach(function(c){b[c]=function(){return a[c].apply(a,arguments)}}),b}function g(b){var c,d,h=!1;this.request=function(){h=!1;var g=arguments;return c=e(),f(c.promise,this),d=n(function(){h||c&&c.resolve(b.apply(a,g))}),this},this.cancel=function(){return d&&(h=!0,o(d),c&&c.reject("CANCEL")),this},this.clone=function(){return new g(b)}}function h(a,b){"function"==typeof b&&(b={0:b});for(var c=a/l,d=1/c,e=[],f=Object.keys(b).map(function(a){return parseInt(a)}),h=0;c>h;h++){var i=f[0],j=d*h;if(null!=i&&100*j>=i){var k=b[""+i];k instanceof g||(k=new g(k)),e.push(k),f.shift()}else e.length&&e.push(e[e.length-1].clone())}return e}function i(a){var c;return"string"==typeof a||a instanceof Array?b.cubicbezier?"string"==typeof a?b.cubicbezier[a]&&(c=b.cubicbezier[a]):a instanceof Array&&4===a.length&&(c=b.cubicbezier.apply(b.cubicbezier,a)):console.error("require lib.cubicbezier"):"function"==typeof a&&(c=a),c}function j(a,b,c){var d,g=h(a,c),j=1/(a/l),k=0,m=i(b);if(!m)throw new Error("unexcept timing function");var n=!1;this.play=function(){function a(){var c=j*(k+1).toFixed(10),e=g[k];e.request(c.toFixed(10),b(c).toFixed(10)).then(function(){n&&(k===g.length-1?(n=!1,d&&d.resolve("FINISH"),d=null):(k++,a()))},function(){})}if(!n)return n=!0,d||(d=e(),f(d.promise,this)),a(),this},this.stop=function(){return n?(n=!1,g[k]&&g[k].cancel(),this):void 0}}var k=60,l=1e3/k,m=a.Promise||b.promise&&b.promise.ES6Promise,n=window.requestAnimationFrame||window.msRequestAnimationFrame||window.webkitRequestAnimationFrame||window.mozRequestAnimationFrame||c,o=window.cancelAnimationFrame||window.msCancelAnimationFrame||window.webkitCancelAnimationFrame||window.mozCancelAnimationFrame||d;(n===c||o===d)&&(n=c,o=d),b.animation=function(a,b,c){return new j(a,b,c)},b.animation.frame=function(a){return new g(a)},b.animation.requestFrame=function(a){var b=new g(a);return b.request()}}(window,window.lib||(window.lib={}));;module.exports = window.lib['animation']; |
| |
| /***/ }, |
| /* 34 */ |
| /***/ function(module, exports) { |
| |
| (typeof window === 'undefined') && (window = {ctrl: {}, lib: {}});!window.ctrl && (window.ctrl = {});!window.lib && (window.lib = {});!function(a,b){function c(a,b,c,d){function e(a){return(3*k*a+2*l)*a+m}function f(a){return((k*a+l)*a+m)*a}function g(a){return((n*a+o)*a+p)*a}function h(a){for(var b,c,d=a,g=0;8>g;g++){if(c=f(d)-a,Math.abs(c)<j)return d;if(b=e(d),Math.abs(b)<j)break;d-=c/b}var h=1,i=0;for(d=a;h>i;){if(c=f(d)-a,Math.abs(c)<j)return d;c>0?h=d:i=d,d=(h+i)/2}return d}function i(a){return g(h(a))}var j=1e-6,k=3*a-3*c+1,l=3*c-6*a,m=3*a,n=3*b-3*d+1,o=3*d-6*b,p=3*b;return i}b.cubicbezier=c,b.cubicbezier.linear=c(0,0,1,1),b.cubicbezier.ease=c(.25,.1,.25,1),b.cubicbezier.easeIn=c(.42,0,1,1),b.cubicbezier.easeOut=c(0,0,.58,1),b.cubicbezier.easeInOut=c(.42,0,.58,1)}(window,window.lib||(window.lib={}));;module.exports = window.lib['cubicbezier']; |
| |
| /***/ }, |
| /* 35 */ |
| /***/ function(module, exports) { |
| |
| (typeof window === 'undefined') && (window = {ctrl: {}, lib: {}});!window.ctrl && (window.ctrl = {});!window.lib && (window.lib = {});!function(a){"use strict";function b(a,b){for(var c=a;c;){if(c.contains(b)||c==b)return c;c=c.parentNode}return null}function c(a,b,c){var d=i.createEvent("HTMLEvents");if(d.initEvent(b,!0,!0),"object"==typeof c)for(var e in c)d[e]=c[e];a.dispatchEvent(d)}function d(a,b,c,d,e,f,g,h){var i=Math.atan2(h-f,g-e)-Math.atan2(d-b,c-a),j=Math.sqrt((Math.pow(h-f,2)+Math.pow(g-e,2))/(Math.pow(d-b,2)+Math.pow(c-a,2))),k=[e-j*a*Math.cos(i)+j*b*Math.sin(i),f-j*b*Math.cos(i)-j*a*Math.sin(i)];return{rotate:i,scale:j,translate:k,matrix:[[j*Math.cos(i),-j*Math.sin(i),k[0]],[j*Math.sin(i),j*Math.cos(i),k[1]],[0,0,1]]}}function e(a){0===Object.keys(l).length&&(j.addEventListener("touchmove",f,!1),j.addEventListener("touchend",g,!1),j.addEventListener("touchcancel",h,!1));for(var d=0;d<a.changedTouches.length;d++){var e=a.changedTouches[d],i={};for(var m in e)i[m]=e[m];var n={startTouch:i,startTime:Date.now(),status:"tapping",element:a.srcElement||a.target,pressingHandler:setTimeout(function(b,d){return function(){"tapping"===n.status&&(n.status="pressing",c(b,"longpress",{touch:d,touches:a.touches,changedTouches:a.changedTouches,touchEvent:a})),clearTimeout(n.pressingHandler),n.pressingHandler=null}}(a.srcElement||a.target,a.changedTouches[d]),500)};l[e.identifier]=n}if(2==Object.keys(l).length){var o=[];for(var m in l)o.push(l[m].element);c(b(o[0],o[1]),"dualtouchstart",{touches:k.call(a.touches),touchEvent:a})}}function f(a){for(var e=0;e<a.changedTouches.length;e++){var f=a.changedTouches[e],g=l[f.identifier];if(!g)return;g.lastTouch||(g.lastTouch=g.startTouch),g.lastTime||(g.lastTime=g.startTime),g.velocityX||(g.velocityX=0),g.velocityY||(g.velocityY=0),g.duration||(g.duration=0);var h=Date.now()-g.lastTime,i=(f.clientX-g.lastTouch.clientX)/h,j=(f.clientY-g.lastTouch.clientY)/h,k=70;h>k&&(h=k),g.duration+h>k&&(g.duration=k-h),g.velocityX=(g.velocityX*g.duration+i*h)/(g.duration+h),g.velocityY=(g.velocityY*g.duration+j*h)/(g.duration+h),g.duration+=h,g.lastTouch={};for(var m in f)g.lastTouch[m]=f[m];g.lastTime=Date.now();var n=f.clientX-g.startTouch.clientX,o=f.clientY-g.startTouch.clientY,p=Math.sqrt(Math.pow(n,2)+Math.pow(o,2));("tapping"===g.status||"pressing"===g.status)&&p>10&&(g.status="panning",g.isVertical=!(Math.abs(n)>Math.abs(o)),c(g.element,"panstart",{touch:f,touches:a.touches,changedTouches:a.changedTouches,touchEvent:a,isVertical:g.isVertical}),c(g.element,(g.isVertical?"vertical":"horizontal")+"panstart",{touch:f,touchEvent:a})),"panning"===g.status&&(g.panTime=Date.now(),c(g.element,"panmove",{displacementX:n,displacementY:o,touch:f,touches:a.touches,changedTouches:a.changedTouches,touchEvent:a,isVertical:g.isVertical}),g.isVertical?c(g.element,"verticalpanmove",{displacementY:o,touch:f,touchEvent:a}):c(g.element,"horizontalpanmove",{displacementX:n,touch:f,touchEvent:a}))}if(2==Object.keys(l).length){for(var q,r=[],s=[],t=[],e=0;e<a.touches.length;e++){var f=a.touches[e],g=l[f.identifier];r.push([g.startTouch.clientX,g.startTouch.clientY]),s.push([f.clientX,f.clientY])}for(var m in l)t.push(l[m].element);q=d(r[0][0],r[0][1],r[1][0],r[1][1],s[0][0],s[0][1],s[1][0],s[1][1]),c(b(t[0],t[1]),"dualtouch",{transform:q,touches:a.touches,touchEvent:a})}}function g(a){if(2==Object.keys(l).length){var d=[];for(var e in l)d.push(l[e].element);c(b(d[0],d[1]),"dualtouchend",{touches:k.call(a.touches),touchEvent:a})}for(var i=0;i<a.changedTouches.length;i++){var n=a.changedTouches[i],o=n.identifier,p=l[o];if(p){if(p.pressingHandler&&(clearTimeout(p.pressingHandler),p.pressingHandler=null),"tapping"===p.status&&(p.timestamp=Date.now(),c(p.element,"tap",{touch:n,touchEvent:a}),m&&p.timestamp-m.timestamp<300&&c(p.element,"doubletap",{touch:n,touchEvent:a}),m=p),"panning"===p.status){var q=Date.now(),r=q-p.startTime,s=((n.clientX-p.startTouch.clientX)/r,(n.clientY-p.startTouch.clientY)/r,n.clientX-p.startTouch.clientX),t=n.clientY-p.startTouch.clientY,u=Math.sqrt(p.velocityY*p.velocityY+p.velocityX*p.velocityX),v=u>.5&&q-p.lastTime<100,w={duration:r,isflick:v,velocityX:p.velocityX,velocityY:p.velocityY,displacementX:s,displacementY:t,touch:n,touches:a.touches,changedTouches:a.changedTouches,touchEvent:a,isVertical:p.isVertical};c(p.element,"panend",w),v&&(c(p.element,"swipe",w),p.isVertical?c(p.element,"verticalswipe",w):c(p.element,"horizontalswipe",w))}"pressing"===p.status&&c(p.element,"pressend",{touch:n,touchEvent:a}),delete l[o]}}0===Object.keys(l).length&&(j.removeEventListener("touchmove",f,!1),j.removeEventListener("touchend",g,!1),j.removeEventListener("touchcancel",h,!1))}function h(a){if(2==Object.keys(l).length){var d=[];for(var e in l)d.push(l[e].element);c(b(d[0],d[1]),"dualtouchend",{touches:k.call(a.touches),touchEvent:a})}for(var i=0;i<a.changedTouches.length;i++){var m=a.changedTouches[i],n=m.identifier,o=l[n];o&&(o.pressingHandler&&(clearTimeout(o.pressingHandler),o.pressingHandler=null),"panning"===o.status&&c(o.element,"panend",{touch:m,touches:a.touches,changedTouches:a.changedTouches,touchEvent:a}),"pressing"===o.status&&c(o.element,"pressend",{touch:m,touchEvent:a}),delete l[n])}0===Object.keys(l).length&&(j.removeEventListener("touchmove",f,!1),j.removeEventListener("touchend",g,!1),j.removeEventListener("touchcancel",h,!1))}var i=a.document,j=i.documentElement,k=Array.prototype.slice,l={},m=null;j.addEventListener("touchstart",e,!1)}(window);;module.exports = window.lib['gesturejs']; |
| |
| /***/ }, |
| /* 36 */ |
| /***/ function(module, exports) { |
| |
| (typeof window === 'undefined') && (window = {ctrl: {}, lib: {}});!window.ctrl && (window.ctrl = {});!window.lib && (window.lib = {});!function(a,b){function c(a,b){return[[(a/3+(a+b)/3-a)/(b-a),(a*a/3+a*b*2/3-a*a)/(b*b-a*a)],[(b/3+(a+b)/3-a)/(b-a),(b*b/3+a*b*2/3-a*a)/(b*b-a*a)]]}function d(a){if(this.v=a.v||0,this.a=a.a||0,"undefined"!=typeof a.t&&(this.t=a.t),"undefined"!=typeof a.s&&(this.s=a.s),"undefined"==typeof this.t)if("undefined"==typeof this.s)this.t=-this.v/this.a;else{var b=(Math.sqrt(this.v*this.v+2*this.a*this.s)-this.v)/this.a,c=(-Math.sqrt(this.v*this.v+2*this.a*this.s)-this.v)/this.a;this.t=Math.min(b,c)}"undefined"==typeof this.s&&(this.s=this.a*this.t*this.t/2+this.v*this.t)}d.prototype.generateCubicBezier=function(){return c(this.v/this.a,this.t+this.v/this.a)},b.motion=d}(window,window.lib||(window.lib={}));;module.exports = window.lib['motion']; |
| |
| /***/ }, |
| /* 37 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| var Atomic = __webpack_require__(27) |
| __webpack_require__(38) |
| |
| var FORMATTER_REGEXP = /(\\)?(dd*|hh?|mm?|ss?)/gi |
| |
| function formatDateTime(data, formatter, timeColor) { |
| return formatter.replace(FORMATTER_REGEXP, function (m) { |
| var len = m.length |
| var firstChar = m.charAt(0) |
| // escape character |
| if (firstChar === '\\') { |
| return m.replace('\\', '') |
| } |
| var value = (firstChar === 'd' ? data.days : |
| firstChar === 'h' ? data.hours : |
| firstChar === 'm' ? data.minutes : |
| firstChar === 's' ? data.seconds : 0) + '' |
| |
| // 5 zero should be enough |
| return '<span style="margin:4px;color:' |
| + timeColor + '" >' |
| + ('00000' + value).substr(-Math.max(value.length, len)) |
| + '</span>' |
| }) |
| } |
| |
| function Countdown (data) { |
| Atomic.call(this, data) |
| } |
| |
| Countdown.prototype = Object.create(Atomic.prototype) |
| |
| Countdown.prototype.create = function () { |
| var node = document.createElement('div') |
| node.classList.add('weex-element') |
| var data = this.data |
| var time = Number(data.attr.countdownTime) || 0 |
| var endTime = Date.now() / 1000 + time |
| var cd = lib.countdown({ |
| endDate: endTime, |
| onUpdate: function (time) { |
| var timeColor = data.style.timeColor || '#000' |
| var result = formatDateTime(time, data.attr.formatterValue, timeColor) |
| node.innerHTML = result |
| }, |
| onEnd: function () { |
| } |
| }).start() |
| |
| return node |
| } |
| |
| Countdown.prototype.style = { |
| textColor: function (value) { |
| this.node.style.color = value |
| } |
| } |
| |
| module.exports = Countdown |
| |
| |
| /***/ }, |
| /* 38 */ |
| /***/ function(module, exports) { |
| |
| !function(a,b){function c(a){var b;if("number"==typeof a)b=new Date(1e3*a);else if("string"==typeof a){var c=a.charAt(0),d="+"===c,h="-"===c;if(d||h){for(var i,j=a.substr(1),k=j.split(":"),l=[0,0,0,0],m=4;k.length&&--m>=0;)l[m]=parseInt(k.pop())||0;i=e*l[0]+f*l[1]+g*l[2]+l[3],b=new Date,b.setSeconds(b.getSeconds()+i*(h?-1:1)),b.setMilliseconds(0)}}return b||(b=new Date(a)),b}function d(a,b){return b.replace(FORMATTER_REGEXP,function(b){var c=b.length,d=b.charAt(0);if("\\"===d)return b.replace("\\","");var e=("d"===d?a.days:"h"===d?a.hours:"m"===d?a.minutes:"s"===d?a.seconds:0)+"";return("00000"+e).substr(-Math.max(e.length,c))})}var e=86400,f=3600,g=60,h="d天hh时mm分ss秒";FORMATTER_REGEXP=/(\\)?(dd*|hh?|mm?|ss?)/gi;var i=function(a){a=a||{};var b=this,d=c(a.endDate);if(!d||!d.getTime())throw new Error("Invalid endDate");b.endDate=d,b.onUpdate=a.onUpdate,b.onEnd=a.onEnd,b.interval=a.interval||1e3,b.stringFormatter=a.stringFormatter||h,b.correctDateOffset=a.correctDateOffset||0,b.updateElement=a.updateElement,b._data={days:0,hours:0,minutes:0,seconds:0}};i.prototype={start:function(){var a=this;return a.stop(),a._update()&&(a._intervalId=setInterval(function(){a._update()},a.interval)),a},_update:function(){var a,b=this,c=b._data,h=b.updateElement,i=+new Date+1e3*b.correctDateOffset,j=Math.max(0,Math.round((b.endDate.getTime()-i)/1e3)),k=0>=j;return c.totalSeconds=j,j-=(c.days=Math.floor(j/e))*e,j-=(c.hours=Math.floor(j/f))*f,j-=(c.minutes=Math.floor(j/g))*g,c.seconds=j,c.stringValue=d(c,b.stringFormatter),h&&(h.innerHTML=c.stringValue),(a=b.onUpdate)&&a.call(b,c),k?(b.stop(),(a=b.onEnd)&&a.call(b),!1):!0},stop:function(){var a=this;return a._intervalId&&(clearInterval(a._intervalId),a._intervalId=null),a},setEndDate:function(a){var b=this;return b.endDate=c(a),b}},b.countdown=function(a){return new i(a)}}(window,window.lib||(window.lib={})); |
| |
| /***/ }, |
| /* 39 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| var config = __webpack_require__(5) |
| var Component = __webpack_require__(16) |
| var ComponentManager = __webpack_require__(9) |
| var LazyLoad = __webpack_require__(12) |
| |
| function Marquee (data) { |
| this.interval = Number(data.attr.interval) || 5 * 1000 |
| this.transitionDuration = Number(data.attr.transitionDuration) || 500 |
| this.delay = Number(data.attr.delay) || 0 |
| Component.call(this, data) |
| } |
| |
| Marquee.prototype = Object.create(Component.prototype) |
| |
| Marquee.prototype.create = function () { |
| var node = document.createElement('div') |
| node.classList.add('weex-container') |
| node.style.overflow = 'hidden' |
| // fix page shaking during slider's playing |
| node.style.webkitTransform = 'translate3D(0,0,0)' |
| node.addEventListener('webkitTransitionEnd', this.end.bind(this), false) |
| return node |
| } |
| |
| Marquee.prototype.createChildren = function () { |
| // first run: |
| // - create each child |
| // - append to parentNode |
| // - find current and next |
| // - set current and next shown and others hidden |
| var children = this.data.children |
| var parentRef = this.data.ref |
| var instanceId = this.data.instanceId |
| var items = [] |
| var componentManager = this.getComponentManager() |
| |
| var fragment, isFlex, child, node, i |
| |
| if (children && children.length) { |
| fragment = document.createDocumentFragment() |
| isFlex = false |
| for (i = 0; i < children.length; i++) { |
| children[i].scale = this.data.scale |
| children[i].instanceId = instanceId |
| child = componentManager.createElement(children[i]) |
| child.parentRef = parentRef |
| this.initChild(child) |
| // append and push |
| items.push(child) |
| fragment.appendChild(child.node) |
| if (!isFlex && child.data.style.hasOwnProperty('flex')) { |
| isFlex = true |
| } |
| } |
| this.node.appendChild(fragment) |
| } |
| |
| // set items |
| this.items = items |
| |
| // reset the clock for first transition |
| this.reset() |
| } |
| |
| Marquee.prototype.initChild = function (child) { |
| var node = child.node |
| node.style.position = 'absolute' |
| node.style.top = '0' |
| node.style.left = '0' |
| } |
| |
| Marquee.prototype.appendChild = function (data) { |
| // dom + items |
| var componentManager = ComponentManager.getInstance(this.data.instanceId) |
| var child = componentManager.createElement(data) |
| this.initChild(child) |
| this.node.appendChild(child.node) |
| this.items.push(child) |
| this.reset() |
| return child // @todo redesign Component#appendChild(component) |
| } |
| |
| Marquee.prototype.insertBefore = function (child, before) { |
| // dom + items |
| var index = this.items.indexOf(before) |
| this.items.splice(index, 0, child) |
| this.initChild(child) |
| this.node.insertBefore(child.node, before.node) |
| this.reset() |
| } |
| |
| Marquee.prototype.removeChild = function (child) { |
| // dom + items |
| var index = this.items.indexOf(child) |
| this.items.splice(index, 1) |
| this.node.removeChild(child.node) |
| this.reset() |
| } |
| |
| /** |
| * status: { |
| * current: {translateY: 0, shown: true}, |
| * next: {translateY: height, shown: true}, |
| * others[]: {shown: false} |
| * index: index |
| * } |
| */ |
| Marquee.prototype.reset = function () { |
| var interval = this.interval - 0 |
| var delay = this.delay - 0 |
| var items = this.items |
| var self = this |
| |
| var loop = function () { |
| self.next() |
| self.timerId = setTimeout(loop, self.interval) |
| } |
| |
| // reset display and transform |
| items.forEach(function (item, index) { |
| var node = item.node |
| // set non-current(0)|next(1) item hidden |
| node.style.display = index > 1 ? 'none' : '' |
| // set next(1) item translateY |
| // TODO: it supposed to use item.data.style |
| // but somehow the style object is empty. |
| // This problem relies on jsframework's bugfix. |
| |
| // node.style.transform = index === 1 |
| // ? 'translate3D(0,' + config.scale * item.data.style.height + 'px,0)' |
| // : '' |
| // node.style.webkitTransform = index === 1 |
| // ? 'translate3D(0,' + config.scale * item.data.style.height + 'px,0)' |
| // : '' |
| node.style.transform = index === 1 |
| ? 'translate3D(0,' + self.data.scale * self.data.style.height + 'px,0)' |
| : '' |
| node.style.webkitTransform = index === 1 |
| ? 'translate3D(0,' + self.data.scale * self.data.style.height + 'px,0)' |
| : '' |
| }) |
| |
| setTimeout(function () { |
| // reset current, next, index |
| self.currentItem = items[0] |
| self.nextItem = items[1] |
| self.currentIndex = 0 |
| |
| items.forEach(function (item, index) { |
| var node = item.node |
| // set transition |
| node.style.transition = 'transform ' |
| + self.transitionDuration |
| + 'ms ease' |
| node.style.webkitTransition = '-webkit-transform ' |
| + self.transitionDuration |
| + 'ms ease' |
| }) |
| |
| clearTimeout(self.timerId) |
| |
| if (items.length > 1) { |
| self.timerId = setTimeout(loop, delay + interval) |
| } |
| }, 13) |
| |
| } |
| |
| /** |
| * next: |
| * - current: {translateY: -height} |
| * - next: {translateY: 0} |
| */ |
| Marquee.prototype.next = function () { |
| // - update state |
| // - set current and next transition |
| // - hide current when transition end |
| // - set next to current |
| // - find new next |
| var next = this.nextItem.node |
| var current = this.currentItem.node |
| this.transitionIndex = this.currentIndex |
| |
| // Use setTimeout to fix the problem that when the |
| // page recover from backstage, the slider will |
| // not work any longer. |
| setTimeout(function () { |
| next.style.transform = 'translate3D(0,0,0)' |
| next.style.webkitTransform = 'translate3D(0,0,0)' |
| current.style.transform = 'translate3D(0,-' |
| + this.data.scale * this.data.style.height |
| + 'px,0)' |
| current.style.webkitTransform = 'translate3D(0,-' |
| + this.data.scale * this.data.style.height |
| + 'px,0)' |
| this.fireEvent('change') |
| }.bind(this), 300) |
| } |
| |
| Marquee.prototype.fireEvent = function (type) { |
| var length = this.items.length |
| var nextIndex = (this.currentIndex + 1) % length |
| var evt = document.createEvent('HTMLEvents') |
| evt.initEvent(type, false, false) |
| evt.data = { |
| prevIndex: this.currentIndex, |
| index: nextIndex |
| } |
| this.node.dispatchEvent(evt) |
| } |
| |
| /** |
| * end: |
| * - old current: {shown: false} |
| * - old current: {translateY: 0} |
| * - index++ % length |
| * - new current = old next |
| * - new next = items[index+1 % length] |
| * - new next: {translateY: height} |
| * - new next: {shown: true} |
| */ |
| Marquee.prototype.end = function (e) { |
| var target = e.target |
| var items = this.items |
| var length = items.length |
| var current, next |
| var currentIndex, nextIndex |
| |
| currentIndex = this.transitionIndex |
| |
| if (isNaN(currentIndex)) { |
| return |
| } |
| delete this.transitionIndex |
| |
| current = this.currentItem.node |
| current.style.display = 'none' |
| current.style.webkitTransform = '' |
| |
| currentIndex = (currentIndex + 1) % length |
| nextIndex = (currentIndex + 1) % length |
| |
| this.currentIndex = currentIndex |
| this.currentItem = this.nextItem |
| this.nextItem = items[nextIndex] |
| |
| setTimeout(function () { |
| next = this.nextItem.node |
| // TODO: it supposed to use this.nextItem.data.style |
| // but somehow the style object is empty. |
| // This problem relies on jsframework's bugfix. |
| |
| next.style.webkitTransform = 'translate3D(0,' |
| + this.data.scale * this.data.style.height |
| + 'px,0)' |
| next.style.display = '' |
| LazyLoad.loadIfNeeded(next) |
| }.bind(this)) |
| } |
| |
| Marquee.prototype.attr = { |
| interval: function (value) { |
| this.interval = value |
| }, |
| transitionDuration: function (value) { |
| this.transitionDuration = value |
| }, |
| delay: function (value) { |
| this.delay = value |
| } |
| } |
| |
| Marquee.prototype.clearAttr = function () { |
| this.interval = 5 * 1000 |
| this.transitionDuration = 500 |
| this.delay = 0 |
| } |
| |
| module.exports = Marquee |
| |
| |
| /***/ }, |
| /* 40 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| var extend = __webpack_require__(7).extend |
| var config = __webpack_require__(5) |
| var Component = __webpack_require__(16) |
| var ComponentManager = __webpack_require__(9) |
| var LazyLoad = __webpack_require__(12) |
| __webpack_require__(41) |
| __webpack_require__(42) |
| |
| function Slider (data) { |
| this.autoPlay = true // always true for autoplay |
| this.direction = 'row' // 'column' is not temporarily supported. |
| this.children = [] |
| this.isPageShow = true |
| this.isDomRendering = true |
| |
| // bind event 'pageshow' and 'pagehide' on window. |
| this._idleWhenPageDisappear() |
| // bind event 'renderBegin' and 'renderEnd' on window. |
| this._idleWhenDomRendering() |
| |
| Component.call(this, data) |
| } |
| |
| Slider.prototype = Object.create(Component.prototype) |
| |
| Slider.prototype._idleWhenPageDisappear = function () { |
| var _this = this |
| window.addEventListener('pageshow', function () { |
| _this.isPageShow = true |
| _this.autoPlay && !_this.isDomRendering && _this.play() |
| }) |
| window.addEventListener('pagehide', function () { |
| _this.isPageShow = false |
| _this.stop() |
| }) |
| } |
| |
| Slider.prototype._idleWhenDomRendering = function () { |
| var _this = this |
| window.addEventListener('renderend', function () { |
| _this.isDomRendering = false |
| _this.autoPlay && _this.isPageShow && _this.play() |
| }) |
| window.addEventListener('renderbegin', function () { |
| _this.isDomRendering = true |
| _this.stop() |
| }) |
| } |
| |
| Slider.prototype.attr = { |
| interval: function (val) { |
| this.interval = parseInt(val) || 3000 |
| if (this.carrousel) { |
| this.carrousel.playInterval = this.interval |
| } |
| }, |
| |
| playstatus: function (val) { |
| this.playstatus = val && val !== 'false' ? true : false |
| this.autoPlay = this.playstatus |
| if (this.carrousel) { |
| if (this.playstatus) { |
| this.play() |
| } else { |
| this.stop() |
| } |
| } |
| }, |
| |
| // support playstatus' alias auto-play for compatibility |
| autoPlay: function (val) { |
| this.attr.playstatus.call(this, val) |
| } |
| } |
| |
| Slider.prototype.create = function () { |
| var node = document.createElement('div') |
| node.classList.add('slider') |
| node.style.position = 'relative' |
| node.style.overflow = 'hidden' |
| return node |
| } |
| |
| Slider.prototype._doRender = function () { |
| var _this = this |
| _this.createChildren() |
| _this.onAppend() |
| } |
| |
| Slider.prototype.removeChild = function (child) { |
| var children = this.data.children |
| if (children) { |
| for (var i = 0; i < children.length; i++) { |
| if (child.data.ref === children[i].ref) { |
| children.splice(i, 1) |
| break |
| } |
| } |
| } |
| |
| this._doRender() |
| } |
| |
| Slider.prototype.insertBefore = function (child, before) { |
| var children = this.data.children |
| // var childIndex = this.children.indexOf(before.data) |
| var childIndex = -1 |
| for (var i = 0, l = children.length; i < l; i++) { |
| if (children[i].ref === before.data.ref) { |
| childIndex = i |
| break |
| } |
| } |
| children.splice(childIndex, 0, child.data) |
| |
| this._doRender() |
| if (this.children.length > 0) { |
| return this.children[this.children.length - 1] |
| } |
| } |
| |
| Slider.prototype.appendChild = function (data) { |
| var children = this.data.children || (this.data.children = []) |
| children.push(data) |
| this._doRender() |
| if (this.children.length > 0) { |
| return this.children[this.children.length - 1] |
| } |
| } |
| |
| Slider.prototype.createChildren = function () { |
| |
| var componentManager = this.getComponentManager() |
| |
| // recreate slider container. |
| if (this.sliderContainer) { |
| this.node.removeChild(this.sliderContainer) |
| } |
| if (this.indicator) { |
| this.indicator.node.parentNode.removeChild(this.indicator.node) |
| } |
| this.children = [] |
| |
| var sliderContainer = document.createElement('ul') |
| sliderContainer.style.listStyle = 'none' |
| this.node.appendChild(sliderContainer) |
| this.sliderContainer = sliderContainer |
| |
| var children = this.data.children |
| var scale = this.data.scale |
| var fragment = document.createDocumentFragment() |
| var indicatorData, width, height |
| var childWidth = 0 |
| var childHeight = 0 |
| |
| if (children && children.length) { |
| for (var i = 0; i < children.length; i++) { |
| var child |
| children[i].scale = this.data.scale |
| children[i].instanceId = this.data.instanceId |
| if (children[i].type === 'indicator') { |
| indicatorData = extend(children[i], { |
| extra: { |
| amount: children.length - 1, |
| index: 0 |
| } |
| }) |
| } else { |
| child = componentManager.createElement(children[i], 'li') |
| this.children.push(child) |
| fragment.appendChild(child.node) |
| width = child.data.style.width || 0 |
| height = child.data.style.height || 0 |
| width > childWidth && (childWidth = width) |
| height > childHeight && (childHeight = height) |
| child.parentRef = this.data.ref |
| } |
| } |
| // append indicator |
| if (indicatorData) { |
| indicatorData.extra.width = this.data.style.width || childWidth |
| indicatorData.extra.height = this.data.style.height || childHeight |
| this.indicator = componentManager.createElement(indicatorData) |
| this.indicator.parentRef = this.data.ref |
| this.indicator.slider = this |
| this.node.appendChild(this.indicator.node) |
| } |
| |
| sliderContainer.style.height = scale * this.data.style.height + 'px' |
| sliderContainer.appendChild(fragment) |
| } |
| } |
| |
| Slider.prototype.onAppend = function () { |
| if (this.carrousel) { |
| this.carrousel.removeEventListener('change', this._getSliderChangeHandler()) |
| this.carrousel.stop() |
| this.carrousel = null |
| } |
| this.carrousel = new lib.carrousel(this.sliderContainer, { |
| autoplay: this.autoPlay, |
| useGesture: true |
| }) |
| |
| this.carrousel.playInterval = this.interval |
| this.carrousel.addEventListener('change', this._getSliderChangeHandler()) |
| this.currentIndex = 0 |
| |
| // preload all images for slider |
| // because: |
| // 1. lib-img doesn't listen to event transitionend |
| // 2. even if we fire lazy load in slider's change event handler, |
| // the next image still won't be preloaded utill the moment it |
| // slides into the view, which is too late. |
| if (this.preloadImgsTimer) { |
| clearTimeout(this.preloadImgsTimer) |
| } |
| // The time just before the second slide appear and enough |
| // for all child elements to append is ok. |
| var preloadTime = 0.8 |
| this.preloadImgsTimer = setTimeout(function () { |
| var imgs = this.carrousel.element.querySelectorAll('img') |
| for (var i = 0, l = imgs.length; i < l; i++) { |
| var img = imgs[i] |
| var iLazySrc = img.getAttribute('i-lazy-src') |
| var imgSrc = img.getAttribute('img-src') |
| if (iLazySrc) { |
| img.setAttribute('src', iLazySrc) |
| } else if (imgSrc) { |
| img.setAttribute('src', imgSrc) |
| } |
| img.removeAttribute('i-lazy-src') |
| img.removeAttribute('img-src') |
| } |
| }.bind(this), preloadTime * 1000) |
| |
| // avoid page scroll when panning |
| var panning = false |
| this.carrousel.element.addEventListener('panstart', function (e) { |
| if (!e.isVertical) { |
| panning = true |
| } |
| }) |
| this.carrousel.element.addEventListener('panend', function (e) { |
| if (!e.isVertical) { |
| panning = false |
| } |
| }) |
| |
| document.addEventListener('touchmove', function (e) { |
| if (panning) { |
| e.preventDefault() |
| return false |
| } |
| return true |
| }.bind(this)) |
| |
| } |
| |
| Slider.prototype._updateIndicators = function () { |
| this.indicator && this.indicator.setIndex(this.currentIndex) |
| } |
| |
| Slider.prototype._getSliderChangeHandler = function (e) { |
| if (!this.sliderChangeHandler) { |
| this.sliderChangeHandler = (function (e) { |
| var index = this.carrousel.items.index |
| this.currentIndex = index |
| |
| // updateIndicators |
| this._updateIndicators() |
| |
| this.dispatchEvent('change', { index: index }) |
| }).bind(this) |
| } |
| return this.sliderChangeHandler |
| } |
| |
| Slider.prototype.play = function () { |
| this.carrousel.play() |
| } |
| |
| Slider.prototype.stop = function () { |
| this.carrousel.stop() |
| } |
| |
| Slider.prototype.slideTo = function (index) { |
| var offset = index - this.currentIndex |
| this.carrousel.items.slide(offset) |
| } |
| |
| module.exports = Slider |
| |
| |
| /***/ }, |
| /* 41 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| (typeof window === 'undefined') && (window = {ctrl: {}, lib: {}});!window.ctrl && (window.ctrl = {});!window.lib && (window.lib = {});__webpack_require__(33);__webpack_require__(34);__webpack_require__(35);!function(){var a="[data-ctrl-name=carrousel]{position:relative;-webkit-transform:translateZ(1px);-ms-transform:translateZ(1px);transform:translateZ(1px)}",b=document.createElement("style");if(document.getElementsByTagName("head")[0].appendChild(b),b.styleSheet)b.styleSheet.disabled||(b.styleSheet.cssText=a);else try{b.innerHTML=a}catch(c){b.innerText=a}}();!function(a,b,c){function d(a){var b,c={x:0,y:0},d=getComputedStyle(a)[l+"Transform"];return"none"!==d&&(b=d.match(/^matrix3d\((?:[-\d.]+,\s*){12}([-\d.]+),\s*([-\d.]+)(?:,\s*[-\d.]+){2}\)/)||d.match(/^matrix\((?:[-\d.]+,\s*){4}([-\d.]+),\s*([-\d.]+)\)$/))&&(c.x=parseFloat(b[1])||0,c.y=parseFloat(b[2])||0),c}function e(a,b){return a=parseFloat(a),b=parseFloat(b),0!=a&&(a+="px"),0!=b&&(b+="px"),n?"translate3d("+a+", "+b+", 0)":"translate("+a+", "+b+")"}function f(a){return o.call(a)}function g(a,c){function g(a,b){var c=h.createEvent("HTMLEvents");if(c.initEvent(a,!1,!1),b)for(var d in b)c[d]=b[d];n.dispatchEvent(c)}function i(a){for(;0>a;)a+=r;for(;a>=r;)a-=r;return a}function j(a){if(0!==r){var b,c,d=q.get(a);r>1&&(b=q.get(a-1),c=2===r?q.getCloned(a+1):q.get(a+1),d.style.left=-o+"px",b.style.left=-o-s+"px",c.style.left=-o+s+"px"),t=d.index,g("change",{prevItem:b,curItem:d,nextItem:c})}}var k=this,m=Date.now()+"-"+ ++p,n=document.createDocumentFragment();1!==arguments.length||arguments[0]instanceof HTMLElement||(c=arguments[0],a=null),a||(a=document.createElement("ul"),n.appendChild(a)),c=c||{},a.setAttribute("data-ctrl-name","carrousel"),a.setAttribute("data-ctrl-id",m),a.style.position="relative",a.style[l+"Transform"]=e(0,0);var o=0,q={},r=0,s=c.step||a.getBoundingClientRect().width,t=0;q.add=function(b){var c=document.createElement("li");return c.style.display="none",c.style["float"]="left",c.index=r,"string"==typeof b?c.innerHTML=b:b instanceof HTMLElement&&c.appendChild(b),a.appendChild(c),Object.defineProperty(q,r+"",{get:function(){return c}}),r++,c},q.get=function(a){return q[i(a)]},q.getCloned=function(b){function c(a,b,d){var e=a._listeners;if(e){b._listeners=e;for(var f in e)b.addEventListener(f,e[f])}if(d&&a.children&&a.children.length)for(var g=0,h=a.children.length;h>g;g++)c(a.children[g],b.children[g],d)}var b=i(b),d=a.querySelector('[cloned="cloned-'+b+'"]'),e=q[b];return d||(d=e.cloneNode(!0),c(e,d,!0),a.appendChild(d),d.setAttribute("cloned","cloned-"+b),d.index=b),d},q.slide=function(c){if(0!==r){1===r&&(c=0);var f=d(a).x,g=o+s*-c,h=g-f;if(0!==h){new b.animation(400,b.cubicbezier.ease,function(b,c){a.style[l+"Transform"]=e(f+h*c,0)}).play().then(function(){o=g,a.style[l+"Transform"]=e(g,0),c&&j(t+c)})}}},q.next=function(){q.slide(1)},q.prev=function(){q.slide(-1)},f(a.querySelectorAll("li")).forEach(function(a){a.style.position="absolute",a.style.top="0",a.style.left=r*s+"px",a.style["float"]="left",a.index=r,Object.defineProperty(q,r+"",{get:function(){return a}}),r++}),Object.defineProperty(this,"items",{get:function(){return q}}),Object.defineProperty(q,"length",{get:function(){return r}}),Object.defineProperty(q,"index",{get:function(){return t}}),Object.defineProperty(q,"step",{get:function(){return s},set:function(a){s=a}});var u=!1,v=!1,w=!1;this.play=function(){return u?void(v||(v=setTimeout(function(){w=!0,q.next(),setTimeout(function(){w=!1},500),v=setTimeout(arguments.callee,400+z)},400+z))):(u=!0,j(0))},this.stop=function(){v&&(clearTimeout(v),setTimeout(function(){v=!1},500))};var x=!1,y=!1;Object.defineProperty(this,"autoplay",{get:function(){return x},set:function(a){x=!!a,y&&(clearTimeout(y),y=!1),x?y=setTimeout(function(){k.play()},2e3):k.stop()}}),this.autoplay=!!c.autoplay;var z=1500;if(Object.defineProperty(this,"playInterval",{get:function(){return z},set:function(a){z=a}}),this.playInterval=!!c.playInterval||1500,c.useGesture){var A,B=!1;a.addEventListener("panstart",function(a){a.isVertical||B&&w||(a.preventDefault(),a.stopPropagation(),x&&k.stop(),A=0,B=!0)}),a.addEventListener("panmove",function(b){!b.isVertical&&B&&(b.preventDefault(),b.stopPropagation(),A=b.displacementX,a.style[l+"Transform"]=e(o+A,0))}),a.addEventListener("panend",function(a){!a.isVertical&&B&&(a.preventDefault(),a.stopPropagation(),B=!1,a.isflick?0>A?q.next():q.prev():Math.abs(A)<s/2?q.slide(0):q.slide(0>A?1:-1),x&&setTimeout(function(){k.play()},2e3))},!1),a.addEventListener("swipe",function(a){a.isVertical||(a.preventDefault(),a.stopPropagation())})}this.addEventListener=function(a,b){this.root.addEventListener(a,b,!1)},this.removeEventListener=function(a,b){this.root.removeEventListener(a,b,!1)},this.root=n,this.element=a}var h=a.document,i=a.navigator.userAgent,j=!!i.match(/Firefox/i),k=!!i.match(/IEMobile/i),l=j?"Moz":k?"ms":"webkit",m=k?"MSCSSMatrix":"WebKitCSSMatrix",n=!!j||m in a&&"m11"in new a[m],o=Array.prototype.slice,p=0;b.carrousel=g}(window,window.lib,window.ctrl||(window.ctrl={}));;module.exports = window.lib['carrousel']; |
| |
| /***/ }, |
| /* 42 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| // style-loader: Adds some css to the DOM by adding a <style> tag |
| |
| // load the styles |
| var content = __webpack_require__(43); |
| if(typeof content === 'string') content = [[module.id, content, '']]; |
| // add the styles to the DOM |
| var update = __webpack_require__(4)(content, {}); |
| if(content.locals) module.exports = content.locals; |
| // Hot Module Replacement |
| if(false) { |
| // When the styles change, update the <style> tags |
| if(!content.locals) { |
| module.hot.accept("!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./slider.scss", function() { |
| var newContent = require("!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./slider.scss"); |
| if(typeof newContent === 'string') newContent = [[module.id, newContent, '']]; |
| update(newContent); |
| }); |
| } |
| // When the module is disposed, remove the <style> tags |
| module.hot.dispose(function() { update(); }); |
| } |
| |
| /***/ }, |
| /* 43 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| exports = module.exports = __webpack_require__(3)(); |
| // imports |
| |
| |
| // module |
| exports.push([module.id, ".slider {\n position: relative; }\n\n.slider .indicator-container {\n position: absolute;\n display: -webkit-box;\n display: -webkit-flex;\n display: flex;\n -webkit-box-align: center;\n box-align: center;\n -webkit-align-items: center;\n align-items: center;\n -webkit-box-pack: center;\n box-pack: center;\n -webkit-justify-content: center;\n justify-content: center;\n font-size: 0; }\n .slider .indicator-container .indicator {\n border-radius: 50%; }\n .slider .indicator-container.row {\n -webkit-box-orient: horizontal;\n box-orient: horizontal;\n -webkit-flex-direction: row;\n flex-direction: row; }\n .slider .indicator-container.column {\n -webkit-box-orient: vertical;\n box-orient: vertical;\n -webkit-flex-direction: column;\n flex-direction: column; }\n", "", {"version":3,"sources":["/./src/src/styles/slider.scss"],"names":[],"mappings":"AAAA;EACE,mBAAmB,EACpB;;AACD;EACE,mBAAmB;EACnB,qBAAqB;EACrB,sBAAsB;EACtB,cAAc;EACd,0BAA0B;EAC1B,kBAAkB;EAClB,4BAA4B;EAC5B,oBAAoB;EACpB,yBAAyB;EACzB,iBAAiB;EACjB,gCAAgC;EAChC,wBAAwB;EACxB,aAAa,EAoBd;EAjCD;IAgBI,mBAAmB,EACpB;EAjBH;IAoBI,+BAA+B;IAC/B,uBAAuB;IACvB,4BAA4B;IAC5B,oBAAoB,EACrB;EAxBH;IA2BI,6BAA6B;IAC7B,qBAAqB;IACrB,+BAA+B;IAC/B,uBAAuB,EACxB","file":"slider.scss","sourcesContent":[".slider {\n position: relative;\n}\n.slider .indicator-container {\n position: absolute;\n display: -webkit-box;\n display: -webkit-flex;\n display: flex;\n -webkit-box-align: center;\n box-align: center;\n -webkit-align-items: center;\n align-items: center;\n -webkit-box-pack: center;\n box-pack: center;\n -webkit-justify-content: center;\n justify-content: center;\n font-size: 0;\n\n .indicator {\n border-radius: 50%;\n }\n\n &.row {\n -webkit-box-orient: horizontal;\n box-orient: horizontal;\n -webkit-flex-direction: row;\n flex-direction: row;\n }\n\n &.column {\n -webkit-box-orient: vertical;\n box-orient: vertical;\n -webkit-flex-direction: column;\n flex-direction: column;\n }\n\n}"],"sourceRoot":"webpack://"}]); |
| |
| // exports |
| |
| |
| /***/ }, |
| /* 44 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| var extend = __webpack_require__(7).extend |
| var config = __webpack_require__(5) |
| var Atomic = __webpack_require__(27) |
| var Component = __webpack_require__(16) |
| |
| __webpack_require__(45) |
| |
| var DEFAULT_ITEM_COLOR = '#999' |
| var DEFAULT_ITEM_SELECTED_COLOR = '#0000ff' |
| var DEFAULT_ITEM_SIZE = 20 |
| var DEFAULT_MARGIN_SIZE = 10 |
| |
| // Style supported: |
| // position: (default - absolute) |
| // itemColor: color of indicator dots |
| // itemSelectedColor: color of the selected indicator dot |
| // itemSize: size of indicators |
| // other layout styles |
| function Indicator (data) { |
| this.direction = 'row' // 'column' is not temporarily supported. |
| this.amount = data.extra.amount |
| this.index = data.extra.index |
| this.sliderWidth = data.extra.width |
| this.sliderHeight = data.extra.height |
| var styles = data.style || {} |
| this.data = data |
| this.style.width.call(this, styles.width) |
| this.style.height.call(this, styles.height) |
| this.items = [] |
| Atomic.call(this, data) |
| } |
| |
| Indicator.prototype = Object.create(Atomic.prototype) |
| |
| Indicator.prototype.create = function () { |
| var node = document.createElement('div') |
| node.classList.add('weex-indicators') |
| node.classList.add('weex-element') |
| node.style.position = 'absolute' |
| this.node = node |
| this.style.itemSize.call(this, 0) |
| this.itemColor = DEFAULT_ITEM_COLOR |
| this.itemSelectedColor = DEFAULT_ITEM_SELECTED_COLOR |
| this.updateStyle({ |
| left: 0, |
| top: 0, |
| itemSize: 0 |
| }) |
| return node |
| } |
| |
| Indicator.prototype.createChildren = function () { |
| var root = document.createDocumentFragment() |
| for (var i = 0; i < this.amount; i++) { |
| var indicator = document.createElement('div') |
| indicator.classList.add('weex-indicator') |
| indicator.style.boxSizing = 'border-box' |
| indicator.style.margin = '0 ' |
| + (DEFAULT_MARGIN_SIZE * this.data.scale) |
| + 'px' |
| indicator.style.width = this.itemSize + 'px' |
| indicator.style.height = this.itemSize + 'px' |
| indicator.setAttribute('index', i) |
| if (this.index === i) { |
| indicator.style.backgroundColor = this.itemSelectedColor |
| } else { |
| indicator.style.backgroundColor = this.itemColor |
| } |
| indicator.addEventListener('click', this._clickHandler.bind(this, i)) |
| this.items[i] = indicator |
| root.appendChild(indicator) |
| } |
| this.node.appendChild(root) |
| } |
| |
| Indicator.prototype.style |
| = extend(Object.create(Atomic.prototype.style), { |
| itemColor: function (val) { |
| this.itemColor = val || DEFAULT_ITEM_COLOR |
| for (var i = 0, l = this.items.length; i < l; i++) { |
| this.items[i].style.backgroundColor = this.itemColor |
| } |
| }, |
| |
| itemSelectedColor: function (val) { |
| this.itemSelectedColor = val || DEFAULT_ITEM_SELECTED_COLOR |
| if (typeof this.index !== 'undefined' |
| && this.items.length > this.index) { |
| this.items[this.index].style.backgroundColor |
| = this.itemSelectedColor |
| } |
| }, |
| |
| itemSize: function (val) { |
| val = parseInt(val) * this.data.scale |
| || DEFAULT_ITEM_SIZE * this.data.scale |
| this.itemSize = val |
| this.node.style.height = val + 'px' |
| for (var i = 0, l = this.items.length; i < l; i++) { |
| this.items[i].style.width = val + 'px' |
| this.items[i].style.height = val + 'px' |
| } |
| }, |
| |
| width: function (val) { |
| val = parseInt(val) * this.data.scale || parseInt(this.sliderWidth) |
| this.virtualWrapperWidth = val |
| }, |
| |
| height: function (val) { |
| val = parseInt(val) * this.data.scale || parseInt(this.sliderHeight) |
| this.virtualWrapperHeight = val |
| }, |
| |
| top: function (val) { |
| val = this.virtualWrapperHeight / 2 - this.itemSize / 2 |
| + val * this.data.scale |
| this.node.style.bottom = '' |
| this.node.style.top = val + 'px' |
| }, |
| |
| bottom: function (val) { |
| val = this.virtualWrapperHeight / 2 - this.itemSize / 2 |
| + val * this.data.scale |
| this.node.style.top = '' |
| this.node.style.bottom = val + 'px' |
| }, |
| |
| left: function (val) { |
| val = this.virtualWrapperWidth / 2 |
| - (this.itemSize + 2 * DEFAULT_MARGIN_SIZE * this.data.scale) |
| * this.amount / 2 |
| + val * this.data.scale |
| this.node.style.right = '' |
| this.node.style.left = val + 'px' |
| }, |
| |
| right: function (val) { |
| val = this.virtualWrapperWidth / 2 |
| - (this.itemSize + 2 * DEFAULT_MARGIN_SIZE * this.data.scale) |
| * this.amount / 2 |
| + val * this.data.scale |
| this.node.style.left = '' |
| this.node.style.right = val + 'px' |
| } |
| }) |
| |
| Indicator.prototype.setIndex = function (idx) { |
| if (idx >= this.amount) { |
| return |
| } |
| var prev = this.items[this.index] |
| var cur = this.items[idx] |
| prev.classList.remove('active') |
| prev.style.backgroundColor = this.itemColor |
| cur.classList.add('active') |
| cur.style.backgroundColor = this.itemSelectedColor |
| this.index = idx |
| } |
| |
| Indicator.prototype._clickHandler = function (idx) { |
| this.slider.slideTo(idx) |
| } |
| |
| module.exports = Indicator |
| |
| |
| /***/ }, |
| /* 45 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| // style-loader: Adds some css to the DOM by adding a <style> tag |
| |
| // load the styles |
| var content = __webpack_require__(46); |
| if(typeof content === 'string') content = [[module.id, content, '']]; |
| // add the styles to the DOM |
| var update = __webpack_require__(4)(content, {}); |
| if(content.locals) module.exports = content.locals; |
| // Hot Module Replacement |
| if(false) { |
| // When the styles change, update the <style> tags |
| if(!content.locals) { |
| module.hot.accept("!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./indicator.scss", function() { |
| var newContent = require("!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./indicator.scss"); |
| if(typeof newContent === 'string') newContent = [[module.id, newContent, '']]; |
| update(newContent); |
| }); |
| } |
| // When the module is disposed, remove the <style> tags |
| module.hot.dispose(function() { update(); }); |
| } |
| |
| /***/ }, |
| /* 46 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| exports = module.exports = __webpack_require__(3)(); |
| // imports |
| |
| |
| // module |
| exports.push([module.id, ".weex-indicators {\n position: absolute;\n white-space: nowrap; }\n .weex-indicators .weex-indicator {\n float: left;\n border-radius: 50%; }\n", "", {"version":3,"sources":["/./src/src/styles/indicator.scss"],"names":[],"mappings":"AAAA;EACE,mBAAmB;EACnB,oBAAoB,EAOrB;EATD;IAKI,YAAY;IACZ,mBAAmB,EACpB","file":"indicator.scss","sourcesContent":[".weex-indicators {\n position: absolute;\n white-space: nowrap;\n\n .weex-indicator {\n float: left;\n border-radius: 50%;\n }\n\n}"],"sourceRoot":"webpack://"}]); |
| |
| // exports |
| |
| |
| /***/ }, |
| /* 47 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| var Atomic = __webpack_require__(27) |
| var msgQueue = __webpack_require__(48) |
| var config = __webpack_require__(5) |
| var utils = __webpack_require__(7) |
| |
| // TODO: refactor this scss code since this is strongly |
| // dependent on lib.flexible other than the value of |
| // scale. |
| __webpack_require__(49) |
| |
| function TabHeader(data) { |
| Atomic.call(this, data) |
| } |
| |
| var proto = TabHeader.prototype = Object.create(Atomic.prototype) |
| |
| proto.create = function () { |
| // outside container. |
| var node = document.createElement('div') |
| node.className = 'tab-header' |
| // tip on the top. |
| var bar = document.createElement('div') |
| bar.className = 'header-bar' |
| bar.textContent = 'CHANGE FLOOR' |
| // middle layer. |
| var body = document.createElement('div') |
| body.className = 'header-body' |
| var box = document.createElement('ul') |
| box.className = 'tabheader' |
| |
| body.appendChild(box) |
| node.appendChild(bar) |
| node.appendChild(body) |
| this._bar = bar |
| this._body = body |
| this.box = box |
| this.node = node |
| // init events. |
| this._initFoldBtn() |
| this._initEvent() |
| return node |
| } |
| |
| proto._initFoldBtn = function () { |
| var _this = this |
| var node = this.node |
| var btn = document.createElement('span') |
| btn.className = 'fold-toggle iconfont' |
| btn.innerHTML = '' |
| node.appendChild(btn) |
| |
| btn.addEventListener('click', function () { |
| if (_this.unfolding) { |
| _this._folding() |
| } else { |
| _this._unfolding() |
| } |
| }) |
| } |
| |
| proto._initMask = function () { |
| var mask = document.createElement('div') |
| mask.className = 'tabheader-mask' |
| this.mask = mask |
| // stop default behavior: page moving. |
| mask.addEventListener('touchmove', function (evt) { |
| evt.preventDefault() |
| }) |
| // click to unfold. |
| var _this = this |
| mask.addEventListener('click', function () { |
| _this._folding() |
| }) |
| |
| document.body.appendChild(mask) |
| } |
| |
| proto._unfolding = function () { |
| // mark the initial posiiton of tabheader |
| if (!this.flag) { |
| var flag = document.createComment('tabheader') |
| this.flag = flag |
| this.node.parentNode.insertBefore(flag, this.node) |
| } |
| if (!this.mask) { |
| this._initMask() |
| } |
| |
| // record the scroll position. |
| this._scrollVal = this._body.scrollLeft |
| // record the position in document. |
| this._topVal = this.node.getBoundingClientRect().top |
| this._styleTop = this.node.style.top |
| |
| document.body.appendChild(this.node) |
| this.node.classList.add('unfold-header') |
| this.node.style.height = 'auto' |
| // recalc the position when it is unfolded. |
| var thHeight = this.node.getBoundingClientRect().height |
| if (thHeight + this._topVal > window.innerHeight) { |
| this._topVal = this._topVal |
| + (window.innerHeight - thHeight - this._topVal) |
| } |
| |
| this.node.style.top = this._topVal + 'px' |
| // process mask style |
| this.mask.classList.add('unfold-header') |
| this.mask.style.height = window.innerHeight + 'px' |
| this.unfolding = true |
| } |
| |
| proto._folding = function () { |
| if (this.unfolding !== true) { |
| return |
| } |
| |
| this.mask.classList.remove('unfold-header') |
| this.node.classList.remove('unfold-header') |
| |
| this.node.style.height = '' |
| this.node.style.top = this._styleTop |
| |
| // recover the position of tabheader. |
| this.flag.parentNode.insertBefore(this.node, this.flag) |
| // recover the position of scoller. |
| this._body.scrollLeft = this._scrollVal |
| |
| this._scrollToView() |
| this.unfolding = false |
| } |
| |
| proto._initEvent = function () { |
| this._initClickEvent() |
| this._initSelectEvent() |
| } |
| |
| // init events. |
| proto._initClickEvent = function () { |
| var box = this.box |
| var _this = this |
| |
| box.addEventListener('click', function (evt) { |
| var target = evt.target |
| if (target.nodeName === 'UL') { |
| return |
| } |
| |
| if (target.parentNode.nodeName === 'LI') { |
| target = target.parentNode |
| } |
| |
| var floor = target.getAttribute('data-floor') |
| |
| if (_this.data.attr.selectedIndex == floor) { |
| // Duplicated clicking, not to trigger select event. |
| return |
| } |
| |
| fireEvent(target, 'select', {index: floor}) |
| }) |
| } |
| |
| proto._initSelectEvent = function () { |
| var node = this.node |
| var _this = this |
| node.addEventListener('select', function (evt) { |
| var index |
| if (evt.index !== undefined) { |
| index = evt.index |
| } else if (evt.data && evt.data.index !== undefined) { |
| index = evt.data.index |
| } |
| |
| if (index === undefined) { |
| return |
| } |
| |
| _this.attr.selectedIndex.call(_this, index) |
| }) |
| } |
| |
| proto.attr = { |
| highlightIcon: function () { |
| return createHighlightIcon() |
| }, |
| data: function () { |
| var attr = this.data.attr |
| // Ensure there is a default selected value. |
| if (attr.selectedIndex === undefined) { |
| attr.selectedIndex = 0 |
| } |
| |
| var list = attr.data || [] |
| var curItem = attr.selectedIndex |
| |
| var ret = [] |
| var itemTmpl = '<li class="th-item" data-floor="{{floor}}">' |
| + '{{hlIcon}}{{floorName}}</li>' |
| |
| list.forEach(function (item, idx) { |
| var html = itemTmpl.replace('{{floor}}', idx) |
| if (curItem == idx) { |
| html = html.replace('{{hlIcon}}', createHighlightIcon()) |
| } else { |
| html = html.replace('{{hlIcon}}', '') |
| } |
| |
| html = html.replace('{{floorName}}', item) |
| |
| ret.push(html) |
| }, this) |
| |
| this.box.innerHTML = ret.join('') |
| }, |
| selectedIndex: function (val) { |
| var attr = this.data.attr |
| |
| if (val === undefined) { |
| val = 0 |
| } |
| |
| // if (val == attr.selectedIndex) { |
| // return |
| // } |
| |
| attr.selectedIndex = val |
| |
| this.attr.data.call(this) |
| |
| this._folding() |
| this.style.textHighlightColor.call(this, this.textHighlightColor) |
| } |
| } |
| |
| proto.style = Object.create(Atomic.prototype.style) |
| |
| proto.style.opacity = function (val) { |
| if (val === undefined || val < 0 || val > 1) { |
| val = 1 |
| } |
| |
| this.node.style.opacity = val |
| } |
| |
| proto.style.textColor = function (val) { |
| if (!isValidColor(val)) { |
| return |
| } |
| |
| this.node.style.color = val |
| } |
| |
| proto.style.textHighlightColor = function (val) { |
| if (!isValidColor(val)) { |
| return |
| } |
| this.textHighlightColor = val |
| var attr = this.data.attr |
| |
| var node = this.node.querySelector('[data-floor="' |
| + attr.selectedIndex + '"]') |
| if (node) { |
| node.style.color = val |
| this._scrollToView(node) |
| } |
| } |
| |
| proto._scrollToView = function (node) { |
| if (!node) { |
| var attr = this.data.attr |
| node = this.node.querySelector('[data-floor="' + attr.selectedIndex + '"]') |
| } |
| if (!node) { |
| return |
| } |
| |
| var defaultVal = this._body.scrollLeft |
| var leftVal = defaultVal - node.offsetLeft + 300 |
| |
| var scrollVal = getScrollVal(this._body.getBoundingClientRect(), node) |
| doScroll(this._body, scrollVal) |
| } |
| |
| // scroll the tabheader. |
| // positive val means to scroll right. |
| // negative val means to scroll left. |
| function doScroll(node, val, finish) { |
| if (!val) { |
| return |
| } |
| if (finish === undefined) { |
| finish = Math.abs(val) |
| } |
| |
| if (finish <= 0) { |
| return |
| } |
| |
| setTimeout(function () { |
| if (val > 0) { |
| node.scrollLeft += 2 |
| } else { |
| node.scrollLeft -= 2 |
| } |
| finish -= 2 |
| |
| doScroll(node, val, finish) |
| }) |
| } |
| |
| // get scroll distance. |
| function getScrollVal(rect, node) { |
| var left = node.previousSibling |
| var right = node.nextSibling |
| var scrollVal |
| |
| // process left-side element first. |
| if (left) { |
| var leftRect = left.getBoundingClientRect() |
| // only need to compare the value of left. |
| if (leftRect.left < rect.left) { |
| scrollVal = leftRect.left |
| return scrollVal |
| } |
| } |
| |
| if (right) { |
| var rightRect = right.getBoundingClientRect() |
| // compare the value of right. |
| if (rightRect.right > rect.right) { |
| scrollVal = rightRect.right - rect.right |
| return scrollVal |
| } |
| } |
| |
| // process current node, from left to right. |
| var nodeRect = node.getBoundingClientRect() |
| if (nodeRect.left < rect.left) { |
| scrollVal = nodeRect.left |
| } else if (nodeRect.right > rect.right) { |
| scrollVal = nodeRect.right - rect.right |
| } |
| |
| return scrollVal |
| } |
| |
| // trigger and broadcast events. |
| function fireEvent(element, type, data) { |
| var evt = document.createEvent('Event') |
| evt.data = data |
| utils.extend(evt, data) |
| // need bubble. |
| evt.initEvent(type, true, true) |
| |
| element.dispatchEvent(evt) |
| } |
| |
| function createHighlightIcon(code) { |
| var html = '<i class="hl-icon iconfont">' + '' + '</i>' |
| return html |
| } |
| |
| function isValidColor(color) { |
| if (!color) { |
| return false |
| } |
| |
| if (color.charAt(0) !== '#') { |
| return false |
| } |
| |
| if (color.length !== 7) { |
| return false |
| } |
| |
| return true |
| } |
| |
| module.exports = TabHeader |
| |
| |
| /***/ }, |
| /* 48 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| var config = __webpack_require__(5) |
| var messageQueue = [] |
| |
| function flushMessage() { |
| if (typeof callJS === 'function' && messageQueue.length > 0) { |
| callJS(config.instanceId, JSON.stringify(messageQueue)) |
| messageQueue.length = 0 |
| } |
| } |
| |
| function push(msg) { |
| messageQueue.push(msg) |
| } |
| |
| /** |
| * To fix the problem of callapp, the two-way time loop mechanism must |
| * be replaced by directly procedure call except the situation of |
| * page loading. |
| * 2015-11-03 |
| */ |
| function pushDirectly(msg) { |
| callJS(config.instanceId, [msg]) |
| } |
| |
| module.exports = { |
| push: pushDirectly |
| } |
| |
| |
| /***/ }, |
| /* 49 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| // style-loader: Adds some css to the DOM by adding a <style> tag |
| |
| // load the styles |
| var content = __webpack_require__(50); |
| if(typeof content === 'string') content = [[module.id, content, '']]; |
| // add the styles to the DOM |
| var update = __webpack_require__(4)(content, {}); |
| if(content.locals) module.exports = content.locals; |
| // Hot Module Replacement |
| if(false) { |
| // When the styles change, update the <style> tags |
| if(!content.locals) { |
| module.hot.accept("!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./tabheader.scss", function() { |
| var newContent = require("!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./tabheader.scss"); |
| if(typeof newContent === 'string') newContent = [[module.id, newContent, '']]; |
| update(newContent); |
| }); |
| } |
| // When the module is disposed, remove the <style> tags |
| module.hot.dispose(function() { update(); }); |
| } |
| |
| /***/ }, |
| /* 50 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| exports = module.exports = __webpack_require__(3)(); |
| // imports |
| |
| |
| // module |
| exports.push([module.id, ".tab-header {\n position: relative;\n width: 10rem;\n font-size: 14px;\n color: #333; }\n .tab-header .header-bar {\n height: 1.17rem;\n line-height: 1.17rem;\n display: none;\n color: #999;\n padding-left: 0.4rem; }\n .tab-header .header-body {\n margin-right: 1.07rem;\n overflow-x: auto;\n overflow-y: hidden; }\n .tab-header .header-body::-webkit-scrollbar {\n width: 0;\n height: 0;\n overflow: hidden; }\n .tab-header .fold-toggle {\n position: absolute;\n top: 0.59rem;\n -webkit-transform: translateY(-50%);\n right: 0.29rem;\n width: 0.48rem;\n height: 0.48rem;\n line-height: 0.48rem;\n text-align: center;\n z-index: 99;\n font-size: 14px; }\n .tab-header.unfold-header {\n position: fixed !important;\n top: 0;\n left: 0;\n overflow: hidden; }\n\n.tabheader {\n list-style: none;\n white-space: nowrap;\n height: 1.17rem;\n line-height: 1.17rem; }\n .tabheader .th-item {\n padding-left: 0.72rem;\n position: relative;\n display: inline-block; }\n .tabheader .hl-icon {\n width: 0.4rem;\n height: 0.4rem;\n line-height: 0.4rem;\n text-align: center;\n position: absolute;\n top: 50%;\n -webkit-transform: translateY(-50%);\n left: 0.24rem;\n font-size: 14px; }\n\n.unfold-header .header-bar {\n display: block; }\n\n.unfold-header .fold-toggle {\n -webkit-transform: translateY(-50%) rotate(180deg); }\n\n.unfold-header .header-body {\n margin-right: 0;\n padding: 0.24rem; }\n\n.unfold-header .tabheader {\n display: block;\n height: auto; }\n\n.unfold-header .th-item {\n box-sizing: border-box;\n float: left;\n width: 33.3333%;\n height: 1.01rem;\n line-height: 1.01rem; }\n\n.unfold-header .hl-icon {\n margin-right: 0;\n position: absolute; }\n\n.unfold-header.tabheader-mask {\n display: block;\n width: 100%;\n height: 100%;\n background-color: rgba(0, 0, 0, 0.6); }\n\n.tabheader-mask {\n display: none;\n position: fixed;\n left: 0;\n top: 0; }\n\n@font-face {\n font-family: \"iconfont\";\n src: url(\"data:application/x-font-ttf;charset=utf-8;base64,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R7AEQ7CAYmAgsAArIIqKYSCwAkNgZCOwA0NhZFBYsAJDYRuwA0NgWbADJbCAYmGwAiVGYTgjIDwjOBshICBGI0ewACsjYTghWbEkARQrLbA7LLAuKy6xJAEUKy2wPCywLyshIyAgPLAEI0IjOLEkARQrsARDLrAkKy2wPSywABUgR7AAI0KyAAEBFRQTLrAqKi2wPiywABUgR7AAI0KyAAEBFRQTLrAqKi2wPyyxAAEUE7ArKi2wQCywLSotsEEssAAWRSMgLiBGiiNhOLEkARQrLbBCLLAJI0KwQSstsEMssgAAOistsEQssgABOistsEUssgEAOistsEYssgEBOistsEcssgAAOystsEgssgABOystsEkssgEAOystsEossgEBOystsEsssgAANystsEwssgABNystsE0ssgEANystsE4ssgEBNystsE8ssgAAOSstsFAssgABOSstsFEssgEAOSstsFIssgEBOSstsFMssgAAPCstsFQssgABPCstsFUssgEAPCstsFYssgEBPCstsFcssgAAOCstsFgssgABOCstsFkssgEAOCstsFossgEBOCstsFsssDArLrEkARQrLbBcLLAwK7A0Ky2wXSywMCuwNSstsF4ssAAWsDArsDYrLbBfLLAxKy6xJAEUKy2wYCywMSuwNCstsGEssDErsDUrLbBiLLAxK7A2Ky2wYyywMisusSQBFCstsGQssDIrsDQrLbBlLLAyK7A1Ky2wZiywMiuwNistsGcssDMrLrEkARQrLbBoLLAzK7A0Ky2waSywMyuwNSstsGossDMrsDYrLbBrLCuwCGWwAyRQeLABFTAtAABLuADIUlixAQGOWbkIAAgAYyCwASNEILADI3CwDkUgIEu4AA5RS7AGU1pYsDQbsChZYGYgilVYsAIlYbABRWMjYrACI0SzCgkFBCuzCgsFBCuzDg8FBCtZsgQoCUVSRLMKDQYEK7EGAUSxJAGIUViwQIhYsQYDRLEmAYhRWLgEAIhYsQYBRFlZWVm4Af+FsASNsQUARAAAAA==\") format(\"truetype\"); }\n\n.iconfont {\n font-family: iconfont !important;\n font-size: 16px;\n font-style: normal;\n -webkit-font-smoothing: antialiased;\n -webkit-text-stroke-width: 0.2px;\n -moz-osx-font-smoothing: grayscale; }\n\n[data-dpr=\"2\"] .tab-header {\n font-size: 28px; }\n\n[data-dpr=\"3\"] .tab-header {\n font-size: 42px; }\n\n[data-dpr=\"2\"] .tabheader .hl-icon {\n font-size: 28px; }\n\n[data-dpr=\"3\"] .tabheader .hl-icon {\n font-size: 42px; }\n\n[data-dpr=\"2\"] .tab-header .fold-toggle {\n font-size: 28px; }\n\n[data-dpr=\"3\"] .tab-header .fold-toggle {\n font-size: 42px; }\n", "", {"version":3,"sources":["/./src/src/styles/tabheader.scss","/./src/styles/tabheader.scss"],"names":[],"mappings":"AAGA;EACE,mBAAmB;EACnB,aAAa;EACb,gBAAgB;EAChB,YAAY,EA0Cb;EA9CD;IAOI,gBAAgB;IAChB,qBAAqB;IACrB,cAAc;IACd,YAAY;IACZ,qBAAqB,EACtB;EAZH;IAeI,sBAAsB;IACtB,iBAAiB;IACjB,mBAAmB,EAOpB;IAxBH;MAoBM,SAAS;MACT,UAAU;MACV,iBAAiB,EAClB;EAvBL;IA2BI,mBAAmB;IACnB,aAAa;IACb,oCAA6B;IAC7B,eAAe;IACf,eAAe;IACf,gBAAgB;IAChB,qBAAqB;IACrB,mBAAmB;IACnB,YAAY;IACZ,gBAAgB,EACjB;EArCH;IAwCI,2BAA2B;IAC3B,OAAO;IACP,QAAQ;IACR,iBAAiB,EAClB;;AAIH;EACE,iBAAiB;EACjB,oBAAoB;EACpB,gBAAgB;EAChB,qBAAqB,EAoBtB;EAxBD;IAOI,sBAAsB;IACtB,mBAAmB;IACnB,sBAAsB,EACvB;EAVH;IAaI,cAAc;IACd,eAAe;IACf,oBAAoB;IACpB,mBAAmB;IACnB,mBAAmB;IACnB,SAAS;IACT,oCAA6B;IAC7B,cAAc;IACd,gBAAgB,EACjB;;AAIH;EAGI,eAAe,EAChB;;AAJH;EAOI,mDAA0C,EAC3C;;AARH;EAWI,gBAAgB;EAChB,iBAAiB,EAClB;;AAbH;EAgBI,eAAe;EACf,aAAa,EACd;;AAlBH;EAqBI,uBAAuB;EACvB,YAAY;EACZ,gBAAgB;EAChB,gBAAgB;EAChB,qBAAqB,EACtB;;AA1BH;EA6BI,gBAAgB;EAChB,mBAAmB,EACpB;;AA/BH;EAkCI,eAAe;EACf,YAAY;EACZ,aAAa;EACb,qCAAsB,EACvB;;AAGH;EACE,cAAc;EACd,gBAAgB;EAChB,QAAQ;EACR,OAAO,EACR;;AAED;EACE,wBAAwB;EACxB,y9NAA48N,EAAA;;AAG98N;EACE,iCAAiC;EACjC,gBAAgB;EAChB,mBAAmB;EACnB,oCAAoC;EACpC,iCAAiC;EACjC,mCAAmC,EACpC;;AChCD;EDmCE,gBAAgB,EACjB;;ACjCD;EDoCE,gBAAgB,EACjB;;AClCD;EDqCE,gBAAgB,EACjB;;ACnCD;EDsCE,gBAAgB,EACjB;;ACpCD;EDuCE,gBAAgB,EACjB;;ACrCD;EDwCE,gBAAgB,EACjB","file":"tabheader.scss","sourcesContent":["// Heads up! Rem is not a good way for\n// weex HTML5 renderer.\n\n.tab-header {\n position: relative;\n width: 10rem;\n font-size: 14px;\n color: #333;\n\n .header-bar {\n height: 1.17rem;\n line-height: 1.17rem;\n display: none;\n color: #999;\n padding-left: 0.4rem;\n }\n \n .header-body {\n margin-right: 1.07rem;\n overflow-x: auto;\n overflow-y: hidden;\n\n &::-webkit-scrollbar {\n width: 0;\n height: 0;\n overflow: hidden;\n }\n }\n\n .fold-toggle {\n position: absolute;\n top: 0.59rem;\n -webkit-transform: translateY(-50%);\n right: 0.29rem;\n width: 0.48rem;\n height: 0.48rem;\n line-height: 0.48rem;\n text-align: center;\n z-index: 99;\n font-size: 14px;\n }\n\n &.unfold-header {\n position: fixed !important;\n top: 0;\n left: 0;\n overflow: hidden;\n }\n\n}\n\n.tabheader {\n list-style: none;\n white-space: nowrap;\n height: 1.17rem;\n line-height: 1.17rem;\n\n .th-item {\n padding-left: 0.72rem;\n position: relative;\n display: inline-block;\n }\n\n .hl-icon {\n width: 0.4rem;\n height: 0.4rem;\n line-height: 0.4rem;\n text-align: center;\n position: absolute;\n top: 50%;\n -webkit-transform: translateY(-50%);\n left: 0.24rem;\n font-size: 14px;\n }\n\n}\n\n.unfold-header {\n\n .header-bar {\n display: block;\n }\n\n .fold-toggle {\n -webkit-transform: translateY(-50%) rotate(180deg);\n }\n\n .header-body {\n margin-right: 0;\n padding: 0.24rem;\n }\n\n .tabheader {\n display: block;\n height: auto;\n }\n\n .th-item {\n box-sizing: border-box;\n float: left;\n width: 33.3333%;\n height: 1.01rem;\n line-height: 1.01rem;\n }\n\n .hl-icon {\n margin-right: 0;\n position: absolute;\n }\n\n &.tabheader-mask {\n display: block;\n width: 100%;\n height: 100%;\n background-color: rgba(0, 0, 0, 0.6);\n }\n}\n\n.tabheader-mask {\n display: none;\n position: fixed;\n left: 0;\n top: 0;\n}\n\n@font-face {\n font-family: \"iconfont\";\n src: url(\"data:application/x-font-ttf;charset=utf-8;base64,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R7AEQ7CAYmAgsAArIIqKYSCwAkNgZCOwA0NhZFBYsAJDYRuwA0NgWbADJbCAYmGwAiVGYTgjIDwjOBshICBGI0ewACsjYTghWbEkARQrLbA7LLAuKy6xJAEUKy2wPCywLyshIyAgPLAEI0IjOLEkARQrsARDLrAkKy2wPSywABUgR7AAI0KyAAEBFRQTLrAqKi2wPiywABUgR7AAI0KyAAEBFRQTLrAqKi2wPyyxAAEUE7ArKi2wQCywLSotsEEssAAWRSMgLiBGiiNhOLEkARQrLbBCLLAJI0KwQSstsEMssgAAOistsEQssgABOistsEUssgEAOistsEYssgEBOistsEcssgAAOystsEgssgABOystsEkssgEAOystsEossgEBOystsEsssgAANystsEwssgABNystsE0ssgEANystsE4ssgEBNystsE8ssgAAOSstsFAssgABOSstsFEssgEAOSstsFIssgEBOSstsFMssgAAPCstsFQssgABPCstsFUssgEAPCstsFYssgEBPCstsFcssgAAOCstsFgssgABOCstsFkssgEAOCstsFossgEBOCstsFsssDArLrEkARQrLbBcLLAwK7A0Ky2wXSywMCuwNSstsF4ssAAWsDArsDYrLbBfLLAxKy6xJAEUKy2wYCywMSuwNCstsGEssDErsDUrLbBiLLAxK7A2Ky2wYyywMisusSQBFCstsGQssDIrsDQrLbBlLLAyK7A1Ky2wZiywMiuwNistsGcssDMrLrEkARQrLbBoLLAzK7A0Ky2waSywMyuwNSstsGossDMrsDYrLbBrLCuwCGWwAyRQeLABFTAtAABLuADIUlixAQGOWbkIAAgAYyCwASNEILADI3CwDkUgIEu4AA5RS7AGU1pYsDQbsChZYGYgilVYsAIlYbABRWMjYrACI0SzCgkFBCuzCgsFBCuzDg8FBCtZsgQoCUVSRLMKDQYEK7EGAUSxJAGIUViwQIhYsQYDRLEmAYhRWLgEAIhYsQYBRFlZWVm4Af+FsASNsQUARAAAAA==\") format(\"truetype\");\n}\n\n.iconfont {\n font-family: iconfont !important;\n font-size: 16px;\n font-style: normal;\n -webkit-font-smoothing: antialiased;\n -webkit-text-stroke-width: 0.2px;\n -moz-osx-font-smoothing: grayscale;\n}\n\n[data-dpr=\"2\"] .tab-header {\n font-size: 28px;\n}\n\n[data-dpr=\"3\"] .tab-header {\n font-size: 42px;\n}\n\n[data-dpr=\"2\"] .tabheader .hl-icon {\n font-size: 28px;\n}\n\n[data-dpr=\"3\"] .tabheader .hl-icon {\n font-size: 42px;\n}\n\n[data-dpr=\"2\"] .tab-header .fold-toggle {\n font-size: 28px;\n}\n\n[data-dpr=\"3\"] .tab-header .fold-toggle {\n font-size: 42px;\n}",".tab-header {\n position: relative;\n width: 10rem;\n font-size: 14px;\n color: #333; }\n .tab-header .header-bar {\n height: 1.17rem;\n line-height: 1.17rem;\n display: none;\n color: #999;\n padding-left: 0.4rem; }\n .tab-header .header-body {\n margin-right: 1.07rem;\n overflow-x: auto;\n overflow-y: hidden; }\n .tab-header .header-body::-webkit-scrollbar {\n width: 0;\n height: 0;\n overflow: hidden; }\n .tab-header .fold-toggle {\n position: absolute;\n top: 0.59rem;\n -webkit-transform: translateY(-50%);\n right: 0.29rem;\n width: 0.48rem;\n height: 0.48rem;\n line-height: 0.48rem;\n text-align: center;\n z-index: 99;\n font-size: 14px; }\n .tab-header.unfold-header {\n position: fixed !important;\n top: 0;\n left: 0;\n overflow: hidden; }\n\n.tabheader {\n list-style: none;\n white-space: nowrap;\n height: 1.17rem;\n line-height: 1.17rem; }\n .tabheader .th-item {\n padding-left: 0.72rem;\n position: relative;\n display: inline-block; }\n .tabheader .hl-icon {\n width: 0.4rem;\n height: 0.4rem;\n line-height: 0.4rem;\n text-align: center;\n position: absolute;\n top: 50%;\n -webkit-transform: translateY(-50%);\n left: 0.24rem;\n font-size: 14px; }\n\n.unfold-header .header-bar {\n display: block; }\n\n.unfold-header .fold-toggle {\n -webkit-transform: translateY(-50%) rotate(180deg); }\n\n.unfold-header .header-body {\n margin-right: 0;\n padding: 0.24rem; }\n\n.unfold-header .tabheader {\n display: block;\n height: auto; }\n\n.unfold-header .th-item {\n box-sizing: border-box;\n float: left;\n width: 33.3333%;\n height: 1.01rem;\n line-height: 1.01rem; }\n\n.unfold-header .hl-icon {\n margin-right: 0;\n position: absolute; }\n\n.unfold-header.tabheader-mask {\n display: block;\n width: 100%;\n height: 100%;\n background-color: rgba(0, 0, 0, 0.6); }\n\n.tabheader-mask {\n display: none;\n position: fixed;\n left: 0;\n top: 0; }\n\n@font-face {\n font-family: \"iconfont\";\n src: url(\"data:application/x-font-ttf;charset=utf-8;base64,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R7AEQ7CAYmAgsAArIIqKYSCwAkNgZCOwA0NhZFBYsAJDYRuwA0NgWbADJbCAYmGwAiVGYTgjIDwjOBshICBGI0ewACsjYTghWbEkARQrLbA7LLAuKy6xJAEUKy2wPCywLyshIyAgPLAEI0IjOLEkARQrsARDLrAkKy2wPSywABUgR7AAI0KyAAEBFRQTLrAqKi2wPiywABUgR7AAI0KyAAEBFRQTLrAqKi2wPyyxAAEUE7ArKi2wQCywLSotsEEssAAWRSMgLiBGiiNhOLEkARQrLbBCLLAJI0KwQSstsEMssgAAOistsEQssgABOistsEUssgEAOistsEYssgEBOistsEcssgAAOystsEgssgABOystsEkssgEAOystsEossgEBOystsEsssgAANystsEwssgABNystsE0ssgEANystsE4ssgEBNystsE8ssgAAOSstsFAssgABOSstsFEssgEAOSstsFIssgEBOSstsFMssgAAPCstsFQssgABPCstsFUssgEAPCstsFYssgEBPCstsFcssgAAOCstsFgssgABOCstsFkssgEAOCstsFossgEBOCstsFsssDArLrEkARQrLbBcLLAwK7A0Ky2wXSywMCuwNSstsF4ssAAWsDArsDYrLbBfLLAxKy6xJAEUKy2wYCywMSuwNCstsGEssDErsDUrLbBiLLAxK7A2Ky2wYyywMisusSQBFCstsGQssDIrsDQrLbBlLLAyK7A1Ky2wZiywMiuwNistsGcssDMrLrEkARQrLbBoLLAzK7A0Ky2waSywMyuwNSstsGossDMrsDYrLbBrLCuwCGWwAyRQeLABFTAtAABLuADIUlixAQGOWbkIAAgAYyCwASNEILADI3CwDkUgIEu4AA5RS7AGU1pYsDQbsChZYGYgilVYsAIlYbABRWMjYrACI0SzCgkFBCuzCgsFBCuzDg8FBCtZsgQoCUVSRLMKDQYEK7EGAUSxJAGIUViwQIhYsQYDRLEmAYhRWLgEAIhYsQYBRFlZWVm4Af+FsASNsQUARAAAAA==\") format(\"truetype\"); }\n\n.iconfont {\n font-family: iconfont !important;\n font-size: 16px;\n font-style: normal;\n -webkit-font-smoothing: antialiased;\n -webkit-text-stroke-width: 0.2px;\n -moz-osx-font-smoothing: grayscale; }\n\n[data-dpr=\"2\"] .tab-header {\n font-size: 28px; }\n\n[data-dpr=\"3\"] .tab-header {\n font-size: 42px; }\n\n[data-dpr=\"2\"] .tabheader .hl-icon {\n font-size: 28px; }\n\n[data-dpr=\"3\"] .tabheader .hl-icon {\n font-size: 42px; }\n\n[data-dpr=\"2\"] .tab-header .fold-toggle {\n font-size: 28px; }\n\n[data-dpr=\"3\"] .tab-header .fold-toggle {\n font-size: 42px; }\n"],"sourceRoot":"webpack://"}]); |
| |
| // exports |
| |
| |
| /***/ }, |
| /* 51 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| __webpack_require__(52) |
| __webpack_require__(32) |
| |
| // lib.scroll events: |
| // - scrollstart |
| // - scrolling |
| // - pulldownend |
| // - pullupend |
| // - pullleftend |
| // - pullrightend |
| // - pulldown |
| // - pullup |
| // - pullleft |
| // - pullright |
| // - contentrefresh |
| |
| var Component = __webpack_require__(16) |
| var utils = __webpack_require__(7) |
| |
| // attrs: |
| // - scroll-direciton: none|vertical|horizontal (default is vertical) |
| // - show-scrollbar: true|false (default is true) |
| function Scroller (data, nodeType) { |
| var attrs = data.attr || {} |
| this.items = [] |
| this.totalWidth = 0 |
| this.scrollDirection = attrs.scrollDirection === 'horizontal' |
| ? 'horizontal' |
| : 'vertical' |
| this.showScrollbar = attrs.showScrollbar || true |
| Component.call(this, data, nodeType) |
| } |
| |
| Scroller.prototype = Object.create(Component.prototype) |
| |
| Scroller.prototype.create = function (nodeType) { |
| var Scroll = lib.scroll |
| var node = Component.prototype.create.call(this, nodeType) |
| node.classList.add('weex-container', 'scroll-wrap') |
| this.scrollElement = document.createElement('div') |
| this.scrollElement.classList.add( |
| 'weex-container', |
| 'scroll-element', |
| this.scrollDirection |
| ) |
| node.appendChild(this.scrollElement) |
| this.scroller = new Scroll({ |
| scrollElement: this.scrollElement, |
| direction: this.scrollDirection === 'vertical' ? 'y' : 'x' |
| }) |
| this.scroller.init() |
| return node |
| } |
| |
| Scroller.prototype.bindEvents = function (evts) { |
| Component.prototype.bindEvents.call(this, evts) |
| // to enable lazyload for Images |
| this.scroller.addEventListener('scrolling', function (e) { |
| var so = e.scrollObj |
| this.dispatchEvent('scroll', { |
| originalType: 'scrolling', |
| scrollTop: so.getScrollTop(), |
| scrollLeft: so.getScrollLeft() |
| }, { |
| bubbles: true |
| }) |
| }.bind(this)) |
| } |
| |
| Scroller.prototype.appendChild = function (data) { |
| var children = this.data.children |
| var componentManager = this.getComponentManager() |
| var child = componentManager.createElement(data) |
| this.scrollElement.appendChild(child.node) |
| |
| var childWidth = child.node.getBoundingClientRect().width |
| this.totalWidth += childWidth |
| // if direction is horizontal then the width of scrollElement |
| // should be set manually due to flexbox's rule (child elements |
| // will not exceed box's width but to shrink to adapt). |
| if (this.scrollDirection === 'horizontal') { |
| this.scrollElement.style.width = this.totalWidth + 'px' |
| } |
| |
| // update this.data.children |
| if (!children || !children.length) { |
| this.data.children = [data] |
| } else { |
| children.push(data) |
| } |
| |
| this.items.push(child) |
| return child |
| } |
| |
| Scroller.prototype.insertBefore = function (child, before) { |
| var children = this.data.children |
| var i = 0 |
| var isAppend = false |
| |
| // update this.data.children |
| if (!children || !children.length || !before) { |
| isAppend = true |
| } else { |
| for (var l = children.length; i < l; i++) { |
| if (children[i].ref === child.data.ref) { |
| break |
| } |
| } |
| if (i === l) { |
| isAppend = true |
| } |
| } |
| |
| if (isAppend) { |
| this.scrollElement.appendChild(child.node) |
| children.push(child.data) |
| this.items.push(child) |
| } else { |
| this.scrollElement.insertBefore(child.node, before.node) |
| children.splice(i, 0, child.data) |
| this.items.splice(i, 0, child) |
| } |
| } |
| |
| Scroller.prototype.removeChild = function () { |
| var children = this.data.children |
| // remove from this.data.children |
| var i = 0 |
| var componentManager = this.getComponentManager() |
| if (children && children.length) { |
| for (var l = children.length; i < l; i++) { |
| if (children[i].ref === child.data.ref) { |
| break |
| } |
| } |
| if (i < l) { |
| children.splice(i, 1) |
| this.items.splice(i, 1) |
| } |
| } |
| // remove from componentMap recursively |
| componentManager.removeElementByRef(child.data.ref) |
| this.scrollElement.removeChild(child.node) |
| } |
| |
| module.exports = Scroller |
| |
| |
| /***/ }, |
| /* 52 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| // style-loader: Adds some css to the DOM by adding a <style> tag |
| |
| // load the styles |
| var content = __webpack_require__(53); |
| if(typeof content === 'string') content = [[module.id, content, '']]; |
| // add the styles to the DOM |
| var update = __webpack_require__(4)(content, {}); |
| if(content.locals) module.exports = content.locals; |
| // Hot Module Replacement |
| if(false) { |
| // When the styles change, update the <style> tags |
| if(!content.locals) { |
| module.hot.accept("!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./scroller.scss", function() { |
| var newContent = require("!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./scroller.scss"); |
| if(typeof newContent === 'string') newContent = [[module.id, newContent, '']]; |
| update(newContent); |
| }); |
| } |
| // When the module is disposed, remove the <style> tags |
| module.hot.dispose(function() { update(); }); |
| } |
| |
| /***/ }, |
| /* 53 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| exports = module.exports = __webpack_require__(3)(); |
| // imports |
| |
| |
| // module |
| exports.push([module.id, ".scroll-wrap {\n display: block;\n overflow: hidden; }\n\n.scroll-element.horizontal {\n -webkit-box-orient: horizontal;\n -webkit-flex-direction: row;\n flex-direction: row; }\n\n.scroll-element.vertical {\n -webkit-box-orient: vertical;\n -webkit-flex-direction: column;\n flex-direction: column; }\n", "", {"version":3,"sources":["/./src/src/styles/scroller.scss"],"names":[],"mappings":"AAAA;EACC,eAAe;EACf,iBAAiB,EACjB;;AAED;EAEI,+BAA+B;EAC/B,4BAA4B;EAC5B,oBAAoB,EACrB;;AALH;EAOI,6BAA6B;EAC7B,+BAA+B;EAC/B,uBAAuB,EACxB","file":"scroller.scss","sourcesContent":[".scroll-wrap {\n\tdisplay: block;\n\toverflow: hidden;\n}\n\n.scroll-element {\n &.horizontal {\n -webkit-box-orient: horizontal;\n -webkit-flex-direction: row;\n flex-direction: row;\n }\n &.vertical {\n -webkit-box-orient: vertical;\n -webkit-flex-direction: column;\n flex-direction: column;\n }\n}"],"sourceRoot":"webpack://"}]); |
| |
| // exports |
| |
| |
| /***/ }, |
| /* 54 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| var Atomic = __webpack_require__(27) |
| var utils = __webpack_require__(7) |
| |
| // attrs: |
| // - type: text|password|tel|email|url |
| // - value |
| // - placeholder |
| // - disabled |
| // - autofocus |
| function Input (data) { |
| var attrs = data.attr || {} |
| this.type = attrs.type || 'text' |
| this.value = attrs.value |
| this.placeholder = attrs.placeholder |
| this.autofocus = attrs.autofocus && (attrs.autofocus !== 'false') |
| ? true |
| : false |
| Atomic.call(this, data) |
| } |
| |
| Input.prototype = Object.create(Atomic.prototype) |
| |
| Input.prototype.create = function () { |
| var node = document.createElement('input') |
| var uuid = Math.floor(10000000000000 * Math.random()) + Date.now() |
| this.className = 'weex-ipt-' + uuid |
| this.styleId = 'weex-style-' + uuid |
| node.classList.add(this.className) |
| node.setAttribute('type', this.type) |
| node.type = this.type |
| // For the consistency of input component's width. |
| // The date and time type of input will have a bigger width |
| // when the 'box-sizing' is not set to 'border-box' |
| node.classList.add('weex-element') |
| this.value && (node.value = this.value) |
| this.placeholder && (node.placeholder = this.placeholder) |
| return node |
| } |
| |
| Input.prototype.updateStyle = function (style) { |
| Atomic.prototype.updateStyle.call(this, style) |
| if (style && style.placeholderColor) { |
| this.placeholderColor = style.placeholderColor |
| this.setPlaceholderColor() |
| } |
| } |
| |
| Input.prototype.attr = { |
| disabled: function (val) { |
| this.node.disabled = val && val !== 'false' |
| ? true |
| : false |
| } |
| } |
| |
| Input.prototype.setPlaceholderColor = function () { |
| if (!this.placeholderColor) { |
| return |
| } |
| var vendors = [ |
| '::-webkit-input-placeholder', |
| ':-moz-placeholder', |
| '::-moz-placeholder', |
| ':-ms-input-placeholder', |
| ':placeholder-shown' |
| ] |
| var css = '' |
| var cssRule = 'color: ' + this.placeholderColor + ';' |
| for (var i = 0, l = vendors.length; i < l; i++) { |
| css += '.' + this.className + vendors[i] + '{' |
| + cssRule + '}' |
| } |
| utils.appendStyle(css, this.styleId, true) |
| } |
| |
| module.exports = Input |
| |
| |
| /***/ }, |
| /* 55 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| var Atomic = __webpack_require__(16) |
| var sender = __webpack_require__(19) |
| |
| // attrs: |
| // - options: the options to be listed, as a array of strings. |
| // - selectedIndex: the selected options' index number. |
| // - disabled |
| function Select (data) { |
| var attrs = data.attr || {} |
| this.options = [] |
| this.selectedIndex = 0 |
| Atomic.call(this, data) |
| } |
| |
| Select.prototype = Object.create(Atomic.prototype) |
| |
| Select.prototype.create = function () { |
| var node = document.createElement('select') |
| var uuid = Math.floor(10000000000000 * Math.random()) + Date.now() |
| this.className = 'weex-slct-' + uuid |
| this.styleId = 'weex-style-' + uuid |
| node.classList.add(this.className) |
| // For the consistency of input component's width. |
| // The date and time type of input will have a bigger width |
| // when the 'box-sizing' is not set to 'border-box' |
| node.style['box-sizing'] = 'border-box' |
| return node |
| } |
| |
| Select.prototype.attr = { |
| disabled: function (val) { |
| this.node.disabled = val && val !== 'false' |
| ? true |
| : false |
| }, |
| options: function (val) { |
| if (Object.prototype.toString.call(val) !== '[object Array]') { |
| return |
| } |
| this.options = val |
| this.node.innerHTML = '' |
| this.createOptions(val) |
| }, |
| selectedIndex: function (val) { |
| val = parseInt(val) |
| if (typeof val !== 'number' || val !== val || val >= this.options.length) { |
| return |
| } |
| this.node.value = this.options[val] |
| } |
| } |
| |
| Select.prototype.bindEvents = function (evts) { |
| var isListenToChange = false |
| Atomic.prototype.bindEvents.call( |
| this, |
| evts.filter(function (val) { |
| var pass = val !== 'change' |
| !pass && (isListenToChange = true) |
| return pass |
| })) |
| if (isListenToChange) { |
| this.node.addEventListener('change', function (e) { |
| e.index = this.options.indexOf(this.node.value) |
| sender.fireEvent(this.data.ref, 'change', e) |
| }.bind(this)) |
| } |
| } |
| |
| Select.prototype.createOptions = function (opts) { |
| var optDoc = document.createDocumentFragment() |
| var opt |
| for (var i = 0, l = opts.length; i < l; i++) { |
| opt = document.createElement('option') |
| opt.appendChild(document.createTextNode(opts[i])) |
| optDoc.appendChild(opt) |
| } |
| this.node.appendChild(optDoc) |
| } |
| |
| module.exports = Select |
| |
| |
| /***/ }, |
| /* 56 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| var Atomic = __webpack_require__(27) |
| |
| // attrs: |
| // - value |
| // - disabled |
| function Datepicker (data) { |
| Atomic.call(this, data) |
| } |
| |
| Datepicker.prototype = Object.create(Atomic.prototype) |
| |
| Datepicker.prototype.create = function () { |
| var node = document.createElement('input') |
| var uuid = Math.floor(10000000000000 * Math.random()) + Date.now() |
| this.className = 'weex-ipt-' + uuid |
| this.styleId = 'weex-style-' + uuid |
| node.classList.add(this.className) |
| node.setAttribute('type', 'date') |
| node.type = 'date' |
| // For the consistency of input component's width. |
| // The date and time type of input will have a bigger width |
| // when the 'box-sizing' is not set to 'border-box' |
| node.classList.add('weex-element') |
| return node |
| } |
| |
| Datepicker.prototype.attr = { |
| disabled: function (val) { |
| this.node.disabled = val && val !== 'false' |
| ? true |
| : false |
| } |
| } |
| |
| module.exports = Datepicker |
| |
| |
| /***/ }, |
| /* 57 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| var Atomic = __webpack_require__(27) |
| |
| // attrs: |
| // - value |
| // - disabled |
| function Timepicker (data) { |
| Atomic.call(this, data) |
| } |
| |
| Timepicker.prototype = Object.create(Atomic.prototype) |
| |
| Timepicker.prototype.create = function () { |
| var node = document.createElement('input') |
| var uuid = Math.floor(10000000000000 * Math.random()) + Date.now() |
| this.className = 'weex-ipt-' + uuid |
| this.styleId = 'weex-style-' + uuid |
| node.classList.add(this.className) |
| node.setAttribute('type', 'time') |
| node.type = 'time' |
| // For the consistency of input component's width. |
| // The date and time type of input will have a bigger width |
| // when the 'box-sizing' is not set to 'border-box' |
| node.classList.add('weex-element') |
| return node |
| } |
| |
| Timepicker.prototype.attr = { |
| disabled: function (val) { |
| this.node.disabled = val && val !== 'false' |
| ? true |
| : false |
| } |
| } |
| |
| module.exports = Timepicker |
| |
| |
| /***/ }, |
| /* 58 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| var Atomic = __webpack_require__(27) |
| var utils = __webpack_require__(7) |
| __webpack_require__(59) |
| |
| // attrs: |
| // - autoPlay: true | false (default: false) |
| // - playStatus: play | pause | stop |
| // - src: {string} |
| // - poster: {string} |
| // - loop: true | false (default: false) |
| // - muted: true | false (default: false) |
| // events: |
| // - start |
| // - pause |
| // - finish |
| // - fail |
| function Video (data) { |
| var autoPlay = data.attr.autoPlay |
| var playStatus = data.attr.playStatus |
| this.autoPlay = autoPlay === true || autoPlay === 'true' |
| if (playStatus !== 'play' |
| && playStatus !== 'stop' |
| && playStatus !== 'pause') { |
| this.playStatus = 'pause' |
| } else { |
| this.playStatus = playStatus |
| } |
| Atomic.call(this, data) |
| } |
| |
| Video.prototype = Object.create(Atomic.prototype) |
| |
| Video.prototype.attr = { |
| playStatus: function (val) { |
| if (val !== 'play' && val !== 'stop' && val !== 'pause') { |
| val = 'pause' |
| } |
| if (this.playStatus === val) { |
| return |
| } |
| this.playStatus = val |
| this.node.setAttribute('play-status', val) |
| this[this.playStatus]() |
| }, |
| autoPlay: function (val) { |
| // DO NOTHING |
| } |
| } |
| |
| Video.prototype.create = function () { |
| var node = document.createElement('video') |
| node.classList.add('weex-video', 'weex-element') |
| node.controls = true |
| node.autoplay = this.autoPlay |
| node.setAttribute('play-status', this.playStatus) |
| this.node = node |
| if (this.autoPlay && this.playStatus === 'play') { |
| this.play() |
| } |
| return node |
| } |
| |
| Video.prototype.bindEvents = function (evts) { |
| Atomic.prototype.bindEvents.call(this, evts) |
| |
| // convert w3c-video events to weex-video events. |
| var evtsMap = { |
| start: 'play', |
| finish: 'ended', |
| fail: 'error' |
| } |
| for (var evtName in evtsMap) { |
| this.node.addEventListener(evtsMap[evtName], function (type, e) { |
| this.dispatchEvent(type, e.data) |
| }.bind(this, evtName)) |
| } |
| } |
| |
| Video.prototype.play = function () { |
| var src = this.node.getAttribute('src') |
| if (!src) { |
| src = this.node.getAttribute('data-src') |
| src && this.node.setAttribute('src', src) |
| } |
| this.node.play() |
| } |
| |
| Video.prototype.pause = function () { |
| this.node.pause() |
| } |
| |
| Video.prototype.stop = function () { |
| this.node.pause() |
| this.node.autoplay = false |
| this.node.setAttribute('data-src', this.node.src) |
| this.node.src = '' |
| } |
| |
| module.exports = Video |
| |
| |
| /***/ }, |
| /* 59 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| // style-loader: Adds some css to the DOM by adding a <style> tag |
| |
| // load the styles |
| var content = __webpack_require__(60); |
| if(typeof content === 'string') content = [[module.id, content, '']]; |
| // add the styles to the DOM |
| var update = __webpack_require__(4)(content, {}); |
| if(content.locals) module.exports = content.locals; |
| // Hot Module Replacement |
| if(false) { |
| // When the styles change, update the <style> tags |
| if(!content.locals) { |
| module.hot.accept("!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./video.scss", function() { |
| var newContent = require("!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./video.scss"); |
| if(typeof newContent === 'string') newContent = [[module.id, newContent, '']]; |
| update(newContent); |
| }); |
| } |
| // When the module is disposed, remove the <style> tags |
| module.hot.dispose(function() { update(); }); |
| } |
| |
| /***/ }, |
| /* 60 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| exports = module.exports = __webpack_require__(3)(); |
| // imports |
| |
| |
| // module |
| exports.push([module.id, ".weex-video {\n background-color: #000; }\n", "", {"version":3,"sources":["/./src/src/styles/video.scss"],"names":[],"mappings":"AAAA;EACC,uBAAuB,EACvB","file":"video.scss","sourcesContent":[".weex-video {\n\tbackground-color: #000;\n}"],"sourceRoot":"webpack://"}]); |
| |
| // exports |
| |
| |
| /***/ }, |
| /* 61 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| var Atomic = __webpack_require__(27) |
| var utils = __webpack_require__(7) |
| __webpack_require__(62) |
| |
| var defaults = { |
| color: '#64bd63' |
| , secondaryColor: '#dfdfdf' |
| , jackColor: '#fff' |
| , jackSecondaryColor: null |
| , className: 'weex-switch' |
| , disabledOpacity: 0.5 |
| , speed: '0.4s' |
| , width: 100 |
| , height: 60 |
| // is width and height scalable ? |
| , scalable: false |
| } |
| |
| // attrs: |
| // - checked: if is checked. |
| // - disabled: if true, this component is not available for interaction. |
| function Switch (data) { |
| this.options = utils.extend({}, defaults) |
| this.checked = data.attr.checked |
| && data.attr.checked !== 'false' ? true : false |
| this.data = data |
| this.width = this.options.width * data.scale |
| this.height = this.options.height * data.scale |
| Atomic.call(this, data) |
| } |
| |
| Switch.prototype = Object.create(Atomic.prototype) |
| |
| Switch.prototype.create = function () { |
| var node = document.createElement('span') |
| this.jack = document.createElement('small') |
| node.appendChild(this.jack) |
| node.className = this.options.className |
| this.node = node |
| this.attr.disabled.call(this, this.data.attr.disabled) |
| return node |
| } |
| |
| Switch.prototype.onAppend = function () { |
| this.setSize() |
| this.setPosition() |
| } |
| |
| Switch.prototype.attr = { |
| disabled: function (val) { |
| this.disabled = val && val !== 'false' |
| ? true |
| : false |
| this.disabled ? this.disable() : this.enable() |
| } |
| } |
| |
| Switch.prototype.setSize = function () { |
| var min = Math.min(this.width, this.height) |
| var max = Math.max(this.width, this.height) |
| this.node.style.width = max + 'px' |
| this.node.style.height = min + 'px' |
| this.node.style.borderRadius = min / 2 + 'px' |
| this.jack.style.width |
| = this.jack.style.height |
| = min + 'px' |
| } |
| |
| Switch.prototype.setPosition = function (clicked) { |
| var checked = this.checked |
| var node = this.node |
| var jack = this.jack |
| |
| if (clicked && checked) { |
| checked = false |
| } else if (clicked && !checked) { |
| checked = true |
| } |
| |
| if (checked === true) { |
| this.checked = true |
| |
| if (window.getComputedStyle) { |
| jack.style.left = parseInt(window.getComputedStyle(node).width) |
| - parseInt(window.getComputedStyle(jack).width) + 'px' |
| } else { |
| jack.style.left = parseInt(node.currentStyle['width']) |
| - parseInt(jack.currentStyle['width']) + 'px' |
| } |
| |
| this.options.color && this.colorize() |
| this.setSpeed() |
| } else { |
| this.checked = false |
| jack.style.left = 0 |
| node.style.boxShadow = 'inset 0 0 0 0 ' + this.options.secondaryColor |
| node.style.borderColor = this.options.secondaryColor |
| node.style.backgroundColor |
| = (this.options.secondaryColor !== defaults.secondaryColor) |
| ? this.options.secondaryColor |
| : '#fff' |
| jack.style.backgroundColor |
| = (this.options.jackSecondaryColor !== this.options.jackColor) |
| ? this.options.jackSecondaryColor |
| : this.options.jackColor |
| this.setSpeed() |
| } |
| } |
| |
| Switch.prototype.colorize = function () { |
| var nodeHeight = this.node.offsetHeight / 2 |
| |
| this.node.style.backgroundColor = this.options.color |
| this.node.style.borderColor = this.options.color |
| this.node.style.boxShadow = 'inset 0 0 0 ' |
| + nodeHeight |
| + 'px ' |
| + this.options.color |
| this.jack.style.backgroundColor = this.options.jackColor |
| } |
| |
| Switch.prototype.setSpeed = function () { |
| var switcherProp = {} |
| var jackProp = { |
| 'background-color': this.options.speed |
| , left: this.options.speed.replace(/[a-z]/, '') / 2 + 's' |
| } |
| |
| if (this.checked) { |
| switcherProp = { |
| border: this.options.speed |
| , 'box-shadow': this.options.speed |
| , 'background-color': this.options.speed.replace(/[a-z]/, '') * 3 + 's' |
| } |
| } else { |
| switcherProp = { |
| border: this.options.speed |
| , 'box-shadow': this.options.speed |
| } |
| } |
| |
| utils.transitionize(this.node, switcherProp) |
| utils.transitionize(this.jack, jackProp) |
| } |
| |
| Switch.prototype.disable = function () { |
| !this.disabled && (this.disabled = true) |
| this.node.style.opacity = defaults.disabledOpacity |
| this.node.removeEventListener('click', this.getClickHandler()) |
| } |
| |
| Switch.prototype.enable = function () { |
| this.disabled && (this.disabled = false) |
| this.node.style.opacity = 1 |
| this.node.addEventListener('click', this.getClickHandler()) |
| } |
| |
| Switch.prototype.getClickHandler = function () { |
| if (!this._clickHandler) { |
| this._clickHandler = function () { |
| // var parent = this.node.parentNode.tagName.toLowerCase() |
| // var labelParent = (parent === 'label') ? false : true |
| this.setPosition(true) |
| this.dispatchEvent('change', { |
| checked: this.checked |
| }) |
| }.bind(this) |
| } |
| return this._clickHandler |
| } |
| |
| Switch.prototype.style |
| = utils.extend(Object.create(Atomic.prototype.style), { |
| |
| width: function (val) { |
| if (!this.options.scalable) { |
| return |
| } |
| val = parseFloat(val) |
| if (val !== val || val < 0) { // NaN |
| val = this.options.width |
| } |
| this.width = val * this.data.scale |
| this.setSize() |
| }, |
| |
| height: function (val) { |
| if (!this.options.scalable) { |
| return |
| } |
| val = parseFloat(val) |
| if (val !== val || val < 0) { // NaN |
| val = this.options.height |
| } |
| this.height = val * this.data.scale |
| this.setSize() |
| } |
| |
| }) |
| |
| module.exports = Switch |
| |
| |
| /***/ }, |
| /* 62 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| // style-loader: Adds some css to the DOM by adding a <style> tag |
| |
| // load the styles |
| var content = __webpack_require__(63); |
| if(typeof content === 'string') content = [[module.id, content, '']]; |
| // add the styles to the DOM |
| var update = __webpack_require__(4)(content, {}); |
| if(content.locals) module.exports = content.locals; |
| // Hot Module Replacement |
| if(false) { |
| // When the styles change, update the <style> tags |
| if(!content.locals) { |
| module.hot.accept("!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./switch.scss", function() { |
| var newContent = require("!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./switch.scss"); |
| if(typeof newContent === 'string') newContent = [[module.id, newContent, '']]; |
| update(newContent); |
| }); |
| } |
| // When the module is disposed, remove the <style> tags |
| module.hot.dispose(function() { update(); }); |
| } |
| |
| /***/ }, |
| /* 63 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| exports = module.exports = __webpack_require__(3)(); |
| // imports |
| |
| |
| // module |
| exports.push([module.id, "/* switch defaults. */\n.weex-switch {\n background-color: #fff;\n border: 1px solid #dfdfdf;\n cursor: pointer;\n display: inline-block;\n position: relative;\n vertical-align: middle;\n -moz-user-select: none;\n -khtml-user-select: none;\n -webkit-user-select: none;\n -ms-user-select: none;\n user-select: none;\n box-sizing: content-box;\n background-clip: content-box; }\n\n.weex-switch > small {\n background: #fff;\n border-radius: 100%;\n box-shadow: 0 1px 3px rgba(0, 0, 0, 0.4);\n position: absolute;\n top: 0; }\n", "", {"version":3,"sources":["/./src/src/styles/switch.scss"],"names":[],"mappings":"AAAA,sBAAsB;AAEtB;EACE,uBAAuB;EACvB,0BAA0B;EAC1B,gBAAgB;EAChB,sBAAsB;EACtB,mBAAmB;EACnB,uBAAuB;EAEvB,uBAAuB;EACvB,yBAAyB;EACzB,0BAA0B;EAC1B,sBAAsB;EACtB,kBAAkB;EAClB,wBAAwB;EACxB,6BAA6B,EAC9B;;AAED;EACE,iBAAiB;EACjB,oBAAoB;EACpB,yCAA0B;EAC1B,mBAAmB;EACnB,OAAO,EACR","file":"switch.scss","sourcesContent":["/* switch defaults. */\n\n.weex-switch {\n background-color: #fff;\n border: 1px solid #dfdfdf;\n cursor: pointer;\n display: inline-block;\n position: relative;\n vertical-align: middle;\n\n -moz-user-select: none;\n -khtml-user-select: none;\n -webkit-user-select: none;\n -ms-user-select: none;\n user-select: none;\n box-sizing: content-box;\n background-clip: content-box;\n}\n\n.weex-switch > small {\n background: #fff;\n border-radius: 100%;\n box-shadow: 0 1px 3px rgba(0, 0, 0, 0.4);\n position: absolute;\n top: 0;\n}\n"],"sourceRoot":"webpack://"}]); |
| |
| // exports |
| |
| |
| /***/ }, |
| /* 64 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| var Component = __webpack_require__(16) |
| |
| // attrs: |
| // - href |
| function A (data) { |
| Component.call(this, data) |
| } |
| |
| A.prototype = Object.create(Component.prototype) |
| |
| A.prototype.create = function () { |
| var node = document.createElement('a') |
| node.classList.add('weex-container') |
| this.node = node |
| this.style.alignItems.call(this, 'center') |
| this.style.justifyContent.call(this, 'center') |
| this.node.style.textDecoration = 'none' |
| return node |
| } |
| |
| module.exports = A |
| |
| |
| /***/ }, |
| /* 65 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| var Component = __webpack_require__(16) |
| var utils = __webpack_require__(7) |
| |
| var ID_PREFIX = 'weex_embed_' |
| |
| function _generateId() { |
| return ID_PREFIX + utils.getRandom(10) |
| } |
| |
| function Embed (data, nodeType) { |
| var attr = data.attr |
| if (attr) { |
| this.source = attr.src |
| this.loader = attr.loade || 'xhr' |
| } |
| Component.call(this, data, nodeType) |
| this.initWeex() |
| } |
| |
| Embed.prototype = Object.create(Component.prototype) |
| |
| Embed.prototype.create = function () { |
| |
| var node = document.createElement('div') |
| node.id = this.id |
| node.style.overflow = 'scroll' |
| // node.classList.add('weex-container') |
| return node |
| } |
| |
| Embed.prototype.initWeex = function () { |
| this.id = _generateId() |
| this.node.id = this.id |
| var config = { |
| appId: this.id, |
| source: this.source, |
| loader: this.loader, |
| width: this.node.getBoundingClientRect().width, |
| rootId: this.id |
| } |
| window.weex.init(config) |
| } |
| |
| Embed.prototype.destroyWeex = function () { |
| this.id && window.destroyInstance(this.id) |
| // TODO: unbind events and clear doms. |
| this.node.innerHTML = '' |
| } |
| |
| Embed.prototype.reloadWeex = function () { |
| this.destroyWeex() |
| this.initWeex() |
| } |
| |
| // src is not updatable temporarily |
| // Embed.prototype.attr = { |
| // src: function (value) { |
| // this.src = value |
| // this.reloadWeex() |
| // } |
| // } |
| |
| module.exports = Embed |
| |
| |
| /***/ }, |
| /* 66 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| var dom = __webpack_require__(67) |
| var event = __webpack_require__(75) |
| var pageInfo = __webpack_require__(76) |
| var stream = __webpack_require__(77) |
| var modal = __webpack_require__(78) |
| var animation = __webpack_require__(95) |
| |
| var api = { |
| init: function (Weex) { |
| Weex.registerApiModule('dom', dom, dom._meta) |
| Weex.registerApiModule('event', event, event._meta) |
| Weex.registerApiModule('pageInfo', pageInfo, pageInfo._meta) |
| Weex.registerApiModule('stream', stream, stream._meta) |
| Weex.registerApiModule('modal', modal, modal._meta) |
| Weex.registerApiModule('animation', animation, animation._meta) |
| } |
| } |
| |
| module.exports = api |
| |
| /***/ }, |
| /* 67 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| var messageQueue = __webpack_require__(48) |
| var FrameUpdater = __webpack_require__(10) |
| var Component = __webpack_require__(16) |
| var scroll = __webpack_require__(68) |
| var config = __webpack_require__(5) |
| // var Weex = require('../weex') |
| |
| var dom = { |
| |
| /** |
| * createBody: create root component |
| * @param {object} element |
| * container|listview|scrollview |
| * @return {[type]} [description] |
| */ |
| createBody: function (element) { |
| var componentManager = this.getComponentManager() |
| element.scale = this.scale |
| element.instanceId = componentManager.instanceId |
| return componentManager.createBody(element) |
| }, |
| |
| addElement: function (parentRef, element, index) { |
| var componentManager = this.getComponentManager() |
| element.scale = this.scale |
| element.instanceId = componentManager.instanceId |
| return componentManager.addElement(parentRef, element, index) |
| }, |
| |
| removeElement: function (ref) { |
| var componentManager = this.getComponentManager() |
| return componentManager.removeElement(ref) |
| }, |
| |
| moveElement: function (ref, parentRef, index) { |
| var componentManager = this.getComponentManager() |
| return componentManager.moveElement(ref, parentRef, index) |
| }, |
| |
| addEvent: function (ref, type) { |
| var componentManager = this.getComponentManager() |
| return componentManager.addEvent(ref, type) |
| }, |
| |
| removeEvent: function (ref, type) { |
| var componentManager = this.getComponentManager() |
| return componentManager.removeEvent(ref, type) |
| }, |
| |
| /** |
| * updateAttrs: update attributes of component |
| * @param {string} ref |
| * @param {obj} attr |
| */ |
| updateAttrs: function (ref, attr) { |
| var componentManager = this.getComponentManager() |
| return componentManager.updateAttrs(ref, attr) |
| }, |
| |
| /** |
| * updateStyle: udpate style of component |
| * @param {string} ref |
| * @param {obj} style |
| */ |
| updateStyle: function (ref, style) { |
| var componentManager = this.getComponentManager() |
| return componentManager.updateStyle(ref, style) |
| }, |
| |
| createFinish: function () { |
| // TODO |
| // FrameUpdater.pause() |
| }, |
| |
| refreshFinish: function () { |
| // TODO |
| }, |
| |
| /** |
| * scrollToElement |
| * @param {string} ref |
| * @param {obj} options {offset:Number} |
| * ps: scroll-to has 'ease' and 'duration'(ms) as options. |
| */ |
| scrollToElement: function (ref, options) { |
| !options && (options = {}) |
| var componentManager = this.getComponentManager() |
| var elem = componentManager.getElementByRef(ref) |
| if (elem) { |
| var offsetTop = elem.node.getBoundingClientRect().top |
| + document.body.scrollTop |
| var offset = (Number(options.offset) || 0) * this.scale |
| var tween = scroll(0, offsetTop + offset, options) |
| // tween.on('end', function () { |
| // }) |
| } |
| } |
| |
| } |
| |
| dom._meta = { |
| dom: [{ |
| name: 'createBody', |
| args: ['object'] |
| }, { |
| name: 'addElement', |
| args: ['string', 'object', 'number'] |
| }, { |
| name: 'removeElement', |
| args: ['string'] |
| }, { |
| name: 'moveElement', |
| args: ['string', 'string', 'number'] |
| }, { |
| name: 'addEvent', |
| args: ['string', 'string'] |
| }, { |
| name: 'removeEvent', |
| args: ['string', 'string'] |
| }, { |
| name: 'updateAttrs', |
| args: ['string', 'object'] |
| }, { |
| name: 'updateStyle', |
| args: ['string', 'object'] |
| }, { |
| name: 'createFinish', |
| args: [] |
| }, { |
| name: 'refreshFinish', |
| args: [] |
| }, { |
| name: 'scrollToElement', |
| args: ['string', 'object'] |
| }] |
| } |
| |
| module.exports = dom |
| |
| |
| /***/ }, |
| /* 68 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| /** |
| * Module dependencies. |
| */ |
| |
| var Tween = __webpack_require__(69); |
| var raf = __webpack_require__(74); |
| |
| /** |
| * Expose `scrollTo`. |
| */ |
| |
| module.exports = scrollTo; |
| |
| /** |
| * Scroll to `(x, y)`. |
| * |
| * @param {Number} x |
| * @param {Number} y |
| * @api public |
| */ |
| |
| function scrollTo(x, y, options) { |
| options = options || {}; |
| |
| // start position |
| var start = scroll(); |
| |
| // setup tween |
| var tween = Tween(start) |
| .ease(options.ease || 'out-circ') |
| .to({ top: y, left: x }) |
| .duration(options.duration || 1000); |
| |
| // scroll |
| tween.update(function(o){ |
| window.scrollTo(o.left | 0, o.top | 0); |
| }); |
| |
| // handle end |
| tween.on('end', function(){ |
| animate = function(){}; |
| }); |
| |
| // animate |
| function animate() { |
| raf(animate); |
| tween.update(); |
| } |
| |
| animate(); |
| |
| return tween; |
| } |
| |
| /** |
| * Return scroll position. |
| * |
| * @return {Object} |
| * @api private |
| */ |
| |
| function scroll() { |
| var y = window.pageYOffset || document.documentElement.scrollTop; |
| var x = window.pageXOffset || document.documentElement.scrollLeft; |
| return { top: y, left: x }; |
| } |
| |
| |
| /***/ }, |
| /* 69 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| |
| /** |
| * Module dependencies. |
| */ |
| |
| var Emitter = __webpack_require__(70); |
| var clone = __webpack_require__(71); |
| var type = __webpack_require__(72); |
| var ease = __webpack_require__(73); |
| |
| /** |
| * Expose `Tween`. |
| */ |
| |
| module.exports = Tween; |
| |
| /** |
| * Initialize a new `Tween` with `obj`. |
| * |
| * @param {Object|Array} obj |
| * @api public |
| */ |
| |
| function Tween(obj) { |
| if (!(this instanceof Tween)) return new Tween(obj); |
| this._from = obj; |
| this.ease('linear'); |
| this.duration(500); |
| } |
| |
| /** |
| * Mixin emitter. |
| */ |
| |
| Emitter(Tween.prototype); |
| |
| /** |
| * Reset the tween. |
| * |
| * @api public |
| */ |
| |
| Tween.prototype.reset = function(){ |
| this.isArray = 'array' === type(this._from); |
| this._curr = clone(this._from); |
| this._done = false; |
| this._start = Date.now(); |
| return this; |
| }; |
| |
| /** |
| * Tween to `obj` and reset internal state. |
| * |
| * tween.to({ x: 50, y: 100 }) |
| * |
| * @param {Object|Array} obj |
| * @return {Tween} self |
| * @api public |
| */ |
| |
| Tween.prototype.to = function(obj){ |
| this.reset(); |
| this._to = obj; |
| return this; |
| }; |
| |
| /** |
| * Set duration to `ms` [500]. |
| * |
| * @param {Number} ms |
| * @return {Tween} self |
| * @api public |
| */ |
| |
| Tween.prototype.duration = function(ms){ |
| this._duration = ms; |
| return this; |
| }; |
| |
| /** |
| * Set easing function to `fn`. |
| * |
| * tween.ease('in-out-sine') |
| * |
| * @param {String|Function} fn |
| * @return {Tween} |
| * @api public |
| */ |
| |
| Tween.prototype.ease = function(fn){ |
| fn = 'function' == typeof fn ? fn : ease[fn]; |
| if (!fn) throw new TypeError('invalid easing function'); |
| this._ease = fn; |
| return this; |
| }; |
| |
| /** |
| * Stop the tween and immediately emit "stop" and "end". |
| * |
| * @return {Tween} |
| * @api public |
| */ |
| |
| Tween.prototype.stop = function(){ |
| this.stopped = true; |
| this._done = true; |
| this.emit('stop'); |
| this.emit('end'); |
| return this; |
| }; |
| |
| /** |
| * Perform a step. |
| * |
| * @return {Tween} self |
| * @api private |
| */ |
| |
| Tween.prototype.step = function(){ |
| if (this._done) return; |
| |
| // duration |
| var duration = this._duration; |
| var now = Date.now(); |
| var delta = now - this._start; |
| var done = delta >= duration; |
| |
| // complete |
| if (done) { |
| this._from = this._to; |
| this._update(this._to); |
| this._done = true; |
| this.emit('end'); |
| return this; |
| } |
| |
| // tween |
| var from = this._from; |
| var to = this._to; |
| var curr = this._curr; |
| var fn = this._ease; |
| var p = (now - this._start) / duration; |
| var n = fn(p); |
| |
| // array |
| if (this.isArray) { |
| for (var i = 0; i < from.length; ++i) { |
| curr[i] = from[i] + (to[i] - from[i]) * n; |
| } |
| |
| this._update(curr); |
| return this; |
| } |
| |
| // objech |
| for (var k in from) { |
| curr[k] = from[k] + (to[k] - from[k]) * n; |
| } |
| |
| this._update(curr); |
| return this; |
| }; |
| |
| /** |
| * Set update function to `fn` or |
| * when no argument is given this performs |
| * a "step". |
| * |
| * @param {Function} fn |
| * @return {Tween} self |
| * @api public |
| */ |
| |
| Tween.prototype.update = function(fn){ |
| if (0 == arguments.length) return this.step(); |
| this._update = fn; |
| return this; |
| }; |
| |
| /***/ }, |
| /* 70 */ |
| /***/ function(module, exports) { |
| |
| |
| /** |
| * Expose `Emitter`. |
| */ |
| |
| module.exports = Emitter; |
| |
| /** |
| * Initialize a new `Emitter`. |
| * |
| * @api public |
| */ |
| |
| function Emitter(obj) { |
| if (obj) return mixin(obj); |
| }; |
| |
| /** |
| * Mixin the emitter properties. |
| * |
| * @param {Object} obj |
| * @return {Object} |
| * @api private |
| */ |
| |
| function mixin(obj) { |
| for (var key in Emitter.prototype) { |
| obj[key] = Emitter.prototype[key]; |
| } |
| return obj; |
| } |
| |
| /** |
| * Listen on the given `event` with `fn`. |
| * |
| * @param {String} event |
| * @param {Function} fn |
| * @return {Emitter} |
| * @api public |
| */ |
| |
| Emitter.prototype.on = |
| Emitter.prototype.addEventListener = function(event, fn){ |
| this._callbacks = this._callbacks || {}; |
| (this._callbacks['$' + event] = this._callbacks['$' + event] || []) |
| .push(fn); |
| return this; |
| }; |
| |
| /** |
| * Adds an `event` listener that will be invoked a single |
| * time then automatically removed. |
| * |
| * @param {String} event |
| * @param {Function} fn |
| * @return {Emitter} |
| * @api public |
| */ |
| |
| Emitter.prototype.once = function(event, fn){ |
| function on() { |
| this.off(event, on); |
| fn.apply(this, arguments); |
| } |
| |
| on.fn = fn; |
| this.on(event, on); |
| return this; |
| }; |
| |
| /** |
| * Remove the given callback for `event` or all |
| * registered callbacks. |
| * |
| * @param {String} event |
| * @param {Function} fn |
| * @return {Emitter} |
| * @api public |
| */ |
| |
| Emitter.prototype.off = |
| Emitter.prototype.removeListener = |
| Emitter.prototype.removeAllListeners = |
| Emitter.prototype.removeEventListener = function(event, fn){ |
| this._callbacks = this._callbacks || {}; |
| |
| // all |
| if (0 == arguments.length) { |
| this._callbacks = {}; |
| return this; |
| } |
| |
| // specific event |
| var callbacks = this._callbacks['$' + event]; |
| if (!callbacks) return this; |
| |
| // remove all handlers |
| if (1 == arguments.length) { |
| delete this._callbacks['$' + event]; |
| return this; |
| } |
| |
| // remove specific handler |
| var cb; |
| for (var i = 0; i < callbacks.length; i++) { |
| cb = callbacks[i]; |
| if (cb === fn || cb.fn === fn) { |
| callbacks.splice(i, 1); |
| break; |
| } |
| } |
| return this; |
| }; |
| |
| /** |
| * Emit `event` with the given args. |
| * |
| * @param {String} event |
| * @param {Mixed} ... |
| * @return {Emitter} |
| */ |
| |
| Emitter.prototype.emit = function(event){ |
| this._callbacks = this._callbacks || {}; |
| var args = [].slice.call(arguments, 1) |
| , callbacks = this._callbacks['$' + event]; |
| |
| if (callbacks) { |
| callbacks = callbacks.slice(0); |
| for (var i = 0, len = callbacks.length; i < len; ++i) { |
| callbacks[i].apply(this, args); |
| } |
| } |
| |
| return this; |
| }; |
| |
| /** |
| * Return array of callbacks for `event`. |
| * |
| * @param {String} event |
| * @return {Array} |
| * @api public |
| */ |
| |
| Emitter.prototype.listeners = function(event){ |
| this._callbacks = this._callbacks || {}; |
| return this._callbacks['$' + event] || []; |
| }; |
| |
| /** |
| * Check if this emitter has `event` handlers. |
| * |
| * @param {String} event |
| * @return {Boolean} |
| * @api public |
| */ |
| |
| Emitter.prototype.hasListeners = function(event){ |
| return !! this.listeners(event).length; |
| }; |
| |
| |
| /***/ }, |
| /* 71 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| /** |
| * Module dependencies. |
| */ |
| |
| var type; |
| try { |
| type = __webpack_require__(72); |
| } catch (_) { |
| type = __webpack_require__(72); |
| } |
| |
| /** |
| * Module exports. |
| */ |
| |
| module.exports = clone; |
| |
| /** |
| * Clones objects. |
| * |
| * @param {Mixed} any object |
| * @api public |
| */ |
| |
| function clone(obj){ |
| switch (type(obj)) { |
| case 'object': |
| var copy = {}; |
| for (var key in obj) { |
| if (obj.hasOwnProperty(key)) { |
| copy[key] = clone(obj[key]); |
| } |
| } |
| return copy; |
| |
| case 'array': |
| var copy = new Array(obj.length); |
| for (var i = 0, l = obj.length; i < l; i++) { |
| copy[i] = clone(obj[i]); |
| } |
| return copy; |
| |
| case 'regexp': |
| // from millermedeiros/amd-utils - MIT |
| var flags = ''; |
| flags += obj.multiline ? 'm' : ''; |
| flags += obj.global ? 'g' : ''; |
| flags += obj.ignoreCase ? 'i' : ''; |
| return new RegExp(obj.source, flags); |
| |
| case 'date': |
| return new Date(obj.getTime()); |
| |
| default: // string, number, boolean, … |
| return obj; |
| } |
| } |
| |
| |
| /***/ }, |
| /* 72 */ |
| /***/ function(module, exports) { |
| |
| /** |
| * toString ref. |
| */ |
| |
| var toString = Object.prototype.toString; |
| |
| /** |
| * Return the type of `val`. |
| * |
| * @param {Mixed} val |
| * @return {String} |
| * @api public |
| */ |
| |
| module.exports = function(val){ |
| switch (toString.call(val)) { |
| case '[object Date]': return 'date'; |
| case '[object RegExp]': return 'regexp'; |
| case '[object Arguments]': return 'arguments'; |
| case '[object Array]': return 'array'; |
| case '[object Error]': return 'error'; |
| } |
| |
| if (val === null) return 'null'; |
| if (val === undefined) return 'undefined'; |
| if (val !== val) return 'nan'; |
| if (val && val.nodeType === 1) return 'element'; |
| |
| val = val.valueOf |
| ? val.valueOf() |
| : Object.prototype.valueOf.apply(val) |
| |
| return typeof val; |
| }; |
| |
| |
| /***/ }, |
| /* 73 */ |
| /***/ function(module, exports) { |
| |
| |
| // easing functions from "Tween.js" |
| |
| exports.linear = function(n){ |
| return n; |
| }; |
| |
| exports.inQuad = function(n){ |
| return n * n; |
| }; |
| |
| exports.outQuad = function(n){ |
| return n * (2 - n); |
| }; |
| |
| exports.inOutQuad = function(n){ |
| n *= 2; |
| if (n < 1) return 0.5 * n * n; |
| return - 0.5 * (--n * (n - 2) - 1); |
| }; |
| |
| exports.inCube = function(n){ |
| return n * n * n; |
| }; |
| |
| exports.outCube = function(n){ |
| return --n * n * n + 1; |
| }; |
| |
| exports.inOutCube = function(n){ |
| n *= 2; |
| if (n < 1) return 0.5 * n * n * n; |
| return 0.5 * ((n -= 2 ) * n * n + 2); |
| }; |
| |
| exports.inQuart = function(n){ |
| return n * n * n * n; |
| }; |
| |
| exports.outQuart = function(n){ |
| return 1 - (--n * n * n * n); |
| }; |
| |
| exports.inOutQuart = function(n){ |
| n *= 2; |
| if (n < 1) return 0.5 * n * n * n * n; |
| return -0.5 * ((n -= 2) * n * n * n - 2); |
| }; |
| |
| exports.inQuint = function(n){ |
| return n * n * n * n * n; |
| } |
| |
| exports.outQuint = function(n){ |
| return --n * n * n * n * n + 1; |
| } |
| |
| exports.inOutQuint = function(n){ |
| n *= 2; |
| if (n < 1) return 0.5 * n * n * n * n * n; |
| return 0.5 * ((n -= 2) * n * n * n * n + 2); |
| }; |
| |
| exports.inSine = function(n){ |
| return 1 - Math.cos(n * Math.PI / 2 ); |
| }; |
| |
| exports.outSine = function(n){ |
| return Math.sin(n * Math.PI / 2); |
| }; |
| |
| exports.inOutSine = function(n){ |
| return .5 * (1 - Math.cos(Math.PI * n)); |
| }; |
| |
| exports.inExpo = function(n){ |
| return 0 == n ? 0 : Math.pow(1024, n - 1); |
| }; |
| |
| exports.outExpo = function(n){ |
| return 1 == n ? n : 1 - Math.pow(2, -10 * n); |
| }; |
| |
| exports.inOutExpo = function(n){ |
| if (0 == n) return 0; |
| if (1 == n) return 1; |
| if ((n *= 2) < 1) return .5 * Math.pow(1024, n - 1); |
| return .5 * (-Math.pow(2, -10 * (n - 1)) + 2); |
| }; |
| |
| exports.inCirc = function(n){ |
| return 1 - Math.sqrt(1 - n * n); |
| }; |
| |
| exports.outCirc = function(n){ |
| return Math.sqrt(1 - (--n * n)); |
| }; |
| |
| exports.inOutCirc = function(n){ |
| n *= 2 |
| if (n < 1) return -0.5 * (Math.sqrt(1 - n * n) - 1); |
| return 0.5 * (Math.sqrt(1 - (n -= 2) * n) + 1); |
| }; |
| |
| exports.inBack = function(n){ |
| var s = 1.70158; |
| return n * n * (( s + 1 ) * n - s); |
| }; |
| |
| exports.outBack = function(n){ |
| var s = 1.70158; |
| return --n * n * ((s + 1) * n + s) + 1; |
| }; |
| |
| exports.inOutBack = function(n){ |
| var s = 1.70158 * 1.525; |
| if ( ( n *= 2 ) < 1 ) return 0.5 * ( n * n * ( ( s + 1 ) * n - s ) ); |
| return 0.5 * ( ( n -= 2 ) * n * ( ( s + 1 ) * n + s ) + 2 ); |
| }; |
| |
| exports.inBounce = function(n){ |
| return 1 - exports.outBounce(1 - n); |
| }; |
| |
| exports.outBounce = function(n){ |
| if ( n < ( 1 / 2.75 ) ) { |
| return 7.5625 * n * n; |
| } else if ( n < ( 2 / 2.75 ) ) { |
| return 7.5625 * ( n -= ( 1.5 / 2.75 ) ) * n + 0.75; |
| } else if ( n < ( 2.5 / 2.75 ) ) { |
| return 7.5625 * ( n -= ( 2.25 / 2.75 ) ) * n + 0.9375; |
| } else { |
| return 7.5625 * ( n -= ( 2.625 / 2.75 ) ) * n + 0.984375; |
| } |
| }; |
| |
| exports.inOutBounce = function(n){ |
| if (n < .5) return exports.inBounce(n * 2) * .5; |
| return exports.outBounce(n * 2 - 1) * .5 + .5; |
| }; |
| |
| // aliases |
| |
| exports['in-quad'] = exports.inQuad; |
| exports['out-quad'] = exports.outQuad; |
| exports['in-out-quad'] = exports.inOutQuad; |
| exports['in-cube'] = exports.inCube; |
| exports['out-cube'] = exports.outCube; |
| exports['in-out-cube'] = exports.inOutCube; |
| exports['in-quart'] = exports.inQuart; |
| exports['out-quart'] = exports.outQuart; |
| exports['in-out-quart'] = exports.inOutQuart; |
| exports['in-quint'] = exports.inQuint; |
| exports['out-quint'] = exports.outQuint; |
| exports['in-out-quint'] = exports.inOutQuint; |
| exports['in-sine'] = exports.inSine; |
| exports['out-sine'] = exports.outSine; |
| exports['in-out-sine'] = exports.inOutSine; |
| exports['in-expo'] = exports.inExpo; |
| exports['out-expo'] = exports.outExpo; |
| exports['in-out-expo'] = exports.inOutExpo; |
| exports['in-circ'] = exports.inCirc; |
| exports['out-circ'] = exports.outCirc; |
| exports['in-out-circ'] = exports.inOutCirc; |
| exports['in-back'] = exports.inBack; |
| exports['out-back'] = exports.outBack; |
| exports['in-out-back'] = exports.inOutBack; |
| exports['in-bounce'] = exports.inBounce; |
| exports['out-bounce'] = exports.outBounce; |
| exports['in-out-bounce'] = exports.inOutBounce; |
| |
| |
| /***/ }, |
| /* 74 */ |
| /***/ function(module, exports) { |
| |
| /** |
| * Expose `requestAnimationFrame()`. |
| */ |
| |
| exports = module.exports = window.requestAnimationFrame |
| || window.webkitRequestAnimationFrame |
| || window.mozRequestAnimationFrame |
| || fallback; |
| |
| /** |
| * Fallback implementation. |
| */ |
| |
| var prev = new Date().getTime(); |
| function fallback(fn) { |
| var curr = new Date().getTime(); |
| var ms = Math.max(0, 16 - (curr - prev)); |
| var req = setTimeout(fn, ms); |
| prev = curr; |
| return req; |
| } |
| |
| /** |
| * Cancel. |
| */ |
| |
| var cancel = window.cancelAnimationFrame |
| || window.webkitCancelAnimationFrame |
| || window.mozCancelAnimationFrame |
| || window.clearTimeout; |
| |
| exports.cancel = function(id){ |
| cancel.call(window, id); |
| }; |
| |
| |
| /***/ }, |
| /* 75 */ |
| /***/ function(module, exports) { |
| |
| 'use strict' |
| |
| var event = { |
| /** |
| * openUrl |
| * @param {string} url |
| */ |
| openURL: function (url) { |
| location.href = url |
| } |
| |
| } |
| |
| event._meta = { |
| event: [{ |
| name: 'openURL', |
| args: ['string'] |
| }] |
| } |
| |
| module.exports = event |
| |
| /***/ }, |
| /* 76 */ |
| /***/ function(module, exports) { |
| |
| 'use strict' |
| |
| var pageInfo = { |
| |
| setTitle: function (title) { |
| title = title || 'Weex HTML5' |
| try { |
| title = decodeURIComponent(title) |
| } catch (e) {} |
| document.title = title |
| } |
| } |
| |
| pageInfo._meta = { |
| pageInfo: [{ |
| name: 'setTitle', |
| args: ['string'] |
| }] |
| } |
| |
| module.exports = pageInfo |
| |
| /***/ }, |
| /* 77 */ |
| /***/ function(module, exports) { |
| |
| 'use strict' |
| |
| // require('httpurl') |
| |
| // var jsonpCnt = 0 |
| |
| // function _sendJsonp(config, callbackId) { |
| // var cbName = '_callback_' + (++jsonpCnt) |
| // var script, url, head |
| // global[cbName] = (function (cb) { |
| // return function (response) { |
| // this.sender.performCallback(callbackId, response) |
| // delete global[cb] |
| // } |
| // })(cbName) |
| // script = document.createElement('script') |
| // url = lib.httpurl(config.url) |
| // url.params.callback = cbName |
| // script.type = 'text/javascript' |
| // script.src = url.toString() |
| // // script.onerror is not working on IE or safari. |
| // // but they are not considered here. |
| // script.onerror = (function (cb) { |
| // return function (err) { |
| // this.sender.performCallback(callbackId, err) |
| // delete global[cb] |
| // } |
| // })(cbName) |
| // head = document.getElementsByTagName('head')[0] |
| // head.insertBefore(script, null) |
| // } |
| |
| var stream = { |
| |
| /** |
| * sendHttp |
| * @param {obj} params |
| * - method: 'GET' | 'POST', |
| * - url: url requested |
| * @param {string} callbackId |
| */ |
| sendHttp: function (param, callbackId) { |
| if (typeof param === 'string') { |
| try { |
| param = JSON.parse(param) |
| } catch (e) { |
| return |
| } |
| } |
| if (typeof param !== 'object' || !param.url) { |
| return |
| } |
| |
| // Not to use jsonp to send http request since it requires the server |
| // to support jsonp callback at the first place. |
| // _sendJsonp.call(this, param, callbackId) |
| |
| var self = this |
| var method = param.method || 'GET' |
| var xhr = new XMLHttpRequest() |
| xhr.open(method, param.url, true) |
| xhr.onload = function () { |
| self.sender.performCallback(callbackId, this.responseText) |
| } |
| xhr.onerror = function (error) { |
| self.sender.performCallback(callbackId, error) |
| } |
| xhr.send() |
| } |
| |
| } |
| |
| stream._meta = { |
| stream: [{ |
| name: 'sendHttp', |
| args: ['object', 'string'] |
| }] |
| } |
| |
| module.exports = stream |
| |
| /***/ }, |
| /* 78 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| var sender = __webpack_require__(19) |
| var modal = __webpack_require__(79) |
| |
| var msg = { |
| |
| // duration: default is 0.8 seconds. |
| toast: function (config) { |
| modal.toast(config.message, config.duration) |
| }, |
| |
| // config: |
| // - message: string |
| // - okTitle: title of ok button |
| // - callback |
| alert: function (config, callbackId) { |
| var sender = this.sender |
| config.callback = function () { |
| sender.performCallback(callbackId) |
| } |
| modal.alert(config) |
| }, |
| |
| // config: |
| // - message: string |
| // - okTitle: title of ok button |
| // - cancelTitle: title of cancel button |
| // - callback |
| confirm: function (config, callbackId) { |
| var sender = this.sender |
| config.callback = function (val) { |
| sender.performCallback(callbackId, val) |
| } |
| modal.confirm(config) |
| }, |
| |
| // config: |
| // - message: string |
| // - okTitle: title of ok button |
| // - cancelTitle: title of cancel button |
| // - callback |
| prompt: function (config, callbackId) { |
| var sender = this.sender |
| config.callback = function (val) { |
| sender.performCallback(callbackId, val) |
| } |
| modal.prompt(config) |
| } |
| |
| } |
| |
| msg._meta = { |
| modal: [{ |
| name: 'toast', |
| args: ['object'] |
| }, { |
| name: 'alert', |
| args: ['object', 'string'] |
| }, { |
| name: 'confirm', |
| args: ['object', 'string'] |
| }, { |
| name: 'prompt', |
| args: ['object', 'string'] |
| }] |
| } |
| |
| module.exports = msg |
| |
| |
| /***/ }, |
| /* 79 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| var Alert = __webpack_require__(80) |
| var Confirm = __webpack_require__(86) |
| var Prompt = __webpack_require__(89) |
| var toast = __webpack_require__(92) |
| |
| var modal = { |
| |
| toast: function (msg, duration) { |
| toast.push(msg, duration) |
| }, |
| |
| alert: function (config) { |
| new Alert(config).show() |
| }, |
| |
| prompt: function (config) { |
| new Prompt(config).show() |
| }, |
| |
| confirm: function (config) { |
| new Confirm(config).show() |
| } |
| |
| } |
| |
| !window.lib && (window.lib = {}) |
| window.lib.modal = modal |
| |
| module.exports = modal |
| |
| /***/ }, |
| /* 80 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| var Modal = __webpack_require__(81) |
| __webpack_require__(84) |
| |
| var CONTENT_CLASS = 'content' |
| var MSG_CLASS = 'content-msg' |
| var BUTTON_GROUP_CLASS = 'btn-group' |
| var BUTTON_CLASS = 'btn' |
| |
| function Alert(config) { |
| this.msg = config.message || '' |
| this.callback = config.callback |
| this.okTitle = config.okTitle || 'OK' |
| Modal.call(this) |
| this.node.classList.add('amfe-alert') |
| } |
| |
| Alert.prototype = Object.create(Modal.prototype) |
| |
| Alert.prototype.createNodeContent = function () { |
| var content = document.createElement('div') |
| content.classList.add(CONTENT_CLASS) |
| this.node.appendChild(content) |
| |
| var msg = document.createElement('div') |
| msg.classList.add(MSG_CLASS) |
| msg.appendChild(document.createTextNode(this.msg)) |
| content.appendChild(msg) |
| |
| var buttonGroup = document.createElement('div') |
| buttonGroup.classList.add(BUTTON_GROUP_CLASS) |
| this.node.appendChild(buttonGroup) |
| var button = document.createElement('div') |
| button.classList.add(BUTTON_CLASS, 'alert-ok') |
| button.appendChild(document.createTextNode(this.okTitle)) |
| buttonGroup.appendChild(button) |
| } |
| |
| Alert.prototype.bindEvents = function () { |
| Modal.prototype.bindEvents.call(this) |
| var button = this.node.querySelector('.' + BUTTON_CLASS) |
| button.addEventListener('click', function () { |
| this.destroy() |
| this.callback && this.callback() |
| }.bind(this)) |
| } |
| |
| module.exports = Alert |
| |
| |
| /***/ }, |
| /* 81 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| __webpack_require__(82) |
| |
| // there will be only one instance of modal. |
| var MODAL_WRAP_CLASS = 'amfe-modal-wrap' |
| var MODAL_NODE_CLASS = 'amfe-modal-node' |
| |
| function Modal() { |
| this.wrap = document.querySelector(MODAL_WRAP_CLASS) |
| this.node = document.querySelector(MODAL_NODE_CLASS) |
| if (!this.wrap) { |
| this.createWrap() |
| } |
| if (!this.node) { |
| this.createNode() |
| } |
| this.clearNode() |
| this.createNodeContent() |
| this.bindEvents() |
| } |
| |
| Modal.prototype = { |
| |
| show: function () { |
| this.wrap.style.display = 'block' |
| this.node.classList.remove('hide') |
| }, |
| |
| destroy: function () { |
| document.body.removeChild(this.wrap) |
| document.body.removeChild(this.node) |
| this.wrap = null |
| this.node = null |
| }, |
| |
| createWrap: function () { |
| this.wrap = document.createElement('div') |
| this.wrap.className = MODAL_WRAP_CLASS |
| document.body.appendChild(this.wrap) |
| }, |
| |
| createNode: function () { |
| this.node = document.createElement('div') |
| this.node.classList.add(MODAL_NODE_CLASS, 'hide') |
| document.body.appendChild(this.node) |
| }, |
| |
| clearNode: function () { |
| this.node.innerHTML = '' |
| }, |
| |
| createNodeContent: function () { |
| |
| // do nothing. |
| // child classes can override this method. |
| }, |
| |
| bindEvents: function () { |
| this.wrap.addEventListener('click', function (e) { |
| e.preventDefault() |
| e.stopPropagation() |
| }) |
| } |
| } |
| |
| module.exports = Modal |
| |
| |
| /***/ }, |
| /* 82 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| // style-loader: Adds some css to the DOM by adding a <style> tag |
| |
| // load the styles |
| var content = __webpack_require__(83); |
| if(typeof content === 'string') content = [[module.id, content, '']]; |
| // add the styles to the DOM |
| var update = __webpack_require__(4)(content, {}); |
| if(content.locals) module.exports = content.locals; |
| // Hot Module Replacement |
| if(false) { |
| // When the styles change, update the <style> tags |
| if(!content.locals) { |
| module.hot.accept("!!./../../css-loader/index.js?sourceMap!./../../sass-loader/index.js?sourceMap!./modal.scss", function() { |
| var newContent = require("!!./../../css-loader/index.js?sourceMap!./../../sass-loader/index.js?sourceMap!./modal.scss"); |
| if(typeof newContent === 'string') newContent = [[module.id, newContent, '']]; |
| update(newContent); |
| }); |
| } |
| // When the module is disposed, remove the <style> tags |
| module.hot.dispose(function() { update(); }); |
| } |
| |
| /***/ }, |
| /* 83 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| exports = module.exports = __webpack_require__(3)(); |
| // imports |
| |
| |
| // module |
| exports.push([module.id, ".amfe-modal-wrap {\n display: none;\n position: fixed;\n z-index: 999999999;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n background-color: #000;\n opacity: 0.5; }\n\n.amfe-modal-node {\n position: fixed;\n z-index: 9999999999;\n top: 50%;\n left: 50%;\n width: 6.666667rem;\n min-height: 2.666667rem;\n border-radius: 0.066667rem;\n -webkit-transform: translate(-50%, -50%);\n transform: translate(-50%, -50%);\n background-color: #fff; }\n .amfe-modal-node.hide {\n display: none; }\n .amfe-modal-node .content {\n width: 100%;\n min-height: 1.866667rem;\n box-sizing: border-box;\n font-size: 0.32rem;\n line-height: 0.426667rem;\n padding: 0.213333rem;\n border-bottom: 1px solid #ddd; }\n .amfe-modal-node .btn-group {\n width: 100%;\n height: 0.8rem;\n font-size: 0.373333rem;\n text-align: center; }\n .amfe-modal-node .btn-group .btn {\n box-sizing: border-box;\n height: 0.8rem;\n line-height: 0.8rem; }\n", "", {"version":3,"sources":["/./node_modules/modals/node_modules/modals/styles/modal.scss"],"names":[],"mappings":"AAAA;EACE,cAAc;EACd,gBAAgB;EAChB,mBAAmB;EACnB,OAAO;EACP,QAAQ;EACR,YAAY;EACZ,aAAa;EACb,uBAAuB;EACvB,aAAa,EAEd;;AAED;EACE,gBAAgB;EAChB,oBAAoB;EACpB,SAAS;EACT,UAAU;EACV,mBAAmB;EACnB,wBAAwB;EACxB,2BAA2B;EAC3B,yCAA4B;EAC5B,iCAAoB;EACpB,uBAAuB,EA4BxB;EAtCD;IAaI,cACD,EAAC;EAdJ;IAiBI,YAAY;IACZ,wBAAwB;IACxB,uBAAuB;IACvB,mBAAmB;IACnB,yBAAyB;IACzB,qBAAqB;IACrB,8BAA8B,EAC/B;EAxBH;IA2BI,YAAY;IACZ,eAAe;IACf,uBAAuB;IACvB,mBAAmB,EAOpB;IArCH;MAiCM,uBAAuB;MACvB,eAAe;MACf,oBAAoB,EACrB","file":"modal.scss","sourcesContent":[".amfe-modal-wrap {\n display: none;\n position: fixed;\n z-index: 999999999;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n background-color: #000;\n opacity: 0.5;\n\n}\n\n.amfe-modal-node {\n position: fixed;\n z-index: 9999999999;\n top: 50%;\n left: 50%;\n width: 6.666667rem; // 500px\n min-height: 2.666667rem; // 200px\n border-radius: 0.066667rem; // 5px\n -webkit-transform: translate(-50%, -50%);\n transform: translate(-50%, -50%);\n background-color: #fff;\n\n &.hide {\n display: none\n }\n\n .content {\n width: 100%;\n min-height: 1.866667rem; // 140px\n box-sizing: border-box;\n font-size: 0.32rem; // 24px\n line-height: 0.426667rem; // 32px\n padding: 0.213333rem; // 16px\n border-bottom: 1px solid #ddd;\n }\n\n .btn-group {\n width: 100%;\n height: 0.8rem; // 60px\n font-size: 0.373333rem; // 28px\n text-align: center;\n\n .btn {\n box-sizing: border-box;\n height: 0.8rem; // 60px\n line-height: 0.8rem; // 60px\n }\n }\n}\n"],"sourceRoot":"webpack://"}]); |
| |
| // exports |
| |
| |
| /***/ }, |
| /* 84 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| // style-loader: Adds some css to the DOM by adding a <style> tag |
| |
| // load the styles |
| var content = __webpack_require__(85); |
| if(typeof content === 'string') content = [[module.id, content, '']]; |
| // add the styles to the DOM |
| var update = __webpack_require__(4)(content, {}); |
| if(content.locals) module.exports = content.locals; |
| // Hot Module Replacement |
| if(false) { |
| // When the styles change, update the <style> tags |
| if(!content.locals) { |
| module.hot.accept("!!./../../css-loader/index.js?sourceMap!./../../sass-loader/index.js?sourceMap!./alert.scss", function() { |
| var newContent = require("!!./../../css-loader/index.js?sourceMap!./../../sass-loader/index.js?sourceMap!./alert.scss"); |
| if(typeof newContent === 'string') newContent = [[module.id, newContent, '']]; |
| update(newContent); |
| }); |
| } |
| // When the module is disposed, remove the <style> tags |
| module.hot.dispose(function() { update(); }); |
| } |
| |
| /***/ }, |
| /* 85 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| exports = module.exports = __webpack_require__(3)(); |
| // imports |
| |
| |
| // module |
| exports.push([module.id, ".amfe-alert .amfe-alert-ok {\n width: 100%; }\n", "", {"version":3,"sources":["/./node_modules/modals/node_modules/modals/styles/alert.scss"],"names":[],"mappings":"AAAA;EAGI,YAAY,EACb","file":"alert.scss","sourcesContent":[".amfe-alert {\n\n .amfe-alert-ok {\n width: 100%;\n }\n}\n"],"sourceRoot":"webpack://"}]); |
| |
| // exports |
| |
| |
| /***/ }, |
| /* 86 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| var Modal = __webpack_require__(81) |
| __webpack_require__(87) |
| |
| var CONTENT_CLASS = 'content' |
| var MSG_CLASS = 'content-msg' |
| var BUTTON_GROUP_CLASS = 'btn-group' |
| var BUTTON_CLASS = 'btn' |
| |
| function Confirm(config) { |
| this.msg = config.message || '' |
| this.callback = config.callback |
| this.okTitle = config.okTitle || 'OK' |
| this.cancelTitle = config.cancelTitle || 'Cancel' |
| Modal.call(this) |
| this.node.classList.add('amfe-confirm') |
| } |
| |
| Confirm.prototype = Object.create(Modal.prototype) |
| |
| Confirm.prototype.createNodeContent = function () { |
| var content = document.createElement('div') |
| content.classList.add(CONTENT_CLASS) |
| this.node.appendChild(content) |
| |
| var msg = document.createElement('div') |
| msg.classList.add(MSG_CLASS) |
| msg.appendChild(document.createTextNode(this.msg)) |
| content.appendChild(msg) |
| |
| var buttonGroup = document.createElement('div') |
| buttonGroup.classList.add(BUTTON_GROUP_CLASS) |
| this.node.appendChild(buttonGroup) |
| var btnOk = document.createElement('div') |
| btnOk.appendChild(document.createTextNode(this.okTitle)) |
| btnOk.classList.add('btn-ok', BUTTON_CLASS) |
| var btnCancel = document.createElement('div') |
| btnCancel.appendChild(document.createTextNode(this.cancelTitle)) |
| btnCancel.classList.add('btn-cancel', BUTTON_CLASS) |
| buttonGroup.appendChild(btnOk) |
| buttonGroup.appendChild(btnCancel) |
| this.node.appendChild(buttonGroup) |
| } |
| |
| Confirm.prototype.bindEvents = function () { |
| Modal.prototype.bindEvents.call(this) |
| var btnOk = this.node.querySelector('.' + BUTTON_CLASS + '.btn-ok') |
| var btnCancel = this.node.querySelector('.' + BUTTON_CLASS + '.btn-cancel') |
| btnOk.addEventListener('click', function () { |
| this.destroy() |
| this.callback && this.callback(this.okTitle) |
| }.bind(this)) |
| btnCancel.addEventListener('click', function () { |
| this.destroy() |
| this.callback && this.callback(this.cancelTitle) |
| }.bind(this)) |
| } |
| |
| module.exports = Confirm |
| |
| |
| /***/ }, |
| /* 87 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| // style-loader: Adds some css to the DOM by adding a <style> tag |
| |
| // load the styles |
| var content = __webpack_require__(88); |
| if(typeof content === 'string') content = [[module.id, content, '']]; |
| // add the styles to the DOM |
| var update = __webpack_require__(4)(content, {}); |
| if(content.locals) module.exports = content.locals; |
| // Hot Module Replacement |
| if(false) { |
| // When the styles change, update the <style> tags |
| if(!content.locals) { |
| module.hot.accept("!!./../../css-loader/index.js?sourceMap!./../../sass-loader/index.js?sourceMap!./confirm.scss", function() { |
| var newContent = require("!!./../../css-loader/index.js?sourceMap!./../../sass-loader/index.js?sourceMap!./confirm.scss"); |
| if(typeof newContent === 'string') newContent = [[module.id, newContent, '']]; |
| update(newContent); |
| }); |
| } |
| // When the module is disposed, remove the <style> tags |
| module.hot.dispose(function() { update(); }); |
| } |
| |
| /***/ }, |
| /* 88 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| exports = module.exports = __webpack_require__(3)(); |
| // imports |
| |
| |
| // module |
| exports.push([module.id, ".amfe-confirm .btn-group .btn {\n float: left;\n width: 50%; }\n .amfe-confirm .btn-group .btn.btn-ok {\n border-right: 1px solid #ddd; }\n", "", {"version":3,"sources":["/./node_modules/modals/node_modules/modals/styles/confirm.scss"],"names":[],"mappings":"AAAA;EAKM,YAAY;EACZ,WAAW,EAKZ;EAXL;IASO,6BAA6B,EAC7B","file":"confirm.scss","sourcesContent":[".amfe-confirm {\n\n .btn-group {\n\n .btn {\n float: left;\n width: 50%;\n\n &.btn-ok {\n \tborder-right: 1px solid #ddd;\n }\n }\n }\n}"],"sourceRoot":"webpack://"}]); |
| |
| // exports |
| |
| |
| /***/ }, |
| /* 89 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| var Modal = __webpack_require__(81) |
| __webpack_require__(90) |
| |
| var CONTENT_CLASS = 'content' |
| var MSG_CLASS = 'content-msg' |
| var BUTTON_GROUP_CLASS = 'btn-group' |
| var BUTTON_CLASS = 'btn' |
| var INPUT_WRAP_CLASS = 'input-wrap' |
| var INPUT_CLASS = 'input' |
| |
| function Prompt(config) { |
| this.msg = config.message || '' |
| this.defaultMsg = config.default || '' |
| this.callback = config.callback |
| this.okTitle = config.okTitle || 'OK' |
| this.cancelTitle = config.cancelTitle || 'Cancel' |
| Modal.call(this) |
| this.node.classList.add('amfe-prompt') |
| } |
| |
| Prompt.prototype = Object.create(Modal.prototype) |
| |
| Prompt.prototype.createNodeContent = function () { |
| |
| var content = document.createElement('div') |
| content.classList.add(CONTENT_CLASS) |
| this.node.appendChild(content) |
| |
| var msg = document.createElement('div') |
| msg.classList.add(MSG_CLASS) |
| msg.appendChild(document.createTextNode(this.msg)) |
| content.appendChild(msg) |
| |
| var inputWrap = document.createElement('div') |
| inputWrap.classList.add(INPUT_WRAP_CLASS) |
| content.appendChild(inputWrap) |
| var input = document.createElement('input') |
| input.classList.add(INPUT_CLASS) |
| input.type = 'text' |
| input.autofocus = true |
| input.placeholder = this.defaultMsg |
| inputWrap.appendChild(input) |
| |
| var buttonGroup = document.createElement('div') |
| buttonGroup.classList.add(BUTTON_GROUP_CLASS) |
| var btnOk = document.createElement('div') |
| btnOk.appendChild(document.createTextNode(this.okTitle)) |
| btnOk.classList.add('btn-ok', BUTTON_CLASS) |
| var btnCancel = document.createElement('div') |
| btnCancel.appendChild(document.createTextNode(this.cancelTitle)) |
| btnCancel.classList.add('btn-cancel', BUTTON_CLASS) |
| buttonGroup.appendChild(btnOk) |
| buttonGroup.appendChild(btnCancel) |
| this.node.appendChild(buttonGroup) |
| } |
| |
| Prompt.prototype.bindEvents = function () { |
| Modal.prototype.bindEvents.call(this) |
| var btnOk = this.node.querySelector('.' + BUTTON_CLASS + '.btn-ok') |
| var btnCancel = this.node.querySelector('.' + BUTTON_CLASS + '.btn-cancel') |
| var that = this |
| btnOk.addEventListener('click', function () { |
| var val = document.querySelector('input').value |
| this.destroy() |
| this.callback && this.callback({ |
| result: that.okTitle, |
| data: val |
| }) |
| }.bind(this)) |
| btnCancel.addEventListener('click', function () { |
| var val = document.querySelector('input').value |
| this.destroy() |
| this.callback && this.callback({ |
| result: that.cancelTitle |
| }) |
| }.bind(this)) |
| } |
| |
| module.exports = Prompt |
| |
| |
| /***/ }, |
| /* 90 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| // style-loader: Adds some css to the DOM by adding a <style> tag |
| |
| // load the styles |
| var content = __webpack_require__(91); |
| if(typeof content === 'string') content = [[module.id, content, '']]; |
| // add the styles to the DOM |
| var update = __webpack_require__(4)(content, {}); |
| if(content.locals) module.exports = content.locals; |
| // Hot Module Replacement |
| if(false) { |
| // When the styles change, update the <style> tags |
| if(!content.locals) { |
| module.hot.accept("!!./../../css-loader/index.js?sourceMap!./../../sass-loader/index.js?sourceMap!./prompt.scss", function() { |
| var newContent = require("!!./../../css-loader/index.js?sourceMap!./../../sass-loader/index.js?sourceMap!./prompt.scss"); |
| if(typeof newContent === 'string') newContent = [[module.id, newContent, '']]; |
| update(newContent); |
| }); |
| } |
| // When the module is disposed, remove the <style> tags |
| module.hot.dispose(function() { update(); }); |
| } |
| |
| /***/ }, |
| /* 91 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| exports = module.exports = __webpack_require__(3)(); |
| // imports |
| |
| |
| // module |
| exports.push([module.id, ".amfe-prompt .input-wrap {\n box-sizing: border-box;\n width: 100%;\n padding: 0.24rem 0.213333rem 0.213333rem;\n height: 0.96rem; }\n .amfe-prompt .input-wrap .input {\n box-sizing: border-box;\n width: 100%;\n height: 0.56rem;\n line-height: 0.56rem;\n font-size: 0.32rem; }\n\n.amfe-prompt .btn-group .btn {\n float: left;\n width: 50%; }\n .amfe-prompt .btn-group .btn.btn-ok {\n border-right: 1px solid #ddd; }\n", "", {"version":3,"sources":["/./node_modules/modals/node_modules/modals/styles/prompt.scss"],"names":[],"mappings":"AAAA;EAGI,uBAAuB;EACvB,YAAY;EACZ,yCAAyC;EACzC,gBAAgB,EASjB;EAfH;IASM,uBAAuB;IACvB,YAAY;IACZ,gBAAgB;IAChB,qBAAqB;IACrB,mBAAmB,EACpB;;AAdL;EAoBM,YAAY;EACZ,WAAW,EAKZ;EA1BL;IAwBQ,6BAA6B,EAC9B","file":"prompt.scss","sourcesContent":[".amfe-prompt {\n\n .input-wrap {\n box-sizing: border-box;\n width: 100%;\n padding: 0.24rem 0.213333rem 0.213333rem; // 18px 16px 16px\n height: 0.96rem; // 74px\n\n .input {\n box-sizing: border-box;\n width: 100%;\n height: 0.56rem; // 42px\n line-height: 0.56rem; // 42px\n font-size: 0.32rem; // 24px\n }\n }\n\n .btn-group {\n\n .btn {\n float: left;\n width: 50%;\n\n &.btn-ok {\n border-right: 1px solid #ddd;\n }\n }\n }\n}"],"sourceRoot":"webpack://"}]); |
| |
| // exports |
| |
| |
| /***/ }, |
| /* 92 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| __webpack_require__(93) |
| |
| var queue = [] |
| var timer |
| var isProcessing = false |
| var toastWin |
| var TOAST_WIN_CLASS_NAME = 'amfe-toast' |
| |
| var DEFAULT_DURATION = 0.8 |
| |
| function showToastWindow(msg, callback) { |
| var handleTransitionEnd = function () { |
| toastWin.removeEventListener('transitionend', handleTransitionEnd) |
| callback && callback() |
| } |
| if (!toastWin) { |
| toastWin = document.createElement('div') |
| toastWin.classList.add(TOAST_WIN_CLASS_NAME, 'hide') |
| document.body.appendChild(toastWin) |
| } |
| toastWin.innerHTML = msg |
| toastWin.addEventListener('transitionend', handleTransitionEnd) |
| setTimeout(function () { |
| toastWin.classList.remove('hide') |
| }, 0) |
| } |
| |
| function hideToastWindow(callback) { |
| var handleTransitionEnd = function () { |
| toastWin.removeEventListener('transitionend', handleTransitionEnd) |
| callback && callback() |
| } |
| if (!toastWin) { |
| return |
| } |
| toastWin.addEventListener('transitionend', handleTransitionEnd) |
| toastWin.classList.add('hide') |
| } |
| |
| var toast = { |
| |
| push: function (msg, duration) { |
| queue.push({ |
| msg: msg, |
| duration: duration || DEFAULT_DURATION |
| }) |
| this.show() |
| }, |
| |
| show: function () { |
| var that = this |
| |
| // All messages had been toasted already, so remove the toast window, |
| if (!queue.length) { |
| toastWin && toastWin.parentNode.removeChild(toastWin) |
| toastWin = null |
| return |
| } |
| |
| // the previous toast is not ended yet. |
| if (isProcessing) { |
| return |
| } |
| isProcessing = true |
| |
| var toastInfo = queue.shift() |
| showToastWindow(toastInfo.msg, function () { |
| timer = setTimeout(function () { |
| timer = null |
| hideToastWindow(function () { |
| isProcessing = false |
| that.show() |
| }) |
| }, toastInfo.duration * 1000) |
| }) |
| } |
| |
| } |
| |
| module.exports = { |
| push: toast.push.bind(toast) |
| } |
| |
| |
| /***/ }, |
| /* 93 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| // style-loader: Adds some css to the DOM by adding a <style> tag |
| |
| // load the styles |
| var content = __webpack_require__(94); |
| if(typeof content === 'string') content = [[module.id, content, '']]; |
| // add the styles to the DOM |
| var update = __webpack_require__(4)(content, {}); |
| if(content.locals) module.exports = content.locals; |
| // Hot Module Replacement |
| if(false) { |
| // When the styles change, update the <style> tags |
| if(!content.locals) { |
| module.hot.accept("!!./../../css-loader/index.js?sourceMap!./../../sass-loader/index.js?sourceMap!./toast.scss", function() { |
| var newContent = require("!!./../../css-loader/index.js?sourceMap!./../../sass-loader/index.js?sourceMap!./toast.scss"); |
| if(typeof newContent === 'string') newContent = [[module.id, newContent, '']]; |
| update(newContent); |
| }); |
| } |
| // When the module is disposed, remove the <style> tags |
| module.hot.dispose(function() { update(); }); |
| } |
| |
| /***/ }, |
| /* 94 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| exports = module.exports = __webpack_require__(3)(); |
| // imports |
| |
| |
| // module |
| exports.push([module.id, ".amfe-toast {\n font-size: 0.32rem;\n line-height: 0.426667rem;\n position: fixed;\n box-sizing: border-box;\n max-width: 80%;\n bottom: 2.666667rem;\n left: 50%;\n padding: 0.213333rem;\n background-color: #000;\n color: #fff;\n text-align: center;\n opacity: 0.6;\n transition: all 0.4s ease-in-out;\n border-radius: 0.066667rem;\n -webkit-transform: translateX(-50%);\n transform: translateX(-50%); }\n\n.amfe-toast.hide {\n opacity: 0; }\n", "", {"version":3,"sources":["/./node_modules/modals/node_modules/modals/styles/toast.scss"],"names":[],"mappings":"AAAA;EACC,mBAAmB;EACnB,yBAAyB;EACzB,gBAAgB;EAChB,uBAAuB;EACvB,eAAe;EACf,oBAAoB;EACpB,UAAU;EACV,qBAAqB;EACrB,uBAAuB;EACvB,YAAY;EACZ,mBAAmB;EACnB,aAAa;EACb,iCAAiC;EACjC,2BAA2B;EAC3B,oCAA6B;EAC5B,4BAAqB,EACtB;;AAED;EACC,WAAW,EACX","file":"toast.scss","sourcesContent":[".amfe-toast {\n\tfont-size: 0.32rem; // 24px\n\tline-height: 0.426667rem; // 32px\n\tposition: fixed;\n\tbox-sizing: border-box;\n\tmax-width: 80%;\n\tbottom: 2.666667rem; // 200px\n\tleft: 50%;\n\tpadding: 0.213333rem; // 16px\n\tbackground-color: #000;\n\tcolor: #fff;\n\ttext-align: center;\n\topacity: 0.6;\n\ttransition: all 0.4s ease-in-out;\n\tborder-radius: 0.066667rem; // 5px\n\t-webkit-transform: translateX(-50%);\n transform: translateX(-50%);\n}\n\n.amfe-toast.hide {\n\topacity: 0;\n}"],"sourceRoot":"webpack://"}]); |
| |
| // exports |
| |
| |
| /***/ }, |
| /* 95 */ |
| /***/ function(module, exports, __webpack_require__) { |
| |
| 'use strict' |
| |
| var Sender = __webpack_require__(19) |
| |
| var _data = {} |
| |
| var animation = { |
| |
| /** |
| * transition |
| * @param {string} ref [description] |
| * @param {obj} config [description] |
| * @param {string} callbackId [description] |
| */ |
| transition: function (ref, config, callbackId) { |
| var refData = _data[ref] |
| var stylesKey = JSON.stringify(config.styles) |
| var weexInstance = this |
| // If the same component perform a animation with exactly the same |
| // styles in a sequence with so short interval that the prev animation |
| // is still in playing, then the next animation should be ignored. |
| if (refData && refData[stylesKey]) { |
| return |
| } |
| if (!refData) { |
| refData = _data[ref] = {} |
| } |
| refData[stylesKey] = true |
| return this.getComponentManager().transition(ref, config, function () { |
| // Remove the stylesKey in refData so that the same animation |
| // can be played again after current animation is already finished. |
| delete refData[stylesKey] |
| weexInstance.sender.performCallback(callbackId) |
| }) |
| } |
| |
| } |
| |
| animation._meta = { |
| animation: [{ |
| name: 'transition', |
| args: ['string', 'object', 'string'] |
| }] |
| } |
| |
| module.exports = animation |
| |
| |
| /***/ }, |
| /* 96 */ |
| /***/ function(module, exports) { |
| |
| (typeof window === 'undefined') && (window = {ctrl: {}, lib: {}});!window.ctrl && (window.ctrl = {});!window.lib && (window.lib = {});!function(a,b){function c(a){Object.defineProperty(this,"val",{value:a.toString(),enumerable:!0}),this.gt=function(a){return c.compare(this,a)>0},this.gte=function(a){return c.compare(this,a)>=0},this.lt=function(a){return c.compare(this,a)<0},this.lte=function(a){return c.compare(this,a)<=0},this.eq=function(a){return 0===c.compare(this,a)}}b.env=b.env||{},c.prototype.toString=function(){return this.val},c.prototype.valueOf=function(){for(var a=this.val.split("."),b=[],c=0;c<a.length;c++){var d=parseInt(a[c],10);isNaN(d)&&(d=0);var e=d.toString();e.length<5&&(e=Array(6-e.length).join("0")+e),b.push(e),1===b.length&&b.push(".")}return parseFloat(b.join(""))},c.compare=function(a,b){a=a.toString().split("."),b=b.toString().split(".");for(var c=0;c<a.length||c<b.length;c++){var d=parseInt(a[c],10),e=parseInt(b[c],10);if(window.isNaN(d)&&(d=0),window.isNaN(e)&&(e=0),e>d)return-1;if(d>e)return 1}return 0},b.version=function(a){return new c(a)}}(window,window.lib||(window.lib={})),function(a,b){b.env=b.env||{};var c=a.location.search.replace(/^\?/,"");if(b.env.params={},c)for(var d=c.split("&"),e=0;e<d.length;e++){d[e]=d[e].split("=");try{b.env.params[d[e][0]]=decodeURIComponent(d[e][1])}catch(f){b.env.params[d[e][0]]=d[e][1]}}}(window,window.lib||(window.lib={})),function(a,b){b.env=b.env||{};var c,d=a.navigator.userAgent;if(c=d.match(/Windows\sPhone\s(?:OS\s)?([\d\.]+)/))b.env.os={name:"Windows Phone",isWindowsPhone:!0,version:c[1]};else if(d.match(/Safari/)&&(c=d.match(/Android[\s\/]([\d\.]+)/)))b.env.os={version:c[1]},d.match(/Mobile\s+Safari/)?(b.env.os.name="Android",b.env.os.isAndroid=!0):(b.env.os.name="AndroidPad",b.env.os.isAndroidPad=!0);else if(c=d.match(/(iPhone|iPad|iPod)/)){var e=c[1];c=d.match(/OS ([\d_\.]+) like Mac OS X/),b.env.os={name:e,isIPhone:"iPhone"===e||"iPod"===e,isIPad:"iPad"===e,isIOS:!0,version:c[1].split("_").join(".")}}else b.env.os={name:"unknown",version:"0.0.0"};b.version&&(b.env.os.version=b.version(b.env.os.version))}(window,window.lib||(window.lib={})),function(a,b){b.env=b.env||{};var c,d=a.navigator.userAgent;(c=d.match(/(?:UCWEB|UCBrowser\/)([\d\.]+)/))?b.env.browser={name:"UC",isUC:!0,version:c[1]}:(c=d.match(/MQQBrowser\/([\d\.]+)/))?b.env.browser={name:"QQ",isQQ:!0,version:c[1]}:(c=d.match(/Firefox\/([\d\.]+)/))?b.env.browser={name:"Firefox",isFirefox:!0,version:c[1]}:(c=d.match(/MSIE\s([\d\.]+)/))||(c=d.match(/IEMobile\/([\d\.]+)/))?(b.env.browser={version:c[1]},d.match(/IEMobile/)?(b.env.browser.name="IEMobile",b.env.browser.isIEMobile=!0):(b.env.browser.name="IE",b.env.browser.isIE=!0),d.match(/Android|iPhone/)&&(b.env.browser.isIELikeWebkit=!0)):(c=d.match(/(?:Chrome|CriOS)\/([\d\.]+)/))?(b.env.browser={name:"Chrome",isChrome:!0,version:c[1]},d.match(/Version\/[\d+\.]+\s*Chrome/)&&(b.env.browser.name="Chrome Webview",b.env.browser.isWebview=!0)):d.match(/Safari/)&&(c=d.match(/Android[\s\/]([\d\.]+)/))?b.env.browser={name:"Android",isAndroid:!0,version:c[1]}:d.match(/iPhone|iPad|iPod/)?d.match(/Safari/)?(c=d.match(/Version\/([\d\.]+)/),b.env.browser={name:"Safari",isSafari:!0,version:c[1]}):(c=d.match(/OS ([\d_\.]+) like Mac OS X/),b.env.browser={name:"iOS Webview",isWebview:!0,version:c[1].replace(/\_/g,".")}):b.env.browser={name:"unknown",version:"0.0.0"},b.version&&(b.env.browser.version=b.version(b.env.browser.version))}(window,window.lib||(window.lib={})),function(a,b){b.env=b.env||{};var c=a.navigator.userAgent;c.match(/Weibo/i)?b.env.thirdapp={appname:"Weibo",isWeibo:!0}:c.match(/MicroMessenger/i)?b.env.thirdapp={appname:"Weixin",isWeixin:!0}:b.env.thirdapp=!1}(window,window.lib||(window.lib={})),function(a,b){b.env=b.env||{};var c,d,e=a.navigator.userAgent;(d=e.match(/WindVane[\/\s]([\d\.\_]+)/))&&(c=d[1]);var f=!1,g="",h="",i="";(d=e.match(/AliApp\(([A-Z\-]+)\/([\d\.]+)\)/i))&&(f=!0,g=d[1],i=d[2],h=g.indexOf("-PD")>0?b.env.os.isIOS?"iPad":b.env.os.isAndroid?"AndroidPad":b.env.os.name:b.env.os.name),!g&&e.indexOf("TBIOS")>0&&(g="TB"),f?b.env.aliapp={windvane:b.version(c||"0.0.0"),appname:g||"unkown",version:b.version(i||"0.0.0"),platform:h||b.env.os.name}:b.env.aliapp=!1,b.env.taobaoApp=b.env.aliapp}(window,window.lib||(window.lib={}));;module.exports = window.lib['env']; |
| |
| /***/ } |
| /******/ ]); |
| //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["webpack:///webpack/bootstrap 96e0afcc657690376e54","webpack:///./src/weex.js","webpack:///./src/styles/base.scss?c2ee","webpack:///./src/styles/base.scss","webpack:///./~/css-loader/lib/css-base.js","webpack:///./~/style-loader/addStyles.js","webpack:///./src/config.js","webpack:///./src/loader.js","webpack:///./src/utils.js","webpack:///./src/protocol.js","webpack:///./src/componentManager.js","webpack:///./src/frameUpdater.js","webpack:///./src/appearWatcher.js","webpack:///./src/lazyLoad.js","webpack:///./~/lazyimg/build/img.common.js","webpack:///./~/appearjs/build/appear.common.js","webpack:///./src/animation.js","webpack:///./src/components/component.js","webpack:///./src/flexbox.js","webpack:///./~/fixedsticky/build/sticky.common.js","webpack:///./src/bridge/sender.js","webpack:///./src/bridge/receiver.js","webpack:///./src/components/index.js","webpack:///./src/components/root.js","webpack:///./src/components/container.js","webpack:///./src/styles/container.scss?d6b4","webpack:///./src/styles/container.scss","webpack:///./src/components/image.js","webpack:///./src/components/atomic.js","webpack:///./src/components/text.js","webpack:///./src/components/list.js","webpack:///./src/styles/list.scss?bd96","webpack:///./src/styles/list.scss","webpack:///./~/scrolljs/build/scroll.common.js","webpack:///./~/animationjs/build/animation.common.js","webpack:///./~/cubicbezier/build/cubicbezier.common.js","webpack:///./~/gesturejs/build/gesturejs.common.js","webpack:///./~/motionjs/build/motion.common.js","webpack:///./src/components/countdown.js","webpack:///./~/kountdown/build/countdown.js","webpack:///./src/components/marquee.js","webpack:///./src/components/slider.js","webpack:///./~/carrousel/build/carrousel.common.js","webpack:///./src/styles/slider.scss?434a","webpack:///./src/styles/slider.scss","webpack:///./src/components/indicator.js","webpack:///./src/styles/indicator.scss?446f","webpack:///./src/styles/indicator.scss","webpack:///./src/components/tabheader.js","webpack:///./src/messageQueue.js","webpack:///./src/styles/tabheader.scss?f5a8","webpack:///./src/styles/tabheader.scss","webpack:///./src/components/scroller.js","webpack:///./src/styles/scroller.scss?663d","webpack:///./src/styles/scroller.scss","webpack:///./src/components/input.js","webpack:///./src/components/select.js","webpack:///./src/components/datepicker.js","webpack:///./src/components/timepicker.js","webpack:///./src/components/video.js","webpack:///./src/styles/video.scss?b1fa","webpack:///./src/styles/video.scss","webpack:///./src/components/switch.js","webpack:///./src/styles/switch.scss?f698","webpack:///./src/styles/switch.scss","webpack:///./src/components/a.js","webpack:///./src/components/embed.js","webpack:///./src/api/index.js","webpack:///./src/api/dom.js","webpack:///./~/scroll-to/index.js","webpack:///./~/component-tween/index.js","webpack:///./~/component-emitter/index.js","webpack:///./~/component-clone/index.js","webpack:///./~/component-type/index.js","webpack:///./~/ease-component/index.js","webpack:///./~/component-raf/index.js","webpack:///./src/api/event.js","webpack:///./src/api/pageInfo.js","webpack:///./src/api/stream.js","webpack:///./src/api/modal.js","webpack:///./~/modals/src/index.js","webpack:///./~/modals/src/alert.js","webpack:///./~/modals/src/modal.js","webpack:///./~/modals/styles/modal.scss?da48","webpack:///./~/modals/styles/modal.scss","webpack:///./~/modals/styles/alert.scss?5782","webpack:///./~/modals/styles/alert.scss","webpack:///./~/modals/src/confirm.js","webpack:///./~/modals/styles/confirm.scss?d64a","webpack:///./~/modals/styles/confirm.scss","webpack:///./~/modals/src/prompt.js","webpack:///./~/modals/styles/prompt.scss?7e1c","webpack:///./~/modals/styles/prompt.scss","webpack:///./~/modals/src/toast.js","webpack:///./~/modals/styles/toast.scss?a60f","webpack:///./~/modals/styles/toast.scss","webpack:///./src/api/animation.js","webpack:///./~/envd/build/envd.common.js"],"names":[],"mappings":";;AAAA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,uBAAe;AACf;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;;AAGA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;;;;;;ACtCA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA,IAAG;;AAEH;;AAEA;AACA;AACA;AACA;AACA,MAAK;AACL,IAAG;AACH;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA,MAAK;AACL,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,QAAO;AACP;AACA;AACA;AACA,QAAO;AACP;;AAEA;AACA;AACA;AACA;AACA,SAAQ;;AAER,IAAG;;AAEH;AACA;AACA,IAAG;;AAEH;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;AACA,EAAC;;AAED;AACA;AACA;AACA,EAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,EAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA,EAAC;;AAED;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,EAAC;;AAED;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;;;;;;;ACrQA;;AAEA;AACA;AACA;AACA;AACA,gDAAmF;AACnF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA,iCAAgC,UAAU,EAAE;AAC5C,E;;;;;;ACpBA;AACA;;;AAGA;AACA,8BAA6B,cAAc,eAAe,2BAA2B,EAAE,YAAY,qBAAqB,EAAE,UAAU,kFAAkF,UAAU,UAAU,iBAAiB,KAAK,0DAA0D,aAAa,cAAc,4BAA4B,SAAS,sBAAsB,6BAA6B;;AAE7a;;;;;;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,iBAAgB,iBAAiB;AACjC;AACA;AACA,yCAAwC,gBAAgB;AACxD,KAAI;AACJ;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,iBAAgB,iBAAiB;AACjC;AACA;AACA;AACA;AACA,aAAY,oBAAoB;AAChC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;ACjDA;AACA;AACA;AACA;AACA,qBAAoB;AACpB;AACA;AACA;AACA;AACA;AACA;AACA,GAAE;AACF;AACA;AACA,GAAE;AACF;AACA;AACA,GAAE;AACF;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,iBAAgB,mBAAmB;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAgB,sBAAsB;AACtC;AACA;AACA,mBAAkB,2BAA2B;AAC7C;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,gBAAe,mBAAmB;AAClC;AACA;AACA;AACA;AACA,kBAAiB,2BAA2B;AAC5C;AACA;AACA,SAAQ,uBAAuB;AAC/B;AACA;AACA,IAAG;AACH;AACA,kBAAiB,uBAAuB;AACxC;AACA;AACA,4BAA2B;AAC3B;AACA;AACA;;AAEA;AACA;AACA;AACA,gBAAe,iBAAiB;AAChC;AACA;AACA;AACA;AACA;AACA,eAAc;AACd;AACA,iCAAgC,sBAAsB;AACtD;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA,IAAG;AACH;AACA;AACA;AACA,GAAE;AACF;AACA,GAAE;AACF;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAE;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAE;AACF;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,EAAC;;AAED;AACA;;AAEA;AACA;AACA,GAAE;AACF;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,GAAE;AACF;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,wDAAuD;AACvD;;AAEA,8BAA6B,mBAAmB;;AAEhD;;AAEA;;AAEA;AACA;AACA;;;;;;;ACrPA;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA,wB;;;;;;ACVA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;;;;;;ACjEA;;AAEA;;AAEA;;AAEA,EAAC;AACD;AACA;AACA,iCAAgC;AAChC;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA,EAAC;;AAED;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAiC,OAAO;AACxC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,E;;;;;;ACjGA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,uCAAsC,OAAO;AAC7C;AACA;AACA,IAAG;AACH;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA,gBAAe;;AAEf;AACA;AACA,IAAG;;AAEH;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA,QAAO;AACP;AACA;AACA;AACA;AACA;AACA,QAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;AACA,QAAO;AACP;AACA;AACA,QAAO;AACP;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA,IAAG;AACH;AACA;AACA,IAAG;AACH;AACA;AACA,IAAG;AACH,EAAC;AACD;AACA;AACA;AACA,IAAG;AACH,EAAC;;AAED;;;;;;;ACnIA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6CAA4C,OAAO;AACnD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;;AAEL,IAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA,IAAG;;AAEH;AACA;AACA,eAAc,OAAO;AACrB;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,QAAO;AACP;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,IAAG;;AAEH;AACA,oBAAmB,qBAAqB;AACxC;AACA;AACA,IAAG;;AAEH;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,yCAAwC,OAAO;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAK,OAAO;AACZ;AACA;;AAEA;;AAEA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;;AAEA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA,cAAa,OAAO;AACpB,cAAa,IAAI;AACjB,cAAa,OAAO;AACpB;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;;AAEA;AACA;AACA;AACA,sBAAqB,qBAAqB;AAC1C;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;;AAEA;;;;;;;AChZA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,wBAAuB,sBAAsB;AAC7C;AACA;AACA;AACA;AACA,MAAK;AACL,IAAG;;AAEH;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;;AAEA;;;;;;;AC/CA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,QAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;AACA,kBAAiB,SAAS;AAC1B;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,kBAAiB,SAAS;AAC1B;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,eAAc;AACd;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;;AAEA,+B;;;;;;ACnJA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAS;AACT;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;;AAEA;;AAEA;;;;;;;AC/DA,sCAAqC,OAAO,QAAQ,+BAA+B,6BAA6B,gBAAgB,gBAAgB,oGAAoG,aAAa,iBAAiB,uEAAuE,WAAW,mEAAmE,EAAE,wBAAoB,UAAU,IAAI,4CAA4C,uBAAuB,kCAAkC,mBAAmB,OAAO,yEAAyE,8BAA8B,sMAAsM,yBAAyB,8BAA8B,kIAAkI,kCAAkC,G;;;;;;ACAllC,sCAAqC,OAAO,QAAQ,+BAA+B,6BAA6B,gBAAgB,aAAa,yHAAyH,gBAAgB,+CAA+C,kCAAkC,kBAAkB,iBAAiB,mBAAmB,cAAc,0FAA0F,gBAAgB,YAAY,mBAAmB,QAAQ,8HAA8H,uCAAuC,gBAAgB,sEAAsE,YAAY,gBAAgB,2CAA2C,wFAAwF,gBAAgB,gDAAgD,SAAS,aAAa,0BAA0B,qBAAqB,oBAAoB,mNAAmN,qBAAqB,+DAA+D,qBAAqB,qEAAqE,qBAAqB,gEAAgE,qBAAqB,KAAK,cAAc,oCAAoC,4HAA4H,8CAA8C,4BAA4B,8BAA8B,gIAAgI,EAAE,cAAc,WAAW,6CAA6C,qEAAqE,EAAE,aAAa,0GAA0G,kCAAkC,yCAAyC,+CAA+C,+BAA+B,eAAe,0DAA0D,QAAQ,YAAY,SAAS,YAAY,6KAA6K,EAAE,cAAc,uBAAuB,2IAA2I,gCAAgC,wBAAwB,IAAI,8BAA8B,OAAO,SAAS,+EAA+E,sBAAsB,0BAA0B,0DAA0D,uBAAuB,uBAAuB,qBAAqB,gCAAgC,4CAA4C,EAAE,KAAK,0DAA0D,4CAA4C,wCAAwC,uFAAuF,mBAAmB,mEAAmE,4DAA4D,OAAO,iBAAiB,wDAAwD,wCAAwC,sGAAsG,cAAc,eAAe,gCAAgC,oBAAoB,qBAAqB,sBAAsB,SAAS,IAAI,eAAe,kCAAkC,G;;;;;;ACA7iI;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,E;;;;;;AClCA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA,IAAG;;AAEH;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAqB,qBAAqB;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;;AAEA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,MAAK;AACL,gCAA+B,OAAO;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;;AAEA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA,oCAAmC,OAAO;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAO;AACP;AACA;AACA,UAAS;AACT;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;AACA,QAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA,uCAAsC,OAAO;AAC7C;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAAuB;AACvB,iCAAgC;AAChC;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA,sBAAqB,qBAAqB;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA,sBAAqB,qBAAqB;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,sBAAqB,qBAAqB;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH,WAAU;;AAEV;;AAEA;AACA,IAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAO;AACP,MAAK;AACL,IAAG;AACH;AACA;AACA;;AAEA;;;;;;;ACxTA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,EAAC;;AAED;;;;;;;ACjDA,+CAA8C,QAAQ,UAAU,EAAE,iCAAiC,EAAE,+BAA+B,EAAE,iBAAiB,cAAc,+EAA+E,gBAAgB,kCAAkC,oCAAoC,kBAAkB,2BAA2B,qGAAqG,cAAc,SAAS,0CAA0C,gBAAgB,EAAE,IAAI,gBAAgB,mCAAmC,wEAAwE,WAAW,4FAA4F,+JAA+J,uCAAuC,uCAAuC,gBAAgB,mCAAmC,GAAG,aAAa,8BAA8B,iCAAiC,6LAA6L,wBAAwB,0JAA0J,sBAAsB,YAAY,WAAW,2BAA2B,oBAAoB,WAAW,qCAAqC,6BAA6B,sCAAsC,yCAAyC,+CAA+C,gEAAgE,kNAAkN,iLAAiL,iCAAiC,SAAS,4BAA4B,wVAAwV,yDAAyD,SAAS,6CAA6C,sCAAsC,oBAAoB,wMAAwM,MAAM,uDAAuD,kCAAkC,gDAAgD,oBAAoB,uBAAuB,wCAAwC,4BAA4B,oFAAoF,oBAAoB,WAAW,YAAY,sBAAsB,4HAA4H,YAAY,2CAA2C,IAAI,sC;;;;;;ACAtjH;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL,IAAG;;AAEH;AACA;AACA;AACA;AACA,8BAA6B;AAC7B;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;;AAEA;;AAEA,wB;;;;;;ACnDA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA,IAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAiB,SAAS;AAC1B;AACA;AACA;AACA;AACA,QAAO;AACP;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;;;;;;;AC9HA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,4B;;;;;;AC7CA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;;;;;;;ACxCA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;;;;;;;ACbA;;AAEA;AACA;AACA;AACA;AACA,gDAAmF;AACnF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA,iCAAgC,UAAU,EAAE;AAC5C,E;;;;;;ACpBA;AACA;;;AAGA;AACA,4CAA2C,2BAA2B,yBAAyB,0BAA0B,kBAAkB,iCAAiC,mCAAmC,2BAA2B,uBAAuB,0BAA0B,cAAc,eAAe,EAAE,mBAAmB,2BAA2B,uBAAuB,EAAE,UAAU,uFAAuF,YAAY,aAAa,aAAa,WAAW,YAAY,aAAa,aAAa,aAAa,aAAa,WAAW,gBAAgB,KAAK,YAAY,gFAAgF,0BAA0B,wBAAwB,yBAAyB,iBAAiB,gCAAgC,kCAAkC,0BAA0B,sBAAsB,yBAAyB,aAAa,gBAAgB,mBAAmB,2BAA2B,uBAAuB,GAAG,6BAA6B;;AAExjC;;;;;;;ACPA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;;;;;;ACxDA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;;;;;;AC5BA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sCAAqC;AACrC;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,oCAAmC;AACnC;AACA;AACA,UAAS;AACT;AACA;AACA;AACA,QAAO;AACP;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,uBAAsB;AACtB;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;;AAEA,EAAC;;AAED;;;;;;;ACvFA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA,MAAK;AACL,IAAG;;AAEH;AACA;AACA,IAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,IAAG;AACH;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,IAAG;AACH,kCAAiC,OAAO;AACxC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAiC,OAAO;AACxC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACvHA;;AAEA;AACA;AACA;AACA;AACA,gDAAmF;AACnF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA,iCAAgC,UAAU,EAAE;AAC5C,E;;;;;;ACpBA;AACA;;;AAGA;AACA,uCAAsC,mBAAmB,qBAAqB,EAAE,mBAAmB,iCAAiC,mCAAmC,2BAA2B,EAAE,UAAU,kFAAkF,UAAU,mBAAmB,KAAK,YAAY,aAAa,sEAAsE,mBAAmB,qBAAqB,GAAG,mBAAmB,iCAAiC,mCAAmC,2BAA2B,GAAG,6BAA6B;;AAE9lB;;;;;;;ACPA,+CAA8C,QAAQ,UAAU,EAAE,iCAAiC,EAAE,+BAA+B,EAAE,wBAAuB,wBAAuB,wBAAqB,wBAAoB,iBAAiB,aAAa,gE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ACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,gBAAe,qBAAqB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,gBAAe,2BAA2B;AAC1C,aAAY,gCAAgC;AAC5C,iBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;;AAEL;;AAEA;AACA;AACA;AACA,IAAG;;AAEH;;AAEA;AACA;AACA,gBAAe;AACf,aAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,oBAAmB;AACnB,oBAAmB;AACnB;AACA;AACA;AACA,iBAAgB;AAChB,iBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;;AAEA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA,IAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACxRA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;AACA,IAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;AACA,IAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA,QAAO;AACP;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,oBAAmB,qBAAqB;AACxC;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,uCAAsC,OAAO;AAC7C;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,oBAAmB,qBAAqB;AACxC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAS;AACT,QAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qCAAoC,OAAO;AAC3C;AACA;AACA;AACA;AACA;AAC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A;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,2CAA0C,OAAO;AACjD;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA,2CAA0C,OAAO;AACjD;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,EAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;;;;;;ACtKA;;AAEA;AACA;AACA;AACA;AACA,gDAAmF;AACnF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA,iCAAgC,UAAU,EAAE;AAC5C,E;;;;;;ACpBA;AACA;;;AAGA;AACA,6CAA4C,uBAAuB,wBAAwB,EAAE,sCAAsC,kBAAkB,yBAAyB,EAAE,UAAU,uFAAuF,YAAY,mBAAmB,KAAK,UAAU,gFAAgF,uBAAuB,wBAAwB,uBAAuB,kBAAkB,yBAAyB,KAAK,KAAK,6BAA6B;;AAEviB;;;;;;;ACPA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,4BAA2B;AAC3B;;AAEA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA,IAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA,kCAAiC,cAAc;AAC/C,IAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;;AAEA;AACA;AACA;;AAEA;AACA,IAAG;AACH;;AAEA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,uDAAsD,OAAO;AAC7D,cAAa,UAAU,WAAW;;AAElC;AACA,sCAAqC,OAAO;AAC5C;AACA,gCAA+B,QAAQ;AACvC,QAAO;AACP,gCAA+B,QAAQ;AACvC;;AAEA,8BAA6B,WAAW;;AAExC;AACA,MAAK;;AAEL;AACA,IAAG;AACH;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;;AAEA;AACA,IAAG;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c,w6NAAw6N,EAAE,eAAe,qCAAqC,oBAAoB,uBAAuB,wCAAwC,qCAAqC,uCAAuC,EAAE,kCAAkC,oBAAoB,EAAE,kCAAkC,oBAAoB,EAAE,0CAA0C,oBAAoB,EAAE,0CAA0C,oBAAoB,EAAE,+CAA+C,oBAAoB,EAAE,+CAA+C,oBAAoB,EAAE,+BAA+B;;AAEnr8B;;;;;;;ACPA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA,MAAK;AACL,IAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,IAAG;AACH;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,IAAG;AACH,kCAAiC,OAAO;AACxC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAiC,OAAO;AACxC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpJA;;AAEA;AACA;AACA;AACA;AACA,gDAAmF;AACnF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA,iCAAgC,UAAU,EAAE;AAC5C,E;;;;;;ACpBA;AACA;;;AAGA;AACA,yCAAwC,mBAAmB,qBAAqB,EAAE,gCAAgC,mCAAmC,gCAAgC,wBAAwB,EAAE,8BAA8B,iCAAiC,mCAAmC,2BAA2B,EAAE,UAAU,sFAAsF,UAAU,mBAAmB,KAAK,YAAY,aAAa,oBAAoB,KAAK,YAAY,aAAa,4EAA4E,mBAAmB,qBAAqB,GAAG,qBAAqB,kBAAkB,qCAAqC,kCAAkC,0BAA0B,KAAK,gBAAgB,mCAAmC,qCAAqC,6BAA6B,KAAK,GAAG,6BAA6B;;AAEz7B;;;;;;;ACPA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uDAAsD;AACtD,sCAAqC,OAAO;AAC5C,kDAAiD;AACjD,0BAAyB;AACzB;AACA;AACA;;AAEA;;;;;;;AC7EA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAO;AACP;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;;AAEA;AACA;AACA;AACA,mCAAkC,OAAO;AACzC;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AClFA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpCA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpCA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,cAAa;AACb,iBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACpGA;;AAEA;AACA;AACA;AACA;AACA,gDAAmF;AACnF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA,iCAAgC,UAAU,EAAE;AAC5C,E;;;;;;ACpBA;AACA;;;AAGA;AACA,wCAAuC,2BAA2B,EAAE,UAAU,mFAAmF,uEAAuE,2BAA2B,GAAG,6BAA6B;;AAEnS;;;;;;;ACPA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,iCAAgC;AAChC;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,IAAG;AACH;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;;AAEA;AACA;AACA,IAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAO;AACP,MAAK;AACL;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,sCAAqC;AACrC;AACA;AACA;AACA;AACA,QAAO;;AAEP;AACA;AACA;AACA;AACA;AACA,sCAAqC;AACrC;AACA;AACA;AACA;AACA;;AAEA,MAAK;;AAEL;;;;;;;AC1MA;;AAEA;AACA;AACA;AACA;AACA,gDAAmF;AACnF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA,iCAAgC,UAAU,EAAE;AAC5C,E;;;;;;ACpBA;AACA;;;AAGA;AACA,iEAAgE,2BAA2B,8BAA8B,oBAAoB,0BAA0B,uBAAuB,2BAA2B,2BAA2B,6BAA6B,8BAA8B,0BAA0B,sBAAsB,4BAA4B,iCAAiC,EAAE,0BAA0B,qBAAqB,wBAAwB,6CAA6C,uBAAuB,WAAW,EAAE,UAAU,2FAA2F,MAAM,YAAY,aAAa,aAAa,aAAa,aAAa,aAAa,aAAa,aAAa,aAAa,aAAa,aAAa,aAAa,oBAAoB,KAAK,YAAY,aAAa,aAAa,aAAa,iGAAiG,2BAA2B,8BAA8B,oBAAoB,0BAA0B,uBAAuB,2BAA2B,6BAA6B,6BAA6B,8BAA8B,0BAA0B,sBAAsB,4BAA4B,iCAAiC,GAAG,0BAA0B,qBAAqB,wBAAwB,6CAA6C,uBAAuB,WAAW,GAAG,+BAA+B;;AAElgD;;;;;;;ACPA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;ACtBA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;AChEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,qB;;;;;;AClBA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,eAAc,OAAO;AACrB;AACA,eAAc,OAAO;AACrB;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA,eAAc,OAAO;AACrB,eAAc,IAAI;AAClB;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA,cAAa,OAAO;AACpB,cAAa,IAAI;AACjB;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA,IAAG;;AAEH;AACA;AACA,eAAc,OAAO;AACrB,eAAc,IAAI,UAAU;AAC5B;AACA;AACA;AACA,8BAA6B;AAC7B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAU;AACV;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA,IAAG;AACH;AACA;AACA,IAAG;AACH;AACA;AACA,IAAG;AACH;AACA;AACA,IAAG;AACH;AACA;AACA,IAAG;AACH;AACA;AACA,IAAG;AACH;AACA;AACA,IAAG;AACH;AACA;AACA,IAAG;AACH;AACA;AACA,IAAG;AACH;AACA;AACA,IAAG;AACH;;AAEA;;;;;;;AC3IA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,OAAO;AAClB;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,UAAS,kBAAkB;AAC3B;;AAEA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,aAAY;AACZ;AACA;;AAEA;AACA;AACA;AACA,WAAU;AACV;;;;;;;;AChEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,YAAW,aAAa;AACxB;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,iBAAgB,gBAAgB;AAChC;AACA,YAAW,aAAa;AACxB,aAAY,MAAM;AAClB;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,OAAO;AAClB,aAAY,MAAM;AAClB;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW,gBAAgB;AAC3B,aAAY;AACZ;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,aAAY;AACZ;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,aAAY,MAAM;AAClB;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,oBAAmB,iBAAiB;AACpC;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAW,SAAS;AACpB,aAAY,MAAM;AAClB;AACA;;AAEA;AACA;AACA;AACA;AACA,G;;;;;;;AChLA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,OAAO;AAClB,aAAY;AACZ;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,SAAS;AACpB,aAAY;AACZ;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,SAAS;AACpB,aAAY;AACZ;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,SAAS;AACpB,aAAY;AACZ;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,kBAAiB,sBAAsB;AACvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,OAAO;AAClB,YAAW,MAAM;AACjB,aAAY;AACZ;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,4CAA2C,SAAS;AACpD;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,YAAW,OAAO;AAClB,aAAY;AACZ;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAW,OAAO;AAClB,aAAY;AACZ;AACA;;AAEA;AACA;AACA;;;;;;;AChKA;AACA;AACA;;AAEA;AACA;AACA;AACA,EAAC;AACD;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,YAAW,MAAM;AACjB;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,sCAAqC,OAAO;AAC5C;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;;;;;;ACxDA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,YAAW,MAAM;AACjB,aAAY;AACZ;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;;;;;;;AChCA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,IAAG;AACH;AACA,IAAG;AACH;AACA,IAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;ACzKA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;;;;;;ACjCA;;AAEA;AACA;AACA;AACA,eAAc,OAAO;AACrB;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,IAAG;AACH;;AAEA,uB;;;;;;ACpBA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAG;AACH;;AAEA,0B;;;;;;ACpBA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAM;AACN;AACA;AACA;;AAEA;;AAEA;AACA;AACA,eAAc,IAAI;AAClB;AACA;AACA,eAAc,OAAO;AACrB;AACA;AACA;AACA;AACA;AACA,QAAO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,IAAG;AACH;;AAEA,wB;;;;;;AC/EA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA,IAAG;AACH;AACA;AACA,IAAG;AACH;AACA;AACA,IAAG;AACH;;AAEA;;;;;;;ACpEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,IAAG;;AAEH;AACA;AACA,IAAG;;AAEH;AACA;AACA,IAAG;;AAEH;AACA;AACA;;AAEA;;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AExkB;;;;;;;ACPA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL,IAAG;AACH;AACA;AACA;AACA;AACA;AACA,MAAK;AACL,IAAG;AACH;;AAEA;;;;;;;AChFA;;AAEA;AACA;AACA;AACA;AACA,gDAAsE;AACtE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA,iCAAgC,UAAU,EAAE;AAC5C,E;;;;;;ACpBA;AACA;;;AAGA;AACA,qDAAoD,2BAA2B,gBAAgB,6CAA6C,oBAAoB,EAAE,qCAAqC,6BAA6B,kBAAkB,sBAAsB,2BAA2B,yBAAyB,EAAE,kCAAkC,gBAAgB,eAAe,EAAE,yCAAyC,mCAAmC,EAAE,UAAU,oHAAoH,YAAY,WAAW,YAAY,mBAAmB,KAAK,YAAY,WAAW,YAAY,aAAa,oBAAoB,KAAK,WAAW,eAAe,MAAM,0EAA0E,mBAAmB,6BAA6B,kBAAkB,+CAA+C,wCAAwC,wBAAwB,+BAA+B,oBAAoB,wBAAwB,qCAAqC,mCAAmC,eAAe,KAAK,kBAAkB,cAAc,oBAAoB,mBAAmB,oBAAoB,uCAAuC,SAAS,OAAO,KAAK,GAAG,6BAA6B;;AAE90C;;;;;;;ACPA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,MAAK;AACL;AACA,IAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAS;AACT,QAAO;AACP,MAAK;AACL;;AAEA;;AAEA;AACA;AACA;;;;;;;ACnFA;;AAEA;AACA;AACA;AACA;AACA,gDAAsE;AACtE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAG;AACH;AACA;AACA,iCAAgC,UAAU,EAAE;AAC5C,E;;;;;;ACpBA;AACA;;;AAGA;AACA,wCAAuC,uBAAuB,6BAA6B,oBAAoB,2BAA2B,mBAAmB,wBAAwB,cAAc,yBAAyB,2BAA2B,gBAAgB,uBAAuB,iBAAiB,qCAAqC,+BAA+B,wCAAwC,gCAAgC,EAAE,sBAAsB,eAAe,EAAE,UAAU,mHAAmH,YAAY,aAAa,aAAa,aAAa,WAAW,YAAY,WAAW,YAAY,aAAa,WAAW,YAAY,WAAW,YAAY,aAAa,aAAa,oBAAoB,KAAK,oEAAoE,uBAAuB,qCAAqC,4BAA4B,2BAA2B,mBAAmB,wBAAwB,uBAAuB,yBAAyB,mCAAmC,gBAAgB,uBAAuB,iBAAiB,qCAAqC,+BAA+B,+CAA+C,gCAAgC,GAAG,sBAAsB,eAAe,GAAG,6BAA6B;;AAEx3C;;;;;;;ACPA;;AAEA;;AAEA;;AAEA;;AAEA;AACA;AACA,eAAc,OAAO;AACrB,eAAc,IAAI;AAClB,eAAc,OAAO;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAK;AACL;;AAEA;;AAEA;AACA;AACA;AACA;AACA,IAAG;AACH;;AAEA;;;;;;;AC7CA,+CAA8C,QAAQ,UAAU,EAAE,iCAAiC,EAAE,+BAA+B,EAAE,eAAe,cAAc,kCAAkC,iCAAiC,sBAAsB,2BAA2B,sBAAsB,4BAA4B,qBAAqB,2BAA2B,sBAAsB,4BAA4B,qBAAqB,8BAA8B,eAAe,iCAAiC,gBAAgB,gCAAgC,uCAAuC,WAAW,KAAK,wBAAwB,gBAAgB,mBAAmB,kFAAkF,8BAA8B,yBAAyB,oDAAoD,YAAY,uBAAuB,KAAK,4CAA4C,8DAA8D,gBAAgB,SAAS,uBAAuB,iBAAiB,kCAAkC,iBAAiB,gBAAgB,0CAA0C,kBAAkB,8BAA8B,WAAW,KAAK,qBAAqB,IAAI,kDAAkD,SAAS,gCAAgC,kCAAkC,iBAAiB,gBAAgB,8BAA8B,6DAA6D,qDAAqD,2EAA2E,aAAa,kIAAkI,yCAAyC,WAAW,mDAAmD,uGAAuG,eAAe,gCAAgC,0DAA0D,kCAAkC,iBAAiB,gBAAgB,8BAA8B,6DAA6D,+BAA+B,qDAAqD,+BAA+B,kDAAkD,yCAAyC,oFAAoF,aAAa,0PAA0P,uCAAuC,kLAAkL,yCAAyC,+FAA+F,uCAAuC,2DAA2D,gEAAgE,iBAAiB,+BAA+B,qEAAqE,kCAAkC,iBAAiB,gBAAgB,4BAA4B,kCAAkC,2BAA2B,4CAA4C,6BAA6B,mBAAmB,kCAAkC,iBAAiB,gBAAgB,gCAAgC,mDAAmD,wBAAwB,gOAAgO,2GAA2G,8CAA8C,kCAAkC,IAAI,mC","file":"index.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId])\n \t\t\treturn installedModules[moduleId].exports;\n\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\texports: {},\n \t\t\tid: moduleId,\n \t\t\tloaded: false\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.loaded = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(0);\n\n\n\n/** WEBPACK FOOTER **\n ** webpack/bootstrap 96e0afcc657690376e54\n **/","'use strict'\n\nrequire('./styles/base.scss')\n\nvar config = require('./config')\nvar Loader = require('./loader')\nvar utils = require('./utils')\nvar protocol = require('./protocol')\nvar ComponentManager = require('./componentManager')\nvar Component = require('./components/component')\nvar Sender = require('./bridge/sender')\nvar receiver = require('./bridge/receiver')\n\n// Components and apis.\nvar components = require('./components')\nvar api = require('./api')\nrequire('envd')\n\nvar WEAPP_STYLE_ID = 'weapp-style'\n\nvar DEFAULT_DESIGN_WIDTH = 750\nvar DEFAULT_ROOT_ID = 'weex'\nvar DEFAULT_JSON_CALLBACK_NAME = 'weexJsonpCallback'\n\n// config.scale = window.innerWidth / DEFAULT_DESIGN_WIDTH\n\nwindow.WXEnvironment = {\n  weexVersion: config.weexVersion,\n  appName: lib.env.aliapp ? lib.env.aliapp.appname : null,\n  appVersion: lib.env.aliapp ? lib.env.aliapp.version.val : null,\n  platform: lib.env.os ? lib.env.os.name : null,\n  osVersion: lib.env.os ? lib.env.os.version.val : null,\n  deviceHeight: window.innerHeight / config.scale\n}\n\nvar _instanceMap = {}\n\nfunction Weex(options) {\n\n  if (!(this instanceof Weex)) {\n    return new Weex(options)\n  }\n\n  // Width of the root container. Default is window.innerWidth.\n  this.width = options.width || window.innerWidth\n  this.bundleUrl = options.bundleUrl || location.href\n  this.instanceId = options.appId\n  this.rootId = options.rootId || (DEFAULT_ROOT_ID + utils.getRandom(10))\n  this.designWidth = options.designWidth || DEFAULT_DESIGN_WIDTH\n  this.jsonpCallback = options.jsonpCallback || DEFAULT_JSON_CALLBACK_NAME\n  this.source = options.source\n  this.loader = options.loader\n\n  this.data = options.data\n\n  this.initScale()\n  this.initComponentManager()\n  this.initBridge()\n  Weex.addInstance(this)\n\n  protocol.injectWeexInstance(this)\n\n  this.loadBundle(function (err, appCode) {\n    if (!err) {\n      this.createApp(config, appCode)\n    } else {\n      console.error('load bundle err:', err)\n    }\n  }.bind(this))\n\n}\n\nWeex.init = function (options) {\n  if (utils.isArray(options)) {\n    options.forEach(function (config) {\n      new Weex(config)\n    })\n  } else if (\n      Object.prototype.toString.call(options).slice(8, -1) === 'Object'\n    ) {\n    new Weex(options)\n  }\n}\n\nWeex.addInstance = function (instance) {\n  _instanceMap[instance.instanceId] = instance\n}\n\nWeex.getInstance = function (instanceId) {\n  return _instanceMap[instanceId]\n}\n\nWeex.prototype = {\n\n  initBridge: function () {\n    receiver.init(this)\n    this.sender = new Sender(this)\n  },\n\n  loadBundle: function (cb) {\n    Loader.load({\n      jsonpCallback: this.jsonpCallback,\n      source: this.source,\n      loader: this.loader\n    }, cb)\n  },\n\n  createApp: function (config, appCode) {\n    var root = document.querySelector('#' + this.rootId)\n    if (!root) {\n      root = document.createElement('div')\n      root.id = this.rootId\n      document.body.appendChild(root)\n    }\n\n    var promise = window.createInstance(\n      this.instanceId\n      , appCode\n      , {\n        bundleUrl: this.bundleUrl,\n        debug: config.debug\n      }\n      , this.data\n    )\n\n    if (Promise && promise instanceof Promise) {\n      promise.then(function () {\n        // Weex._instances[this.instanceId] = this.root\n      }.bind(this)).catch(function (err) {\n        if (err && config.debug) {\n          console.error(err)\n        }\n      })\n    }\n\n    // Do not destroy instance here, because in most browser\n    // press back button to back to this page will not refresh\n    // the window and the instance will not be recreated then.\n    // window.addEventListener('beforeunload', function (e) {\n    // })\n\n  },\n\n  initScale: function () {\n    this.scale = this.width / this.designWidth\n  },\n\n  initComponentManager: function () {\n    this._componentManager = new ComponentManager(this)\n  },\n\n  getComponentManager: function () {\n    return this._componentManager\n  }\n}\n\nWeex.appendStyle = function (css) {\n  utils.appendStyle(css, WEAPP_STYLE_ID)\n},\n\n// Register a new component with the specified name.\nWeex.registerComponent = function (name, comp) {\n  ComponentManager.registerComponent(name, comp)\n},\n\n// Register a new api module.\n// If the module already exists, just add methods from the\n// new module to the old one.\nWeex.registerApiModule = function (name, module, meta) {\n  if (!protocol.apiModule[name]) {\n    protocol.apiModule[name] = module\n  } else {\n    for (var key in module) {\n      if (module.hasOwnProperty(key)) {\n        protocol.apiModule[name][key] = module[key]\n      }\n    }\n  }\n  // register API module's meta info to jsframework\n  if (meta) {\n    protocol.setApiModuleMeta(meta)\n    window.registerModules(protocol.getApiModuleMeta(name), true)\n  }\n},\n\n// Register a new api method for the specified module.\n// opts:\n//  - args: type of arguments the API method takes such\n//    as ['string', 'function']\nWeex.registerApi = function (moduleName, name, method, args) {\n  if (typeof method !== 'function') {\n    return\n  }\n  if (!protocol.apiModule[moduleName]) {\n    protocol.apiModule[moduleName] = {}\n    protocol._meta[moduleName] = []\n  }\n  protocol.apiModule[moduleName][name] = method\n  if (!args) {\n    return\n  }\n  // register API meta info to jsframework\n  protocol.setApiMeta(moduleName, {\n    name: name,\n    args: args\n  })\n  window.registerModules(protocol.getApiModuleMeta(moduleName, meta), true)\n},\n\n// Register a new weex-bundle-loader.\nWeex.registerLoader = function (name, loaderFunc) {\n  Loader.registerLoader(name, loaderFunc)\n}\n\n// To install components and plugins.\nWeex.install = function (mod) {\n  mod.init(Weex)\n}\n\nWeex.stopTheWorld = function () {\n  for (var instanceId in _instanceMap) {\n    if (_instanceMap.hasOwnProperty(instanceId)) {\n      window.destroyInstance(instanceId)\n    }\n  }\n}\n\n(function startRefreshController() {\n  if (location.search.indexOf('hot-reload_controller') === -1)  {\n    return\n  }\n  if (!window.WebSocket) {\n    console.info('auto refresh need WebSocket support')\n    return\n  }\n  var host = location.hostname\n  var port = 8082\n  var client = new WebSocket('ws://' + host + ':' + port + '/',\n    'echo-protocol'\n  )\n  client.onerror = function () {\n    console.log('refresh controller websocket connection error')\n  }\n  client.onmessage = function (e) {\n    console.log('Received: \\'' + e.data + '\\'')\n    if (e.data  === 'refresh') {\n      location.reload()\n    }\n  }\n}())\n\n// Weex.install(require('weex-components'))\nWeex.install(components)\nWeex.install(api)\n\nWeex.Component = Component\nWeex.ComponentManager = ComponentManager\nWeex.utils = utils\nWeex.config = config\n\nglobal.weex = Weex\nmodule.exports = Weex\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/weex.js\n ** module id = 0\n ** module chunks = 0\n **/","// style-loader: Adds some css to the DOM by adding a <style> tag\n\n// load the styles\nvar content = require(\"!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./base.scss\");\nif(typeof content === 'string') content = [[module.id, content, '']];\n// add the styles to the DOM\nvar update = require(\"!./../../node_modules/style-loader/addStyles.js\")(content, {});\nif(content.locals) module.exports = content.locals;\n// Hot Module Replacement\nif(module.hot) {\n\t// When the styles change, update the <style> tags\n\tif(!content.locals) {\n\t\tmodule.hot.accept(\"!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./base.scss\", function() {\n\t\t\tvar newContent = require(\"!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./base.scss\");\n\t\t\tif(typeof newContent === 'string') newContent = [[module.id, newContent, '']];\n\t\t\tupdate(newContent);\n\t\t});\n\t}\n\t// When the module is disposed, remove the <style> tags\n\tmodule.hot.dispose(function() { update(); });\n}\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/styles/base.scss\n ** module id = 1\n ** module chunks = 0\n **/","exports = module.exports = require(\"./../../node_modules/css-loader/lib/css-base.js\")();\n// imports\n\n\n// module\nexports.push([module.id, \"* {\\n  margin: 0;\\n  padding: 0;\\n  text-size-adjust: none; }\\n\\nul, ol {\\n  list-style: none; }\\n\", \"\", {\"version\":3,\"sources\":[\"/./src/src/styles/base.scss\"],\"names\":[],\"mappings\":\"AAAA;EACE,UAAS;EACT,WAAU;EACV,uBACD,EAAC;;AACF;EACE,iBACD,EAAC\",\"file\":\"base.scss\",\"sourcesContent\":[\"* {\\n  margin:0;\\n  padding:0;\\n  text-size-adjust:none\\n}\\nul,ol {\\n  list-style:none\\n}\"],\"sourceRoot\":\"webpack://\"}]);\n\n// exports\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/css-loader?sourceMap!./~/sass-loader?sourceMap!./src/styles/base.scss\n ** module id = 2\n ** module chunks = 0\n **/","/*\r\n\tMIT License http://www.opensource.org/licenses/mit-license.php\r\n\tAuthor Tobias Koppers @sokra\r\n*/\r\n// css base code, injected by the css-loader\r\nmodule.exports = function() {\r\n\tvar list = [];\r\n\r\n\t// return the list of modules as css string\r\n\tlist.toString = function toString() {\r\n\t\tvar result = [];\r\n\t\tfor(var i = 0; i < this.length; i++) {\r\n\t\t\tvar item = this[i];\r\n\t\t\tif(item[2]) {\r\n\t\t\t\tresult.push(\"@media \" + item[2] + \"{\" + item[1] + \"}\");\r\n\t\t\t} else {\r\n\t\t\t\tresult.push(item[1]);\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn result.join(\"\");\r\n\t};\r\n\r\n\t// import a list of modules into the list\r\n\tlist.i = function(modules, mediaQuery) {\r\n\t\tif(typeof modules === \"string\")\r\n\t\t\tmodules = [[null, modules, \"\"]];\r\n\t\tvar alreadyImportedModules = {};\r\n\t\tfor(var i = 0; i < this.length; i++) {\r\n\t\t\tvar id = this[i][0];\r\n\t\t\tif(typeof id === \"number\")\r\n\t\t\t\talreadyImportedModules[id] = true;\r\n\t\t}\r\n\t\tfor(i = 0; i < modules.length; i++) {\r\n\t\t\tvar item = modules[i];\r\n\t\t\t// skip already imported module\r\n\t\t\t// this implementation is not 100% perfect for weird media query combinations\r\n\t\t\t//  when a module is imported multiple times with different media queries.\r\n\t\t\t//  I hope this will never occur (Hey this way we have smaller bundles)\r\n\t\t\tif(typeof item[0] !== \"number\" || !alreadyImportedModules[item[0]]) {\r\n\t\t\t\tif(mediaQuery && !item[2]) {\r\n\t\t\t\t\titem[2] = mediaQuery;\r\n\t\t\t\t} else if(mediaQuery) {\r\n\t\t\t\t\titem[2] = \"(\" + item[2] + \") and (\" + mediaQuery + \")\";\r\n\t\t\t\t}\r\n\t\t\t\tlist.push(item);\r\n\t\t\t}\r\n\t\t}\r\n\t};\r\n\treturn list;\r\n};\r\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/css-loader/lib/css-base.js\n ** module id = 3\n ** module chunks = 0\n **/","/*\r\n\tMIT License http://www.opensource.org/licenses/mit-license.php\r\n\tAuthor Tobias Koppers @sokra\r\n*/\r\nvar stylesInDom = {},\r\n\tmemoize = function(fn) {\r\n\t\tvar memo;\r\n\t\treturn function () {\r\n\t\t\tif (typeof memo === \"undefined\") memo = fn.apply(this, arguments);\r\n\t\t\treturn memo;\r\n\t\t};\r\n\t},\r\n\tisOldIE = memoize(function() {\r\n\t\treturn /msie [6-9]\\b/.test(window.navigator.userAgent.toLowerCase());\r\n\t}),\r\n\tgetHeadElement = memoize(function () {\r\n\t\treturn document.head || document.getElementsByTagName(\"head\")[0];\r\n\t}),\r\n\tsingletonElement = null,\r\n\tsingletonCounter = 0,\r\n\tstyleElementsInsertedAtTop = [];\r\n\r\nmodule.exports = function(list, options) {\r\n\tif(typeof DEBUG !== \"undefined\" && DEBUG) {\r\n\t\tif(typeof document !== \"object\") throw new Error(\"The style-loader cannot be used in a non-browser environment\");\r\n\t}\r\n\r\n\toptions = options || {};\r\n\t// Force single-tag solution on IE6-9, which has a hard limit on the # of <style>\r\n\t// tags it will allow on a page\r\n\tif (typeof options.singleton === \"undefined\") options.singleton = isOldIE();\r\n\r\n\t// By default, add <style> tags to the bottom of <head>.\r\n\tif (typeof options.insertAt === \"undefined\") options.insertAt = \"bottom\";\r\n\r\n\tvar styles = listToStyles(list);\r\n\taddStylesToDom(styles, options);\r\n\r\n\treturn function update(newList) {\r\n\t\tvar mayRemove = [];\r\n\t\tfor(var i = 0; i < styles.length; i++) {\r\n\t\t\tvar item = styles[i];\r\n\t\t\tvar domStyle = stylesInDom[item.id];\r\n\t\t\tdomStyle.refs--;\r\n\t\t\tmayRemove.push(domStyle);\r\n\t\t}\r\n\t\tif(newList) {\r\n\t\t\tvar newStyles = listToStyles(newList);\r\n\t\t\taddStylesToDom(newStyles, options);\r\n\t\t}\r\n\t\tfor(var i = 0; i < mayRemove.length; i++) {\r\n\t\t\tvar domStyle = mayRemove[i];\r\n\t\t\tif(domStyle.refs === 0) {\r\n\t\t\t\tfor(var j = 0; j < domStyle.parts.length; j++)\r\n\t\t\t\t\tdomStyle.parts[j]();\r\n\t\t\t\tdelete stylesInDom[domStyle.id];\r\n\t\t\t}\r\n\t\t}\r\n\t};\r\n}\r\n\r\nfunction addStylesToDom(styles, options) {\r\n\tfor(var i = 0; i < styles.length; i++) {\r\n\t\tvar item = styles[i];\r\n\t\tvar domStyle = stylesInDom[item.id];\r\n\t\tif(domStyle) {\r\n\t\t\tdomStyle.refs++;\r\n\t\t\tfor(var j = 0; j < domStyle.parts.length; j++) {\r\n\t\t\t\tdomStyle.parts[j](item.parts[j]);\r\n\t\t\t}\r\n\t\t\tfor(; j < item.parts.length; j++) {\r\n\t\t\t\tdomStyle.parts.push(addStyle(item.parts[j], options));\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\tvar parts = [];\r\n\t\t\tfor(var j = 0; j < item.parts.length; j++) {\r\n\t\t\t\tparts.push(addStyle(item.parts[j], options));\r\n\t\t\t}\r\n\t\t\tstylesInDom[item.id] = {id: item.id, refs: 1, parts: parts};\r\n\t\t}\r\n\t}\r\n}\r\n\r\nfunction listToStyles(list) {\r\n\tvar styles = [];\r\n\tvar newStyles = {};\r\n\tfor(var i = 0; i < list.length; i++) {\r\n\t\tvar item = list[i];\r\n\t\tvar id = item[0];\r\n\t\tvar css = item[1];\r\n\t\tvar media = item[2];\r\n\t\tvar sourceMap = item[3];\r\n\t\tvar part = {css: css, media: media, sourceMap: sourceMap};\r\n\t\tif(!newStyles[id])\r\n\t\t\tstyles.push(newStyles[id] = {id: id, parts: [part]});\r\n\t\telse\r\n\t\t\tnewStyles[id].parts.push(part);\r\n\t}\r\n\treturn styles;\r\n}\r\n\r\nfunction insertStyleElement(options, styleElement) {\r\n\tvar head = getHeadElement();\r\n\tvar lastStyleElementInsertedAtTop = styleElementsInsertedAtTop[styleElementsInsertedAtTop.length - 1];\r\n\tif (options.insertAt === \"top\") {\r\n\t\tif(!lastStyleElementInsertedAtTop) {\r\n\t\t\thead.insertBefore(styleElement, head.firstChild);\r\n\t\t} else if(lastStyleElementInsertedAtTop.nextSibling) {\r\n\t\t\thead.insertBefore(styleElement, lastStyleElementInsertedAtTop.nextSibling);\r\n\t\t} else {\r\n\t\t\thead.appendChild(styleElement);\r\n\t\t}\r\n\t\tstyleElementsInsertedAtTop.push(styleElement);\r\n\t} else if (options.insertAt === \"bottom\") {\r\n\t\thead.appendChild(styleElement);\r\n\t} else {\r\n\t\tthrow new Error(\"Invalid value for parameter 'insertAt'. Must be 'top' or 'bottom'.\");\r\n\t}\r\n}\r\n\r\nfunction removeStyleElement(styleElement) {\r\n\tstyleElement.parentNode.removeChild(styleElement);\r\n\tvar idx = styleElementsInsertedAtTop.indexOf(styleElement);\r\n\tif(idx >= 0) {\r\n\t\tstyleElementsInsertedAtTop.splice(idx, 1);\r\n\t}\r\n}\r\n\r\nfunction createStyleElement(options) {\r\n\tvar styleElement = document.createElement(\"style\");\r\n\tstyleElement.type = \"text/css\";\r\n\tinsertStyleElement(options, styleElement);\r\n\treturn styleElement;\r\n}\r\n\r\nfunction createLinkElement(options) {\r\n\tvar linkElement = document.createElement(\"link\");\r\n\tlinkElement.rel = \"stylesheet\";\r\n\tinsertStyleElement(options, linkElement);\r\n\treturn linkElement;\r\n}\r\n\r\nfunction addStyle(obj, options) {\r\n\tvar styleElement, update, remove;\r\n\r\n\tif (options.singleton) {\r\n\t\tvar styleIndex = singletonCounter++;\r\n\t\tstyleElement = singletonElement || (singletonElement = createStyleElement(options));\r\n\t\tupdate = applyToSingletonTag.bind(null, styleElement, styleIndex, false);\r\n\t\tremove = applyToSingletonTag.bind(null, styleElement, styleIndex, true);\r\n\t} else if(obj.sourceMap &&\r\n\t\ttypeof URL === \"function\" &&\r\n\t\ttypeof URL.createObjectURL === \"function\" &&\r\n\t\ttypeof URL.revokeObjectURL === \"function\" &&\r\n\t\ttypeof Blob === \"function\" &&\r\n\t\ttypeof btoa === \"function\") {\r\n\t\tstyleElement = createLinkElement(options);\r\n\t\tupdate = updateLink.bind(null, styleElement);\r\n\t\tremove = function() {\r\n\t\t\tremoveStyleElement(styleElement);\r\n\t\t\tif(styleElement.href)\r\n\t\t\t\tURL.revokeObjectURL(styleElement.href);\r\n\t\t};\r\n\t} else {\r\n\t\tstyleElement = createStyleElement(options);\r\n\t\tupdate = applyToTag.bind(null, styleElement);\r\n\t\tremove = function() {\r\n\t\t\tremoveStyleElement(styleElement);\r\n\t\t};\r\n\t}\r\n\r\n\tupdate(obj);\r\n\r\n\treturn function updateStyle(newObj) {\r\n\t\tif(newObj) {\r\n\t\t\tif(newObj.css === obj.css && newObj.media === obj.media && newObj.sourceMap === obj.sourceMap)\r\n\t\t\t\treturn;\r\n\t\t\tupdate(obj = newObj);\r\n\t\t} else {\r\n\t\t\tremove();\r\n\t\t}\r\n\t};\r\n}\r\n\r\nvar replaceText = (function () {\r\n\tvar textStore = [];\r\n\r\n\treturn function (index, replacement) {\r\n\t\ttextStore[index] = replacement;\r\n\t\treturn textStore.filter(Boolean).join('\\n');\r\n\t};\r\n})();\r\n\r\nfunction applyToSingletonTag(styleElement, index, remove, obj) {\r\n\tvar css = remove ? \"\" : obj.css;\r\n\r\n\tif (styleElement.styleSheet) {\r\n\t\tstyleElement.styleSheet.cssText = replaceText(index, css);\r\n\t} else {\r\n\t\tvar cssNode = document.createTextNode(css);\r\n\t\tvar childNodes = styleElement.childNodes;\r\n\t\tif (childNodes[index]) styleElement.removeChild(childNodes[index]);\r\n\t\tif (childNodes.length) {\r\n\t\t\tstyleElement.insertBefore(cssNode, childNodes[index]);\r\n\t\t} else {\r\n\t\t\tstyleElement.appendChild(cssNode);\r\n\t\t}\r\n\t}\r\n}\r\n\r\nfunction applyToTag(styleElement, obj) {\r\n\tvar css = obj.css;\r\n\tvar media = obj.media;\r\n\r\n\tif(media) {\r\n\t\tstyleElement.setAttribute(\"media\", media)\r\n\t}\r\n\r\n\tif(styleElement.styleSheet) {\r\n\t\tstyleElement.styleSheet.cssText = css;\r\n\t} else {\r\n\t\twhile(styleElement.firstChild) {\r\n\t\t\tstyleElement.removeChild(styleElement.firstChild);\r\n\t\t}\r\n\t\tstyleElement.appendChild(document.createTextNode(css));\r\n\t}\r\n}\r\n\r\nfunction updateLink(linkElement, obj) {\r\n\tvar css = obj.css;\r\n\tvar sourceMap = obj.sourceMap;\r\n\r\n\tif(sourceMap) {\r\n\t\t// http://stackoverflow.com/a/26603875\r\n\t\tcss += \"\\n/*# sourceMappingURL=data:application/json;base64,\" + btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap)))) + \" */\";\r\n\t}\r\n\r\n\tvar blob = new Blob([css], { type: \"text/css\" });\r\n\r\n\tvar oldSrc = linkElement.href;\r\n\r\n\tlinkElement.href = URL.createObjectURL(blob);\r\n\r\n\tif(oldSrc)\r\n\t\tURL.revokeObjectURL(oldSrc);\r\n}\r\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/style-loader/addStyles.js\n ** module id = 4\n ** module chunks = 0\n **/","'use strict'\n\nvar config = {\n\n  weexVersion: '1.4.0',\n\n  debug: true\n\n}\n\nmodule.exports = config\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/config.js\n ** module id = 5\n ** module chunks = 0\n **/","'use strict'\n\nfunction loadByXHR(config, callback) {\n  if (!config.source) {\n    callback(new Error('xhr loader: missing config.source.'))\n  }\n  var xhr = new XMLHttpRequest()\n  xhr.open('GET', config.source)\n  xhr.onload = function () {\n    callback(null, this.responseText)\n  }\n  xhr.onerror = function (error) {\n    callback(error)\n  }\n  xhr.send()\n}\n\nfunction loadByJsonp(config, callback) {\n  if (!config.source) {\n    callback(new Error('jsonp loader: missing config.source.'))\n  }\n  var callbackName = config.jsonpCallback || 'weexJsonpCallback'\n  window[callbackName] = function (code) {\n    if (code) {\n      callback(null, code)\n    } else {\n      callback(new Error('load by jsonp error'))\n    }\n  }\n  var script = document.createElement('script')\n  script.src = decodeURIComponent(config.source)\n  script.type = 'text/javascript'\n  document.body.appendChild(script)\n}\n\nfunction loadBySourceCode(config, callback) {\n  // src is the jsbundle.\n  // no need to fetch from anywhere.\n  if (config.source) {\n    callback(null, config.source)\n  } else {\n    callback(new Error('source code laoder: missing config.source.'))\n  }\n}\n\nvar callbackMap = {\n  xhr: loadByXHR,\n  jsonp: loadByJsonp,\n  source: loadBySourceCode\n}\n\nfunction load(options, callback) {\n  var loadFn = callbackMap[options.loader]\n  loadFn(options, callback)\n}\n\nfunction registerLoader(name, loaderFunc) {\n  if (typeof loaderFunc === 'function') {\n    callbackMap[name] = loaderFunc\n  }\n}\n\nmodule.exports = {\n  load: load,\n  registerLoader: registerLoader\n}\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/loader.js\n ** module id = 6\n ** module chunks = 0\n **/","'use strict'\n\nvar WEAPP_STYLE_ID = 'weapp-style'\n\nvar _isWebpSupported = false\n\n; (function isSupportWebp() {\n  try {\n    var webP = new Image()\n    webP.src = 'data:image/webp;base64,UklGRjoAAABXRUJQVlA4IC4AAACyAgCdA'\n              + 'SoCAAIALmk0mk0iIiIiIgBoSygABc6WWgAA/veff/0PP8bA//LwYAAA'\n    webP.onload = function () {\n      if (webP.height === 2) {\n        _isWebpSupported = true\n      }\n    }\n  } catch (e) {\n    // do nothing.\n  }\n})()\n\nfunction extend(to, from) {\n  for (var key in from) {\n    to[key] = from[key]\n  }\n  return to\n}\n\nfunction isArray(arr) {\n  return Array.isArray\n    ? Array.isArray(arr)\n    : (Object.prototype.toString.call(arr) === '[object Array]')\n}\n\nfunction appendStyle(css, styleId, replace) {\n  var style = document.getElementById(styleId)\n  if (style && replace) {\n    style.parentNode.removeChild(style)\n    style = null\n  }\n  if (!style) {\n    style = document.createElement('style')\n    style.type = 'text/css'\n    styleId && (style.id = styleId)\n    document.getElementsByTagName('head')[0].appendChild(style)\n  }\n  style.appendChild(document.createTextNode(css))\n}\n\nfunction getUniqueFromArray(arr) {\n  if (!isArray(arr)) {\n    return []\n  }\n  var res = []\n  var unique = {}\n  var val\n  for (var i = 0, l = arr.length; i < l; i++) {\n    val = arr[i]\n    if (unique[val]) {\n      continue\n    }\n    unique[val] = true\n    res.push(val)\n  }\n  return res\n}\n\nfunction transitionize(element, props) {\n  var transitions = []\n  for (var key in props) {\n    transitions.push(key + ' ' + props[key])\n  }\n  element.style.transition = transitions.join(', ')\n  element.style.webkitTransition = transitions.join(', ')\n}\n\nfunction detectWebp() {\n  return _isWebpSupported\n}\n\nfunction getRandom(num) {\n  var _defaultNum = 10\n  if (typeof num !== 'number' || num <= 0) {\n    num = _defaultNum\n  }\n  var _max = Math.pow(10, num)\n  return Math.floor(Date.now() + Math.random() * _max) % _max\n}\n\nmodule.exports = {\n  extend: extend,\n  isArray: isArray,\n  appendStyle: appendStyle,\n  getUniqueFromArray: getUniqueFromArray,\n  transitionize: transitionize,\n  detectWebp: detectWebp,\n  getRandom: getRandom\n}\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/utils.js\n ** module id = 7\n ** module chunks = 0\n **/","'use strict'\n\nvar extend = require('./utils').extend\nvar isArray = require('./utils').isArray\nvar ComponentManager = require('./componentManager')\n\n// for jsframework to register modules.\nvar _registerModules = function (config) {\n  if (isArray(config)) {\n    for (var i = 0, l = config.length; i < l; i++) {\n      window.registerModules(config[i])\n    }\n  } else {\n    window.registerModules(config)\n  }\n}\n\nvar protocol = {\n\n  // weex instances\n  _instances: [],\n\n  // api meta info\n  _meta: [],\n\n  apiModule: {},\n\n  injectWeexInstance: function (instance) {\n    this._instances[instance.instanceId] = instance\n  },\n\n  getWeexInstance: function (instanceId) {\n    return this._instances[instanceId]\n  },\n\n  // get the api method meta info array for the module.\n  getApiModuleMeta: function (moduleName) {\n    var metaObj = {}\n    metaObj[moduleName] = this._meta[moduleName]\n    return metaObj\n  },\n\n  // Set meta info for a api module.\n  // If there is a same named api, just replace it.\n  // opts:\n  // - metaObj: meta object like\n  // {\n  //    dom: [{\n  //      name: 'addElement',\n  //      args: ['string', 'object']\n  //    }]\n  // }\n  setApiModuleMeta: function (metaObj) {\n    var moduleName\n    for (var k in metaObj) {\n      if (metaObj.hasOwnProperty(k)) {\n        moduleName = k\n      }\n    }\n    var metaArray = this._meta[moduleName]\n    if (!metaArray) {\n      this._meta[moduleName] = metaObj[moduleName]\n    } else {\n      var nameObj = {}\n      metaObj[moduleName].forEach(function (api) {\n        nameObj[api.name] = api\n      })\n      metaArray.forEach(function (api, i) {\n        if (nameObj[api.name]) {\n          metaArray[i] = nameObj[api.name]\n          delete nameObj[api.name]\n        }\n      })\n      for (var k in metaObj) {\n        if (metaObj.hasOwnProperty(k)) {\n          metaArray.push(metaObj[k])\n        }\n      }\n    }\n    this._meta[moduleName] = metaObj[moduleName]\n  },\n\n  // Set meta info for a single api.\n  // opts:\n  //  - moduleName: api module name.\n  //  - meta: a meta object like:\n  //  {\n  //    name: 'addElement',\n  //    args: ['string', 'object']\n  //  }\n  setApiMeta: function (moduleName, meta) {\n    var metaArray = this._meta[moduleName]\n    if (!metaArray) {\n      this._meta[moduleName] = [meta]\n    } else {\n      var metaIdx = -1\n      metaArray.forEach(function (api, i) {\n        if (meta.name === name) {\n          metaIdx = i\n        }\n      })\n      if (metaIdx !== -1) {\n        metaArray[metaIdx] = meta\n      } else {\n        metaArray.push(meta)\n      }\n    }\n  }\n}\n\n_registerModules([{\n  modal: [{\n    name: 'toast',\n    args: ['object', 'function']\n  }, {\n    name: 'alert',\n    args: ['object', 'function']\n  }, {\n    name: 'confirm',\n    args: ['object', 'function']\n  }, {\n    name: 'prompt',\n    args: ['object', 'function']\n  }]\n}, {\n  animation: [{\n    name: 'transition',\n    args: ['string', 'object', 'function']\n  }]\n}])\n\nmodule.exports = protocol\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/protocol.js\n ** module id = 8\n ** module chunks = 0\n **/","'use strict'\n\nvar config = require('./config')\nvar FrameUpdater = require('./frameUpdater')\nvar AppearWatcher = require('./appearWatcher')\nvar utils = require('./utils')\nvar LazyLoad = require('./lazyLoad')\nvar animation = require('./animation')\n\nvar RENDERING_INDENT = 800\n\nvar _instanceMap = {}\nvar typeMap = {}\nvar scrollableTypes = ['scroller', 'list']\n\nfunction ComponentManager(instance) {\n  this.instanceId = instance.instanceId\n  this.weexInstance = instance\n  this.componentMap = {}\n  _instanceMap[this.instanceId] = this\n}\n\nComponentManager.getInstance = function (instanceId) {\n  return _instanceMap[instanceId]\n}\n\nComponentManager.getWeexInstance = function (instanceId) {\n  return _instanceMap[instanceId].weexInstance\n}\n\nComponentManager.registerComponent = function (type, definition) {\n  typeMap[type] = definition\n}\n\nComponentManager.getScrollableTypes = function () {\n  return scrollableTypes\n}\n\nComponentManager.prototype = {\n\n  // Fire a event 'renderbegin'/'renderend' on body element.\n  rendering: function () {\n    function _renderingEnd() {\n      // get weex instance root\n      window.dispatchEvent(new Event('renderend'))\n      this._renderingTimer = null\n    }\n    if (this._renderingTimer) {\n      clearTimeout(this._renderingTimer)\n      this._renderingTimer = setTimeout(\n        _renderingEnd.bind(this),\n        RENDERING_INDENT\n      )\n    } else {\n      window.dispatchEvent(new Event('renderbegin'))\n      this._renderingTimer = setTimeout(\n        _renderingEnd.bind(this),\n        RENDERING_INDENT\n      )\n    }\n  },\n\n  getElementByRef: function (ref) {\n    return this.componentMap[ref]\n  },\n\n  removeElementByRef: function (ref) {\n    var cmp\n    var self = this\n    if (!ref || !(cmp = this.componentMap[ref])) {\n      return\n    }\n    // remove from this.componentMap cursively\n    (function _removeCursively(_ref) {\n      var child = self.componentMap[_ref]\n      var listeners = child._listeners\n      var children = child.data.children\n      if (children && children.length) {\n        for (var i = 0, l = children.length; i < l; i++) {\n          _removeCursively(children[i].ref)\n        }\n      }\n      // remove events from _ref component\n      if (listeners) {\n        for (var type in listeners) {\n          child.node.removeEventListener(type, listeners[type])\n        }\n      }\n      delete child._listeners\n      delete child.node._listeners\n      // remove _ref component\n      delete self.componentMap[_ref]\n    })(ref)\n\n  },\n\n  createElement: function (data, nodeType) {\n    var ComponentType = typeMap[data.type]\n    if (!ComponentType) {\n      ComponentType = typeMap['container']\n    }\n\n    var ref = data.ref\n    var component = new ComponentType(data, nodeType)\n\n    this.componentMap[ref] = component\n    component.node.setAttribute('data-ref', ref)\n\n    return component\n  },\n\n  /**\n   * createBody: generate root component\n   * @param  {object} element\n   */\n  createBody: function (element) {\n\n    // TODO: creatbody on document.body\n    // no need to create a extra div\n    var root, body, nodeType\n    if (this.componentMap['_root']) {\n      return\n    }\n\n    nodeType = element.type\n    element.type = 'root'\n    element.rootId = this.weexInstance.rootId\n    element.ref = '_root'\n\n    var root = this.createElement(element, nodeType)\n    body = document.querySelector('#' + this.weexInstance.rootId)\n          || document.body\n    body.appendChild(root.node)\n    root._appended = true\n  },\n\n  appendChild: function (parentRef, data) {\n    var parent = this.componentMap[parentRef]\n\n    if (this.componentMap[data.ref] || !parent) {\n      return\n    }\n\n    if (parentRef === '_root' && !parent) {\n      parent = this.createElement({\n        type: 'root',\n        rootId: this.weexInstance.rootId,\n        ref: '_root'\n      })\n      parent._appended = true\n    }\n\n    var child = parent.appendChild(data)\n\n    // In some parent component the implementation of method\n    // appendChild didn't return the component at all, therefor\n    // child maybe a undefined object.\n    if (child) {\n      child.parentRef = parentRef\n    }\n\n    if (child && parent._appended) {\n      this.handleAppend(child)\n    }\n  },\n\n  appendChildren: function (ref, elements) {\n    for (var i = 0; i < elements.length; i++) {\n      this.appendChild(ref, elements[i])\n    }\n  },\n\n  removeElement: function (ref) {\n    var component = this.componentMap[ref]\n\n    // fire event for rendering dom on body elment.\n    this.rendering()\n\n    if (component && component.parentRef) {\n      var parent = this.componentMap[component.parentRef]\n      component.onRemove && component.onRemove()\n      parent.removeChild(component)\n    } else {\n      console.warn('ref: ', ref)\n    }\n  },\n\n  moveElement: function (ref, parentRef, index) {\n    var component = this.componentMap[ref]\n    var newParent = this.componentMap[parentRef]\n    var oldParentRef = component.parentRef\n    var children, before, i, l\n    if (!component || !newParent) {\n      console.warn('ref: ', ref)\n      return\n    }\n\n    // fire event for rendering dom on body elment.\n    this.rendering()\n\n    // remove from oldParent.data.children\n    if (oldParentRef && this.componentMap[oldParentRef]) {\n      children = this.componentMap[oldParentRef].data.children\n      if (children && children.length) {\n        for (i = 0, l = children.length; i < l; i++) {\n          if (children[i].ref === ref) {\n            break\n          }\n        }\n        if (l > i) {\n          children.splice(i, 1)\n        }\n      }\n    }\n\n    if (index < -1) {\n      index = -1\n      console.warn('index cannot be less than -1.')\n    }\n\n    children = newParent.data.children\n    if (children\n        && children.length\n        && index !== -1\n        && index < children.length) {\n      before = this.componentMap[newParent.data.children[index].ref]\n      newParent.insertBefore(component, before)\n    } else {  // append\n      newParent.insertBefore(component)\n    }\n\n    component.onMove && component.onMove(parentRef, index)\n\n  },\n\n  insertBefore: function (ref, data) {\n    var child, before, parent\n    before = this.componentMap[ref]\n    child = this.componentMap[data.ref]\n    before && (parent = this.componentMap[before.parentRef])\n    if (child || !parent || !before) {\n      return\n    }\n\n    child = this.createElement(data)\n    if (child) {\n      child.parentRef = before.parentRef\n      parent.insertBefore(child, before)\n    } else {\n      return\n    }\n\n    if (this.componentMap[before.parentRef]._appended) {\n      this.handleAppend(child)\n    }\n  },\n\n  /**\n   * addElement\n   * If index is larget than any child's index, the\n   * element will be appended behind.\n   * @param {string} parentRef\n   * @param {obj} element (data of the component)\n   * @param {number} index\n   */\n  addElement: function (parentRef, element, index) {\n    var parent, children, before\n\n    // fire event for rendering dom on body elment.\n    this.rendering()\n\n    parent = this.componentMap[parentRef]\n    if (!parent) {\n      return\n    }\n    children = parent.data.children\n    // -1 means append as the last.\n    if (index < -1) {\n      index = -1\n      console.warn('index cannot be less than -1.')\n    }\n    if (children && children.length\n        && children.length > index\n        && index !== -1) {\n      this.insertBefore(children[index].ref, element)\n    } else {\n      this.appendChild(parentRef, element)\n    }\n  },\n\n  clearChildren: function (ref) {\n    var component = this.componentMap[ref]\n    if (component) {\n      component.node.innerHTML = ''\n      if (component.data) {\n        component.data.children = null\n      }\n    }\n  },\n\n  addEvent: function (ref, type) {\n    var component\n    if (typeof ref === 'string' || typeof ref === 'number') {\n      component = this.componentMap[ref]\n    } else if (Object.prototype.toString.call(ref).slice(8, -1) === 'Object') {\n      component = ref\n      ref = component.data.ref\n    }\n    if (component && component.node) {\n      var sender = this.weexInstance.sender\n      var listener = sender.fireEvent.bind(sender, ref, type)\n      var listeners = component._listeners\n      component.node.addEventListener(type, listener, false, false)\n      if (!listeners) {\n        listeners = component._listeners = {}\n        component.node._listeners = {}\n      }\n      listeners[type] = listener\n      component.node._listeners[type] = listener\n    }\n  },\n\n  removeEvent: function (ref, type) {\n    var component = this.componentMap[ref]\n    var listener = component._listeners[type]\n    if (component && listener) {\n      component.node.removeEventListener(type, listener)\n      component._listeners[type] = null\n      component.node._listeners[type] = null\n    }\n  },\n\n  updateAttrs: function (ref, attr) {\n    var component = this.componentMap[ref]\n    if (component) {\n      component.updateAttrs(attr)\n      if (component.data.type === 'image' && attr.src) {\n        LazyLoad.startIfNeeded(component)\n      }\n    }\n  },\n\n  updateStyle: function (ref, style) {\n    var component = this.componentMap[ref]\n    if (component) {\n      component.updateStyle(style)\n    }\n  },\n\n  updateFullAttrs: function (ref, attr) {\n    var component = this.componentMap[ref]\n    if (component) {\n      component.clearAttr()\n      component.updateAttrs(attr)\n      if (component.data.type === 'image' && attr.src) {\n        LazyLoad.startIfNeeded(component)\n      }\n    }\n  },\n\n  updateFullStyle: function (ref, style) {\n    var component = this.componentMap[ref]\n    if (component) {\n      component.clearStyle()\n      component.updateStyle(style)\n    }\n  },\n\n  handleAppend: function (component) {\n    component._appended = true\n    component.onAppend && component.onAppend()\n\n    // invoke onAppend on children recursively\n    var children = component.data.children\n    if (children) {\n      for (var i = 0; i < children.length; i++) {\n        var child = this.componentMap[children[i].ref]\n        if (child) {\n          this.handleAppend(child)\n        }\n      }\n    }\n\n    // watch appear/disappear of the component if needed\n    AppearWatcher.watchIfNeeded(component)\n\n    // do lazyload if needed\n    LazyLoad.startIfNeeded(component)\n  },\n\n  transition: function (ref, config, callback) {\n    var component = this.componentMap[ref]\n    animation.transitionOnce(component, config, callback)\n  },\n\n  renderFinish: function () {\n    FrameUpdater.pause()\n  }\n}\n\nmodule.exports = ComponentManager\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/componentManager.js\n ** module id = 9\n ** module chunks = 0\n **/","'use strict'\n\nvar raf = window.requestAnimationFrame ||\n          window.webkitRequestAnimationFrame ||\n          function (calllback) {\n            setTimeout(calllback, 16)\n          }\n\nvar rafId\nvar observers = []\nvar paused = false\n\nvar FrameUpdater = {\n  start: function () {\n    if (rafId) {\n      return\n    }\n\n    rafId = raf(function runLoop() {\n      if (!paused) {\n        for (var i = 0; i < observers.length; i++) {\n          observers[i]()\n        }\n        raf(runLoop)\n      }\n    })\n  },\n\n  isActive: function () {\n    return !paused\n  },\n\n  pause: function () {\n    paused = true\n    rafId = undefined\n  },\n\n  resume: function () {\n    paused = false\n    this.start()\n  },\n\n  addUpdateObserver: function (observeMethod) {\n    observers.push(observeMethod)\n  }\n}\n\nmodule.exports = FrameUpdater\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/frameUpdater.js\n ** module id = 10\n ** module chunks = 0\n **/","'use strict'\n\nvar utils = require('./utils')\n\nvar componentsInScroller = []\nvar componentsOutOfScroller = []\nvar listened = false\nvar direction = 'up'\nvar scrollY = 0\n\nvar AppearWatcher = {\n  watchIfNeeded: function (component) {\n    if (needWatch(component)) {\n      if (component.isInScrollable()) {\n        componentsInScroller.push(component)\n      } else {\n        componentsOutOfScroller.push(component)\n      }\n      if (!listened) {\n        listened = true\n        // var handler = throttle(onScroll, 25)\n        var handler = throttle(onScroll, 100)\n        window.addEventListener('scroll', handler, false)\n      }\n    }\n  }\n}\n\nfunction needWatch(component) {\n  var events = component.data.event\n  if (events\n      && (events.indexOf('appear') != -1\n        || events.indexOf('disappear') != -1)) {\n    return true\n  }\n  return false\n}\n\nfunction onScroll(e) {\n  // If the scroll event is dispatched from a scrollable component\n  // implemented through scrollerjs, then the appear/disappear events\n  // should be treated specially by handleScrollerScroll.\n  if (e.originalType === 'scrolling') {\n    handleScrollerScroll()\n  } else {\n    handleWindowScroll()\n  }\n}\n\nfunction handleScrollerScroll() {\n  var cmps = componentsInScroller\n  var len = cmps.length\n  for (var i = 0; i < len; i++) {\n    var component = cmps[i]\n    var appear = isComponentInScrollerAppear(component)\n    if (appear && !component._appear) {\n      component._appear = true\n      fireEvent(component, 'appear')\n    } else if (!appear && component._appear) {\n      component._appear = false\n      fireEvent(component, 'disappear')\n    }\n  }\n}\n\nfunction handleWindowScroll() {\n  var y = window.scrollY\n  direction = y >= scrollY ? 'up' : 'down'\n  scrollY = y\n\n  var len = componentsOutOfScroller.length\n  if (len === 0) {\n    return\n  }\n  for (var i = 0; i < len; i++) {\n    var component = componentsOutOfScroller[i]\n    var appear = isComponentInWindow(component)\n    if (appear && !component._appear) {\n      component._appear = true\n      fireEvent(component, 'appear')\n    } else if (!appear && component._appear) {\n      component._appear = false\n      fireEvent(component, 'disappear')\n    }\n  }\n}\n\nfunction isComponentInScrollerAppear(component) {\n  var parentScroller = component._parentScroller\n  var cmpRect = component.node.getBoundingClientRect()\n  if (!isComponentInWindow(component)) {\n    return false\n  }\n  while (parentScroller) {\n    var parentRect = parentScroller.node.getBoundingClientRect()\n    if (!(cmpRect.right > parentRect.left\n        && cmpRect.left < parentRect.right\n        && cmpRect.bottom > parentRect.top\n        && cmpRect.top < parentRect.bottom)) {\n      return false\n    }\n    parentScroller = parentScroller._parentScroller\n  }\n  return true\n}\n\nfunction isComponentInWindow(component) {\n  var rect = component.node.getBoundingClientRect()\n  return rect.right > 0 && rect.left < window.innerWidth &&\n         rect.bottom > 0 && rect.top < window.innerHeight\n}\n\nfunction fireEvent(component, type) {\n  var evt = document.createEvent('HTMLEvents')\n  var data = { direction: direction }\n  evt.initEvent(type, false, false)\n  evt.data = data\n  utils.extend(evt, data)\n  component.node.dispatchEvent(evt)\n}\n\nfunction throttle(func, wait) {\n  var context, args, result\n  var timeout = null\n  var previous = 0\n  var later = function () {\n    previous = Date.now()\n    timeout = null\n    result = func.apply(context, args)\n  }\n  return function () {\n    var now = Date.now()\n    var remaining = wait - (now - previous)\n    context = this\n    args = arguments\n    if (remaining <= 0) {\n      clearTimeout(timeout)\n      timeout = null\n      previous = now\n      result = func.apply(context, args)\n    } else if (!timeout) {\n      timeout = setTimeout(later, remaining)\n    }\n    return result\n  }\n}\n\nmodule.exports = AppearWatcher\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/appearWatcher.js\n ** module id = 11\n ** module chunks = 0\n **/","'use strict'\n\nrequire('lazyimg')\n\nvar lazyloadTimer\n\nvar LazyLoad = {\n  makeImageLazy: function (image, src) {\n    image.removeAttribute('img-src')\n    image.removeAttribute('i-lazy-src')\n    image.removeAttribute('src')\n    image.setAttribute('img-src', src)\n    // should replace 'src' with 'img-src'. but for now lib.img.fire is\n    // not working for the situation that the appear event has been\n    // already triggered.\n    // image.setAttribute('src', src)\n    // image.setAttribute('img-src', src)\n    this.fire()\n  },\n\n  // we don't know when all image are appended\n  // just use setTimeout to do delay lazyload\n  //\n  // -- actually everytime we add a element or update styles,\n  // the component manager will call startIfNeed to fire\n  // lazyload once again in the handleAppend function. so there\n  // is no way that any image element can miss it. See source\n  // code in componentMangager.js.\n  startIfNeeded: function (component) {\n    var that = this\n    if (component.data.type === 'image') {\n      if (!lazyloadTimer) {\n        lazyloadTimer = setTimeout(function () {\n          that.fire()\n          clearTimeout(lazyloadTimer)\n          lazyloadTimer = null\n        }, 16)\n      }\n    }\n  },\n\n  loadIfNeeded: function (elementScope) {\n    var notPreProcessed = elementScope.querySelectorAll('[img-src]')\n    var that = this\n    // image elements which have attribute 'i-lazy-src' were elements\n    // that had been preprocessed by lib-img-core, but not loaded yet, and\n    // must be loaded when 'appear' events were fired. It turns out the\n    // 'appear' event was not fired correctly in the css-translate-transition\n    // situation, so 'i-lazy-src' must be checked and lazyload must be\n    // fired manually.\n    var preProcessed = elementScope.querySelectorAll('[i-lazy-src]')\n    if (notPreProcessed.length > 0 || preProcessed.length > 0) {\n      that.fire()\n    }\n  },\n\n  // fire lazyload.\n  fire: function () {\n    lib.img.fire()\n  }\n\n}\n\nmodule.exports = LazyLoad\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/lazyLoad.js\n ** module id = 12\n ** module chunks = 0\n **/","\"undefined\"==typeof window&&(window={ctrl:{},lib:{}}),!window.ctrl&&(window.ctrl={}),!window.lib&&(window.lib={}),function(t,i){function e(t,i){i&&(\"IMG\"==t.nodeName.toUpperCase()?t.setAttribute(\"src\",i):t.style.backgroundImage='url(\"'+i+'\")')}function a(){r=i.appear.init({cls:\"imgtmp\",once:!0,x:o.lazyWidth,y:o.lazyHeight,onAppear:function(t){var i=this;e(i,i.getAttribute(\"i-lazy-src\")),i.removeAttribute(\"i-lazy-src\")}})}require(\"appearjs\");var r,A={},o={dataSrc:\"img-src\",lazyHeight:0,lazyWidth:0};A.logConfig=function(){console.log(\"lib-img Config\\n\",o)},A.fire=function(){r||a();var t=\"i_\"+Date.now()%1e5,i=document.querySelectorAll(\"[\"+o.dataSrc+\"]\");[].forEach.call(i,function(i){\"false\"==i.dataset.lazy&&\"true\"!=i.dataset.lazy?e(i,processSrc(i,i.getAttribute(o.dataSrc))):(i.classList.add(t),i.setAttribute(\"i-lazy-src\",i.getAttribute(o.dataSrc))),i.removeAttribute(o.dataSrc)}),r.bind(\".\"+t),r.fire()},A.defaultSrc=\"data:image/gif;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAADUlEQVQImWNgYGBgAAAABQABh6FO1AAAAABJRU5ErkJggg==\",i.img=A,module.exports=A}(window,window.lib||(window.lib={}));\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/lazyimg/build/img.common.js\n ** module id = 13\n ** module chunks = 0\n **/","\"undefined\"==typeof window&&(window={ctrl:{},lib:{}}),!window.ctrl&&(window.ctrl={}),!window.lib&&(window.lib={}),function(n,e){function i(){d=w.createEvent(\"HTMLEvents\"),v=w.createEvent(\"HTMLEvents\"),d.initEvent(\"_appear\",!1,!0),v.initEvent(\"_disappear\",!1,!0)}function a(t,n){var e,i,a,s=(Date.now(),0),o=null,r=function(){s=Date.now(),o=null,t.apply(e,i)};return function(){var l=Date.now();e=this,i=arguments;var c=n-(l-s);return 0>=c||c>=n?(clearTimeout(o),o=null,a=t.apply(e,i)):null==o&&(o=setTimeout(r,c)),a}}function s(n,e){var n,i,a,s;if(n)return e||(e={x:0,y:0}),n!=window?(n=n.getBoundingClientRect(),i=n.left,t=n.top,a=n.right,s=n.bottom):(i=0,t=0,a=i+n.innerWidth,s=t+n.innerHeight),{left:i,top:t,right:a+e.x,bottom:s+e.y}}function o(t,n){var e=n.right>t.left&&n.left<t.right,i=n.bottom>t.top&&n.top<t.bottom;return e&&i}function r(t,n){var e=\"none\",i=t.left-n.left,a=t.top-n.top;return 0==a&&(e=0!=i?i>0?\"left\":\"right\":\"none\"),0==i&&(e=0!=a?a>0?\"up\":\"down\":\"none\"),e}function l(t,n){for(var e in n)n.hasOwnProperty(e)&&(t[e]=n[e]);return t}function c(){var t=this,n=a(function(){f.apply(t,arguments)},this.options.wait);this.__handle&&(this.container.removeEventListener(\"scroll\",this.__handle),this.__handle=null),this.__handle=n,this.container.addEventListener(\"scroll\",n,!1),this.container.addEventListener(\"resize\",function(n){f.apply(t,arguments)},!1),this.container.addEventListener(\"animationEnd\",function(){f.apply(t,arguments)},!1),this.container.addEventListener(\"webkitAnimationEnd\",function(){f.apply(t,arguments)},!1),this.container.addEventListener(\"transitionend\",function(){f.apply(t,arguments)},!1)}function p(t){var n=this,e=this.options.container;if(\"string\"==typeof e?this.container=w.querySelector(e):this.container=e,this.container==window)var i=w.querySelectorAll(t);else var i=this.container.querySelectorAll(t);var i=[].slice.call(i,null);return i=i.filter(function(t){return\"1\"==t.dataset.bind?(delete t._hasAppear,delete t._hasDisAppear,delete t._appear,t.classList.remove(n.options.cls),!1):!0})}function h(t){var n=this;t&&t.length>0&&[].forEach.call(t,function(t){t._eleOffset=s(t),t.classList.remove(n.options.cls),t.dataset.bind=1})}function f(){var t=this.container,n=this.appearWatchElements,e=this.options.onAppear,i=this.options.onDisappear,a=s(t,{x:this.options.x,y:this.options.y}),l=this.options.once,c=arguments[0]||{};n&&n.length>0&&[].forEach.call(n,function(t,n){var p=s(t),h=r(t._eleOffset,p);t._eleOffset=p;var f=o(a,p),u=t._appear,w=t._hasAppear,E=t._hasDisAppear;d.data={direction:h},v.data={direction:h},f&&!u?(l&&!w||!l)&&(e&&e.call(t,c),t.dispatchEvent(d),t._hasAppear=!0,t._appear=!0):!f&&u&&(l&&!E||!l)&&(i&&i.call(t,c),t.dispatchEvent(v),t._hasDisAppear=!0,t._appear=!1)})}function u(t){l(this.options,t||(t={})),this.appearWatchElements=this.appearWatchElements||p.call(this,\".\"+this.options.cls),h.call(this,this.appearWatchElements),c.call(this)}var d,v,w=document,E=function(){u.apply(this,arguments)},_={instances:[],init:function(t){var n={options:{container:window,wait:100,x:0,y:0,cls:\"lib-appear\",once:!1,onReset:function(){},onAppear:function(){},onDisappear:function(){}},container:null,appearWatchElements:null,bind:function(t){var n=this.options.cls;if(\"string\"==typeof t){var e=p.call(this,t);[].forEach.call(e,function(t,e){t.classList.contains(n)||t.classList.add(n)})}else{if(1!=t.nodeType||!this.container.contains(t))return this;t.classList.contains(n)||t.classList.add(n)}var i=p.call(this,\".\"+this.options.cls);return this.appearWatchElements=this.appearWatchElements.concat(i),h.call(this,i),this},reset:function(t){return u.call(this,t),this.appearWatchElements.forEach(function(t){delete t._hasAppear,delete t._hasDisAppear,delete t._appear}),this},fire:function(){this.appearWatchElements||(this.appearWatchElements=[]);var t=p.call(this,\".\"+this.options.cls);return this.appearWatchElements=this.appearWatchElements.concat(t),h.call(this,t),f.call(this),this}};E.prototype=n;var e=new E(t);return this.instances.push(e),e},fireAll:function(){var t=this.instances;t.forEach(function(t){t.fire()})}};i(),e.appear=_}(window,window.lib||(window.lib={}));\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/appearjs/build/appear.common.js\n ** module id = 14\n ** module chunks = 0\n **/","'use strict'\n\nmodule.exports = {\n\n  /**\n   * config:\n   *   - styles\n   *   - duration [Number] milliseconds(ms)\n   *   - timingFunction [string]\n   *   - dealy [Number] milliseconds(ms)\n   */\n  transitionOnce: function (comp, config, callback) {\n    var styles = config.styles || {}\n    var duration = config.duration || 1000 // ms\n    var timingFunction = config.timingFunction || 'ease'\n    var delay = config.delay || 0  // ms\n    var transitionValue = 'all ' + duration + 'ms '\n        + timingFunction + ' ' + delay + 'ms'\n    var dom = comp.node\n    var transitionEndHandler = function (e) {\n      e.stopPropagation()\n      dom.removeEventListener('webkitTransitionEnd', transitionEndHandler)\n      dom.removeEventListener('transitionend', transitionEndHandler)\n      dom.style.transition = ''\n      dom.style.webkitTransition = ''\n      callback()\n    }\n    dom.style.transition = transitionValue\n    dom.style.webkitTransition = transitionValue\n    dom.addEventListener('webkitTransitionEnd', transitionEndHandler)\n    dom.addEventListener('transitionend', transitionEndHandler)\n    comp.updateStyle(styles)\n  }\n\n}\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/animation.js\n ** module id = 15\n ** module chunks = 0\n **/","'use strict'\n\nvar config = require('../config')\nvar utils = require('../utils')\nvar ComponentManager = require('../componentManager')\nvar flexbox = require('../flexbox')\nrequire('fixedsticky')\n\nfunction Component(data, nodeType) {\n  this.data = data\n  this.node = this.create(nodeType)\n\n  this.createChildren()\n  this.updateAttrs(this.data.attr)\n  // issue: when add element to a list in lifetime hook 'ready', the\n  // styles is set to the classStyle, not style. This is a issue\n  // that jsframework should do something about.\n  var classStyle = this.data.classStyle\n  classStyle && this.updateStyle(this.data.classStyle)\n  this.updateStyle(this.data.style)\n  this.bindEvents(this.data.event)\n}\n\nComponent.prototype = {\n\n  create: function (nodeType) {\n    var node = document.createElement(nodeType || 'div')\n    return node\n  },\n\n  getComponentManager: function () {\n    return ComponentManager.getInstance(this.data.instanceId)\n  },\n\n  getParent: function () {\n    return this.getComponentManager().componentMap[this.parentRef]\n  },\n\n  isScrollable: function () {\n    var t = this.data.type\n    return ComponentManager.getScrollableTypes().indexOf(t) !== -1\n  },\n\n  isInScrollable: function () {\n    if (typeof this._isInScrollable === 'boolean') {\n      return this._isInScrollable\n    }\n    var parent = this.getParent()\n    if (parent\n        && (typeof parent._isInScrollable !== 'boolean')\n        && !parent.isScrollable()) {\n      if (parent.data.type === 'root') {\n        this._isInScrollable = false\n        return false\n      }\n      this._isInScrollable = parent.isInScrollable()\n      this._parentScroller = parent._parentScroller\n      return this._isInScrollable\n    }\n    if (typeof parent._isInScrollable === 'boolean') {\n      this._isInScrollable = parent._isInScrollable\n      this._parentScroller = parent._parentScroller\n      return this._isInScrollable\n    }\n    if (parent.isScrollable()) {\n      this._isInScrollable = true\n      this._parentScroller = parent\n      return true\n    }\n    if (!parent) {\n      console && console.error('isInScrollable - parent not exist.')\n    }\n  },\n\n  createChildren: function () {\n    var children = this.data.children\n    var parentRef = this.data.ref\n    var componentManager = this.getComponentManager()\n    if (children && children.length) {\n      var fragment = document.createDocumentFragment()\n      var isFlex = false\n      for (var i = 0; i < children.length; i++) {\n        children[i].instanceId = this.data.instanceId\n        children[i].scale = this.data.scale\n        var child = componentManager.createElement(children[i])\n        fragment.appendChild(child.node)\n        child.parentRef = parentRef\n        if (!isFlex\n            && child.data.style\n            && child.data.style.hasOwnProperty('flex')\n          ) {\n          isFlex = true\n        }\n      }\n      this.node.appendChild(fragment)\n    }\n  },\n\n  // @todo: changed param data to child\n  appendChild: function (data) {\n    var children = this.data.children\n    var componentManager = this.getComponentManager()\n    var child = componentManager.createElement(data)\n    this.node.appendChild(child.node)\n    // update this.data.children\n    if (!children || !children.length) {\n      this.data.children = [data]\n    } else {\n      children.push(data)\n    }\n\n    return child\n  },\n\n  insertBefore: function (child, before) {\n    var children = this.data.children\n    var i = 0\n    var l\n    var isAppend = false\n\n    // update this.data.children\n    if (!children || !children.length || !before) {\n      isAppend = true\n    } else {\n      for (l = children.length; i < l; i++) {\n        if (children[i].ref === before.data.ref) {\n          break\n        }\n      }\n      if (i === l) {\n        isAppend = true\n      }\n    }\n\n\n    if (isAppend) {\n      this.node.appendChild(child.node)\n      children.push(child.data)\n    } else {\n      this.node.insertBefore(child.node, before.node)\n      children.splice(i, 0, child.data)\n    }\n\n  },\n\n  removeChild: function (child) {\n    var children = this.data.children\n    // remove from this.data.children\n    var i = 0\n    var componentManager = this.getComponentManager()\n    if (children && children.length) {\n      for (var l = children.length; i < l; i++) {\n        if (children[i].ref === child.data.ref) {\n          break\n        }\n      }\n      if (i < l) {\n        children.splice(i, 1)\n      }\n    }\n    // remove from componentMap recursively\n    componentManager.removeElementByRef(child.data.ref)\n    this.node.removeChild(child.node)\n  },\n\n  updateAttrs: function (attrs) {\n    // Note：attr must be injected into the dom element because\n    // it will be accessed from the outside developer by event.target.attr.\n    if (!this.node.attr) {\n      this.node.attr = {}\n    }\n    for (var key in attrs) {\n      var value = attrs[key]\n      var attrSetter = this.attr[key]\n      if (typeof attrSetter === 'function') {\n        attrSetter.call(this, value)\n      } else {\n        if (typeof value === 'boolean') {\n          this.node[key] = value\n        } else {\n          this.node.setAttribute(key, value)\n        }\n        this.node.attr[key] = value\n      }\n    }\n  },\n\n  updateStyle: function (style) {\n    for (var key in style) {\n      var value = style[key]\n      var styleSetter = this.style[key]\n\n      if (typeof styleSetter === 'function') {\n        styleSetter.call(this, value)\n      } else {\n        if (typeof value === 'number'\n            && (key !== 'flex' && key !== 'opacity' && key !== 'zIndex')\n          ) {\n          value = value * this.data.scale + 'px'\n        }\n        this.node.style[key] = value\n      }\n    }\n  },\n\n  bindEvents: function (evts) {\n    var componentManager = this.getComponentManager()\n    if (evts\n        && Object.prototype.toString.call(evts).slice(8, -1) === 'Array'\n      ) {\n      for (var i = 0, l = evts.length; i < l; i++) {\n        componentManager.addEvent(this, evts[i])\n      }\n    }\n  },\n\n  // dispatch a specified event on this.node\n  //  - type: event type\n  //  - data: event data\n  //  - config: event config object\n  //     - bubbles\n  //     - cancelable\n  dispatchEvent: function (type, data, config) {\n    var event = document.createEvent('HTMLEvents')\n    config = config || {}\n    event.initEvent(type, config.bubbles || false, config.cancelable || false)\n    !data && (data = {})\n    event.data = utils.extend({}, data)\n    utils.extend(event, data)\n    if (type === 'appear') {\n      console.log('appear', data)\n    }\n    this.node.dispatchEvent(event)\n  },\n\n  updateRecursiveAttr: function (data) {\n    this.updateAttrs(data.attr)\n    var componentManager = this.getComponentManager()\n    var children = this.data.children\n    if (children) {\n      for (var i = 0; i < children.length; i++) {\n        var child = componentManager.getElementByRef(children[i].ref)\n        if (child) {\n          child.updateRecursiveAttr(data.children[i])\n        }\n      }\n    }\n  },\n\n  updateRecursiveStyle: function (data) {\n    this.updateStyle(data.style)\n    var componentManager = this.getComponentManager()\n    var children = this.data.children\n    if (children) {\n      for (var i = 0; i < children.length; i++) {\n        var child = componentManager.getElementByRef(children[i].ref)\n        if (child) {\n          child.updateRecursiveStyle(data.children[i])\n        }\n      }\n    }\n  },\n\n  updateRecursiveAll: function (data) {\n    this.updateAttrs(data.attr)\n    this.updateStyle(data.style)\n    var componentManager = this.getComponentManager()\n\n    // var oldRef = this.data.ref\n    // if (componentMap[oldRef]) {\n    //   delete componentMap[oldRef]\n    // }\n    // this.data.ref = data.ref\n    // componentMap[data.ref] = this\n\n    var children = this.data.children\n    if (children) {\n      for (var i = 0; i < children.length; i++) {\n        var child = componentManager.getElementByRef(children[i].ref)\n        if (child) {\n          child.updateRecursiveAll(data.children[i])\n        }\n      }\n    }\n  },\n\n  attr: {}, // attr setters\n\n  style: Object.create(flexbox), // style setters\n\n  clearAttr: function () {\n  },\n\n  clearStyle: function () {\n    this.node.cssText = ''\n  }\n}\n\nComponent.prototype.style.position = function (value) {\n  // TODO: make it in a decent implementation\n  if (value === 'sticky') {\n    this.node.style.zIndex = 100\n    setTimeout(function () {\n      this.sticky = new lib.sticky(this.node, {\n        top: 0\n      })\n    }.bind(this), 0)\n  } else {\n    this.node.style.position = value\n  }\n}\n\nmodule.exports = Component\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/components/component.js\n ** module id = 16\n ** module chunks = 0\n **/","'use strict'\n\n// Flexbox polyfill\nvar flexboxSetters = (function () {\n  var BOX_ALIGN = {\n    stretch: 'stretch',\n    'flex-start': 'start',\n    'flex-end': 'end',\n    center: 'center'\n  }\n  var BOX_ORIENT = {\n    row: 'horizontal',\n    column: 'vertical'\n  }\n  var BOX_PACK = {\n    'flex-start': 'start',\n    'flex-end': 'end',\n    center: 'center',\n    'space-between': 'justify',\n    'space-around': 'justify' // Just same as `space-between`\n  }\n  return {\n    flex: function (value) {\n      this.node.style.webkitBoxFlex = value\n      this.node.style.webkitFlex = value\n      this.node.style.flex = value\n    },\n    alignItems: function (value) {\n      this.node.style.webkitBoxAlign = BOX_ALIGN[value]\n      this.node.style.webkitAlignItems = value\n      this.node.style.alignItems = value\n    },\n    alignSelf: function (value) {\n      this.node.style.webkitAlignSelf = value\n      this.node.style.alignSelf = value\n    },\n    flexDirection: function (value) {\n      this.node.style.webkitBoxOrient = BOX_ORIENT[value]\n      this.node.style.webkitFlexDirection = value\n      this.node.style.flexDirection = value\n    },\n    justifyContent: function (value) {\n      this.node.style.webkitBoxPack = BOX_PACK[value]\n      this.node.style.webkitJustifyContent = value\n      this.node.style.justifyContent = value\n    }\n  }\n})()\n\nmodule.exports = flexboxSetters\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/flexbox.js\n ** module id = 17\n ** module chunks = 0\n **/","(typeof window === 'undefined') && (window = {ctrl: {}, lib: {}});!window.ctrl && (window.ctrl = {});!window.lib && (window.lib = {});!function(a,b,c){function d(a){return null!=a&&\"object\"==typeof a&&Object.getPrototypeOf(a)==Object.prototype}function e(a,b){var c,d,e,f=null,g=0,h=function(){g=Date.now(),f=null,e=a.apply(c,d)};return function(){var i=Date.now(),j=b-(i-g);return c=this,d=arguments,0>=j?(clearTimeout(f),f=null,g=i,e=a.apply(c,d)):f||(f=setTimeout(h,j)),e}}function f(a){var b=\"\";return Object.keys(a).forEach(function(c){b+=c+\":\"+a[c]+\";\"}),b}function g(a,c){!c&&d(a)&&(c=a,a=c.element),c=c||{},a.nodeType!=b.ELEMENT_NODE&&\"string\"==typeof a&&(a=b.querySelector(a));var e=this;e.element=a,e.top=c.top||0,e.withinParent=void 0==c.withinParent?!1:c.withinParent,e.init()}var h=a.parseInt,i=navigator.userAgent,j=!!i.match(/Firefox/i),k=!!i.match(/IEMobile/i),l=j?\"-moz-\":k?\"-ms-\":\"-webkit-\",m=j?\"Moz\":k?\"ms\":\"webkit\",n=function(){var a=b.createElement(\"div\"),c=a.style;return c.cssText=\"position:\"+l+\"sticky;position:sticky;\",-1!=c.position.indexOf(\"sticky\")}();g.prototype={constructor:g,init:function(){var a=this,b=a.element,c=b.style;c[m+\"Transform\"]=\"translateZ(0)\",c.transform=\"translateZ(0)\",a._originCssText=c.cssText,n?(c.position=l+\"sticky\",c.position=\"sticky\",c.top=a.top+\"px\"):(a._simulateSticky(),a._bindResize())},_bindResize:function(){var b=this,c=/android/gi.test(navigator.appVersion),d=b._resizeEvent=\"onorientationchange\"in a?\"orientationchange\":\"resize\",e=b._resizeHandler=function(){setTimeout(function(){b.refresh()},c?200:0)};a.addEventListener(d,e,!1)},refresh:function(){var a=this;n||(a._detach(),a._simulateSticky())},_addPlaceholder:function(a){var c,d=this,e=d.element,g=a.position;if(-1!=[\"static\",\"relative\"].indexOf(g)){c=d._placeholderElement=b.createElement(\"div\");var i=h(a.width)+h(a.marginLeft)+h(a.marginRight),j=h(a.height);\"border-box\"!=a.boxSizing&&(i+=h(a.borderLeftWidth)+h(a.borderRightWidth)+h(a.paddingLeft)+h(a.paddingRight),j+=h(a.borderTopWidth)+h(a.borderBottomWidth)+h(a.paddingTop)+h(a.paddingBottom)),c.style.cssText=f({display:\"none\",visibility:\"hidden\",width:i+\"px\",height:j+\"px\",margin:0,\"margin-top\":a.marginTop,\"margin-bottom\":a.marginBottom,border:0,padding:0,\"float\":a[\"float\"]||a.cssFloat}),e.parentNode.insertBefore(c,e)}return c},_simulateSticky:function(){var c=this,d=c.element,g=c.top,i=d.style,j=d.getBoundingClientRect(),k=getComputedStyle(d,\"\"),l=d.parentNode,m=getComputedStyle(l,\"\"),n=c._addPlaceholder(k),o=c.withinParent,p=c._originCssText,q=j.top-g+a.pageYOffset,r=l.getBoundingClientRect().bottom-h(m.paddingBottom)-h(m.borderBottomWidth)-h(k.marginBottom)-j.height-g+a.pageYOffset,s=p+f({position:\"fixed\",top:g+\"px\",width:k.width,\"margin-top\":0}),t=p+f({position:\"absolute\",top:r+\"px\",width:k.width}),u=1,v=c._scrollHandler=e(function(){var b=a.pageYOffset;q>b?1!=u&&(i.cssText=p,n&&(n.style.display=\"none\"),u=1):!o&&b>=q||o&&b>=q&&r>b?2!=u&&(i.cssText=s,n&&3!=u&&(n.style.display=\"block\"),u=2):o&&3!=u&&(i.cssText=t,n&&2!=u&&(n.style.display=\"block\"),u=3)},100);if(a.addEventListener(\"scroll\",v,!1),a.pageYOffset>=q){var w=b.createEvent(\"HTMLEvents\");w.initEvent(\"scroll\",!0,!0),a.dispatchEvent(w)}},_detach:function(){var b=this,c=b.element;if(c.style.cssText=b._originCssText,!n){var d=b._placeholderElement;d&&c.parentNode.removeChild(d),a.removeEventListener(\"scroll\",b._scrollHandler,!1)}},destroy:function(){var b=this;b._detach();var c=b.element.style;c.removeProperty(l+\"transform\"),c.removeProperty(\"transform\"),n||a.removeEventListener(b._resizeEvent,b._resizeHandler,!1)}},c.sticky=g}(window,document,window.lib||(window.lib={}));;module.exports = window.lib['sticky'];\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/fixedsticky/build/sticky.common.js\n ** module id = 18\n ** module chunks = 0\n **/","'use strict'\n\nvar utils = require('../utils')\n\nvar _senderMap = {}\n\nfunction Sender(instance) {\n  if (!(this instanceof Sender)) {\n    return new Sender(instance)\n  }\n  this.instanceId = instance.instanceId\n  this.weexInstance = instance\n  _senderMap[this.instanceId] = this\n}\n\nfunction _send(instanceId, msg) {\n  callJS(instanceId, [msg])\n}\n\nSender.getSender = function (instanceId) {\n  return _senderMap[instanceId]\n}\n\nSender.prototype = {\n\n  // perform a callback to jsframework.\n  performCallback: function (callbackId, data) {\n    var args = [callbackId]\n    data && args.push(data)\n    _send(this.instanceId, {\n      method: 'callback',\n      args: args\n    })\n  },\n\n  fireEvent: function (ref, type, event) {\n    // Note that the event.target must be the standard event's\n    // currentTarget. Therefor a process for replacing target must\n    // be done when a event is fired.\n    var evt = utils.extend({}, event)\n    evt.target = evt.currentTarget\n    evt.value = event.target.value\n    evt.timestamp = Date.now()\n    _send(this.instanceId, {\n      method: 'fireEvent',\n      args: [ref, type, evt]\n    })\n  }\n\n}\n\nmodule.exports = Sender\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/bridge/sender.js\n ** module id = 19\n ** module chunks = 0\n **/","'use strict'\n\nvar config = require('../config')\nvar protocol = require('../protocol')\nvar utils = require('../utils')\nvar FrameUpdater = require('../frameUpdater')\nvar Sender = require('./sender')\n\nvar callQueue = []\n// Need a task counter?\n// When FrameUpdater is not activated, tasks will not be push\n// into callQueue and there will be no trace for situation of\n// execution of tasks.\n\n// give 10ms for call handling, and rest 6ms for others\nvar MAX_TIME_FOR_EACH_FRAME = 10\n\n// callNative: jsFramework will call this method to talk to\n// this renderer.\n// params:\n//  - instanceId: string.\n//  - tasks: array of object.\n//  - callbackId: number.\nfunction callNative(instanceId, tasks, callbackId) {\n  var calls = []\n  if (typeof tasks === 'string') {\n    try {\n      calls = JSON.parse(tasks)\n    } catch (e) {\n      console.error('invalid tasks:', tasks)\n    }\n  } else if (Object.prototype.toString.call(tasks).slice(8, -1) === 'Array') {\n    calls = tasks\n  }\n  var len = calls.length\n  calls[len - 1].callbackId = (!callbackId && callbackId !== 0)\n                              ? -1\n                              : callbackId\n  // To solve the problem of callapp, the two-way time loop rule must\n  // be replaced by calling directly except the situation of page loading.\n  // 2015-11-03\n  for (var i = 0; i < len; i++) {\n    if (FrameUpdater.isActive()) {\n      callQueue.push({\n        instanceId: instanceId,\n        call: calls[i]\n      })\n    }\n    else {\n      processCall(instanceId, calls[i])\n    }\n  }\n\n}\n\nfunction processCallQueue() {\n  var len = callQueue.length\n  if (len === 0) {\n    return\n  }\n  var start = Date.now()\n  var elapsed = 0\n\n  while (--len >= 0 && elapsed < MAX_TIME_FOR_EACH_FRAME) {\n    var callObj = callQueue.shift()\n    processCall(callObj.instanceId, callObj.call)\n    elapsed = Date.now() - start\n  }\n}\n\nfunction processCall(instanceId, call) {\n  var moduleName = call.module\n  var methodName = call.method\n  var module, method\n  var args = call.args || call.arguments || []\n\n  if (!(module = protocol.apiModule[moduleName])) {\n    return\n  }\n  if (!(method = module[methodName])) {\n    return\n  }\n\n  method.apply(protocol.getWeexInstance(instanceId), args)\n\n  var callbackId = call.callbackId\n  if ((callbackId\n    || callbackId === 0\n    || callbackId === '0')\n    && callbackId !== '-1'\n    && callbackId !== -1) {\n    performNextTick(instanceId, callbackId)\n  }\n}\n\nfunction performNextTick(instanceId, callbackId) {\n  Sender.getSender(instanceId).performCallback(callbackId)\n}\n\nfunction nativeLog() {\n  if (config.debug) {\n    if (arguments[0].match(/^perf/)) {\n      console.info.apply(console, arguments)\n      return\n    }\n    console.debug.apply(console, arguments)\n  }\n}\n\nfunction exportsBridgeMethodsToGlobal() {\n  global.callNative = callNative\n  global.nativeLog = nativeLog\n}\n\nmodule.exports = {\n\n  init: function () {\n\n    // process callQueue every 16 milliseconds.\n    FrameUpdater.addUpdateObserver(processCallQueue)\n    FrameUpdater.start()\n\n    // exports methods to global(window).\n    exportsBridgeMethodsToGlobal()\n  }\n\n}\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/bridge/receiver.js\n ** module id = 20\n ** module chunks = 0\n **/","var RootComponent = require('./root')\nvar Container = require('./container')\nvar Image = require('./image')\nvar Text = require('./text')\nvar List = require('./list')\nvar Countdown = require('./countdown')\nvar Marquee = require('./marquee')\nvar Slider = require('./slider')\nvar Indicator = require('./indicator')\nvar Tabheader = require('./tabheader')\nvar Scroller = require('./scroller')\nvar Input = require('./input')\nvar Select = require('./select')\nvar Datepicker = require('./datepicker')\nvar Timepicker = require('./timepicker')\nvar Video = require('./video')\nvar Switch = require('./switch')\nvar A = require('./a')\nvar Embed = require('./embed')\n\nvar components = {\n  init: function (Weex) {\n    Weex.registerComponent('root', RootComponent)\n    Weex.registerComponent('root', RootComponent)\n    Weex.registerComponent('container', Container)\n    Weex.registerComponent('image', Image)\n    Weex.registerComponent('text', Text)\n    Weex.registerComponent('list', List)\n    Weex.registerComponent('countdown', Countdown)\n    Weex.registerComponent('marquee', Marquee)\n    Weex.registerComponent('slider', Slider)\n    Weex.registerComponent('indicator', Indicator)\n    Weex.registerComponent('tabheader', Tabheader)\n    Weex.registerComponent('scroller', Scroller)\n    Weex.registerComponent('input', Input)\n    Weex.registerComponent('select', Select)\n    Weex.registerComponent('datepicker', Datepicker)\n    Weex.registerComponent('timepicker', Timepicker)\n    Weex.registerComponent('video', Video)\n    Weex.registerComponent('switch', Switch)\n    Weex.registerComponent('a', A)\n    Weex.registerComponent('embed', Embed)\n  }\n}\n\nmodule.exports = components\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/components/index.js\n ** module id = 21\n ** module chunks = 0\n **/","'use strict'\n\nvar ComponentManager = require('../componentManager')\nvar Component = require('./component')\n\n// If nodeType is in this WHITE_LIST, just ignore it and\n// replace it with a div element.\nvar WHITE_LIST = []\n\nfunction RootComponent(data, nodeType) {\n  var id = data.rootId + '-root'\n  var componentManager = ComponentManager.getInstance(data.instanceId)\n\n  // Return a NodeType instance.\n  if (nodeType && nodeType !== 'div' && WHITE_LIST.indexOf(nodeType) === -1) {\n    data.type = nodeType\n    var cmp = componentManager.createElement(data)\n    cmp.node.id = id\n    return cmp\n  }\n\n  // Otherwise return a common weex-container component,\n  // whose node is a div element.\n  var node = document.createElement('div')\n  this.data = data\n  this.node = node\n\n  this.createChildren()\n  this.updateAttrs(this.data.attr)\n  // issue: when add element to a list in lifetime hook 'ready', the\n  // styles is set to the classStyle, not style. This is a issue\n  // that jsframework should do something about.\n  var classStyle = this.data.classStyle\n  classStyle && this.updateStyle(this.data.classStyle)\n  this.updateStyle(this.data.style)\n  this.bindEvents(this.data.event)\n}\n\nRootComponent.prototype = Object.create(Component.prototype)\n\nmodule.exports = RootComponent\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/components/root.js\n ** module id = 22\n ** module chunks = 0\n **/","'use strict'\n\nrequire('../styles/container.scss')\n\nvar Component = require('./component')\n\nfunction Container (data, nodeType) {\n  Component.call(this, data, nodeType)\n  this.node.classList.add('weex-container')\n}\n\nContainer.prototype = Object.create(Component.prototype)\n\nmodule.exports = Container\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/components/container.js\n ** module id = 23\n ** module chunks = 0\n **/","// style-loader: Adds some css to the DOM by adding a <style> tag\n\n// load the styles\nvar content = require(\"!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./container.scss\");\nif(typeof content === 'string') content = [[module.id, content, '']];\n// add the styles to the DOM\nvar update = require(\"!./../../node_modules/style-loader/addStyles.js\")(content, {});\nif(content.locals) module.exports = content.locals;\n// Hot Module Replacement\nif(module.hot) {\n\t// When the styles change, update the <style> tags\n\tif(!content.locals) {\n\t\tmodule.hot.accept(\"!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./container.scss\", function() {\n\t\t\tvar newContent = require(\"!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./container.scss\");\n\t\t\tif(typeof newContent === 'string') newContent = [[module.id, newContent, '']];\n\t\t\tupdate(newContent);\n\t\t});\n\t}\n\t// When the module is disposed, remove the <style> tags\n\tmodule.hot.dispose(function() { update(); });\n}\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/styles/container.scss\n ** module id = 24\n ** module chunks = 0\n **/","exports = module.exports = require(\"./../../node_modules/css-loader/lib/css-base.js\")();\n// imports\n\n\n// module\nexports.push([module.id, \".weex-container {\\n  box-sizing: border-box;\\n  display: -webkit-box;\\n  display: -webkit-flex;\\n  display: flex;\\n  -webkit-box-orient: vertical;\\n  -webkit-flex-direction: column;\\n  flex-direction: column;\\n  position: relative;\\n  border: 0 solid black;\\n  margin: 0;\\n  padding: 0; }\\n\\n.weex-element {\\n  box-sizing: border-box;\\n  position: relative; }\\n\", \"\", {\"version\":3,\"sources\":[\"/./src/src/styles/container.scss\"],\"names\":[],\"mappings\":\"AAAA;EACE,uBAAsB;EACtB,qBAAoB;EACpB,sBAAqB;EACrB,cAAa;EACb,6BAA4B;EAC5B,+BAA8B;EAC9B,uBAAsB;EACtB,mBAAkB;EAClB,sBAAqB;EACrB,UAAS;EACT,WACD,EAAC;;AAEF;EACE,uBAAuB;EACvB,mBAAmB,EACpB\",\"file\":\"container.scss\",\"sourcesContent\":[\".weex-container {\\n  box-sizing:border-box;\\n  display:-webkit-box;\\n  display:-webkit-flex;\\n  display:flex;\\n  -webkit-box-orient:vertical;\\n  -webkit-flex-direction:column;\\n  flex-direction:column;\\n  position:relative;\\n  border:0 solid black;\\n  margin:0;\\n  padding:0\\n}\\n\\n.weex-element {\\n  box-sizing: border-box;\\n  position: relative;\\n}\"],\"sourceRoot\":\"webpack://\"}]);\n\n// exports\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/css-loader?sourceMap!./~/sass-loader?sourceMap!./src/styles/container.scss\n ** module id = 25\n ** module chunks = 0\n **/","'use strict'\n\nvar Atomic = require('./atomic')\nvar LazyLoad = require('../lazyLoad')\nvar config = require('../config')\n\nvar DEFAULT_SIZE = 200\nvar RESIZE_MODES = ['cover', 'contain'] // not temporarily supported\n\n/**\n * resize=cover|contain|stretch v1.4 temporarily not supported\n * src=url\n */\n\nfunction Image (data) {\n  this.width = data.style && data.style.width\n               ? (data.style.width + '').replace(/[^\\d]/g, '')\n               : DEFAULT_SIZE\n  this.height = data.style && data.style.height\n               ? (data.style.height + '').replace(/[^\\d]/g, '')\n               : DEFAULT_SIZE\n  this.width *= data.scale\n  this.height *= data.scale\n  var mode\n  var attr = data.attr\n  attr && (mode = attr.resize || attr.resizeMode)\n  if (RESIZE_MODES.indexOf(mode) !== -1) {\n    this.mode = mode\n    // TODO: resize-mode is not temporarily supported.\n  }\n  Atomic.call(this, data)\n}\n\nImage.prototype = Object.create(Atomic.prototype)\n\nImage.prototype.create = function () {\n  var node = document.createElement('img')\n  node.classList.add('weex-element')\n  node.style.display = 'block'\n  node.style.outline = 'none'\n  return node\n}\n\nImage.prototype.attr = {\n  src: function (value) {\n    if (!this.node.src) {\n      this.node.src = lib.img.defaultSrc\n    }\n    LazyLoad.makeImageLazy(this.node, value)\n  }\n}\n\nImage.prototype.clearAttr = function () {\n  this.node.src = ''\n}\n\nmodule.exports = Image\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/components/image.js\n ** module id = 26\n ** module chunks = 0\n **/","'use strict'\n\nvar Component = require('./component')\n\n// Component which can have no subcomponents.\n// This component should not be instantiated directly, since\n// it is designed to be used as a base class to extend from.\nfunction Atomic (data) {\n  Component.call(this, data)\n}\n\nAtomic.prototype = Object.create(Component.prototype)\n\nAtomic.prototype.appendChild = function (data) {\n  // do nothing\n  return\n}\n\nAtomic.prototype.insertBefore = function (child, before) {\n  // do nothing\n  return\n}\n\nAtomic.prototype.removeChild = function (child) {\n  // do nothing\n  return\n}\n\nmodule.exports = Atomic\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/components/atomic.js\n ** module id = 27\n ** module chunks = 0\n **/","'use strict'\n\nvar Atomic = require('./component')\nvar utils = require('../utils')\n\nvar DEFAULT_FONT_SIZE = 32\n\n// attr\n//  - value: text content.\n//  - lines: maximum lines of the text.\nfunction Text (data) {\n  Atomic.call(this, data)\n}\n\nText.prototype = Object.create(Atomic.prototype)\n\nText.prototype.create = function () {\n  var node = document.createElement('div')\n  node.classList.add('weex-container')\n  node.style.fontSize = DEFAULT_FONT_SIZE * this.data.scale + 'px'\n  this.textNode = document.createElement('span')\n  // Give the developers the ability to control space\n  // and line-breakers.\n  this.textNode.style.whiteSpace = 'pre-wrap'\n  this.textNode.style.display = '-webkit-box'\n  this.textNode.style.webkitBoxOrient = 'vertical'\n  this.style.lines.call(this, this.data.style.lines)\n  node.appendChild(this.textNode)\n  return node\n}\n\nText.prototype.attr = {\n  value: function (value) {\n    var span = this.node.firstChild\n    span.innerHTML = ''\n    if (!value) {\n      return\n    }\n    span.textContent = value\n    /**\n     * Developers are supposed to have the ability to break text\n     * lines manually. Using ``&nbsp;`` to replace text space is\n     * not compatible with the ``-webkit-line-clamp``. Therefor\n     * we use ``white-space: no-wrap`` instead (instead of the\n     * code bellow).\n\n      var frag = document.createDocumentFragment()\n        text.split(' ').forEach(function(str) {\n          var textNode = document.createTextNode(str)\n          var space = document.createElement('i')\n          space.innerHTML = '&nbsp;'\n          frag.appendChild(space)\n          frag.appendChild(textNode)\n        })\n        frag.removeChild(frag.firstChild)\n        span.appendChild(document.createElement('br'))\n        span.appendChild(frag)\n      })\n      span.removeChild(span.firstChild)\n     */\n  }\n}\n\nText.prototype.clearAttr = function () {\n  this.node.firstChild.textContent = ''\n}\n\nText.prototype.style = utils.extend(Object.create(Atomic.prototype.style), {\n\n  lines: function (val) {\n    val = parseInt(val)\n    if (val !== val) { // NaN\n      return\n    }\n    if (val <= 0) {\n      this.textNode.style.textOverflow = ''\n      this.textNode.style.overflow = 'visible'\n      this.textNode.style.webkitLineClamp = ''\n    } else {\n      this.textNode.style.overflow = 'hidden'\n      this.textNode.style.textOverflow = 'ellipsis'\n      this.textNode.style.webkitLineClamp = lines\n    }\n  }\n\n})\n\nmodule.exports = Text\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/components/text.js\n ** module id = 28\n ** module chunks = 0\n **/","'use strict'\n\nrequire('../styles/list.scss')\nrequire('scrolljs')\n\nvar Component = require('./component')\nvar LazyLoad = require('../lazyLoad')\n\nvar DEFAULT_LOAD_MORE_OFFSET = 500\n\nfunction List(data, nodeType) {\n  // this.loadmoreOffset = Number(data.attr.loadmoreoffset)\n  // this.isAvailableToFireloadmore = true\n  Component.call(this, data, nodeType)\n}\n\nList.prototype = Object.create(Component.prototype)\n\nList.prototype.create = function (nodeType) {\n  var Scroll = lib.scroll\n  var node = Component.prototype.create.call(this, nodeType)\n  node.classList.add('weex-container', 'list-wrap')\n  this.listElement = document.createElement('div')\n  this.listElement.classList.add(\n    'weex-container'\n    , 'list-element'\n  )\n  node.appendChild(this.listElement)\n  this.scroller = new Scroll({\n    scrollElement: this.listElement\n    , direction: 'y'\n  })\n  this.scroller.init()\n  return node\n}\n\nList.prototype.bindEvents = function (evts) {\n  Component.prototype.bindEvents.call(this, evts)\n  // to enable lazyload for Images.\n  this.scroller.addEventListener('scrolling', function (e) {\n    var so = e.scrollObj\n    this.dispatchEvent('scroll', {\n      originalType: 'scrolling',\n      scrollTop: so.getScrollTop(),\n      scrollLeft: so.getScrollLeft()\n    }, {\n      bubbles: true\n    })\n  }.bind(this))\n\n  this.scroller.addEventListener('pullupend', function (e) {\n    this.dispatchEvent('loadmore')\n  }.bind(this))\n}\n\nList.prototype.appendChild = function (data) {\n  var children = this.data.children\n  var componentManager = this.getComponentManager()\n  var child = componentManager.createElement(data)\n  this.listElement.appendChild(child.node)\n\n  // update this.data.children\n  if (!children || !children.length) {\n    this.data.children = [data]\n  } else {\n    children.push(data)\n  }\n\n  return child\n}\n\nList.prototype.insertBefore = function (child, before) {\n  var children = this.data.children\n  var i = 0\n  var isAppend = false\n\n  // update this.data.children\n  if (!children || !children.length || !before) {\n    isAppend = true\n  } else {\n    for (var l = children.length; i < l; i++) {\n      if (children[i].ref === child.data.ref) {\n        break\n      }\n    }\n    if (i === l) {\n      isAppend = true\n    }\n  }\n\n  if (isAppend) {\n    this.listElement.appendChild(child.node)\n    children.push(child.data)\n  } else {\n    this.listElement.insertBefore(child.node, before.node)\n    children.splice(i, 0, child.data)\n  }\n}\n\nList.prototype.removeChild = function (child) {\n  var children = this.data.children\n  // remove from this.data.children\n  var i = 0\n  var componentManager = this.getComponentManager()\n  if (children && children.length) {\n    for (var l = children.length; i < l; i++) {\n      if (children[i].ref === child.data.ref) {\n        break\n      }\n    }\n    if (i < l) {\n      children.splice(i, 1)\n    }\n  }\n  // remove from componentMap recursively\n  componentManager.removeElementByRef(child.data.ref)\n  this.listElement.removeChild(child.node)\n}\n\nmodule.exports = List\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/components/list.js\n ** module id = 29\n ** module chunks = 0\n **/","// style-loader: Adds some css to the DOM by adding a <style> tag\n\n// load the styles\nvar content = require(\"!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./list.scss\");\nif(typeof content === 'string') content = [[module.id, content, '']];\n// add the styles to the DOM\nvar update = require(\"!./../../node_modules/style-loader/addStyles.js\")(content, {});\nif(content.locals) module.exports = content.locals;\n// Hot Module Replacement\nif(module.hot) {\n\t// When the styles change, update the <style> tags\n\tif(!content.locals) {\n\t\tmodule.hot.accept(\"!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./list.scss\", function() {\n\t\t\tvar newContent = require(\"!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./list.scss\");\n\t\t\tif(typeof newContent === 'string') newContent = [[module.id, newContent, '']];\n\t\t\tupdate(newContent);\n\t\t});\n\t}\n\t// When the module is disposed, remove the <style> tags\n\tmodule.hot.dispose(function() { update(); });\n}\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/styles/list.scss\n ** module id = 30\n ** module chunks = 0\n **/","exports = module.exports = require(\"./../../node_modules/css-loader/lib/css-base.js\")();\n// imports\n\n\n// module\nexports.push([module.id, \".list-wrap {\\n  display: block;\\n  overflow: hidden; }\\n\\n.list-element {\\n  -webkit-box-orient: vertical;\\n  -webkit-flex-direction: column;\\n  flex-direction: column; }\\n\", \"\", {\"version\":3,\"sources\":[\"/./src/src/styles/list.scss\"],\"names\":[],\"mappings\":\"AAAA;EACC,eAAe;EACf,iBAAiB,EACjB;;AAED;EACE,6BAA6B;EAC7B,+BAA+B;EAC/B,uBAAuB,EACxB\",\"file\":\"list.scss\",\"sourcesContent\":[\".list-wrap {\\n\\tdisplay: block;\\n\\toverflow: hidden;\\n}\\n\\n.list-element {\\n  -webkit-box-orient: vertical;\\n  -webkit-flex-direction: column;\\n  flex-direction: column;\\n}\"],\"sourceRoot\":\"webpack://\"}]);\n\n// exports\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/css-loader?sourceMap!./~/sass-loader?sourceMap!./src/styles/list.scss\n ** module id = 31\n ** module chunks = 0\n **/","(typeof window === 'undefined') && (window = {ctrl: {}, lib: {}});!window.ctrl && (window.ctrl = {});!window.lib && (window.lib = {});require('animationjs');require('cubicbezier');require('gesturejs');require('motionjs');!function(a,b,c){function d(){b.scroll.outputDebugLog&&console.debug.apply(console,arguments)}function e(a){var b=a.getBoundingClientRect();if(!b){b={},b.width=a.offsetWidth,b.height=a.offsetHeight,b.left=a.offsetLeft,b.top=a.offsetTop;for(var c=a.offsetParent;c;)b.left+=c.offsetLeft,b.top+=c.offsetTop,c=c.offsetParent;b.right=b.left+b.width,b.bottom=b.top+b.height}return b}function f(a){return 0-a.options[a.axis+\"PaddingTop\"]}function g(a){var b=e(a.element),c=e(a.viewport),d=f(a);if(\"y\"===a.axis)var g=0-b.height+c.height;else var g=0-b.width+c.width;return Math.min(g+a.options[a.axis+\"PaddingBottom\"],d)}function h(a,b){return b>a.minScrollOffset?b-a.minScrollOffset:b<a.maxScrollOffset?b-a.maxScrollOffset:void 0}function i(a,b){return b>a.minScrollOffset?b=a.minScrollOffset:b<a.maxScrollOffset&&(b=a.maxScrollOffset),b}function j(a,b,c){d(a.element.scrollId,b,c);var e=p.createEvent(\"HTMLEvents\");if(e.initEvent(b,!1,!0),e.scrollObj=a,c)for(var f in c)e[f]=c[f];a.element.dispatchEvent(e),a.viewport.dispatchEvent(e)}function k(a){var b,c={x:0,y:0},d=getComputedStyle(a.element)[y+\"Transform\"];return\"none\"!==d&&(b=d.match(/^matrix3d\\((?:[-\\d.]+,\\s*){12}([-\\d.]+),\\s*([-\\d.]+)(?:,\\s*[-\\d.]+){2}\\)/)||d.match(/^matrix\\((?:[-\\d.]+,\\s*){4}([-\\d.]+),\\s*([-\\d.]+)\\)$/))&&(c.x=parseFloat(b[1])||0,c.y=parseFloat(b[2])||0),c}function l(a,b){return a=parseFloat(a),b=parseFloat(b),0!=a&&(a+=\"px\"),0!=b&&(b+=\"px\"),A?\"translate3d(\"+a+\", \"+b+\", 0)\":\"translate(\"+a+\", \"+b+\")\"}function m(a,b,c){\"\"===b&&\"\"===c?a.element.style[y+\"Transition\"]=\"\":a.element.style[y+\"Transition\"]=x+\"transform \"+b+\" \"+c+\" 0s\"}function n(a,b){var c=0,d=0;\"object\"==typeof b?(c=b.x,d=b.y):\"y\"===a.axis?d=b:c=b,a.element.style[y+\"Transform\"]=l(c,d)}function o(a,c){function l(a){return F||L?(a.preventDefault(),a.stopPropagation(),!1):!0}function o(a){F||L||setTimeout(function(){var b=document.createEvent(\"HTMLEvents\");b.initEvent(\"niceclick\",!0,!0),a.target.dispatchEvent(b)},300)}function p(a,c){I=null,clearTimeout(J),J=setTimeout(function(){I&&(I=null,b.animation.requestFrame(a))},c||400),I=a}function q(a){if(!E.enabled)return!1;if(\"undefined\"!=typeof a.isVertical){if(!(\"y\"===E.axis&&a.isVertical||\"x\"===E.axis&&!a.isVertical))return!1;a.stopPropagation()}return!0}function t(a){if(q(a))if(L&&D(),c.useFrameAnimation)H&&H.stop(),H=null;else{var b=k(E);n(E,b),m(E,\"\",\"\"),I=null,clearTimeout(J)}}function w(a){if(q(a)){var d=k(E)[E.axis],e=h(E,d);if(e){var f=i(E,d);if(c.useFrameAnimation){var g=f-d;H=new b.animation(400,b.cubicbezier.ease,0,function(a,b){var c=(d+g*b).toFixed(2);n(E,c),j(E,\"scrolling\")}),H.onend(D),H.play()}else{var l=f.toFixed(0);m(E,\"0.4s\",\"ease\"),n(E,l),p(D,400),b.animation.requestFrame(function(){L&&E.enabled&&(j(E,\"scrolling\"),b.animation.requestFrame(arguments.callee))})}e>0?j(E,\"y\"===E.axis?\"pulldownend\":\"pullrightend\"):0>e&&j(E,\"y\"===E.axis?\"pullupend\":\"pullleftend\")}else L&&D()}}function x(a){q(a)&&(E.transformOffset=k(E),E.minScrollOffset=f(E),E.maxScrollOffset=g(E),K=2.5,N=!0,L=!0,M=!1,j(E,\"scrollstart\"),O=a[\"displacement\"+E.axis.toUpperCase()])}function z(a){if(q(a)){var b=a[\"displacement\"+E.axis.toUpperCase()];if(Math.abs(b-O)<5)return void a.stopPropagation();O=b;var c=E.transformOffset[E.axis]+b;c>E.minScrollOffset?(c=E.minScrollOffset+(c-E.minScrollOffset)/K,K*=1.003):c<E.maxScrollOffset&&(c=E.maxScrollOffset-(E.maxScrollOffset-c)/K,K*=1.003),K>4&&(K=4);var d=h(E,c);d&&(j(E,d>0?\"y\"===E.axis?\"pulldown\":\"pullright\":\"y\"===E.axis?\"pullup\":\"pullleft\",{boundaryOffset:Math.abs(d)}),E.options.noBounce&&(c=i(E,c))),n(E,c.toFixed(2)),j(E,\"scrolling\")}}function A(a){q(a)&&a.isflick&&C(a)}function C(a){N=!0;var e,f,g,i,l,o,q,r,s,t,v,w,x,y,z,A,B;i=k(E)[E.axis];var C=h(E,i);if(!C){e=a[\"velocity\"+E.axis.toUpperCase()];var F=2,G=.0015;c.inertia&&u[c.inertia]&&(F=u[c.inertia][0],G=u[c.inertia][1]),e>F&&(e=F),-F>e&&(e=-F),f=G*(e/Math.abs(e)),o=new b.motion({v:e,a:-f}),g=o.t,l=i+o.s;var I=h(E,l);if(I){d(\"惯性计算超出了边缘\",I),q=e,r=f,I>0?(t=E.minScrollOffset,w=1):(t=E.maxScrollOffset,w=-1),v=new b.motion({v:w*q,a:-w*r,s:Math.abs(t-i)}),s=v.t;var J=v.generateCubicBezier();x=q-r*s,y=.03*(x/Math.abs(x)),B=new b.motion({v:x,a:-y}),z=B.t,A=t+B.s;B.generateCubicBezier();if(c.noBounce)if(d(\"没有回弹效果\"),i!==t)if(c.useFrameAnimation){var K=t-i,O=b.cubicbezier(J[0][0],J[0][1],J[1][0],J[1][1]);H=new b.animation(s.toFixed(0),O,0,function(a,b){var c=i+K*b;k(E,c.toFixed(2)),j(E,\"scrolling\",{afterFlick:!0})}),H.onend(D),H.play()}else{var P=t.toFixed(0);m(E,(s/1e3).toFixed(2)+\"s\",\"cubic-bezier(\"+J+\")\"),n(E,P),p(D,1e3*(s/1e3).toFixed(2))}else D();else if(i!==A)if(d(\"惯性滚动\",\"s=\"+A.toFixed(0),\"t=\"+((s+z)/1e3).toFixed(2)),c.useFrameAnimation){var K=A-i,O=b.cubicbezier.easeOut;H=new b.animation((s+z).toFixed(0),O,0,function(a,b){var c=i+K*b;n(E,c.toFixed(2)),j(E,\"scrolling\",{afterFlick:!0})}),H.onend(function(){if(E.enabled){var a=t-A,c=b.cubicbezier.ease;H=new b.animation(400,c,0,function(b,c){var d=A+a*c;n(E,d.toFixed(2)),j(E,\"scrolling\",{afterFlick:!0})}),H.onend(D),H.play()}}),H.play()}else{var P=A.toFixed(0);m(E,((s+z)/1e3).toFixed(2)+\"s\",\"ease-out\"),n(E,P),p(function(a){if(E.enabled)if(d(\"惯性回弹\",\"s=\"+t.toFixed(0),\"t=400\"),A!==t){var b=t.toFixed(0);m(E,\"0.4s\",\"ease\"),n(E,b),p(D,400)}else D()},1e3*((s+z)/1e3).toFixed(2))}else D()}else{d(\"惯性计算没有超出边缘\");var Q=o.generateCubicBezier();if(c.useFrameAnimation){var K=l-i,O=b.cubicbezier(Q[0][0],Q[0][1],Q[1][0],Q[1][1]);H=new b.animation(g.toFixed(0),O,0,function(a,b){var c=(i+K*b).toFixed(2);n(E,c),j(E,\"scrolling\",{afterFlick:!0})}),H.onend(D),H.play()}else{var P=l.toFixed(0);m(E,(g/1e3).toFixed(2)+\"s\",\"cubic-bezier(\"+Q+\")\"),n(E,P),p(D,1e3*(g/1e3).toFixed(2))}}M=!0,c.useFrameAnimation||b.animation.requestFrame(function(){L&&M&&E.enabled&&(j(E,\"scrolling\",{afterFlick:!0}),b.animation.requestFrame(arguments.callee))})}}function D(){E.enabled&&(N=!1,setTimeout(function(){!N&&L&&(L=!1,M=!1,c.useFrameAnimation?(H&&H.stop(),H=null):m(E,\"\",\"\"),j(E,\"scrollend\"))},50))}var E=this;if(c=c||{},c.noBounce=!!c.noBounce,c.padding=c.padding||{},null==c.isPrevent?c.isPrevent=!0:c.isPrevent=!!c.isPrevent,null==c.isFixScrollendClick?c.isFixScrollendClick=!0:c.isFixScrollendClick=!!c.isFixScrollendClick,c.padding?(c.yPaddingTop=-c.padding.top||0,c.yPaddingBottom=-c.padding.bottom||0,c.xPaddingTop=-c.padding.left||0,c.xPaddingBottom=-c.padding.right||0):(c.yPaddingTop=0,c.yPaddingBottom=0,c.xPaddingTop=0,c.xPaddingBottom=0),c.direction=c.direction||\"y\",c.inertia=c.inertia||\"normal\",this.options=c,E.axis=c.direction,this.element=a,this.viewport=a.parentNode,this.plugins={},this.element.scrollId=setTimeout(function(){r[E.element.scrollId+\"\"]=E},1),this.viewport.addEventListener(\"touchstart\",t,!1),this.viewport.addEventListener(\"touchend\",w,!1),this.viewport.addEventListener(\"touchcancel\",w,!1),this.viewport.addEventListener(\"panstart\",x,!1),this.viewport.addEventListener(\"panmove\",z,!1),this.viewport.addEventListener(\"panend\",A,!1),c.isPrevent&&(this.viewport.addEventListener(\"touchstart\",function(a){B=!0},!1),E.viewport.addEventListener(\"touchend\",function(a){B=!1},!1)),c.isFixScrollendClick){var F,G;this.viewport.addEventListener(\"scrolling\",function(){F=!0,G&&clearTimeout(G),G=setTimeout(function(a){F=!1},400)},!1),this.viewport.addEventListener(\"click\",l,!1),this.viewport.addEventListener(\"tap\",o,!1)}if(c.useFrameAnimation){var H;Object.defineProperty(this,\"animation\",{get:function(){return H}})}else{var I,J=0;a.addEventListener(v?\"transitionend\":y+\"TransitionEnd\",function(a){if(I){var c=I;I=null,clearTimeout(J),b.animation.requestFrame(function(){c(a)})}},!1)}var K,L,M,N;Object.defineProperty(this,\"isScrolling\",{get:function(){return!!L}});var O,P={init:function(){return this.enable(),this.refresh(),this.scrollTo(0),this},enable:function(){return this.enabled=!0,this},disable:function(){var a=this.element;return this.enabled=!1,this.options.useFrameAnimation?H&&H.stop():b.animation.requestFrame(function(){a.style[y+\"Transform\"]=getComputedStyle(a)[y+\"Transform\"]}),this},getScrollWidth:function(){return e(this.element).width},getScrollHeight:function(){return e(this.element).height},getScrollLeft:function(){return-k(this).x-this.options.xPaddingTop},getScrollTop:function(){return-k(this).y-this.options.yPaddingTop},getMaxScrollLeft:function(){return-E.maxScrollOffset-this.options.xPaddingTop},getMaxScrollTop:function(){return-E.maxScrollOffset-this.options.yPaddingTop},getBoundaryOffset:function(){return Math.abs(h(this,k(this)[this.axis])||0)},refresh:function(){var a=this.element,b=\"y\"===this.axis,c=b?\"height\":\"width\";if(null!=this.options[c])a.style[c]=this.options[c]+\"px\";else if(this.options.useElementRect)a.style[c]=\"auto\",a.style[c]=e(a)[c]+\"px\";else if(a.childElementCount>0){var d,h,i=a.firstElementChild,l=a.lastElementChild;if(document.createRange&&!this.options.ignoreOverflow&&(d=document.createRange(),d.selectNodeContents(a),h=e(d)),h)a.style[c]=h[c]+\"px\";else{for(;i&&0===e(i)[c]&&i.nextElementSibling;)i=i.nextElementSibling;for(;l&&l!==i&&0===e(l)[c]&&l.previousElementSibling;)l=l.previousElementSibling;a.style[c]=e(l)[b?\"bottom\":\"right\"]-e(i)[b?\"top\":\"left\"]+\"px\"}}return this.transformOffset=k(this),this.minScrollOffset=f(this),this.maxScrollOffset=g(this),this.scrollTo(-this.transformOffset[this.axis]-this.options[this.axis+\"PaddingTop\"]),j(this,\"contentrefresh\"),this},offset:function(a){var b=e(this.element),c=e(a);if(\"y\"===this.axis){var d={top:c.top-b.top-this.options.yPaddingTop,left:c.left-b.left,right:b.right-c.right,width:c.width,height:c.height};d.bottom=d.top+d.height}else{var d={top:c.top-b.top,bottom:b.bottom-c.bottom,left:c.left-b.left-this.options.xPaddingTop,width:c.width,height:c.height};d.right=d.left+d.width}return d},getRect:function(a){var b=e(this.viewport),c=e(a);if(\"y\"===this.axis){var d={top:c.top-b.top,left:c.left-b.left,right:b.right-c.right,width:c.width,height:c.height};d.bottom=d.top+d.height}else{var d={top:c.top-b.top,bottom:b.bottom-c.bottom,left:c.left-b.left,width:c.width,height:c.height};d.right=d.left+d.width}return d},isInView:function(a){var b=this.getRect(this.viewport),c=this.getRect(a);return\"y\"===this.axis?b.top<c.bottom&&b.bottom>c.top:b.left<c.right&&b.right>c.left},scrollTo:function(a,c){var d=this;this.element;if(a=-a-this.options[this.axis+\"PaddingTop\"],a=i(this,a),L=!0,c===!0)if(this.options.useFrameAnimation){var e=k(d)[this.axis],f=a-e;H=new b.animation(400,b.cubicbezier.ease,0,function(a,b){var c=(e+f*b).toFixed(2);n(d,c),j(d,\"scrolling\")}),H.onend(D),H.play()}else m(d,\"0.4s\",\"ease\"),n(d,a),p(D,400),b.animation.requestFrame(function(){L&&d.enabled&&(j(d,\"scrolling\"),b.animation.requestFrame(arguments.callee))});else this.options.useFrameAnimation||m(d,\"\",\"\"),n(d,a),D();return this},scrollToElement:function(a,b){var c=this.offset(a);return c=c[\"y\"===this.axis?\"top\":\"left\"],this.scrollTo(c,b)},getViewWidth:function(){return e(this.viewport).width},getViewHeight:function(){return e(this.viewport).height},addPulldownHandler:function(a){var b=this;return this.element.addEventListener(\"pulldownend\",function(c){b.disable(),a.call(b,c,function(){b.scrollTo(0,!0),b.refresh(),b.enable()})},!1),this},addPullupHandler:function(a){var b=this;return this.element.addEventListener(\"pullupend\",function(c){b.disable(),a.call(b,c,function(){b.scrollTo(b.getScrollHeight(),!0),b.refresh(),b.enable()})},!1),this},addScrollstartHandler:function(a){var b=this;return this.element.addEventListener(\"scrollstart\",function(c){a.call(b,c)},!1),this},addScrollingHandler:function(a){var b=this;return this.element.addEventListener(\"scrolling\",function(c){a.call(b,c)},!1),this},addScrollendHandler:function(a){var b=this;return this.element.addEventListener(\"scrollend\",function(c){a.call(b,c)},!1),this},addContentrenfreshHandler:function(a){var b=this;this.element.addEventListener(\"contentrefresh\",function(c){a.call(b,c)},!1)},addEventListener:function(a,b,c){var d=this;this.element.addEventListener(a,function(a){b.call(d,a)},!!c)},removeEventListener:function(a,b){var c=this;this.element.removeEventListener(a,function(a){b.call(c,a)})},enablePlugin:function(a,b){var c=s[a];return c&&!this.plugins[a]&&(this.plugins[a]=!0,b=b||{},c.call(this,a,b)),this}};for(var Q in P)this[Q]=P[Q];delete P}var p=a.document,q=a.navigator.userAgent,r={},s={},t=a.dpr||(a.navigator.userAgent.match(/iPhone|iPad|iPod/)?document.documentElement.clientWidth/a.screen.availWidth:1),u={normal:[2*t,.0015*t],slow:[1.5*t,.003*t],veryslow:[1.5*t,.005*t]},v=!!q.match(/Firefox/i),w=!!q.match(/IEMobile/i),x=v?\"-moz-\":w?\"-ms-\":\"-webkit-\",y=v?\"Moz\":w?\"ms\":\"webkit\",z=w?\"MSCSSMatrix\":\"WebKitCSSMatrix\",A=!!v||z in a&&\"m11\"in new a[z],B=!1;p.addEventListener(\"touchmove\",function(a){return B?(a.preventDefault(),!1):!0},!1),b.scroll=function(a,c){if(1===arguments.length&&!(arguments[0]instanceof HTMLElement))if(c=arguments[0],c.scrollElement)a=c.scrollElement;else{if(!c.scrollWrap)throw new Error(\"no scroll element\");a=c.scrollWrap.firstElementChild}if(!a.parentNode)throw new Error(\"wrong dom tree\");if(c&&c.direction&&[\"x\",\"y\"].indexOf(c.direction)<0)throw new Error(\"wrong direction\");var d;return d=c.downgrade===!0&&b.scroll.downgrade?b.scroll.downgrade(a,c):a.scrollId?r[a.scrollId]:new o(a,c)},b.scroll.plugin=function(a,b){return b?(a=a.split(\",\"),void a.forEach(function(a){s[a]=b})):s[a]}}(window,window.lib||(window.lib={}));;module.exports = window.lib['scroll'];\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/scrolljs/build/scroll.common.js\n ** module id = 32\n ** module chunks = 0\n **/","(typeof window === 'undefined') && (window = {ctrl: {}, lib: {}});!window.ctrl && (window.ctrl = {});!window.lib && (window.lib = {});!function(a,b){function c(a){return setTimeout(a,l)}function d(a){clearTimeout(a)}function e(){var a={},b=new m(function(b,c){a.resolve=b,a.reject=c});return a.promise=b,a}function f(a,b){return[\"then\",\"catch\"].forEach(function(c){b[c]=function(){return a[c].apply(a,arguments)}}),b}function g(b){var c,d,h=!1;this.request=function(){h=!1;var g=arguments;return c=e(),f(c.promise,this),d=n(function(){h||c&&c.resolve(b.apply(a,g))}),this},this.cancel=function(){return d&&(h=!0,o(d),c&&c.reject(\"CANCEL\")),this},this.clone=function(){return new g(b)}}function h(a,b){\"function\"==typeof b&&(b={0:b});for(var c=a/l,d=1/c,e=[],f=Object.keys(b).map(function(a){return parseInt(a)}),h=0;c>h;h++){var i=f[0],j=d*h;if(null!=i&&100*j>=i){var k=b[\"\"+i];k instanceof g||(k=new g(k)),e.push(k),f.shift()}else e.length&&e.push(e[e.length-1].clone())}return e}function i(a){var c;return\"string\"==typeof a||a instanceof Array?b.cubicbezier?\"string\"==typeof a?b.cubicbezier[a]&&(c=b.cubicbezier[a]):a instanceof Array&&4===a.length&&(c=b.cubicbezier.apply(b.cubicbezier,a)):console.error(\"require lib.cubicbezier\"):\"function\"==typeof a&&(c=a),c}function j(a,b,c){var d,g=h(a,c),j=1/(a/l),k=0,m=i(b);if(!m)throw new Error(\"unexcept timing function\");var n=!1;this.play=function(){function a(){var c=j*(k+1).toFixed(10),e=g[k];e.request(c.toFixed(10),b(c).toFixed(10)).then(function(){n&&(k===g.length-1?(n=!1,d&&d.resolve(\"FINISH\"),d=null):(k++,a()))},function(){})}if(!n)return n=!0,d||(d=e(),f(d.promise,this)),a(),this},this.stop=function(){return n?(n=!1,g[k]&&g[k].cancel(),this):void 0}}var k=60,l=1e3/k,m=a.Promise||b.promise&&b.promise.ES6Promise,n=window.requestAnimationFrame||window.msRequestAnimationFrame||window.webkitRequestAnimationFrame||window.mozRequestAnimationFrame||c,o=window.cancelAnimationFrame||window.msCancelAnimationFrame||window.webkitCancelAnimationFrame||window.mozCancelAnimationFrame||d;(n===c||o===d)&&(n=c,o=d),b.animation=function(a,b,c){return new j(a,b,c)},b.animation.frame=function(a){return new g(a)},b.animation.requestFrame=function(a){var b=new g(a);return b.request()}}(window,window.lib||(window.lib={}));;module.exports = window.lib['animation'];\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/animationjs/build/animation.common.js\n ** module id = 33\n ** module chunks = 0\n **/","(typeof window === 'undefined') && (window = {ctrl: {}, lib: {}});!window.ctrl && (window.ctrl = {});!window.lib && (window.lib = {});!function(a,b){function c(a,b,c,d){function e(a){return(3*k*a+2*l)*a+m}function f(a){return((k*a+l)*a+m)*a}function g(a){return((n*a+o)*a+p)*a}function h(a){for(var b,c,d=a,g=0;8>g;g++){if(c=f(d)-a,Math.abs(c)<j)return d;if(b=e(d),Math.abs(b)<j)break;d-=c/b}var h=1,i=0;for(d=a;h>i;){if(c=f(d)-a,Math.abs(c)<j)return d;c>0?h=d:i=d,d=(h+i)/2}return d}function i(a){return g(h(a))}var j=1e-6,k=3*a-3*c+1,l=3*c-6*a,m=3*a,n=3*b-3*d+1,o=3*d-6*b,p=3*b;return i}b.cubicbezier=c,b.cubicbezier.linear=c(0,0,1,1),b.cubicbezier.ease=c(.25,.1,.25,1),b.cubicbezier.easeIn=c(.42,0,1,1),b.cubicbezier.easeOut=c(0,0,.58,1),b.cubicbezier.easeInOut=c(.42,0,.58,1)}(window,window.lib||(window.lib={}));;module.exports = window.lib['cubicbezier'];\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/cubicbezier/build/cubicbezier.common.js\n ** module id = 34\n ** module chunks = 0\n **/","(typeof window === 'undefined') && (window = {ctrl: {}, lib: {}});!window.ctrl && (window.ctrl = {});!window.lib && (window.lib = {});!function(a){\"use strict\";function b(a,b){for(var c=a;c;){if(c.contains(b)||c==b)return c;c=c.parentNode}return null}function c(a,b,c){var d=i.createEvent(\"HTMLEvents\");if(d.initEvent(b,!0,!0),\"object\"==typeof c)for(var e in c)d[e]=c[e];a.dispatchEvent(d)}function d(a,b,c,d,e,f,g,h){var i=Math.atan2(h-f,g-e)-Math.atan2(d-b,c-a),j=Math.sqrt((Math.pow(h-f,2)+Math.pow(g-e,2))/(Math.pow(d-b,2)+Math.pow(c-a,2))),k=[e-j*a*Math.cos(i)+j*b*Math.sin(i),f-j*b*Math.cos(i)-j*a*Math.sin(i)];return{rotate:i,scale:j,translate:k,matrix:[[j*Math.cos(i),-j*Math.sin(i),k[0]],[j*Math.sin(i),j*Math.cos(i),k[1]],[0,0,1]]}}function e(a){0===Object.keys(l).length&&(j.addEventListener(\"touchmove\",f,!1),j.addEventListener(\"touchend\",g,!1),j.addEventListener(\"touchcancel\",h,!1));for(var d=0;d<a.changedTouches.length;d++){var e=a.changedTouches[d],i={};for(var m in e)i[m]=e[m];var n={startTouch:i,startTime:Date.now(),status:\"tapping\",element:a.srcElement||a.target,pressingHandler:setTimeout(function(b,d){return function(){\"tapping\"===n.status&&(n.status=\"pressing\",c(b,\"longpress\",{touch:d,touches:a.touches,changedTouches:a.changedTouches,touchEvent:a})),clearTimeout(n.pressingHandler),n.pressingHandler=null}}(a.srcElement||a.target,a.changedTouches[d]),500)};l[e.identifier]=n}if(2==Object.keys(l).length){var o=[];for(var m in l)o.push(l[m].element);c(b(o[0],o[1]),\"dualtouchstart\",{touches:k.call(a.touches),touchEvent:a})}}function f(a){for(var e=0;e<a.changedTouches.length;e++){var f=a.changedTouches[e],g=l[f.identifier];if(!g)return;g.lastTouch||(g.lastTouch=g.startTouch),g.lastTime||(g.lastTime=g.startTime),g.velocityX||(g.velocityX=0),g.velocityY||(g.velocityY=0),g.duration||(g.duration=0);var h=Date.now()-g.lastTime,i=(f.clientX-g.lastTouch.clientX)/h,j=(f.clientY-g.lastTouch.clientY)/h,k=70;h>k&&(h=k),g.duration+h>k&&(g.duration=k-h),g.velocityX=(g.velocityX*g.duration+i*h)/(g.duration+h),g.velocityY=(g.velocityY*g.duration+j*h)/(g.duration+h),g.duration+=h,g.lastTouch={};for(var m in f)g.lastTouch[m]=f[m];g.lastTime=Date.now();var n=f.clientX-g.startTouch.clientX,o=f.clientY-g.startTouch.clientY,p=Math.sqrt(Math.pow(n,2)+Math.pow(o,2));(\"tapping\"===g.status||\"pressing\"===g.status)&&p>10&&(g.status=\"panning\",g.isVertical=!(Math.abs(n)>Math.abs(o)),c(g.element,\"panstart\",{touch:f,touches:a.touches,changedTouches:a.changedTouches,touchEvent:a,isVertical:g.isVertical}),c(g.element,(g.isVertical?\"vertical\":\"horizontal\")+\"panstart\",{touch:f,touchEvent:a})),\"panning\"===g.status&&(g.panTime=Date.now(),c(g.element,\"panmove\",{displacementX:n,displacementY:o,touch:f,touches:a.touches,changedTouches:a.changedTouches,touchEvent:a,isVertical:g.isVertical}),g.isVertical?c(g.element,\"verticalpanmove\",{displacementY:o,touch:f,touchEvent:a}):c(g.element,\"horizontalpanmove\",{displacementX:n,touch:f,touchEvent:a}))}if(2==Object.keys(l).length){for(var q,r=[],s=[],t=[],e=0;e<a.touches.length;e++){var f=a.touches[e],g=l[f.identifier];r.push([g.startTouch.clientX,g.startTouch.clientY]),s.push([f.clientX,f.clientY])}for(var m in l)t.push(l[m].element);q=d(r[0][0],r[0][1],r[1][0],r[1][1],s[0][0],s[0][1],s[1][0],s[1][1]),c(b(t[0],t[1]),\"dualtouch\",{transform:q,touches:a.touches,touchEvent:a})}}function g(a){if(2==Object.keys(l).length){var d=[];for(var e in l)d.push(l[e].element);c(b(d[0],d[1]),\"dualtouchend\",{touches:k.call(a.touches),touchEvent:a})}for(var i=0;i<a.changedTouches.length;i++){var n=a.changedTouches[i],o=n.identifier,p=l[o];if(p){if(p.pressingHandler&&(clearTimeout(p.pressingHandler),p.pressingHandler=null),\"tapping\"===p.status&&(p.timestamp=Date.now(),c(p.element,\"tap\",{touch:n,touchEvent:a}),m&&p.timestamp-m.timestamp<300&&c(p.element,\"doubletap\",{touch:n,touchEvent:a}),m=p),\"panning\"===p.status){var q=Date.now(),r=q-p.startTime,s=((n.clientX-p.startTouch.clientX)/r,(n.clientY-p.startTouch.clientY)/r,n.clientX-p.startTouch.clientX),t=n.clientY-p.startTouch.clientY,u=Math.sqrt(p.velocityY*p.velocityY+p.velocityX*p.velocityX),v=u>.5&&q-p.lastTime<100,w={duration:r,isflick:v,velocityX:p.velocityX,velocityY:p.velocityY,displacementX:s,displacementY:t,touch:n,touches:a.touches,changedTouches:a.changedTouches,touchEvent:a,isVertical:p.isVertical};c(p.element,\"panend\",w),v&&(c(p.element,\"swipe\",w),p.isVertical?c(p.element,\"verticalswipe\",w):c(p.element,\"horizontalswipe\",w))}\"pressing\"===p.status&&c(p.element,\"pressend\",{touch:n,touchEvent:a}),delete l[o]}}0===Object.keys(l).length&&(j.removeEventListener(\"touchmove\",f,!1),j.removeEventListener(\"touchend\",g,!1),j.removeEventListener(\"touchcancel\",h,!1))}function h(a){if(2==Object.keys(l).length){var d=[];for(var e in l)d.push(l[e].element);c(b(d[0],d[1]),\"dualtouchend\",{touches:k.call(a.touches),touchEvent:a})}for(var i=0;i<a.changedTouches.length;i++){var m=a.changedTouches[i],n=m.identifier,o=l[n];o&&(o.pressingHandler&&(clearTimeout(o.pressingHandler),o.pressingHandler=null),\"panning\"===o.status&&c(o.element,\"panend\",{touch:m,touches:a.touches,changedTouches:a.changedTouches,touchEvent:a}),\"pressing\"===o.status&&c(o.element,\"pressend\",{touch:m,touchEvent:a}),delete l[n])}0===Object.keys(l).length&&(j.removeEventListener(\"touchmove\",f,!1),j.removeEventListener(\"touchend\",g,!1),j.removeEventListener(\"touchcancel\",h,!1))}var i=a.document,j=i.documentElement,k=Array.prototype.slice,l={},m=null;j.addEventListener(\"touchstart\",e,!1)}(window);;module.exports = window.lib['gesturejs'];\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/gesturejs/build/gesturejs.common.js\n ** module id = 35\n ** module chunks = 0\n **/","(typeof window === 'undefined') && (window = {ctrl: {}, lib: {}});!window.ctrl && (window.ctrl = {});!window.lib && (window.lib = {});!function(a,b){function c(a,b){return[[(a/3+(a+b)/3-a)/(b-a),(a*a/3+a*b*2/3-a*a)/(b*b-a*a)],[(b/3+(a+b)/3-a)/(b-a),(b*b/3+a*b*2/3-a*a)/(b*b-a*a)]]}function d(a){if(this.v=a.v||0,this.a=a.a||0,\"undefined\"!=typeof a.t&&(this.t=a.t),\"undefined\"!=typeof a.s&&(this.s=a.s),\"undefined\"==typeof this.t)if(\"undefined\"==typeof this.s)this.t=-this.v/this.a;else{var b=(Math.sqrt(this.v*this.v+2*this.a*this.s)-this.v)/this.a,c=(-Math.sqrt(this.v*this.v+2*this.a*this.s)-this.v)/this.a;this.t=Math.min(b,c)}\"undefined\"==typeof this.s&&(this.s=this.a*this.t*this.t/2+this.v*this.t)}d.prototype.generateCubicBezier=function(){return c(this.v/this.a,this.t+this.v/this.a)},b.motion=d}(window,window.lib||(window.lib={}));;module.exports = window.lib['motion'];\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/motionjs/build/motion.common.js\n ** module id = 36\n ** module chunks = 0\n **/","'use strict'\n\nvar Atomic = require('./atomic')\nrequire('kountdown/build/countdown')\n\nvar FORMATTER_REGEXP = /(\\\\)?(dd*|hh?|mm?|ss?)/gi\n\nfunction formatDateTime(data, formatter, timeColor) {\n  return formatter.replace(FORMATTER_REGEXP, function (m) {\n    var len = m.length\n    var firstChar = m.charAt(0)\n    // escape character\n    if (firstChar === '\\\\') {\n      return m.replace('\\\\', '')\n    }\n    var value = (firstChar === 'd' ? data.days :\n                firstChar === 'h' ? data.hours :\n                firstChar === 'm' ? data.minutes :\n                firstChar === 's' ? data.seconds : 0) + ''\n\n    // 5 zero should be enough\n    return '<span style=\"margin:4px;color:'\n      + timeColor + '\" >'\n      + ('00000' + value).substr(-Math.max(value.length, len))\n      + '</span>'\n  })\n}\n\nfunction Countdown (data) {\n  Atomic.call(this, data)\n}\n\nCountdown.prototype = Object.create(Atomic.prototype)\n\nCountdown.prototype.create = function () {\n  var node = document.createElement('div')\n  node.classList.add('weex-element')\n  var data = this.data\n  var time = Number(data.attr.countdownTime) || 0\n  var endTime = Date.now() / 1000 + time\n  var cd = lib.countdown({\n    endDate: endTime,\n    onUpdate: function (time) {\n      var timeColor = data.style.timeColor || '#000'\n      var result = formatDateTime(time, data.attr.formatterValue, timeColor)\n      node.innerHTML = result\n    },\n    onEnd: function () {\n    }\n  }).start()\n\n  return node\n}\n\nCountdown.prototype.style = {\n  textColor: function (value) {\n    this.node.style.color = value\n  }\n}\n\nmodule.exports = Countdown\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/components/countdown.js\n ** module id = 37\n ** module chunks = 0\n **/","!function(a,b){function c(a){var b;if(\"number\"==typeof a)b=new Date(1e3*a);else if(\"string\"==typeof a){var c=a.charAt(0),d=\"+\"===c,h=\"-\"===c;if(d||h){for(var i,j=a.substr(1),k=j.split(\":\"),l=[0,0,0,0],m=4;k.length&&--m>=0;)l[m]=parseInt(k.pop())||0;i=e*l[0]+f*l[1]+g*l[2]+l[3],b=new Date,b.setSeconds(b.getSeconds()+i*(h?-1:1)),b.setMilliseconds(0)}}return b||(b=new Date(a)),b}function d(a,b){return b.replace(FORMATTER_REGEXP,function(b){var c=b.length,d=b.charAt(0);if(\"\\\\\"===d)return b.replace(\"\\\\\",\"\");var e=(\"d\"===d?a.days:\"h\"===d?a.hours:\"m\"===d?a.minutes:\"s\"===d?a.seconds:0)+\"\";return(\"00000\"+e).substr(-Math.max(e.length,c))})}var e=86400,f=3600,g=60,h=\"d天hh时mm分ss秒\";FORMATTER_REGEXP=/(\\\\)?(dd*|hh?|mm?|ss?)/gi;var i=function(a){a=a||{};var b=this,d=c(a.endDate);if(!d||!d.getTime())throw new Error(\"Invalid endDate\");b.endDate=d,b.onUpdate=a.onUpdate,b.onEnd=a.onEnd,b.interval=a.interval||1e3,b.stringFormatter=a.stringFormatter||h,b.correctDateOffset=a.correctDateOffset||0,b.updateElement=a.updateElement,b._data={days:0,hours:0,minutes:0,seconds:0}};i.prototype={start:function(){var a=this;return a.stop(),a._update()&&(a._intervalId=setInterval(function(){a._update()},a.interval)),a},_update:function(){var a,b=this,c=b._data,h=b.updateElement,i=+new Date+1e3*b.correctDateOffset,j=Math.max(0,Math.round((b.endDate.getTime()-i)/1e3)),k=0>=j;return c.totalSeconds=j,j-=(c.days=Math.floor(j/e))*e,j-=(c.hours=Math.floor(j/f))*f,j-=(c.minutes=Math.floor(j/g))*g,c.seconds=j,c.stringValue=d(c,b.stringFormatter),h&&(h.innerHTML=c.stringValue),(a=b.onUpdate)&&a.call(b,c),k?(b.stop(),(a=b.onEnd)&&a.call(b),!1):!0},stop:function(){var a=this;return a._intervalId&&(clearInterval(a._intervalId),a._intervalId=null),a},setEndDate:function(a){var b=this;return b.endDate=c(a),b}},b.countdown=function(a){return new i(a)}}(window,window.lib||(window.lib={}));\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/kountdown/build/countdown.js\n ** module id = 38\n ** module chunks = 0\n **/","'use strict'\n\nvar config = require('../config')\nvar Component = require('./component')\nvar ComponentManager = require('../componentManager')\nvar LazyLoad = require('../lazyLoad')\n\nfunction Marquee (data) {\n  this.interval = Number(data.attr.interval) || 5 * 1000\n  this.transitionDuration = Number(data.attr.transitionDuration) || 500\n  this.delay = Number(data.attr.delay) || 0\n  Component.call(this, data)\n}\n\nMarquee.prototype = Object.create(Component.prototype)\n\nMarquee.prototype.create = function () {\n  var node = document.createElement('div')\n  node.classList.add('weex-container')\n  node.style.overflow = 'hidden'\n  // fix page shaking during slider's playing\n  node.style.webkitTransform = 'translate3D(0,0,0)'\n  node.addEventListener('webkitTransitionEnd', this.end.bind(this), false)\n  return node\n}\n\nMarquee.prototype.createChildren = function () {\n  // first run:\n  // - create each child\n  // - append to parentNode\n  // - find current and next\n  // - set current and next shown and others hidden\n  var children = this.data.children\n  var parentRef = this.data.ref\n  var instanceId = this.data.instanceId\n  var items = []\n  var componentManager = this.getComponentManager()\n\n  var fragment, isFlex, child, node, i\n\n  if (children && children.length) {\n    fragment = document.createDocumentFragment()\n    isFlex = false\n    for (i = 0; i < children.length; i++) {\n      children[i].scale = this.data.scale\n      children[i].instanceId = instanceId\n      child = componentManager.createElement(children[i])\n      child.parentRef = parentRef\n      this.initChild(child)\n      // append and push\n      items.push(child)\n      fragment.appendChild(child.node)\n      if (!isFlex && child.data.style.hasOwnProperty('flex')) {\n        isFlex = true\n      }\n    }\n    this.node.appendChild(fragment)\n  }\n\n  // set items\n  this.items = items\n\n  // reset the clock for first transition\n  this.reset()\n}\n\nMarquee.prototype.initChild = function (child) {\n  var node = child.node\n  node.style.position = 'absolute'\n  node.style.top = '0'\n  node.style.left = '0'\n}\n\nMarquee.prototype.appendChild = function (data) {\n  // dom + items\n  var componentManager = ComponentManager.getInstance(this.data.instanceId)\n  var child = componentManager.createElement(data)\n  this.initChild(child)\n  this.node.appendChild(child.node)\n  this.items.push(child)\n  this.reset()\n  return child // @todo redesign Component#appendChild(component)\n}\n\nMarquee.prototype.insertBefore = function (child, before) {\n  // dom + items\n  var index = this.items.indexOf(before)\n  this.items.splice(index, 0, child)\n  this.initChild(child)\n  this.node.insertBefore(child.node, before.node)\n  this.reset()\n}\n\nMarquee.prototype.removeChild = function (child) {\n  // dom + items\n  var index = this.items.indexOf(child)\n  this.items.splice(index, 1)\n  this.node.removeChild(child.node)\n  this.reset()\n}\n\n/**\n * status: {\n *   current: {translateY: 0, shown: true},\n *   next: {translateY: height, shown: true},\n *   others[]: {shown: false}\n *   index: index\n * }\n */\nMarquee.prototype.reset = function () {\n  var interval = this.interval - 0\n  var delay = this.delay - 0\n  var items = this.items\n  var self = this\n\n  var loop = function () {\n    self.next()\n    self.timerId = setTimeout(loop, self.interval)\n  }\n\n  // reset display and transform\n  items.forEach(function (item, index) {\n    var node = item.node\n    // set non-current(0)|next(1) item hidden\n    node.style.display = index > 1 ? 'none' : ''\n    // set next(1) item translateY\n    // TODO: it supposed to use item.data.style\n    // but somehow the style object is empty.\n    // This problem relies on jsframework's bugfix.\n\n    // node.style.transform = index === 1\n    //     ? 'translate3D(0,' + config.scale * item.data.style.height + 'px,0)'\n    //     : ''\n    // node.style.webkitTransform = index === 1\n    //     ? 'translate3D(0,' + config.scale * item.data.style.height + 'px,0)'\n    //     : ''\n    node.style.transform = index === 1\n        ? 'translate3D(0,' + self.data.scale * self.data.style.height + 'px,0)'\n        : ''\n    node.style.webkitTransform = index === 1\n        ? 'translate3D(0,' + self.data.scale * self.data.style.height + 'px,0)'\n        : ''\n  })\n\n  setTimeout(function () {\n    // reset current, next, index\n    self.currentItem = items[0]\n    self.nextItem = items[1]\n    self.currentIndex = 0\n\n    items.forEach(function (item, index) {\n      var node = item.node\n      // set transition\n      node.style.transition = 'transform '\n          + self.transitionDuration\n          + 'ms ease'\n      node.style.webkitTransition = '-webkit-transform '\n          + self.transitionDuration\n          + 'ms ease'\n    })\n\n    clearTimeout(self.timerId)\n\n    if (items.length > 1) {\n      self.timerId = setTimeout(loop, delay + interval)\n    }\n  }, 13)\n\n}\n\n/**\n * next:\n * - current: {translateY: -height}\n * - next: {translateY: 0}\n */\nMarquee.prototype.next = function () {\n  // - update state\n  //   - set current and next transition\n  //   - hide current when transition end\n  //   - set next to current\n  //   - find new next\n  var next = this.nextItem.node\n  var current = this.currentItem.node\n  this.transitionIndex = this.currentIndex\n\n  // Use setTimeout to fix the problem that when the\n  // page recover from backstage, the slider will\n  // not work any longer.\n  setTimeout(function () {\n    next.style.transform = 'translate3D(0,0,0)'\n    next.style.webkitTransform = 'translate3D(0,0,0)'\n    current.style.transform = 'translate3D(0,-'\n        + this.data.scale * this.data.style.height\n        + 'px,0)'\n    current.style.webkitTransform = 'translate3D(0,-'\n        + this.data.scale * this.data.style.height\n        + 'px,0)'\n    this.fireEvent('change')\n  }.bind(this), 300)\n}\n\nMarquee.prototype.fireEvent = function (type) {\n  var length = this.items.length\n  var nextIndex = (this.currentIndex + 1) % length\n  var evt = document.createEvent('HTMLEvents')\n  evt.initEvent(type, false, false)\n  evt.data = {\n    prevIndex: this.currentIndex,\n    index: nextIndex\n  }\n  this.node.dispatchEvent(evt)\n}\n\n/**\n * end:\n * - old current: {shown: false}\n * - old current: {translateY: 0}\n * - index++ % length\n * - new current = old next\n * - new next = items[index+1 % length]\n * - new next: {translateY: height}\n * - new next: {shown: true}\n */\nMarquee.prototype.end = function (e) {\n  var target = e.target\n  var items = this.items\n  var length = items.length\n  var current, next\n  var currentIndex, nextIndex\n\n  currentIndex = this.transitionIndex\n\n  if (isNaN(currentIndex)) {\n    return\n  }\n  delete this.transitionIndex\n\n  current = this.currentItem.node\n  current.style.display = 'none'\n  current.style.webkitTransform = ''\n\n  currentIndex = (currentIndex + 1) % length\n  nextIndex = (currentIndex + 1) % length\n\n  this.currentIndex = currentIndex\n  this.currentItem = this.nextItem\n  this.nextItem = items[nextIndex]\n\n  setTimeout(function () {\n    next = this.nextItem.node\n    // TODO: it supposed to use this.nextItem.data.style\n    // but somehow the style object is empty.\n    // This problem relies on jsframework's bugfix.\n\n    next.style.webkitTransform = 'translate3D(0,'\n        + this.data.scale * this.data.style.height\n        + 'px,0)'\n    next.style.display = ''\n    LazyLoad.loadIfNeeded(next)\n  }.bind(this))\n}\n\nMarquee.prototype.attr = {\n  interval: function (value) {\n    this.interval = value\n  },\n  transitionDuration: function (value) {\n    this.transitionDuration = value\n  },\n  delay: function (value) {\n    this.delay = value\n  }\n}\n\nMarquee.prototype.clearAttr = function () {\n  this.interval = 5 * 1000\n  this.transitionDuration = 500\n  this.delay = 0\n}\n\nmodule.exports = Marquee\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/components/marquee.js\n ** module id = 39\n ** module chunks = 0\n **/","'use strict'\n\nvar extend = require('../utils').extend\nvar config = require('../config')\nvar Component = require('./component')\nvar ComponentManager = require('../componentManager')\nvar LazyLoad = require('../lazyLoad')\nrequire('carrousel')\nrequire('../styles/slider.scss')\n\nfunction Slider (data) {\n  this.autoPlay = true  // always true for autoplay\n  this.direction = 'row' // 'column' is not temporarily supported.\n  this.children = []\n  this.isPageShow = true\n  this.isDomRendering = true\n\n  // bind event 'pageshow' and 'pagehide' on window.\n  this._idleWhenPageDisappear()\n  // bind event 'renderBegin' and 'renderEnd' on window.\n  this._idleWhenDomRendering()\n\n  Component.call(this, data)\n}\n\nSlider.prototype = Object.create(Component.prototype)\n\nSlider.prototype._idleWhenPageDisappear = function () {\n  var _this = this\n  window.addEventListener('pageshow', function () {\n    _this.isPageShow = true\n    _this.autoPlay && !_this.isDomRendering && _this.play()\n  })\n  window.addEventListener('pagehide', function () {\n    _this.isPageShow = false\n    _this.stop()\n  })\n}\n\nSlider.prototype._idleWhenDomRendering = function () {\n  var _this = this\n  window.addEventListener('renderend', function () {\n    _this.isDomRendering = false\n    _this.autoPlay && _this.isPageShow && _this.play()\n  })\n  window.addEventListener('renderbegin', function () {\n    _this.isDomRendering = true\n    _this.stop()\n  })\n}\n\nSlider.prototype.attr = {\n  interval: function (val) {\n    this.interval = parseInt(val) || 3000\n    if (this.carrousel) {\n      this.carrousel.playInterval = this.interval\n    }\n  },\n\n  playstatus: function (val) {\n    this.playstatus = val && val !== 'false' ? true : false\n    this.autoPlay = this.playstatus\n    if (this.carrousel) {\n      if (this.playstatus) {\n        this.play()\n      } else {\n        this.stop()\n      }\n    }\n  },\n\n  // support playstatus' alias auto-play for compatibility\n  autoPlay: function (val) {\n    this.attr.playstatus.call(this, val)\n  }\n}\n\nSlider.prototype.create = function () {\n  var node = document.createElement('div')\n  node.classList.add('slider')\n  node.style.position = 'relative'\n  node.style.overflow = 'hidden'\n  return node\n}\n\nSlider.prototype._doRender = function () {\n  var _this = this\n  _this.createChildren()\n  _this.onAppend()\n}\n\nSlider.prototype.removeChild = function (child) {\n  var children = this.data.children\n  if (children) {\n    for (var i = 0; i < children.length; i++) {\n      if (child.data.ref === children[i].ref) {\n        children.splice(i, 1)\n        break\n      }\n    }\n  }\n\n  this._doRender()\n}\n\nSlider.prototype.insertBefore = function (child, before) {\n  var children = this.data.children\n  // var childIndex = this.children.indexOf(before.data)\n  var childIndex = -1\n  for (var i = 0, l = children.length; i < l; i++) {\n    if (children[i].ref === before.data.ref) {\n      childIndex = i\n      break\n    }\n  }\n  children.splice(childIndex, 0, child.data)\n\n  this._doRender()\n  if (this.children.length > 0) {\n    return this.children[this.children.length - 1]\n  }\n}\n\nSlider.prototype.appendChild = function (data) {\n  var children = this.data.children || (this.data.children = [])\n  children.push(data)\n  this._doRender()\n  if (this.children.length > 0) {\n    return this.children[this.children.length - 1]\n  }\n}\n\nSlider.prototype.createChildren = function () {\n\n  var componentManager = this.getComponentManager()\n\n  // recreate slider container.\n  if (this.sliderContainer) {\n    this.node.removeChild(this.sliderContainer)\n  }\n  if (this.indicator) {\n    this.indicator.node.parentNode.removeChild(this.indicator.node)\n  }\n  this.children = []\n\n  var sliderContainer = document.createElement('ul')\n  sliderContainer.style.listStyle = 'none'\n  this.node.appendChild(sliderContainer)\n  this.sliderContainer = sliderContainer\n\n  var children = this.data.children\n  var scale = this.data.scale\n  var fragment = document.createDocumentFragment()\n  var indicatorData, width, height\n  var childWidth = 0\n  var childHeight = 0\n\n  if (children && children.length) {\n    for (var i = 0; i < children.length; i++) {\n      var child\n      children[i].scale = this.data.scale\n      children[i].instanceId = this.data.instanceId\n      if (children[i].type === 'indicator') {\n        indicatorData = extend(children[i], {\n          extra: {\n            amount: children.length - 1,\n            index: 0\n          }\n        })\n      } else {\n        child = componentManager.createElement(children[i], 'li')\n        this.children.push(child)\n        fragment.appendChild(child.node)\n        width = child.data.style.width || 0\n        height = child.data.style.height || 0\n        width > childWidth && (childWidth = width)\n        height > childHeight && (childHeight = height)\n        child.parentRef = this.data.ref\n      }\n    }\n    // append indicator\n    if (indicatorData) {\n      indicatorData.extra.width = this.data.style.width || childWidth\n      indicatorData.extra.height = this.data.style.height || childHeight\n      this.indicator = componentManager.createElement(indicatorData)\n      this.indicator.parentRef = this.data.ref\n      this.indicator.slider = this\n      this.node.appendChild(this.indicator.node)\n    }\n\n    sliderContainer.style.height = scale * this.data.style.height + 'px'\n    sliderContainer.appendChild(fragment)\n  }\n}\n\nSlider.prototype.onAppend = function () {\n  if (this.carrousel) {\n    this.carrousel.removeEventListener('change', this._getSliderChangeHandler())\n    this.carrousel.stop()\n    this.carrousel = null\n  }\n  this.carrousel = new lib.carrousel(this.sliderContainer, {\n    autoplay: this.autoPlay,\n    useGesture: true\n  })\n\n  this.carrousel.playInterval = this.interval\n  this.carrousel.addEventListener('change', this._getSliderChangeHandler())\n  this.currentIndex = 0\n\n  // preload all images for slider\n  // because:\n  // 1. lib-img doesn't listen to event transitionend\n  // 2. even if we fire lazy load in slider's change event handler,\n  //    the next image still won't be preloaded utill the moment it\n  //    slides into the view, which is too late.\n  if (this.preloadImgsTimer) {\n    clearTimeout(this.preloadImgsTimer)\n  }\n  // The time just before the second slide appear and enough\n  // for all child elements to append is ok.\n  var preloadTime = 0.8\n  this.preloadImgsTimer = setTimeout(function () {\n    var imgs = this.carrousel.element.querySelectorAll('img')\n    for (var i = 0, l = imgs.length; i < l; i++) {\n      var img = imgs[i]\n      var iLazySrc = img.getAttribute('i-lazy-src')\n      var imgSrc = img.getAttribute('img-src')\n      if (iLazySrc) {\n        img.setAttribute('src', iLazySrc)\n      } else if (imgSrc) {\n        img.setAttribute('src', imgSrc)\n      }\n      img.removeAttribute('i-lazy-src')\n      img.removeAttribute('img-src')\n    }\n  }.bind(this), preloadTime * 1000)\n\n  // avoid page scroll when panning\n  var panning = false\n  this.carrousel.element.addEventListener('panstart', function (e) {\n    if (!e.isVertical) {\n      panning = true\n    }\n  })\n  this.carrousel.element.addEventListener('panend', function (e) {\n    if (!e.isVertical) {\n      panning = false\n    }\n  })\n\n  document.addEventListener('touchmove', function (e) {\n    if (panning) {\n      e.preventDefault()\n      return false\n    }\n    return true\n  }.bind(this))\n\n}\n\nSlider.prototype._updateIndicators = function () {\n  this.indicator && this.indicator.setIndex(this.currentIndex)\n}\n\nSlider.prototype._getSliderChangeHandler = function (e) {\n  if (!this.sliderChangeHandler) {\n    this.sliderChangeHandler = (function (e) {\n      var index = this.carrousel.items.index\n      this.currentIndex = index\n\n      // updateIndicators\n      this._updateIndicators()\n\n      this.dispatchEvent('change', { index: index })\n    }).bind(this)\n  }\n  return this.sliderChangeHandler\n}\n\nSlider.prototype.play = function () {\n  this.carrousel.play()\n}\n\nSlider.prototype.stop = function () {\n  this.carrousel.stop()\n}\n\nSlider.prototype.slideTo = function (index) {\n  var offset = index - this.currentIndex\n  this.carrousel.items.slide(offset)\n}\n\nmodule.exports = Slider\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/components/slider.js\n ** module id = 40\n ** module chunks = 0\n **/","(typeof window === 'undefined') && (window = {ctrl: {}, lib: {}});!window.ctrl && (window.ctrl = {});!window.lib && (window.lib = {});require('animationjs');require('cubicbezier');require('gesturejs');!function(){var a=\"[data-ctrl-name=carrousel]{position:relative;-webkit-transform:translateZ(1px);-ms-transform:translateZ(1px);transform:translateZ(1px)}\",b=document.createElement(\"style\");if(document.getElementsByTagName(\"head\")[0].appendChild(b),b.styleSheet)b.styleSheet.disabled||(b.styleSheet.cssText=a);else try{b.innerHTML=a}catch(c){b.innerText=a}}();!function(a,b,c){function d(a){var b,c={x:0,y:0},d=getComputedStyle(a)[l+\"Transform\"];return\"none\"!==d&&(b=d.match(/^matrix3d\\((?:[-\\d.]+,\\s*){12}([-\\d.]+),\\s*([-\\d.]+)(?:,\\s*[-\\d.]+){2}\\)/)||d.match(/^matrix\\((?:[-\\d.]+,\\s*){4}([-\\d.]+),\\s*([-\\d.]+)\\)$/))&&(c.x=parseFloat(b[1])||0,c.y=parseFloat(b[2])||0),c}function e(a,b){return a=parseFloat(a),b=parseFloat(b),0!=a&&(a+=\"px\"),0!=b&&(b+=\"px\"),n?\"translate3d(\"+a+\", \"+b+\", 0)\":\"translate(\"+a+\", \"+b+\")\"}function f(a){return o.call(a)}function g(a,c){function g(a,b){var c=h.createEvent(\"HTMLEvents\");if(c.initEvent(a,!1,!1),b)for(var d in b)c[d]=b[d];n.dispatchEvent(c)}function i(a){for(;0>a;)a+=r;for(;a>=r;)a-=r;return a}function j(a){if(0!==r){var b,c,d=q.get(a);r>1&&(b=q.get(a-1),c=2===r?q.getCloned(a+1):q.get(a+1),d.style.left=-o+\"px\",b.style.left=-o-s+\"px\",c.style.left=-o+s+\"px\"),t=d.index,g(\"change\",{prevItem:b,curItem:d,nextItem:c})}}var k=this,m=Date.now()+\"-\"+ ++p,n=document.createDocumentFragment();1!==arguments.length||arguments[0]instanceof HTMLElement||(c=arguments[0],a=null),a||(a=document.createElement(\"ul\"),n.appendChild(a)),c=c||{},a.setAttribute(\"data-ctrl-name\",\"carrousel\"),a.setAttribute(\"data-ctrl-id\",m),a.style.position=\"relative\",a.style[l+\"Transform\"]=e(0,0);var o=0,q={},r=0,s=c.step||a.getBoundingClientRect().width,t=0;q.add=function(b){var c=document.createElement(\"li\");return c.style.display=\"none\",c.style[\"float\"]=\"left\",c.index=r,\"string\"==typeof b?c.innerHTML=b:b instanceof HTMLElement&&c.appendChild(b),a.appendChild(c),Object.defineProperty(q,r+\"\",{get:function(){return c}}),r++,c},q.get=function(a){return q[i(a)]},q.getCloned=function(b){function c(a,b,d){var e=a._listeners;if(e){b._listeners=e;for(var f in e)b.addEventListener(f,e[f])}if(d&&a.children&&a.children.length)for(var g=0,h=a.children.length;h>g;g++)c(a.children[g],b.children[g],d)}var b=i(b),d=a.querySelector('[cloned=\"cloned-'+b+'\"]'),e=q[b];return d||(d=e.cloneNode(!0),c(e,d,!0),a.appendChild(d),d.setAttribute(\"cloned\",\"cloned-\"+b),d.index=b),d},q.slide=function(c){if(0!==r){1===r&&(c=0);var f=d(a).x,g=o+s*-c,h=g-f;if(0!==h){new b.animation(400,b.cubicbezier.ease,function(b,c){a.style[l+\"Transform\"]=e(f+h*c,0)}).play().then(function(){o=g,a.style[l+\"Transform\"]=e(g,0),c&&j(t+c)})}}},q.next=function(){q.slide(1)},q.prev=function(){q.slide(-1)},f(a.querySelectorAll(\"li\")).forEach(function(a){a.style.position=\"absolute\",a.style.top=\"0\",a.style.left=r*s+\"px\",a.style[\"float\"]=\"left\",a.index=r,Object.defineProperty(q,r+\"\",{get:function(){return a}}),r++}),Object.defineProperty(this,\"items\",{get:function(){return q}}),Object.defineProperty(q,\"length\",{get:function(){return r}}),Object.defineProperty(q,\"index\",{get:function(){return t}}),Object.defineProperty(q,\"step\",{get:function(){return s},set:function(a){s=a}});var u=!1,v=!1,w=!1;this.play=function(){return u?void(v||(v=setTimeout(function(){w=!0,q.next(),setTimeout(function(){w=!1},500),v=setTimeout(arguments.callee,400+z)},400+z))):(u=!0,j(0))},this.stop=function(){v&&(clearTimeout(v),setTimeout(function(){v=!1},500))};var x=!1,y=!1;Object.defineProperty(this,\"autoplay\",{get:function(){return x},set:function(a){x=!!a,y&&(clearTimeout(y),y=!1),x?y=setTimeout(function(){k.play()},2e3):k.stop()}}),this.autoplay=!!c.autoplay;var z=1500;if(Object.defineProperty(this,\"playInterval\",{get:function(){return z},set:function(a){z=a}}),this.playInterval=!!c.playInterval||1500,c.useGesture){var A,B=!1;a.addEventListener(\"panstart\",function(a){a.isVertical||B&&w||(a.preventDefault(),a.stopPropagation(),x&&k.stop(),A=0,B=!0)}),a.addEventListener(\"panmove\",function(b){!b.isVertical&&B&&(b.preventDefault(),b.stopPropagation(),A=b.displacementX,a.style[l+\"Transform\"]=e(o+A,0))}),a.addEventListener(\"panend\",function(a){!a.isVertical&&B&&(a.preventDefault(),a.stopPropagation(),B=!1,a.isflick?0>A?q.next():q.prev():Math.abs(A)<s/2?q.slide(0):q.slide(0>A?1:-1),x&&setTimeout(function(){k.play()},2e3))},!1),a.addEventListener(\"swipe\",function(a){a.isVertical||(a.preventDefault(),a.stopPropagation())})}this.addEventListener=function(a,b){this.root.addEventListener(a,b,!1)},this.removeEventListener=function(a,b){this.root.removeEventListener(a,b,!1)},this.root=n,this.element=a}var h=a.document,i=a.navigator.userAgent,j=!!i.match(/Firefox/i),k=!!i.match(/IEMobile/i),l=j?\"Moz\":k?\"ms\":\"webkit\",m=k?\"MSCSSMatrix\":\"WebKitCSSMatrix\",n=!!j||m in a&&\"m11\"in new a[m],o=Array.prototype.slice,p=0;b.carrousel=g}(window,window.lib,window.ctrl||(window.ctrl={}));;module.exports = window.lib['carrousel'];\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/carrousel/build/carrousel.common.js\n ** module id = 41\n ** module chunks = 0\n **/","// style-loader: Adds some css to the DOM by adding a <style> tag\n\n// load the styles\nvar content = require(\"!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./slider.scss\");\nif(typeof content === 'string') content = [[module.id, content, '']];\n// add the styles to the DOM\nvar update = require(\"!./../../node_modules/style-loader/addStyles.js\")(content, {});\nif(content.locals) module.exports = content.locals;\n// Hot Module Replacement\nif(module.hot) {\n\t// When the styles change, update the <style> tags\n\tif(!content.locals) {\n\t\tmodule.hot.accept(\"!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./slider.scss\", function() {\n\t\t\tvar newContent = require(\"!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./slider.scss\");\n\t\t\tif(typeof newContent === 'string') newContent = [[module.id, newContent, '']];\n\t\t\tupdate(newContent);\n\t\t});\n\t}\n\t// When the module is disposed, remove the <style> tags\n\tmodule.hot.dispose(function() { update(); });\n}\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/styles/slider.scss\n ** module id = 42\n ** module chunks = 0\n **/","exports = module.exports = require(\"./../../node_modules/css-loader/lib/css-base.js\")();\n// imports\n\n\n// module\nexports.push([module.id, \".slider {\\n  position: relative; }\\n\\n.slider .indicator-container {\\n  position: absolute;\\n  display: -webkit-box;\\n  display: -webkit-flex;\\n  display: flex;\\n  -webkit-box-align: center;\\n  box-align: center;\\n  -webkit-align-items: center;\\n  align-items: center;\\n  -webkit-box-pack: center;\\n  box-pack: center;\\n  -webkit-justify-content: center;\\n  justify-content: center;\\n  font-size: 0; }\\n  .slider .indicator-container .indicator {\\n    border-radius: 50%; }\\n  .slider .indicator-container.row {\\n    -webkit-box-orient: horizontal;\\n    box-orient: horizontal;\\n    -webkit-flex-direction: row;\\n    flex-direction: row; }\\n  .slider .indicator-container.column {\\n    -webkit-box-orient: vertical;\\n    box-orient: vertical;\\n    -webkit-flex-direction: column;\\n    flex-direction: column; }\\n\", \"\", {\"version\":3,\"sources\":[\"/./src/src/styles/slider.scss\"],\"names\":[],\"mappings\":\"AAAA;EACE,mBAAmB,EACpB;;AACD;EACE,mBAAmB;EACnB,qBAAqB;EACrB,sBAAsB;EACtB,cAAc;EACd,0BAA0B;EAC1B,kBAAkB;EAClB,4BAA4B;EAC5B,oBAAoB;EACpB,yBAAyB;EACzB,iBAAiB;EACjB,gCAAgC;EAChC,wBAAwB;EACxB,aAAa,EAoBd;EAjCD;IAgBI,mBAAmB,EACpB;EAjBH;IAoBI,+BAA+B;IAC/B,uBAAuB;IACvB,4BAA4B;IAC5B,oBAAoB,EACrB;EAxBH;IA2BI,6BAA6B;IAC7B,qBAAqB;IACrB,+BAA+B;IAC/B,uBAAuB,EACxB\",\"file\":\"slider.scss\",\"sourcesContent\":[\".slider {\\n  position: relative;\\n}\\n.slider .indicator-container {\\n  position: absolute;\\n  display: -webkit-box;\\n  display: -webkit-flex;\\n  display: flex;\\n  -webkit-box-align: center;\\n  box-align: center;\\n  -webkit-align-items: center;\\n  align-items: center;\\n  -webkit-box-pack: center;\\n  box-pack: center;\\n  -webkit-justify-content: center;\\n  justify-content: center;\\n  font-size: 0;\\n\\n  .indicator {\\n    border-radius: 50%;\\n  }\\n\\n  &.row {\\n    -webkit-box-orient: horizontal;\\n    box-orient: horizontal;\\n    -webkit-flex-direction: row;\\n    flex-direction: row;\\n  }\\n\\n  &.column {\\n    -webkit-box-orient: vertical;\\n    box-orient: vertical;\\n    -webkit-flex-direction: column;\\n    flex-direction: column;\\n  }\\n\\n}\"],\"sourceRoot\":\"webpack://\"}]);\n\n// exports\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/css-loader?sourceMap!./~/sass-loader?sourceMap!./src/styles/slider.scss\n ** module id = 43\n ** module chunks = 0\n **/","'use strict'\n\nvar extend = require('../utils').extend\nvar config = require('../config')\nvar Atomic = require('./atomic')\nvar Component = require('./component')\n\nrequire('../styles/indicator.scss')\n\nvar DEFAULT_ITEM_COLOR = '#999'\nvar DEFAULT_ITEM_SELECTED_COLOR = '#0000ff'\nvar DEFAULT_ITEM_SIZE = 20\nvar DEFAULT_MARGIN_SIZE = 10\n\n// Style supported:\n//   position: (default - absolute)\n//   itemColor: color of indicator dots\n//   itemSelectedColor: color of the selected indicator dot\n//   itemSize: size of indicators\n//   other layout styles\nfunction Indicator (data) {\n  this.direction = 'row' // 'column' is not temporarily supported.\n  this.amount = data.extra.amount\n  this.index = data.extra.index\n  this.sliderWidth = data.extra.width\n  this.sliderHeight = data.extra.height\n  var styles = data.style || {}\n  this.data = data\n  this.style.width.call(this, styles.width)\n  this.style.height.call(this, styles.height)\n  this.items = []\n  Atomic.call(this, data)\n}\n\nIndicator.prototype = Object.create(Atomic.prototype)\n\nIndicator.prototype.create = function () {\n  var node = document.createElement('div')\n  node.classList.add('weex-indicators')\n  node.classList.add('weex-element')\n  node.style.position = 'absolute'\n  this.node = node\n  this.style.itemSize.call(this, 0)\n  this.itemColor = DEFAULT_ITEM_COLOR\n  this.itemSelectedColor = DEFAULT_ITEM_SELECTED_COLOR\n  this.updateStyle({\n    left: 0,\n    top: 0,\n    itemSize: 0\n  })\n  return node\n}\n\nIndicator.prototype.createChildren = function () {\n  var root = document.createDocumentFragment()\n  for (var i = 0; i < this.amount; i++) {\n    var indicator = document.createElement('div')\n    indicator.classList.add('weex-indicator')\n    indicator.style.boxSizing = 'border-box'\n    indicator.style.margin = '0 '\n                            + (DEFAULT_MARGIN_SIZE * this.data.scale)\n                            + 'px'\n    indicator.style.width = this.itemSize + 'px'\n    indicator.style.height = this.itemSize + 'px'\n    indicator.setAttribute('index', i)\n    if (this.index === i) {\n      indicator.style.backgroundColor = this.itemSelectedColor\n    } else {\n      indicator.style.backgroundColor = this.itemColor\n    }\n    indicator.addEventListener('click', this._clickHandler.bind(this, i))\n    this.items[i] = indicator\n    root.appendChild(indicator)\n  }\n  this.node.appendChild(root)\n}\n\nIndicator.prototype.style\n    = extend(Object.create(Atomic.prototype.style), {\n  itemColor: function (val) {\n    this.itemColor = val || DEFAULT_ITEM_COLOR\n    for (var i = 0, l = this.items.length; i < l; i++) {\n      this.items[i].style.backgroundColor = this.itemColor\n    }\n  },\n\n  itemSelectedColor: function (val) {\n    this.itemSelectedColor = val || DEFAULT_ITEM_SELECTED_COLOR\n    if (typeof this.index !== 'undefined'\n        && this.items.length > this.index) {\n      this.items[this.index].style.backgroundColor\n          = this.itemSelectedColor\n    }\n  },\n\n  itemSize: function (val) {\n    val = parseInt(val) * this.data.scale\n          || DEFAULT_ITEM_SIZE * this.data.scale\n    this.itemSize = val\n    this.node.style.height = val + 'px'\n    for (var i = 0, l = this.items.length; i < l; i++) {\n      this.items[i].style.width = val + 'px'\n      this.items[i].style.height = val + 'px'\n    }\n  },\n\n  width: function (val) {\n    val = parseInt(val) * this.data.scale || parseInt(this.sliderWidth)\n    this.virtualWrapperWidth = val\n  },\n\n  height: function (val) {\n    val = parseInt(val) * this.data.scale || parseInt(this.sliderHeight)\n    this.virtualWrapperHeight = val\n  },\n\n  top: function (val) {\n    val = this.virtualWrapperHeight / 2 - this.itemSize / 2\n        + val * this.data.scale\n    this.node.style.bottom = ''\n    this.node.style.top = val + 'px'\n  },\n\n  bottom: function (val) {\n    val = this.virtualWrapperHeight / 2 - this.itemSize / 2\n        + val * this.data.scale\n    this.node.style.top = ''\n    this.node.style.bottom = val + 'px'\n  },\n\n  left: function (val) {\n    val = this.virtualWrapperWidth / 2\n          - (this.itemSize + 2 * DEFAULT_MARGIN_SIZE * this.data.scale)\n              * this.amount / 2\n          + val * this.data.scale\n    this.node.style.right = ''\n    this.node.style.left = val + 'px'\n  },\n\n  right: function (val) {\n    val = this.virtualWrapperWidth / 2\n          - (this.itemSize + 2 * DEFAULT_MARGIN_SIZE * this.data.scale)\n              * this.amount / 2\n          + val * this.data.scale\n    this.node.style.left = ''\n    this.node.style.right = val + 'px'\n  }\n})\n\nIndicator.prototype.setIndex = function (idx) {\n  if (idx >= this.amount) {\n    return\n  }\n  var prev = this.items[this.index]\n  var cur = this.items[idx]\n  prev.classList.remove('active')\n  prev.style.backgroundColor = this.itemColor\n  cur.classList.add('active')\n  cur.style.backgroundColor = this.itemSelectedColor\n  this.index = idx\n}\n\nIndicator.prototype._clickHandler = function (idx) {\n  this.slider.slideTo(idx)\n}\n\nmodule.exports = Indicator\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/components/indicator.js\n ** module id = 44\n ** module chunks = 0\n **/","// style-loader: Adds some css to the DOM by adding a <style> tag\n\n// load the styles\nvar content = require(\"!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./indicator.scss\");\nif(typeof content === 'string') content = [[module.id, content, '']];\n// add the styles to the DOM\nvar update = require(\"!./../../node_modules/style-loader/addStyles.js\")(content, {});\nif(content.locals) module.exports = content.locals;\n// Hot Module Replacement\nif(module.hot) {\n\t// When the styles change, update the <style> tags\n\tif(!content.locals) {\n\t\tmodule.hot.accept(\"!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./indicator.scss\", function() {\n\t\t\tvar newContent = require(\"!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./indicator.scss\");\n\t\t\tif(typeof newContent === 'string') newContent = [[module.id, newContent, '']];\n\t\t\tupdate(newContent);\n\t\t});\n\t}\n\t// When the module is disposed, remove the <style> tags\n\tmodule.hot.dispose(function() { update(); });\n}\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/styles/indicator.scss\n ** module id = 45\n ** module chunks = 0\n **/","exports = module.exports = require(\"./../../node_modules/css-loader/lib/css-base.js\")();\n// imports\n\n\n// module\nexports.push([module.id, \".weex-indicators {\\n  position: absolute;\\n  white-space: nowrap; }\\n  .weex-indicators .weex-indicator {\\n    float: left;\\n    border-radius: 50%; }\\n\", \"\", {\"version\":3,\"sources\":[\"/./src/src/styles/indicator.scss\"],\"names\":[],\"mappings\":\"AAAA;EACE,mBAAmB;EACnB,oBAAoB,EAOrB;EATD;IAKI,YAAY;IACZ,mBAAmB,EACpB\",\"file\":\"indicator.scss\",\"sourcesContent\":[\".weex-indicators {\\n  position: absolute;\\n  white-space: nowrap;\\n\\n  .weex-indicator {\\n    float: left;\\n    border-radius: 50%;\\n  }\\n\\n}\"],\"sourceRoot\":\"webpack://\"}]);\n\n// exports\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/css-loader?sourceMap!./~/sass-loader?sourceMap!./src/styles/indicator.scss\n ** module id = 46\n ** module chunks = 0\n **/","'use strict'\n\nvar Atomic = require('./atomic')\nvar msgQueue = require('../messageQueue')\nvar config = require('../config')\nvar utils = require('../utils')\n\n// TODO: refactor this scss code since this is strongly\n// dependent on lib.flexible other than the value of\n// scale.\nrequire('../styles/tabheader.scss')\n\nfunction TabHeader(data) {\n  Atomic.call(this, data)\n}\n\nvar proto = TabHeader.prototype = Object.create(Atomic.prototype)\n\nproto.create = function () {\n  // outside container.\n  var node = document.createElement('div')\n  node.className = 'tab-header'\n  // tip on the top.\n  var bar = document.createElement('div')\n  bar.className = 'header-bar'\n  bar.textContent = 'CHANGE FLOOR'\n  // middle layer.\n  var body = document.createElement('div')\n  body.className = 'header-body'\n  var box = document.createElement('ul')\n  box.className = 'tabheader'\n\n  body.appendChild(box)\n  node.appendChild(bar)\n  node.appendChild(body)\n  this._bar = bar\n  this._body = body\n  this.box = box\n  this.node = node\n  // init events.\n  this._initFoldBtn()\n  this._initEvent()\n  return node\n}\n\nproto._initFoldBtn = function () {\n  var _this = this\n  var node = this.node\n  var btn = document.createElement('span')\n  btn.className = 'fold-toggle iconfont'\n  btn.innerHTML = '&#xe661;'\n  node.appendChild(btn)\n\n  btn.addEventListener('click', function () {\n    if (_this.unfolding) {\n      _this._folding()\n    } else {\n      _this._unfolding()\n    }\n  })\n}\n\nproto._initMask = function () {\n  var mask = document.createElement('div')\n  mask.className = 'tabheader-mask'\n  this.mask = mask\n  // stop default behavior: page moving.\n  mask.addEventListener('touchmove', function (evt) {\n    evt.preventDefault()\n  })\n  // click to unfold.\n  var _this = this\n  mask.addEventListener('click', function () {\n    _this._folding()\n  })\n\n  document.body.appendChild(mask)\n}\n\nproto._unfolding = function () {\n  // mark the initial posiiton of tabheader\n  if (!this.flag) {\n    var flag = document.createComment('tabheader')\n    this.flag = flag\n    this.node.parentNode.insertBefore(flag, this.node)\n  }\n  if (!this.mask) {\n    this._initMask()\n  }\n\n  // record the scroll position.\n  this._scrollVal = this._body.scrollLeft\n  // record the position in document.\n  this._topVal = this.node.getBoundingClientRect().top\n  this._styleTop = this.node.style.top\n\n  document.body.appendChild(this.node)\n  this.node.classList.add('unfold-header')\n  this.node.style.height = 'auto'\n  // recalc the position when it is unfolded.\n  var thHeight = this.node.getBoundingClientRect().height\n  if (thHeight + this._topVal > window.innerHeight) {\n    this._topVal = this._topVal\n        + (window.innerHeight - thHeight - this._topVal)\n  }\n\n  this.node.style.top = this._topVal + 'px'\n  // process mask style\n  this.mask.classList.add('unfold-header')\n  this.mask.style.height = window.innerHeight + 'px'\n  this.unfolding = true\n}\n\nproto._folding = function () {\n  if (this.unfolding !== true) {\n    return\n  }\n\n  this.mask.classList.remove('unfold-header')\n  this.node.classList.remove('unfold-header')\n\n  this.node.style.height = ''\n  this.node.style.top = this._styleTop\n\n  // recover the position of tabheader.\n  this.flag.parentNode.insertBefore(this.node, this.flag)\n  // recover the position of scoller.\n  this._body.scrollLeft = this._scrollVal\n\n  this._scrollToView()\n  this.unfolding = false\n}\n\nproto._initEvent = function () {\n  this._initClickEvent()\n  this._initSelectEvent()\n}\n\n// init events.\nproto._initClickEvent = function () {\n  var box = this.box\n  var _this = this\n\n  box.addEventListener('click', function (evt) {\n    var target = evt.target\n    if (target.nodeName === 'UL') {\n      return\n    }\n\n    if (target.parentNode.nodeName === 'LI') {\n      target = target.parentNode\n    }\n\n    var floor = target.getAttribute('data-floor')\n\n    if (_this.data.attr.selectedIndex == floor) {\n      // Duplicated clicking, not to trigger select event.\n      return\n    }\n\n    fireEvent(target, 'select', {index:  floor})\n  })\n}\n\nproto._initSelectEvent = function () {\n  var node = this.node\n  var _this = this\n  node.addEventListener('select', function (evt) {\n    var index\n    if (evt.index !== undefined) {\n      index = evt.index\n    } else if (evt.data && evt.data.index !== undefined) {\n      index = evt.data.index\n    }\n\n    if (index === undefined) {\n      return\n    }\n\n    _this.attr.selectedIndex.call(_this, index)\n  })\n}\n\nproto.attr = {\n  highlightIcon: function () {\n    return createHighlightIcon()\n  },\n  data: function () {\n    var attr = this.data.attr\n    // Ensure there is a default selected value.\n    if (attr.selectedIndex === undefined) {\n      attr.selectedIndex = 0\n    }\n\n    var list = attr.data || []\n    var curItem = attr.selectedIndex\n\n    var ret = []\n    var itemTmpl = '<li class=\"th-item\" data-floor=\"{{floor}}\">'\n        + '{{hlIcon}}{{floorName}}</li>'\n\n    list.forEach(function (item, idx) {\n      var html = itemTmpl.replace('{{floor}}', idx)\n      if (curItem == idx) {\n        html = html.replace('{{hlIcon}}', createHighlightIcon())\n      } else {\n        html = html.replace('{{hlIcon}}', '')\n      }\n\n      html = html.replace('{{floorName}}', item)\n\n      ret.push(html)\n    }, this)\n\n    this.box.innerHTML = ret.join('')\n  },\n  selectedIndex: function (val) {\n    var attr = this.data.attr\n\n    if (val === undefined) {\n      val = 0\n    }\n\n    // if (val == attr.selectedIndex) {\n    //   return\n    // }\n\n    attr.selectedIndex = val\n\n    this.attr.data.call(this)\n\n    this._folding()\n    this.style.textHighlightColor.call(this, this.textHighlightColor)\n  }\n}\n\nproto.style = Object.create(Atomic.prototype.style)\n\nproto.style.opacity = function (val) {\n  if (val === undefined || val < 0 || val > 1) {\n    val = 1\n  }\n\n  this.node.style.opacity = val\n}\n\nproto.style.textColor = function (val) {\n  if (!isValidColor(val)) {\n    return\n  }\n\n  this.node.style.color = val\n}\n\nproto.style.textHighlightColor = function (val) {\n  if (!isValidColor(val)) {\n    return\n  }\n  this.textHighlightColor = val\n  var attr = this.data.attr\n\n  var node = this.node.querySelector('[data-floor=\"'\n      + attr.selectedIndex + '\"]')\n  if (node) {\n    node.style.color = val\n    this._scrollToView(node)\n  }\n}\n\nproto._scrollToView = function (node) {\n  if (!node) {\n    var attr = this.data.attr\n    node = this.node.querySelector('[data-floor=\"' + attr.selectedIndex + '\"]')\n  }\n  if (!node) {\n    return\n  }\n\n  var defaultVal = this._body.scrollLeft\n  var leftVal = defaultVal  - node.offsetLeft + 300\n\n  var scrollVal = getScrollVal(this._body.getBoundingClientRect(), node)\n  doScroll(this._body, scrollVal)\n}\n\n// scroll the tabheader.\n// positive val means to scroll right.\n// negative val means to scroll left.\nfunction doScroll(node, val, finish) {\n  if (!val) {\n    return\n  }\n  if (finish === undefined) {\n    finish = Math.abs(val)\n  }\n\n  if (finish <= 0) {\n    return\n  }\n\n  setTimeout(function () {\n    if (val > 0) {\n      node.scrollLeft += 2\n    } else {\n      node.scrollLeft -= 2\n    }\n    finish -= 2\n\n    doScroll(node, val, finish)\n  })\n}\n\n// get scroll distance.\nfunction getScrollVal(rect, node) {\n  var left = node.previousSibling\n  var right = node.nextSibling\n  var scrollVal\n\n  // process left-side element first.\n  if (left) {\n    var leftRect = left.getBoundingClientRect()\n    // only need to compare the value of left.\n    if (leftRect.left < rect.left) {\n      scrollVal = leftRect.left\n      return scrollVal\n    }\n  }\n\n  if (right) {\n    var rightRect = right.getBoundingClientRect()\n    // compare the value of right.\n    if (rightRect.right > rect.right) {\n      scrollVal = rightRect.right - rect.right\n      return scrollVal\n    }\n  }\n\n  // process current node, from left to right.\n  var nodeRect = node.getBoundingClientRect()\n  if (nodeRect.left < rect.left) {\n    scrollVal = nodeRect.left\n  } else if (nodeRect.right > rect.right) {\n    scrollVal = nodeRect.right - rect.right\n  }\n\n  return scrollVal\n}\n\n// trigger and broadcast events.\nfunction fireEvent(element, type, data) {\n  var evt = document.createEvent('Event')\n  evt.data = data\n  utils.extend(evt, data)\n  // need bubble.\n  evt.initEvent(type, true, true)\n\n  element.dispatchEvent(evt)\n}\n\nfunction createHighlightIcon(code) {\n  var html = '<i class=\"hl-icon iconfont\">' + '&#xe650' + '</i>'\n  return html\n}\n\nfunction isValidColor(color) {\n  if (!color) {\n    return false\n  }\n\n  if (color.charAt(0) !== '#') {\n    return false\n  }\n\n  if (color.length !== 7) {\n    return false\n  }\n\n  return true\n}\n\nmodule.exports = TabHeader\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/components/tabheader.js\n ** module id = 47\n ** module chunks = 0\n **/","'use strict'\n\nvar config = require('./config')\nvar messageQueue = []\n\nfunction flushMessage() {\n  if (typeof callJS === 'function' && messageQueue.length > 0) {\n    callJS(config.instanceId, JSON.stringify(messageQueue))\n    messageQueue.length = 0\n  }\n}\n\nfunction push(msg) {\n  messageQueue.push(msg)\n}\n\n/**\n * To fix the problem of callapp, the two-way time loop mechanism must\n * be replaced by directly procedure call except the situation of\n * page loading.\n * 2015-11-03\n */\nfunction pushDirectly(msg) {\n  callJS(config.instanceId, [msg])\n}\n\nmodule.exports = {\n  push: pushDirectly\n}\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/messageQueue.js\n ** module id = 48\n ** module chunks = 0\n **/","// style-loader: Adds some css to the DOM by adding a <style> tag\n\n// load the styles\nvar content = require(\"!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./tabheader.scss\");\nif(typeof content === 'string') content = [[module.id, content, '']];\n// add the styles to the DOM\nvar update = require(\"!./../../node_modules/style-loader/addStyles.js\")(content, {});\nif(content.locals) module.exports = content.locals;\n// Hot Module Replacement\nif(module.hot) {\n\t// When the styles change, update the <style> tags\n\tif(!content.locals) {\n\t\tmodule.hot.accept(\"!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./tabheader.scss\", function() {\n\t\t\tvar newContent = require(\"!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./tabheader.scss\");\n\t\t\tif(typeof newContent === 'string') newContent = [[module.id, newContent, '']];\n\t\t\tupdate(newContent);\n\t\t});\n\t}\n\t// When the module is disposed, remove the <style> tags\n\tmodule.hot.dispose(function() { update(); });\n}\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/styles/tabheader.scss\n ** module id = 49\n ** module chunks = 0\n **/","exports = module.exports = require(\"./../../node_modules/css-loader/lib/css-base.js\")();\n// imports\n\n\n// module\nexports.push([module.id, \".tab-header {\\n  position: relative;\\n  width: 10rem;\\n  font-size: 14px;\\n  color: #333; }\\n  .tab-header .header-bar {\\n    height: 1.17rem;\\n    line-height: 1.17rem;\\n    display: none;\\n    color: #999;\\n    padding-left: 0.4rem; }\\n  .tab-header .header-body {\\n    margin-right: 1.07rem;\\n    overflow-x: auto;\\n    overflow-y: hidden; }\\n    .tab-header .header-body::-webkit-scrollbar {\\n      width: 0;\\n      height: 0;\\n      overflow: hidden; }\\n  .tab-header .fold-toggle {\\n    position: absolute;\\n    top: 0.59rem;\\n    -webkit-transform: translateY(-50%);\\n    right: 0.29rem;\\n    width: 0.48rem;\\n    height: 0.48rem;\\n    line-height: 0.48rem;\\n    text-align: center;\\n    z-index: 99;\\n    font-size: 14px; }\\n  .tab-header.unfold-header {\\n    position: fixed !important;\\n    top: 0;\\n    left: 0;\\n    overflow: hidden; }\\n\\n.tabheader {\\n  list-style: none;\\n  white-space: nowrap;\\n  height: 1.17rem;\\n  line-height: 1.17rem; }\\n  .tabheader .th-item {\\n    padding-left: 0.72rem;\\n    position: relative;\\n    display: inline-block; }\\n  .tabheader .hl-icon {\\n    width: 0.4rem;\\n    height: 0.4rem;\\n    line-height: 0.4rem;\\n    text-align: center;\\n    position: absolute;\\n    top: 50%;\\n    -webkit-transform: translateY(-50%);\\n    left: 0.24rem;\\n    font-size: 14px; }\\n\\n.unfold-header .header-bar {\\n  display: block; }\\n\\n.unfold-header .fold-toggle {\\n  -webkit-transform: translateY(-50%) rotate(180deg); }\\n\\n.unfold-header .header-body {\\n  margin-right: 0;\\n  padding: 0.24rem; }\\n\\n.unfold-header .tabheader {\\n  display: block;\\n  height: auto; }\\n\\n.unfold-header .th-item {\\n  box-sizing: border-box;\\n  float: left;\\n  width: 33.3333%;\\n  height: 1.01rem;\\n  line-height: 1.01rem; }\\n\\n.unfold-header .hl-icon {\\n  margin-right: 0;\\n  position: absolute; }\\n\\n.unfold-header.tabheader-mask {\\n  display: block;\\n  width: 100%;\\n  height: 100%;\\n  background-color: rgba(0, 0, 0, 0.6); }\\n\\n.tabheader-mask {\\n  display: none;\\n  position: fixed;\\n  left: 0;\\n  top: 0; }\\n\\n@font-face {\\n  font-family: \\\"iconfont\\\";\\n  src: url(\\\"data:application/x-font-ttf;charset=utf-8;base64,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R7AEQ7CAYmAgsAArIIqKYSCwAkNgZCOwA0NhZFBYsAJDYRuwA0NgWbADJbCAYmGwAiVGYTgjIDwjOBshICBGI0ewACsjYTghWbEkARQrLbA7LLAuKy6xJAEUKy2wPCywLyshIyAgPLAEI0IjOLEkARQrsARDLrAkKy2wPSywABUgR7AAI0KyAAEBFRQTLrAqKi2wPiywABUgR7AAI0KyAAEBFRQTLrAqKi2wPyyxAAEUE7ArKi2wQCywLSotsEEssAAWRSMgLiBGiiNhOLEkARQrLbBCLLAJI0KwQSstsEMssgAAOistsEQssgABOistsEUssgEAOistsEYssgEBOistsEcssgAAOystsEgssgABOystsEkssgEAOystsEossgEBOystsEsssgAANystsEwssgABNystsE0ssgEANystsE4ssgEBNystsE8ssgAAOSstsFAssgABOSstsFEssgEAOSstsFIssgEBOSstsFMssgAAPCstsFQssgABPCstsFUssgEAPCstsFYssgEBPCstsFcssgAAOCstsFgssgABOCstsFkssgEAOCstsFossgEBOCstsFsssDArLrEkARQrLbBcLLAwK7A0Ky2wXSywMCuwNSstsF4ssAAWsDArsDYrLbBfLLAxKy6xJAEUKy2wYCywMSuwNCstsGEssDErsDUrLbBiLLAxK7A2Ky2wYyywMisusSQBFCstsGQssDIrsDQrLbBlLLAyK7A1Ky2wZiywMiuwNistsGcssDMrLrEkARQrLbBoLLAzK7A0Ky2waSywMyuwNSstsGossDMrsDYrLbBrLCuwCGWwAyRQeLABFTAtAABLuADIUlixAQGOWbkIAAgAYyCwASNEILADI3CwDkUgIEu4AA5RS7AGU1pYsDQbsChZYGYgilVYsAIlYbABRWMjYrACI0SzCgkFBCuzCgsFBCuzDg8FBCtZsgQoCUVSRLMKDQYEK7EGAUSxJAGIUViwQIhYsQYDRLEmAYhRWLgEAIhYsQYBRFlZWVm4Af+FsASNsQUARAAAAA==\\\") format(\\\"truetype\\\"); }\\n\\n.iconfont {\\n  font-family: iconfont !important;\\n  font-size: 16px;\\n  font-style: normal;\\n  -webkit-font-smoothing: antialiased;\\n  -webkit-text-stroke-width: 0.2px;\\n  -moz-osx-font-smoothing: grayscale; }\\n\\n[data-dpr=\\\"2\\\"] .tab-header {\\n  font-size: 28px; }\\n\\n[data-dpr=\\\"3\\\"] .tab-header {\\n  font-size: 42px; }\\n\\n[data-dpr=\\\"2\\\"] .tabheader .hl-icon {\\n  font-size: 28px; }\\n\\n[data-dpr=\\\"3\\\"] .tabheader .hl-icon {\\n  font-size: 42px; }\\n\\n[data-dpr=\\\"2\\\"] .tab-header .fold-toggle {\\n  font-size: 28px; }\\n\\n[data-dpr=\\\"3\\\"] .tab-header .fold-toggle {\\n  font-size: 42px; }\\n\", \"\", {\"version\":3,\"sources\":[\"/./src/src/styles/tabheader.scss\",\"/./src/styles/tabheader.scss\"],\"names\":[],\"mappings\":\"AAGA;EACE,mBAAmB;EACnB,aAAa;EACb,gBAAgB;EAChB,YAAY,EA0Cb;EA9CD;IAOI,gBAAgB;IAChB,qBAAqB;IACrB,cAAc;IACd,YAAY;IACZ,qBAAqB,EACtB;EAZH;IAeI,sBAAsB;IACtB,iBAAiB;IACjB,mBAAmB,EAOpB;IAxBH;MAoBM,SAAS;MACT,UAAU;MACV,iBAAiB,EAClB;EAvBL;IA2BI,mBAAmB;IACnB,aAAa;IACb,oCAA6B;IAC7B,eAAe;IACf,eAAe;IACf,gBAAgB;IAChB,qBAAqB;IACrB,mBAAmB;IACnB,YAAY;IACZ,gBAAgB,EACjB;EArCH;IAwCI,2BAA2B;IAC3B,OAAO;IACP,QAAQ;IACR,iBAAiB,EAClB;;AAIH;EACE,iBAAiB;EACjB,oBAAoB;EACpB,gBAAgB;EAChB,qBAAqB,EAoBtB;EAxBD;IAOI,sBAAsB;IACtB,mBAAmB;IACnB,sBAAsB,EACvB;EAVH;IAaI,cAAc;IACd,eAAe;IACf,oBAAoB;IACpB,mBAAmB;IACnB,mBAAmB;IACnB,SAAS;IACT,oCAA6B;IAC7B,cAAc;IACd,gBAAgB,EACjB;;AAIH;EAGI,eAAe,EAChB;;AAJH;EAOI,mDAA0C,EAC3C;;AARH;EAWI,gBAAgB;EAChB,iBAAiB,EAClB;;AAbH;EAgBI,eAAe;EACf,aAAa,EACd;;AAlBH;EAqBI,uBAAuB;EACvB,YAAY;EACZ,gBAAgB;EAChB,gBAAgB;EAChB,qBAAqB,EACtB;;AA1BH;EA6BI,gBAAgB;EAChB,mBAAmB,EACpB;;AA/BH;EAkCI,eAAe;EACf,YAAY;EACZ,aAAa;EACb,qCAAsB,EACvB;;AAGH;EACE,cAAc;EACd,gBAAgB;EAChB,QAAQ;EACR,OAAO,EACR;;AAED;EACE,wBAAwB;EACxB,y9NAA48N,EAAA;;AAG98N;EACE,iCAAiC;EACjC,gBAAgB;EAChB,mBAAmB;EACnB,oCAAoC;EACpC,iCAAiC;EACjC,mCAAmC,EACpC;;AChCD;EDmCE,gBAAgB,EACjB;;ACjCD;EDoCE,gBAAgB,EACjB;;AClCD;EDqCE,gBAAgB,EACjB;;ACnCD;EDsCE,gBAAgB,EACjB;;ACpCD;EDuCE,gBAAgB,EACjB;;ACrCD;EDwCE,gBAAgB,EACjB\",\"file\":\"tabheader.scss\",\"sourcesContent\":[\"// Heads up! Rem is not a good way for\\n// weex HTML5 renderer.\\n\\n.tab-header {\\n  position: relative;\\n  width: 10rem;\\n  font-size: 14px;\\n  color: #333;\\n\\n  .header-bar {\\n    height: 1.17rem;\\n    line-height: 1.17rem;\\n    display: none;\\n    color: #999;\\n    padding-left: 0.4rem;\\n  }\\n  \\n  .header-body {\\n    margin-right: 1.07rem;\\n    overflow-x: auto;\\n    overflow-y: hidden;\\n\\n    &::-webkit-scrollbar {\\n      width: 0;\\n      height: 0;\\n      overflow: hidden;\\n    }\\n  }\\n\\n  .fold-toggle {\\n    position: absolute;\\n    top: 0.59rem;\\n    -webkit-transform: translateY(-50%);\\n    right: 0.29rem;\\n    width: 0.48rem;\\n    height: 0.48rem;\\n    line-height: 0.48rem;\\n    text-align: center;\\n    z-index: 99;\\n    font-size: 14px;\\n  }\\n\\n  &.unfold-header {\\n    position: fixed !important;\\n    top: 0;\\n    left: 0;\\n    overflow: hidden;\\n  }\\n\\n}\\n\\n.tabheader {\\n  list-style: none;\\n  white-space: nowrap;\\n  height: 1.17rem;\\n  line-height: 1.17rem;\\n\\n  .th-item {\\n    padding-left: 0.72rem;\\n    position: relative;\\n    display: inline-block;\\n  }\\n\\n  .hl-icon {\\n    width: 0.4rem;\\n    height: 0.4rem;\\n    line-height: 0.4rem;\\n    text-align: center;\\n    position: absolute;\\n    top: 50%;\\n    -webkit-transform: translateY(-50%);\\n    left: 0.24rem;\\n    font-size: 14px;\\n  }\\n\\n}\\n\\n.unfold-header {\\n\\n  .header-bar {\\n    display: block;\\n  }\\n\\n  .fold-toggle {\\n    -webkit-transform: translateY(-50%) rotate(180deg);\\n  }\\n\\n  .header-body {\\n    margin-right: 0;\\n    padding: 0.24rem;\\n  }\\n\\n  .tabheader {\\n    display: block;\\n    height: auto;\\n  }\\n\\n  .th-item {\\n    box-sizing: border-box;\\n    float: left;\\n    width: 33.3333%;\\n    height: 1.01rem;\\n    line-height: 1.01rem;\\n  }\\n\\n  .hl-icon {\\n    margin-right: 0;\\n    position: absolute;\\n  }\\n\\n  &.tabheader-mask {\\n    display: block;\\n    width: 100%;\\n    height: 100%;\\n    background-color: rgba(0, 0, 0, 0.6);\\n  }\\n}\\n\\n.tabheader-mask {\\n  display: none;\\n  position: fixed;\\n  left: 0;\\n  top: 0;\\n}\\n\\n@font-face {\\n  font-family: \\\"iconfont\\\";\\n  src: url(\\\"data:application/x-font-ttf;charset=utf-8;base64,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R7AEQ7CAYmAgsAArIIqKYSCwAkNgZCOwA0NhZFBYsAJDYRuwA0NgWbADJbCAYmGwAiVGYTgjIDwjOBshICBGI0ewACsjYTghWbEkARQrLbA7LLAuKy6xJAEUKy2wPCywLyshIyAgPLAEI0IjOLEkARQrsARDLrAkKy2wPSywABUgR7AAI0KyAAEBFRQTLrAqKi2wPiywABUgR7AAI0KyAAEBFRQTLrAqKi2wPyyxAAEUE7ArKi2wQCywLSotsEEssAAWRSMgLiBGiiNhOLEkARQrLbBCLLAJI0KwQSstsEMssgAAOistsEQssgABOistsEUssgEAOistsEYssgEBOistsEcssgAAOystsEgssgABOystsEkssgEAOystsEossgEBOystsEsssgAANystsEwssgABNystsE0ssgEANystsE4ssgEBNystsE8ssgAAOSstsFAssgABOSstsFEssgEAOSstsFIssgEBOSstsFMssgAAPCstsFQssgABPCstsFUssgEAPCstsFYssgEBPCstsFcssgAAOCstsFgssgABOCstsFkssgEAOCstsFossgEBOCstsFsssDArLrEkARQrLbBcLLAwK7A0Ky2wXSywMCuwNSstsF4ssAAWsDArsDYrLbBfLLAxKy6xJAEUKy2wYCywMSuwNCstsGEssDErsDUrLbBiLLAxK7A2Ky2wYyywMisusSQBFCstsGQssDIrsDQrLbBlLLAyK7A1Ky2wZiywMiuwNistsGcssDMrLrEkARQrLbBoLLAzK7A0Ky2waSywMyuwNSstsGossDMrsDYrLbBrLCuwCGWwAyRQeLABFTAtAABLuADIUlixAQGOWbkIAAgAYyCwASNEILADI3CwDkUgIEu4AA5RS7AGU1pYsDQbsChZYGYgilVYsAIlYbABRWMjYrACI0SzCgkFBCuzCgsFBCuzDg8FBCtZsgQoCUVSRLMKDQYEK7EGAUSxJAGIUViwQIhYsQYDRLEmAYhRWLgEAIhYsQYBRFlZWVm4Af+FsASNsQUARAAAAA==\\\") format(\\\"truetype\\\");\\n}\\n\\n.iconfont {\\n  font-family: iconfont !important;\\n  font-size: 16px;\\n  font-style: normal;\\n  -webkit-font-smoothing: antialiased;\\n  -webkit-text-stroke-width: 0.2px;\\n  -moz-osx-font-smoothing: grayscale;\\n}\\n\\n[data-dpr=\\\"2\\\"] .tab-header {\\n  font-size: 28px;\\n}\\n\\n[data-dpr=\\\"3\\\"] .tab-header {\\n  font-size: 42px;\\n}\\n\\n[data-dpr=\\\"2\\\"] .tabheader .hl-icon {\\n  font-size: 28px;\\n}\\n\\n[data-dpr=\\\"3\\\"] .tabheader .hl-icon {\\n  font-size: 42px;\\n}\\n\\n[data-dpr=\\\"2\\\"] .tab-header .fold-toggle {\\n  font-size: 28px;\\n}\\n\\n[data-dpr=\\\"3\\\"] .tab-header .fold-toggle {\\n  font-size: 42px;\\n}\",\".tab-header {\\n  position: relative;\\n  width: 10rem;\\n  font-size: 14px;\\n  color: #333; }\\n  .tab-header .header-bar {\\n    height: 1.17rem;\\n    line-height: 1.17rem;\\n    display: none;\\n    color: #999;\\n    padding-left: 0.4rem; }\\n  .tab-header .header-body {\\n    margin-right: 1.07rem;\\n    overflow-x: auto;\\n    overflow-y: hidden; }\\n    .tab-header .header-body::-webkit-scrollbar {\\n      width: 0;\\n      height: 0;\\n      overflow: hidden; }\\n  .tab-header .fold-toggle {\\n    position: absolute;\\n    top: 0.59rem;\\n    -webkit-transform: translateY(-50%);\\n    right: 0.29rem;\\n    width: 0.48rem;\\n    height: 0.48rem;\\n    line-height: 0.48rem;\\n    text-align: center;\\n    z-index: 99;\\n    font-size: 14px; }\\n  .tab-header.unfold-header {\\n    position: fixed !important;\\n    top: 0;\\n    left: 0;\\n    overflow: hidden; }\\n\\n.tabheader {\\n  list-style: none;\\n  white-space: nowrap;\\n  height: 1.17rem;\\n  line-height: 1.17rem; }\\n  .tabheader .th-item {\\n    padding-left: 0.72rem;\\n    position: relative;\\n    display: inline-block; }\\n  .tabheader .hl-icon {\\n    width: 0.4rem;\\n    height: 0.4rem;\\n    line-height: 0.4rem;\\n    text-align: center;\\n    position: absolute;\\n    top: 50%;\\n    -webkit-transform: translateY(-50%);\\n    left: 0.24rem;\\n    font-size: 14px; }\\n\\n.unfold-header .header-bar {\\n  display: block; }\\n\\n.unfold-header .fold-toggle {\\n  -webkit-transform: translateY(-50%) rotate(180deg); }\\n\\n.unfold-header .header-body {\\n  margin-right: 0;\\n  padding: 0.24rem; }\\n\\n.unfold-header .tabheader {\\n  display: block;\\n  height: auto; }\\n\\n.unfold-header .th-item {\\n  box-sizing: border-box;\\n  float: left;\\n  width: 33.3333%;\\n  height: 1.01rem;\\n  line-height: 1.01rem; }\\n\\n.unfold-header .hl-icon {\\n  margin-right: 0;\\n  position: absolute; }\\n\\n.unfold-header.tabheader-mask {\\n  display: block;\\n  width: 100%;\\n  height: 100%;\\n  background-color: rgba(0, 0, 0, 0.6); }\\n\\n.tabheader-mask {\\n  display: none;\\n  position: fixed;\\n  left: 0;\\n  top: 0; }\\n\\n@font-face {\\n  font-family: \\\"iconfont\\\";\\n  src: url(\\\"data:application/x-font-ttf;charset=utf-8;base64,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R7AEQ7CAYmAgsAArIIqKYSCwAkNgZCOwA0NhZFBYsAJDYRuwA0NgWbADJbCAYmGwAiVGYTgjIDwjOBshICBGI0ewACsjYTghWbEkARQrLbA7LLAuKy6xJAEUKy2wPCywLyshIyAgPLAEI0IjOLEkARQrsARDLrAkKy2wPSywABUgR7AAI0KyAAEBFRQTLrAqKi2wPiywABUgR7AAI0KyAAEBFRQTLrAqKi2wPyyxAAEUE7ArKi2wQCywLSotsEEssAAWRSMgLiBGiiNhOLEkARQrLbBCLLAJI0KwQSstsEMssgAAOistsEQssgABOistsEUssgEAOistsEYssgEBOistsEcssgAAOystsEgssgABOystsEkssgEAOystsEossgEBOystsEsssgAANystsEwssgABNystsE0ssgEANystsE4ssgEBNystsE8ssgAAOSstsFAssgABOSstsFEssgEAOSstsFIssgEBOSstsFMssgAAPCstsFQssgABPCstsFUssgEAPCstsFYssgEBPCstsFcssgAAOCstsFgssgABOCstsFkssgEAOCstsFossgEBOCstsFsssDArLrEkARQrLbBcLLAwK7A0Ky2wXSywMCuwNSstsF4ssAAWsDArsDYrLbBfLLAxKy6xJAEUKy2wYCywMSuwNCstsGEssDErsDUrLbBiLLAxK7A2Ky2wYyywMisusSQBFCstsGQssDIrsDQrLbBlLLAyK7A1Ky2wZiywMiuwNistsGcssDMrLrEkARQrLbBoLLAzK7A0Ky2waSywMyuwNSstsGossDMrsDYrLbBrLCuwCGWwAyRQeLABFTAtAABLuADIUlixAQGOWbkIAAgAYyCwASNEILADI3CwDkUgIEu4AA5RS7AGU1pYsDQbsChZYGYgilVYsAIlYbABRWMjYrACI0SzCgkFBCuzCgsFBCuzDg8FBCtZsgQoCUVSRLMKDQYEK7EGAUSxJAGIUViwQIhYsQYDRLEmAYhRWLgEAIhYsQYBRFlZWVm4Af+FsASNsQUARAAAAA==\\\") format(\\\"truetype\\\"); }\\n\\n.iconfont {\\n  font-family: iconfont !important;\\n  font-size: 16px;\\n  font-style: normal;\\n  -webkit-font-smoothing: antialiased;\\n  -webkit-text-stroke-width: 0.2px;\\n  -moz-osx-font-smoothing: grayscale; }\\n\\n[data-dpr=\\\"2\\\"] .tab-header {\\n  font-size: 28px; }\\n\\n[data-dpr=\\\"3\\\"] .tab-header {\\n  font-size: 42px; }\\n\\n[data-dpr=\\\"2\\\"] .tabheader .hl-icon {\\n  font-size: 28px; }\\n\\n[data-dpr=\\\"3\\\"] .tabheader .hl-icon {\\n  font-size: 42px; }\\n\\n[data-dpr=\\\"2\\\"] .tab-header .fold-toggle {\\n  font-size: 28px; }\\n\\n[data-dpr=\\\"3\\\"] .tab-header .fold-toggle {\\n  font-size: 42px; }\\n\"],\"sourceRoot\":\"webpack://\"}]);\n\n// exports\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/css-loader?sourceMap!./~/sass-loader?sourceMap!./src/styles/tabheader.scss\n ** module id = 50\n ** module chunks = 0\n **/","'use strict'\n\nrequire('../styles/scroller.scss')\nrequire('scrolljs')\n\n// lib.scroll events:\n//  - scrollstart\n//  - scrolling\n//  - pulldownend\n//  - pullupend\n//  - pullleftend\n//  - pullrightend\n//  - pulldown\n//  - pullup\n//  - pullleft\n//  - pullright\n//  - contentrefresh\n\nvar Component = require('./component')\nvar utils = require('../utils')\n\n// attrs:\n//  - scroll-direciton: none|vertical|horizontal (default is vertical)\n//  - show-scrollbar: true|false (default is true)\nfunction Scroller (data, nodeType) {\n  var attrs = data.attr || {}\n  this.items = []\n  this.totalWidth = 0\n  this.scrollDirection = attrs.scrollDirection === 'horizontal'\n                          ? 'horizontal'\n                          : 'vertical'\n  this.showScrollbar = attrs.showScrollbar || true\n  Component.call(this, data, nodeType)\n}\n\nScroller.prototype = Object.create(Component.prototype)\n\nScroller.prototype.create = function (nodeType) {\n  var Scroll = lib.scroll\n  var node = Component.prototype.create.call(this, nodeType)\n  node.classList.add('weex-container', 'scroll-wrap')\n  this.scrollElement = document.createElement('div')\n  this.scrollElement.classList.add(\n    'weex-container',\n    'scroll-element',\n    this.scrollDirection\n  )\n  node.appendChild(this.scrollElement)\n  this.scroller = new Scroll({\n    scrollElement: this.scrollElement,\n    direction: this.scrollDirection === 'vertical' ? 'y' : 'x'\n  })\n  this.scroller.init()\n  return node\n}\n\nScroller.prototype.bindEvents = function (evts) {\n  Component.prototype.bindEvents.call(this, evts)\n  // to enable lazyload for Images\n  this.scroller.addEventListener('scrolling', function (e) {\n    var so = e.scrollObj\n    this.dispatchEvent('scroll', {\n      originalType: 'scrolling',\n      scrollTop: so.getScrollTop(),\n      scrollLeft: so.getScrollLeft()\n    }, {\n      bubbles: true\n    })\n  }.bind(this))\n}\n\nScroller.prototype.appendChild = function (data) {\n  var children = this.data.children\n  var componentManager = this.getComponentManager()\n  var child = componentManager.createElement(data)\n  this.scrollElement.appendChild(child.node)\n\n  var childWidth = child.node.getBoundingClientRect().width\n  this.totalWidth += childWidth\n  // if direction is horizontal then the width of scrollElement\n  // should be set manually due to flexbox's rule (child elements\n  // will not exceed box's width but to shrink to adapt).\n  if (this.scrollDirection === 'horizontal') {\n    this.scrollElement.style.width = this.totalWidth + 'px'\n  }\n\n  // update this.data.children\n  if (!children || !children.length) {\n    this.data.children = [data]\n  } else {\n    children.push(data)\n  }\n\n  this.items.push(child)\n  return child\n}\n\nScroller.prototype.insertBefore = function (child, before) {\n  var children = this.data.children\n  var i = 0\n  var isAppend = false\n\n  // update this.data.children\n  if (!children || !children.length || !before) {\n    isAppend = true\n  } else {\n    for (var l = children.length; i < l; i++) {\n      if (children[i].ref === child.data.ref) {\n        break\n      }\n    }\n    if (i === l) {\n      isAppend = true\n    }\n  }\n\n  if (isAppend) {\n    this.scrollElement.appendChild(child.node)\n    children.push(child.data)\n    this.items.push(child)\n  } else {\n    this.scrollElement.insertBefore(child.node, before.node)\n    children.splice(i, 0, child.data)\n    this.items.splice(i, 0, child)\n  }\n}\n\nScroller.prototype.removeChild = function () {\n  var children = this.data.children\n  // remove from this.data.children\n  var i = 0\n  var componentManager = this.getComponentManager()\n  if (children && children.length) {\n    for (var l = children.length; i < l; i++) {\n      if (children[i].ref === child.data.ref) {\n        break\n      }\n    }\n    if (i < l) {\n      children.splice(i, 1)\n      this.items.splice(i, 1)\n    }\n  }\n  // remove from componentMap recursively\n  componentManager.removeElementByRef(child.data.ref)\n  this.scrollElement.removeChild(child.node)\n}\n\nmodule.exports = Scroller\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/components/scroller.js\n ** module id = 51\n ** module chunks = 0\n **/","// style-loader: Adds some css to the DOM by adding a <style> tag\n\n// load the styles\nvar content = require(\"!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./scroller.scss\");\nif(typeof content === 'string') content = [[module.id, content, '']];\n// add the styles to the DOM\nvar update = require(\"!./../../node_modules/style-loader/addStyles.js\")(content, {});\nif(content.locals) module.exports = content.locals;\n// Hot Module Replacement\nif(module.hot) {\n\t// When the styles change, update the <style> tags\n\tif(!content.locals) {\n\t\tmodule.hot.accept(\"!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./scroller.scss\", function() {\n\t\t\tvar newContent = require(\"!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./scroller.scss\");\n\t\t\tif(typeof newContent === 'string') newContent = [[module.id, newContent, '']];\n\t\t\tupdate(newContent);\n\t\t});\n\t}\n\t// When the module is disposed, remove the <style> tags\n\tmodule.hot.dispose(function() { update(); });\n}\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/styles/scroller.scss\n ** module id = 52\n ** module chunks = 0\n **/","exports = module.exports = require(\"./../../node_modules/css-loader/lib/css-base.js\")();\n// imports\n\n\n// module\nexports.push([module.id, \".scroll-wrap {\\n  display: block;\\n  overflow: hidden; }\\n\\n.scroll-element.horizontal {\\n  -webkit-box-orient: horizontal;\\n  -webkit-flex-direction: row;\\n  flex-direction: row; }\\n\\n.scroll-element.vertical {\\n  -webkit-box-orient: vertical;\\n  -webkit-flex-direction: column;\\n  flex-direction: column; }\\n\", \"\", {\"version\":3,\"sources\":[\"/./src/src/styles/scroller.scss\"],\"names\":[],\"mappings\":\"AAAA;EACC,eAAe;EACf,iBAAiB,EACjB;;AAED;EAEI,+BAA+B;EAC/B,4BAA4B;EAC5B,oBAAoB,EACrB;;AALH;EAOI,6BAA6B;EAC7B,+BAA+B;EAC/B,uBAAuB,EACxB\",\"file\":\"scroller.scss\",\"sourcesContent\":[\".scroll-wrap {\\n\\tdisplay: block;\\n\\toverflow: hidden;\\n}\\n\\n.scroll-element {\\n  &.horizontal {\\n    -webkit-box-orient: horizontal;\\n    -webkit-flex-direction: row;\\n    flex-direction: row;\\n  }\\n  &.vertical {\\n    -webkit-box-orient: vertical;\\n    -webkit-flex-direction: column;\\n    flex-direction: column;\\n  }\\n}\"],\"sourceRoot\":\"webpack://\"}]);\n\n// exports\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/css-loader?sourceMap!./~/sass-loader?sourceMap!./src/styles/scroller.scss\n ** module id = 53\n ** module chunks = 0\n **/","'use strict'\n\nvar Atomic = require('./atomic')\nvar utils = require('../utils')\n\n// attrs:\n//   - type: text|password|tel|email|url\n//   - value\n//   - placeholder\n//   - disabled\n//   - autofocus\nfunction Input (data) {\n  var attrs = data.attr || {}\n  this.type = attrs.type || 'text'\n  this.value = attrs.value\n  this.placeholder = attrs.placeholder\n  this.autofocus = attrs.autofocus && (attrs.autofocus !== 'false')\n                    ? true\n                    : false\n  Atomic.call(this, data)\n}\n\nInput.prototype = Object.create(Atomic.prototype)\n\nInput.prototype.create = function () {\n  var node = document.createElement('input')\n  var uuid = Math.floor(10000000000000 * Math.random()) + Date.now()\n  this.className = 'weex-ipt-' + uuid\n  this.styleId = 'weex-style-' + uuid\n  node.classList.add(this.className)\n  node.setAttribute('type', this.type)\n  node.type = this.type\n  // For the consistency of input component's width.\n  // The date and time type of input will have a bigger width\n  // when the 'box-sizing' is not set to 'border-box'\n  node.classList.add('weex-element')\n  this.value && (node.value = this.value)\n  this.placeholder && (node.placeholder = this.placeholder)\n  return node\n}\n\nInput.prototype.updateStyle = function (style) {\n  Atomic.prototype.updateStyle.call(this, style)\n  if (style && style.placeholderColor) {\n    this.placeholderColor = style.placeholderColor\n    this.setPlaceholderColor()\n  }\n}\n\nInput.prototype.attr = {\n  disabled: function (val) {\n    this.node.disabled = val && val !== 'false'\n                    ? true\n                    : false\n  }\n}\n\nInput.prototype.setPlaceholderColor = function () {\n  if (!this.placeholderColor) {\n    return\n  }\n  var vendors = [\n    '::-webkit-input-placeholder',\n    ':-moz-placeholder',\n    '::-moz-placeholder',\n    ':-ms-input-placeholder',\n    ':placeholder-shown'\n  ]\n  var css = ''\n  var cssRule = 'color: ' + this.placeholderColor + ';'\n  for (var i = 0, l = vendors.length; i < l; i++) {\n    css += '.' + this.className + vendors[i] + '{'\n           + cssRule + '}'\n  }\n  utils.appendStyle(css, this.styleId, true)\n}\n\nmodule.exports = Input\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/components/input.js\n ** module id = 54\n ** module chunks = 0\n **/","'use strict'\n\nvar Atomic = require('./component')\nvar sender = require('../bridge/sender')\n\n// attrs:\n//   - options: the options to be listed, as a array of strings.\n//   - selectedIndex: the selected options' index number.\n//   - disabled\nfunction Select (data) {\n  var attrs = data.attr || {}\n  this.options = []\n  this.selectedIndex = 0\n  Atomic.call(this, data)\n}\n\nSelect.prototype = Object.create(Atomic.prototype)\n\nSelect.prototype.create = function () {\n  var node = document.createElement('select')\n  var uuid = Math.floor(10000000000000 * Math.random()) + Date.now()\n  this.className = 'weex-slct-' + uuid\n  this.styleId = 'weex-style-' + uuid\n  node.classList.add(this.className)\n  // For the consistency of input component's width.\n  // The date and time type of input will have a bigger width\n  // when the 'box-sizing' is not set to 'border-box'\n  node.style['box-sizing'] = 'border-box'\n  return node\n}\n\nSelect.prototype.attr = {\n  disabled: function (val) {\n    this.node.disabled = val && val !== 'false'\n                    ? true\n                    : false\n  },\n  options: function (val) {\n    if (Object.prototype.toString.call(val) !== '[object Array]') {\n      return\n    }\n    this.options = val\n    this.node.innerHTML = ''\n    this.createOptions(val)\n  },\n  selectedIndex: function (val) {\n    val = parseInt(val)\n    if (typeof val !== 'number' || val !== val || val >= this.options.length) {\n      return\n    }\n    this.node.value = this.options[val]\n  }\n}\n\nSelect.prototype.bindEvents = function (evts) {\n  var isListenToChange = false\n  Atomic.prototype.bindEvents.call(\n      this,\n      evts.filter(function (val) {\n        var pass = val !== 'change'\n        !pass && (isListenToChange = true)\n        return pass\n      }))\n  if (isListenToChange) {\n    this.node.addEventListener('change', function (e) {\n      e.index = this.options.indexOf(this.node.value)\n      sender.fireEvent(this.data.ref, 'change', e)\n    }.bind(this))\n  }\n}\n\nSelect.prototype.createOptions = function (opts) {\n  var optDoc = document.createDocumentFragment()\n  var opt\n  for (var i = 0, l = opts.length; i < l; i++) {\n    opt = document.createElement('option')\n    opt.appendChild(document.createTextNode(opts[i]))\n    optDoc.appendChild(opt)\n  }\n  this.node.appendChild(optDoc)\n}\n\nmodule.exports = Select\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/components/select.js\n ** module id = 55\n ** module chunks = 0\n **/","'use strict'\n\nvar Atomic = require('./atomic')\n\n// attrs:\n//   - value\n//   - disabled\nfunction Datepicker (data) {\n  Atomic.call(this, data)\n}\n\nDatepicker.prototype = Object.create(Atomic.prototype)\n\nDatepicker.prototype.create = function () {\n  var node = document.createElement('input')\n  var uuid = Math.floor(10000000000000 * Math.random()) + Date.now()\n  this.className = 'weex-ipt-' + uuid\n  this.styleId = 'weex-style-' + uuid\n  node.classList.add(this.className)\n  node.setAttribute('type', 'date')\n  node.type = 'date'\n  // For the consistency of input component's width.\n  // The date and time type of input will have a bigger width\n  // when the 'box-sizing' is not set to 'border-box'\n  node.classList.add('weex-element')\n  return node\n}\n\nDatepicker.prototype.attr = {\n  disabled: function (val) {\n    this.node.disabled = val && val !== 'false'\n                    ? true\n                    : false\n  }\n}\n\nmodule.exports = Datepicker\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/components/datepicker.js\n ** module id = 56\n ** module chunks = 0\n **/","'use strict'\n\nvar Atomic = require('./atomic')\n\n// attrs:\n//   - value\n//   - disabled\nfunction Timepicker (data) {\n  Atomic.call(this, data)\n}\n\nTimepicker.prototype = Object.create(Atomic.prototype)\n\nTimepicker.prototype.create = function () {\n  var node = document.createElement('input')\n  var uuid = Math.floor(10000000000000 * Math.random()) + Date.now()\n  this.className = 'weex-ipt-' + uuid\n  this.styleId = 'weex-style-' + uuid\n  node.classList.add(this.className)\n  node.setAttribute('type', 'time')\n  node.type = 'time'\n  // For the consistency of input component's width.\n  // The date and time type of input will have a bigger width\n  // when the 'box-sizing' is not set to 'border-box'\n  node.classList.add('weex-element')\n  return node\n}\n\nTimepicker.prototype.attr = {\n  disabled: function (val) {\n    this.node.disabled = val && val !== 'false'\n                    ? true\n                    : false\n  }\n}\n\nmodule.exports = Timepicker\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/components/timepicker.js\n ** module id = 57\n ** module chunks = 0\n **/","'use strict'\n\nvar Atomic = require('./atomic')\nvar utils = require('../utils')\nrequire('../styles/video.scss')\n\n// attrs:\n//   - autoPlay: true | false (default: false)\n//   - playStatus: play | pause | stop\n//   - src: {string}\n//   - poster: {string}\n//   - loop: true | false (default: false)\n//   - muted: true | false (default: false)\n// events:\n//   - start\n//   - pause\n//   - finish\n//   - fail\nfunction Video (data) {\n  var autoPlay = data.attr.autoPlay\n  var playStatus = data.attr.playStatus\n  this.autoPlay = autoPlay === true || autoPlay === 'true'\n  if (playStatus !== 'play'\n      && playStatus !== 'stop'\n      && playStatus !== 'pause') {\n    this.playStatus = 'pause'\n  } else {\n    this.playStatus = playStatus\n  }\n  Atomic.call(this, data)\n}\n\nVideo.prototype = Object.create(Atomic.prototype)\n\nVideo.prototype.attr = {\n  playStatus: function (val) {\n    if (val !== 'play' && val !== 'stop' && val !== 'pause') {\n      val = 'pause'\n    }\n    if (this.playStatus === val) {\n      return\n    }\n    this.playStatus = val\n    this.node.setAttribute('play-status', val)\n    this[this.playStatus]()\n  },\n  autoPlay: function (val) {\n    // DO NOTHING\n  }\n}\n\nVideo.prototype.create = function () {\n  var node = document.createElement('video')\n  node.classList.add('weex-video', 'weex-element')\n  node.controls = true\n  node.autoplay = this.autoPlay\n  node.setAttribute('play-status', this.playStatus)\n  this.node = node\n  if (this.autoPlay && this.playStatus === 'play') {\n    this.play()\n  }\n  return node\n}\n\nVideo.prototype.bindEvents = function (evts) {\n  Atomic.prototype.bindEvents.call(this, evts)\n\n  // convert w3c-video events to weex-video events.\n  var evtsMap = {\n    start: 'play',\n    finish: 'ended',\n    fail: 'error'\n  }\n  for (var evtName in evtsMap) {\n    this.node.addEventListener(evtsMap[evtName], function (type, e) {\n      this.dispatchEvent(type, e.data)\n    }.bind(this, evtName))\n  }\n}\n\nVideo.prototype.play = function () {\n  var src = this.node.getAttribute('src')\n  if (!src) {\n    src = this.node.getAttribute('data-src')\n    src && this.node.setAttribute('src', src)\n  }\n  this.node.play()\n}\n\nVideo.prototype.pause = function () {\n  this.node.pause()\n}\n\nVideo.prototype.stop = function () {\n  this.node.pause()\n  this.node.autoplay = false\n  this.node.setAttribute('data-src', this.node.src)\n  this.node.src = ''\n}\n\nmodule.exports = Video\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/components/video.js\n ** module id = 58\n ** module chunks = 0\n **/","// style-loader: Adds some css to the DOM by adding a <style> tag\n\n// load the styles\nvar content = require(\"!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./video.scss\");\nif(typeof content === 'string') content = [[module.id, content, '']];\n// add the styles to the DOM\nvar update = require(\"!./../../node_modules/style-loader/addStyles.js\")(content, {});\nif(content.locals) module.exports = content.locals;\n// Hot Module Replacement\nif(module.hot) {\n\t// When the styles change, update the <style> tags\n\tif(!content.locals) {\n\t\tmodule.hot.accept(\"!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./video.scss\", function() {\n\t\t\tvar newContent = require(\"!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./video.scss\");\n\t\t\tif(typeof newContent === 'string') newContent = [[module.id, newContent, '']];\n\t\t\tupdate(newContent);\n\t\t});\n\t}\n\t// When the module is disposed, remove the <style> tags\n\tmodule.hot.dispose(function() { update(); });\n}\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/styles/video.scss\n ** module id = 59\n ** module chunks = 0\n **/","exports = module.exports = require(\"./../../node_modules/css-loader/lib/css-base.js\")();\n// imports\n\n\n// module\nexports.push([module.id, \".weex-video {\\n  background-color: #000; }\\n\", \"\", {\"version\":3,\"sources\":[\"/./src/src/styles/video.scss\"],\"names\":[],\"mappings\":\"AAAA;EACC,uBAAuB,EACvB\",\"file\":\"video.scss\",\"sourcesContent\":[\".weex-video {\\n\\tbackground-color: #000;\\n}\"],\"sourceRoot\":\"webpack://\"}]);\n\n// exports\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/css-loader?sourceMap!./~/sass-loader?sourceMap!./src/styles/video.scss\n ** module id = 60\n ** module chunks = 0\n **/","'use strict'\n\nvar Atomic = require('./atomic')\nvar utils = require('../utils')\nrequire('../styles/switch.scss')\n\nvar defaults = {\n  color: '#64bd63'\n  , secondaryColor: '#dfdfdf'\n  , jackColor: '#fff'\n  , jackSecondaryColor: null\n  , className: 'weex-switch'\n  , disabledOpacity: 0.5\n  , speed: '0.4s'\n  , width: 100\n  , height: 60\n  // is width and height scalable ?\n  , scalable: false\n}\n\n// attrs:\n//   - checked: if is checked.\n//   - disabled: if true, this component is not available for interaction.\nfunction Switch (data) {\n  this.options = utils.extend({}, defaults)\n  this.checked = data.attr.checked\n      && data.attr.checked !== 'false' ? true : false\n  this.data = data\n  this.width = this.options.width * data.scale\n  this.height = this.options.height * data.scale\n  Atomic.call(this, data)\n}\n\nSwitch.prototype = Object.create(Atomic.prototype)\n\nSwitch.prototype.create = function () {\n  var node = document.createElement('span')\n  this.jack = document.createElement('small')\n  node.appendChild(this.jack)\n  node.className = this.options.className\n  this.node = node\n  this.attr.disabled.call(this, this.data.attr.disabled)\n  return node\n}\n\nSwitch.prototype.onAppend = function () {\n  this.setSize()\n  this.setPosition()\n}\n\nSwitch.prototype.attr = {\n  disabled: function (val) {\n    this.disabled = val && val !== 'false'\n                    ? true\n                    : false\n    this.disabled ? this.disable() : this.enable()\n  }\n}\n\nSwitch.prototype.setSize = function () {\n  var min = Math.min(this.width, this.height)\n  var max = Math.max(this.width, this.height)\n  this.node.style.width = max + 'px'\n  this.node.style.height = min + 'px'\n  this.node.style.borderRadius = min / 2 + 'px'\n  this.jack.style.width\n      = this.jack.style.height\n      = min + 'px'\n}\n\nSwitch.prototype.setPosition = function (clicked) {\n  var checked = this.checked\n  var node = this.node\n  var jack = this.jack\n\n  if (clicked && checked) {\n    checked = false\n  } else if (clicked && !checked) {\n    checked = true\n  }\n\n  if (checked === true) {\n    this.checked = true\n\n    if (window.getComputedStyle) {\n      jack.style.left = parseInt(window.getComputedStyle(node).width)\n                        - parseInt(window.getComputedStyle(jack).width) + 'px'\n    } else {\n      jack.style.left = parseInt(node.currentStyle['width'])\n                        - parseInt(jack.currentStyle['width']) + 'px'\n    }\n\n    this.options.color && this.colorize()\n    this.setSpeed()\n  } else {\n    this.checked = false\n    jack.style.left = 0\n    node.style.boxShadow = 'inset 0 0 0 0 ' + this.options.secondaryColor\n    node.style.borderColor = this.options.secondaryColor\n    node.style.backgroundColor\n        = (this.options.secondaryColor !== defaults.secondaryColor)\n          ? this.options.secondaryColor\n          : '#fff'\n    jack.style.backgroundColor\n        = (this.options.jackSecondaryColor !== this.options.jackColor)\n          ? this.options.jackSecondaryColor\n          : this.options.jackColor\n    this.setSpeed()\n  }\n}\n\nSwitch.prototype.colorize = function () {\n  var nodeHeight = this.node.offsetHeight / 2\n\n  this.node.style.backgroundColor = this.options.color\n  this.node.style.borderColor = this.options.color\n  this.node.style.boxShadow = 'inset 0 0 0 '\n                              + nodeHeight\n                              + 'px '\n                              + this.options.color\n  this.jack.style.backgroundColor = this.options.jackColor\n}\n\nSwitch.prototype.setSpeed = function () {\n  var switcherProp = {}\n  var jackProp = {\n      'background-color': this.options.speed\n      , left: this.options.speed.replace(/[a-z]/, '') / 2 + 's'\n    }\n\n  if (this.checked) {\n    switcherProp = {\n      border: this.options.speed\n      , 'box-shadow': this.options.speed\n      , 'background-color': this.options.speed.replace(/[a-z]/, '') * 3 + 's'\n    }\n  } else {\n    switcherProp = {\n      border: this.options.speed\n      , 'box-shadow': this.options.speed\n    }\n  }\n\n  utils.transitionize(this.node, switcherProp)\n  utils.transitionize(this.jack, jackProp)\n}\n\nSwitch.prototype.disable = function () {\n  !this.disabled && (this.disabled = true)\n  this.node.style.opacity = defaults.disabledOpacity\n  this.node.removeEventListener('click', this.getClickHandler())\n}\n\nSwitch.prototype.enable = function () {\n  this.disabled && (this.disabled = false)\n  this.node.style.opacity = 1\n  this.node.addEventListener('click', this.getClickHandler())\n}\n\nSwitch.prototype.getClickHandler = function () {\n  if (!this._clickHandler) {\n    this._clickHandler = function () {\n      // var parent = this.node.parentNode.tagName.toLowerCase()\n      // var labelParent = (parent === 'label') ? false : true\n      this.setPosition(true)\n      this.dispatchEvent('change', {\n        checked: this.checked\n      })\n    }.bind(this)\n  }\n  return this._clickHandler\n}\n\nSwitch.prototype.style\n    = utils.extend(Object.create(Atomic.prototype.style), {\n\n      width: function (val) {\n        if (!this.options.scalable) {\n          return\n        }\n        val = parseFloat(val)\n        if (val !== val || val < 0) { // NaN\n          val = this.options.width\n        }\n        this.width = val * this.data.scale\n        this.setSize()\n      },\n\n      height: function (val) {\n        if (!this.options.scalable) {\n          return\n        }\n        val = parseFloat(val)\n        if (val !== val || val < 0) { // NaN\n          val = this.options.height\n        }\n        this.height = val * this.data.scale\n        this.setSize()\n      }\n\n    })\n\nmodule.exports = Switch\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/components/switch.js\n ** module id = 61\n ** module chunks = 0\n **/","// style-loader: Adds some css to the DOM by adding a <style> tag\n\n// load the styles\nvar content = require(\"!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./switch.scss\");\nif(typeof content === 'string') content = [[module.id, content, '']];\n// add the styles to the DOM\nvar update = require(\"!./../../node_modules/style-loader/addStyles.js\")(content, {});\nif(content.locals) module.exports = content.locals;\n// Hot Module Replacement\nif(module.hot) {\n\t// When the styles change, update the <style> tags\n\tif(!content.locals) {\n\t\tmodule.hot.accept(\"!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./switch.scss\", function() {\n\t\t\tvar newContent = require(\"!!./../../node_modules/css-loader/index.js?sourceMap!./../../node_modules/sass-loader/index.js?sourceMap!./switch.scss\");\n\t\t\tif(typeof newContent === 'string') newContent = [[module.id, newContent, '']];\n\t\t\tupdate(newContent);\n\t\t});\n\t}\n\t// When the module is disposed, remove the <style> tags\n\tmodule.hot.dispose(function() { update(); });\n}\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/styles/switch.scss\n ** module id = 62\n ** module chunks = 0\n **/","exports = module.exports = require(\"./../../node_modules/css-loader/lib/css-base.js\")();\n// imports\n\n\n// module\nexports.push([module.id, \"/* switch defaults. */\\n.weex-switch {\\n  background-color: #fff;\\n  border: 1px solid #dfdfdf;\\n  cursor: pointer;\\n  display: inline-block;\\n  position: relative;\\n  vertical-align: middle;\\n  -moz-user-select: none;\\n  -khtml-user-select: none;\\n  -webkit-user-select: none;\\n  -ms-user-select: none;\\n  user-select: none;\\n  box-sizing: content-box;\\n  background-clip: content-box; }\\n\\n.weex-switch > small {\\n  background: #fff;\\n  border-radius: 100%;\\n  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.4);\\n  position: absolute;\\n  top: 0; }\\n\", \"\", {\"version\":3,\"sources\":[\"/./src/src/styles/switch.scss\"],\"names\":[],\"mappings\":\"AAAA,sBAAsB;AAEtB;EACE,uBAAuB;EACvB,0BAA0B;EAC1B,gBAAgB;EAChB,sBAAsB;EACtB,mBAAmB;EACnB,uBAAuB;EAEvB,uBAAuB;EACvB,yBAAyB;EACzB,0BAA0B;EAC1B,sBAAsB;EACtB,kBAAkB;EAClB,wBAAwB;EACxB,6BAA6B,EAC9B;;AAED;EACE,iBAAiB;EACjB,oBAAoB;EACpB,yCAA0B;EAC1B,mBAAmB;EACnB,OAAO,EACR\",\"file\":\"switch.scss\",\"sourcesContent\":[\"/* switch defaults. */\\n\\n.weex-switch {\\n  background-color: #fff;\\n  border: 1px solid #dfdfdf;\\n  cursor: pointer;\\n  display: inline-block;\\n  position: relative;\\n  vertical-align: middle;\\n\\n  -moz-user-select: none;\\n  -khtml-user-select: none;\\n  -webkit-user-select: none;\\n  -ms-user-select: none;\\n  user-select: none;\\n  box-sizing: content-box;\\n  background-clip: content-box;\\n}\\n\\n.weex-switch > small {\\n  background: #fff;\\n  border-radius: 100%;\\n  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.4);\\n  position: absolute;\\n  top: 0;\\n}\\n\"],\"sourceRoot\":\"webpack://\"}]);\n\n// exports\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/css-loader?sourceMap!./~/sass-loader?sourceMap!./src/styles/switch.scss\n ** module id = 63\n ** module chunks = 0\n **/","'use strict'\n\nvar Component = require('./component')\n\n// attrs:\n//   - href\nfunction A (data) {\n  Component.call(this, data)\n}\n\nA.prototype = Object.create(Component.prototype)\n\nA.prototype.create = function () {\n  var node = document.createElement('a')\n  node.classList.add('weex-container')\n  this.node = node\n  this.style.alignItems.call(this, 'center')\n  this.style.justifyContent.call(this, 'center')\n  this.node.style.textDecoration = 'none'\n  return node\n}\n\nmodule.exports = A\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/components/a.js\n ** module id = 64\n ** module chunks = 0\n **/","'use strict'\n\nvar Component = require('./component')\nvar utils = require('../utils')\n\nvar ID_PREFIX = 'weex_embed_'\n\nfunction _generateId() {\n  return ID_PREFIX + utils.getRandom(10)\n}\n\nfunction Embed (data, nodeType) {\n  var attr = data.attr\n  if (attr) {\n    this.source = attr.src\n    this.loader = attr.loade || 'xhr'\n  }\n  Component.call(this, data, nodeType)\n  this.initWeex()\n}\n\nEmbed.prototype = Object.create(Component.prototype)\n\nEmbed.prototype.create = function () {\n\n  var node = document.createElement('div')\n  node.id = this.id\n  node.style.overflow = 'scroll'\n  // node.classList.add('weex-container')\n  return node\n}\n\nEmbed.prototype.initWeex = function () {\n  this.id = _generateId()\n  this.node.id = this.id\n  var config = {\n    appId: this.id,\n    source: this.source,\n    loader: this.loader,\n    width: this.node.getBoundingClientRect().width,\n    rootId: this.id\n  }\n  window.weex.init(config)\n}\n\nEmbed.prototype.destroyWeex = function () {\n  this.id && window.destroyInstance(this.id)\n  // TODO: unbind events and clear doms.\n  this.node.innerHTML = ''\n}\n\nEmbed.prototype.reloadWeex = function () {\n  this.destroyWeex()\n  this.initWeex()\n}\n\n// src is not updatable temporarily\n// Embed.prototype.attr = {\n//   src: function (value) {\n//     this.src = value\n//     this.reloadWeex()\n//   }\n// }\n\nmodule.exports = Embed\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/components/embed.js\n ** module id = 65\n ** module chunks = 0\n **/","var dom = require('./dom')\nvar event = require('./event')\nvar pageInfo = require('./pageInfo')\nvar stream = require('./stream')\nvar modal = require('./modal')\nvar animation = require('./animation')\n\nvar api = {\n  init: function (Weex) {\n    Weex.registerApiModule('dom', dom, dom._meta)\n    Weex.registerApiModule('event', event, event._meta)\n    Weex.registerApiModule('pageInfo', pageInfo, pageInfo._meta)\n    Weex.registerApiModule('stream', stream, stream._meta)\n    Weex.registerApiModule('modal', modal, modal._meta)\n    Weex.registerApiModule('animation', animation, animation._meta)\n  }\n}\n\nmodule.exports = api\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/api/index.js\n ** module id = 66\n ** module chunks = 0\n **/","'use strict'\n\nvar messageQueue = require('../messageQueue')\nvar FrameUpdater = require('../frameUpdater')\nvar Component = require('../components/component')\nvar scroll = require('scroll-to')\nvar config = require('../config')\n// var Weex = require('../weex')\n\nvar dom = {\n\n  /**\n   * createBody: create root component\n   * @param  {object} element\n   *    container|listview|scrollview\n   * @return {[type]}      [description]\n   */\n  createBody: function (element) {\n    var componentManager = this.getComponentManager()\n    element.scale = this.scale\n    element.instanceId = componentManager.instanceId\n    return componentManager.createBody(element)\n  },\n\n  addElement: function (parentRef, element, index) {\n    var componentManager = this.getComponentManager()\n    element.scale = this.scale\n    element.instanceId = componentManager.instanceId\n    return componentManager.addElement(parentRef, element, index)\n  },\n\n  removeElement: function (ref) {\n    var componentManager = this.getComponentManager()\n    return componentManager.removeElement(ref)\n  },\n\n  moveElement: function (ref, parentRef, index) {\n    var componentManager = this.getComponentManager()\n    return componentManager.moveElement(ref, parentRef, index)\n  },\n\n  addEvent: function (ref, type) {\n    var componentManager = this.getComponentManager()\n    return componentManager.addEvent(ref, type)\n  },\n\n  removeEvent: function (ref, type) {\n    var componentManager = this.getComponentManager()\n    return componentManager.removeEvent(ref, type)\n  },\n\n  /**\n   * updateAttrs: update attributes of component\n   * @param  {string} ref\n   * @param  {obj} attr\n   */\n  updateAttrs: function (ref, attr) {\n    var componentManager = this.getComponentManager()\n    return componentManager.updateAttrs(ref, attr)\n  },\n\n  /**\n   * updateStyle: udpate style of component\n   * @param {string} ref\n   * @param {obj} style\n   */\n  updateStyle: function (ref, style) {\n    var componentManager = this.getComponentManager()\n    return componentManager.updateStyle(ref, style)\n  },\n\n  createFinish: function () {\n    // TODO\n    // FrameUpdater.pause()\n  },\n\n  refreshFinish: function () {\n    // TODO\n  },\n\n  /**\n   * scrollToElement\n   * @param  {string} ref\n   * @param  {obj} options {offset:Number}\n   *   ps: scroll-to has 'ease' and 'duration'(ms) as options.\n   */\n  scrollToElement: function (ref, options) {\n    !options && (options = {})\n    var componentManager = this.getComponentManager()\n    var elem = componentManager.getElementByRef(ref)\n    if (elem) {\n      var offsetTop = elem.node.getBoundingClientRect().top\n          + document.body.scrollTop\n      var offset = (Number(options.offset) || 0) * this.scale\n      var tween = scroll(0, offsetTop + offset, options)\n      // tween.on('end', function () {\n      // })\n    }\n  }\n\n}\n\ndom._meta = {\n  dom: [{\n    name: 'createBody',\n    args: ['object']\n  }, {\n    name: 'addElement',\n    args: ['string', 'object', 'number']\n  }, {\n    name: 'removeElement',\n    args: ['string']\n  }, {\n    name: 'moveElement',\n    args: ['string', 'string', 'number']\n  }, {\n    name: 'addEvent',\n    args: ['string', 'string']\n  }, {\n    name: 'removeEvent',\n    args: ['string', 'string']\n  }, {\n    name: 'updateAttrs',\n    args: ['string', 'object']\n  }, {\n    name: 'updateStyle',\n    args: ['string', 'object']\n  }, {\n    name: 'createFinish',\n    args: []\n  }, {\n    name: 'refreshFinish',\n    args: []\n  }, {\n    name: 'scrollToElement',\n    args: ['string', 'object']\n  }]\n}\n\nmodule.exports = dom\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/api/dom.js\n ** module id = 67\n ** module chunks = 0\n **/","/**\n * Module dependencies.\n */\n\nvar Tween = require('tween');\nvar raf = require('raf');\n\n/**\n * Expose `scrollTo`.\n */\n\nmodule.exports = scrollTo;\n\n/**\n * Scroll to `(x, y)`.\n *\n * @param {Number} x\n * @param {Number} y\n * @api public\n */\n\nfunction scrollTo(x, y, options) {\n  options = options || {};\n\n  // start position\n  var start = scroll();\n\n  // setup tween\n  var tween = Tween(start)\n    .ease(options.ease || 'out-circ')\n    .to({ top: y, left: x })\n    .duration(options.duration || 1000);\n\n  // scroll\n  tween.update(function(o){\n    window.scrollTo(o.left | 0, o.top | 0);\n  });\n\n  // handle end\n  tween.on('end', function(){\n    animate = function(){};\n  });\n\n  // animate\n  function animate() {\n    raf(animate);\n    tween.update();\n  }\n\n  animate();\n  \n  return tween;\n}\n\n/**\n * Return scroll position.\n *\n * @return {Object}\n * @api private\n */\n\nfunction scroll() {\n  var y = window.pageYOffset || document.documentElement.scrollTop;\n  var x = window.pageXOffset || document.documentElement.scrollLeft;\n  return { top: y, left: x };\n}\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/scroll-to/index.js\n ** module id = 68\n ** module chunks = 0\n **/","\n/**\n * Module dependencies.\n */\n\nvar Emitter = require('emitter');\nvar clone = require('clone');\nvar type = require('type');\nvar ease = require('ease');\n\n/**\n * Expose `Tween`.\n */\n\nmodule.exports = Tween;\n\n/**\n * Initialize a new `Tween` with `obj`.\n *\n * @param {Object|Array} obj\n * @api public\n */\n\nfunction Tween(obj) {\n  if (!(this instanceof Tween)) return new Tween(obj);\n  this._from = obj;\n  this.ease('linear');\n  this.duration(500);\n}\n\n/**\n * Mixin emitter.\n */\n\nEmitter(Tween.prototype);\n\n/**\n * Reset the tween.\n *\n * @api public\n */\n\nTween.prototype.reset = function(){\n  this.isArray = 'array' === type(this._from);\n  this._curr = clone(this._from);\n  this._done = false;\n  this._start = Date.now();\n  return this;\n};\n\n/**\n * Tween to `obj` and reset internal state.\n *\n *    tween.to({ x: 50, y: 100 })\n *\n * @param {Object|Array} obj\n * @return {Tween} self\n * @api public\n */\n\nTween.prototype.to = function(obj){\n  this.reset();\n  this._to = obj;\n  return this;\n};\n\n/**\n * Set duration to `ms` [500].\n *\n * @param {Number} ms\n * @return {Tween} self\n * @api public\n */\n\nTween.prototype.duration = function(ms){\n  this._duration = ms;\n  return this;\n};\n\n/**\n * Set easing function to `fn`.\n *\n *    tween.ease('in-out-sine')\n *\n * @param {String|Function} fn\n * @return {Tween}\n * @api public\n */\n\nTween.prototype.ease = function(fn){\n  fn = 'function' == typeof fn ? fn : ease[fn];\n  if (!fn) throw new TypeError('invalid easing function');\n  this._ease = fn;\n  return this;\n};\n\n/**\n * Stop the tween and immediately emit \"stop\" and \"end\".\n *\n * @return {Tween}\n * @api public\n */\n\nTween.prototype.stop = function(){\n  this.stopped = true;\n  this._done = true;\n  this.emit('stop');\n  this.emit('end');\n  return this;\n};\n\n/**\n * Perform a step.\n *\n * @return {Tween} self\n * @api private\n */\n\nTween.prototype.step = function(){\n  if (this._done) return;\n\n  // duration\n  var duration = this._duration;\n  var now = Date.now();\n  var delta = now - this._start;\n  var done = delta >= duration;\n\n  // complete\n  if (done) {\n    this._from = this._to;\n    this._update(this._to);\n    this._done = true;\n    this.emit('end');\n    return this;\n  }\n\n  // tween\n  var from = this._from;\n  var to = this._to;\n  var curr = this._curr;\n  var fn = this._ease;\n  var p = (now - this._start) / duration;\n  var n = fn(p);\n\n  // array\n  if (this.isArray) {\n    for (var i = 0; i < from.length; ++i) {\n      curr[i] = from[i] + (to[i] - from[i]) * n;\n    }\n\n    this._update(curr);\n    return this;\n  }\n\n  // objech\n  for (var k in from) {\n    curr[k] = from[k] + (to[k] - from[k]) * n;\n  }\n\n  this._update(curr);\n  return this;\n};\n\n/**\n * Set update function to `fn` or\n * when no argument is given this performs\n * a \"step\".\n *\n * @param {Function} fn\n * @return {Tween} self\n * @api public\n */\n\nTween.prototype.update = function(fn){\n  if (0 == arguments.length) return this.step();\n  this._update = fn;\n  return this;\n};\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/component-tween/index.js\n ** module id = 69\n ** module chunks = 0\n **/","\n/**\n * Expose `Emitter`.\n */\n\nmodule.exports = Emitter;\n\n/**\n * Initialize a new `Emitter`.\n *\n * @api public\n */\n\nfunction Emitter(obj) {\n  if (obj) return mixin(obj);\n};\n\n/**\n * Mixin the emitter properties.\n *\n * @param {Object} obj\n * @return {Object}\n * @api private\n */\n\nfunction mixin(obj) {\n  for (var key in Emitter.prototype) {\n    obj[key] = Emitter.prototype[key];\n  }\n  return obj;\n}\n\n/**\n * Listen on the given `event` with `fn`.\n *\n * @param {String} event\n * @param {Function} fn\n * @return {Emitter}\n * @api public\n */\n\nEmitter.prototype.on =\nEmitter.prototype.addEventListener = function(event, fn){\n  this._callbacks = this._callbacks || {};\n  (this._callbacks['$' + event] = this._callbacks['$' + event] || [])\n    .push(fn);\n  return this;\n};\n\n/**\n * Adds an `event` listener that will be invoked a single\n * time then automatically removed.\n *\n * @param {String} event\n * @param {Function} fn\n * @return {Emitter}\n * @api public\n */\n\nEmitter.prototype.once = function(event, fn){\n  function on() {\n    this.off(event, on);\n    fn.apply(this, arguments);\n  }\n\n  on.fn = fn;\n  this.on(event, on);\n  return this;\n};\n\n/**\n * Remove the given callback for `event` or all\n * registered callbacks.\n *\n * @param {String} event\n * @param {Function} fn\n * @return {Emitter}\n * @api public\n */\n\nEmitter.prototype.off =\nEmitter.prototype.removeListener =\nEmitter.prototype.removeAllListeners =\nEmitter.prototype.removeEventListener = function(event, fn){\n  this._callbacks = this._callbacks || {};\n\n  // all\n  if (0 == arguments.length) {\n    this._callbacks = {};\n    return this;\n  }\n\n  // specific event\n  var callbacks = this._callbacks['$' + event];\n  if (!callbacks) return this;\n\n  // remove all handlers\n  if (1 == arguments.length) {\n    delete this._callbacks['$' + event];\n    return this;\n  }\n\n  // remove specific handler\n  var cb;\n  for (var i = 0; i < callbacks.length; i++) {\n    cb = callbacks[i];\n    if (cb === fn || cb.fn === fn) {\n      callbacks.splice(i, 1);\n      break;\n    }\n  }\n  return this;\n};\n\n/**\n * Emit `event` with the given args.\n *\n * @param {String} event\n * @param {Mixed} ...\n * @return {Emitter}\n */\n\nEmitter.prototype.emit = function(event){\n  this._callbacks = this._callbacks || {};\n  var args = [].slice.call(arguments, 1)\n    , callbacks = this._callbacks['$' + event];\n\n  if (callbacks) {\n    callbacks = callbacks.slice(0);\n    for (var i = 0, len = callbacks.length; i < len; ++i) {\n      callbacks[i].apply(this, args);\n    }\n  }\n\n  return this;\n};\n\n/**\n * Return array of callbacks for `event`.\n *\n * @param {String} event\n * @return {Array}\n * @api public\n */\n\nEmitter.prototype.listeners = function(event){\n  this._callbacks = this._callbacks || {};\n  return this._callbacks['$' + event] || [];\n};\n\n/**\n * Check if this emitter has `event` handlers.\n *\n * @param {String} event\n * @return {Boolean}\n * @api public\n */\n\nEmitter.prototype.hasListeners = function(event){\n  return !! this.listeners(event).length;\n};\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/component-emitter/index.js\n ** module id = 70\n ** module chunks = 0\n **/","/**\n * Module dependencies.\n */\n\nvar type;\ntry {\n  type = require('component-type');\n} catch (_) {\n  type = require('type');\n}\n\n/**\n * Module exports.\n */\n\nmodule.exports = clone;\n\n/**\n * Clones objects.\n *\n * @param {Mixed} any object\n * @api public\n */\n\nfunction clone(obj){\n  switch (type(obj)) {\n    case 'object':\n      var copy = {};\n      for (var key in obj) {\n        if (obj.hasOwnProperty(key)) {\n          copy[key] = clone(obj[key]);\n        }\n      }\n      return copy;\n\n    case 'array':\n      var copy = new Array(obj.length);\n      for (var i = 0, l = obj.length; i < l; i++) {\n        copy[i] = clone(obj[i]);\n      }\n      return copy;\n\n    case 'regexp':\n      // from millermedeiros/amd-utils - MIT\n      var flags = '';\n      flags += obj.multiline ? 'm' : '';\n      flags += obj.global ? 'g' : '';\n      flags += obj.ignoreCase ? 'i' : '';\n      return new RegExp(obj.source, flags);\n\n    case 'date':\n      return new Date(obj.getTime());\n\n    default: // string, number, boolean, …\n      return obj;\n  }\n}\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/component-clone/index.js\n ** module id = 71\n ** module chunks = 0\n **/","/**\n * toString ref.\n */\n\nvar toString = Object.prototype.toString;\n\n/**\n * Return the type of `val`.\n *\n * @param {Mixed} val\n * @return {String}\n * @api public\n */\n\nmodule.exports = function(val){\n  switch (toString.call(val)) {\n    case '[object Date]': return 'date';\n    case '[object RegExp]': return 'regexp';\n    case '[object Arguments]': return 'arguments';\n    case '[object Array]': return 'array';\n    case '[object Error]': return 'error';\n  }\n\n  if (val === null) return 'null';\n  if (val === undefined) return 'undefined';\n  if (val !== val) return 'nan';\n  if (val && val.nodeType === 1) return 'element';\n\n  val = val.valueOf\n    ? val.valueOf()\n    : Object.prototype.valueOf.apply(val)\n\n  return typeof val;\n};\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/component-type/index.js\n ** module id = 72\n ** module chunks = 0\n **/","\n// easing functions from \"Tween.js\"\n\nexports.linear = function(n){\n  return n;\n};\n\nexports.inQuad = function(n){\n  return n * n;\n};\n\nexports.outQuad = function(n){\n  return n * (2 - n);\n};\n\nexports.inOutQuad = function(n){\n  n *= 2;\n  if (n < 1) return 0.5 * n * n;\n  return - 0.5 * (--n * (n - 2) - 1);\n};\n\nexports.inCube = function(n){\n  return n * n * n;\n};\n\nexports.outCube = function(n){\n  return --n * n * n + 1;\n};\n\nexports.inOutCube = function(n){\n  n *= 2;\n  if (n < 1) return 0.5 * n * n * n;\n  return 0.5 * ((n -= 2 ) * n * n + 2);\n};\n\nexports.inQuart = function(n){\n  return n * n * n * n;\n};\n\nexports.outQuart = function(n){\n  return 1 - (--n * n * n * n);\n};\n\nexports.inOutQuart = function(n){\n  n *= 2;\n  if (n < 1) return 0.5 * n * n * n * n;\n  return -0.5 * ((n -= 2) * n * n * n - 2);\n};\n\nexports.inQuint = function(n){\n  return n * n * n * n * n;\n}\n\nexports.outQuint = function(n){\n  return --n * n * n * n * n + 1;\n}\n\nexports.inOutQuint = function(n){\n  n *= 2;\n  if (n < 1) return 0.5 * n * n * n * n * n;\n  return 0.5 * ((n -= 2) * n * n * n * n + 2);\n};\n\nexports.inSine = function(n){\n  return 1 - Math.cos(n * Math.PI / 2 );\n};\n\nexports.outSine = function(n){\n  return Math.sin(n * Math.PI / 2);\n};\n\nexports.inOutSine = function(n){\n  return .5 * (1 - Math.cos(Math.PI * n));\n};\n\nexports.inExpo = function(n){\n  return 0 == n ? 0 : Math.pow(1024, n - 1);\n};\n\nexports.outExpo = function(n){\n  return 1 == n ? n : 1 - Math.pow(2, -10 * n);\n};\n\nexports.inOutExpo = function(n){\n  if (0 == n) return 0;\n  if (1 == n) return 1;\n  if ((n *= 2) < 1) return .5 * Math.pow(1024, n - 1);\n  return .5 * (-Math.pow(2, -10 * (n - 1)) + 2);\n};\n\nexports.inCirc = function(n){\n  return 1 - Math.sqrt(1 - n * n);\n};\n\nexports.outCirc = function(n){\n  return Math.sqrt(1 - (--n * n));\n};\n\nexports.inOutCirc = function(n){\n  n *= 2\n  if (n < 1) return -0.5 * (Math.sqrt(1 - n * n) - 1);\n  return 0.5 * (Math.sqrt(1 - (n -= 2) * n) + 1);\n};\n\nexports.inBack = function(n){\n  var s = 1.70158;\n  return n * n * (( s + 1 ) * n - s);\n};\n\nexports.outBack = function(n){\n  var s = 1.70158;\n  return --n * n * ((s + 1) * n + s) + 1;\n};\n\nexports.inOutBack = function(n){\n  var s = 1.70158 * 1.525;\n  if ( ( n *= 2 ) < 1 ) return 0.5 * ( n * n * ( ( s + 1 ) * n - s ) );\n  return 0.5 * ( ( n -= 2 ) * n * ( ( s + 1 ) * n + s ) + 2 );\n};\n\nexports.inBounce = function(n){\n  return 1 - exports.outBounce(1 - n);\n};\n\nexports.outBounce = function(n){\n  if ( n < ( 1 / 2.75 ) ) {\n    return 7.5625 * n * n;\n  } else if ( n < ( 2 / 2.75 ) ) {\n    return 7.5625 * ( n -= ( 1.5 / 2.75 ) ) * n + 0.75;\n  } else if ( n < ( 2.5 / 2.75 ) ) {\n    return 7.5625 * ( n -= ( 2.25 / 2.75 ) ) * n + 0.9375;\n  } else {\n    return 7.5625 * ( n -= ( 2.625 / 2.75 ) ) * n + 0.984375;\n  }\n};\n\nexports.inOutBounce = function(n){\n  if (n < .5) return exports.inBounce(n * 2) * .5;\n  return exports.outBounce(n * 2 - 1) * .5 + .5;\n};\n\n// aliases\n\nexports['in-quad'] = exports.inQuad;\nexports['out-quad'] = exports.outQuad;\nexports['in-out-quad'] = exports.inOutQuad;\nexports['in-cube'] = exports.inCube;\nexports['out-cube'] = exports.outCube;\nexports['in-out-cube'] = exports.inOutCube;\nexports['in-quart'] = exports.inQuart;\nexports['out-quart'] = exports.outQuart;\nexports['in-out-quart'] = exports.inOutQuart;\nexports['in-quint'] = exports.inQuint;\nexports['out-quint'] = exports.outQuint;\nexports['in-out-quint'] = exports.inOutQuint;\nexports['in-sine'] = exports.inSine;\nexports['out-sine'] = exports.outSine;\nexports['in-out-sine'] = exports.inOutSine;\nexports['in-expo'] = exports.inExpo;\nexports['out-expo'] = exports.outExpo;\nexports['in-out-expo'] = exports.inOutExpo;\nexports['in-circ'] = exports.inCirc;\nexports['out-circ'] = exports.outCirc;\nexports['in-out-circ'] = exports.inOutCirc;\nexports['in-back'] = exports.inBack;\nexports['out-back'] = exports.outBack;\nexports['in-out-back'] = exports.inOutBack;\nexports['in-bounce'] = exports.inBounce;\nexports['out-bounce'] = exports.outBounce;\nexports['in-out-bounce'] = exports.inOutBounce;\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/ease-component/index.js\n ** module id = 73\n ** module chunks = 0\n **/","/**\n * Expose `requestAnimationFrame()`.\n */\n\nexports = module.exports = window.requestAnimationFrame\n  || window.webkitRequestAnimationFrame\n  || window.mozRequestAnimationFrame\n  || fallback;\n\n/**\n * Fallback implementation.\n */\n\nvar prev = new Date().getTime();\nfunction fallback(fn) {\n  var curr = new Date().getTime();\n  var ms = Math.max(0, 16 - (curr - prev));\n  var req = setTimeout(fn, ms);\n  prev = curr;\n  return req;\n}\n\n/**\n * Cancel.\n */\n\nvar cancel = window.cancelAnimationFrame\n  || window.webkitCancelAnimationFrame\n  || window.mozCancelAnimationFrame\n  || window.clearTimeout;\n\nexports.cancel = function(id){\n  cancel.call(window, id);\n};\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/component-raf/index.js\n ** module id = 74\n ** module chunks = 0\n **/","'use strict'\n\nvar event = {\n  /**\n   * openUrl\n   * @param  {string} url\n   */\n  openURL: function (url) {\n    location.href = url\n  }\n\n}\n\nevent._meta = {\n  event: [{\n    name: 'openURL',\n    args: ['string']\n  }]\n}\n\nmodule.exports = event\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/api/event.js\n ** module id = 75\n ** module chunks = 0\n **/","'use strict'\n\nvar pageInfo = {\n\n  setTitle: function (title) {\n    title = title || 'Weex HTML5'\n    try {\n      title = decodeURIComponent(title)\n    } catch (e) {}\n    document.title = title\n  }\n}\n\npageInfo._meta = {\n  pageInfo: [{\n    name: 'setTitle',\n    args: ['string']\n  }]\n}\n\nmodule.exports = pageInfo\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/api/pageInfo.js\n ** module id = 76\n ** module chunks = 0\n **/","'use strict'\n\n// require('httpurl')\n\n// var jsonpCnt = 0\n\n// function _sendJsonp(config, callbackId) {\n//   var cbName = '_callback_' + (++jsonpCnt)\n//   var script, url, head\n//   global[cbName] = (function (cb) {\n//     return function (response) {\n//       this.sender.performCallback(callbackId, response)\n//       delete global[cb]\n//     }\n//   })(cbName)\n//   script = document.createElement('script')\n//   url = lib.httpurl(config.url)\n//   url.params.callback = cbName\n//   script.type = 'text/javascript'\n//   script.src = url.toString()\n//   // script.onerror is not working on IE or safari.\n//   // but they are not considered here.\n//   script.onerror = (function (cb) {\n//     return function (err) {\n//       this.sender.performCallback(callbackId, err)\n//       delete global[cb]\n//     }\n//   })(cbName)\n//   head = document.getElementsByTagName('head')[0]\n//   head.insertBefore(script, null)\n// }\n\nvar stream = {\n\n  /**\n   * sendHttp\n   * @param  {obj} params\n   *  - method: 'GET' | 'POST',\n   *  - url: url requested\n   * @param  {string} callbackId\n   */\n  sendHttp: function (param, callbackId) {\n    if (typeof param === 'string') {\n      try {\n        param = JSON.parse(param)\n      } catch (e) {\n        return\n      }\n    }\n    if (typeof param !== 'object' || !param.url) {\n      return\n    }\n\n    // Not to use jsonp to send http request since it requires the server\n    // to support jsonp callback at the first place.\n    // _sendJsonp.call(this, param, callbackId)\n\n    var self = this\n    var method = param.method || 'GET'\n    var xhr = new XMLHttpRequest()\n    xhr.open(method, param.url, true)\n    xhr.onload = function () {\n      self.sender.performCallback(callbackId, this.responseText)\n    }\n    xhr.onerror = function (error) {\n      self.sender.performCallback(callbackId, error)\n    }\n    xhr.send()\n  }\n\n}\n\nstream._meta = {\n  stream: [{\n    name: 'sendHttp',\n    args: ['object', 'string']\n  }]\n}\n\nmodule.exports = stream\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/api/stream.js\n ** module id = 77\n ** module chunks = 0\n **/","'use strict'\n\nvar sender = require('../bridge/sender')\nvar modal = require('modals')\n\nvar msg = {\n\n  // duration: default is 0.8 seconds.\n  toast: function (config) {\n    modal.toast(config.message, config.duration)\n  },\n\n  // config:\n  //  - message: string\n  //  - okTitle: title of ok button\n  //  - callback\n  alert: function (config, callbackId) {\n    var sender =  this.sender\n    config.callback = function () {\n      sender.performCallback(callbackId)\n    }\n    modal.alert(config)\n  },\n\n  // config:\n  //  - message: string\n  //  - okTitle: title of ok button\n  //  - cancelTitle: title of cancel button\n  //  - callback\n  confirm: function (config, callbackId) {\n    var sender =  this.sender\n    config.callback = function (val) {\n      sender.performCallback(callbackId, val)\n    }\n    modal.confirm(config)\n  },\n\n  // config:\n  //  - message: string\n  //  - okTitle: title of ok button\n  //  - cancelTitle: title of cancel button\n  //  - callback\n  prompt: function (config, callbackId) {\n    var sender =  this.sender\n    config.callback = function (val) {\n      sender.performCallback(callbackId, val)\n    }\n    modal.prompt(config)\n  }\n\n}\n\nmsg._meta = {\n  modal: [{\n    name: 'toast',\n    args: ['object']\n  }, {\n    name: 'alert',\n    args: ['object', 'string']\n  }, {\n    name: 'confirm',\n    args: ['object', 'string']\n  }, {\n    name: 'prompt',\n    args: ['object', 'string']\n  }]\n}\n\nmodule.exports = msg\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/api/modal.js\n ** module id = 78\n ** module chunks = 0\n **/","'use strict'\n\nvar Alert = require('./alert')\nvar Confirm = require('./confirm')\nvar Prompt = require('./prompt')\nvar toast = require('./toast')\n\nvar modal = {\n\n  toast: function (msg, duration) {\n    toast.push(msg, duration)\n  },\n\n  alert: function (config) {\n    new Alert(config).show()\n  },\n\n  prompt: function (config) {\n    new Prompt(config).show()\n  },\n\n  confirm: function (config) {\n    new Confirm(config).show()\n  }\n\n}\n\n!window.lib && (window.lib = {})\nwindow.lib.modal = modal\n\nmodule.exports = modal\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/modals/src/index.js\n ** module id = 79\n ** module chunks = 0\n **/","'use strict'\n\nvar Modal = require('./modal')\nrequire('../styles/alert.scss')\n\nvar CONTENT_CLASS = 'content'\nvar MSG_CLASS = 'content-msg'\nvar BUTTON_GROUP_CLASS = 'btn-group'\nvar BUTTON_CLASS = 'btn'\n\nfunction Alert(config) {\n  this.msg = config.message || ''\n  this.callback = config.callback\n  this.okTitle = config.okTitle || 'OK'\n  Modal.call(this)\n  this.node.classList.add('amfe-alert')\n}\n\nAlert.prototype = Object.create(Modal.prototype)\n\nAlert.prototype.createNodeContent = function () {\n  var content = document.createElement('div')\n  content.classList.add(CONTENT_CLASS)\n  this.node.appendChild(content)\n\n  var msg = document.createElement('div')\n  msg.classList.add(MSG_CLASS)\n  msg.appendChild(document.createTextNode(this.msg))\n  content.appendChild(msg)\n\n  var buttonGroup = document.createElement('div')\n  buttonGroup.classList.add(BUTTON_GROUP_CLASS)\n  this.node.appendChild(buttonGroup)\n  var button = document.createElement('div')\n  button.classList.add(BUTTON_CLASS, 'alert-ok')\n  button.appendChild(document.createTextNode(this.okTitle))\n  buttonGroup.appendChild(button)\n}\n\nAlert.prototype.bindEvents = function () {\n  Modal.prototype.bindEvents.call(this)\n  var button = this.node.querySelector('.' + BUTTON_CLASS)\n  button.addEventListener('click', function () {\n    this.destroy()\n    this.callback && this.callback()\n  }.bind(this))\n}\n\nmodule.exports = Alert\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/modals/src/alert.js\n ** module id = 80\n ** module chunks = 0\n **/","'use strict'\n\nrequire('../styles/modal.scss')\n\n// there will be only one instance of modal.\nvar MODAL_WRAP_CLASS = 'amfe-modal-wrap'\nvar MODAL_NODE_CLASS = 'amfe-modal-node'\n\nfunction Modal() {\n  this.wrap = document.querySelector(MODAL_WRAP_CLASS)\n  this.node = document.querySelector(MODAL_NODE_CLASS)\n  if (!this.wrap) {\n    this.createWrap()\n  }\n  if (!this.node) {\n    this.createNode()\n  }\n  this.clearNode()\n  this.createNodeContent()\n  this.bindEvents()\n}\n\nModal.prototype = {\n\n  show: function () {\n    this.wrap.style.display = 'block'\n    this.node.classList.remove('hide')\n  },\n\n  destroy: function () {\n    document.body.removeChild(this.wrap)\n    document.body.removeChild(this.node)\n    this.wrap = null\n    this.node = null\n  },\n\n  createWrap: function () {\n    this.wrap = document.createElement('div')\n    this.wrap.className = MODAL_WRAP_CLASS\n    document.body.appendChild(this.wrap)\n  },\n\n  createNode: function () {\n    this.node = document.createElement('div')\n    this.node.classList.add(MODAL_NODE_CLASS, 'hide')\n    document.body.appendChild(this.node)\n  },\n\n  clearNode: function () {\n    this.node.innerHTML = ''\n  },\n\n  createNodeContent: function () {\n\n    // do nothing.\n    // child classes can override this method.\n  },\n\n  bindEvents: function () {\n    this.wrap.addEventListener('click', function (e) {\n      e.preventDefault()\n      e.stopPropagation()\n    })\n  }\n}\n\nmodule.exports = Modal\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/modals/src/modal.js\n ** module id = 81\n ** module chunks = 0\n **/","// style-loader: Adds some css to the DOM by adding a <style> tag\n\n// load the styles\nvar content = require(\"!!./../../css-loader/index.js?sourceMap!./../../sass-loader/index.js?sourceMap!./modal.scss\");\nif(typeof content === 'string') content = [[module.id, content, '']];\n// add the styles to the DOM\nvar update = require(\"!./../../style-loader/addStyles.js\")(content, {});\nif(content.locals) module.exports = content.locals;\n// Hot Module Replacement\nif(module.hot) {\n\t// When the styles change, update the <style> tags\n\tif(!content.locals) {\n\t\tmodule.hot.accept(\"!!./../../css-loader/index.js?sourceMap!./../../sass-loader/index.js?sourceMap!./modal.scss\", function() {\n\t\t\tvar newContent = require(\"!!./../../css-loader/index.js?sourceMap!./../../sass-loader/index.js?sourceMap!./modal.scss\");\n\t\t\tif(typeof newContent === 'string') newContent = [[module.id, newContent, '']];\n\t\t\tupdate(newContent);\n\t\t});\n\t}\n\t// When the module is disposed, remove the <style> tags\n\tmodule.hot.dispose(function() { update(); });\n}\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/modals/styles/modal.scss\n ** module id = 82\n ** module chunks = 0\n **/","exports = module.exports = require(\"./../../css-loader/lib/css-base.js\")();\n// imports\n\n\n// module\nexports.push([module.id, \".amfe-modal-wrap {\\n  display: none;\\n  position: fixed;\\n  z-index: 999999999;\\n  top: 0;\\n  left: 0;\\n  width: 100%;\\n  height: 100%;\\n  background-color: #000;\\n  opacity: 0.5; }\\n\\n.amfe-modal-node {\\n  position: fixed;\\n  z-index: 9999999999;\\n  top: 50%;\\n  left: 50%;\\n  width: 6.666667rem;\\n  min-height: 2.666667rem;\\n  border-radius: 0.066667rem;\\n  -webkit-transform: translate(-50%, -50%);\\n  transform: translate(-50%, -50%);\\n  background-color: #fff; }\\n  .amfe-modal-node.hide {\\n    display: none; }\\n  .amfe-modal-node .content {\\n    width: 100%;\\n    min-height: 1.866667rem;\\n    box-sizing: border-box;\\n    font-size: 0.32rem;\\n    line-height: 0.426667rem;\\n    padding: 0.213333rem;\\n    border-bottom: 1px solid #ddd; }\\n  .amfe-modal-node .btn-group {\\n    width: 100%;\\n    height: 0.8rem;\\n    font-size: 0.373333rem;\\n    text-align: center; }\\n    .amfe-modal-node .btn-group .btn {\\n      box-sizing: border-box;\\n      height: 0.8rem;\\n      line-height: 0.8rem; }\\n\", \"\", {\"version\":3,\"sources\":[\"/./node_modules/modals/node_modules/modals/styles/modal.scss\"],\"names\":[],\"mappings\":\"AAAA;EACE,cAAc;EACd,gBAAgB;EAChB,mBAAmB;EACnB,OAAO;EACP,QAAQ;EACR,YAAY;EACZ,aAAa;EACb,uBAAuB;EACvB,aAAa,EAEd;;AAED;EACE,gBAAgB;EAChB,oBAAoB;EACpB,SAAS;EACT,UAAU;EACV,mBAAmB;EACnB,wBAAwB;EACxB,2BAA2B;EAC3B,yCAA4B;EAC5B,iCAAoB;EACpB,uBAAuB,EA4BxB;EAtCD;IAaI,cACD,EAAC;EAdJ;IAiBI,YAAY;IACZ,wBAAwB;IACxB,uBAAuB;IACvB,mBAAmB;IACnB,yBAAyB;IACzB,qBAAqB;IACrB,8BAA8B,EAC/B;EAxBH;IA2BI,YAAY;IACZ,eAAe;IACf,uBAAuB;IACvB,mBAAmB,EAOpB;IArCH;MAiCM,uBAAuB;MACvB,eAAe;MACf,oBAAoB,EACrB\",\"file\":\"modal.scss\",\"sourcesContent\":[\".amfe-modal-wrap {\\n  display: none;\\n  position: fixed;\\n  z-index: 999999999;\\n  top: 0;\\n  left: 0;\\n  width: 100%;\\n  height: 100%;\\n  background-color: #000;\\n  opacity: 0.5;\\n\\n}\\n\\n.amfe-modal-node {\\n  position: fixed;\\n  z-index: 9999999999;\\n  top: 50%;\\n  left: 50%;\\n  width: 6.666667rem; // 500px\\n  min-height: 2.666667rem; // 200px\\n  border-radius: 0.066667rem; // 5px\\n  -webkit-transform: translate(-50%, -50%);\\n  transform: translate(-50%, -50%);\\n  background-color: #fff;\\n\\n  &.hide {\\n    display: none\\n  }\\n\\n  .content {\\n    width: 100%;\\n    min-height: 1.866667rem; // 140px\\n    box-sizing: border-box;\\n    font-size: 0.32rem; // 24px\\n    line-height: 0.426667rem; // 32px\\n    padding: 0.213333rem; // 16px\\n    border-bottom: 1px solid #ddd;\\n  }\\n\\n  .btn-group {\\n    width: 100%;\\n    height: 0.8rem; // 60px\\n    font-size: 0.373333rem; // 28px\\n    text-align: center;\\n\\n    .btn {\\n      box-sizing: border-box;\\n      height: 0.8rem; // 60px\\n      line-height: 0.8rem; // 60px\\n    }\\n  }\\n}\\n\"],\"sourceRoot\":\"webpack://\"}]);\n\n// exports\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/css-loader?sourceMap!./~/sass-loader?sourceMap!./~/modals/styles/modal.scss\n ** module id = 83\n ** module chunks = 0\n **/","// style-loader: Adds some css to the DOM by adding a <style> tag\n\n// load the styles\nvar content = require(\"!!./../../css-loader/index.js?sourceMap!./../../sass-loader/index.js?sourceMap!./alert.scss\");\nif(typeof content === 'string') content = [[module.id, content, '']];\n// add the styles to the DOM\nvar update = require(\"!./../../style-loader/addStyles.js\")(content, {});\nif(content.locals) module.exports = content.locals;\n// Hot Module Replacement\nif(module.hot) {\n\t// When the styles change, update the <style> tags\n\tif(!content.locals) {\n\t\tmodule.hot.accept(\"!!./../../css-loader/index.js?sourceMap!./../../sass-loader/index.js?sourceMap!./alert.scss\", function() {\n\t\t\tvar newContent = require(\"!!./../../css-loader/index.js?sourceMap!./../../sass-loader/index.js?sourceMap!./alert.scss\");\n\t\t\tif(typeof newContent === 'string') newContent = [[module.id, newContent, '']];\n\t\t\tupdate(newContent);\n\t\t});\n\t}\n\t// When the module is disposed, remove the <style> tags\n\tmodule.hot.dispose(function() { update(); });\n}\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/modals/styles/alert.scss\n ** module id = 84\n ** module chunks = 0\n **/","exports = module.exports = require(\"./../../css-loader/lib/css-base.js\")();\n// imports\n\n\n// module\nexports.push([module.id, \".amfe-alert .amfe-alert-ok {\\n  width: 100%; }\\n\", \"\", {\"version\":3,\"sources\":[\"/./node_modules/modals/node_modules/modals/styles/alert.scss\"],\"names\":[],\"mappings\":\"AAAA;EAGI,YAAY,EACb\",\"file\":\"alert.scss\",\"sourcesContent\":[\".amfe-alert {\\n\\n  .amfe-alert-ok {\\n    width: 100%;\\n  }\\n}\\n\"],\"sourceRoot\":\"webpack://\"}]);\n\n// exports\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/css-loader?sourceMap!./~/sass-loader?sourceMap!./~/modals/styles/alert.scss\n ** module id = 85\n ** module chunks = 0\n **/","'use strict'\n\nvar Modal = require('./modal')\nrequire('../styles/confirm.scss')\n\nvar CONTENT_CLASS = 'content'\nvar MSG_CLASS = 'content-msg'\nvar BUTTON_GROUP_CLASS = 'btn-group'\nvar BUTTON_CLASS = 'btn'\n\nfunction Confirm(config) {\n  this.msg = config.message || ''\n  this.callback = config.callback\n  this.okTitle = config.okTitle || 'OK'\n  this.cancelTitle = config.cancelTitle || 'Cancel'\n  Modal.call(this)\n  this.node.classList.add('amfe-confirm')\n}\n\nConfirm.prototype = Object.create(Modal.prototype)\n\nConfirm.prototype.createNodeContent = function () {\n  var content = document.createElement('div')\n  content.classList.add(CONTENT_CLASS)\n  this.node.appendChild(content)\n\n  var msg = document.createElement('div')\n  msg.classList.add(MSG_CLASS)\n  msg.appendChild(document.createTextNode(this.msg))\n  content.appendChild(msg)\n\n  var buttonGroup = document.createElement('div')\n  buttonGroup.classList.add(BUTTON_GROUP_CLASS)\n  this.node.appendChild(buttonGroup)\n  var btnOk = document.createElement('div')\n  btnOk.appendChild(document.createTextNode(this.okTitle))\n  btnOk.classList.add('btn-ok', BUTTON_CLASS)\n  var btnCancel = document.createElement('div')\n  btnCancel.appendChild(document.createTextNode(this.cancelTitle))\n  btnCancel.classList.add('btn-cancel', BUTTON_CLASS)\n  buttonGroup.appendChild(btnOk)\n  buttonGroup.appendChild(btnCancel)\n  this.node.appendChild(buttonGroup)\n}\n\nConfirm.prototype.bindEvents = function () {\n  Modal.prototype.bindEvents.call(this)\n  var btnOk = this.node.querySelector('.' + BUTTON_CLASS + '.btn-ok')\n  var btnCancel = this.node.querySelector('.' + BUTTON_CLASS + '.btn-cancel')\n  btnOk.addEventListener('click', function () {\n    this.destroy()\n    this.callback && this.callback(this.okTitle)\n  }.bind(this))\n  btnCancel.addEventListener('click', function () {\n    this.destroy()\n    this.callback && this.callback(this.cancelTitle)\n  }.bind(this))\n}\n\nmodule.exports = Confirm\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/modals/src/confirm.js\n ** module id = 86\n ** module chunks = 0\n **/","// style-loader: Adds some css to the DOM by adding a <style> tag\n\n// load the styles\nvar content = require(\"!!./../../css-loader/index.js?sourceMap!./../../sass-loader/index.js?sourceMap!./confirm.scss\");\nif(typeof content === 'string') content = [[module.id, content, '']];\n// add the styles to the DOM\nvar update = require(\"!./../../style-loader/addStyles.js\")(content, {});\nif(content.locals) module.exports = content.locals;\n// Hot Module Replacement\nif(module.hot) {\n\t// When the styles change, update the <style> tags\n\tif(!content.locals) {\n\t\tmodule.hot.accept(\"!!./../../css-loader/index.js?sourceMap!./../../sass-loader/index.js?sourceMap!./confirm.scss\", function() {\n\t\t\tvar newContent = require(\"!!./../../css-loader/index.js?sourceMap!./../../sass-loader/index.js?sourceMap!./confirm.scss\");\n\t\t\tif(typeof newContent === 'string') newContent = [[module.id, newContent, '']];\n\t\t\tupdate(newContent);\n\t\t});\n\t}\n\t// When the module is disposed, remove the <style> tags\n\tmodule.hot.dispose(function() { update(); });\n}\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/modals/styles/confirm.scss\n ** module id = 87\n ** module chunks = 0\n **/","exports = module.exports = require(\"./../../css-loader/lib/css-base.js\")();\n// imports\n\n\n// module\nexports.push([module.id, \".amfe-confirm .btn-group .btn {\\n  float: left;\\n  width: 50%; }\\n  .amfe-confirm .btn-group .btn.btn-ok {\\n    border-right: 1px solid #ddd; }\\n\", \"\", {\"version\":3,\"sources\":[\"/./node_modules/modals/node_modules/modals/styles/confirm.scss\"],\"names\":[],\"mappings\":\"AAAA;EAKM,YAAY;EACZ,WAAW,EAKZ;EAXL;IASO,6BAA6B,EAC7B\",\"file\":\"confirm.scss\",\"sourcesContent\":[\".amfe-confirm {\\n\\n  .btn-group {\\n\\n    .btn {\\n      float: left;\\n      width: 50%;\\n\\n      &.btn-ok {\\n      \\tborder-right: 1px solid #ddd;\\n      }\\n    }\\n  }\\n}\"],\"sourceRoot\":\"webpack://\"}]);\n\n// exports\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/css-loader?sourceMap!./~/sass-loader?sourceMap!./~/modals/styles/confirm.scss\n ** module id = 88\n ** module chunks = 0\n **/","'use strict'\n\nvar Modal = require('./modal')\nrequire('../styles/prompt.scss')\n\nvar CONTENT_CLASS = 'content'\nvar MSG_CLASS = 'content-msg'\nvar BUTTON_GROUP_CLASS = 'btn-group'\nvar BUTTON_CLASS = 'btn'\nvar INPUT_WRAP_CLASS = 'input-wrap'\nvar INPUT_CLASS = 'input'\n\nfunction Prompt(config) {\n  this.msg = config.message || ''\n  this.defaultMsg = config.default || ''\n  this.callback = config.callback\n  this.okTitle = config.okTitle || 'OK'\n  this.cancelTitle = config.cancelTitle || 'Cancel'\n  Modal.call(this)\n  this.node.classList.add('amfe-prompt')\n}\n\nPrompt.prototype = Object.create(Modal.prototype)\n\nPrompt.prototype.createNodeContent = function () {\n\n  var content = document.createElement('div')\n  content.classList.add(CONTENT_CLASS)\n  this.node.appendChild(content)\n\n  var msg = document.createElement('div')\n  msg.classList.add(MSG_CLASS)\n  msg.appendChild(document.createTextNode(this.msg))\n  content.appendChild(msg)\n\n  var inputWrap = document.createElement('div')\n  inputWrap.classList.add(INPUT_WRAP_CLASS)\n  content.appendChild(inputWrap)\n  var input = document.createElement('input')\n  input.classList.add(INPUT_CLASS)\n  input.type = 'text'\n  input.autofocus = true\n  input.placeholder = this.defaultMsg\n  inputWrap.appendChild(input)\n\n  var buttonGroup = document.createElement('div')\n  buttonGroup.classList.add(BUTTON_GROUP_CLASS)\n  var btnOk = document.createElement('div')\n  btnOk.appendChild(document.createTextNode(this.okTitle))\n  btnOk.classList.add('btn-ok', BUTTON_CLASS)\n  var btnCancel = document.createElement('div')\n  btnCancel.appendChild(document.createTextNode(this.cancelTitle))\n  btnCancel.classList.add('btn-cancel', BUTTON_CLASS)\n  buttonGroup.appendChild(btnOk)\n  buttonGroup.appendChild(btnCancel)\n  this.node.appendChild(buttonGroup)\n}\n\nPrompt.prototype.bindEvents = function () {\n  Modal.prototype.bindEvents.call(this)\n  var btnOk = this.node.querySelector('.' + BUTTON_CLASS + '.btn-ok')\n  var btnCancel = this.node.querySelector('.' + BUTTON_CLASS + '.btn-cancel')\n  var that = this\n  btnOk.addEventListener('click', function () {\n    var val = document.querySelector('input').value\n    this.destroy()\n    this.callback && this.callback({\n      result: that.okTitle,\n      data: val\n    })\n  }.bind(this))\n  btnCancel.addEventListener('click', function () {\n    var val = document.querySelector('input').value\n    this.destroy()\n    this.callback && this.callback({\n      result: that.cancelTitle\n    })\n  }.bind(this))\n}\n\nmodule.exports = Prompt\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/modals/src/prompt.js\n ** module id = 89\n ** module chunks = 0\n **/","// style-loader: Adds some css to the DOM by adding a <style> tag\n\n// load the styles\nvar content = require(\"!!./../../css-loader/index.js?sourceMap!./../../sass-loader/index.js?sourceMap!./prompt.scss\");\nif(typeof content === 'string') content = [[module.id, content, '']];\n// add the styles to the DOM\nvar update = require(\"!./../../style-loader/addStyles.js\")(content, {});\nif(content.locals) module.exports = content.locals;\n// Hot Module Replacement\nif(module.hot) {\n\t// When the styles change, update the <style> tags\n\tif(!content.locals) {\n\t\tmodule.hot.accept(\"!!./../../css-loader/index.js?sourceMap!./../../sass-loader/index.js?sourceMap!./prompt.scss\", function() {\n\t\t\tvar newContent = require(\"!!./../../css-loader/index.js?sourceMap!./../../sass-loader/index.js?sourceMap!./prompt.scss\");\n\t\t\tif(typeof newContent === 'string') newContent = [[module.id, newContent, '']];\n\t\t\tupdate(newContent);\n\t\t});\n\t}\n\t// When the module is disposed, remove the <style> tags\n\tmodule.hot.dispose(function() { update(); });\n}\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/modals/styles/prompt.scss\n ** module id = 90\n ** module chunks = 0\n **/","exports = module.exports = require(\"./../../css-loader/lib/css-base.js\")();\n// imports\n\n\n// module\nexports.push([module.id, \".amfe-prompt .input-wrap {\\n  box-sizing: border-box;\\n  width: 100%;\\n  padding: 0.24rem 0.213333rem 0.213333rem;\\n  height: 0.96rem; }\\n  .amfe-prompt .input-wrap .input {\\n    box-sizing: border-box;\\n    width: 100%;\\n    height: 0.56rem;\\n    line-height: 0.56rem;\\n    font-size: 0.32rem; }\\n\\n.amfe-prompt .btn-group .btn {\\n  float: left;\\n  width: 50%; }\\n  .amfe-prompt .btn-group .btn.btn-ok {\\n    border-right: 1px solid #ddd; }\\n\", \"\", {\"version\":3,\"sources\":[\"/./node_modules/modals/node_modules/modals/styles/prompt.scss\"],\"names\":[],\"mappings\":\"AAAA;EAGI,uBAAuB;EACvB,YAAY;EACZ,yCAAyC;EACzC,gBAAgB,EASjB;EAfH;IASM,uBAAuB;IACvB,YAAY;IACZ,gBAAgB;IAChB,qBAAqB;IACrB,mBAAmB,EACpB;;AAdL;EAoBM,YAAY;EACZ,WAAW,EAKZ;EA1BL;IAwBQ,6BAA6B,EAC9B\",\"file\":\"prompt.scss\",\"sourcesContent\":[\".amfe-prompt {\\n\\n  .input-wrap {\\n    box-sizing: border-box;\\n    width: 100%;\\n    padding: 0.24rem 0.213333rem 0.213333rem; // 18px 16px 16px\\n    height: 0.96rem; // 74px\\n\\n    .input {\\n      box-sizing: border-box;\\n      width: 100%;\\n      height: 0.56rem; // 42px\\n      line-height: 0.56rem; // 42px\\n      font-size: 0.32rem; // 24px\\n    }\\n  }\\n\\n  .btn-group {\\n\\n    .btn {\\n      float: left;\\n      width: 50%;\\n\\n      &.btn-ok {\\n        border-right: 1px solid #ddd;\\n      }\\n    }\\n  }\\n}\"],\"sourceRoot\":\"webpack://\"}]);\n\n// exports\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/css-loader?sourceMap!./~/sass-loader?sourceMap!./~/modals/styles/prompt.scss\n ** module id = 91\n ** module chunks = 0\n **/","'use strict'\n\nrequire('../styles/toast.scss')\n\nvar queue = []\nvar timer\nvar isProcessing = false\nvar toastWin\nvar TOAST_WIN_CLASS_NAME = 'amfe-toast'\n\nvar DEFAULT_DURATION = 0.8\n\nfunction showToastWindow(msg, callback) {\n  var handleTransitionEnd = function () {\n    toastWin.removeEventListener('transitionend', handleTransitionEnd)\n    callback && callback()\n  }\n  if (!toastWin) {\n    toastWin = document.createElement('div')\n    toastWin.classList.add(TOAST_WIN_CLASS_NAME, 'hide')\n    document.body.appendChild(toastWin)\n  }\n  toastWin.innerHTML = msg\n  toastWin.addEventListener('transitionend', handleTransitionEnd)\n  setTimeout(function () {\n    toastWin.classList.remove('hide')\n  }, 0)\n}\n\nfunction hideToastWindow(callback) {\n  var handleTransitionEnd = function () {\n    toastWin.removeEventListener('transitionend', handleTransitionEnd)\n    callback && callback()\n  }\n  if (!toastWin) {\n    return\n  }\n  toastWin.addEventListener('transitionend', handleTransitionEnd)\n  toastWin.classList.add('hide')\n}\n\nvar toast = {\n\n  push: function (msg, duration) {\n    queue.push({\n      msg: msg,\n      duration: duration || DEFAULT_DURATION\n    })\n    this.show()\n  },\n\n  show: function () {\n    var that = this\n\n    // All messages had been toasted already, so remove the toast window,\n    if (!queue.length) {\n      toastWin && toastWin.parentNode.removeChild(toastWin)\n      toastWin = null\n      return\n    }\n\n    // the previous toast is not ended yet.\n    if (isProcessing) {\n      return\n    }\n    isProcessing = true\n\n    var toastInfo = queue.shift()\n    showToastWindow(toastInfo.msg, function () {\n      timer = setTimeout(function () {\n        timer = null\n        hideToastWindow(function () {\n          isProcessing = false\n          that.show()\n        })\n      }, toastInfo.duration * 1000)\n    })\n  }\n\n}\n\nmodule.exports = {\n  push: toast.push.bind(toast)\n}\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/modals/src/toast.js\n ** module id = 92\n ** module chunks = 0\n **/","// style-loader: Adds some css to the DOM by adding a <style> tag\n\n// load the styles\nvar content = require(\"!!./../../css-loader/index.js?sourceMap!./../../sass-loader/index.js?sourceMap!./toast.scss\");\nif(typeof content === 'string') content = [[module.id, content, '']];\n// add the styles to the DOM\nvar update = require(\"!./../../style-loader/addStyles.js\")(content, {});\nif(content.locals) module.exports = content.locals;\n// Hot Module Replacement\nif(module.hot) {\n\t// When the styles change, update the <style> tags\n\tif(!content.locals) {\n\t\tmodule.hot.accept(\"!!./../../css-loader/index.js?sourceMap!./../../sass-loader/index.js?sourceMap!./toast.scss\", function() {\n\t\t\tvar newContent = require(\"!!./../../css-loader/index.js?sourceMap!./../../sass-loader/index.js?sourceMap!./toast.scss\");\n\t\t\tif(typeof newContent === 'string') newContent = [[module.id, newContent, '']];\n\t\t\tupdate(newContent);\n\t\t});\n\t}\n\t// When the module is disposed, remove the <style> tags\n\tmodule.hot.dispose(function() { update(); });\n}\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/modals/styles/toast.scss\n ** module id = 93\n ** module chunks = 0\n **/","exports = module.exports = require(\"./../../css-loader/lib/css-base.js\")();\n// imports\n\n\n// module\nexports.push([module.id, \".amfe-toast {\\n  font-size: 0.32rem;\\n  line-height: 0.426667rem;\\n  position: fixed;\\n  box-sizing: border-box;\\n  max-width: 80%;\\n  bottom: 2.666667rem;\\n  left: 50%;\\n  padding: 0.213333rem;\\n  background-color: #000;\\n  color: #fff;\\n  text-align: center;\\n  opacity: 0.6;\\n  transition: all 0.4s ease-in-out;\\n  border-radius: 0.066667rem;\\n  -webkit-transform: translateX(-50%);\\n  transform: translateX(-50%); }\\n\\n.amfe-toast.hide {\\n  opacity: 0; }\\n\", \"\", {\"version\":3,\"sources\":[\"/./node_modules/modals/node_modules/modals/styles/toast.scss\"],\"names\":[],\"mappings\":\"AAAA;EACC,mBAAmB;EACnB,yBAAyB;EACzB,gBAAgB;EAChB,uBAAuB;EACvB,eAAe;EACf,oBAAoB;EACpB,UAAU;EACV,qBAAqB;EACrB,uBAAuB;EACvB,YAAY;EACZ,mBAAmB;EACnB,aAAa;EACb,iCAAiC;EACjC,2BAA2B;EAC3B,oCAA6B;EAC5B,4BAAqB,EACtB;;AAED;EACC,WAAW,EACX\",\"file\":\"toast.scss\",\"sourcesContent\":[\".amfe-toast {\\n\\tfont-size: 0.32rem; // 24px\\n\\tline-height: 0.426667rem; // 32px\\n\\tposition: fixed;\\n\\tbox-sizing: border-box;\\n\\tmax-width: 80%;\\n\\tbottom: 2.666667rem; // 200px\\n\\tleft: 50%;\\n\\tpadding: 0.213333rem; // 16px\\n\\tbackground-color: #000;\\n\\tcolor: #fff;\\n\\ttext-align: center;\\n\\topacity: 0.6;\\n\\ttransition: all 0.4s ease-in-out;\\n\\tborder-radius: 0.066667rem; // 5px\\n\\t-webkit-transform: translateX(-50%);\\n  transform: translateX(-50%);\\n}\\n\\n.amfe-toast.hide {\\n\\topacity: 0;\\n}\"],\"sourceRoot\":\"webpack://\"}]);\n\n// exports\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/css-loader?sourceMap!./~/sass-loader?sourceMap!./~/modals/styles/toast.scss\n ** module id = 94\n ** module chunks = 0\n **/","'use strict'\n\nvar Sender = require('../bridge/sender')\n\nvar _data = {}\n\nvar animation = {\n\n  /**\n   * transition\n   * @param  {string} ref        [description]\n   * @param  {obj} config     [description]\n   * @param  {string} callbackId [description]\n   */\n  transition: function (ref, config, callbackId) {\n    var refData = _data[ref]\n    var stylesKey = JSON.stringify(config.styles)\n    var weexInstance = this\n    // If the same component perform a animation with exactly the same\n    // styles in a sequence with so short interval that the prev animation\n    // is still in playing, then the next animation should be ignored.\n    if (refData && refData[stylesKey]) {\n      return\n    }\n    if (!refData) {\n      refData = _data[ref] = {}\n    }\n    refData[stylesKey] = true\n    return this.getComponentManager().transition(ref, config, function () {\n      // Remove the stylesKey in refData so that the same animation\n      // can be played again after current animation is already finished.\n      delete refData[stylesKey]\n      weexInstance.sender.performCallback(callbackId)\n    })\n  }\n\n}\n\nanimation._meta = {\n  animation: [{\n    name: 'transition',\n    args: ['string', 'object', 'string']\n  }]\n}\n\nmodule.exports = animation\n\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./src/api/animation.js\n ** module id = 95\n ** module chunks = 0\n **/","(typeof window === 'undefined') && (window = {ctrl: {}, lib: {}});!window.ctrl && (window.ctrl = {});!window.lib && (window.lib = {});!function(a,b){function c(a){Object.defineProperty(this,\"val\",{value:a.toString(),enumerable:!0}),this.gt=function(a){return c.compare(this,a)>0},this.gte=function(a){return c.compare(this,a)>=0},this.lt=function(a){return c.compare(this,a)<0},this.lte=function(a){return c.compare(this,a)<=0},this.eq=function(a){return 0===c.compare(this,a)}}b.env=b.env||{},c.prototype.toString=function(){return this.val},c.prototype.valueOf=function(){for(var a=this.val.split(\".\"),b=[],c=0;c<a.length;c++){var d=parseInt(a[c],10);isNaN(d)&&(d=0);var e=d.toString();e.length<5&&(e=Array(6-e.length).join(\"0\")+e),b.push(e),1===b.length&&b.push(\".\")}return parseFloat(b.join(\"\"))},c.compare=function(a,b){a=a.toString().split(\".\"),b=b.toString().split(\".\");for(var c=0;c<a.length||c<b.length;c++){var d=parseInt(a[c],10),e=parseInt(b[c],10);if(window.isNaN(d)&&(d=0),window.isNaN(e)&&(e=0),e>d)return-1;if(d>e)return 1}return 0},b.version=function(a){return new c(a)}}(window,window.lib||(window.lib={})),function(a,b){b.env=b.env||{};var c=a.location.search.replace(/^\\?/,\"\");if(b.env.params={},c)for(var d=c.split(\"&\"),e=0;e<d.length;e++){d[e]=d[e].split(\"=\");try{b.env.params[d[e][0]]=decodeURIComponent(d[e][1])}catch(f){b.env.params[d[e][0]]=d[e][1]}}}(window,window.lib||(window.lib={})),function(a,b){b.env=b.env||{};var c,d=a.navigator.userAgent;if(c=d.match(/Windows\\sPhone\\s(?:OS\\s)?([\\d\\.]+)/))b.env.os={name:\"Windows Phone\",isWindowsPhone:!0,version:c[1]};else if(d.match(/Safari/)&&(c=d.match(/Android[\\s\\/]([\\d\\.]+)/)))b.env.os={version:c[1]},d.match(/Mobile\\s+Safari/)?(b.env.os.name=\"Android\",b.env.os.isAndroid=!0):(b.env.os.name=\"AndroidPad\",b.env.os.isAndroidPad=!0);else if(c=d.match(/(iPhone|iPad|iPod)/)){var e=c[1];c=d.match(/OS ([\\d_\\.]+) like Mac OS X/),b.env.os={name:e,isIPhone:\"iPhone\"===e||\"iPod\"===e,isIPad:\"iPad\"===e,isIOS:!0,version:c[1].split(\"_\").join(\".\")}}else b.env.os={name:\"unknown\",version:\"0.0.0\"};b.version&&(b.env.os.version=b.version(b.env.os.version))}(window,window.lib||(window.lib={})),function(a,b){b.env=b.env||{};var c,d=a.navigator.userAgent;(c=d.match(/(?:UCWEB|UCBrowser\\/)([\\d\\.]+)/))?b.env.browser={name:\"UC\",isUC:!0,version:c[1]}:(c=d.match(/MQQBrowser\\/([\\d\\.]+)/))?b.env.browser={name:\"QQ\",isQQ:!0,version:c[1]}:(c=d.match(/Firefox\\/([\\d\\.]+)/))?b.env.browser={name:\"Firefox\",isFirefox:!0,version:c[1]}:(c=d.match(/MSIE\\s([\\d\\.]+)/))||(c=d.match(/IEMobile\\/([\\d\\.]+)/))?(b.env.browser={version:c[1]},d.match(/IEMobile/)?(b.env.browser.name=\"IEMobile\",b.env.browser.isIEMobile=!0):(b.env.browser.name=\"IE\",b.env.browser.isIE=!0),d.match(/Android|iPhone/)&&(b.env.browser.isIELikeWebkit=!0)):(c=d.match(/(?:Chrome|CriOS)\\/([\\d\\.]+)/))?(b.env.browser={name:\"Chrome\",isChrome:!0,version:c[1]},d.match(/Version\\/[\\d+\\.]+\\s*Chrome/)&&(b.env.browser.name=\"Chrome Webview\",b.env.browser.isWebview=!0)):d.match(/Safari/)&&(c=d.match(/Android[\\s\\/]([\\d\\.]+)/))?b.env.browser={name:\"Android\",isAndroid:!0,version:c[1]}:d.match(/iPhone|iPad|iPod/)?d.match(/Safari/)?(c=d.match(/Version\\/([\\d\\.]+)/),b.env.browser={name:\"Safari\",isSafari:!0,version:c[1]}):(c=d.match(/OS ([\\d_\\.]+) like Mac OS X/),b.env.browser={name:\"iOS Webview\",isWebview:!0,version:c[1].replace(/\\_/g,\".\")}):b.env.browser={name:\"unknown\",version:\"0.0.0\"},b.version&&(b.env.browser.version=b.version(b.env.browser.version))}(window,window.lib||(window.lib={})),function(a,b){b.env=b.env||{};var c=a.navigator.userAgent;c.match(/Weibo/i)?b.env.thirdapp={appname:\"Weibo\",isWeibo:!0}:c.match(/MicroMessenger/i)?b.env.thirdapp={appname:\"Weixin\",isWeixin:!0}:b.env.thirdapp=!1}(window,window.lib||(window.lib={})),function(a,b){b.env=b.env||{};var c,d,e=a.navigator.userAgent;(d=e.match(/WindVane[\\/\\s]([\\d\\.\\_]+)/))&&(c=d[1]);var f=!1,g=\"\",h=\"\",i=\"\";(d=e.match(/AliApp\\(([A-Z\\-]+)\\/([\\d\\.]+)\\)/i))&&(f=!0,g=d[1],i=d[2],h=g.indexOf(\"-PD\")>0?b.env.os.isIOS?\"iPad\":b.env.os.isAndroid?\"AndroidPad\":b.env.os.name:b.env.os.name),!g&&e.indexOf(\"TBIOS\")>0&&(g=\"TB\"),f?b.env.aliapp={windvane:b.version(c||\"0.0.0\"),appname:g||\"unkown\",version:b.version(i||\"0.0.0\"),platform:h||b.env.os.name}:b.env.aliapp=!1,b.env.taobaoApp=b.env.aliapp}(window,window.lib||(window.lib={}));;module.exports = window.lib['env'];\n\n\n/*****************\n ** WEBPACK FOOTER\n ** ./~/envd/build/envd.common.js\n ** module id = 96\n ** module chunks = 0\n **/"],"sourceRoot":""} |