|
|
|
@ -14,11 +14,6 @@ class DomGenerator extends Generator {
|
|
|
|
|
this.renderers = [];
|
|
|
|
|
this.uses = {};
|
|
|
|
|
|
|
|
|
|
// allow compiler to deconflict user's `import { get } from 'whatever'` and
|
|
|
|
|
// Svelte's builtin `import { get, ... } from 'svelte/shared.js'`;
|
|
|
|
|
this.importedNames = {};
|
|
|
|
|
this.aliases = {};
|
|
|
|
|
|
|
|
|
|
this.importedComponents = {};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -143,20 +138,6 @@ class DomGenerator extends Generator {
|
|
|
|
|
|
|
|
|
|
return this.alias( name );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
alias ( name ) {
|
|
|
|
|
if ( !( name in this.aliases ) ) {
|
|
|
|
|
let alias = name;
|
|
|
|
|
let i = 1;
|
|
|
|
|
while ( alias in this.importedNames ) {
|
|
|
|
|
alias = `${name}$${i++}`;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
this.aliases[ name ] = alias;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return this.aliases[ name ];
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export default function dom ( parsed, source, options, names ) {
|
|
|
|
@ -180,12 +161,6 @@ export default function dom ( parsed, source, options, names ) {
|
|
|
|
|
templateProperties.ondestroy = templateProperties.onteardown;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
generator.imports.forEach( node => {
|
|
|
|
|
node.specifiers.forEach( specifier => {
|
|
|
|
|
generator.importedNames[ specifier.local.name ] = true;
|
|
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
let namespace = null;
|
|
|
|
|
if ( templateProperties.namespace ) {
|
|
|
|
|
const ns = templateProperties.namespace.value.value;
|
|
|
|
@ -261,7 +236,7 @@ export default function dom ( parsed, source, options, names ) {
|
|
|
|
|
computations.forEach( ({ key, deps }) => {
|
|
|
|
|
builder.addBlock( deindent`
|
|
|
|
|
if ( isInitial || ${deps.map( dep => `( '${dep}' in newState && typeof state.${dep} === 'object' || state.${dep} !== oldState.${dep} )` ).join( ' || ' )} ) {
|
|
|
|
|
state.${key} = newState.${key} = template.computed.${key}( ${deps.map( dep => `state.${dep}` ).join( ', ' )} );
|
|
|
|
|
state.${key} = newState.${key} = ${generator.alias( 'template' )}.computed.${key}( ${deps.map( dep => `state.${dep}` ).join( ', ' )} );
|
|
|
|
|
}
|
|
|
|
|
` );
|
|
|
|
|
});
|
|
|
|
@ -338,9 +313,9 @@ export default function dom ( parsed, source, options, names ) {
|
|
|
|
|
if ( templateProperties.oncreate ) {
|
|
|
|
|
builders.init.addBlock( deindent`
|
|
|
|
|
if ( options._root ) {
|
|
|
|
|
options._root._renderHooks.push({ fn: template.oncreate, context: this });
|
|
|
|
|
options._root._renderHooks.push({ fn: ${generator.alias( 'template' )}.oncreate, context: this });
|
|
|
|
|
} else {
|
|
|
|
|
template.oncreate.call( this );
|
|
|
|
|
${generator.alias( 'template' )}.oncreate.call( this );
|
|
|
|
|
}
|
|
|
|
|
` );
|
|
|
|
|
}
|
|
|
|
@ -351,7 +326,7 @@ export default function dom ( parsed, source, options, names ) {
|
|
|
|
|
if ( generator.usesRefs ) constructorBlock.addLine( `this.refs = {};` );
|
|
|
|
|
|
|
|
|
|
constructorBlock.addLine(
|
|
|
|
|
`this._state = ${templateProperties.data ? `Object.assign( template.data(), options.data )` : `options.data || {}`};`
|
|
|
|
|
`this._state = ${templateProperties.data ? `Object.assign( ${generator.alias( 'template' )}.data(), options.data )` : `options.data || {}`};`
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
if ( templateProperties.computed ) {
|
|
|
|
@ -399,11 +374,11 @@ export default function dom ( parsed, source, options, names ) {
|
|
|
|
|
const sharedPath = options.shared === true ? 'svelte/shared.js' : options.shared;
|
|
|
|
|
|
|
|
|
|
if ( sharedPath ) {
|
|
|
|
|
const base = templateProperties.methods ? `{}, template.methods` : `{}`;
|
|
|
|
|
const base = templateProperties.methods ? `{}, ${generator.alias( 'template' )}.methods` : `{}`;
|
|
|
|
|
builders.main.addBlock( `${name}.prototype = Object.assign( ${base}, ${generator.helper( 'proto' )} );` );
|
|
|
|
|
} else {
|
|
|
|
|
if ( templateProperties.methods ) {
|
|
|
|
|
builders.main.addBlock( `${name}.prototype = template.methods;` );
|
|
|
|
|
builders.main.addBlock( `${name}.prototype = ${generator.alias( 'template' )}.methods;` );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[ 'get', 'fire', 'observe', 'on', 'set', '_flush' ].forEach( methodName => {
|
|
|
|
@ -418,7 +393,7 @@ export default function dom ( parsed, source, options, names ) {
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
${name}.prototype.teardown = ${name}.prototype.destroy = function destroy ( detach ) {
|
|
|
|
|
this.fire( 'destroy' );${templateProperties.ondestroy ? `\ntemplate.ondestroy.call( this );` : ``}
|
|
|
|
|
this.fire( 'destroy' );${templateProperties.ondestroy ? `\n${generator.alias( 'template' )}.ondestroy.call( this );` : ``}
|
|
|
|
|
|
|
|
|
|
this._fragment.teardown( detach !== false );
|
|
|
|
|
this._fragment = null;
|
|
|
|
|