use direct references to components that have been imported

pull/390/head
Conduitry 8 years ago
parent 3070abc291
commit cede99d68b

@ -191,6 +191,17 @@ export default function dom ( parsed, source, options, names ) {
// TODO remove the namespace property from the generated code, it's unused past this point // TODO remove the namespace property from the generated code, it's unused past this point
} }
if ( templateProperties.components ) {
generator.importedComponents = {};
templateProperties.components.value.properties.forEach( property => {
const key = property.key.name;
const value = source.slice( property.value.start, property.value.end );
if ( generator.importedNames[ value ] ) {
generator.importedComponents[ key ] = value;
}
});
}
generator.push({ generator.push({
name: generator.alias( 'renderMainFragment' ), name: generator.alias( 'renderMainFragment' ),
namespace, namespace,

@ -106,7 +106,7 @@ export default {
componentInitProperties.push(`data: ${name}_initialData`); componentInitProperties.push(`data: ${name}_initialData`);
} }
const expression = node.name === ':Self' ? generator.name : `template.components.${node.name}`; const expression = node.name === ':Self' ? generator.name : generator.importedComponents[ node.name ] || `template.components.${node.name}`;
local.init.addBlockAtStart( deindent` local.init.addBlockAtStart( deindent`
${statements.join( '\n\n' )} ${statements.join( '\n\n' )}

Loading…
Cancel
Save