aboutsummaryrefslogtreecommitdiffstats
path: root/frontend/app/app.component.ts
blob: 662f34f789becef9e83835f562d292ef0a1b8683 (plain)
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";
  }
}