-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathindex.js
executable file
·90 lines (74 loc) · 2.41 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
var jsdom = require('jsdom');
var dashify = require('dashify');
var JSDOM = jsdom.JSDOM;
var getCss = function() {
// TODO (we can use BEM here)
return '';
}
var getTsCode = function(name, dashedName) {
return `import { Component } from '@angular/core';
@Component({
selector: '${dashedName}',
templateUrl: './${dashedName}.component.html',
styleUrls: ['./${dashedName}.component.css']
})
export class ${name}Component {
constructor () {}
}
`
}
var getSpec = function(name, dashedName) {
return `import { async, ComponentFixture, TestBed } from '@angular/core/testing';
import { ${name}Component } from './${dashedName}.component';
describe('${name}Component', () => {
let component: ${name}Component;
let fixture: ComponentFixture<${name}Component>;
beforeEach(async(() => {
TestBed.configureTestingModule({
declarations: [ ${name}Component ]
})
.compileComponents();
}));
beforeEach(() => {
fixture = TestBed.createComponent(${name}Component);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should be created', () => {
expect(component).toBeTruthy();
});
});
`
}
var generator = {
getComponentsFromHtml: function(fileText) {
var that = this;
var dom = new JSDOM(fileText);
var nodes = dom.window.document.querySelectorAll('[data-component]');
var nodesArray = Array.prototype.slice.call(nodes);
var components = nodesArray.reverse().map(function(node){
return that.getComponentFromNode(node);
});
return components;
},
getComponentFromNode: function(node) {
node = node.cloneNode(true);
var name = node.getAttribute('data-component');
var dashedName = dashify(name);
var children = node.querySelectorAll('[data-component]');
for (var i = 0; i < children.length; i++) {
var cmp = this.getComponentFromNode(children[i]);
children[i].outerHTML = '<' + cmp.dashedName + '>' + '</' + cmp.dashedName + '>';
}
node.removeAttribute('data-component');
return {
name: name,
dashedName: dashedName,
ts: getTsCode(name, dashedName),
spec: getSpec(name, dashedName),
css: getCss(),
html: node.outerHTML,
}
}
};
module.exports = generator;