@rasifix/orienteering-utils 2.0.48 → 2.0.50

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,4 +1,5 @@
1
1
  import * as kraemer from './kraemer';
2
+ import * as picoevents from './picoevents';
2
3
  import * as oware from './oware';
3
4
  import * as solv from './solv';
4
- export { kraemer, oware, solv };
5
+ export { kraemer, oware, picoevents, solv };
@@ -1,8 +1,10 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.solv = exports.oware = exports.kraemer = void 0;
3
+ exports.solv = exports.picoevents = exports.oware = exports.kraemer = void 0;
4
4
  var kraemer = require("./kraemer");
5
5
  exports.kraemer = kraemer;
6
+ var picoevents = require("./picoevents");
7
+ exports.picoevents = picoevents;
6
8
  var oware = require("./oware");
7
9
  exports.oware = oware;
8
10
  var solv = require("./solv");
@@ -0,0 +1,7 @@
1
+ import { Format } from "../format";
2
+ import { Competition } from "../model/competition";
3
+ export declare class PicoeventsFormat implements Format {
4
+ parse(text: string): Competition;
5
+ serialize(event: Competition): string;
6
+ check(text: string): boolean;
7
+ }
@@ -0,0 +1,100 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.PicoeventsFormat = void 0;
4
+ var time_1 = require("../time");
5
+ function clean(value) {
6
+ if (value) {
7
+ return value.startsWith('"') && value.endsWith('"')
8
+ ? value.substring(1, value.length - 1)
9
+ : value;
10
+ }
11
+ return value;
12
+ }
13
+ var PicoeventsFormat = /** @class */ (function () {
14
+ function PicoeventsFormat() {
15
+ }
16
+ PicoeventsFormat.prototype.parse = function (text) {
17
+ // convert CSV to JSON
18
+ var categories = {};
19
+ var lines = text.split(/\r?\n/);
20
+ var eventHeader = lines.splice(0, 1);
21
+ var result = {
22
+ id: eventHeader[1],
23
+ name: eventHeader[2],
24
+ map: eventHeader[7],
25
+ date: eventHeader[3],
26
+ startTime: eventHeader[4],
27
+ categories: [],
28
+ };
29
+ var header = lines.splice(0, 1)[0].split(",");
30
+ var sortKeyIdx = header.indexOf("[SORTKEY]");
31
+ var statusIdx = header.indexOf("[IOFRESSTATTEXT]");
32
+ var startTimeIdx = header.indexOf("[STARTFULLPREC]");
33
+ var noOfSplitsIdx = header.indexOf("[NOFSPLITS]");
34
+ var termIdx = header.indexOf("[TERM]");
35
+ var firstNameIdx = header.indexOf("[FIRSTNAME]");
36
+ var familyNameIdx = header.indexOf("[FAMILYNAME]");
37
+ var yobIdx = header.indexOf("[YOB]");
38
+ var townIdx = header.indexOf("[TOWN]");
39
+ var clubIdx = header.indexOf("[CLUB]");
40
+ var runtimeNetIdx = header.indexOf("[RUNTIMENET]");
41
+ lines.forEach(function (line, idx) {
42
+ var tokens = line.split(",");
43
+ if (tokens.length < 50) {
44
+ return;
45
+ }
46
+ var name = tokens[9];
47
+ if (name.indexOf("TW") !== -1 || name.indexOf("TM") !== -1) {
48
+ return;
49
+ }
50
+ var category = categories[name];
51
+ if (!category) {
52
+ category = {
53
+ name: name,
54
+ distance: 0,
55
+ ascent: 0,
56
+ controls: parseInt(tokens[noOfSplitsIdx]),
57
+ runners: [],
58
+ };
59
+ categories[name] = category;
60
+ result.categories.push(category);
61
+ }
62
+ var status = tokens[statusIdx];
63
+ if (status !== "OK") {
64
+ return;
65
+ }
66
+ var startTime = parseInt(tokens[startTimeIdx]);
67
+ var runner = {
68
+ id: tokens[sortKeyIdx] || "0",
69
+ category: name,
70
+ fullName: clean(tokens[firstNameIdx]) + " " + clean(tokens[familyNameIdx]),
71
+ yearOfBirth: tokens[yobIdx] || undefined,
72
+ city: clean(tokens[townIdx]),
73
+ club: clean(tokens[clubIdx]),
74
+ time: (0, time_1.formatTime)(parseInt(tokens[runtimeNetIdx])),
75
+ startTime: (0, time_1.formatTime)(startTime),
76
+ splits: [],
77
+ };
78
+ for (var i = termIdx + 3; i < tokens.length - 2; i += 2) {
79
+ var time = tokens[i + 1]
80
+ ? (0, time_1.formatTime)(parseInt(tokens[i + 1]) - startTime)
81
+ : "";
82
+ var code = tokens[i] === "9999" ? "Zi" : tokens[i];
83
+ runner.splits.push({ code: code, time: time });
84
+ }
85
+ category.runners.push(runner);
86
+ });
87
+ return result;
88
+ };
89
+ PicoeventsFormat.prototype.serialize = function (event) {
90
+ var result = "BasicData,".concat(event.id, ",\"").concat(event.name, "\",").concat(event.date, ",").concat(event.startTime, ",,,\"").concat(event.map, "\",\n");
91
+ result += "EXTCLASS=[DATATYPE],[SORTKEY],[ACTITEM],[NOFITEMS],[POINTER],[POSSPLITS],[RUNORLEG],[CLASSSORT],[BASECLASS],[FULLCLASS],[SUBSTCLASS],[COURSE],[MULTIHEATNUM],[REGTIME],[ISCLIQUE],[FAMILYNAME],[FIRSTNAME],[YOB],[SEX],[SEXLOC],[ZIP],[TOWN],[REGION],[COUNTRY],[FEDNR],[CLUB],[CLUBID],[NATION],[NATIONCODE],[IOFID],[RANKING],[GROUPNAME],[GROUPCLUB],[FOREIGNKEY],[REFPERS],[REFHEAT],[REFGRP],[REFEXT],[CARDHASDATA],[CARDNUM],[CARDNUMORIG],[RFID],[STARTNUM],[CLASSSTA],[COMBINATION],[DATEH0],[TIMEPREC],[STARTTIMELIST],[STARTTIMEGATE],[STARTTIMELATE],[STARTFULLPREC],[FINISHFULLPREC],[STARTPRECADJ],[FINISHPRECADJ],[RUNTIMEEFF],[RUNTIMENET],[RANKNET],[BEHINDNET],[PENALTY],[CREDIT],[NEUTRAL],[POINTS],[TIMEUSERMOD],[CARDUSERMOD],[RESPERSIDX],[RESCARDIDX],[IOFRESSTATTEXT],[INFOALL],[INFOMAND],[NOTCLASSTEXT],[RANKTEXT],[RESULTTEXT],[BEHINDTEXT],[PENCRENEUTTEXT],[SCHEDULED],[STARTED],[FINISHED],[SLIADDTEXT],[RESADDTEXT],[RENMERGINFO],[LIVEOFFSET],[LIVEINVALID1],[LIVEINVALID2],[LIVEINVALID3],[LEGMASSSTART],[LEGMAXTIMELIMIT],[LEGMAXTIMENCLA],[RELAYSTARTTIME],[RELCUMRUNTIMEEFF],[RELCUMRUNTIMENET],[RELCUMRANKNET],[RELCUMBEHINDNET],[RELCUMRANKTEXT],[RELCUMRESULTTEXT],[RELCUMBEHINDTEXT],[RELCUMPERSRESIDX],[RELCUMIOFSTATTEXT],[RELCUMINFOALL],[RELCUMINFOMAND],[RELCUMNOTCLATEXT],[RELCUMMASTAFLAG],[RELCUMSTARTED],[RELCUMFINISHED],[RELCUMORDERRES],[RELCUMSPARE2],[RELCUMSPARE3],[EXCLUDED],[NEGRUNTIME],[CLASSOKNOTREADY],[RESULTINVALID],[DOPSTATOK],[SLIORDER],[SORTORDERRES],[SUBSECRUNTIMENET],[STARTTIMEEXT],[FINISHTIMEEXT],[RUNTIMENETFULLPREC],[IMPORTGROUPID],[IMPORTUSER],[HIDETIME],[PAID],[RESERVE8],[RESERVE7],[RESERVE6],[RESERVE5],[RESERVE4],[LASTUPDATE],[MISSLISTCODE],[EXTRALISTCODE],[EXTRALISTTIME],[RADIOLISTCODE],[NOFSPLITS],[NOFSPLITPARAMS],[SPLITTYPE],[SPLITSTATUS],[TERM]\n";
92
+ // FIXME: implement serialization of runners
93
+ return result;
94
+ };
95
+ PicoeventsFormat.prototype.check = function (text) {
96
+ return text.startsWith("BasicData,");
97
+ };
98
+ return PicoeventsFormat;
99
+ }());
100
+ exports.PicoeventsFormat = PicoeventsFormat;
package/lib/index.d.ts CHANGED
@@ -1,5 +1,6 @@
1
1
  import * as formats from './formats';
2
2
  import * as ranking from './utils/ranking';
3
3
  import * as model from './model';
4
+ import { Format } from './format';
4
5
  import { formatTime, parseTime } from './time';
5
- export { formats, ranking, model, formatTime, parseTime };
6
+ export { formats, ranking, model, Format, formatTime, parseTime };
@@ -1,5 +1,6 @@
1
1
  import { Category } from "./category";
2
2
  export interface Competition {
3
+ id?: string;
3
4
  name: string;
4
5
  map?: string;
5
6
  date: string;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@rasifix/orienteering-utils",
3
- "version": "2.0.48",
3
+ "version": "2.0.50",
4
4
  "description": "utility functions for orienteering result analyzis",
5
5
  "main": "lib/index.js",
6
6
  "types": "lib/index.d.ts",