2 * Copyright 2016-2017, CMCC Technologies Co., Ltd.
\r
4 * Licensed under the Apache License, Version 2.0 (the "License");
\r
5 * you may not use this file except in compliance with the License.
\r
6 * You may obtain a copy of the License at
\r
8 * http://www.apache.org/licenses/LICENSE-2.0
\r
10 * Unless required by applicable law or agreed to in writing, software
\r
11 * distributed under the License is distributed on an "AS IS" BASIS,
\r
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
\r
13 * See the License for the specific language governing permissions and
\r
14 * limitations under the License.
\r
16 ;(function(window, define) {
\r
23 inherit: function(api, o) {
\r
24 for (var p in api) {
\r
25 if (!o.hasOwnProperty(p)) {
\r
31 stringify: function(d) {
\r
32 return d === undefined || typeof d === "function" ? d+'' : JSON.stringify(d);
\r
34 parse: function(s) {
\r
35 // if it doesn't parse, return as is
\r
36 try{ return JSON.parse(s); }catch(e){ return s; }
\r
40 fn: function(name, fn) {
\r
41 _.storeAPI[name] = fn;
\r
42 for (var api in _.apis) {
\r
43 _.apis[api][name] = fn;
\r
46 get: function(area, key){ return area.getItem(key); },
\r
47 set: function(area, key, string){ area.setItem(key, string); },
\r
48 remove: function(area, key){ area.removeItem(key); },
\r
49 key: function(area, i){ return area.key(i); },
\r
50 length: function(area){ return area.length; },
\r
51 clear: function(area){ area.clear(); },
\r
54 Store: function(id, area, namespace) {
\r
55 var store = _.inherit(_.storeAPI, function(key, data, overwrite) {
\r
56 if (arguments.length === 0){ return store.getAll(); }
\r
57 if (data !== undefined){ return store.set(key, data, overwrite); }
\r
58 if (typeof key === "string"){ return store.get(key); }
\r
59 if (!key){ return store.clear(); }
\r
60 return store.setAll(key, data);// overwrite=data, data=key
\r
64 var testKey = '_safariPrivate_';
\r
65 area.setItem(testKey, 'sucks');
\r
67 area.removeItem(testKey);
\r
70 store._area = _.inherit(_.storageAPI, { items: {}, name: 'fake' });
\r
72 store._ns = namespace || '';
\r
74 _.areas[id] = store._area;
\r
76 if (!_.apis[store._ns+store._id]) {
\r
77 _.apis[store._ns+store._id] = store;
\r
83 area: function(id, area) {
\r
84 var store = this[id];
\r
85 if (!store || !store.area) {
\r
86 store = _.Store(id, area, this._ns);//new area-specific api in this namespace
\r
87 if (!this[id]){ this[id] = store; }
\r
91 namespace: function(namespace, noSession) {
\r
93 return this._ns ? this._ns.substring(0,this._ns.length-1) : '';
\r
95 var ns = namespace, store = this[ns];
\r
96 if (!store || !store.namespace) {
\r
97 store = _.Store(this._id, this._area, this._ns+ns+'.');//new namespaced api
\r
98 if (!this[ns]){ this[ns] = store; }
\r
99 if (!noSession){ store.area('session', _.areas.session); }
\r
103 isFake: function(){ return this._area.name === 'fake'; },
\r
104 toString: function() {
\r
105 return 'store'+(this._ns?'.'+this.namespace():'')+'['+this._id+']';
\r
108 // storage functions
\r
109 has: function(key) {
\r
110 if (this._area.has) {
\r
111 return this._area.has(this._in(key));//extension hook
\r
113 return !!(this._in(key) in this._area);
\r
115 size: function(){ return this.keys().length; },
\r
116 each: function(fn, and) {
\r
117 for (var i=0, m=_.length(this._area); i<m; i++) {
\r
118 var key = this._out(_.key(this._area, i));
\r
119 if (key !== undefined) {
\r
120 if (fn.call(this, key, and || this.get(key)) === false) {
\r
124 if (m > _.length(this._area)) { m--; i--; }// in case of removeItem
\r
126 return and || this;
\r
129 return this.each(function(k, list){ list.push(k); }, []);
\r
131 get: function(key, alt) {
\r
132 var s = _.get(this._area, this._in(key));
\r
133 return s !== null ? _.parse(s) : alt || s;// support alt for easy default mgmt
\r
135 getAll: function() {
\r
136 return this.each(function(k, all){ all[k] = this.get(k); }, {});
\r
138 set: function(key, data, overwrite) {
\r
139 var d = this.get(key);
\r
140 if (d != null && overwrite === false) {
\r
143 return _.set(this._area, this._in(key), _.stringify(data), overwrite) || d;
\r
145 setAll: function(data, overwrite) {
\r
147 for (var key in data) {
\r
149 if (this.set(key, val, overwrite) !== val) {
\r
155 remove: function(key) {
\r
156 var d = this.get(key);
\r
157 _.remove(this._area, this._in(key));
\r
160 clear: function() {
\r
162 _.clear(this._area);
\r
164 this.each(function(k){ _.remove(this._area, this._in(k)); }, 1);
\r
168 clearAll: function() {
\r
169 var area = this._area;
\r
170 for (var id in _.areas) {
\r
171 if (_.areas.hasOwnProperty(id)) {
\r
172 this._area = _.areas[id];
\r
180 // internal use functions
\r
182 if (typeof k !== "string"){ k = _.stringify(k); }
\r
183 return this._ns ? this._ns + k : k;
\r
185 _out: function(k) {
\r
187 k && k.indexOf(this._ns) === 0 ?
\r
188 k.substring(this._ns.length) :
\r
189 undefined : // so each() knows to skip it
\r
192 },// end _.storeAPI
\r
195 has: function(k){ return this.items.hasOwnProperty(k); },
\r
198 for (var k in this.items){
\r
199 if (this.has(k) && i === c++) {
\r
204 setItem: function(k, v) {
\r
205 if (!this.has(k)) {
\r
210 removeItem: function(k) {
\r
212 delete this.items[k];
\r
216 getItem: function(k){ return this.has(k) ? this.items[k] : null; },
\r
217 clear: function(){ for (var k in this.list){ this.removeItem(k); } },
\r
218 toString: function(){ return this.length+' items in '+this.name+'Storage'; }
\r
219 }// end _.storageAPI
\r
222 // setup the primary store fn
\r
223 if (window.store){ _.conflict = window.store; }
\r
225 // safely set this up (throws error in IE10/32bit mode for local files)
\r
226 _.Store("local", (function(){try{ return localStorage; }catch(e){}})());
\r
227 store.local = store;// for completeness
\r
228 store._ = _;// for extenders and debuggers...
\r
229 // safely setup store.session (throws exception in FF for file:/// urls)
\r
230 store.area("session", (function(){try{ return sessionStorage; }catch(e){}})());
\r
232 //Expose store to the global object
\r
233 window.store = store;
\r
235 if (typeof define === 'function' && define.amd !== undefined) {
\r
236 define(function () {
\r
239 } else if (typeof module !== 'undefined' && module.exports) {
\r
240 module.exports = store;
\r
245 // XHook - v1.3.3 - https://github.com/jpillora/xhook
\r
246 // Jaime Pillora <dev@jpillora.com> - MIT Copyright 2015
\r
247 (function(window,undefined) {
\r
248 var AFTER, BEFORE, COMMON_EVENTS, EventEmitter, FIRE, FormData, NativeFormData, NativeXMLHttp, OFF, ON, READY_STATE, UPLOAD_EVENTS, XHookFormData, XHookHttpRequest, XMLHTTP, convertHeaders, depricatedProp, document, fakeEvent, mergeObjects, msie, proxyEvents, slice, xhook, _base,
\r
249 __indexOf = [].indexOf || function(item) { for (var i = 0, l = this.length; i < l; i++) { if (i in this && this[i] === item) return i; } return -1; };
\r
251 document = window.document;
\r
257 READY_STATE = 'readyState';
\r
259 ON = 'addEventListener';
\r
261 OFF = 'removeEventListener';
\r
263 FIRE = 'dispatchEvent';
\r
265 XMLHTTP = 'XMLHttpRequest';
\r
267 FormData = 'FormData';
\r
269 UPLOAD_EVENTS = ['load', 'loadend', 'loadstart'];
\r
271 COMMON_EVENTS = ['progress', 'abort', 'error', 'timeout'];
\r
273 msie = parseInt((/msie (\d+)/.exec(navigator.userAgent.toLowerCase()) || [])[1]);
\r
276 msie = parseInt((/trident\/.*; rv:(\d+)/.exec(navigator.userAgent.toLowerCase()) || [])[1]);
\r
279 (_base = Array.prototype).indexOf || (_base.indexOf = function(item) {
\r
280 var i, x, _i, _len;
\r
281 for (i = _i = 0, _len = this.length; _i < _len; i = ++_i) {
\r
290 slice = function(o, n) {
\r
291 return Array.prototype.slice.call(o, n);
\r
294 depricatedProp = function(p) {
\r
295 return p === "returnValue" || p === "totalSize" || p === "position";
\r
298 mergeObjects = function(src, dst) {
\r
302 if (depricatedProp(k)) {
\r
307 } catch (_error) {}
\r
312 proxyEvents = function(events, src, dst) {
\r
313 var event, p, _i, _len;
\r
314 p = function(event) {
\r
315 return function(e) {
\r
319 if (depricatedProp(k)) {
\r
323 clone[k] = val === src ? dst : val;
\r
325 return dst[FIRE](event, clone);
\r
328 for (_i = 0, _len = events.length; _i < _len; _i++) {
\r
329 event = events[_i];
\r
330 if (dst._has(event)) {
\r
331 src["on" + event] = p(event);
\r
336 fakeEvent = function(type) {
\r
337 var msieEventObject;
\r
338 if (document.createEventObject != null) {
\r
339 msieEventObject = document.createEventObject();
\r
340 msieEventObject.type = type;
\r
341 return msieEventObject;
\r
344 return new Event(type);
\r
353 EventEmitter = function(nodeStyle) {
\r
354 var emitter, events, listeners;
\r
356 listeners = function(event) {
\r
357 return events[event] || [];
\r
360 emitter[ON] = function(event, callback, i) {
\r
361 events[event] = listeners(event);
\r
362 if (events[event].indexOf(callback) >= 0) {
\r
365 i = i === undefined ? events[event].length : i;
\r
366 events[event].splice(i, 0, callback);
\r
368 emitter[OFF] = function(event, callback) {
\r
370 if (event === undefined) {
\r
374 if (callback === undefined) {
\r
375 events[event] = [];
\r
377 i = listeners(event).indexOf(callback);
\r
381 listeners(event).splice(i, 1);
\r
383 emitter[FIRE] = function() {
\r
384 var args, event, i, legacylistener, listener, _i, _len, _ref;
\r
385 args = slice(arguments);
\r
386 event = args.shift();
\r
388 args[0] = mergeObjects(args[0], fakeEvent(event));
\r
390 legacylistener = emitter["on" + event];
\r
391 if (legacylistener) {
\r
392 legacylistener.apply(undefined, args);
\r
394 _ref = listeners(event).concat(listeners("*"));
\r
395 for (i = _i = 0, _len = _ref.length; _i < _len; i = ++_i) {
\r
396 listener = _ref[i];
\r
397 listener.apply(undefined, args);
\r
400 emitter._has = function(event) {
\r
401 return !!(events[event] || emitter["on" + event]);
\r
404 emitter.listeners = function(event) {
\r
405 return slice(listeners(event));
\r
407 emitter.on = emitter[ON];
\r
408 emitter.off = emitter[OFF];
\r
409 emitter.fire = emitter[FIRE];
\r
410 emitter.once = function(e, fn) {
\r
412 fire = function() {
\r
413 emitter.off(e, fire);
\r
414 return fn.apply(null, arguments);
\r
416 return emitter.on(e, fire);
\r
418 emitter.destroy = function() {
\r
419 return events = {};
\r
425 xhook = EventEmitter(true);
\r
427 xhook.EventEmitter = EventEmitter;
\r
429 xhook[BEFORE] = function(handler, i) {
\r
430 if (handler.length < 1 || handler.length > 2) {
\r
431 throw "invalid hook";
\r
433 return xhook[ON](BEFORE, handler, i);
\r
436 xhook[AFTER] = function(handler, i) {
\r
437 if (handler.length < 2 || handler.length > 3) {
\r
438 throw "invalid hook";
\r
440 return xhook[ON](AFTER, handler, i);
\r
443 xhook.enable = function() {
\r
444 window[XMLHTTP] = XHookHttpRequest;
\r
445 if (NativeFormData) {
\r
446 window[FormData] = XHookFormData;
\r
450 xhook.disable = function() {
\r
451 window[XMLHTTP] = xhook[XMLHTTP];
\r
452 window[FormData] = NativeFormData;
\r
455 convertHeaders = xhook.headers = function(h, dest) {
\r
456 var header, headers, k, name, v, value, _i, _len, _ref;
\r
457 if (dest == null) {
\r
460 switch (typeof h) {
\r
465 name = k.toLowerCase();
\r
466 headers.push("" + name + ":\t" + v);
\r
468 return headers.join('\n');
\r
470 headers = h.split('\n');
\r
471 for (_i = 0, _len = headers.length; _i < _len; _i++) {
\r
472 header = headers[_i];
\r
473 if (/([^:]+):\s*(.+)/.test(header)) {
\r
474 name = (_ref = RegExp.$1) != null ? _ref.toLowerCase() : void 0;
\r
476 if (dest[name] == null) {
\r
477 dest[name] = value;
\r
485 NativeFormData = window[FormData];
\r
487 XHookFormData = function(form) {
\r
489 this.fd = form ? new NativeFormData(form) : new NativeFormData();
\r
492 Object.defineProperty(this, 'entries', {
\r
495 fentries = !form ? [] : slice(form.querySelectorAll("input,select")).filter(function(e) {
\r
497 return ((_ref = e.type) !== 'checkbox' && _ref !== 'radio') || e.checked;
\r
498 }).map(function(e) {
\r
499 return [e.name, e.type === "file" ? e.files : e.value];
\r
501 return fentries.concat(entries);
\r
504 this.append = (function(_this) {
\r
505 return function() {
\r
507 args = slice(arguments);
\r
508 entries.push(args);
\r
509 return _this.fd.append.apply(_this.fd, args);
\r
514 if (NativeFormData) {
\r
515 xhook[FormData] = NativeFormData;
\r
516 window[FormData] = XHookFormData;
\r
519 NativeXMLHttp = window[XMLHTTP];
\r
521 xhook[XMLHTTP] = NativeXMLHttp;
\r
523 XHookHttpRequest = window[XMLHTTP] = function() {
\r
524 var ABORTED, currentState, emitFinal, emitReadyState, facade, hasError, hasErrorHandler, readBody, readHead, request, response, setReadyState, status, transiting, writeBody, writeHead, xhr;
\r
526 xhr = new xhook[XMLHTTP]();
\r
530 transiting = void 0;
\r
532 readHead = function() {
\r
533 var key, name, val, _ref;
\r
534 response.status = status || xhr.status;
\r
535 if (!(status === ABORTED && msie < 10)) {
\r
536 response.statusText = xhr.statusText;
\r
538 if (status !== ABORTED) {
\r
539 _ref = convertHeaders(xhr.getAllResponseHeaders());
\r
540 for (key in _ref) {
\r
542 if (!response.headers[key]) {
\r
543 name = key.toLowerCase();
\r
544 response.headers[name] = val;
\r
549 readBody = function() {
\r
550 if (!xhr.responseType || xhr.responseType === "text") {
\r
551 response.text = xhr.responseText;
\r
552 response.data = xhr.responseText;
\r
553 } else if (xhr.responseType === "document") {
\r
554 response.xml = xhr.responseXML;
\r
555 response.data = xhr.responseXML;
\r
557 response.data = xhr.response;
\r
559 if ("responseURL" in xhr) {
\r
560 response.finalUrl = xhr.responseURL;
\r
563 writeHead = function() {
\r
564 facade.status = response.status;
\r
565 facade.statusText = response.statusText;
\r
567 writeBody = function() {
\r
568 if ('text' in response) {
\r
569 facade.responseText = response.text;
\r
571 if ('xml' in response) {
\r
572 facade.responseXML = response.xml;
\r
574 if ('data' in response) {
\r
575 facade.response = response.data;
\r
577 if ('finalUrl' in response) {
\r
578 facade.responseURL = response.finalUrl;
\r
581 emitReadyState = function(n) {
\r
582 while (n > currentState && currentState < 4) {
\r
583 facade[READY_STATE] = ++currentState;
\r
584 if (currentState === 1) {
\r
585 facade[FIRE]("loadstart", {});
\r
587 if (currentState === 2) {
\r
590 if (currentState === 4) {
\r
594 facade[FIRE]("readystatechange", {});
\r
595 if (currentState === 4) {
\r
596 setTimeout(emitFinal, 0);
\r
600 emitFinal = function() {
\r
602 facade[FIRE]("load", {});
\r
604 facade[FIRE]("loadend", {});
\r
606 facade[READY_STATE] = 0;
\r
610 setReadyState = function(n) {
\r
611 var hooks, process;
\r
616 hooks = xhook.listeners(AFTER);
\r
617 process = function() {
\r
619 if (!hooks.length) {
\r
620 return emitReadyState(4);
\r
622 hook = hooks.shift();
\r
623 if (hook.length === 2) {
\r
624 hook(request, response);
\r
626 } else if (hook.length === 3 && request.async) {
\r
627 return hook(request, response, process);
\r
634 facade = request.xhr = EventEmitter();
\r
635 xhr.onreadystatechange = function(event) {
\r
637 if (xhr[READY_STATE] === 2) {
\r
640 } catch (_error) {}
\r
641 if (xhr[READY_STATE] === 4) {
\r
642 transiting = false;
\r
646 setReadyState(xhr[READY_STATE]);
\r
648 hasErrorHandler = function() {
\r
651 facade[ON]('error', hasErrorHandler);
\r
652 facade[ON]('timeout', hasErrorHandler);
\r
653 facade[ON]('abort', hasErrorHandler);
\r
654 facade[ON]('progress', function() {
\r
655 if (currentState < 3) {
\r
658 facade[FIRE]("readystatechange", {});
\r
661 if ('withCredentials' in xhr || xhook.addWithCredentials) {
\r
662 facade.withCredentials = false;
\r
665 facade.open = function(method, url, async, user, pass) {
\r
668 transiting = false;
\r
669 request.headers = {};
\r
670 request.headerNames = {};
\r
671 request.status = 0;
\r
673 response.headers = {};
\r
674 request.method = method;
\r
676 request.async = async !== false;
\r
677 request.user = user;
\r
678 request.pass = pass;
\r
681 facade.send = function(body) {
\r
682 var hooks, k, modk, process, send, _i, _len, _ref;
\r
683 _ref = ['type', 'timeout', 'withCredentials'];
\r
684 if(navigator.userAgent.indexOf("Firefox/") != -1){http://atmosphere-framework.2306103.n4.nabble.com/Atmosphere-js-withCredentials-true-does-not-work-in-Firefox-td4656661.html
\r
685 _ref = ['type', 'timeout'];
\r
687 for (_i = 0, _len = _ref.length; _i < _len; _i++) {
\r
689 modk = k === "type" ? "responseType" : k;
\r
690 if (modk in facade) {
\r
691 request[k] = facade[modk];
\r
694 request.body = body;
\r
695 send = function() {
\r
696 var header, value, _j, _len1, _ref1, _ref2;
\r
697 proxyEvents(COMMON_EVENTS, xhr, facade);
\r
698 if (facade.upload) {
\r
699 proxyEvents(COMMON_EVENTS.concat(UPLOAD_EVENTS), xhr.upload, facade.upload);
\r
702 xhr.open(request.method, request.url, request.async, request.user, request.pass);
\r
703 _ref1 = ['type', 'timeout', 'withCredentials'];
\r
704 if(navigator.userAgent.indexOf("Firefox/") != -1){//http://atmosphere-framework.2306103.n4.nabble.com/Atmosphere-js-withCredentials-true-does-not-work-in-Firefox-td4656661.html
\r
705 _ref1 = ['type', 'timeout'];
\r
707 for (_j = 0, _len1 = _ref1.length; _j < _len1; _j++) {
\r
709 modk = k === "type" ? "responseType" : k;
\r
710 if (k in request) {
\r
711 xhr[modk] = request[k];
\r
714 _ref2 = request.headers;
\r
715 for (header in _ref2) {
\r
716 value = _ref2[header];
\r
717 xhr.setRequestHeader(header, value);
\r
719 if (request.body instanceof XHookFormData) {
\r
720 request.body = request.body.fd;
\r
722 xhr.send(request.body);
\r
724 hooks = xhook.listeners(BEFORE);
\r
725 process = function() {
\r
727 if (!hooks.length) {
\r
730 done = function(userResponse) {
\r
731 if (typeof userResponse === 'object' && (typeof userResponse.status === 'number' || typeof response.status === 'number')) {
\r
732 mergeObjects(userResponse, response);
\r
733 if (__indexOf.call(userResponse, 'data') < 0) {
\r
734 userResponse.data = userResponse.response || userResponse.text;
\r
741 done.head = function(userResponse) {
\r
742 mergeObjects(userResponse, response);
\r
743 return setReadyState(2);
\r
745 done.progress = function(userResponse) {
\r
746 mergeObjects(userResponse, response);
\r
747 return setReadyState(3);
\r
749 hook = hooks.shift();
\r
750 if (hook.length === 1) {
\r
751 return done(hook(request));
\r
752 } else if (hook.length === 2 && request.async) {
\r
753 return hook(request, done);
\r
760 facade.abort = function() {
\r
765 facade[FIRE]('abort', {});
\r
768 facade.setRequestHeader = function(header, value) {
\r
770 lName = header != null ? header.toLowerCase() : void 0;
\r
771 name = request.headerNames[lName] = request.headerNames[lName] || header;
\r
772 if (request.headers[name]) {
\r
773 value = request.headers[name] + ', ' + value;
\r
775 request.headers[name] = value;
\r
777 facade.getResponseHeader = function(header) {
\r
779 name = header != null ? header.toLowerCase() : void 0;
\r
780 return response.headers[name];
\r
782 facade.getAllResponseHeaders = function() {
\r
783 return convertHeaders(response.headers);
\r
785 if (xhr.overrideMimeType) {
\r
786 facade.overrideMimeType = function() {
\r
787 return xhr.overrideMimeType.apply(xhr, arguments);
\r
791 facade.upload = request.upload = EventEmitter();
\r
796 if (typeof this.define === "function" && this.define.amd) {
\r
797 define("xhook", [], function() {
\r
801 (this.exports || this).xhook = xhook;
\r
804 }.call(this,window));
\r
806 xhook.before(function(request) {
\r
807 var zte_headers = store('zte_http_headers');
\r
808 if (zte_headers && zte_headers.length > 0) {
\r
809 for (i = 0; i < zte_headers.length; i++) {
\r
810 if (zte_headers[i].store === true) {
\r
811 if ( !! store(zte_headers[i].value)) {
\r
812 request.headers[zte_headers[i].key] = store(zte_headers[i].value).toUpperCase()
\r
815 request.headers[zte_headers[i].key] = zte_headers[i].value
\r
829 * @param {Object} name
\r
830 * @param {Object} object
\r
832 $Boot.createNamespace = function(name, object) {
\r
833 var splits = name.split(".");
\r
834 var parent = window;
\r
835 //document.window浏览器内置对象
\r
836 var part = splits[0];
\r
837 for (var i = 0, len = splits.length - 1; i < len; i++, part = splits[i]) {
\r
838 if (!parent[part]) {
\r
839 parent = parent[part] = {};
\r
841 parent = parent[part];
\r
845 parent[part] = object;
\r
846 // 返回 last part name (例如:classname)
\r
850 $Boot.isDefined = function(o) {
\r
851 return typeof (o) != "undefined"
\r
856 $Boot.Config = function() {
\r
858 function isDefined(o) {
\r
859 return typeof (o) != "undefined"
\r
863 if (!isDefined(window.$userAppDir)) {
\r
864 window.$userAppDir = './'
\r
867 if (!isDefined(window.$userFrameDir)) {
\r
868 window.$userFrameDir = '/common/'
\r
871 if (!isDefined(window.$userI18nDir)) {
\r
872 window.$userI18nDir = './'
\r
876 var language = "en-US";
\r
877 //var languageList = ['ar', 'ba', 'cr', 'cs', 'de', 'el', 'es', 'fi', 'fr', 'fr-FR', 'hu-HU', 'id', 'it', 'ja', 'nb-NO', 'nl', 'pl', 'pl-PL', 'pt', 'pt-BR', 'ro-RO', 'ru-RU', 'sk', 'sr', 'sr-Latn', 'sv-SE', 'en-US','uk-UA', 'zh-CN', 'zh-TW'];
\r
878 var languageList = ['en-US', 'zh-CN'];
\r
881 var getAcceptLangFromServer = true;
\r
885 * 创建XMLHttpRequest对象
\r
887 function createXMLHttpRequest() {
\r
888 if (window.ActiveXObject) {
\r
889 return new ActiveXObject("Microsoft.XMLHTTP");
\r
890 } else if (window.XMLHttpRequest) {
\r
891 return new XMLHttpRequest();
\r
893 throw new Error("This Brower do not support XMLHTTP!!");
\r
900 * @param {Object} url
\r
901 * @param {Object} data
\r
902 * @param {Object} method
\r
904 function httpRequest(method, url, data) {
\r
906 xmlhttp = createXMLHttpRequest();
\r
907 var sendData = null;
\r
908 if (method == "get") {
\r
909 url = url + "?" + data;
\r
911 } else if (method == "post") {
\r
914 xmlhttp.open(method, url, false);
\r
915 xmlhttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded; charset=UTF-8");
\r
916 xmlhttp.setRequestHeader("If-Modified-Since", "0");
\r
917 xmlhttp.send(sendData);
\r
918 if (xmlhttp.status == 200)
\r
919 return xmlhttp.responseText;
\r
923 * 同步发送xml http 请求(给外部调用)
\r
924 * @param {Object} url
\r
925 * @param {Object} data
\r
926 * @param {Object} method
\r
928 this.httpRequestStatic = function(method, url, data) {
\r
930 xmlhttp = createXMLHttpRequest();
\r
931 var sendData = null;
\r
932 if (method == "get") {
\r
933 url = url + "?" + data;
\r
935 } else if (method == "post") {
\r
938 xmlhttp.open(method, url, false);
\r
939 xmlhttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded; charset=UTF-8");
\r
940 xmlhttp.setRequestHeader("If-Modified-Since", "0");
\r
941 xmlhttp.send(sendData);
\r
942 if (xmlhttp.status == 200)
\r
943 return xmlhttp.responseText;
\r
946 function inArray(array, obj) {
\r
947 for (var i = 0; i < array.length; i++) {
\r
948 if (array[i] == obj) {
\r
957 this.getUrlParam=function(name){
\r
958 var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)"); //构造一个含有目标参数的正则表达式对象
\r
959 var search =decodeURIComponent(location.search.substring(1)); //decodeURIComponent() 函数可对 encodeURIComponent() 函数编码的 URI 进行解码。
\r
960 var r =search.match(reg); //匹配目标参数
\r
961 if (r != null) return unescape(r[2]); //unescape() 函数可对通过 escape() 编码的字符串进行解码。
\r
962 return null; //返回参数值
\r
969 $Boot.createNamespace("com.zte.ums.aos.framework.BootConfig", $Boot.Config);
\r
971 $Boot.bootConfig = new com.zte.ums.aos.framework.BootConfig();
\r
973 function getLanguage(){
\r
977 function getStringWidth(text,fontSize)
\r
979 var span = document.getElementById("_ictframework_getwidth");
\r
980 if (span == null) {
\r
981 span = document.createElement("span");
\r
982 span.id = "_ictframework_getwidth";
\r
983 document.body.appendChild(span);
\r
985 span.innerText = text;
\r
986 span.style.whiteSpace = "nowrap";
\r
987 $("#_ictframework_getwidth").attr('style','font-size:'+fontSize+'px;');
\r
988 var width = span.offsetWidth;
\r
989 $("#_ictframework_getwidth").attr('style','display:none');
\r
993 function getUrlParam(name){
\r
994 return $Boot.bootConfig.getUrlParam(name);
\r
997 function httpRequest(method, url, data) {
\r
998 return $Boot.bootConfig.httpRequestStatic(method, url, data)
\r
1001 // 定义JQUERY AJAX 完成函数,判断返回状态,如果状态正常,但HEADER头里有session超时信息,则刷新重登录
\r
1002 // 如果状态为 401, 也刷新重登录
\r
1003 // 注意如果在$.ajax() 函数中定义了 complete,则覆盖了这里预定义complete内容,以$.ajax()函数中定义的为准,这里预定义的函数则失效,如果
\r
1004 // 要继续判断session超时,则需要在 $.ajax()函数中定义的complete函数中加入这里预定义内容。
\r
1007 complete:function(XMLHttpRequest,textStatus){
\r
1008 if (XMLHttpRequest.status == 401) {
\r
1009 window.location.replace("login.html");
\r
1011 // if (XMLHttpRequest.status == 200) {
\r
1012 // var sessionstatus=XMLHttpRequest.getResponseHeader("sessionstatus"); ////通过XMLHttpRequest取得响应头,sessionstatus,
\r
1013 // if(sessionstatus=="timeout"){
\r
1014 // window.location.replace("/");
\r
1016 // } else if (XMLHttpRequest.status == 401) {
\r
1017 // window.location.replace("/");
\r