basic-editor.component.ts
2.31 KB
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
import {StateConfig, Component, Inject, provide} from 'ng-forward';
import {ArticleService} from "../../../lib/ng-noosfero-api/http/article.service";
import {ProfileService} from "../../../lib/ng-noosfero-api/http/profile.service";
import {NotificationService} from "../../shared/services/notification.service.ts";
@Component({
selector: 'article-basic-editor',
templateUrl: "app/article/basic-editor/basic-editor.html",
providers: [
provide('articleService', { useClass: ArticleService }),
provide('profileService', { useClass: ProfileService }),
provide('notification', { useClass: NotificationService })
]
})
@Inject(ArticleService, ProfileService, "$state", NotificationService, "$stateParams")
export class BasicEditorComponent {
article: noosfero.Article = <noosfero.Article>{};
parent: noosfero.Article = <noosfero.Article>{};
parentId: number;
profileIdentifier: string;
editorOptions = {};
constructor(private articleService: ArticleService,
private profileService: ProfileService,
private $state: ng.ui.IStateService,
private notification: NotificationService,
private $stateParams: ng.ui.IStateParamsService) {
this.parentId = this.$stateParams['parent_id'];
this.profileIdentifier = this.$stateParams["profile"];
this.articleService.get(this.parentId).then((result: noosfero.RestResult<noosfero.Article>) => {
this.parent = result.data;
});
}
save() {
this.profileService.setCurrentProfileByIdentifier(this.profileIdentifier).then((profile: noosfero.Profile) => {
return this.articleService.createInParent(this.parentId, this.article);
}).then((response: noosfero.RestResult<noosfero.Article>) => {
let article = (<noosfero.Article>response.data);
this.$state.go('main.profile.page', { page: article.path, profile: article.profile.identifier });
this.notification.success({ title: "Good job!", message: "Article saved!" });
});
}
cancel() {
if (this.parent && this.parent.path) {
this.$state.go('main.profile.page', { page: this.parent.path, profile: this.profileIdentifier });
} else {
this.$state.go('main.profile.home', { profile: this.profileIdentifier });
}
}
}