summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/gui/gui_edit.pas85
1 files changed, 81 insertions, 4 deletions
diff --git a/src/gui/gui_edit.pas b/src/gui/gui_edit.pas
index b9c608af..24ac8ef1 100644
--- a/src/gui/gui_edit.pas
+++ b/src/gui/gui_edit.pas
@@ -246,7 +246,7 @@ type
property OnMouseExit;
end;
-
+
TfpgEditCurrency = class(TfpgBaseNumericEdit)
private
fDecimals: integer;
@@ -844,7 +844,7 @@ procedure TfpgBaseEdit.HandleLMouseDown(x, y: integer; shiftstate: TShiftState);
cp: integer;}
begin
inherited HandleLMouseDown(x, y, shiftstate);
-
+
{cp := PointToCharPos(x, y);
FMouseDragPos := cp;
FCursorPos := cp;
@@ -887,7 +887,7 @@ var
begin
if (btnstate and MOUSE_LEFT) = 0 then
Exit;
-
+
{cp := PointToCharPos(x, y);
//FMouseDragPos := cp;
@@ -1354,7 +1354,7 @@ end;
procedure TfpgEditInteger.SetValue(const AValue: integer);
begin
try
- fText := IntToStr(AValue);
+ Text := IntToStr(AValue);
except
on E: EConvertError do
Text := '';
@@ -1655,9 +1655,83 @@ begin
end;
procedure TfpgEditCurrency.SetValue(const AValue: Currency);
+var
+ i,long: integer;
+ txt, texte, decimal: string;
begin
try
fText := CurrToStr(AValue);
+ if ShowThousand then
+ begin
+ if Pos(DecimalSeparator, fText) = 0 then
+ txt := fText
+ else
+ begin
+ txt := UTF8Copy(fText, 1, Pred(Pos(DecimalSeparator, fText)));
+ decimal := UTF8Copy(fText, Succ(Pos(DecimalSeparator, fText)), UTF8Length(fText) - Pos(DecimalSeparator, fText));
+ end;
+ if AValue < 0 then
+ txt:= UTF8Copy(txt, 2, UTF8Length(txt)-1);
+ long := UTF8Length(txt);
+ i := 0;
+ texte := '';
+ repeat
+ if i > 0 then
+ if ((i mod 3) = 0) and (txt[UTF8Length(txt)-UTF8Length(texte)] <> ThousandSeparator) then
+ begin
+ texte := ThousandSeparator + texte;
+ if AValue < 0 then
+ begin
+ if Pred(FCursorPos) <= UTF8Length(texte) then
+ Inc(FCursorPos);
+ end
+ else
+ if FCursorPos <= UTF8Length(texte) then
+ Inc(FCursorPos);
+ end;
+ texte := Copy(txt, long - i, 1) + texte;
+ inc(i);
+ until i = long;
+ if Pos(DecimalSeparator, fText) = 0 then
+ begin
+ if AValue < 0 then
+ begin
+ fText := '-' + texte;
+ Inc(FCursorPos);
+ end
+ else
+ fText := texte;
+ end
+ else
+ begin
+ if AValue < 0 then
+ begin
+ fText := '-' + texte + DecimalSeparator + decimal;
+ Inc(FCursorPos);
+ end
+ else
+ fText := texte + DecimalSeparator + decimal;
+ FCursorPos := FCursorPos + Succ(Length(decimal));
+ end;
+ end;
+ if fDecimals > 0 then
+ begin
+ if Pos(DecimalSeparator, fText) = 0 then
+ begin
+ fText := fText + DecimalSeparator;
+ Inc(FCursorPos);
+ end;
+ if UTF8Length(fText)-Pos(DecimalSeparator, fText) < fDecimals then
+ while UTF8Length(fText)-Pos(DecimalSeparator, fText) < fDecimals do
+ begin
+ fText := fText + '0';
+ Inc(FCursorPos);
+ end;
+ end;
+ if AValue < 0 then
+ TextColor := NegativeColor
+ else
+ TextColor := OldColor;
except
on E: EConvertError do
Text := '';
@@ -1749,7 +1823,10 @@ begin
if fDecimals > 0 then
begin
if Pos(DecimalSeparator, fText) = 0 then
+ begin
fText := fText + DecimalSeparator;
+ Inc(FCursorPos);
+ end;
if UTF8Length(fText)-Pos(DecimalSeparator, fText) < fDecimals then
while UTF8Length(fText)-Pos(DecimalSeparator, fText) < fDecimals do
begin