const Component = require(`vn-print/core/component`);
const reportBody = new Component('report-body');
const jsBarcode = require('jsbarcode');
const {DOMImplementation, XMLSerializer} = require('xmldom');
const UserError = require('vn-loopback/util/user-error');
const qrcode = require('qrcode');

module.exports = {
    name: 'expedition-pallet-label',
    props: {
        id: {
            type: Number,
            required: true,
            description: 'The pallet id'
        },
        userFk: {
            type: Number,
            required: true,
            description: 'The user id'
        }
    },
    async serverPrefetch() {
        this.labelsData = await this.rawSqlFromDef('labelData', this.id);
        this.username = await this.findOneFromDef('username', this.userFk);
        this.labelData = this.labelsData[0];

        let QRdata = JSON.stringify({
            company: 'vnl',
            user: this.userFk,
            created: new Date(),
            table: 'expeditionPallet',
            id: this.id
        });

        this.QR = await this.getQR(QRdata);
        if (!this.labelsData.length)
            throw new UserError('Empty data source');
    },
    methods: {
        getQR(id) {
            const data = String(id);
            return qrcode.toDataURL(data, {margin: 0});
        },
        getBarcode(id) {
            const xmlSerializer = new XMLSerializer();
            const document = new DOMImplementation().createDocument('http://www.w3.org/1999/xhtml', 'html', null);
            const svgNode = document.createElementNS('http://www.w3.org/2000/svg', 'svg');

            jsBarcode(svgNode, id, {
                xmlDocument: document,
                format: 'code128',
                displayValue: false,
                width: 6,
                height: 90,
            });
            return xmlSerializer.serializeToString(svgNode);
        },
    },
    components: {
        'report-body': reportBody.build()
    },
};