0.3.1 • Published 10 months ago
@flatfile/plugin-enrich-gpx v0.3.1
@flatfile/plugin-enrich-gpx
A powerful Flatfile Listener plugin for parsing and analyzing GPX (GPS Exchange Format) files. This plugin extracts valuable information from GPX files, performs data processing, and provides statistical analysis.
Event Type:
listener.on('commit:created')
Features
- Parse GPX files containing waypoints, tracks, and routes
- Convert GPX data to a tabular format
- Calculate total distance and elevation gain
- Remove duplicate points
- Filter data by date range
- Extract metadata such as name and description
- Count waypoints, tracks, and routes
Installation
To install the plugin, run the following command:
npm install @flatfile/plugin-enrich-gpxExample Usage
import { FlatfileListener } from "@flatfile/listener";
import { enrichGpx } from "@flatfile/plugin-enrich-gpx";
export default function (listener: FlatfileListener) {
  listener.use(enrichGpx({
    sheetSlug: 'gpx-data',
    gpxFileField: 'gpx_file',
    removeDuplicatesField: 'remove_duplicates',
    filterDatesField: 'filter_dates',
    startDateField: 'start_date',
    endDateField: 'end_date'
  }));
}Configuration
The plugin accepts the following configuration options through record fields:
- sheetSlug: (Required) The sheet to apply the GPX enrichment to as a string
- gpxFileField: (Required) The field in the record that contains the GPX file content as a string
- remove_duplicates: Set to "true" to remove duplicate points
- filter_dates: Set to "true" to filter points by date range
- start_date: The start date for filtering (when- filter_datesis true)
- end_date: The end date for filtering (when- filter_datesis true)
Behavior
- The plugin parses the GPX file content provided in the gpx_filefield.
- It extracts waypoints, tracks, and routes from the GPX data.
- The data is converted to a tabular format for easier processing.
- If remove_duplicatesis set to "true", duplicate points are removed.
- If filter_datesis set to "true" and valid start and end dates are provided, the data is filtered by date range.
- The plugin calculates statistics such as total distance and elevation gain.
- Metadata and statistics are set on the record fields:- name: Name from GPX metadata
- description: Description from GPX metadata
- waypoint_count: Number of waypoints
- track_count: Number of tracks
- route_count: Number of routes
- total_distance: Calculated total distance in kilometers
- elevation_gain: Calculated elevation gain in meters
- point_count: Total number of points after processing
- tabular_data: JSON string of the processed tabular data
 
The plugin handles errors gracefully and adds appropriate error messages to the record if parsing fails or required data is missing.