fix(compiler): treat custom elements as unknown elements by default
Closes #10300
This commit is contained in:
parent
482c019199
commit
fc83bbbe98
|
@ -271,23 +271,21 @@ export class DomElementSchemaRegistry extends ElementSchemaRegistry {
|
||||||
}
|
}
|
||||||
|
|
||||||
hasProperty(tagName: string, propName: string, schemaMetas: SchemaMetadata[]): boolean {
|
hasProperty(tagName: string, propName: string, schemaMetas: SchemaMetadata[]): boolean {
|
||||||
const hasCustomElementSchema =
|
|
||||||
schemaMetas.some((schema) => schema.name === CUSTOM_ELEMENTS_SCHEMA.name);
|
|
||||||
if (tagName.indexOf('-') !== -1) {
|
if (tagName.indexOf('-') !== -1) {
|
||||||
if (tagName === 'ng-container' || tagName === 'ng-content') {
|
if (tagName === 'ng-container' || tagName === 'ng-content') {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
if (schemaMetas.some((schema) => schema.name === CUSTOM_ELEMENTS_SCHEMA.name)) {
|
||||||
// Can't tell now as we don't know which properties a custom element will get
|
// Can't tell now as we don't know which properties a custom element will get
|
||||||
// once it is instantiated
|
// once it is instantiated
|
||||||
return hasCustomElementSchema;
|
return true;
|
||||||
} else {
|
|
||||||
var elementProperties = this.schema[tagName.toLowerCase()];
|
|
||||||
if (!isPresent(elementProperties)) {
|
|
||||||
elementProperties = this.schema['unknown'];
|
|
||||||
}
|
}
|
||||||
return isPresent(elementProperties[propName]);
|
|
||||||
}
|
}
|
||||||
|
var elementProperties = this.schema[tagName.toLowerCase()];
|
||||||
|
if (!isPresent(elementProperties)) {
|
||||||
|
elementProperties = this.schema['unknown'];
|
||||||
|
}
|
||||||
|
return isPresent(elementProperties[propName]);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -47,8 +47,12 @@ export function main() {
|
||||||
expect(registry.hasProperty('video', 'click', [])).toBeFalsy();
|
expect(registry.hasProperty('video', 'click', [])).toBeFalsy();
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should return false for custom-like elements by default',
|
it('should treat custom elements as an unknown element by default', () => {
|
||||||
() => { expect(registry.hasProperty('custom-like', 'unknown', [])).toBe(false); });
|
expect(registry.hasProperty('custom-like', 'unknown', [])).toBe(false);
|
||||||
|
expect(registry.hasProperty('custom-like', 'className', [])).toBeTruthy();
|
||||||
|
expect(registry.hasProperty('custom-like', 'style', [])).toBeTruthy();
|
||||||
|
expect(registry.hasProperty('custom-like', 'id', [])).toBeTruthy();
|
||||||
|
});
|
||||||
|
|
||||||
it('should return true for custom-like elements if the CUSTOM_ELEMENTS_SCHEMA was used', () => {
|
it('should return true for custom-like elements if the CUSTOM_ELEMENTS_SCHEMA was used', () => {
|
||||||
expect(registry.hasProperty('custom-like', 'unknown', [CUSTOM_ELEMENTS_SCHEMA])).toBeTruthy();
|
expect(registry.hasProperty('custom-like', 'unknown', [CUSTOM_ELEMENTS_SCHEMA])).toBeTruthy();
|
||||||
|
|
Loading…
Reference in New Issue