| Index: lib/html/src/shared_FactoryProviders.dart
 | 
| diff --git a/lib/html/src/shared_FactoryProviders.dart b/lib/html/src/shared_FactoryProviders.dart
 | 
| index 99c90a25eef827ab961618f60f2d4ccd012267b4..e9ea9238de2f682b10f3e8331f4ff1b90c25dbed 100644
 | 
| --- a/lib/html/src/shared_FactoryProviders.dart
 | 
| +++ b/lib/html/src/shared_FactoryProviders.dart
 | 
| @@ -2,16 +2,11 @@
 | 
|  // for details. All rights reserved. Use of this source code is governed by a
 | 
|  // BSD-style license that can be found in the LICENSE file.
 | 
|  
 | 
| -class _TextFactoryProvider {
 | 
| -
 | 
| -  factory Text(String data) => _document._createTextNode(data);
 | 
| -}
 | 
| -
 | 
|  class _EventFactoryProvider {
 | 
|    factory Event(String type, [bool canBubble = true,
 | 
|        bool cancelable = true]) {
 | 
| -    final _EventImpl e = _document._createEvent("Event");
 | 
| -    e._initEvent(type, canBubble, cancelable);
 | 
| +    final _EventImpl e = _document.$dom_createEvent("Event");
 | 
| +    e.$dom_initEvent(type, canBubble, cancelable);
 | 
|      return e;
 | 
|    }
 | 
|  }
 | 
| @@ -22,8 +17,8 @@ class _MouseEventFactoryProvider {
 | 
|        [bool canBubble = true, bool cancelable = true, bool ctrlKey = false,
 | 
|        bool altKey = false, bool shiftKey = false, bool metaKey = false,
 | 
|        EventTarget relatedTarget = null]) {
 | 
| -    final e = _document._createEvent("MouseEvent");
 | 
| -    e._initMouseEvent(type, canBubble, cancelable, view, detail,
 | 
| +    final e = _document.$dom_createEvent("MouseEvent");
 | 
| +    e.$dom_initMouseEvent(type, canBubble, cancelable, view, detail,
 | 
|          screenX, screenY, clientX, clientY, ctrlKey, altKey, shiftKey, metaKey,
 | 
|          button, relatedTarget);
 | 
|      return e;
 | 
| @@ -42,62 +37,6 @@ class _CSSStyleDeclarationFactoryProvider {
 | 
|    }
 | 
|  }
 | 
|  
 | 
| -final _START_TAG_REGEXP = const RegExp('<(\\w+)');
 | 
| -class _ElementFactoryProvider {
 | 
| -  static final _CUSTOM_PARENT_TAG_MAP = const {
 | 
| -    'body' : 'html',
 | 
| -    'head' : 'html',
 | 
| -    'caption' : 'table',
 | 
| -    'td': 'tr',
 | 
| -    'colgroup': 'table',
 | 
| -    'col' : 'colgroup',
 | 
| -    'tr' : 'tbody',
 | 
| -    'tbody' : 'table',
 | 
| -    'tfoot' : 'table',
 | 
| -    'thead' : 'table',
 | 
| -    'track' : 'audio',
 | 
| -  };
 | 
| -
 | 
| -  /** @domName Document.createElement */
 | 
| -  factory Element.html(String html) {
 | 
| -    // TODO(jacobr): this method can be made more robust and performant.
 | 
| -    // 1) Cache the dummy parent elements required to use innerHTML rather than
 | 
| -    //    creating them every call.
 | 
| -    // 2) Verify that the html does not contain leading or trailing text nodes.
 | 
| -    // 3) Verify that the html does not contain both <head> and <body> tags.
 | 
| -    // 4) Detatch the created element from its dummy parent.
 | 
| -    String parentTag = 'div';
 | 
| -    String tag;
 | 
| -    final match = _START_TAG_REGEXP.firstMatch(html);
 | 
| -    if (match !== null) {
 | 
| -      tag = match.group(1).toLowerCase();
 | 
| -      if (_CUSTOM_PARENT_TAG_MAP.containsKey(tag)) {
 | 
| -        parentTag = _CUSTOM_PARENT_TAG_MAP[tag];
 | 
| -      }
 | 
| -    }
 | 
| -    final _ElementImpl temp = new Element.tag(parentTag);
 | 
| -    temp.innerHTML = html;
 | 
| -
 | 
| -    Element element;
 | 
| -    if (temp.elements.length == 1) {
 | 
| -      element = temp.elements.first;
 | 
| -    } else if (parentTag == 'html' && temp.elements.length == 2) {
 | 
| -      // Work around for edge case in WebKit and possibly other browsers where
 | 
| -      // both body and head elements are created even though the inner html
 | 
| -      // only contains a head or body element.
 | 
| -      element = temp.elements[tag == 'head' ? 0 : 1];
 | 
| -    } else {
 | 
| -      throw new IllegalArgumentException('HTML had ${temp.elements.length} ' +
 | 
| -          'top level elements but 1 expected');
 | 
| -    }
 | 
| -    element.remove();
 | 
| -    return element;
 | 
| -  }
 | 
| -
 | 
| -  /** @domName Document.createElement */
 | 
| -  factory Element.tag(String tag) => _document._createElement(tag);
 | 
| -}
 | 
| -
 | 
|  class _DocumentFragmentFactoryProvider {
 | 
|    /** @domName Document.createDocumentFragment */
 | 
|    factory DocumentFragment() => document.createDocumentFragment();
 | 
| @@ -135,7 +74,7 @@ class _DocumentFragmentFactoryProvider {
 | 
|  class _SVGElementFactoryProvider {
 | 
|    factory SVGElement.tag(String tag) {
 | 
|      final Element temp =
 | 
| -      _document._createElementNS("http://www.w3.org/2000/svg", tag);
 | 
| +      _document.$dom_createElementNS("http://www.w3.org/2000/svg", tag);
 | 
|      return temp;
 | 
|    }
 | 
|  
 | 
| 
 |