aiber-martin/www/cordova.js.map
Martin Donnelly a4b8625d0f init
2020-12-17 16:23:12 +00:00

1 line
78 KiB
Plaintext

{"version":3,"sources":["platforms/ios/platform_www/cordova.js"],"names":[],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY;AACZ;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD;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;;AAEA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA,SAAS;AACT;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA,6DAA6D,2BAA2B;AACxF;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,SAAS;AACT;AACA;;AAEA;;AAEA,CAAC;;AAED;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,OAAO;AAClB;AACA,WAAW,gBAAgB;AAC3B,WAAW,SAAS;AACpB;AACA,YAAY,UAAU;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,iBAAiB;AACpC;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;AACA;AACA;;AAEA;AACA;AACA;;AAEA,CAAC;;AAED;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,4CAA4C,SAAS;AACrD;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,mBAAmB,QAAQ;AAC3B,uBAAuB,QAAQ;AAC/B;AACA;AACA;AACA,kCAAkC,kBAAkB;AACpD;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,mBAAmB,kBAAkB;AACrC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;;AAEA,CAAC;;AAED;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,CAAC;;AAED;AACA;;AAEA;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;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB,SAAS;AAChC;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA,8BAA8B;;AAE9B;AACA;AACA;AACA;AACA;AACA,uBAAuB,OAAO;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA,uBAAuB,OAAO;AAC9B;AACA;AACA;AACA;AACA;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;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;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,uBAAuB,mBAAmB;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,CAAC;;AAED;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA,2BAA2B,gBAAgB;AAC3C;AACA;AACA;AACA;AACA;AACA,kDAAkD;AAClD;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,SAAS;AACT,KAAK;AACL;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA,+EAA+E;AAC/E;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,oFAAoF;AACpF,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,CAAC;;AAED;AACA;;AAEA;AACA;;AAEA;;AAEA,0DAA0D,2EAA2E,IAAI;AACzI;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;;AAEA,CAAC;;AAED;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA,mBAAmB,gBAAgB;AACnC;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,CAAC;AACD;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,CAAC;;AAED;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,CAAC;;AAED,CAAC;;AAED;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,2CAA2C;AAC3C,KAAK;AACL;;AAEA;AACA;AACA;AACA,4CAA4C,SAAS;AACrD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,kBAAkB;AACrC;AACA;AACA;AACA;;AAEA;;AAEA,CAAC;;AAED;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,CAAC;;AAED;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,iCAAiC,EAAE;AAChD,aAAa,8BAA8B,EAAE;AAC7C;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,CAAC;;AAED;AACA;;AAEA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;;AAEA,CAAC;;AAED;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,eAAe,mBAAmB;AAClC;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC,+BAA+B;;AAEhE;AACA;AACA;AACA;AACA;AACA;AACA,mCAAmC,iCAAiC;;AAEpE;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,gCAAgC;;AAElE;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,gCAAgC;;AAElE;AACA;AACA;AACA;AACA;AACA;AACA,mCAAmC,iCAAiC;;AAEpE;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sCAAsC;AACtC;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,sDAAsD;AACtD,oEAAoE;AACpE,kEAAkE;AAClE,kEAAkE;AAClE,oEAAoE;AACpE;AACA;AACA;;AAEA;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;;AAEA,2CAA2C,wCAAwC;;AAEnF;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA,mBAAmB,mBAAmB;AACtC;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA,CAAC;;AAED;AACA;;AAEA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,CAAC;;AAED;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,SAAS;AACT;AACA;;AAEA;AACA;AACA,2BAA2B,0BAA0B;AACrD;AACA,2BAA2B,4BAA4B;AACvD;AACA;AACA;;AAEA;AACA,2BAA2B,0BAA0B;AACrD;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,mBAAmB,uBAAuB;AAC1C;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,oCAAoC,QAAQ;AAC5C,sDAAsD;AACtD;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA,CAAC;;AAED;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,CAAC;;AAED;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,mBAAmB,SAAS;AAC5B;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,8BAA8B,sCAAsC;;AAEpE;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,mBAAmB,gBAAgB;AACnC;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,mBAAmB,YAAY;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA,CAAC;;AAED;AACA;AACA;;AAEA,CAAC","file":"cordova.js","sourcesContent":["// Platform: ios\n// 538a985db128858c0a0eb4dd40fb9c8e5433fc94\n/*\n Licensed to the Apache Software Foundation (ASF) under one\n or more contributor license agreements. See the NOTICE file\n distributed with this work for additional information\n regarding copyright ownership. The ASF licenses this file\n to you under the Apache License, Version 2.0 (the\n \"License\"); you may not use this file except in compliance\n with the License. You may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\n Unless required by applicable law or agreed to in writing,\n software distributed under the License is distributed on an\n \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n KIND, either express or implied. See the License for the\n specific language governing permissions and limitations\n under the License.\n*/\n;(function() {\nvar PLATFORM_VERSION_BUILD_LABEL = '6.1.1';\n// file: src/scripts/require.js\nvar require;\nvar define;\n\n(function () {\n var modules = {};\n // Stack of moduleIds currently being built.\n var requireStack = [];\n // Map of module ID -> index into requireStack of modules currently being built.\n var inProgressModules = {};\n var SEPARATOR = '.';\n\n function build (module) {\n var factory = module.factory;\n var localRequire = function (id) {\n var resultantId = id;\n // Its a relative path, so lop off the last portion and add the id (minus \"./\")\n if (id.charAt(0) === '.') {\n resultantId = module.id.slice(0, module.id.lastIndexOf(SEPARATOR)) + SEPARATOR + id.slice(2);\n }\n return require(resultantId);\n };\n module.exports = {};\n delete module.factory;\n factory(localRequire, module.exports, module);\n return module.exports;\n }\n\n require = function (id) {\n if (!modules[id]) {\n throw new Error('module ' + id + ' not found');\n } else if (id in inProgressModules) {\n var cycle = requireStack.slice(inProgressModules[id]).join('->') + '->' + id;\n throw new Error('Cycle in require graph: ' + cycle);\n }\n if (modules[id].factory) {\n try {\n inProgressModules[id] = requireStack.length;\n requireStack.push(id);\n return build(modules[id]);\n } finally {\n delete inProgressModules[id];\n requireStack.pop();\n }\n }\n return modules[id].exports;\n };\n\n define = function (id, factory) {\n if (Object.prototype.hasOwnProperty.call(modules, id)) {\n throw new Error('module ' + id + ' already defined');\n }\n\n modules[id] = {\n id: id,\n factory: factory\n };\n };\n\n define.remove = function (id) {\n delete modules[id];\n };\n\n define.moduleMap = modules;\n})();\n\n// Export for use in node\nif (typeof module === 'object' && typeof require === 'function') {\n module.exports.require = require;\n module.exports.define = define;\n}\n\n// file: src/cordova.js\ndefine(\"cordova\", function(require, exports, module) {\n\n// Workaround for Windows 10 in hosted environment case\n// http://www.w3.org/html/wg/drafts/html/master/browsers.html#named-access-on-the-window-object\nif (window.cordova && !(window.cordova instanceof HTMLElement)) {\n throw new Error('cordova already defined');\n}\n\nvar channel = require('cordova/channel');\nvar platform = require('cordova/platform');\n\n/**\n * Intercept calls to addEventListener + removeEventListener and handle deviceready,\n * resume, and pause events.\n */\nvar m_document_addEventListener = document.addEventListener;\nvar m_document_removeEventListener = document.removeEventListener;\nvar m_window_addEventListener = window.addEventListener;\nvar m_window_removeEventListener = window.removeEventListener;\n\n/**\n * Houses custom event handlers to intercept on document + window event listeners.\n */\nvar documentEventHandlers = {};\nvar windowEventHandlers = {};\n\ndocument.addEventListener = function (evt, handler, capture) {\n var e = evt.toLowerCase();\n if (typeof documentEventHandlers[e] !== 'undefined') {\n documentEventHandlers[e].subscribe(handler);\n } else {\n m_document_addEventListener.call(document, evt, handler, capture);\n }\n};\n\nwindow.addEventListener = function (evt, handler, capture) {\n var e = evt.toLowerCase();\n if (typeof windowEventHandlers[e] !== 'undefined') {\n windowEventHandlers[e].subscribe(handler);\n } else {\n m_window_addEventListener.call(window, evt, handler, capture);\n }\n};\n\ndocument.removeEventListener = function (evt, handler, capture) {\n var e = evt.toLowerCase();\n // If unsubscribing from an event that is handled by a plugin\n if (typeof documentEventHandlers[e] !== 'undefined') {\n documentEventHandlers[e].unsubscribe(handler);\n } else {\n m_document_removeEventListener.call(document, evt, handler, capture);\n }\n};\n\nwindow.removeEventListener = function (evt, handler, capture) {\n var e = evt.toLowerCase();\n // If unsubscribing from an event that is handled by a plugin\n if (typeof windowEventHandlers[e] !== 'undefined') {\n windowEventHandlers[e].unsubscribe(handler);\n } else {\n m_window_removeEventListener.call(window, evt, handler, capture);\n }\n};\n\nfunction createEvent (type, data) {\n var event = document.createEvent('Events');\n event.initEvent(type, false, false);\n if (data) {\n for (var i in data) {\n if (Object.prototype.hasOwnProperty.call(data, i)) {\n event[i] = data[i];\n }\n }\n }\n return event;\n}\n\nvar cordova = {\n define: define,\n require: require,\n version: PLATFORM_VERSION_BUILD_LABEL,\n platformVersion: PLATFORM_VERSION_BUILD_LABEL,\n platformId: platform.id,\n\n /**\n * Methods to add/remove your own addEventListener hijacking on document + window.\n */\n addWindowEventHandler: function (event) {\n return (windowEventHandlers[event] = channel.create(event));\n },\n addStickyDocumentEventHandler: function (event) {\n return (documentEventHandlers[event] = channel.createSticky(event));\n },\n addDocumentEventHandler: function (event) {\n return (documentEventHandlers[event] = channel.create(event));\n },\n removeWindowEventHandler: function (event) {\n delete windowEventHandlers[event];\n },\n removeDocumentEventHandler: function (event) {\n delete documentEventHandlers[event];\n },\n\n /**\n * Retrieve original event handlers that were replaced by Cordova\n *\n * @return object\n */\n getOriginalHandlers: function () {\n return {\n document: {\n addEventListener: m_document_addEventListener,\n removeEventListener: m_document_removeEventListener\n },\n window: {\n addEventListener: m_window_addEventListener,\n removeEventListener: m_window_removeEventListener\n }\n };\n },\n\n /**\n * Method to fire event from native code\n * bNoDetach is required for events which cause an exception which needs to be caught in native code\n */\n fireDocumentEvent: function (type, data, bNoDetach) {\n var evt = createEvent(type, data);\n if (typeof documentEventHandlers[type] !== 'undefined') {\n if (bNoDetach) {\n documentEventHandlers[type].fire(evt);\n } else {\n setTimeout(function () {\n // Fire deviceready on listeners that were registered before cordova.js was loaded.\n if (type === 'deviceready') {\n document.dispatchEvent(evt);\n }\n documentEventHandlers[type].fire(evt);\n }, 0);\n }\n } else {\n document.dispatchEvent(evt);\n }\n },\n\n fireWindowEvent: function (type, data) {\n var evt = createEvent(type, data);\n if (typeof windowEventHandlers[type] !== 'undefined') {\n setTimeout(function () {\n windowEventHandlers[type].fire(evt);\n }, 0);\n } else {\n window.dispatchEvent(evt);\n }\n },\n\n /**\n * Plugin callback mechanism.\n */\n // Randomize the starting callbackId to avoid collisions after refreshing or navigating.\n // This way, it's very unlikely that any new callback would get the same callbackId as an old callback.\n callbackId: Math.floor(Math.random() * 2000000000),\n callbacks: {},\n callbackStatus: {\n NO_RESULT: 0,\n OK: 1,\n CLASS_NOT_FOUND_EXCEPTION: 2,\n ILLEGAL_ACCESS_EXCEPTION: 3,\n INSTANTIATION_EXCEPTION: 4,\n MALFORMED_URL_EXCEPTION: 5,\n IO_EXCEPTION: 6,\n INVALID_ACTION: 7,\n JSON_EXCEPTION: 8,\n ERROR: 9\n },\n\n /**\n * Called by native code when returning successful result from an action.\n */\n callbackSuccess: function (callbackId, args) {\n cordova.callbackFromNative(callbackId, true, args.status, [args.message], args.keepCallback);\n },\n\n /**\n * Called by native code when returning error result from an action.\n */\n callbackError: function (callbackId, args) {\n // TODO: Deprecate callbackSuccess and callbackError in favour of callbackFromNative.\n // Derive success from status.\n cordova.callbackFromNative(callbackId, false, args.status, [args.message], args.keepCallback);\n },\n\n /**\n * Called by native code when returning the result from an action.\n */\n callbackFromNative: function (callbackId, isSuccess, status, args, keepCallback) {\n try {\n var callback = cordova.callbacks[callbackId];\n if (callback) {\n if (isSuccess && status === cordova.callbackStatus.OK) {\n callback.success && callback.success.apply(null, args);\n } else if (!isSuccess) {\n callback.fail && callback.fail.apply(null, args);\n }\n /*\n else\n Note, this case is intentionally not caught.\n this can happen if isSuccess is true, but callbackStatus is NO_RESULT\n which is used to remove a callback from the list without calling the callbacks\n typically keepCallback is false in this case\n */\n // Clear callback if not expecting any more results\n if (!keepCallback) {\n delete cordova.callbacks[callbackId];\n }\n }\n } catch (err) {\n var msg = 'Error in ' + (isSuccess ? 'Success' : 'Error') + ' callbackId: ' + callbackId + ' : ' + err;\n cordova.fireWindowEvent('cordovacallbackerror', { message: msg, error: err });\n throw err;\n }\n },\n\n addConstructor: function (func) {\n channel.onCordovaReady.subscribe(function () {\n try {\n func();\n } catch (e) {\n console.log('Failed to run constructor: ' + e);\n }\n });\n }\n};\n\nmodule.exports = cordova;\n\n});\n\n// file: src/common/argscheck.js\ndefine(\"cordova/argscheck\", function(require, exports, module) {\n\nvar utils = require('cordova/utils');\n\nvar moduleExports = module.exports;\n\nvar typeMap = {\n A: 'Array',\n D: 'Date',\n N: 'Number',\n S: 'String',\n F: 'Function',\n O: 'Object'\n};\n\nfunction extractParamName (callee, argIndex) {\n return (/\\(\\s*([^)]*?)\\s*\\)/).exec(callee)[1].split(/\\s*,\\s*/)[argIndex];\n}\n\n/**\n * Checks the given arguments' types and throws if they are not as expected.\n *\n * `spec` is a string where each character stands for the required type of the\n * argument at the same position. In other words: the character at `spec[i]`\n * specifies the required type for `args[i]`. The characters in `spec` are the\n * first letter of the required type's name. The supported types are:\n *\n * Array, Date, Number, String, Function, Object\n *\n * Lowercase characters specify arguments that must not be `null` or `undefined`\n * while uppercase characters allow those values to be passed.\n *\n * Finally, `*` can be used to allow any type at the corresponding position.\n *\n * @example\n * function foo (arr, opts) {\n * // require `arr` to be an Array and `opts` an Object, null or undefined\n * checkArgs('aO', 'my.package.foo', arguments);\n * // ...\n * }\n * @param {String} spec - the type specification for `args` as described above\n * @param {String} functionName - full name of the callee.\n * Used in the error message\n * @param {Array|arguments} args - the arguments to be checked against `spec`\n * @param {Function} [opt_callee=args.callee] - the recipient of `args`.\n * Used to extract parameter names for the error message\n * @throws {TypeError} if args do not satisfy spec\n */\nfunction checkArgs (spec, functionName, args, opt_callee) {\n if (!moduleExports.enableChecks) {\n return;\n }\n var errMsg = null;\n var typeName;\n for (var i = 0; i < spec.length; ++i) {\n var c = spec.charAt(i);\n var cUpper = c.toUpperCase();\n var arg = args[i];\n // Asterix means allow anything.\n if (c === '*') {\n continue;\n }\n typeName = utils.typeName(arg);\n if ((arg === null || arg === undefined) && c === cUpper) {\n continue;\n }\n if (typeName !== typeMap[cUpper]) {\n errMsg = 'Expected ' + typeMap[cUpper];\n break;\n }\n }\n if (errMsg) {\n errMsg += ', but got ' + typeName + '.';\n errMsg = 'Wrong type for parameter \"' + extractParamName(opt_callee || args.callee, i) + '\" of ' + functionName + ': ' + errMsg;\n // Don't log when running unit tests.\n if (typeof jasmine === 'undefined') {\n console.error(errMsg);\n }\n throw TypeError(errMsg);\n }\n}\n\nfunction getValue (value, defaultValue) {\n return value === undefined ? defaultValue : value;\n}\n\nmoduleExports.checkArgs = checkArgs;\nmoduleExports.getValue = getValue;\nmoduleExports.enableChecks = true;\n\n});\n\n// file: src/common/base64.js\ndefine(\"cordova/base64\", function(require, exports, module) {\n\nvar base64 = exports;\n\nbase64.fromArrayBuffer = function (arrayBuffer) {\n var array = new Uint8Array(arrayBuffer);\n return uint8ToBase64(array);\n};\n\nbase64.toArrayBuffer = function (str) {\n var decodedStr = atob(str);\n var arrayBuffer = new ArrayBuffer(decodedStr.length);\n var array = new Uint8Array(arrayBuffer);\n for (var i = 0, len = decodedStr.length; i < len; i++) {\n array[i] = decodedStr.charCodeAt(i);\n }\n return arrayBuffer;\n};\n\n// ------------------------------------------------------------------------------\n\n/* This code is based on the performance tests at http://jsperf.com/b64tests\n * This 12-bit-at-a-time algorithm was the best performing version on all\n * platforms tested.\n */\n\nvar b64_6bit = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/';\nvar b64_12bit;\n\nvar b64_12bitTable = function () {\n b64_12bit = [];\n for (var i = 0; i < 64; i++) {\n for (var j = 0; j < 64; j++) {\n b64_12bit[i * 64 + j] = b64_6bit[i] + b64_6bit[j];\n }\n }\n b64_12bitTable = function () { return b64_12bit; };\n return b64_12bit;\n};\n\nfunction uint8ToBase64 (rawData) {\n var numBytes = rawData.byteLength;\n var output = '';\n var segment;\n var table = b64_12bitTable();\n for (var i = 0; i < numBytes - 2; i += 3) {\n segment = (rawData[i] << 16) + (rawData[i + 1] << 8) + rawData[i + 2];\n output += table[segment >> 12];\n output += table[segment & 0xfff];\n }\n if (numBytes - i === 2) {\n segment = (rawData[i] << 16) + (rawData[i + 1] << 8);\n output += table[segment >> 12];\n output += b64_6bit[(segment & 0xfff) >> 6];\n output += '=';\n } else if (numBytes - i === 1) {\n segment = (rawData[i] << 16);\n output += table[segment >> 12];\n output += '==';\n }\n return output;\n}\n\n});\n\n// file: src/common/builder.js\ndefine(\"cordova/builder\", function(require, exports, module) {\n\nvar utils = require('cordova/utils');\n\nfunction each (objects, func, context) {\n for (var prop in objects) {\n if (Object.prototype.hasOwnProperty.call(objects, prop)) {\n func.apply(context, [objects[prop], prop]);\n }\n }\n}\n\nfunction clobber (obj, key, value) {\n var needsProperty = false;\n try {\n obj[key] = value;\n } catch (e) {\n needsProperty = true;\n }\n // Getters can only be overridden by getters.\n if (needsProperty || obj[key] !== value) {\n utils.defineGetter(obj, key, function () {\n return value;\n });\n }\n}\n\nfunction assignOrWrapInDeprecateGetter (obj, key, value, message) {\n if (message) {\n utils.defineGetter(obj, key, function () {\n console.log(message);\n delete obj[key];\n clobber(obj, key, value);\n return value;\n });\n } else {\n clobber(obj, key, value);\n }\n}\n\nfunction include (parent, objects, clobber, merge) {\n each(objects, function (obj, key) {\n try {\n var result = obj.path ? require(obj.path) : {};\n\n if (clobber) {\n // Clobber if it doesn't exist.\n if (typeof parent[key] === 'undefined') {\n assignOrWrapInDeprecateGetter(parent, key, result, obj.deprecated);\n } else if (typeof obj.path !== 'undefined') {\n // If merging, merge properties onto parent, otherwise, clobber.\n if (merge) {\n recursiveMerge(parent[key], result);\n } else {\n assignOrWrapInDeprecateGetter(parent, key, result, obj.deprecated);\n }\n }\n result = parent[key];\n } else {\n // Overwrite if not currently defined.\n if (typeof parent[key] === 'undefined') {\n assignOrWrapInDeprecateGetter(parent, key, result, obj.deprecated);\n } else {\n // Set result to what already exists, so we can build children into it if they exist.\n result = parent[key];\n }\n }\n\n if (obj.children) {\n include(result, obj.children, clobber, merge);\n }\n } catch (e) {\n utils.alert('Exception building Cordova JS globals: ' + e + ' for key \"' + key + '\"');\n }\n });\n}\n\n/**\n * Merge properties from one object onto another recursively. Properties from\n * the src object will overwrite existing target property.\n *\n * @param target Object to merge properties into.\n * @param src Object to merge properties from.\n */\nfunction recursiveMerge (target, src) {\n for (var prop in src) {\n if (Object.prototype.hasOwnProperty.call(src, prop)) {\n if (target.prototype && target.prototype.constructor === target) {\n // If the target object is a constructor override off prototype.\n clobber(target.prototype, prop, src[prop]);\n } else {\n if (typeof src[prop] === 'object' && typeof target[prop] === 'object') {\n recursiveMerge(target[prop], src[prop]);\n } else {\n clobber(target, prop, src[prop]);\n }\n }\n }\n }\n}\n\nexports.buildIntoButDoNotClobber = function (objects, target) {\n include(target, objects, false, false);\n};\nexports.buildIntoAndClobber = function (objects, target) {\n include(target, objects, true, false);\n};\nexports.buildIntoAndMerge = function (objects, target) {\n include(target, objects, true, true);\n};\nexports.recursiveMerge = recursiveMerge;\nexports.assignOrWrapInDeprecateGetter = assignOrWrapInDeprecateGetter;\n\n});\n\n// file: src/common/channel.js\ndefine(\"cordova/channel\", function(require, exports, module) {\n\nvar utils = require('cordova/utils');\nvar nextGuid = 1;\n\n/**\n * Custom pub-sub \"channel\" that can have functions subscribed to it\n * This object is used to define and control firing of events for\n * cordova initialization, as well as for custom events thereafter.\n *\n * The order of events during page load and Cordova startup is as follows:\n *\n * onDOMContentLoaded* Internal event that is received when the web page is loaded and parsed.\n * onNativeReady* Internal event that indicates the Cordova native side is ready.\n * onCordovaReady* Internal event fired when all Cordova JavaScript objects have been created.\n * onDeviceReady* User event fired to indicate that Cordova is ready\n * onResume User event fired to indicate a start/resume lifecycle event\n * onPause User event fired to indicate a pause lifecycle event\n *\n * The events marked with an * are sticky. Once they have fired, they will stay in the fired state.\n * All listeners that subscribe after the event is fired will be executed right away.\n *\n * The only Cordova events that user code should register for are:\n * deviceready Cordova native code is initialized and Cordova APIs can be called from JavaScript\n * pause App has moved to background\n * resume App has returned to foreground\n *\n * Listeners can be registered as:\n * document.addEventListener(\"deviceready\", myDeviceReadyListener, false);\n * document.addEventListener(\"resume\", myResumeListener, false);\n * document.addEventListener(\"pause\", myPauseListener, false);\n *\n * The DOM lifecycle events should be used for saving and restoring state\n * window.onload\n * window.onunload\n *\n */\n\n/**\n * Channel\n * @constructor\n * @param type String the channel name\n */\nvar Channel = function (type, sticky) {\n this.type = type;\n // Map of guid -> function.\n this.handlers = {};\n // 0 = Non-sticky, 1 = Sticky non-fired, 2 = Sticky fired.\n this.state = sticky ? 1 : 0;\n // Used in sticky mode to remember args passed to fire().\n this.fireArgs = null;\n // Used by onHasSubscribersChange to know if there are any listeners.\n this.numHandlers = 0;\n // Function that is called when the first listener is subscribed, or when\n // the last listener is unsubscribed.\n this.onHasSubscribersChange = null;\n};\nvar channel = {\n /**\n * Calls the provided function only after all of the channels specified\n * have been fired. All channels must be sticky channels.\n */\n join: function (h, c) {\n var len = c.length;\n var i = len;\n var f = function () {\n if (!(--i)) h();\n };\n for (var j = 0; j < len; j++) {\n if (c[j].state === 0) {\n throw Error('Can only use join with sticky channels.');\n }\n c[j].subscribe(f);\n }\n if (!len) h();\n },\n\n create: function (type) {\n return (channel[type] = new Channel(type, false));\n },\n createSticky: function (type) {\n return (channel[type] = new Channel(type, true));\n },\n\n /**\n * cordova Channels that must fire before \"deviceready\" is fired.\n */\n deviceReadyChannelsArray: [],\n deviceReadyChannelsMap: {},\n\n /**\n * Indicate that a feature needs to be initialized before it is ready to be used.\n * This holds up Cordova's \"deviceready\" event until the feature has been initialized\n * and Cordova.initComplete(feature) is called.\n *\n * @param feature {String} The unique feature name\n */\n waitForInitialization: function (feature) {\n if (feature) {\n var c = channel[feature] || this.createSticky(feature);\n this.deviceReadyChannelsMap[feature] = c;\n this.deviceReadyChannelsArray.push(c);\n }\n },\n\n /**\n * Indicate that initialization code has completed and the feature is ready to be used.\n *\n * @param feature {String} The unique feature name\n */\n initializationComplete: function (feature) {\n var c = this.deviceReadyChannelsMap[feature];\n if (c) {\n c.fire();\n }\n }\n};\n\nfunction checkSubscriptionArgument (argument) {\n if (typeof argument !== 'function' && typeof argument.handleEvent !== 'function') {\n throw new Error(\n 'Must provide a function or an EventListener object ' +\n 'implementing the handleEvent interface.'\n );\n }\n}\n\n/**\n * Subscribes the given function to the channel. Any time that\n * Channel.fire is called so too will the function.\n * Optionally specify an execution context for the function\n * and a guid that can be used to stop subscribing to the channel.\n * Returns the guid.\n */\nChannel.prototype.subscribe = function (eventListenerOrFunction, eventListener) {\n checkSubscriptionArgument(eventListenerOrFunction);\n var handleEvent, guid;\n\n if (eventListenerOrFunction && typeof eventListenerOrFunction === 'object') {\n // Received an EventListener object implementing the handleEvent interface\n handleEvent = eventListenerOrFunction.handleEvent;\n eventListener = eventListenerOrFunction;\n } else {\n // Received a function to handle event\n handleEvent = eventListenerOrFunction;\n }\n\n if (this.state === 2) {\n handleEvent.apply(eventListener || this, this.fireArgs);\n return;\n }\n\n guid = eventListenerOrFunction.observer_guid;\n if (typeof eventListener === 'object') {\n handleEvent = utils.close(eventListener, handleEvent);\n }\n\n if (!guid) {\n // First time any channel has seen this subscriber\n guid = '' + nextGuid++;\n }\n handleEvent.observer_guid = guid;\n eventListenerOrFunction.observer_guid = guid;\n\n // Don't add the same handler more than once.\n if (!this.handlers[guid]) {\n this.handlers[guid] = handleEvent;\n this.numHandlers++;\n if (this.numHandlers === 1) {\n this.onHasSubscribersChange && this.onHasSubscribersChange();\n }\n }\n};\n\n/**\n * Unsubscribes the function with the given guid from the channel.\n */\nChannel.prototype.unsubscribe = function (eventListenerOrFunction) {\n checkSubscriptionArgument(eventListenerOrFunction);\n var handleEvent, guid, handler;\n\n if (eventListenerOrFunction && typeof eventListenerOrFunction === 'object') {\n // Received an EventListener object implementing the handleEvent interface\n handleEvent = eventListenerOrFunction.handleEvent;\n } else {\n // Received a function to handle event\n handleEvent = eventListenerOrFunction;\n }\n\n guid = handleEvent.observer_guid;\n handler = this.handlers[guid];\n if (handler) {\n delete this.handlers[guid];\n this.numHandlers--;\n if (this.numHandlers === 0) {\n this.onHasSubscribersChange && this.onHasSubscribersChange();\n }\n }\n};\n\n/**\n * Calls all functions subscribed to this channel.\n */\nChannel.prototype.fire = function (e) {\n var fireArgs = Array.prototype.slice.call(arguments);\n // Apply stickiness.\n if (this.state === 1) {\n this.state = 2;\n this.fireArgs = fireArgs;\n }\n if (this.numHandlers) {\n // Copy the values first so that it is safe to modify it from within\n // callbacks.\n var toCall = [];\n for (var item in this.handlers) {\n toCall.push(this.handlers[item]);\n }\n for (var i = 0; i < toCall.length; ++i) {\n toCall[i].apply(this, fireArgs);\n }\n if (this.state === 2 && this.numHandlers) {\n this.numHandlers = 0;\n this.handlers = {};\n this.onHasSubscribersChange && this.onHasSubscribersChange();\n }\n }\n};\n\n// defining them here so they are ready super fast!\n// DOM event that is received when the web page is loaded and parsed.\nchannel.createSticky('onDOMContentLoaded');\n\n// Event to indicate the Cordova native side is ready.\nchannel.createSticky('onNativeReady');\n\n// Event to indicate that all Cordova JavaScript objects have been created\n// and it's time to run plugin constructors.\nchannel.createSticky('onCordovaReady');\n\n// Event to indicate that all automatically loaded JS plugins are loaded and ready.\n// FIXME remove this\nchannel.createSticky('onPluginsReady');\n\n// Event to indicate that Cordova is ready\nchannel.createSticky('onDeviceReady');\n\n// Event to indicate a resume lifecycle event\nchannel.create('onResume');\n\n// Event to indicate a pause lifecycle event\nchannel.create('onPause');\n\n// Channels that must fire before \"deviceready\" is fired.\nchannel.waitForInitialization('onCordovaReady');\nchannel.waitForInitialization('onDOMContentLoaded');\n\nmodule.exports = channel;\n\n});\n\n// file: ../cordova-ios/cordova-js-src/exec.js\ndefine(\"cordova/exec\", function(require, exports, module) {\n\n/**\n * Creates the exec bridge used to notify the native code of\n * commands.\n */\nvar cordova = require('cordova');\nvar utils = require('cordova/utils');\nvar base64 = require('cordova/base64');\n\nfunction massageArgsJsToNative (args) {\n if (!args || utils.typeName(args) !== 'Array') {\n return args;\n }\n var ret = [];\n args.forEach(function (arg, i) {\n if (utils.typeName(arg) === 'ArrayBuffer') {\n ret.push({\n CDVType: 'ArrayBuffer',\n data: base64.fromArrayBuffer(arg)\n });\n } else {\n ret.push(arg);\n }\n });\n return ret;\n}\n\nfunction massageMessageNativeToJs (message) {\n if (message.CDVType === 'ArrayBuffer') {\n var stringToArrayBuffer = function (str) {\n var ret = new Uint8Array(str.length);\n for (var i = 0; i < str.length; i++) {\n ret[i] = str.charCodeAt(i);\n }\n return ret.buffer;\n };\n var base64ToArrayBuffer = function (b64) {\n return stringToArrayBuffer(atob(b64)); // eslint-disable-line no-undef\n };\n message = base64ToArrayBuffer(message.data);\n }\n return message;\n}\n\nfunction convertMessageToArgsNativeToJs (message) {\n var args = [];\n if (!message || !Object.prototype.hasOwnProperty.call(message, 'CDVType')) {\n args.push(message);\n } else if (message.CDVType === 'MultiPart') {\n message.messages.forEach(function (e) {\n args.push(massageMessageNativeToJs(e));\n });\n } else {\n args.push(massageMessageNativeToJs(message));\n }\n return args;\n}\n\nvar iOSExec = function () {\n var successCallback, failCallback, service, action, actionArgs;\n var callbackId = null;\n if (typeof arguments[0] !== 'string') {\n // FORMAT ONE\n successCallback = arguments[0];\n failCallback = arguments[1];\n service = arguments[2];\n action = arguments[3];\n actionArgs = arguments[4];\n\n // Since we need to maintain backwards compatibility, we have to pass\n // an invalid callbackId even if no callback was provided since plugins\n // will be expecting it. The Cordova.exec() implementation allocates\n // an invalid callbackId and passes it even if no callbacks were given.\n callbackId = 'INVALID';\n } else {\n \t throw new Error('The old format of this exec call has been removed (deprecated since 2.1). Change to: ' + // eslint-disable-line\n 'cordova.exec(null, null, \\'Service\\', \\'action\\', [ arg1, arg2 ]);');\n }\n\n // If actionArgs is not provided, default to an empty array\n actionArgs = actionArgs || [];\n\n // Register the callbacks and add the callbackId to the positional\n // arguments if given.\n if (successCallback || failCallback) {\n callbackId = service + cordova.callbackId++;\n cordova.callbacks[callbackId] =\n { success: successCallback, fail: failCallback };\n }\n\n actionArgs = massageArgsJsToNative(actionArgs);\n\n // CB-10133 DataClone DOM Exception 25 guard (fast function remover)\n var command = [callbackId, service, action, JSON.parse(JSON.stringify(actionArgs))];\n window.webkit.messageHandlers.cordova.postMessage(command);\n};\n\niOSExec.nativeCallback = function (callbackId, status, message, keepCallback, debug) {\n var success = status === 0 || status === 1;\n var args = convertMessageToArgsNativeToJs(message);\n Promise.resolve().then(function () {\n cordova.callbackFromNative(callbackId, success, status, args, keepCallback); // eslint-disable-line\n });\n};\n\n// for backwards compatibility\niOSExec.nativeEvalAndFetch = function (func) {\n try {\n func();\n } catch (e) {\n console.log(e);\n }\n};\n\n// Proxy the exec for bridge changes. See CB-10106\n\nfunction cordovaExec () {\n var cexec = require('cordova/exec');\n var cexec_valid = (typeof cexec.nativeFetchMessages === 'function') && (typeof cexec.nativeEvalAndFetch === 'function') && (typeof cexec.nativeCallback === 'function');\n return (cexec_valid && execProxy !== cexec) ? cexec : iOSExec;\n}\n\nfunction execProxy () {\n cordovaExec().apply(null, arguments);\n}\n\nexecProxy.nativeFetchMessages = function () {\n return cordovaExec().nativeFetchMessages.apply(null, arguments);\n};\n\nexecProxy.nativeEvalAndFetch = function () {\n return cordovaExec().nativeEvalAndFetch.apply(null, arguments);\n};\n\nexecProxy.nativeCallback = function () {\n return cordovaExec().nativeCallback.apply(null, arguments);\n};\n\nmodule.exports = execProxy;\n\n});\n\n// file: src/common/exec/proxy.js\ndefine(\"cordova/exec/proxy\", function(require, exports, module) {\n\n// internal map of proxy function\nvar CommandProxyMap = {};\n\nmodule.exports = {\n\n // example: cordova.commandProxy.add(\"Accelerometer\",{getCurrentAcceleration: function(successCallback, errorCallback, options) {...},...);\n add: function (id, proxyObj) {\n console.log('adding proxy for ' + id);\n CommandProxyMap[id] = proxyObj;\n return proxyObj;\n },\n\n // cordova.commandProxy.remove(\"Accelerometer\");\n remove: function (id) {\n var proxy = CommandProxyMap[id];\n delete CommandProxyMap[id];\n CommandProxyMap[id] = null;\n return proxy;\n },\n\n get: function (service, action) {\n return (CommandProxyMap[service] ? CommandProxyMap[service][action] : null);\n }\n};\n\n});\n\n// file: src/common/init.js\ndefine(\"cordova/init\", function(require, exports, module) {\n\nvar channel = require('cordova/channel');\nvar cordova = require('cordova');\nvar modulemapper = require('cordova/modulemapper');\nvar platform = require('cordova/platform');\nvar pluginloader = require('cordova/pluginloader');\n\nvar platformInitChannelsArray = [channel.onNativeReady, channel.onPluginsReady];\n\nfunction logUnfiredChannels (arr) {\n for (var i = 0; i < arr.length; ++i) {\n if (arr[i].state !== 2) {\n console.log('Channel not fired: ' + arr[i].type);\n }\n }\n}\n\nwindow.setTimeout(function () {\n if (channel.onDeviceReady.state !== 2) {\n console.log('deviceready has not fired after 5 seconds.');\n logUnfiredChannels(platformInitChannelsArray);\n logUnfiredChannels(channel.deviceReadyChannelsArray);\n }\n}, 5000);\n\nif (!window.console) {\n window.console = {\n log: function () {}\n };\n}\nif (!window.console.warn) {\n window.console.warn = function (msg) {\n this.log('warn: ' + msg);\n };\n}\n\n// Register pause, resume and deviceready channels as events on document.\nchannel.onPause = cordova.addDocumentEventHandler('pause');\nchannel.onResume = cordova.addDocumentEventHandler('resume');\nchannel.onActivated = cordova.addDocumentEventHandler('activated');\nchannel.onDeviceReady = cordova.addStickyDocumentEventHandler('deviceready');\n\n// Listen for DOMContentLoaded and notify our channel subscribers.\nif (document.readyState === 'complete' || document.readyState === 'interactive') {\n channel.onDOMContentLoaded.fire();\n} else {\n document.addEventListener('DOMContentLoaded', function () {\n channel.onDOMContentLoaded.fire();\n }, false);\n}\n\n// _nativeReady is global variable that the native side can set\n// to signify that the native code is ready. It is a global since\n// it may be called before any cordova JS is ready.\nif (window._nativeReady) {\n channel.onNativeReady.fire();\n}\n\nmodulemapper.clobbers('cordova', 'cordova');\nmodulemapper.clobbers('cordova/exec', 'cordova.exec');\nmodulemapper.clobbers('cordova/exec', 'Cordova.exec');\n\n// Call the platform-specific initialization.\nplatform.bootstrap && platform.bootstrap();\n\n// Wrap in a setTimeout to support the use-case of having plugin JS appended to cordova.js.\n// The delay allows the attached modules to be defined before the plugin loader looks for them.\nsetTimeout(function () {\n pluginloader.load(function () {\n channel.onPluginsReady.fire();\n });\n}, 0);\n\n/**\n * Create all cordova objects once native side is ready.\n */\nchannel.join(function () {\n modulemapper.mapModules(window);\n\n platform.initialize && platform.initialize();\n\n // Fire event to notify that all objects are created\n channel.onCordovaReady.fire();\n\n // Fire onDeviceReady event once page has fully loaded, all\n // constructors have run and cordova info has been received from native\n // side.\n channel.join(function () {\n require('cordova').fireDocumentEvent('deviceready');\n }, channel.deviceReadyChannelsArray);\n}, platformInitChannelsArray);\n\n});\n\n// file: src/common/modulemapper.js\ndefine(\"cordova/modulemapper\", function(require, exports, module) {\n\nvar builder = require('cordova/builder');\nvar moduleMap = define.moduleMap;\nvar symbolList;\nvar deprecationMap;\n\nexports.reset = function () {\n symbolList = [];\n deprecationMap = {};\n};\n\nfunction addEntry (strategy, moduleName, symbolPath, opt_deprecationMessage) {\n if (!(moduleName in moduleMap)) {\n throw new Error('Module ' + moduleName + ' does not exist.');\n }\n symbolList.push(strategy, moduleName, symbolPath);\n if (opt_deprecationMessage) {\n deprecationMap[symbolPath] = opt_deprecationMessage;\n }\n}\n\n// Note: Android 2.3 does have Function.bind().\nexports.clobbers = function (moduleName, symbolPath, opt_deprecationMessage) {\n addEntry('c', moduleName, symbolPath, opt_deprecationMessage);\n};\n\nexports.merges = function (moduleName, symbolPath, opt_deprecationMessage) {\n addEntry('m', moduleName, symbolPath, opt_deprecationMessage);\n};\n\nexports.defaults = function (moduleName, symbolPath, opt_deprecationMessage) {\n addEntry('d', moduleName, symbolPath, opt_deprecationMessage);\n};\n\nexports.runs = function (moduleName) {\n addEntry('r', moduleName, null);\n};\n\nfunction prepareNamespace (symbolPath, context) {\n if (!symbolPath) {\n return context;\n }\n return symbolPath.split('.').reduce(function (cur, part) {\n return (cur[part] = cur[part] || {});\n }, context);\n}\n\nexports.mapModules = function (context) {\n var origSymbols = {};\n context.CDV_origSymbols = origSymbols;\n for (var i = 0, len = symbolList.length; i < len; i += 3) {\n var strategy = symbolList[i];\n var moduleName = symbolList[i + 1];\n var module = require(moduleName);\n // <runs/>\n if (strategy === 'r') {\n continue;\n }\n var symbolPath = symbolList[i + 2];\n var lastDot = symbolPath.lastIndexOf('.');\n var namespace = symbolPath.substr(0, lastDot);\n var lastName = symbolPath.substr(lastDot + 1);\n\n var deprecationMsg = symbolPath in deprecationMap ? 'Access made to deprecated symbol: ' + symbolPath + '. ' + deprecationMsg : null;\n var parentObj = prepareNamespace(namespace, context);\n var target = parentObj[lastName];\n\n if (strategy === 'm' && target) {\n builder.recursiveMerge(target, module);\n } else if ((strategy === 'd' && !target) || (strategy !== 'd')) {\n if (!(symbolPath in origSymbols)) {\n origSymbols[symbolPath] = target;\n }\n builder.assignOrWrapInDeprecateGetter(parentObj, lastName, module, deprecationMsg);\n }\n }\n};\n\nexports.getOriginalSymbol = function (context, symbolPath) {\n var origSymbols = context.CDV_origSymbols;\n if (origSymbols && (symbolPath in origSymbols)) {\n return origSymbols[symbolPath];\n }\n var parts = symbolPath.split('.');\n var obj = context;\n for (var i = 0; i < parts.length; ++i) {\n obj = obj && obj[parts[i]];\n }\n return obj;\n};\n\nexports.reset();\n\n});\n\n// file: ../cordova-ios/cordova-js-src/platform.js\ndefine(\"cordova/platform\", function(require, exports, module) {\n\nmodule.exports = {\n id: 'ios',\n bootstrap: function () {\n // Attach the console polyfill that is iOS-only to window.console\n // see the file under plugin/ios/console.js\n require('cordova/modulemapper').clobbers('cordova/plugin/ios/console', 'window.console');\n\n // Attach the wkwebkit utility to window.WkWebView\n // see the file under plugin/ios/wkwebkit.js\n require('cordova/modulemapper').clobbers('cordova/plugin/ios/wkwebkit', 'window.WkWebView');\n\n // Attach the splashscreen utility to window.navigator.splashscreen\n // see the file under plugin/ios/launchscreen.js\n require('cordova/modulemapper').clobbers('cordova/plugin/ios/launchscreen', 'navigator.splashscreen');\n\n require('cordova/channel').onNativeReady.fire();\n }\n};\n\n});\n\n// file: ../cordova-ios/cordova-js-src/plugin/ios/console.js\ndefine(\"cordova/plugin/ios/console\", function(require, exports, module) {\n\n// ------------------------------------------------------------------------------\n\nvar logger = require('cordova/plugin/ios/logger');\n\n// ------------------------------------------------------------------------------\n// object that we're exporting\n// ------------------------------------------------------------------------------\nvar console = module.exports;\n\n// ------------------------------------------------------------------------------\n// copy of the original console object\n// ------------------------------------------------------------------------------\nvar WinConsole = window.console;\n\n// ------------------------------------------------------------------------------\n// whether to use the logger\n// ------------------------------------------------------------------------------\nvar UseLogger = false;\n\n// ------------------------------------------------------------------------------\n// Timers\n// ------------------------------------------------------------------------------\nvar Timers = {};\n\n// ------------------------------------------------------------------------------\n// used for unimplemented methods\n// ------------------------------------------------------------------------------\nfunction noop () {}\n\n// ------------------------------------------------------------------------------\n// used for unimplemented methods\n// ------------------------------------------------------------------------------\nconsole.useLogger = function (value) {\n if (arguments.length) UseLogger = !!value;\n\n if (UseLogger) {\n if (logger.useConsole()) {\n throw new Error('console and logger are too intertwingly');\n }\n }\n\n return UseLogger;\n};\n\n// ------------------------------------------------------------------------------\nconsole.log = function () {\n if (logger.useConsole()) return;\n logger.log.apply(logger, [].slice.call(arguments));\n};\n\n// ------------------------------------------------------------------------------\nconsole.error = function () {\n if (logger.useConsole()) return;\n logger.error.apply(logger, [].slice.call(arguments));\n};\n\n// ------------------------------------------------------------------------------\nconsole.warn = function () {\n if (logger.useConsole()) return;\n logger.warn.apply(logger, [].slice.call(arguments));\n};\n\n// ------------------------------------------------------------------------------\nconsole.info = function () {\n if (logger.useConsole()) return;\n logger.info.apply(logger, [].slice.call(arguments));\n};\n\n// ------------------------------------------------------------------------------\nconsole.debug = function () {\n if (logger.useConsole()) return;\n logger.debug.apply(logger, [].slice.call(arguments));\n};\n\n// ------------------------------------------------------------------------------\nconsole.assert = function (expression) {\n if (expression) return;\n\n var message = logger.format.apply(logger.format, [].slice.call(arguments, 1));\n console.log('ASSERT: ' + message);\n};\n\n// ------------------------------------------------------------------------------\nconsole.clear = function () {};\n\n// ------------------------------------------------------------------------------\nconsole.dir = function (object) {\n console.log('%o', object);\n};\n\n// ------------------------------------------------------------------------------\nconsole.dirxml = function (node) {\n console.log(node.innerHTML);\n};\n\n// ------------------------------------------------------------------------------\nconsole.trace = noop;\n\n// ------------------------------------------------------------------------------\nconsole.group = console.log;\n\n// ------------------------------------------------------------------------------\nconsole.groupCollapsed = console.log;\n\n// ------------------------------------------------------------------------------\nconsole.groupEnd = noop;\n\n// ------------------------------------------------------------------------------\nconsole.time = function (name) {\n Timers[name] = new Date().valueOf();\n};\n\n// ------------------------------------------------------------------------------\nconsole.timeEnd = function (name) {\n var timeStart = Timers[name];\n if (!timeStart) {\n console.warn('unknown timer: ' + name);\n return;\n }\n\n var timeElapsed = new Date().valueOf() - timeStart;\n console.log(name + ': ' + timeElapsed + 'ms');\n};\n\n// ------------------------------------------------------------------------------\nconsole.timeStamp = noop;\n\n// ------------------------------------------------------------------------------\nconsole.profile = noop;\n\n// ------------------------------------------------------------------------------\nconsole.profileEnd = noop;\n\n// ------------------------------------------------------------------------------\nconsole.count = noop;\n\n// ------------------------------------------------------------------------------\nconsole.exception = console.log;\n\n// ------------------------------------------------------------------------------\nconsole.table = function (data, columns) {\n console.log('%o', data);\n};\n\n// ------------------------------------------------------------------------------\n// return a new function that calls both functions passed as args\n// ------------------------------------------------------------------------------\nfunction wrappedOrigCall (orgFunc, newFunc) {\n return function () {\n var args = [].slice.call(arguments);\n try { orgFunc.apply(WinConsole, args); } catch (e) {}\n try { newFunc.apply(console, args); } catch (e) {}\n };\n}\n\n// ------------------------------------------------------------------------------\n// For every function that exists in the original console object, that\n// also exists in the new console object, wrap the new console method\n// with one that calls both\n// ------------------------------------------------------------------------------\nfor (var key in console) {\n if (typeof WinConsole[key] === 'function') {\n console[key] = wrappedOrigCall(WinConsole[key], console[key]);\n }\n}\n\n});\n\n// file: ../cordova-ios/cordova-js-src/plugin/ios/launchscreen.js\ndefine(\"cordova/plugin/ios/launchscreen\", function(require, exports, module) {\n\nvar exec = require('cordova/exec');\n\nvar launchscreen = {\n show: function () {\n exec(null, null, 'LaunchScreen', 'show', []);\n },\n hide: function () {\n exec(null, null, 'LaunchScreen', 'hide', []);\n }\n};\n\nmodule.exports = launchscreen;\n\n});\n\n// file: ../cordova-ios/cordova-js-src/plugin/ios/logger.js\ndefine(\"cordova/plugin/ios/logger\", function(require, exports, module) {\n\n// ------------------------------------------------------------------------------\n// The logger module exports the following properties/functions:\n//\n// LOG - constant for the level LOG\n// ERROR - constant for the level ERROR\n// WARN - constant for the level WARN\n// INFO - constant for the level INFO\n// DEBUG - constant for the level DEBUG\n// logLevel() - returns current log level\n// logLevel(value) - sets and returns a new log level\n// useConsole() - returns whether logger is using console\n// useConsole(value) - sets and returns whether logger is using console\n// log(message,...) - logs a message at level LOG\n// error(message,...) - logs a message at level ERROR\n// warn(message,...) - logs a message at level WARN\n// info(message,...) - logs a message at level INFO\n// debug(message,...) - logs a message at level DEBUG\n// logLevel(level,message,...) - logs a message specified level\n//\n// ------------------------------------------------------------------------------\n\nvar logger = exports;\n\nvar exec = require('cordova/exec');\n\nvar UseConsole = false;\nvar UseLogger = true;\nvar Queued = [];\nvar DeviceReady = false;\nvar CurrentLevel;\n\nvar originalConsole = console;\n\n/**\n * Logging levels\n */\n\nvar Levels = [\n 'LOG',\n 'ERROR',\n 'WARN',\n 'INFO',\n 'DEBUG'\n];\n\n/*\n * add the logging levels to the logger object and\n * to a separate levelsMap object for testing\n */\n\nvar LevelsMap = {};\nfor (var i = 0; i < Levels.length; i++) {\n var level = Levels[i];\n LevelsMap[level] = i;\n logger[level] = level;\n}\n\nCurrentLevel = LevelsMap.WARN;\n\n/**\n * Getter/Setter for the logging level\n *\n * Returns the current logging level.\n *\n * When a value is passed, sets the logging level to that value.\n * The values should be one of the following constants:\n * logger.LOG\n * logger.ERROR\n * logger.WARN\n * logger.INFO\n * logger.DEBUG\n *\n * The value used determines which messages get printed. The logging\n * values above are in order, and only messages logged at the logging\n * level or above will actually be displayed to the user. E.g., the\n * default level is WARN, so only messages logged with LOG, ERROR, or\n * WARN will be displayed; INFO and DEBUG messages will be ignored.\n */\nlogger.level = function (value) {\n if (arguments.length) {\n if (LevelsMap[value] === null) {\n throw new Error('invalid logging level: ' + value);\n }\n CurrentLevel = LevelsMap[value];\n }\n\n return Levels[CurrentLevel];\n};\n\n/**\n * Getter/Setter for the useConsole functionality\n *\n * When useConsole is true, the logger will log via the\n * browser 'console' object.\n */\nlogger.useConsole = function (value) {\n if (arguments.length) UseConsole = !!value;\n\n if (UseConsole) {\n if (typeof console === 'undefined') {\n throw new Error('global console object is not defined');\n }\n\n if (typeof console.log !== 'function') {\n throw new Error('global console object does not have a log function');\n }\n\n if (typeof console.useLogger === 'function') {\n if (console.useLogger()) {\n throw new Error('console and logger are too intertwingly');\n }\n }\n }\n\n return UseConsole;\n};\n\n/**\n * Getter/Setter for the useLogger functionality\n *\n * When useLogger is true, the logger will log via the\n * native Logger plugin.\n */\nlogger.useLogger = function (value) {\n // Enforce boolean\n if (arguments.length) UseLogger = !!value;\n return UseLogger;\n};\n\n/**\n * Logs a message at the LOG level.\n *\n * Parameters passed after message are used applied to\n * the message with utils.format()\n */\nlogger.log = function (message) { logWithArgs('LOG', arguments); };\n\n/**\n * Logs a message at the ERROR level.\n *\n * Parameters passed after message are used applied to\n * the message with utils.format()\n */\nlogger.error = function (message) { logWithArgs('ERROR', arguments); };\n\n/**\n * Logs a message at the WARN level.\n *\n * Parameters passed after message are used applied to\n * the message with utils.format()\n */\nlogger.warn = function (message) { logWithArgs('WARN', arguments); };\n\n/**\n * Logs a message at the INFO level.\n *\n * Parameters passed after message are used applied to\n * the message with utils.format()\n */\nlogger.info = function (message) { logWithArgs('INFO', arguments); };\n\n/**\n * Logs a message at the DEBUG level.\n *\n * Parameters passed after message are used applied to\n * the message with utils.format()\n */\nlogger.debug = function (message) { logWithArgs('DEBUG', arguments); };\n\n// log at the specified level with args\nfunction logWithArgs (level, args) {\n args = [level].concat([].slice.call(args));\n logger.logLevel.apply(logger, args);\n}\n\n// return the correct formatString for an object\nfunction formatStringForMessage (message) {\n return (typeof message === 'string') ? '' : '%o';\n}\n\n/**\n * Logs a message at the specified level.\n *\n * Parameters passed after message are used applied to\n * the message with utils.format()\n */\nlogger.logLevel = function (level /* , ... */) {\n // format the message with the parameters\n var formatArgs = [].slice.call(arguments, 1);\n var fmtString = formatStringForMessage(formatArgs[0]);\n if (fmtString.length > 0) {\n formatArgs.unshift(fmtString); // add formatString\n }\n\n var message = logger.format.apply(logger.format, formatArgs);\n\n if (LevelsMap[level] === null) {\n throw new Error('invalid logging level: ' + level);\n }\n\n if (LevelsMap[level] > CurrentLevel) return;\n\n // queue the message if not yet at deviceready\n if (!DeviceReady && !UseConsole) {\n Queued.push([level, message]);\n return;\n }\n\n // Log using the native logger if that is enabled\n if (UseLogger) {\n exec(null, null, 'Console', 'logLevel', [level, message]);\n }\n\n // Log using the console if that is enabled\n if (UseConsole) {\n // make sure console is not using logger\n if (console.useLogger()) {\n throw new Error('console and logger are too intertwingly');\n }\n\n // log to the console\n switch (level) {\n case logger.LOG: originalConsole.log(message); break;\n case logger.ERROR: originalConsole.log('ERROR: ' + message); break;\n case logger.WARN: originalConsole.log('WARN: ' + message); break;\n case logger.INFO: originalConsole.log('INFO: ' + message); break;\n case logger.DEBUG: originalConsole.log('DEBUG: ' + message); break;\n }\n }\n};\n\n/**\n * Formats a string and arguments following it ala console.log()\n *\n * Any remaining arguments will be appended to the formatted string.\n *\n * for rationale, see FireBug's Console API:\n * http://getfirebug.com/wiki/index.php/Console_API\n */\nlogger.format = function (formatString, args) {\n return __format(arguments[0], [].slice.call(arguments, 1)).join(' ');\n};\n\n// ------------------------------------------------------------------------------\n/**\n * Formats a string and arguments following it ala vsprintf()\n *\n * format chars:\n * %j - format arg as JSON\n * %o - format arg as JSON\n * %c - format arg as ''\n * %% - replace with '%'\n * any other char following % will format it's\n * arg via toString().\n *\n * Returns an array containing the formatted string and any remaining\n * arguments.\n */\nfunction __format (formatString, args) {\n if (formatString === null || formatString === undefined) return [''];\n if (arguments.length === 1) return [formatString.toString()];\n\n if (typeof formatString !== 'string') { formatString = formatString.toString(); }\n\n var pattern = /(.*?)%(.)(.*)/;\n var rest = formatString;\n var result = [];\n\n while (args.length) {\n var match = pattern.exec(rest);\n if (!match) break;\n\n var arg = args.shift();\n rest = match[3];\n result.push(match[1]);\n\n if (match[2] === '%') {\n result.push('%');\n args.unshift(arg);\n continue;\n }\n\n result.push(__formatted(arg, match[2]));\n }\n\n result.push(rest);\n\n var remainingArgs = [].slice.call(args);\n remainingArgs.unshift(result.join(''));\n return remainingArgs;\n}\n\nfunction __formatted (object, formatChar) {\n try {\n switch (formatChar) {\n case 'j':\n case 'o': return JSON.stringify(object);\n case 'c': return '';\n }\n } catch (e) {\n return 'error JSON.stringify()ing argument: ' + e;\n }\n\n if ((object === null) || (object === undefined)) {\n return Object.prototype.toString.call(object);\n }\n\n return object.toString();\n}\n\n// ------------------------------------------------------------------------------\n// when deviceready fires, log queued messages\nlogger.__onDeviceReady = function () {\n if (DeviceReady) return;\n\n DeviceReady = true;\n\n for (var i = 0; i < Queued.length; i++) {\n var messageArgs = Queued[i];\n logger.logLevel(messageArgs[0], messageArgs[1]);\n }\n\n Queued = null;\n};\n\n// add a deviceready event to log queued messages\ndocument.addEventListener('deviceready', logger.__onDeviceReady, false);\n\n});\n\n// file: ../cordova-ios/cordova-js-src/plugin/ios/wkwebkit.js\ndefine(\"cordova/plugin/ios/wkwebkit\", function(require, exports, module) {\n\nvar exec = require('cordova/exec');\n\nvar WkWebKit = {\n allowsBackForwardNavigationGestures: function (allow) {\n exec(null, null, 'CDVWebViewEngine', 'allowsBackForwardNavigationGestures', [allow]);\n },\n convertFilePath: function (path) {\n if (!path || !window.CDV_ASSETS_URL) {\n return path;\n }\n if (path.startsWith('/')) {\n return window.CDV_ASSETS_URL + '/_app_file_' + path;\n }\n if (path.startsWith('file://')) {\n return window.CDV_ASSETS_URL + path.replace('file://', '/_app_file_');\n }\n return path;\n }\n};\n\nmodule.exports = WkWebKit;\n\n});\n\n// file: src/common/pluginloader.js\ndefine(\"cordova/pluginloader\", function(require, exports, module) {\n\nvar modulemapper = require('cordova/modulemapper');\n\n// Helper function to inject a <script> tag.\n// Exported for testing.\nexports.injectScript = function (url, onload, onerror) {\n var script = document.createElement('script');\n // onload fires even when script fails loads with an error.\n script.onload = onload;\n // onerror fires for malformed URLs.\n script.onerror = onerror;\n script.src = url;\n document.head.appendChild(script);\n};\n\nfunction injectIfNecessary (id, url, onload, onerror) {\n onerror = onerror || onload;\n if (id in define.moduleMap) {\n onload();\n } else {\n exports.injectScript(url, function () {\n if (id in define.moduleMap) {\n onload();\n } else {\n onerror();\n }\n }, onerror);\n }\n}\n\nfunction onScriptLoadingComplete (moduleList, finishPluginLoading) {\n // Loop through all the plugins and then through their clobbers and merges.\n for (var i = 0, module; (module = moduleList[i]); i++) {\n if (module.clobbers && module.clobbers.length) {\n for (var j = 0; j < module.clobbers.length; j++) {\n modulemapper.clobbers(module.id, module.clobbers[j]);\n }\n }\n\n if (module.merges && module.merges.length) {\n for (var k = 0; k < module.merges.length; k++) {\n modulemapper.merges(module.id, module.merges[k]);\n }\n }\n\n // Finally, if runs is truthy we want to simply require() the module.\n if (module.runs) {\n modulemapper.runs(module.id);\n }\n }\n\n finishPluginLoading();\n}\n\n// Handler for the cordova_plugins.js content.\n// See plugman's plugin_loader.js for the details of this object.\n// This function is only called if the really is a plugins array that isn't empty.\n// Otherwise the onerror response handler will just call finishPluginLoading().\nfunction handlePluginsObject (path, moduleList, finishPluginLoading) {\n // Now inject the scripts.\n var scriptCounter = moduleList.length;\n\n if (!scriptCounter) {\n finishPluginLoading();\n return;\n }\n function scriptLoadedCallback () {\n if (!--scriptCounter) {\n onScriptLoadingComplete(moduleList, finishPluginLoading);\n }\n }\n\n for (var i = 0; i < moduleList.length; i++) {\n injectIfNecessary(moduleList[i].id, path + moduleList[i].file, scriptLoadedCallback);\n }\n}\n\nfunction findCordovaPath () {\n var path = null;\n var scripts = document.getElementsByTagName('script');\n var term = '/cordova.js';\n for (var n = scripts.length - 1; n > -1; n--) {\n var src = scripts[n].src.replace(/\\?.*$/, ''); // Strip any query param (CB-6007).\n if (src.indexOf(term) === (src.length - term.length)) {\n path = src.substring(0, src.length - term.length) + '/';\n break;\n }\n }\n return path;\n}\n\n// Tries to load all plugins' js-modules.\n// This is an async process, but onDeviceReady is blocked on onPluginsReady.\n// onPluginsReady is fired when there are no plugins to load, or they are all done.\nexports.load = function (callback) {\n var pathPrefix = findCordovaPath();\n if (pathPrefix === null) {\n console.log('Could not find cordova.js script tag. Plugin loading may fail.');\n pathPrefix = '';\n }\n injectIfNecessary('cordova/plugin_list', pathPrefix + 'cordova_plugins.js', function () {\n var moduleList = require('cordova/plugin_list');\n handlePluginsObject(pathPrefix, moduleList, callback);\n }, callback);\n};\n\n});\n\n// file: src/common/urlutil.js\ndefine(\"cordova/urlutil\", function(require, exports, module) {\n\n/**\n * For already absolute URLs, returns what is passed in.\n * For relative URLs, converts them to absolute ones.\n */\nexports.makeAbsolute = function makeAbsolute (url) {\n var anchorEl = document.createElement('a');\n anchorEl.href = url;\n return anchorEl.href;\n};\n\n});\n\n// file: src/common/utils.js\ndefine(\"cordova/utils\", function(require, exports, module) {\n\nvar utils = exports;\n\n/**\n * Defines a property getter / setter for obj[key].\n */\nutils.defineGetterSetter = function (obj, key, getFunc, opt_setFunc) {\n if (Object.defineProperty) {\n var desc = {\n get: getFunc,\n configurable: true\n };\n if (opt_setFunc) {\n desc.set = opt_setFunc;\n }\n Object.defineProperty(obj, key, desc);\n } else {\n obj.__defineGetter__(key, getFunc);\n if (opt_setFunc) {\n obj.__defineSetter__(key, opt_setFunc);\n }\n }\n};\n\n/**\n * Defines a property getter for obj[key].\n */\nutils.defineGetter = utils.defineGetterSetter;\n\nutils.arrayIndexOf = function (a, item) {\n if (a.indexOf) {\n return a.indexOf(item);\n }\n var len = a.length;\n for (var i = 0; i < len; ++i) {\n if (a[i] === item) {\n return i;\n }\n }\n return -1;\n};\n\n/**\n * Returns whether the item was found in the array.\n */\nutils.arrayRemove = function (a, item) {\n var index = utils.arrayIndexOf(a, item);\n if (index !== -1) {\n a.splice(index, 1);\n }\n return index !== -1;\n};\n\nutils.typeName = function (val) {\n return Object.prototype.toString.call(val).slice(8, -1);\n};\n\n/**\n * Returns an indication of whether the argument is an array or not\n */\nutils.isArray = Array.isArray ||\n function (a) { return utils.typeName(a) === 'Array'; };\n\n/**\n * Returns an indication of whether the argument is a Date or not\n */\nutils.isDate = function (d) {\n return (d instanceof Date);\n};\n\n/**\n * Does a deep clone of the object.\n */\nutils.clone = function (obj) {\n if (!obj || typeof obj === 'function' || utils.isDate(obj) || typeof obj !== 'object') {\n return obj;\n }\n\n var retVal, i;\n\n if (utils.isArray(obj)) {\n retVal = [];\n for (i = 0; i < obj.length; ++i) {\n retVal.push(utils.clone(obj[i]));\n }\n return retVal;\n }\n\n retVal = {};\n for (i in obj) {\n // 'unknown' type may be returned in custom protocol activation case on\n // Windows Phone 8.1 causing \"No such interface supported\" exception on\n // cloning (https://issues.apache.org/jira/browse/CB-11522)\n // eslint-disable-next-line valid-typeof\n if ((!(i in retVal) || retVal[i] !== obj[i]) && typeof obj[i] !== 'undefined' && typeof obj[i] !== 'unknown') {\n retVal[i] = utils.clone(obj[i]);\n }\n }\n return retVal;\n};\n\n/**\n * Returns a wrapped version of the function\n */\nutils.close = function (context, func, params) {\n return function () {\n var args = params || arguments;\n return func.apply(context, args);\n };\n};\n\n// ------------------------------------------------------------------------------\nfunction UUIDcreatePart (length) {\n var uuidpart = '';\n for (var i = 0; i < length; i++) {\n var uuidchar = parseInt((Math.random() * 256), 10).toString(16);\n if (uuidchar.length === 1) {\n uuidchar = '0' + uuidchar;\n }\n uuidpart += uuidchar;\n }\n return uuidpart;\n}\n\n/**\n * Create a UUID\n */\nutils.createUUID = function () {\n return UUIDcreatePart(4) + '-' +\n UUIDcreatePart(2) + '-' +\n UUIDcreatePart(2) + '-' +\n UUIDcreatePart(2) + '-' +\n UUIDcreatePart(6);\n};\n\n/**\n * Extends a child object from a parent object using classical inheritance\n * pattern.\n */\nutils.extend = (function () {\n // proxy used to establish prototype chain\n var F = function () {};\n // extend Child from Parent\n return function (Child, Parent) {\n F.prototype = Parent.prototype;\n Child.prototype = new F();\n Child.__super__ = Parent.prototype;\n Child.prototype.constructor = Child;\n };\n}());\n\n/**\n * Alerts a message in any available way: alert or console.log.\n */\nutils.alert = function (msg) {\n if (window.alert) {\n window.alert(msg);\n } else if (console && console.log) {\n console.log(msg);\n }\n};\n\n});\n\nwindow.cordova = require('cordova');\n// file: src/scripts/bootstrap.js\nrequire('cordova/init');\n\n})();\n"],"sourceRoot":"webpack:///"}