UNPKG

trackswap

Version:

A powerful and flexible GPX parser and encoder library for Node.js and TypeScript. TrackSwap provides comprehensive support for GPX 1.1 format with advanced features like plugin system, middleware support, and optimized performance.

11 lines 96.9 kB
var N=class{constructor(){this.stage="parse"}async process(e){let t=Date.now();if(!e.rawData)throw new Error("FIT data cannot be empty");try{let r=await this.parseWithFitSDK(e.rawData);return e.rawMessages=r,e.performance.parseTime=Date.now()-t,e}catch(r){throw new Error(`FIT parsing failed: ${r.message}`)}}async parseWithFitSDK(e){let{Decoder:t,Stream:r}=await import("@garmin/fitsdk"),i=r.fromBuffer(e);if(!t.isFIT(i))throw new Error("Not a valid FIT file");let n=new t(i),{messages:s,errors:o}=n.read();return o&&o.length>0,s}},Y=class{constructor(e){this.getConverters=e;this.stage="extract"}async process(e){let t=Date.now();if(!e.rawMessages)throw new Error("Raw messages cannot be empty");let r={};for(let[i,n]of Object.entries(e.rawMessages)){if(!Array.isArray(n)||n.length===0){r[i]=n;continue}let s=this.getConverters(i);if(s.length===0)r[i]=n;else{let o=s[0];try{let a=o.convertMessages(n,e);r[i]=a}catch(a){e.errors.push(a),r[i]=n}}}return e.rawMessages=r,e.performance.extractTime=Date.now()-t,e}},Z=class{constructor(e){this.getStructurePlugins=e;this.stage="structure"}async process(e){let t=Date.now();if(!e.rawMessages)throw new Error("Message data cannot be empty");let r={},i=this.getStructurePlugins();for(let n of i)try{let s=n.structureData(e.rawMessages,e);r={...r,...s}}catch(s){e.errors.push(s)}return e.result=r,e.performance.structureTime=Date.now()-t,e}},q=class{constructor(){this.stage="complete"}async process(e){e.performance.endTime=Date.now();let t=e.performance.endTime-e.performance.startTime;return e.metadata.set("performance",{totalTime:t,parseTime:e.performance.parseTime,extractTime:e.performance.extractTime,structureTime:e.performance.structureTime}),e.stats&&(e.stats.endTime=Date.now(),e.rawMessages&&(e.stats.processedTokens=this.countTotalMessages(e.rawMessages))),e}countTotalMessages(e){let t=0;return Object.values(e).forEach(r=>{Array.isArray(r)&&(t+=r.length)}),t}};import x from"dayjs";var v=class{constructor(){this.version="1.0.0";this.priority=100}async initialize(e){e.metadata.set(`plugin:${this.name}:initialized`,!0)}async destroy(e){e.metadata.delete(`plugin:${this.name}:initialized`)}async validate(e){return!0}};var _=class extends v{constructor(){super(...arguments);this.name="SessionStructurePlugin";this.priority=10}structureData(t,r){let{sessionMesgs:i,lapMesgs:n,recordMesgs:s,lengthMesgs:o}=t;return i!=null&&i.length?{sessionMesgs:i.map(c=>{let d=x(c.startTime).valueOf(),l=d+c.totalElapsedTime*1e3,R=((n==null?void 0:n.filter(u=>{let h=x(u.startTime).valueOf(),b=h+(u.totalElapsedTime??0)*1e3;return h>=d&&b<=l}))||[]).map(u=>{let h=x(u.startTime).valueOf(),b=h+(u.totalElapsedTime??0)*1e3,qe=(s==null?void 0:s.filter(De=>{let L=x(De.timestamp).valueOf();return L>=h&&L<b}))||[],Se=u.firstLengthIndex??void 0,$e=u.numLengths??void 0,Ge=[];if(Se!==void 0&&$e!==void 0){let De=Se+$e;Ge=(o==null?void 0:o.filter(L=>L.messageIndex>=Se&&L.messageIndex<De))||[]}return{...u,recordMesgs:qe,lengthMesgs:Ge,messageIndex:u.messageIndex!==void 0?u.messageIndex:0}});return{...c,lapMesgs:R,messageIndex:c.messageIndex!==void 0?c.messageIndex:0}})}:{}}},M=class extends v{constructor(){super(...arguments);this.name="CourseStructurePlugin";this.priority=10}structureData(t,r){let{courseMesgs:i,lapMesgs:n,recordMesgs:s}=t;if(!(i!=null&&i.length))return{};let o=2e3;return{courseMesgs:i.map(c=>{let d=(n==null?void 0:n.map(l=>{let K=x(l.startTime).valueOf(),R=x(l.timestamp).valueOf(),u=(s==null?void 0:s.filter(h=>{let b=x(h.timestamp).valueOf();return b>=K-o&&b<=R+o}))||[];return{...l,recordMesgs:u}}))||[];return{...c,lapMesgs:d}})}}},O=class extends v{constructor(){super(...arguments);this.name="FileHeaderPlugin";this.priority=1}structureData(t,r){let{fileIdMesgs:i}=t;if(i!=null&&i.length&&i[0]){let n=i[0];r.fileHeader={type:n.type,manufacturer:n.manufacturer,product:n.product}}return{}}};var C=class{constructor(){this.converterPlugins=new Map;this.registeredPlugins=new Set;this.structurePlugins=[];this.middlewarePlugins=[];this.processors=[];this.initialized=!1;this.defaultPluginsRegistered=!1;this.initializePipeline()}initializePipeline(){this.processors=[new N,new Y(e=>this.getConverters(e)),new Z(()=>this.structurePlugins),new q]}async registerDefaultPlugins(){if(this.defaultPluginsRegistered)return;let e=[new O,new _,new M];for(let t of e)this.addStructurePlugin(t),this.registeredPlugins.add(t.name);this.defaultPluginsRegistered=!0}addConverterForMessageType(e,t){this.converterPlugins.has(e)||this.converterPlugins.set(e,[]);let r=this.converterPlugins.get(e);r.push(t),r.sort((i,n)=>(i.priority||100)-(n.priority||100))}addStructurePlugin(e){this.structurePlugins.push(e),this.structurePlugins.sort((t,r)=>(t.priority||100)-(r.priority||100))}async registerMessageConverter(e){if(this.registeredPlugins.has(e.name))throw new Error(`Message converter plugin ${e.name} already exists`);e.supportedMessageTypes.forEach(r=>{this.addConverterForMessageType(r,e)}),this.registeredPlugins.add(e.name);let t=e.priority!==void 0?` (priority: ${e.priority})`:"";e.supportedMessageTypes.forEach(r=>{let n=(this.converterPlugins.get(r)||[]).map(s=>`${s.name}(${s.priority||100})`)})}async registerStructurePlugin(e){if(this.registeredPlugins.has(e.name))throw new Error(`Structure plugin ${e.name} already exists`);this.addStructurePlugin(e),this.registeredPlugins.add(e.name);let t=e.priority!==void 0?` (priority: ${e.priority})`:""}async registerMiddleware(e){let t=this.middlewarePlugins.findIndex(i=>i.name===e.name);t!==-1?this.middlewarePlugins[t]=e:(this.middlewarePlugins.push(e),this.middlewarePlugins.sort((i,n)=>(i.priority||100)-(n.priority||100)));let r=[];e.onParse&&r.push("onParse"),e.onExtractMessages&&r.push("onExtractMessages"),e.onStructure&&r.push("onStructure"),e.onComplete&&r.push("onComplete"),e.onError&&r.push("onError"),r.length>0}getConverter(e){let t=this.converterPlugins.get(e);return t&&t.length>0?t[0]:void 0}getConverters(e){return this.converterPlugins.get(e)||[]}unregisterPlugin(e){if(!this.registeredPlugins.has(e))return!1;for(let[i,n]of this.converterPlugins){let s=n.findIndex(o=>o.name===e);s!==-1&&(n.splice(s,1),n.length===0&&this.converterPlugins.delete(i))}let t=this.structurePlugins.findIndex(i=>i.name===e);t!==-1&&this.structurePlugins.splice(t,1);let r=this.middlewarePlugins.findIndex(i=>i.name===e);return r!==-1&&this.middlewarePlugins.splice(r,1),this.registeredPlugins.delete(e),!0}async initialize(){var r;if(this.initialized)return;await this.registerDefaultPlugins();let e=this.createContext(),t=[...Array.from(this.converterPlugins.values()).flat(),...this.structurePlugins,...this.middlewarePlugins];for(let i of t)try{await((r=i.initialize)==null?void 0:r.call(i,e))}catch{}this.initialized=!0}async destroy(){var r;if(!this.initialized)return;let e=this.createContext(),t=[...Array.from(this.converterPlugins.values()).flat(),...this.structurePlugins,...this.middlewarePlugins];for(let i of t)try{await((r=i.destroy)==null?void 0:r.call(i,e))}catch{}this.initialized=!1}createContext(){return{metadata:new Map,errors:[],warnings:[],stats:{startTime:Date.now(),processedTokens:0,convertedElements:0},performance:{startTime:Date.now()}}}async executeMiddlewareHook(e,t,r){var n;let i=t;for(let s of this.middlewarePlugins){let o=s[e];if(o)try{i=await o.call(s,i,r)||i}catch(a){r.errors.push(a),await((n=s.onError)==null?void 0:n.call(s,a,r))}}return i}async parseByBuffer(e,t={}){var i;await this.initialize();let r=this.createContext();r.rawData=e,r.userData=t.userData,r.metadata.set("decoder",this);try{for(let n of this.processors)try{switch(r=await n.process(r),n.stage){case"parse":r.rawData&&(r.rawData=await this.executeMiddlewareHook("onParse",r.rawData,r));break;case"extract":r.rawMessages&&(r.rawMessages=await this.executeMiddlewareHook("onExtractMessages",r.rawMessages,r));break;case"structure":r.result&&(r.result=await this.executeMiddlewareHook("onStructure",r.result,r));break;case"complete":r.result&&(r.result=await this.executeMiddlewareHook("onComplete",r.result,r));break}}catch(s){r.errors.push(s);for(let o of this.middlewarePlugins)await((i=o.onError)==null?void 0:i.call(o,s,r))}return r.result}catch(n){throw n}}};var Je={file:{course:6,device:1,settings:2,sport:3,activity:4,workout:5,schedules:7,weight:9,totals:10,goals:11,blood_pressure:14,monitoring_a:15,activity_summary:20,monitoring_daily:28,monitoring_b:32,segment_list:35,exd_configuration:40,invalid:0},sport:{generic:0,running:1,cycling:2,transition:3,fitness_equipment:4,swimming:5,basketball:6,soccer:7,tennis:8,american_football:9,training:10,walking:11,cross_country_skiing:12,alpine_skiing:13,snowboarding:14,rowing:15,mountaineering:16,hiking:17,multisport:18,paddling:19,invalid:254},event:{timer:0,workout:3,workout_step:4,power_down:5,power_up:6,off_course:7,session:8,lap:9,course_point:10,battery:11,virtual_partner_pace:12,hr_high_alert:13,hr_low_alert:14,speed_high_alert:15,speed_low_alert:16,cad_high_alert:17,cad_low_alert:18,power_high_alert:19,power_low_alert:20,recovery_hr:21,battery_low:22,time_duration_alert:23,distance_duration_alert:24,calorie_duration_alert:25,activity:26,fitness_equipment:27,length:28,user_marker:32,sport_point:33,calibration:36,front_gear_change:42,rear_gear_change:43,rider_position_change:44,elev_high_alert:45,elev_low_alert:46,comm_timeout:47,invalid:255},event_type:{start:0,stop:1,consecutive_depreciated:2,marker:3,stop_all:4,begin_depreciated:5,end_depreciated:6,end_all_depreciated:7,stop_disable:8,stop_disable_all:9,invalid:255},course_point:{generic:0,summit:1,valley:2,water:3,food:4,danger:5,left:6,right:7,straight:8,first_aid:9,fourth_category:10,third_category:11,second_category:12,first_category:13,hors_category:14,sprint:15,left_fork:16,right_fork:17,middle_fork:18,slight_left:19,sharp_left:20,slight_right:21,sharp_right:22,u_turn:23,segment_start:24,segment_end:25,invalid:255}},P=p=>{let e=Je[p];return{size:1,baseType:0,mapValue:t=>typeof t=="string"?e[t]??255:t,setValue:function(t,r){this.setUint8(t,r)}}},Xe={enum_file:P("file"),enum_activity:P("sport"),enum_sport:P("sport"),enum_sub_sport:P("sport"),enum_event:P("event"),enum_event_type:P("event_type"),enum_course_point:P("course_point"),uint8:{size:1,baseType:2,setValue:DataView.prototype.setUint8},sint8:{size:1,baseType:1,setValue:DataView.prototype.setInt8},uint16:{size:2,baseType:132,setValue:DataView.prototype.setUint16},sint16:{size:2,baseType:131,setValue:DataView.prototype.setInt16},uint32:{size:4,baseType:134,setValue:DataView.prototype.setUint32},sint32:{size:4,baseType:133,setValue:DataView.prototype.setInt32},string:{size:0,baseType:7,mapValue:p=>Array.from(He(p)),setValue:et},distance:{size:4,baseType:134,setValue:DataView.prototype.setUint32,mapValue:p=>Math.round(p*1e3)},speed:{size:2,baseType:132,setValue:DataView.prototype.setUint16,mapValue:p=>Math.round(p*100)},altitude:{size:2,baseType:132,setValue:DataView.prototype.setUint16,mapValue:p=>Math.round((p+500)*5)},seconds:{size:4,baseType:134,setValue:DataView.prototype.setUint32,mapValue:p=>Math.round(p*1e3)},date_time:{size:4,baseType:134,setValue:DataView.prototype.setUint32,mapValue:p=>{let e;return p instanceof Date?(e=Math.floor(p.getTime()/1e3),e-631065600):typeof p=="string"?(e=Math.floor(new Date(p).getTime()/1e3),e-631065600):p<631065600?Math.floor(p):(p>9999999999?e=Math.floor(p/1e3):e=Math.floor(p),e-631065600)}},semicircles:{size:4,baseType:133,setValue:DataView.prototype.setInt32,mapValue:p=>Math.round(p/180*2147483648)}};function Be(p){return Array.from(He(p)).length+1}function*He(p){for(let e of Qe(p))e<128?yield e:e<2048?(yield 192|e>>6,yield 128|e&63):e<65536?(yield 224|e>>12,yield 128|e>>6&63,yield 128|e&63):(yield 240|e>>18,yield 128|e>>12&63,yield 128|e>>6&63,yield 128|e&63);yield 0}function*Qe(p){for(let e=0;e<p.length;){let t=p.codePointAt(e);if(t===void 0)break;yield t,e+=t>65535?2:1}}function et(p,e){for(let t=0;t<e.length;t++)this.setUint8(p+t,e[t])}var tt={file_id:{mesgNum:0,fieldDefns:[{name:"type",number:0,type:"enum_file"},{name:"time_created",number:4,type:"date_time"}]},session:{mesgNum:18,fieldDefns:[{name:"timestamp",number:253,type:"date_time"},{name:"start_time",number:2,type:"date_time"},{name:"total_elapsed_time",number:7,type:"seconds"},{name:"total_timer_time",number:8,type:"seconds"},{name:"start_position_lat",number:3,type:"semicircles"},{name:"start_position_long",number:4,type:"semicircles"},{name:"total_distance",number:9,type:"distance"},{name:"total_ascent",number:21,type:"uint16"},{name:"total_descent",number:22,type:"uint16"},{name:"sport",number:5,type:"enum_sport"},{name:"sub_sport",number:6,type:"enum_sub_sport"},{name:"first_lap_index",number:11,type:"uint16"},{name:"num_laps",number:26,type:"uint16"}]},lap:{mesgNum:19,fieldDefns:[{name:"timestamp",number:253,type:"date_time"},{name:"start_time",number:2,type:"date_time"},{name:"start_position_lat",number:3,type:"semicircles"},{name:"start_position_long",number:4,type:"semicircles"},{name:"end_position_lat",number:5,type:"semicircles"},{name:"end_position_long",number:6,type:"semicircles"},{name:"total_elapsed_time",number:7,type:"seconds"},{name:"total_timer_time",number:8,type:"seconds"},{name:"total_distance",number:9,type:"distance"},{name:"total_ascent",number:21,type:"uint16"},{name:"total_descent",number:22,type:"uint16"}]},record:{mesgNum:20,fieldDefns:[{name:"timestamp",number:253,type:"date_time"},{name:"position_lat",number:0,type:"semicircles"},{name:"position_long",number:1,type:"semicircles"},{name:"altitude",number:2,type:"altitude"},{name:"distance",number:5,type:"distance"},{name:"heart_rate",number:3,type:"uint8"},{name:"cadence",number:4,type:"uint8"},{name:"speed",number:6,type:"speed"},{name:"power",number:7,type:"uint16"}]},event:{mesgNum:21,fieldDefns:[{name:"timestamp",number:253,type:"date_time"},{name:"event",number:0,type:"enum_event"},{name:"event_type",number:1,type:"enum_event_type"},{name:"event_group",number:4,type:"uint8"}]},course:{mesgNum:31,fieldDefns:[{name:"name",number:5,type:"string"},{name:"sport",number:4,type:"enum_sport"},{name:"sub_sport",number:7,type:"enum_sub_sport"}]},activity:{mesgNum:34,fieldDefns:[{name:"timestamp",number:253,type:"date_time"},{name:"total_timer_time",number:0,type:"seconds"},{name:"num_sessions",number:1,type:"uint16"},{name:"type",number:2,type:"enum_activity"},{name:"event",number:3,type:"enum_event"},{name:"event_type",number:4,type:"enum_event_type"},{name:"local_timestamp",number:5,type:"date_time"},{name:"event_group",number:6,type:"uint8"}]},course_point:{mesgNum:32,fieldDefns:[{name:"timestamp",number:1,type:"date_time"},{name:"position_lat",number:2,type:"semicircles"},{name:"position_long",number:3,type:"semicircles"},{name:"distance",number:4,type:"distance"},{name:"type",number:5,type:"enum_course_point"}]}},rt=(p,e)=>p.map(t=>({...t,value:e[t.name]})).filter(({value:t})=>t!==void 0),J=class p{static check(e,t,r,i){if(t===void 0)throw new Error(`Message '${e}' not known`);if(r===void 0)throw new Error(`Message '${e}' has no field definitions`);let n=r.map(o=>o.name),s=Object.keys(i).filter(o=>!n.includes(o));if(s.length)throw new Error(`Message '${e}' has no field definitions named '${s}'`)}constructor(e,t,r){let i=tt[t];if(!i)throw new Error(`Unknown message type: ${t}`);let{mesgNum:n,fieldDefns:s}=i;p.check(t,n,s,r),this.localNum=e,this.mesgNum=n,this.fields=rt(s,r)}get mesgDefn(){let e=this.fields.map(({number:t,type:r,value:i})=>{let n=Xe[r];if(!n)throw new Error(`Unknown type: ${r}`);let{size:s,baseType:o}=n;return r==="string"?{number:t,size:Be(i),baseType:o}:{number:t,size:s,baseType:o}});return{localNum:this.localNum,mesgNum:this.mesgNum,fieldDefns:e}}isSameDefn(e){let t=(o,a)=>o.number===a.number&&o.size===a.size&&o.baseType===a.baseType,r=(o,a)=>o.length===a.length&&o.every((c,d)=>t(c,a[d])),{localNum:i,mesgNum:n,fieldDefns:s}=this.mesgDefn;return n===e.mesgNum&&i===e.localNum&&r(s,e.fieldDefns)}get defnRecord(){let{localNum:e,mesgNum:t,fieldDefns:r}=this.mesgDefn,i=6+3*r.length,n=new DataView(new ArrayBuffer(i));n.setUint8(0,64|e),n.setUint8(2,1),n.setUint16(3,t),n.setUint8(5,r.length);let s=6;for(let o of r)n.setUint8(s++,o.number),n.setUint8(s++,o.size),n.setUint8(s++,o.baseType);return n.buffer}get dataRecord(){let{fieldDefns:e}=this.mesgDefn,t=1+e.reduce((n,{size:s})=>n+s,0),r=new DataView(new ArrayBuffer(t));r.setUint8(0,this.localNum);let i=1;for(let{number:n,type:s,value:o}of this.fields){let a=Xe[s];if(!a)throw new Error(`Unknown type: ${s}`);let{size:c,setValue:d}=a,l;"mapValue"in a?l=a.mapValue(o):l=o,d&&d.call(r,i,l),i+=c}return r.buffer}};var nt=[0,52225,55297,5120,61441,15360,10240,58369,40961,27648,30720,46081,20480,39937,34817,17408],Ve=(p,e)=>(p>>>4^nt[p&15^e])&65535,it=(p,e,t)=>Ve(Ve(p,e),t),st=(p,e)=>it(p,e&15,e>>>4);function Re(p,e=0){let t=e,r=p instanceof ArrayBuffer?new Uint8Array(p):p;for(let i=0;i<r.length;i++)t=st(t,r[i]);return t}import ot from"dayjs";var ze=14,at=16,ct=2078,pt=776358228,w=class{constructor(e={}){this.localNum={};this.mesgDefn=[];this.messages=[];this.options={compact:e.compact??!0,defaultActivity:e.defaultActivity??"cycling",defaultSubActivity:e.defaultSubActivity??"generic"}}async encode(e){return this.reset(),this.buildFITContent(e,"activity"),Buffer.from(await this.blob.arrayBuffer())}async encodeCourse(e){return this.reset(),this.buildFITContent(e,"course"),Buffer.from(await this.blob.arrayBuffer())}async encodeToBlob(e,t="activity"){return this.reset(),this.buildFITContent(e,t),this.blob}reset(){this.localNum={},this.mesgDefn=[],this.messages=[]}buildFITContent(e,t){this.buildFileId(e,t),t==="course"?this.buildCourseContent(e):this.buildActivityContent(e)}buildActivityContent(e){let t=e.sessionMesgs||[];if(t.length===0)throw new Error("Activity file must contain at least one Session");let r=0,i=[],n=[];for(let s of t){if(s.lapMesgs&&this.buildEventsFromLaps(s.lapMesgs,i),s.lapMesgs)for(let o of s.lapMesgs)o.recordMesgs&&this.buildRecords(o.recordMesgs);s.lapMesgs&&this.buildLaps(s.lapMesgs),this.buildSession(s),r++,this.buildActivityFromSession(s,n)}i.forEach(s=>this.buildEvent(s)),n.forEach(s=>this.buildActivity(s))}buildCourseContent(e){let t=e.sessionMesgs||[];if(t.length===0)throw new Error("Course file must contain track data");let r=t[0];if(this.buildCourse({name:"course",sport:this.options.defaultActivity}),r.lapMesgs){let i=[];for(let o of r.lapMesgs)o.recordMesgs&&i.push(...o.recordMesgs);i.sort((o,a)=>o.timestamp&&a.timestamp?new Date(o.timestamp).getTime()-new Date(a.timestamp).getTime():(o.distance||0)-(a.distance||0));let n=i[0],s=i[i.length-1];if(r.startTime&&this.buildEvent({timestamp:r.startTime,event:"timer",eventType:"start",eventGroup:0}),i.forEach(o=>this.buildRecord(o)),s.timestamp&&this.buildEvent({timestamp:s.timestamp,event:"timer",eventType:"stop_all",eventGroup:0}),r.lapMesgs)for(let o=0;o<r.lapMesgs.length;o++)this.buildLap(r.lapMesgs[o])}}buildFileId(e,t){var i;let r=((i=e.fileIdMesgs)==null?void 0:i[0])||{};this.writeMesg("file_id",{type:t,time_created:r.timeCreated?this.parseTimestamp(r.timeCreated):Date.now(),manufacturer:r.manufacturer,product:r.product,serial_number:r.serialNumber})}buildSession(e){var t;this.writeMesg("session",{timestamp:e.timestamp?e.timestamp:void 0,start_time:e.startTime?e.startTime:void 0,total_elapsed_time:e.totalElapsedTime,total_timer_time:e.totalTimerTime,start_position_lat:e.startPositionLat?this.convertToSemicircles(e.startPositionLat):void 0,start_position_long:e.startPositionLong?this.convertToSemicircles(e.startPositionLong):void 0,total_distance:e.totalDistance,total_ascent:e.totalAscent,total_descent:e.totalDescent,sport:e.sport||this.options.defaultActivity,sub_sport:e.subSport||this.options.defaultSubActivity,first_lap_index:e.firstLapIndex||0,num_laps:e.numLaps||((t=e.lapMesgs)==null?void 0:t.length)||1})}buildLaps(e){e.forEach(t=>this.buildLap(t))}buildLap(e){this.writeMesg("lap",{timestamp:e!=null&&e.timestamp?e.timestamp:void 0,start_time:e!=null&&e.startTime?e.startTime:void 0,start_position_lat:e!=null&&e.startPositionLat?this.convertToSemicircles(e.startPositionLat):void 0,start_position_long:e!=null&&e.startPositionLong?this.convertToSemicircles(e.startPositionLong):void 0,end_position_lat:e!=null&&e.endPositionLat?this.convertToSemicircles(e.endPositionLat):void 0,end_position_long:e!=null&&e.endPositionLong?this.convertToSemicircles(e.endPositionLong):void 0,total_elapsed_time:e==null?void 0:e.totalElapsedTime,total_timer_time:e==null?void 0:e.totalTimerTime,total_distance:e==null?void 0:e.totalDistance,total_ascent:e==null?void 0:e.totalAscent,total_descent:e==null?void 0:e.totalDescent})}buildRecords(e){e.forEach(t=>this.buildRecord(t))}buildRecord(e){this.writeMesg("record",{timestamp:e.timestamp,position_lat:e!=null&&e.positionLat?this.convertToSemicircles(e.positionLat):void 0,position_long:e!=null&&e.positionLong?this.convertToSemicircles(e.positionLong):void 0,altitude:e==null?void 0:e.altitude,enhancedAltitude:e==null?void 0:e.enhancedAltitude,distance:e==null?void 0:e.distance,heart_rate:e==null?void 0:e.heartRate,cadence:e==null?void 0:e.cadence,speed:e==null?void 0:e.speed,enhancedSpeed:e==null?void 0:e.enhancedSpeed,power:e==null?void 0:e.power})}buildEvent(e){this.writeMesg("event",{timestamp:e.timestamp?e.timestamp:void 0,event:e.event,event_type:e.eventType,event_group:e.eventGroup})}buildActivity(e){this.writeMesg("activity",{timestamp:e.timestamp?e.timestamp:void 0,total_timer_time:e.totalTimerTime,num_sessions:e.numSessions,type:e.type,event:e.event,event_type:e.eventType,local_timestamp:e.localTimestamp?this.parseTimestamp(e.localTimestamp):void 0,event_group:e.eventGroup})}buildCourse(e){this.writeMesg("course",{name:e.name,sport:e.sport})}buildEventsFromLaps(e,t){e.forEach((r,i)=>{r.startTime&&t.push({timestamp:r.startTime,event:"timer",eventType:"start",eventGroup:i}),r.timestamp&&t.push({timestamp:r.timestamp,event:"timer",eventType:i===e.length-1?"stop_all":"stop",eventGroup:i})})}buildActivityFromSession(e,t){t.push({timestamp:e.timestamp,totalTimerTime:e.totalTimerTime,numSessions:1,type:e.sport||this.options.defaultActivity,event:"activity",eventType:"stop",eventGroup:0})}parseTimestamp(e){return typeof e=="number"?e:ot(e).valueOf()}convertToSemicircles(e){if(e!=null)return Math.round(e*2**31/180)}validateRequiredFields(e){if(!e.sessionMesgs||e.sessionMesgs.length===0)throw new Error("FIT file must contain at least one Session")}writeMesg(e,t){let r=Object.fromEntries(Object.entries(t).filter(([o,a])=>a!==void 0));if(Object.keys(r).length===0)return;let i=this.localNum[e];i===void 0&&(i=this.localNum[e]=Object.keys(this.localNum).length);let n=new J(i,e,r),s=this.mesgDefn[i];(!s||!n.isSameDefn(s))&&(this.messages.push(n.defnRecord),this.mesgDefn[i]=n.mesgDefn),this.messages.push(n.dataRecord)}get blob(){let e=[this.header,...this.messages,this.trailer];return new Blob(e,{type:"application/octet-stream"})}get dataLen(){return this.messages.reduce((e,t)=>e+t.byteLength,0)}get dataCrc(){return this.messages.reduce((e,t)=>Re(t,e),0)}get header(){let e=new DataView(new ArrayBuffer(ze));return e.setUint8(0,ze),e.setUint8(1,at),e.setUint16(2,ct,!0),e.setUint32(4,this.dataLen,!0),e.setUint32(8,pt),e.setUint16(12,Re(e.buffer.slice(0,12)),!0),e.buffer}get trailer(){let e=new DataView(new ArrayBuffer(2));return e.setUint16(0,this.dataCrc,!0),e.buffer}async encoder(e){return this.encode(e)}};var y=class{constructor(){this.version="1.0.0";this.priority=100}supports(e){return this.supportedTags.includes(e)}async initialize(e){e.metadata.set(`plugin:${this.name}:initialized`,!0)}async destroy(e){e.metadata.delete(`plugin:${this.name}:initialized`)}async validate(e){return!0}parseFloat(e){if(!(typeof e>"u"))return typeof e=="number"?e:typeof e=="string"&&parseFloat(e)||0}parseInt(e){return typeof e=="number"?Math.floor(e):typeof e=="string"&&parseInt(e,10)||0}parseString(e){return String(e||"")}parseBoolean(e){return typeof e=="boolean"?e:typeof e=="string"?e.toLowerCase()==="true":!1}parseDate(e){if(!e)return;let t=new Date(e);return isNaN(t.getTime())?void 0:t}hasRequiredAttributes(e,t){return t.every(r=>{var i;return(i=e.attributes)==null?void 0:i[r]})}extractAttributes(e,t,r){e.attributes&&Object.entries(e.attributes).forEach(([i,n])=>{let s=r[i];s&&s in t&&(t[s]=String(n||""))})}processChildren(e,t,r){var i;(i=e.children)==null||i.forEach(n=>{let s=r[n.tag];s&&s(n,t)})}getChildValue(e,t){var i;let r=(i=e.children)==null?void 0:i.find(n=>n.tag===t);return r!=null&&r.value?String(r.value):void 0}getChildByTag(e,t){var r;return(r=e.children)==null?void 0:r.find(i=>i.tag===t)}getChildrenByTag(e,t){var r;return((r=e.children)==null?void 0:r.filter(i=>i.tag===t))||[]}convertExtensions(e){var r;let t={};return(r=e.children)==null||r.forEach(i=>{t[i.tag]=this.convertExtensionContent(i)}),t}convertExtensionContent(e){var t;if((t=e.children)!=null&&t.length){let r={};return e.children.forEach(i=>{r[i.tag]=this.convertExtensionContent(i)}),r}else return e.value}},E=class{constructor(){this.version="1.0.0";this.description=""}async initialize(e){}async destroy(e){}async validate(e){return!0}async onTokenize(e,t){return e}async onAstGenerate(e,t){return e}async onConvert(e,t){return e}async onComplete(e,t){return e}async onError(e,t){}};var m=class extends y{parseCoordinate(e){let t=this.parseFloat(e);return t===0?void 0:t}parseGPXTime(e){if(!e)return;let t=new Date(e);return isNaN(t.getTime())?void 0:t}extractNumericAttributes(e,t,r){e.attributes&&Object.entries(e.attributes).forEach(([i,n])=>{let s=r[i];s&&s in t&&typeof n<"u"&&(t[s]=this.parseFloat(n))})}},$=class extends E{async onError(e,t){t.warnings.push(`Middleware ${this.name} error: ${e.message}`)}};var Q=class extends m{constructor(){super(...arguments);this.name="wpt-converter";this.supportedTags=["wpt","trkpt","rtept"];this.version="1.0.0"}convert(t,r){var n,s;if(!this.hasRequiredAttributes(t,["lat","lon"]))return;let i={lat:this.parseFloat((n=t.attributes)==null?void 0:n.lat),lon:this.parseFloat((s=t.attributes)==null?void 0:s.lon)};return this.processChildren(t,i,{ele:(o,a)=>a.ele=this.parseFloat(o.value),time:(o,a)=>a.time=new Date(this.parseString(o.value)),speed:(o,a)=>a.speed=this.parseFloat(o.value),power:(o,a)=>a.power=this.parseFloat(o.value),cadence:(o,a)=>a.cadence=this.parseFloat(o.value),heartRate:(o,a)=>a.heartRate=this.parseFloat(o.value),course:(o,a)=>a.course=this.parseFloat(o.value),name:(o,a)=>a.name=this.parseString(o.value),cmt:(o,a)=>a.cmt=this.parseString(o.value),desc:(o,a)=>a.desc=this.parseString(o.value),src:(o,a)=>a.src=this.parseString(o.value),sym:(o,a)=>a.sym=this.parseString(o.value),type:(o,a)=>a.type=this.parseString(o.value),fix:(o,a)=>a.fix=this.parseString(o.value),sat:(o,a)=>a.sat=this.parseString(o.value),hdop:(o,a)=>a.hdop=this.parseFloat(o.value),vdop:(o,a)=>a.vdop=this.parseFloat(o.value),pdop:(o,a)=>a.pdop=this.parseFloat(o.value),ageofdgpsdata:(o,a)=>a.ageofdgpsdata=this.parseFloat(o.value),geoidheight:(o,a)=>a.geoidheight=this.parseFloat(o.value),magvar:(o,a)=>a.magvar=this.parseFloat(o.value),dgpsid:(o,a)=>a.dgpsid=this.parseFloat(o.value),extensions:(o,a)=>{let c=r.metadata.get("decoder"),d=c==null?void 0:c.getConverter("extensions");if(d){let l=d.convert(o,r);l&&(this.mapExtensionsToPoint(l,a),a.extensions=l)}},link:(o,a)=>{var l;a.link||(a.link=[]);let c=r.metadata.get("decoder"),d=(l=c==null?void 0:c.getConverter("link"))==null?void 0:l.convert(o,r);d&&a.link&&a.link.push(d)}}),i}mapExtensionsToPoint(t,r){Object.entries(t).forEach(([i,n])=>{if(n!==void 0&&(typeof n=="string"||typeof n=="number")){let s=o=>(Array.isArray(o)?o:[o]).some(c=>{let d=i.toLowerCase(),l=c.toLowerCase();return d===l||d.endsWith(`:${l}`)});s("speed")?r.speed=this.parseFloat(n):s("hr")?r.heartRate=this.parseFloat(n):s(["cad","cadence"])?r.cadence=this.parseFloat(n):s(["PowerInWatts","power"])&&(r.power=this.parseFloat(n))}})}},ee=class extends m{constructor(){super(...arguments);this.name="rte-converter";this.supportedTags=["rte"]}convert(t,r){let i={rtept:[]};return this.processChildren(t,i,{name:(n,s)=>s.name=this.parseString(n.value),cmt:(n,s)=>s.cmt=this.parseString(n.value),desc:(n,s)=>s.desc=this.parseString(n.value),src:(n,s)=>s.src=this.parseString(n.value),number:(n,s)=>s.number=this.parseFloat(n.value),type:(n,s)=>s.type=this.parseString(n.value),rtept:(n,s)=>{var c;let o=r.metadata.get("decoder"),a=(c=o==null?void 0:o.getConverter("wpt"))==null?void 0:c.convert(n,r);a&&s.rtept&&s.rtept.push(a)},extensions:(n,s)=>{let o=r.metadata.get("decoder"),a=o==null?void 0:o.getConverter("extensions");a&&(s.extensions=a.convert(n,r))},link:(n,s)=>{var a;s.link||(s.link=[]);let o=r.metadata.get("decoder");(a=n.children)==null||a.forEach(c=>{var l;let d=(l=o==null?void 0:o.getConverter("link"))==null?void 0:l.convert(c,r);d&&s.link&&s.link.push(d)})}}),i}},te=class extends m{constructor(){super(...arguments);this.name="trk-converter";this.supportedTags=["trk"]}convert(t,r){let i={trkseg:[]};return this.processChildren(t,i,{name:(n,s)=>s.name=this.parseString(n.value),cmt:(n,s)=>s.cmt=this.parseString(n.value),desc:(n,s)=>s.desc=this.parseString(n.value),src:(n,s)=>s.src=this.parseString(n.value),number:(n,s)=>s.number=this.parseFloat(n.value),type:(n,s)=>s.type=this.parseString(n.value),trkseg:(n,s)=>{var c;let o=r.metadata.get("decoder"),a=(c=o==null?void 0:o.getConverter("trkseg"))==null?void 0:c.convert(n,r);a&&s.trkseg&&s.trkseg.push(a)},extensions:(n,s)=>{let o=r.metadata.get("decoder"),a=o==null?void 0:o.getConverter("extensions");a&&(s.extensions=a.convert(n,r))},link:(n,s)=>{var a;s.link||(s.link=[]);let o=r.metadata.get("decoder");(a=n.children)==null||a.forEach(c=>{var l;let d=(l=o==null?void 0:o.getConverter("link"))==null?void 0:l.convert(c,r);d&&s.link&&s.link.push(d)})}}),i}},re=class extends m{constructor(){super(...arguments);this.name="trkseg-converter";this.supportedTags=["trkseg"]}convert(t,r){let i={trkpt:[]};return this.processChildren(t,i,{trkpt:(n,s)=>{var c;let o=r.metadata.get("decoder"),a=(c=o==null?void 0:o.getConverter("wpt"))==null?void 0:c.convert(n,r);a&&s.trkpt&&s.trkpt.push(a)},extensions:(n,s)=>{let o=r.metadata.get("decoder"),a=o==null?void 0:o.getConverter("extensions");a&&(s.extensions=a.convert(n,r))}}),i}},ne=class extends m{constructor(){super(...arguments);this.name="link-converter";this.supportedTags=["link"]}convert(t,r){var n;let i={};return(n=t.attributes)!=null&&n.href&&(i.href=t.attributes.href),this.processChildren(t,i,{text:(s,o)=>o.text=this.parseString(s.value),type:(s,o)=>o.type=this.parseString(s.value)}),i}},ie=class extends m{constructor(){super(...arguments);this.name="metadata-converter";this.supportedTags=["metadata"]}convert(t,r){let i={};return this.processChildren(t,i,{name:(n,s)=>s.name=this.parseString(n.value),desc:(n,s)=>s.desc=this.parseString(n.value),keywords:(n,s)=>s.keywords=this.parseString(n.value),time:(n,s)=>s.time=new Date(this.parseString(n.value)),author:(n,s)=>{var a;let o=r.metadata.get("decoder");s.author=(a=o==null?void 0:o.getConverter("author"))==null?void 0:a.convert(n,r)},copyright:(n,s)=>{var a;let o=r.metadata.get("decoder");s.copyright=(a=o==null?void 0:o.getConverter("copyright"))==null?void 0:a.convert(n,r)},bounds:(n,s)=>{var a;let o=r.metadata.get("decoder");s.bounds=(a=o==null?void 0:o.getConverter("bounds"))==null?void 0:a.convert(n,r)},extensions:(n,s)=>{let o=r.metadata.get("decoder"),a=o==null?void 0:o.getConverter("extensions");a&&(s.extensions=a.convert(n,r))},link:(n,s)=>{var c;s.link||(s.link=[]);let o=r.metadata.get("decoder"),a=(c=o==null?void 0:o.getConverter("link"))==null?void 0:c.convert(n,r);a&&s.link&&s.link.push(a)}}),i}},se=class extends m{constructor(){super(...arguments);this.name="person-converter";this.supportedTags=["author"]}convert(t,r){var n;let i={};return t.value&&!((n=t.children)!=null&&n.length)?(i.name=this.parseString(t.value),i):(this.processChildren(t,i,{name:(s,o)=>o.name=this.parseString(s.value),email:(s,o)=>{var c;let a=r.metadata.get("decoder");o.email=(c=a==null?void 0:a.getConverter("email"))==null?void 0:c.convert(s,r)},link:(s,o)=>{var c;let a=r.metadata.get("decoder");o.link=(c=a==null?void 0:a.getConverter("link"))==null?void 0:c.convert(s,r)}}),i)}},oe=class extends m{constructor(){super(...arguments);this.name="email-converter";this.supportedTags=["email"]}convert(t,r){let i={};return this.processChildren(t,i,{id:(n,s)=>s.id=this.parseString(n.value),domain:(n,s)=>s.domain=this.parseString(n.value)}),i}},ae=class extends m{constructor(){super(...arguments);this.name="copyright-converter";this.supportedTags=["copyright"]}convert(t,r){var n;let i={};return(n=t.attributes)!=null&&n.author&&(i.author=t.attributes.author),this.processChildren(t,i,{year:(s,o)=>o.year=this.parseString(s.value),license:(s,o)=>o.license=this.parseString(s.value)}),i}},ce=class extends m{constructor(){super(...arguments);this.name="bounds-converter";this.supportedTags=["bounds"]}convert(t,r){let i={};return this.extractAttributes(t,i,{minlat:"minlat",minlon:"minlon",maxlat:"maxlat",maxlon:"maxlon"}),i}},pe=class extends m{constructor(){super(...arguments);this.name="extensions-converter";this.supportedTags=["extensions"]}convert(t,r){var n;let i={};return(n=t.children)==null||n.forEach(s=>{this.flattenExtensionElement(s,i)}),i}flattenExtensionElement(t,r){var i,n;if(!((i=t.children)!=null&&i.length)&&t.value!==void 0){r[t.tag]=this.parseExtensionValue(t.value);return}(n=t.children)!=null&&n.length&&t.children.forEach(s=>{this.flattenExtensionElement(s,r)})}parseExtensionValue(t){if(t===void 0)return;let r=String(t),i=parseFloat(r);return!isNaN(i)&&isFinite(i)?i:r}};import{Parser as dt}from"htmlparser2";var Te=(i=>(i.TOKENIZE="tokenize",i.AST_GENERATE="ast_generate",i.CONVERT="convert",i.COMPLETE="complete",i))(Te||{}),de=class{constructor(){this.stage="tokenize"}async process(e){let t=Date.now();if(!e.xmlContent)throw new Error("XML content cannot be empty");let r=[],i=new dt({onopentag(n,s){r.push({type:"open",tag:n,attributes:s})},ontext(n){let s=n.replace(/\n/g,"").trim();s&&r.push({type:"text",tag:"text",value:s})},onclosetag(n){r.push({type:"close",tag:n})}},{xmlMode:!0});return i.write(e.xmlContent),i.end(),e.tokens=r,e.performance.tokenizeTime=Date.now()-t,e}},le=class{constructor(){this.stage="ast_generate"}async process(e){var s;let t=Date.now();if(!e.tokens)throw new Error("Tokens cannot be empty");let r=[],i,n=null;for(let o of e.tokens)if(o.type==="open"){let a={tag:o.tag,attributes:o.attributes||{},children:[]};i?n&&((s=n.children)==null||s.push(a)):i=a,r.push(a),n=a}else o.type==="text"&&n?n.value=o.value:o.type==="close"&&(r.pop(),n=r[r.length-1]||null);return e.ast=i,e.performance.astTime=Date.now()-t,e}},ue=class{constructor(e){this.getConverter=e;this.stage="convert"}async process(e){var i;let t=Date.now();if(!e.ast)throw new Error("AST cannot be empty");let r={};return e.ast.attributes&&Object.entries(e.ast.attributes).forEach(([n,s])=>{n.startsWith("xmlns:")?r[n]=s.replace(/&#39;/g,"'"):n==="xsi:schemaLocation"?r[n]=s.replace(/&#39;/g,"'"):r[n]=s}),(i=e.ast.children)==null||i.forEach(n=>{let s=this.getConverter(n.tag);try{let o=s.convert(n,e);o&&this.assignResult(r,n.tag,o)}catch(o){e.errors.push(o)}}),e.result=r,e.performance.convertTime=Date.now()-t,e}assignResult(e,t,r){switch(t){case"metadata":e.metadata=r;break;case"wpt":e.wpt||(e.wpt=[]),e.wpt.push(r);break;case"rte":e.rte||(e.rte=[]),e.rte.push(r);break;case"trk":e.trk||(e.trk=[]),e.trk.push(r);break;case"extensions":e.extensions=r;break}}},me=class{constructor(){this.stage="complete"}async process(e){e.performance.endTime=Date.now();let t=e.performance.endTime-e.performance.startTime;return e.metadata.set("performance",{totalTime:t,tokenizeTime:e.performance.tokenizeTime,astTime:e.performance.astTime,convertTime:e.performance.convertTime}),e}};var I=class{constructor(){this.converterPlugins=new Map;this.registeredPlugins=new Set;this.middlewarePlugins=[];this.processors=[];this.initialized=!1;this.defaultConvertersRegistered=!1;this.initializePipeline()}initializePipeline(){this.processors=[new de,new le,new ue(e=>this.getConverter(e)),new me]}async registerDefaultConverters(){var t;if(this.defaultConvertersRegistered)return;let e=[new Q,new ee,new te,new re,new ne,new ie,new se,new oe,new ae,new ce,new pe];for(let r of e)(t=r.supportedTags)==null||t.forEach(i=>{this.addConverterForTag(i,r)}),this.registeredPlugins.add(r.name);this.defaultConvertersRegistered=!0}addConverterForTag(e,t){this.converterPlugins.has(e)||this.converterPlugins.set(e,[]);let r=this.converterPlugins.get(e);r.push(t),r.sort((i,n)=>(i.priority||100)-(n.priority||100))}async registerConverter(e){var r,n;if(this.registeredPlugins.has(e.name))throw new Error(`Converter plugin ${e.name} already exists`);(r=e.supportedTags)==null||r.forEach(s=>{this.addConverterForTag(s,e)}),this.registeredPlugins.add(e.name);let t=e.priority!==void 0?` (priority: ${e.priority})`:"";(n=e.supportedTags)==null||n.forEach(s=>{let a=(this.converterPlugins.get(s)||[]).map(c=>`${c.name}(${c.priority||100})`)})}async registerMiddleware(e){let t=this.middlewarePlugins.findIndex(i=>i.name===e.name);t!==-1?this.middlewarePlugins[t]=e:this.middlewarePlugins.push(e);let r=[];e.onTokenize&&r.push("onTokenize"),e.onAstGenerate&&r.push("onAstGenerate"),e.onConvert&&r.push("onConvert"),e.onComplete&&r.push("onComplete"),e.onError&&r.push("onError"),r.length>0}getConverter(e){let t=this.converterPlugins.get(e);return t&&t.length>0?t[0]:void 0}getAllConverters(e){return this.converterPlugins.get(e)||[]}unregisterConverter(e){let t;for(let[r,i]of this.converterPlugins){let n=i.findIndex(s=>s.name===e);n!==-1&&(t=i[n],i.splice(n,1),i.length===0&&this.converterPlugins.delete(r))}t&&this.registeredPlugins.delete(e)}unregisterMiddleware(e){let t=this.middlewarePlugins.findIndex(r=>r.name===e);t!==-1&&this.middlewarePlugins.splice(t,1)}listConverters(){return Array.from(this.converterPlugins.keys())}listConverterPlugins(){return Array.from(this.registeredPlugins)}listMiddlewares(){return this.middlewarePlugins.map(e=>e.name)}listProcessors(){return this.processors.map(e=>e.constructor.name)}getConverterDetails(e){let t={};if(e){let r=this.converterPlugins.get(e);r&&(t[e]=r.map(i=>({name:i.name,priority:i.priority||100})))}else for(let[r,i]of this.converterPlugins)t[r]=i.map(n=>({name:n.name,priority:n.priority||100}));return t}getMiddlewareDetails(){return this.middlewarePlugins.map(e=>{let t=[];return e.onTokenize&&t.push("onTokenize"),e.onAstGenerate&&t.push("onAstGenerate"),e.onConvert&&t.push("onConvert"),e.onComplete&&t.push("onComplete"),e.onError&&t.push("onError"),{name:e.name,hooks:t}})}async initialize(){var r;if(this.initialized)return;await this.registerDefaultConverters();let e=this.createContext(),t=[...Array.from(this.converterPlugins.values()).flat(),...this.middlewarePlugins];for(let i of t)try{await((r=i.initialize)==null?void 0:r.call(i,e))}catch{}this.initialized=!0}async destroy(){var r;if(!this.initialized)return;let e=this.createContext(),t=[...Array.from(this.converterPlugins.values()).flat(),...this.middlewarePlugins];for(let i of t)try{await((r=i.destroy)==null?void 0:r.call(i,e))}catch{}this.initialized=!1}createContext(){return{metadata:new Map,errors:[],warnings:[],stats:{startTime:Date.now(),processedTokens:0,convertedElements:0},performance:{startTime:Date.now()}}}async executeMiddlewareHook(e,t,r){var n;let i=t;for(let s of this.middlewarePlugins){let o=s[e];if(o)try{i=await o.call(s,i,r)||i}catch(a){r.errors.push(a),await((n=s.onError)==null?void 0:n.call(s,a,r))}}return i}async parserByBuffer(e){var r;await this.initialize();let t=this.createContext();t.rawData=e,t.xmlContent=e.toString("utf-8"),t.metadata.set("decoder",this);try{for(let i of this.processors)try{switch(t=await i.process(t),i.stage){case"tokenize":t.tokens&&(t.tokens=await this.executeMiddlewareHook("onTokenize",t.tokens,t));break;case"ast_generate":t.ast&&(t.ast=await this.executeMiddlewareHook("onAstGenerate",t.ast,t));break;case"convert":t.result&&(t.result=await this.executeMiddlewareHook("onConvert",t.result,t));break;case"complete":t.result&&(t.result=await this.executeMiddlewareHook("onComplete",t.result,t));break}}catch(n){t.errors.push(n);for(let s of this.middlewarePlugins)await((r=s.onError)==null?void 0:r.call(s,n,t))}return t.result}catch(i){throw i}}convertExtensions(e){var s,o;let t={},{attributes:r,tag:i,value:n}=e;if(r&&Object.entries(r).forEach(([a,c])=>{t[a]=c}),(s=e==null?void 0:e.children)!=null&&s.length)(o=e.children)==null||o.forEach(a=>{t[a.tag]=this.convertExtensions(a)});else if(n!==void 0)return n;return t}};import We from"dayjs";import lt from"dayjs/plugin/utc.js";var Le={temperature:"atemp",wtemp:"wtemp",heartRate:"hr",cadence:"cad"};var _e={temperature:"Temperature",Depth:"Depth"};We.extend(lt);var k=class{constructor(e={}){this.formatElevation=e=>{let t=parseFloat(e);return isNaN(t)?e:this.roundTo(t,2).toString()};this.compact=e.compact??!0}async encode(e){let t=this.buildGPXXML(e);return Buffer.from(t,"utf-8")}encodeToString(e){return this.buildGPXXML(e)}buildGPXXML(e){let t=this.buildXMLHeader(),r=this.buildGPXContent(e),n=`${t}${r} </gpx>`;return this.compact?this.compressXML(n):n}compressXML(e){return e.replace(/>\s+</g,"><").replace(/^\s+|\s+$/gm,"").replace(/\s+/g," ").trim()}buildXMLHeader(){return['<?xml version="1.0" encoding="UTF-8"?>','<gpx creator="https://gpxonline.net" version="1.1"',' xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"',' xsi:schemaLocation="http://www.topografix.com/GPX/1/1 http://www.topografix.com/GPX/1/1/gpx.xsd'," http://www.garmin.com/xmlschemas/GpxExtensions/v3 http://www.garmin.com/xmlschemas/GpxExtensionsv3.xsd"," http://www.garmin.com/xmlschemas/TrackPointExtension/v1 http://www.garmin.com/xmlschemas/TrackPointExtensionv1.xsd"," http://www.garmin.com/xmlschemas/PowerExtension/v1 http://www.garmin.com/xmlschemas/PowerExtensionv1.xsd",' http://www.topografix.com/GPX/gpx_style/0/2 http://www.topografix.com/GPX/gpx_style/0/2/gpx_style.xsd"',' xmlns:gpxtpx="http://www.garmin.com/xmlschemas/TrackPointExtension/v1"',' xmlns:gpxx="http://www.garmin.com/xmlschemas/GpxExtensions/v3"',' xmlns:gpxpx="http://www.garmin.com/xmlschemas/PowerExtension/v1"',' xmlns:gpx_style="http://www.topografix.com/GPX/gpx_style/0/2"',' xmlns="http://www.topografix.com/GPX/1/1">'].join(` `)}buildGPXContent(e){let{metadata:t,wpt:r=[],rte:i=[],trk:n=[]}=e,s=[];return t&&s.push(this.buildMetadata(t)),r.forEach(o=>{s.push(this.buildWaypoint(o,"wpt"))}),i.forEach(o=>{s.push(this.buildRoute(o))}),n.forEach(o=>{s.push(this.buildTrack(o))}),s.join(` `)}buildMetadata(e){let t=["<metadata>"];return this.addOptionalElement(t,"name",e.name),this.addOptionalElement(t,"desc",e.desc),e.author&&t.push(this.buildAuthor(e.author)),e.copyright&&t.push(this.buildCopyright(e.copyright)),e.link&&this.addLinks(t,e.link),e.time&&t.push(this.buildTimeElement(e.time)),this.addOptionalElement(t,"keywords",e.keywords),e.bounds&&t.push(this.buildBounds(e.bounds)),e.extensions&&t.push(this.buildExtensions(e.extensions)),t.push("</metadata>"),t.join(` `)}buildAuthor(e){let t=["<author>"];return this.addOptionalElement(t,"name",e.name),e.email&&t.push(`<email id="${this.escapeXML(e.email.id||"")}" domain="${this.escapeXML(e.email.domain||"")}"/>`),e.link&&t.push(this.buildLink(e.link)),t.push("</author>"),t.join(` `)}buildCopyright(e){let t=[`<copyright author="${this.escapeXML(e.author||"")}">`];return this.addOptionalElement(t,"year",e.year),this.addOptionalElement(t,"license",e.license),t.push("</copyright>"),t.join(` `)}buildBounds(e){let t=this.escapeXMLAttribute((e.minlat||0).toString()),r=this.escapeXMLAttribute((e.minlon||0).toString()),i=this.escapeXMLAttribute((e.maxlat||0).toString()),n=this.escapeXMLAttribute((e.maxlon||0).toString());return`<bounds minlat="${t}" minlon="${r}" maxlat="${i}" maxlon="${n}"/>`}buildWaypoint(e,t){var i,n,s;if(e.time===void 0)return"";let r=[`<${t} lat="${this.escapeXMLAttribute(e.lat?this.formatCoordinate(e.lat):"")}" lon="${this.escapeXMLAttribute(e.lon?this.formatCoordinate(e.lon):"")}">`];if(this.addOptionalElement(r,"ele",(i=e.ele)==null?void 0:i.toString(),this.formatElevation),e!=null&&e.time&&r.push(this.buildTimeElement(e.time)),this.addOptionalElement(r,"speed",(n=e.speed)==null?void 0:n.toString()),this.addOptionalElement(r,"course",(s=e.course)==null?void 0:s.toString()),this.addStandardWaypointElements(r,e),e.extensions){let o=this.processPointExtensions(e,e.extensions);Object.keys(o).length>0&&r.push(this.buildExtensions(o))}return r.push(`</${t}>`),r.join(` `)}addStandardWaypointElements(e,t){var r,i,n,s,o,a,c;this.addOptionalElement(e,"magvar",(r=t.magvar)==null?void 0:r.toString()),this.addOptionalElement(e,"geoidheight",(i=t.geoidheight)==null?void 0:i.toString()),this.addOptionalElement(e,"name",t.name),this.addOptionalElement(e,"cmt",t.cmt),this.addOptionalElement(e,"desc",t.desc),this.addOptionalElement(e,"src",t.src),t.link&&this.addLinks(e,t.link),this.addOptionalElement(e,"sym",t.sym),this.addOptionalElement(e,"type",t.type),this.addOptionalElement(e,"fix",t.fix),this.addOptionalElement(e,"sat",t.sat),this.addOptionalElement(e,"hdop",(n=t.hdop)==null?void 0:n.toString()),this.addOptionalElement(e,"vdop",(s=t.vdop)==null?void 0:s.toString()),this.addOptionalElement(e,"pdop",(o=t.pdop)==null?void 0:o.toString()),this.addOptionalElement(e,"ageofdgpsdata",(a=t.ageofdgpsdata)==null?void 0:a.toString()),this.addOptionalElement(e,"dgpsid",(c=t.dgpsid)==null?void 0:c.toString())}buildRoute(e){var r;let t=["<rte>"];return this.addRouteTrackCommonElements(t,e),e.rtept&&((r=e.rtept)==null||r.forEach(i=>{t.push(this.buildWaypoint(i,"rtept"))})),e.extensions&&t.push(this.buildExtensions(e.extensions)),t.push("</rte>"),t.join(` `)}buildTrack(e){let t=["<trk>"];return this.addRouteTrackCommonElements(t,e),e.trkseg&&e.trkseg.forEach(r=>{t.push(this.buildTrackSegment(r))}),e.extensions&&t.push(this.buildExtensions(e.extensions)),t.push("</trk>"),t.join(` `)}buildTrackSegment(e){let t=["<trkseg>"];return e.trkpt&&e.trkpt.forEach(r=>{t.push(this.buildWaypoint(r,"trkpt"))}),e.extensions&&t.push(this.buildExtensions(e.extensions)),t.push("</trkseg>"),t.join(` `)}addRouteTrackCommonElements(e,t){var r;this.addOptionalElement(e,"name",t.name),this.addOptionalElement(e,"cmt",t.cmt),this.addOptionalElement(e,"desc",t.desc),this.addOptionalElement(e,"src",t.src),t.link&&this.addLinks(e,t.link),this.addOptionalElement(e,"number",(r=t.number)==null?void 0:r.toString()),this.addOptionalElement(e,"type",t.type)}processPointExtensions(e,t){let r={};return Object.entries({"gpxtpx:TrackPointExtension":{"gpxtpx:hr":"heartRate","gpxtpx:cad":"cadence","gpxtpx:speed":"speed","gpxtpx:atemp":"temperature","gpxtpx:wtemp":"wtemp","gpxtpx:temp":"temperature"},"gpxpx:PowerExtension":{"gpxpx:PowerInWatts":"power"},"gpxx:GpxExtensions":{"gpxx:Temperature":"temperature","gpxx:Depth":"depth"}}).forEach(([n,s])=>{let o={},a=!1;Object.entries(s).forEach(([c,d])=>{let l;if(e[d]!==void 0)l=e[d];else if(t)if(t[c]!==void 0)l=t[c];else{let K=c.split(":").pop();Object.entries(t).forEach(([R,u])=>{R.endsWith(`:${K}`)&&u!==void 0&&(l=u)})}l!==void 0&&(o[c]=l,a=!0)}),a&&(r[n]=o)}),r}buildTrackPointExtension(e,t){let r=this.deepClone(t["gpxtpx:TrackPointExtension"]||{}),i=Object.keys(Le);return Object.keys(e).filter(n=>i.includes(n)).forEach(n=>{let s=Le[n];s&&e[n]!==void 0&&(r[`gpxtpx:${s}`]=e[n])}),r}buildPowerExtension(e,t){return this.deepClone(t["gpxpx:PowerExtension"]||{})}buildGpxExtensions(e,t){let r=this.deepClone(t["gpxx:GpxExtensions"]||{}),i=Object.keys(_e);return Object.keys(e).filter(n=>i.includes(n)).forEach(n=>{let s=_e[n];s&&e[n]!==void 0&&(r[`gpxx:${s}`]=e[n])}),r}buildExtensions(e){let t=this.buildExtensionContent(e);return t?`<extensions>${t}</extensions>`:""}buildExtensionContent(e){return Object.entries(e).filter(([t])=>!t.startsWith("xmlns")).map(([t,r])=>{if(r&&typeof r=="object"){let i=this.buildExtensionContent(r);return`<${t}>${i}</${t}>`}else if(r!=null)return`<${t}>${this.escapeXML(String(r))}</${t}>`;return""}).filter(t=>t).join("")}buildLink(e){let t=[`<link href="${this.escapeXMLAttribute(e.href||"")}">`];return this.addOptionalElement(t,"text",e.text),this.addOptionalElement(t,"type",e.type),t.push("</link>"),t.join("")}addLinks(e,t){(Array.isArray(t)?t:[t]).forEach(i=>{e.push(this.buildLink(i))})}buildTimeElement(e){return typeof e=="string"&&/^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}Z?$/.test(e)?`<time>${e}</time>`:`<time>${We(e).utc().format("YYYY-MM-DDTHH:mm:ss[Z]")}</time>`}addOptionalElement(e,t,r,i){if(r!=null&&r!==""){let n=i?i(r):this.escapeXML(r);e.push(`<${t}>${n}</${t}>`)}}isValidCoordinate(e,t){return e!=null&&t!==void 0&&t!==null&&!isNaN(e)&&!isNaN(t)}formatCoordinate(e){return this.roundTo(e,6).toString()}roundTo(e,t){let r=Math.pow(10,t);return Math.round(e*r)/r}escapeXML(e){return e.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,"&quot;").replace(/'/g,"&apos;")}escapeXMLAttribute(e){return typeof e!="string"?String(e||""):e.replace(/&/g,"&amp;").replace(/"/g,"&quot;").replace(/'/g,"&apos;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/\r/g,"&#13;").replace(/\n/g,"&#10;").replace(/\t/g,"&#9;")}deepClone(e){if(e===null||typeof e!="object")return e;if(e instanceof Date)return new Date(e.getTime());if(Array.isArray(e))return e.map(r=>this.deepClone(r));let t={};for(let r in e)Object.prototype.hasOwnProperty.call(e,r)&&(t[r]=this.deepClone(e[r]));return t}encoder(e){return this.encode(e)}};var Me=class extends ${constructor(){super(...arguments);this.name="performance-middleware";this.description="Monitor parsing performance"}async onTokenize(t,r){return t}async onAstGenerate(t,r){let i=this.countNodes(t);return t}async onComplete(t,r){let i