|
|
@ -17,7 +17,7 @@ import clone from '../utils/clone';
|
|
|
|
import Stylesheet from '../css/Stylesheet';
|
|
|
|
import Stylesheet from '../css/Stylesheet';
|
|
|
|
import { test } from '../config';
|
|
|
|
import { test } from '../config';
|
|
|
|
import nodes from './nodes/index';
|
|
|
|
import nodes from './nodes/index';
|
|
|
|
import { Node, GenerateOptions, Parsed, CompileOptions, CustomElementOptions } from '../interfaces';
|
|
|
|
import { Node, GenerateOptions, ShorthandImport, Parsed, CompileOptions, CustomElementOptions } from '../interfaces';
|
|
|
|
|
|
|
|
|
|
|
|
interface Computation {
|
|
|
|
interface Computation {
|
|
|
|
key: string;
|
|
|
|
key: string;
|
|
|
@ -90,6 +90,7 @@ export default class Generator {
|
|
|
|
|
|
|
|
|
|
|
|
defaultExport: Node[];
|
|
|
|
defaultExport: Node[];
|
|
|
|
imports: Node[];
|
|
|
|
imports: Node[];
|
|
|
|
|
|
|
|
shorthandImports: ShorthandImport[];
|
|
|
|
helpers: Set<string>;
|
|
|
|
helpers: Set<string>;
|
|
|
|
components: Set<string>;
|
|
|
|
components: Set<string>;
|
|
|
|
events: Set<string>;
|
|
|
|
events: Set<string>;
|
|
|
@ -139,6 +140,7 @@ export default class Generator {
|
|
|
|
this.options = options;
|
|
|
|
this.options = options;
|
|
|
|
|
|
|
|
|
|
|
|
this.imports = [];
|
|
|
|
this.imports = [];
|
|
|
|
|
|
|
|
this.shorthandImports = [];
|
|
|
|
this.helpers = new Set();
|
|
|
|
this.helpers = new Set();
|
|
|
|
this.components = new Set();
|
|
|
|
this.components = new Set();
|
|
|
|
this.events = new Set();
|
|
|
|
this.events = new Set();
|
|
|
@ -315,7 +317,7 @@ export default class Generator {
|
|
|
|
generate(result: string, options: CompileOptions, { banner = '', sharedPath, helpers, name, format }: GenerateOptions ) {
|
|
|
|
generate(result: string, options: CompileOptions, { banner = '', sharedPath, helpers, name, format }: GenerateOptions ) {
|
|
|
|
const pattern = /\[✂(\d+)-(\d+)$/;
|
|
|
|
const pattern = /\[✂(\d+)-(\d+)$/;
|
|
|
|
|
|
|
|
|
|
|
|
const module = wrapModule(result, format, name, options, banner, sharedPath, helpers, this.imports, this.source);
|
|
|
|
const module = wrapModule(result, format, name, options, banner, sharedPath, helpers, this.imports, this.shorthandImports, this.source);
|
|
|
|
|
|
|
|
|
|
|
|
const parts = module.split('✂]');
|
|
|
|
const parts = module.split('✂]');
|
|
|
|
const finalChunk = parts.pop();
|
|
|
|
const finalChunk = parts.pop();
|
|
|
@ -517,7 +519,7 @@ export default class Generator {
|
|
|
|
`);
|
|
|
|
`);
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
const addDeclaration = (key: string, node: Node, disambiguator?: string, conflicts?: Record<string, boolean>) => {
|
|
|
|
const addDeclaration = (key: string, node: Node, allowShorthandImport?: boolean, disambiguator?: string, conflicts?: Record<string, boolean>) => {
|
|
|
|
const qualified = disambiguator ? `${disambiguator}-${key}` : key;
|
|
|
|
const qualified = disambiguator ? `${disambiguator}-${key}` : key;
|
|
|
|
|
|
|
|
|
|
|
|
if (node.type === 'Identifier' && node.name === key) {
|
|
|
|
if (node.type === 'Identifier' && node.name === key) {
|
|
|
@ -531,6 +533,11 @@ export default class Generator {
|
|
|
|
let name = this.getUniqueName(deconflicted);
|
|
|
|
let name = this.getUniqueName(deconflicted);
|
|
|
|
this.templateVars.set(qualified, name);
|
|
|
|
this.templateVars.set(qualified, name);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (allowShorthandImport && node.type === 'Literal' && typeof node.value === 'string') {
|
|
|
|
|
|
|
|
this.shorthandImports.push({ name, source: node.value });
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// deindent
|
|
|
|
// deindent
|
|
|
|
const indentationLevel = getIndentationLevel(source, node.start);
|
|
|
|
const indentationLevel = getIndentationLevel(source, node.start);
|
|
|
|
if (indentationLevel) {
|
|
|
|
if (indentationLevel) {
|
|
|
@ -548,7 +555,7 @@ export default class Generator {
|
|
|
|
|
|
|
|
|
|
|
|
if (templateProperties.components) {
|
|
|
|
if (templateProperties.components) {
|
|
|
|
templateProperties.components.value.properties.forEach((property: Node) => {
|
|
|
|
templateProperties.components.value.properties.forEach((property: Node) => {
|
|
|
|
addDeclaration(getName(property.key), property.value, 'components');
|
|
|
|
addDeclaration(getName(property.key), property.value, true, 'components');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -582,7 +589,7 @@ export default class Generator {
|
|
|
|
|
|
|
|
|
|
|
|
const prop = templateProperties.computed.value.properties.find((prop: Node) => getName(prop.key) === key);
|
|
|
|
const prop = templateProperties.computed.value.properties.find((prop: Node) => getName(prop.key) === key);
|
|
|
|
|
|
|
|
|
|
|
|
addDeclaration(key, prop.value, 'computed', {
|
|
|
|
addDeclaration(key, prop.value, false, 'computed', {
|
|
|
|
state: true,
|
|
|
|
state: true,
|
|
|
|
changed: true
|
|
|
|
changed: true
|
|
|
|
});
|
|
|
|
});
|
|
|
@ -599,13 +606,13 @@ export default class Generator {
|
|
|
|
|
|
|
|
|
|
|
|
if (templateProperties.events && dom) {
|
|
|
|
if (templateProperties.events && dom) {
|
|
|
|
templateProperties.events.value.properties.forEach((property: Node) => {
|
|
|
|
templateProperties.events.value.properties.forEach((property: Node) => {
|
|
|
|
addDeclaration(getName(property.key), property.value, 'events');
|
|
|
|
addDeclaration(getName(property.key), property.value, false, 'events');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (templateProperties.helpers) {
|
|
|
|
if (templateProperties.helpers) {
|
|
|
|
templateProperties.helpers.value.properties.forEach((property: Node) => {
|
|
|
|
templateProperties.helpers.value.properties.forEach((property: Node) => {
|
|
|
|
addDeclaration(getName(property.key), property.value, 'helpers');
|
|
|
|
addDeclaration(getName(property.key), property.value, false, 'helpers');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -660,13 +667,13 @@ export default class Generator {
|
|
|
|
|
|
|
|
|
|
|
|
if (templateProperties.transitions) {
|
|
|
|
if (templateProperties.transitions) {
|
|
|
|
templateProperties.transitions.value.properties.forEach((property: Node) => {
|
|
|
|
templateProperties.transitions.value.properties.forEach((property: Node) => {
|
|
|
|
addDeclaration(getName(property.key), property.value, 'transitions');
|
|
|
|
addDeclaration(getName(property.key), property.value, false, 'transitions');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (templateProperties.actions) {
|
|
|
|
if (templateProperties.actions) {
|
|
|
|
templateProperties.actions.value.properties.forEach((property: Node) => {
|
|
|
|
templateProperties.actions.value.properties.forEach((property: Node) => {
|
|
|
|
addDeclaration(getName(property.key), property.value, 'actions');
|
|
|
|
addDeclaration(getName(property.key), property.value, false, 'actions');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|