Угловой 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
в разделе скриптов