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, "$stateParams") export class BasicEditorComponent { article: noosfero.Article = {}; parentId: number; 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']; } save() { this.profileService.getCurrentProfile().then((profile: noosfero.Profile) => { return this.articleService.createInParent(this.parentId, this.article); }).then((response: noosfero.RestResult) => { let 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!" }); }); } }