wip
This commit is contained in:
parent
fff4fdea81
commit
89e36d7eb0
8 changed files with 0 additions and 6074 deletions
93
tests/web.rs
93
tests/web.rs
|
@ -1,93 +0,0 @@
|
|||
//! Test suite for the Web and headless browsers.
|
||||
|
||||
#![cfg(target_arch = "wasm32")]
|
||||
|
||||
extern crate wasm_bindgen_test;
|
||||
use wasm_bindgen_test::*;
|
||||
|
||||
wasm_bindgen_test_configure!(run_in_browser);
|
||||
|
||||
#[wasm_bindgen_test]
|
||||
fn basic_merge() {
|
||||
// arrange
|
||||
let array: js_sys::Array = js_sys::Array::new();
|
||||
let file1 = wasm_bindgen::JsValue::from_str(
|
||||
"<?xml version='1.0' encoding='utf-8'?>
|
||||
<gpx version='1.0' encoding='UTF-8'>
|
||||
<trk>
|
||||
<name>file1 tracks</name>
|
||||
<type>1</type>
|
||||
<trkseg>
|
||||
<trkpt lat='35.466388' lon='-111.640076'>
|
||||
<ele>2152.8</ele>
|
||||
<time>2020-09-27T15:39:27+00:00</time>
|
||||
</trkpt>
|
||||
</trkseg>
|
||||
</trk>
|
||||
</gpx>",
|
||||
);
|
||||
let file2 = wasm_bindgen::JsValue::from_str(
|
||||
"<?xml version='1.0' encoding='utf-8'?>
|
||||
<gpx version='1.0' encoding='UTF-8'>
|
||||
<trk>
|
||||
<name>file2 tracks</name>
|
||||
<type>1</type>
|
||||
<trkseg>
|
||||
<trkpt lat='35.339854' lon='-111.737165'>
|
||||
<ele>2556.8</ele>
|
||||
<time>2020-09-26T19:07:14+00:00</time>
|
||||
</trkpt>
|
||||
</trkseg>
|
||||
</trk>
|
||||
</gpx>",
|
||||
);
|
||||
array.push(&file1);
|
||||
array.push(&file2);
|
||||
|
||||
let exp = wasm_bindgen::JsValue::from_str(
|
||||
"<?xml version=\"1.0\" encoding=\"utf-8\"?>
|
||||
<gpx version=\"1.1\" creator=\"https://github.com/georust/gpx\">
|
||||
<metadata>
|
||||
<name>merged</name>
|
||||
<author>
|
||||
<link href=\"https://gpx.thermokar.st\" />
|
||||
</author>
|
||||
</metadata>
|
||||
<trk>
|
||||
<name>file1 tracks</name>
|
||||
<type>1</type>
|
||||
<trkseg>
|
||||
<trkpt lat=\"35.466388\" lon=\"-111.640076\">
|
||||
<ele>2152.8</ele>
|
||||
<time>2020-09-27T15:39:27+00:00</time>
|
||||
</trkpt>
|
||||
</trkseg>
|
||||
</trk>
|
||||
<trk>
|
||||
<name>file2 tracks</name>
|
||||
<type>1</type>
|
||||
<trkseg>
|
||||
<trkpt lat=\"35.339854\" lon=\"-111.737165\">
|
||||
<ele>2556.8</ele>
|
||||
<time>2020-09-26T19:07:14+00:00</time>
|
||||
</trkpt>
|
||||
</trkseg>
|
||||
</trk>
|
||||
<rte />
|
||||
</gpx>",
|
||||
);
|
||||
|
||||
// act
|
||||
let obs = gpx_web_utils::merge(array);
|
||||
|
||||
// assert
|
||||
assert_eq!(obs, exp);
|
||||
}
|
||||
|
||||
// TODO: https://github.com/rustwasm/wasm-bindgen/issues/2286
|
||||
// #[wasm_bindgen_test]
|
||||
// #[should_panic]
|
||||
// fn invalid_inputs() {
|
||||
// let array: js_sys::Array = js_sys::Array::new_with_length(10);
|
||||
// let obs = gpx_web_utils::merge(array);
|
||||
// }
|
2
www/.gitignore
vendored
2
www/.gitignore
vendored
|
@ -1,2 +0,0 @@
|
|||
node_modules
|
||||
dist
|
5
www/bootstrap.js
vendored
5
www/bootstrap.js
vendored
|
@ -1,5 +0,0 @@
|
|||
// A dependency graph that contains any wasm must all be imported
|
||||
// asynchronously. This `bootstrap.js` file does the single async import, so
|
||||
// that no one else needs to worry about it again.
|
||||
import("./index.js")
|
||||
.catch(e => console.error("Error importing `index.js`:", e));
|
|
@ -1,46 +0,0 @@
|
|||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<meta charset="utf-8">
|
||||
<title>gpx.thermokar.st</title>
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||
<style>
|
||||
body {
|
||||
max-width: 35em;
|
||||
margin: 0 auto;
|
||||
line-height: 1.5;
|
||||
font-family: sans-serif;
|
||||
font-size: large;
|
||||
}
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
<h1>
|
||||
<a href="https://gpx.thermokar.st">gpx.thermokar.st</a>
|
||||
</h1>
|
||||
<noscript>
|
||||
<mark>
|
||||
This page contains webassembly and javascript content, please enable
|
||||
javascript in your browser.
|
||||
</mark>
|
||||
</noscript>
|
||||
<p>
|
||||
This client-side tool is for merging
|
||||
<a href="https://www.topografix.com/gpx.asp">GPX files</a>.
|
||||
Please note, this has only been tested on GPX files produced by
|
||||
<a href="https://www.garmin.com">Garmin</a> and
|
||||
<a href="https://www.strava.com">Strava</a> - your mileage may vary.
|
||||
</p>
|
||||
<form>
|
||||
<input id="gpxInput" type="file" multiple accept="text/gpx,.gpx">
|
||||
</form>
|
||||
<hr>
|
||||
<p>
|
||||
<small>
|
||||
<a href="https://github.com/thermokarst/gpx-web-utils">
|
||||
https://github.com/thermokarst/gpx-web-utils</a>
|
||||
</small>
|
||||
</p>
|
||||
<script src="./bootstrap.js"></script>
|
||||
</body>
|
||||
</html>
|
37
www/index.js
37
www/index.js
|
@ -1,37 +0,0 @@
|
|||
import * as gpx from "gpx-web-utils";
|
||||
|
||||
const inputElement = document.getElementById("gpxInput");
|
||||
const loadingElement = document.createElement("span");
|
||||
|
||||
loadingElement.innerHTML = "<strong>processing...</strong>";
|
||||
inputElement.value = "";
|
||||
inputElement.addEventListener("change", readFiles, false);
|
||||
|
||||
function readFiles() {
|
||||
if (inputElement.files.length < 2) { alert("open two or more files"); return; }
|
||||
|
||||
inputElement.replaceWith(loadingElement);
|
||||
const files = Array.from(inputElement.files);
|
||||
const promises = files.map(f => f.text());
|
||||
|
||||
Promise.all(promises).then(gpxes => {
|
||||
try {
|
||||
const merged = gpx.merge(gpxes);
|
||||
writeOutput(merged);
|
||||
} catch {
|
||||
alert("there was a problem, please check the console.");
|
||||
} finally {
|
||||
inputElement.value = "";
|
||||
loadingElement.replaceWith(inputElement);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
function writeOutput(file) {
|
||||
const blob = new Blob([file], {type: "text/gpx"});
|
||||
const anchorElement = document.createElement("a");
|
||||
anchorElement.href = URL.createObjectURL(blob);
|
||||
anchorElement.download = "merged.gpx";
|
||||
anchorElement.click();
|
||||
URL.revokeObjectURL(anchorElement.href);
|
||||
}
|
5842
www/package-lock.json
generated
5842
www/package-lock.json
generated
File diff suppressed because it is too large
Load diff
|
@ -1,35 +0,0 @@
|
|||
{
|
||||
"name": "gpx-web-utils",
|
||||
"version": "0.0.1",
|
||||
"description": "just some gpx-related tools that i want to use.",
|
||||
"main": "index.js",
|
||||
"scripts": {
|
||||
"build": "webpack --config webpack.config.js",
|
||||
"start": "webpack-dev-server"
|
||||
},
|
||||
"repository": {
|
||||
"type": "git",
|
||||
"url": "git+https://github.com/thermokarst/gpx-web-utils.git"
|
||||
},
|
||||
"keywords": [
|
||||
"webassembly",
|
||||
"wasm",
|
||||
"rust",
|
||||
"webpack"
|
||||
],
|
||||
"author": "Matthew Ryan Dillon <matthewrdillon@gmail.com>",
|
||||
"license": "MIT",
|
||||
"bugs": {
|
||||
"url": "https://github.com/thermokarst/gpx-web-utils/issues"
|
||||
},
|
||||
"homepage": "https://github.com/thermokarst/gpx-web-util#readme",
|
||||
"dependencies": {
|
||||
"gpx-web-utils": "file:../pkg"
|
||||
},
|
||||
"devDependencies": {
|
||||
"webpack": "^4.29.3",
|
||||
"webpack-cli": "^3.1.0",
|
||||
"webpack-dev-server": "^3.1.5",
|
||||
"copy-webpack-plugin": "^5.0.0"
|
||||
}
|
||||
}
|
|
@ -1,14 +0,0 @@
|
|||
const CopyWebpackPlugin = require("copy-webpack-plugin");
|
||||
const path = require('path');
|
||||
|
||||
module.exports = {
|
||||
entry: "./bootstrap.js",
|
||||
output: {
|
||||
path: path.resolve(__dirname, "dist"),
|
||||
filename: "bootstrap.js",
|
||||
},
|
||||
mode: "development",
|
||||
plugins: [
|
||||
new CopyWebpackPlugin(['index.html'])
|
||||
],
|
||||
};
|
Loading…
Add table
Reference in a new issue