Угловой POS Print Issue

Мое требование: печать без предварительного просмотра угловой 6

Единственное решение, которое я нашел

Angular 2 Raw Printing Service Я использую ссылку думаю для угловой печати POS

У меня есть другие альтернативы?

.ts код

 printInvoice() {
  console.log(this.printService.getPrinters());
  }

Мой Сервисный код

import { Observable } from 'rxjs';
import 'rxjs/add/observable/fromPromise';
import 'rxjs/add/observable/throw';
import 'rxjs/add/operator/map';
import 'rxjs/add/operator/catch';
import { Injectable } from '@angular/core';
import * as shajs from 'sha.js';
import * as qz from 'qz-tray';
**import * as RSVP from 'rsvp';**

@Injectable()
export class QzTrayService {
    constructor() { }

    errorHandler(error: any): Observable<any> {
        console.log('error handler');
        return Observable.throw(error);
    }

    // Get list of printers connected
    getPrinters(): Observable<string[]> {
        console.log(Observable
            .fromPromise(qz.websocket.connect()
                .then(() => qz.printers.find()))
            .map((printers: string[]) => printers) );
        return Observable
            .fromPromise(qz.websocket.connect()
            .then(() => qz.printers.find()))
            .map((printers: string[]) => printers)
            .catch(this.errorHandler);
    }

    // Get the SPECIFIC connected printer
    getPrinter(printerName: string): Observable<string> {
        return Observable
            .fromPromise(qz.websocket.connect().then(() => qz.printers.find(printerName)))
            .map((printer: string) => printer)
            .catch(this.errorHandler);
    }

    // Print data to chosen printer
    printData(printer: string, data: any): Observable<any> {
        // Create a default config for the found printer
        const config = qz.configs.create(printer);
        return Observable.fromPromise(qz.print(config, data))
            .map((anything: any) => anything)
            .catch(this.errorHandler);
    }

    // Disconnect QZ Tray from the browser
    removePrinter(): void {
        qz.websocket.disconnect();
    }
}

Ошибка:

Я получаю RSVP не определено, как это исправить?

введите описание изображения здесь

1 ответ

Решение

Добавление его в этот файл не сделает его доступным для других сценариев.

Вы должны включить его в качестве глобального скрипта.

Для этого добавьте в ваш index.html следующее:

<head>
   <script src="../node_modules/rsvp/dist/rsvp.min.js"></script>
</head> 

Кроме того, вы можете включить его в angular.json в разделе скриптов

Другие вопросы по тегам