Skip to content

Commit

Permalink
ARRL SS - remove dots in Log column headers (#345)
Browse files Browse the repository at this point in the history
This fixes a problem where the Log Report Column headers would have dots
`...` displayed in the column heading names and sometimes in the data.
The change fixed how the column width per character was computed and
allowed for fractions to be used when declaring column widths.
  • Loading branch information
w7sst authored Sep 3, 2024
2 parents 5892733 + c6c9d42 commit 9e8e7ff
Showing 1 changed file with 13 additions and 10 deletions.
23 changes: 13 additions & 10 deletions Log.pas
Original file line number Diff line number Diff line change
Expand Up @@ -145,7 +145,7 @@ implementation
const
ShowHstCorrections: Boolean = true;
LogColUtcWidth: Integer = 80; // matches value in resource file
LogColPadding: Integer = 8; // Additional padding space for columns
LogColPadding: Integer = 10; // Additional padding space for columns

{
The following constants are used to initialize the Log Report columns
Expand All @@ -165,12 +165,12 @@ implementation
ARRL_SECT_COL = 'Sect,4,L';
FD_CLASS_COL = 'Class,5,L';
CORRECTIONS_COL = 'Corrections,11,L';
WPM_COL = 'Wpm,3,R';
WPM_COL = 'Wpm,3.25,R';
WPM_FARNS_COL = 'Wpm,5,R';
NAME_COL = 'Name,8,L';
STATE_PROV_COL = 'State,5,L';
PREFIX_COL = 'Pref,5,L';
ARRLDX_EXCH_COL = 'Exch,6,L';
PREFIX_COL = 'Pref,4,L';
ARRLDX_EXCH_COL = 'Exch,5,R';
CWT_EXCH_COL = 'Exch,5,L';
SST_EXCH_COL = 'Exch,5,L';
ALLJA_EXCH_COL = 'Exch,6,L';
Expand All @@ -179,9 +179,9 @@ implementation
WPX_EXCH_COL = 'Exch,6,L';
HST_EXCH_COL = 'Exch,6,L';
CQ_ZONE_COL = 'CQ-Zone,7,L';
SS_PREC_COL = 'Pr,2,C';
SS_CHECK_COL = 'Chk,3,C';
SS_SECT_COL = 'Sect,4,L';
SS_CALL_COL = 'Call,9,L';
SS_PREC_COL = 'Pr,2.5,C';
SS_CHECK_COL = 'Chk,3.25,C';

{$ifdef DEBUG}
DEBUG_INDENT: Integer = 3;
Expand Down Expand Up @@ -299,7 +299,7 @@ procedure ScoreTableInit(const ColDefs: array of string);
begin
Width := MainForm.ListView2.Column[0].Width;
LogColScaling := Width / LogColUtcWidth; // e.g. 125% for laptops
LogColWidthPerChar := (Width - (LogColPadding*LogColScaling)) / 8;
LogColWidthPerChar := Width / 8.5; // UTC-column width, ~8.5 characters
ScaleTableInitialized:= true;
end;

Expand All @@ -317,7 +317,10 @@ procedure ScoreTableInit(const ColDefs: array of string);
tl.DelimitedText := ColDefs[I];
assert(tl.Count = 3);
Name := tl[0];
Width := Round(tl[1].ToInteger * LogColWidthPerChar + LogColPadding*LogColScaling);
if I = 0 then // use existing width for UTC Column
Width := MainForm.ListView2.Column[I].Width
else
Width := Round(tl[1].ToSingle * LogColWidthPerChar + LogColPadding*LogColScaling);
Alignment := taLeftJustify;
case tl[2][1] of
'L': Alignment := taLeftJustify;
Expand Down Expand Up @@ -456,7 +459,7 @@ procedure Clear;
ScoreTableInit([UTC_COL, CALL_COL, FD_CLASS_COL, ARRL_SECT_COL, CORRECTIONS_COL, WPM_COL]);
scArrlSS:
begin
ScoreTableInit([UTC_COL, CALL_COL, NR_COL, SS_PREC_COL, SS_CHECK_COL, ARRL_SECT_COL, CORRECTIONS_COL, WPM_COL]);
ScoreTableInit([UTC_COL, SS_CALL_COL, NR_COL, SS_PREC_COL, SS_CHECK_COL, ARRL_SECT_COL, CORRECTIONS_COL, WPM_COL]);
SetExchColumns(2, 4, 3, 5);
end;
scNaQp:
Expand Down

0 comments on commit 9e8e7ff

Please sign in to comment.