// vim: set tw=80 ts=2 sw=2 sts=2 : import { CurrencyPipe } from '@angular/common'; import { Component, Inject, Input, Output, EventEmitter } from '@angular/core'; import { NgbModal } from '@ng-bootstrap/ng-bootstrap'; import { ToastrService } from 'ngx-toastr'; var operationFormTmpl = require('./operation.form.tmpl.html'); import { Account } from '../accounts/account'; import { Operation } from './operation'; import { OperationService } from './operation.service'; import { OperationDeleteModalComponent } from './operationDeleteModal.component'; @Component({ selector: 'tr[operation-row]', host: { "[id]": "operation.id", "[class.stroke]": "operation.canceled", "[class.italic]": "!operation.confirmed", "[class.warning]": "operation.balance < 0", "[class.danger]": "operation.balance < account.authorized_overdraft" }, template: ` {{ operation.id }} {{ operation.operation_date | date:"yyyy-MM-dd" }} {{ operation.label }} {{ operation.value | currency:'EUR':true }} {{ operation.balance | currency:'EUR':true }} {{ operation.category }}
` }) export class OperationRowComponent { @Input('operation-row') operation: Operation; @Input() account: Account; @Output() needsReload: EventEmitter = new EventEmitter(); constructor( private operationService: OperationService, private toastrService: ToastrService, private modal: NgbModal, @Inject('$modal') private $modal, ) {} togglePointed(operation, rowform) { operation.pointed = !operation.pointed; this.save(operation); }; toggleCanceled(operation) { operation.canceled = !operation.canceled; this.save(operation); }; save(operation) { return this.operationService.update(operation).subscribe((operation) => { operation.confirmed = true; this.toastrService.success('Operation #' + operation.id + ' saved.'); this.needsReload.emit(); }, (result) => { this.toastrService.error( 'Error while saving operation: ' + result.message ); }); } confirmDelete(operation) { const modal = this.modal.open(OperationDeleteModalComponent); modal.componentInstance.operation = this.operation; var id = operation.id; modal.result.then((operation: Operation) => { this.delete(operation); }, (reason) => { }) }; delete(operation) { var id = operation.id; return this.operationService.delete(operation).subscribe(() => { this.toastrService.success('Operation #' + id + ' deleted.'); this.needsReload.emit(); }, (result) => { this.toastrService.error( 'An error occurred while trying to delete operation #' + id + ':
' + result ); }); }; modify(operation) { // FIXME Alexis Lahouze 2017-06-15 i18n var title = "Modify operation #" + operation.id; this.$modal({ templateUrl: operationFormTmpl, controller: function($scope, title, operation, $save) { $scope.title = title; $scope.operation = operation; $scope.$save = () => { $scope.$hide(); $save($scope.operation); }; }, locals: { title: title, operation: operation, $save: (operation: Operation) => { this.save(operation); } } }); }; }