From 540b8c2a1ac78f8477d125eeea40460a4768581e Mon Sep 17 00:00:00 2001 From: Tobias Bosch Date: Tue, 27 Oct 2015 15:41:34 -0700 Subject: [PATCH] fix(renderer): support `xlink:href` attribute in svg Closes #4956 --- .../src/core/dom/browser_adapter.dart | 9 +++++- .../angular2/src/core/dom/browser_adapter.ts | 2 +- .../src/core/render/dom/dom_renderer.ts | 2 +- .../test/core/linker/integration_spec.ts | 32 ++++++++++--------- 4 files changed, 27 insertions(+), 18 deletions(-) diff --git a/modules/angular2/src/core/dom/browser_adapter.dart b/modules/angular2/src/core/dom/browser_adapter.dart index 78a3924d45..1a7a46ddce 100644 --- a/modules/angular2/src/core/dom/browser_adapter.dart +++ b/modules/angular2/src/core/dom/browser_adapter.dart @@ -346,7 +346,14 @@ class BrowserDomAdapter extends GenericBrowserDomAdapter { String tagName(Element element) => element.tagName; Map attributeMap(Element element) { - return new Map.from(element.attributes); + var result = {}; + result.addAll(element.attributes); + // TODO(tbosch): element.getNamespacedAttributes() somehow does not return the attribute value + var xlinkHref = element.getAttributeNS('http://www.w3.org/1999/xlink', 'href'); + if (xlinkHref != null) { + result['xlink:href'] = xlinkHref; + } + return result; } bool hasAttribute(Element element, String attribute) => diff --git a/modules/angular2/src/core/dom/browser_adapter.ts b/modules/angular2/src/core/dom/browser_adapter.ts index cb7a6a808f..35539f02e7 100644 --- a/modules/angular2/src/core/dom/browser_adapter.ts +++ b/modules/angular2/src/core/dom/browser_adapter.ts @@ -226,7 +226,7 @@ export class BrowserDomAdapter extends GenericBrowserDomAdapter { hasAttribute(element, attribute: string): boolean { return element.hasAttribute(attribute); } getAttribute(element, attribute: string): string { return element.getAttribute(attribute); } setAttribute(element, name: string, value: string) { element.setAttribute(name, value); } - setAttributeNS(ns: string, element, name: string, value: string) { + setAttributeNS(element, ns: string, name: string, value: string) { element.setAttributeNS(ns, name, value); } removeAttribute(element, attribute: string) { element.removeAttribute(attribute); } diff --git a/modules/angular2/src/core/render/dom/dom_renderer.ts b/modules/angular2/src/core/render/dom/dom_renderer.ts index 5b59c64f80..dc5380af22 100644 --- a/modules/angular2/src/core/render/dom/dom_renderer.ts +++ b/modules/angular2/src/core/render/dom/dom_renderer.ts @@ -116,7 +116,7 @@ const SVG_ELEMENT_NAMES = CONST_EXPR({ 'vkern': true }); -const SVG_ATTR_NAMESPACES = CONST_EXPR({'href': XLINK_NAMESPACE}); +const SVG_ATTR_NAMESPACES = CONST_EXPR({'href': XLINK_NAMESPACE, 'xlink:href': XLINK_NAMESPACE}); export abstract class DomRenderer extends Renderer implements NodeFactory { abstract registerComponentTemplate(templateId: number, commands: RenderTemplateCmd[], diff --git a/modules/angular2/test/core/linker/integration_spec.ts b/modules/angular2/test/core/linker/integration_spec.ts index 26f1790c7e..cbb7553151 100644 --- a/modules/angular2/test/core/linker/integration_spec.ts +++ b/modules/angular2/test/core/linker/integration_spec.ts @@ -1745,22 +1745,24 @@ export function main() { if (DOM.supportsDOMEvents()) { describe('svg', () => { it('should support svg elements', - inject([TestComponentBuilder, AsyncTestCompleter], - (tcb: TestComponentBuilder, async) => { - tcb.overrideView(MyComp, new ViewMetadata({template: ''})) - .createAsync(MyComp) - .then((rootTC) => { - var el = rootTC.debugElement.nativeElement; - var svg = DOM.childNodes(el)[0]; - var g = DOM.childNodes(svg)[0]; - expect(DOM.getProperty(svg, 'namespaceURI')) - .toEqual('http://www.w3.org/2000/svg'); - expect(DOM.getProperty(g, 'namespaceURI')) - .toEqual('http://www.w3.org/2000/svg'); + inject([TestComponentBuilder, AsyncTestCompleter], (tcb: TestComponentBuilder, + async) => { + tcb.overrideView(MyComp, + new ViewMetadata({template: ''})) + .createAsync(MyComp) + .then((rootTC) => { + var el = rootTC.debugElement.nativeElement; + var svg = DOM.childNodes(el)[0]; + var use = DOM.childNodes(svg)[0]; + expect(DOM.getProperty(svg, 'namespaceURI')) + .toEqual('http://www.w3.org/2000/svg'); + expect(DOM.getProperty(use, 'namespaceURI')) + .toEqual('http://www.w3.org/2000/svg'); + expect(DOM.getOuterHTML(use)).toContain('xmlns:xlink'); - async.done(); - }); - })); + async.done(); + }); + })); }); }