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
|
import {Component} from "angular2/core";
import {Router, RouteParams} from "angular2/router";
import {RouteConfig, ROUTER_DIRECTIVES} from "angular2/router";
import {HTTP_PROVIDERS} from "angular2/http";
import {Title} from "angular2/platform/browser";
import {HomeComponent} from "./home.component";
import {SnippetDetailComponent} from "./snippet-detail.component";
import {Snippet, SnippetService} from "./snippet.service";
import {EditingData, EditingDataService} from "./editing-data.service";
import {EditorComponent} from "./editor.component";
@Component({
selector: "my-app",
template: `
<nav class="navbar">
<div class="brand">
<a class="navbar-brand" href="#">{{generateHeader()}}</a>
</div>
<!--<ul>
<li><a href="/">about poe</a></li>
</ul>-->
</nav>
<div class="container">
<div class="panel panel-default">
<div class="panel-body">
<form (ngSubmit)="onSubmit()">
<div class="form-group" id="code-field">
<editor (onSubmit)="onSubmit()" [(value)]="editing.code" [mode]="editing.lang"></editor>
</div>
<div class="form-group form-inline">
<select class="form-control" [(ngModel)]="editing.lang" required>
<option *ngFor="#p of availableLangs()" [value]="p">{{p}}</option>
</select>
<button class="btn btn-default" type="submit">Run</button>
</div>
</form>
</div>
</div>
<router-outlet></router-outlet>
</div>
`,
directives: [ROUTER_DIRECTIVES, EditorComponent],
providers: [SnippetService, EditingDataService, Title],
})
@RouteConfig([
{ path: "/", name: "Home", component: HomeComponent },
{ path: "/:sid", name: "SnippetDetail", component: SnippetDetailComponent },
])
export class AppComponent {
editing: EditingData;
constructor(
private _service: SnippetService,
private _router: Router,
_edit_service: EditingDataService,
private _title: Title) {
this.editing = _edit_service.get();
this.editing.onChange(e => this._title.setTitle(this.generateTitle()));
}
onSubmit() {
this._service.createSnippet(this.editing).subscribe(
snip => this._router.navigate(["SnippetDetail", { sid: snip.id }]),
error => console.log(error)
);
}
// これなんとかならない?
availableLangs() {
return EditingData.availableLangs;
}
generateHeader() {
const summary = this.editing.summarize();
if (summary === "")
return "poe: eval in 30+ Ruby interpreters";
else
return summary;
}
generateTitle() {
return this.generateHeader() + " - poe";
}
}
|