ngx-kel-agent 0.4.8 → 0.5.1
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.
- package/README.md +0 -26
- package/esm2020/lib/agent-message.service.mjs +18 -0
- package/esm2020/lib/agent.service.mjs +93 -170
- package/esm2020/lib/hamlib-messages.mjs +2 -0
- package/esm2020/lib/hamlib.service.mjs +48 -0
- package/esm2020/lib/wsjtx-messages.mjs +2 -0
- package/esm2020/lib/wsjtx.service.mjs +247 -0
- package/esm2020/public-api.mjs +8 -2
- package/fesm2015/ngx-kel-agent.mjs +376 -160
- package/fesm2015/ngx-kel-agent.mjs.map +1 -1
- package/fesm2020/ngx-kel-agent.mjs +376 -155
- package/fesm2020/ngx-kel-agent.mjs.map +1 -1
- package/lib/agent-message.service.d.ts +9 -0
- package/lib/agent.service.d.ts +114 -27
- package/lib/hamlib-messages.d.ts +10 -0
- package/lib/hamlib.service.d.ts +16 -0
- package/lib/{messages.d.ts → wsjtx-messages.d.ts} +152 -16
- package/lib/wsjtx.service.d.ts +62 -0
- package/package.json +4 -4
- package/public-api.d.ts +5 -1
- package/esm2020/lib/messages.mjs +0 -2
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { BehaviorSubject, ReplaySubject, Subject } from 'rxjs';
|
|
2
|
+
import { WsjtxClear, WsjtxClose, WsjtxConfigure, WsjtxDecode, WsjtxFreeText, WsjtxHeartbeat, WsjtxHighlightCallsign, WsjtxLoggedAdif, WsjtxQsoLogged, WsjtxStatus, WsjtxWsprDecode } from './wsjtx-messages';
|
|
3
|
+
import { AgentMessageService } from './agent-message.service';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export declare class WsjtxService {
|
|
6
|
+
private messages;
|
|
7
|
+
/** Whether we're getting any messages from WSJT-X. */
|
|
8
|
+
readonly connected$: BehaviorSubject<boolean>;
|
|
9
|
+
/** Subject for listening to WSJT-X "Heartbeat" messages. */
|
|
10
|
+
readonly heartbeat$: ReplaySubject<WsjtxHeartbeat | null>;
|
|
11
|
+
/** Subject for listening to WSJT-X "Status" messages. */
|
|
12
|
+
readonly status$: ReplaySubject<WsjtxStatus | null>;
|
|
13
|
+
/** Subject for listening to WSJT-X "Decode" messages. */
|
|
14
|
+
readonly decode$: Subject<WsjtxDecode>;
|
|
15
|
+
/** Subject for listening to WSJT-X "Clear" messages. */
|
|
16
|
+
readonly clear$: Subject<WsjtxClear>;
|
|
17
|
+
/** Subject for listening to WSJT-X "QsoLogged" messages. */
|
|
18
|
+
readonly qsoLogged$: Subject<WsjtxQsoLogged>;
|
|
19
|
+
/** Subject for listening to WSJT-X "Close" messages. */
|
|
20
|
+
readonly close$: Subject<WsjtxClose>;
|
|
21
|
+
/** Subject for listening to WSJT-X "WsprDecode" messages. */
|
|
22
|
+
readonly wsprDecode$: Subject<WsjtxWsprDecode>;
|
|
23
|
+
/** Subject for listening to WSJT-X "LoggedAdif" messages. */
|
|
24
|
+
readonly loggedAdif$: Subject<WsjtxLoggedAdif>;
|
|
25
|
+
private wsjtxId;
|
|
26
|
+
constructor(messages: AgentMessageService);
|
|
27
|
+
private setupBehaviors;
|
|
28
|
+
private handleMessage;
|
|
29
|
+
/** Send a command to WSJT-X to clear the Band Activity window. */
|
|
30
|
+
clearBandActivity(): void;
|
|
31
|
+
/** Send a command to WSJT-X to clear the Rx Frequency window. */
|
|
32
|
+
clearRxFreqWindow(): void;
|
|
33
|
+
/** Send a command to WSJT-X to clear the Band Activity and Rx Frequency windows. */
|
|
34
|
+
clearAll(): void;
|
|
35
|
+
/** Send a command to WSJT-X to replay messages. Useful for a fresh client that wants to hear
|
|
36
|
+
* previous WSJT-X decodes. */
|
|
37
|
+
replay(): void;
|
|
38
|
+
/** Send a command to WSJT-X to halt any transmissions immediately. */
|
|
39
|
+
haltTxNow(): void;
|
|
40
|
+
/** Send a command to WSJT-X to stop auto-transmitting after finishing the current round. */
|
|
41
|
+
haltTxAfterCurrent(): void;
|
|
42
|
+
/** Send a command to WSJT-X to reply to the given decode. The message must include CQ or QRZ. */
|
|
43
|
+
reply(decode: WsjtxDecode): void;
|
|
44
|
+
/** Send a command to WSJT-X to reply to the given decode. The message must include CQ or QRZ. */
|
|
45
|
+
highlightCallsign(highlightMsg: WsjtxHighlightCallsign): void;
|
|
46
|
+
/**
|
|
47
|
+
* Send a command to WSJT-X to transmit the given free text. If the text is too long to be
|
|
48
|
+
* encoded in a single message, it may be silently truncated. */
|
|
49
|
+
sendFreeText(freeText: WsjtxFreeText): void;
|
|
50
|
+
/** Send a command to WSJT-X to set the local station's Maidenhead grid. This is temporary,
|
|
51
|
+
* lasting only as long as WSJT-X is running. */
|
|
52
|
+
setLocation(grid: string): void;
|
|
53
|
+
/** Send a command to WSJT-X to switch to the named configuration. */
|
|
54
|
+
switchConfiguration(configName: string): void;
|
|
55
|
+
/** Send a command to WSJT-X to set the given configuration parameters. */
|
|
56
|
+
configure(config: WsjtxConfigure): void;
|
|
57
|
+
/** Given a decode message, format a string the same way as displayed in the WSJT-X Band
|
|
58
|
+
* Activity/Rx Frequency windows. */
|
|
59
|
+
static formatDecode(msg: WsjtxDecode): string;
|
|
60
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<WsjtxService, never>;
|
|
61
|
+
static ɵprov: i0.ɵɵInjectableDeclaration<WsjtxService>;
|
|
62
|
+
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "ngx-kel-agent",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.5.1",
|
|
4
4
|
"license": "Apache-2.0",
|
|
5
5
|
"homepage": "https://github.com/k0swe/ngx-kel-agent/tree/main/projects/ngx-kel-agent#readme",
|
|
6
6
|
"repository": {
|
|
@@ -15,9 +15,9 @@
|
|
|
15
15
|
"wsjtx"
|
|
16
16
|
],
|
|
17
17
|
"peerDependencies": {
|
|
18
|
-
"@angular/common": "
|
|
19
|
-
"@angular/core": "
|
|
20
|
-
"rxjs": "
|
|
18
|
+
"@angular/common": ">=12 <14",
|
|
19
|
+
"@angular/core": ">=12 <14",
|
|
20
|
+
"rxjs": ">=6 <8"
|
|
21
21
|
},
|
|
22
22
|
"dependencies": {
|
|
23
23
|
"tslib": "2.3.1"
|
package/public-api.d.ts
CHANGED
|
@@ -1,2 +1,6 @@
|
|
|
1
1
|
export * from './lib/agent.service';
|
|
2
|
-
export * from './lib/
|
|
2
|
+
export * from './lib/agent-message.service';
|
|
3
|
+
export * from './lib/hamlib-messages';
|
|
4
|
+
export * from './lib/hamlib.service';
|
|
5
|
+
export * from './lib/wsjtx-messages';
|
|
6
|
+
export * from './lib/wsjtx.service';
|
package/esm2020/lib/messages.mjs
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"messages.js","sourceRoot":"","sources":["../../../../projects/ngx-kel-agent/src/lib/messages.ts"],"names":[],"mappings":"","sourcesContent":["/**\n * The heartbeat  message shall be  sent on a periodic  basis every\n *    15   seconds.  This\n *    message is intended to be used by servers to detect the presence\n *    of a  client and also  the unexpected disappearance of  a client\n *    and  by clients  to learn  the schema  negotiated by  the server\n *    after it receives  the initial heartbeat message  from a client.\n *\n * See\n * [WSJT-X source](https://sourceforge.net/p/wsjt/wsjtx/ci/8f99fcceffc76c986413e22ed25b93ef3fc66f1e/tree/Network/NetworkMessage.hpp#l110).\n */\nexport interface WsjtxHeartbeat {\n  /** WSJT-X client name */\n  id: string;\n  /** WSJT-X client's supported schema version */\n  maxSchemaVersion: number;\n  /** WSJT-X client's commit hash */\n  revision: string;\n  /** WSJT-X client's semantic version */\n  version: string;\n}\n\n/**\n * WSJT-X  sends this  status message  when various  internal state\n * changes to allow the server to  track the relevant state of each\n * client without the need for  polling commands.\n *\n * See\n * [WSJT-X source](https://sourceforge.net/p/wsjt/wsjtx/ci/8f99fcceffc76c986413e22ed25b93ef3fc66f1e/tree/Network/NetworkMessage.hpp#l141).\n */\nexport interface WsjtxStatus {\n  configName: string;\n  /** Local station's callsign */\n  deCall: string;\n  /** Local station's Maidenhead grid */\n  deGrid: string;\n  /** Whether WSJT-X is currently decoding */\n  decoding: boolean;\n  /** The connected transceiver's dial frequency in hertz */\n  dialFrequency: number;\n  /** Remote station's callsign */\n  dxCall: string;\n  /** Remote station's Maidenhead grid */\n  dxGrid: string;\n  fastMode: boolean;\n  frequencyTolerance: number;\n  /** WSJT-X client name */\n  id: string;\n  /** The receive protocol that WSJT-X is decoding */\n  mode: string;\n  /** The local station's signal report for the remote station */\n  report: string;\n  /** The listening frequency in hertz above the dial frequency */\n  rxDeltaFreq: number;\n  /** If non-zero, WSJT-X is in a special mode like Fox/Hound or Field Day */\n  specialMode: number;\n  submode: string;\n  /** Whether WSJT-X is transmitting */\n  transmitting: boolean;\n  /** The transmit frequency in hertz above the dial frequency */\n  txDeltaFreq: number;\n  /** Whether WSJT-X is allowed to transmit during the next window */\n  txEnabled: boolean;\n  txMode: string;\n  txRxPeriod: number;\n  txWatchdog: boolean;\n  /** The message being transmitted */\n  txMessage: string;\n}\n\n/**\n * The decode message is sent when  a new decode is completed, in\n * this case the 'New' field is true. It is also used in response\n * to  a \"Replay\"  message where  each  old decode  in the  \"Band\n * activity\" window, that  has not been erased, is  sent in order\n * as a one of these messages  with the 'New' field set to false.\n *\n * See\n * [WSJT-X source](https://sourceforge.net/p/wsjt/wsjtx/ci/8f99fcceffc76c986413e22ed25b93ef3fc66f1e/tree/Network/NetworkMessage.hpp#l206).\n */\nexport interface WsjtxDecode {\n  /** The decode's frequency in hertz above the dial frequency */\n  deltaFrequency: number;\n  /** The perceived clock differential between the local station and remote station, in seconds. */\n  deltaTime: number;\n  /** WSJT-X client name */\n  id: string;\n  lowConfidence: boolean;\n  /** The message payload contained in the decode */\n  message: string;\n  /** The protocol of the decoded message */\n  mode: string;\n  /** Whether the decode is new or replayed */\n  new: boolean;\n  /** Whether the decode came from playback of a recording */\n  offAir: boolean;\n  /** Local station's perceived signal to noise ratio */\n  snr: number;\n  /** Clock time in milliseconds since midnight */\n  time: number;\n}\n\n/**\n * This message is  send when all prior \"Decode\"  messages in the\n * \"Band Activity\"  window have been discarded  and therefore are\n * no long available for actioning  with a \"Reply\" message.\n *\n * See\n * [WSJT-X source](https://sourceforge.net/p/wsjt/wsjtx/ci/8f99fcceffc76c986413e22ed25b93ef3fc66f1e/tree/Network/NetworkMessage.hpp#l232).\n */\nexport interface WsjtxClear {\n  /** WSJT-X client name */\n  id: string;\n  /** Which window to clear (send only). Send 0 to clear Band Activity, 1 to clear Rx Frequency, */\n  /** or 2 to clear both. */\n  window: number;\n}\n\n/**\n * The QSO logged message is sent when the WSJT-X user accepts the \"Log  QSO\" dialog by clicking\n * the \"OK\" button.\n *\n * See\n * [WSJT-X source](https://sourceforge.net/p/wsjt/wsjtx/ci/8f99fcceffc76c986413e22ed25b93ef3fc66f1e/tree/Network/NetworkMessage.hpp#l293).\n */\nexport interface WsjtxQsoLogged {\n  comments: string;\n  dateTimeOff: Date;\n  dateTimeOn: Date;\n  /** remote station's callsign */\n  dxCall: string;\n  /** remote station's Maidenhead grid */\n  dxGrid: string;\n  /** contest exchange received */\n  exchangeReceived: string;\n  /** contest exchange sent */\n  exchangeSent: string;\n  mode: string;\n  /** local station's callsign */\n  myCall: string;\n  /** local station's Maidenhead grid */\n  myGrid: string;\n  /** remote station's operator's name */\n  name: string;\n  /** remote stations operator's callsign (if different from station) */\n  operatorCall: string;\n  /** signal report received */\n  reportReceived: string;\n  /** signal report sent */\n  reportSent: string;\n  /** frequency in hertz */\n  txFrequency: number;\n  /** power in watts */\n  txPower: string;\n  /** WSJT-X client name */\n  id: string;\n}\n\n/**\n * Close is  sent by  a client immediately  prior to  it shutting\n * down gracefully.\n *\n * See\n * [WSJT-X source](https://sourceforge.net/p/wsjt/wsjtx/ci/8f99fcceffc76c986413e22ed25b93ef3fc66f1e/tree/Network/NetworkMessage.hpp#l318).\n */\nexport interface WsjtxClose {\n  /** WSJT-X client name */\n  id: string;\n}\n\n/**\n * When a server starts it may  be useful for it to determine the\n * state  of preexisting  clients. Sending  this message  to each\n * client as it is discovered  will cause that client (WSJT-X) to\n * send a \"Decode\" message for each decode currently in its \"Band\n * activity\"  window. Each  \"Decode\" message  sent will  have the\n * \"New\" flag set to false so that they can be distinguished from\n * new decodes. After  all the old decodes have  been broadcast a\n * \"Status\" message  is also broadcast.  If the server  wishes to\n * determine  the  status  of  a newly  discovered  client;  this\n * message should be used.\n *\n * See\n * [WSJT-X source](https://sourceforge.net/p/wsjt/wsjtx/ci/wsjtx-2.5.2/tree/Network/NetworkMessage.hpp#l328).\n */\nexport interface WsjtxReplay {\n  /** WSJT-X client name */\n  id: string;\n}\n\n/**\n * The server may stop a client from transmitting messages either\n * immediately or at  the end of the  current transmission period\n * using this message.\n *\n * See\n * [WSJT-X source](https://sourceforge.net/p/wsjt/wsjtx/ci/wsjtx-2.5.2/tree/Network/NetworkMessage.hpp#l343).\n */\nexport interface WsjtxHaltTx {\n  /** WSJT-X client name */\n  id: string;\n  /** If `false`, stop the ongoing transmission immediately. If `true`, this doesn't halt the\n   * current transmission, it just disables WSJT-X from transmitting after the current round. */\n  autoTxOnly: boolean;\n}\n\n/**\n * The decode message is sent when  a new decode is completed, in\n * this case the 'New' field is true.\n *\n * See\n * [WSJT-X source](https://sourceforge.net/p/wsjt/wsjtx/ci/8f99fcceffc76c986413e22ed25b93ef3fc66f1e/tree/Network/NetworkMessage.hpp#l381).\n */\nexport interface WsjtxWsprDecode {\n  /** WSJT-X client name */\n  id: string;\n  /** Whether the decode is new or replayed */\n  new: boolean;\n  /** Clock time in milliseconds since midnight */\n  time: number;\n  /** Local station's perceived signal to noise ratio */\n  snr: number;\n  /** The perceived clock differential between the local station and remote station, in seconds. */\n  deltaTime: number;\n  frequency: number;\n  drift: number;\n  /** remote station's callsign */\n  callsign: string;\n  /** remote station's Maidenhead grid */\n  grid: string;\n  /** power in dBm */\n  power: number;\n  /** whether the decode came from playback of a recording */\n  offAir: boolean;\n}\n\n/**\n * The  logged ADIF  message is  sent to  the server(s)  when the\n * WSJT-X user accepts the \"Log  QSO\" dialog by clicking the \"OK\"\n * button.\n *\n * See\n * [WSJT-X source](https://sourceforge.net/p/wsjt/wsjtx/ci/8f99fcceffc76c986413e22ed25b93ef3fc66f1e/tree/Network/NetworkMessage.hpp#l421).\n */\nexport interface WsjtxLoggedAdif {\n  /** WSJT-X client name */\n  id: string;\n  /** ADIF encoded QSO data */\n  adif: string;\n}\n\nexport interface HamlibRigState {\n  /** Transceiver model name */\n  model: string;\n  /** Dial frequency of the \"current\" VFO in Hz */\n  frequency: number;\n  /** Mode name of the \"current\" VFO */\n  mode: string;\n  /** Width of the current passband filter in Hz */\n  passbandWidthHz: number;\n}\n"]}
|