Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/superdev-tech/nuxt-plotly
📊 Enhance your Nuxt 3 projects with interactive data visualizations using nuxt-plotly – Simplified Plotly.js integration made easy!
https://github.com/superdev-tech/nuxt-plotly
charting data-visualization frontend interactive-visualizations javascript nuxt nuxtjs plotly
Last synced: 18 days ago
JSON representation
📊 Enhance your Nuxt 3 projects with interactive data visualizations using nuxt-plotly – Simplified Plotly.js integration made easy!
- Host: GitHub
- URL: https://github.com/superdev-tech/nuxt-plotly
- Owner: superdev-tech
- License: mit
- Created: 2023-07-21T06:37:30.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-07-08T11:52:18.000Z (7 months ago)
- Last Synced: 2025-01-02T05:12:07.209Z (25 days ago)
- Topics: charting, data-visualization, frontend, interactive-visualizations, javascript, nuxt, nuxtjs, plotly
- Language: Vue
- Homepage: https://stackblitz.com/edit/nuxt-starter-1bs1ke?file=app.vue
- Size: 1.44 MB
- Stars: 27
- Watchers: 1
- Forks: 4
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# Nuxt Plotly Module
📊 `nuxt-plotly` module is thin Nuxt3 wrapper for [plotly.js](https://plotly.com/javascript/)
- [🏀 Online playground](https://stackblitz.com/edit/nuxt-starter-1bs1ke?file=app.vue)
- [📖 Plotly Documentation](https://plotly.com/javascript/plotly-fundamentals/)## Features
- 🎇 All plotly.js methods and events
- 🗾 Auto redraw on screensize changes and props update
- 🚀 Data reactivity
- 🏝️ TypeScript support## Quick Setup
1. Add `nuxt-plotly` dependency to your project
```bash
npx nuxi@latest module add nuxt-plotly
```2. Add `nuxt-plotly` to the `modules` section of `nuxt.config.ts`
```js
// nuxt.config.js
export default defineNuxtConfig({
/**
* Add nuxt-plotly module
*/
modules: ["nuxt-plotly"],/**
* Add nuxt-plotly module with options
* Set the inject option to true to use plotly function via $plotly
*/
// modules: [["nuxt-plotly", { inject: true }]],
});
```3. Add `plotly.js-dist-min` to the `vite.optimizeDeps.include` section of `nuxt.config.ts`
```js
// nuxt.config.js
export default defineNuxtConfig({
vite: {
optimizeDeps: {
include: ["plotly.js-dist-min"],
},
},
});
```That's it! You can now use Nuxt Plotly Module in your Nuxt app ✨
## Require client-side
There are two ways to use the `nuxt-plotly` module on the client-side in Nuxt3:
1. Wrap the component with the `` tag.
```html
```
2. Create a file with the `.client.vue` extension, for example, [PieChart.client.vue](https://github.com/superdev-tech/nuxt-plotly/blob/main/playground/components/PieChart.client.vue) and then you can use the component without the `` tag.
## Plotly Event listeners
You can access [Plotly events](https://plotly.com/javascript/plotlyjs-events) using the `@on-ready` directive to receive the `PlotlyHTMLElement` object from the `` component.
- HTML template example
```html
```
- After receiving the PlotlyHTMLElement, you can access Plotly events
```typescript
function myChartOnReady(plotlyHTMLElement: NuxtPlotlyHTMLElement) {
console.log({ plotlyHTMLElement });plotlyHTMLElement.on?.("plotly_afterplot", function () {
console.log("done plotting");
});plotlyHTMLElement.on?.("plotly_click", function () {
alert("You clicked this Plotly chart!");
});
}
```## Plotly Functions
To use the [Plotly Function](https://plotly.com/javascript/plotlyjs-function-reference/) in your nuxt project, follow these steps:
- Step 1: Set the `inject` option to `true` in the `nuxt-plotly` module configuration of your `nuxt.config.ts` file.
```js
// nuxt.config.js
export default defineNuxtConfig({
modules: [["nuxt-plotly", { inject: true }]],
});
```- Step 2: After setting the inject option to true, you can now access the plotly function via `$plotly` in your nuxt project.
```ts
// app.vueconst { $plotly } = useNuxtApp();
/**
* Show all plotly functions
*/
console.log($plotly);/**
* Use downloadImage function
*/
$plotly.downloadImage(plotlyHTMLElement as HTMLElement, {
format: "png",
width: 800,
height: 600,
filename: "newplot",
});
```## Type Aliases
These type aliases simplify the usage of Plotly types in your Nuxt project:
```typescript
/**
* Represents an array of Plotly data objects.
*/
export type NuxtPlotlyData = Array;/**
* Represents a partial configuration object for Plotly charts.
*/
export type NuxtPlotlyConfig = Partial;/**
* Represents a partial layout object for Plotly charts.
*/
export type NuxtPlotlyLayout = Partial;/**
* Represents a partial HTML element that holds a rendered Plotly chart.
*/
export type NuxtPlotlyHTMLElement = Partial;
```With these type aliases, you can easily work with Plotly data, configurations, layouts, and HTML elements in your Nuxt application, enhancing your experience when creating interactive charts and visualizations.
## Development: If you want to contribute
```bash
# Install dependencies
npm install# Generate type stubs
npm run dev:prepare# Develop with the playground
npm run dev# Build the playground
npm run dev:build# Run ESLint
npm run lint# Run Vitest
npm run test
npm run test:watch# Release new version
npm run release
```## License
Copyright © 2023 [Supanut Dokmaithong](https://github.com/Boomgeek).
This project is [MIT licensed](https://github.com/superdev-tech/nuxt-plotly/blob/main/LICENSE).