2015-05-22 11:47:13 -04:00
|
|
|
import {List, ListWrapper, MapWrapper} from 'angular2/src/facade/collection';
|
2015-02-27 17:50:06 -05:00
|
|
|
import {DOM} from 'angular2/src/dom/dom_adapter';
|
2015-05-22 11:47:13 -04:00
|
|
|
import {isPresent, isString, RegExpWrapper, StringWrapper, RegExp} from 'angular2/src/facade/lang';
|
2014-12-05 21:30:45 -05:00
|
|
|
|
|
|
|
export class Log {
|
2015-05-20 20:19:46 -04:00
|
|
|
_result: List<any>;
|
2014-12-05 21:30:45 -05:00
|
|
|
|
2015-05-20 20:19:46 -04:00
|
|
|
constructor() { this._result = []; }
|
2014-12-05 21:30:45 -05:00
|
|
|
|
2015-06-17 14:17:21 -04:00
|
|
|
add(value): void { this._result.push(value); }
|
2014-12-05 21:30:45 -05:00
|
|
|
|
|
|
|
fn(value) {
|
2015-06-17 14:17:21 -04:00
|
|
|
return (a1 = null, a2 = null, a3 = null, a4 = null, a5 = null) => { this._result.push(value); }
|
2014-12-05 21:30:45 -05:00
|
|
|
}
|
|
|
|
|
2015-05-21 10:42:19 -04:00
|
|
|
result(): string { return ListWrapper.join(this._result, "; "); }
|
2014-12-05 21:30:45 -05:00
|
|
|
}
|
2015-02-03 10:27:09 -05:00
|
|
|
|
|
|
|
export function dispatchEvent(element, eventType) {
|
|
|
|
DOM.dispatchEvent(element, DOM.createEvent(eventType));
|
|
|
|
}
|
|
|
|
|
2015-07-07 23:03:00 -04:00
|
|
|
export function el(html: string): HTMLElement {
|
|
|
|
return <HTMLElement>DOM.firstChild(DOM.content(DOM.createTemplate(html)));
|
2015-02-03 10:27:09 -05:00
|
|
|
}
|
2015-05-26 16:57:13 -04:00
|
|
|
|
2015-06-12 10:50:45 -04:00
|
|
|
var _RE_SPECIAL_CHARS =
|
|
|
|
['-', '[', ']', '/', '{', '}', '\\', '(', ')', '*', '+', '?', '.', '^', '$', '|'];
|
2015-05-26 16:57:13 -04:00
|
|
|
var _ESCAPE_RE = RegExpWrapper.create(`[\\${_RE_SPECIAL_CHARS.join('\\')}]`);
|
|
|
|
export function containsRegexp(input: string): RegExp {
|
2015-05-26 12:45:15 -04:00
|
|
|
return RegExpWrapper.create(
|
|
|
|
StringWrapper.replaceAllMapped(input, _ESCAPE_RE, (match) => `\\${match[0]}`));
|
2015-05-26 16:57:13 -04:00
|
|
|
}
|
2015-05-27 04:22:30 -04:00
|
|
|
|
|
|
|
export function normalizeCSS(css: string): string {
|
2015-06-23 06:46:38 -04:00
|
|
|
css = StringWrapper.replaceAll(css, /\s+/g, ' ');
|
|
|
|
css = StringWrapper.replaceAll(css, /:\s/g, ':');
|
2015-07-29 12:34:02 -04:00
|
|
|
css = StringWrapper.replaceAll(css, /'/g, '"');
|
2015-06-23 06:46:38 -04:00
|
|
|
css = StringWrapper.replaceAllMapped(css, /url\(\"(.+)\\"\)/g, (match) => `url(${match[1]})`);
|
|
|
|
css = StringWrapper.replaceAllMapped(css, /\[(.+)=([^"\]]+)\]/g,
|
2015-05-27 04:22:30 -04:00
|
|
|
(match) => `[${match[1]}="${match[2]}"]`);
|
|
|
|
return css;
|
|
|
|
}
|
2015-05-22 11:47:13 -04:00
|
|
|
|
|
|
|
var _singleTagWhitelist = ['br', 'hr', 'input'];
|
|
|
|
export function stringifyElement(el): string {
|
|
|
|
var result = '';
|
|
|
|
if (DOM.isElementNode(el)) {
|
|
|
|
var tagName = StringWrapper.toLowerCase(DOM.tagName(el));
|
|
|
|
|
|
|
|
// Opening tag
|
|
|
|
result += `<${tagName}`;
|
|
|
|
|
|
|
|
// Attributes in an ordered way
|
|
|
|
var attributeMap = DOM.attributeMap(el);
|
2015-06-17 14:17:21 -04:00
|
|
|
var keys = [];
|
|
|
|
MapWrapper.forEach(attributeMap, (v, k) => { keys.push(k); });
|
2015-05-22 11:47:13 -04:00
|
|
|
ListWrapper.sort(keys);
|
|
|
|
for (let i = 0; i < keys.length; i++) {
|
|
|
|
var key = keys[i];
|
2015-06-17 19:21:40 -04:00
|
|
|
var attValue = attributeMap.get(key);
|
2015-05-22 11:47:13 -04:00
|
|
|
if (!isString(attValue)) {
|
|
|
|
result += ` ${key}`;
|
|
|
|
} else {
|
|
|
|
result += ` ${key}="${attValue}"`;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
result += '>';
|
|
|
|
|
|
|
|
// Children
|
|
|
|
var children = DOM.childNodes(DOM.templateAwareRoot(el));
|
|
|
|
for (let j = 0; j < children.length; j++) {
|
|
|
|
result += stringifyElement(children[j]);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Closing tag
|
|
|
|
if (!ListWrapper.contains(_singleTagWhitelist, tagName)) {
|
|
|
|
result += `</${tagName}>`;
|
|
|
|
}
|
2015-07-29 20:41:09 -04:00
|
|
|
} else if (DOM.isCommentNode(el)) {
|
|
|
|
result += `<!--${DOM.nodeValue(el)}-->`;
|
2015-05-22 11:47:13 -04:00
|
|
|
} else {
|
|
|
|
result += DOM.getText(el);
|
|
|
|
}
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
2015-08-18 10:16:30 -04:00
|
|
|
|
|
|
|
// The Intl API is only properly supported in Chrome and Opera.
|
|
|
|
// Note: Edge is disguised as Chrome 42, so checking the "Edge" part is needed,
|
|
|
|
// see https://msdn.microsoft.com/en-us/library/hh869301(v=vs.85).aspx
|
|
|
|
export function supportsIntlApi(): boolean {
|
|
|
|
return DOM.getUserAgent().indexOf('Chrome') > -1 && DOM.getUserAgent().indexOf('Edge') == -1;
|
|
|
|
}
|
2015-08-19 10:47:18 -04:00
|
|
|
|
|
|
|
// TODO(mlaval): extract all browser detection checks from all tests
|
|
|
|
export function isFirefox(): boolean {
|
|
|
|
return DOM.getUserAgent().indexOf("Firefox") > -1;
|
|
|
|
}
|