From ebfee8cf28bae4eb9d15427dd5df3deb37b18053 Mon Sep 17 00:00:00 2001
From: panaaj <38519157+panaaj@users.noreply.github.com>
Date: Thu, 16 Jan 2025 11:41:55 +1030
Subject: [PATCH] TTG display formatting (closes #226)
---
CHANGELOG.md | 2 +-
src/app/app.component.html | 13 ++++---
src/app/app.component.ts | 11 ++++++
src/app/app.module.ts | 2 ++
src/app/lib/components/dial-text.ts | 54 ++++++++++++++++++++++++++++-
5 files changed, 73 insertions(+), 9 deletions(-)
diff --git a/CHANGELOG.md b/CHANGELOG.md
index 8e5b548b..90954381 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -6,13 +6,13 @@
- **New**: Display specific Note icons when "skIcon" property matches a POI type.
- **Fixed**: Notes popover and dialog formatting. (#214, #223)
- **Fixed**: Navigation data panel alignment on smaller screens. (#212)
+- **Fixed**: Update TTG display format based on magnitude of value. (#226)
- **Updated**: Resource Set feature popover formatting. (#213)
- **Updated**: Show more / less ui icons in AIS properties. (#217)
- **Updated**: Relocated close button on resource lists. (#218)
- **Updated**: Additional aisCogLine length options. (#209)
- **Added**: %map:zoom% token for use in Notes fetch filter (#222)
-
### v2.12.2
- **Fixed**: Issue applying URL query parameters. (#201)
- **Fixed**: S57 symbol display issue. (#202)
diff --git a/src/app/app.component.html b/src/app/app.component.html
index 07c5296d..bbebafdd 100644
--- a/src/app/app.component.html
+++ b/src/app/app.component.html
@@ -1032,16 +1032,15 @@
>
} @if(app.data.navData.ttg) {
-
-
+
} @if(app.data.navData.xte) {
10
+ ? app.data.navData.xte.toFixed(1)
+ : app.data.navData.xte.toFixed(3)
+ "
[units]="app.config.units.distance === 'm' ? 'km' : 'NM'"
>
diff --git a/src/app/app.component.ts b/src/app/app.component.ts
index e57d13be..b9edb250 100644
--- a/src/app/app.component.ts
+++ b/src/app/app.component.ts
@@ -613,8 +613,19 @@ export class AppComponent {
.get(this.app.skApiVersion, 'vessels/self/steering/autopilot')
.subscribe(
() => {
+ const sap = this.app.data.autopilot.hasApi;
this.app.data.autopilot.hasApi = true;
this.app.data.autopilot.isLocal = true;
+ if (sap && this.app.data.autopilot.isLocal) {
+ setTimeout(() =>
+ this.app.showMessage(
+ 'Built-in PyPilot support is deprecated! See Help for more.',
+ true,
+ 5000
+ )
+ ),
+ 10000;
+ }
},
() => {
this.app.debug('No local AP API found.');
diff --git a/src/app/app.module.ts b/src/app/app.module.ts
index 433c65d6..87d3f488 100644
--- a/src/app/app.module.ts
+++ b/src/app/app.module.ts
@@ -34,6 +34,7 @@ import {
import {
TextDialComponent,
+ TTGDialComponent,
FileInputComponent,
PiPVideoComponent,
WakeLockComponent,
@@ -56,6 +57,7 @@ import {
BrowserAnimationsModule,
FBMapComponent,
TextDialComponent,
+ TTGDialComponent,
FileInputComponent,
PiPVideoComponent,
WakeLockComponent,
diff --git a/src/app/lib/components/dial-text.ts b/src/app/lib/components/dial-text.ts
index ee8f40e3..96a63e11 100644
--- a/src/app/lib/components/dial-text.ts
+++ b/src/app/lib/components/dial-text.ts
@@ -1,7 +1,12 @@
/** Text Dial Component **
************************/
-import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
+import {
+ ChangeDetectionStrategy,
+ Component,
+ Input,
+ SimpleChanges
+} from '@angular/core';
/*********** Text Dial ***************
title: "" title text,
@@ -27,3 +32,50 @@ export class TextDialComponent {
@Input() value: string;
@Input() units: string;
}
+
+/*********** TTG Text Dial ***************
+value: "" TTG value in minutes
+***********************************/
+@Component({
+ standalone: true,
+ changeDetection: ChangeDetectionStrategy.OnPush,
+ selector: 'ap-dial-ttg',
+ imports: [],
+ template: `
+
+
TTG
+
{{ ttg }}
+
{{ units }}
+
+ `,
+ styleUrls: ['./dial-text.css']
+})
+export class TTGDialComponent {
+ @Input() value: number;
+ protected ttg: string = '--';
+ protected units: string = 'min';
+
+ ngOnChanges(changes: SimpleChanges) {
+ const cv = changes.value.currentValue;
+ if (typeof cv !== 'number') {
+ this.ttg = '--';
+ this.units = 'min';
+ } else if (cv < 60) {
+ this.ttg = Math.floor(cv).toString();
+ this.units = 'min';
+ } else if (cv < 60 * 24) {
+ this.ttg = `${Math.floor(cv / 60)}:${(cv % 60).toFixed(0)}`;
+ this.units = 'hr:min';
+ } else {
+ const minPerDay = 60 * 24;
+ const days = Math.floor(cv / minPerDay);
+ const dm = days * minPerDay;
+ const rhm = cv - dm;
+ const hours = Math.floor(rhm / 60);
+ const minutes = Math.floor(rhm - hours * 60);
+
+ this.ttg = `${days}:${hours}:${minutes}`;
+ this.units = 'day:hr:min';
+ }
+ }
+}