How to use the Web Report Designer in Vue.js
Environment
Product | Progress® Telerik® Reporting |
Framework | Vue.js |
Description
The Web Report Designer is built upon HTML5, CSS, JavaScript, jQuery and Kendo.
This allows the viewer to be used in virtually any JavaScript framework, such as Vue.js.
The solution we are about to examine is a very basic approach to create a new Vue.js application, include the designer's dependencies, and display it in the application.
Solution
The following guide assumes previous knowledge of Vue.js
-
Start by creating a new Vue application using the following CLI command:
npm init vue@latest
-
Add a reference to jQuery in
index.html
:<script src="https://code.jquery.com/jquery-3.3.1.min.js"></script>
-
Add a reference to the Kendo JS library in
index.html
:<script src="https://kendo.cdn.telerik.com/2022.1.301/js/kendo.all.min.js"></script>
-
Add references to the Web Report Designer and Report Viewer JS resources, again to
index.html
:<script src="https://demos.telerik.com/reporting/api/reports/resources/js/telerikReportViewer"></script> <script src="https://demos.telerik.com/reporting/api/reportdesigner/designerresources/js/webReportDesigner"></script>
-
Create a new web report designer component and configure the routes accordingly. The new component contains a
div
element to hold the web report designer object and applies CSS to this element. The component calls thetelerik_webReportDesiger
method to initialize the web report designer widget with the specified configuration options. It is important that theserviceUrl
option points to the URL of a working Reporting REST Service. How to implement this service is described in the article How to Host Reports Service in ASP.NET Core 3.1.<template> <div id="wrd1">...</div> </template> <script> export default { name: "WebReportDesigner", mounted() { this.$nextTick(function () { $("#wrd1") .telerik_WebReportDesigner({ toolboxArea: { layout: "list", //Change to "grid" to display the contents of the Components area in a flow grid layout. }, serviceUrl: "https://demos.telerik.com/reporting/api/reportdesigner/", report: "Barcodes Report.trdx", }) .data("telerik_WebDesigner"); }); }, }; </script> <!-- Add "scoped" attribute to limit CSS to this component only --> <style scoped> #wrd1 { position: relative; height: 880px; } </style>
-
Run the app
npm run dev