basic-editor.component.ts
1.5 KB
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.html",
providers: [
provide('articleService', { useClass: ArticleService }),
provide('profileService', { useClass: ProfileService }),
provide('notification', { useClass: NotificationService })
]
})
@Inject(ArticleService, ProfileService, "$state", NotificationService)
export class BasicEditorComponent {
article: noosfero.Article = <noosfero.Article>{};
constructor(private articleService: ArticleService,
private profileService: ProfileService,
private $state: ng.ui.IStateService,
private notification: NotificationService) { }
save() {
this.profileService.getCurrentProfile().then((profile: noosfero.Profile) => {
return this.articleService.createInProfile(profile, this.article);
}).then((response: noosfero.RestResult<noosfero.Article>) => {
let article = (<noosfero.Article>response.data);
this.$state.transitionTo('main.profile.page', { page: article.path, profile: article.profile.identifier });
this.notification.success({ title: "Good job!", message: "Article saved!" });
});
}
}