Как сделать PDF на стороне сервера из Vue-Tables-2, Vue Js и Laravel - PullRequest
0 голосов
/ 04 октября 2018

У меня есть данные Vue-tables-2, что у меня есть метод createPDF() для кнопки - работа в качестве генератора pdf на стороне клиента с использованием pdfmake

После проверки мой клиент предпочитает использовать server-side генератор PDF.Я вижу, что у pdfmake есть и клиент / серверная сторона, но я изо всех сил пытаюсь найти примеры, которым я могу следовать.

Как можно:

  • Реализовать pdf на стороне сервера, используя pdfmake
  • Или перейти на пакет, который лучше для генерации pdf на стороне сервера

Вот мой pdf-код на стороне клиента в моем компоненте vue-tables-2:

<template>
    <el-container>
        <side-nav></side-nav>
        <el-main>
            <v-server-table url="/getListings" :data="tableData" :columns="columns" :options="options">
                <input slot="selected" slot-scope="props" type="checkbox" :checked="props.row.selected" v-model="checkedRows" :value="props.row">
                <button slot="afterFilter" type="button" class="btn btn-primary btn-pdf" @click="createPDF">Create Purchase Order</button>
            </v-server-table>
        </el-main>
    </el-container>
</template>


<script>

import {ServerTable, Event} from 'vue-tables-2';    
Vue.use(ServerTable, {}, false, 'bootstrap4');

var pdfMake = require('pdfmake/build/pdfmake.js');
    var pdfFonts = require('pdfmake/build/vfs_fonts.js');
    pdfMake.vfs = pdfFonts.pdfMake.vfs;

export default {
    data() {
        return {
            toggle:[],
            tableData: [],
            checkedRows: [],
            columns: [
                'selected',
                'sku',
            ],     
            options: {

            }
        }
    },

    methods: {

        createPDF() {
            var docDefinition = {
            content: [
                {
                    table: {
                        headerRows: 1,
                        widths: [ 'auto' ],

                        body: [
                            [{text: 'sku', bold: true}]
                        ]
                    }
                }
            ]
            };
            for(var i=0;i<this.checkedRows.length;i++){
                docDefinition.content[0].table.body.push(Object.values(this.checkedRows[i]));  
            }
            pdfMake.createPdf(docDefinition).download('PO.pdf');
        }            
    }
}

</script>
...