summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--extras/tiopf/gui/tiListMediators.pas177
-rw-r--r--extras/tiopf/gui/tiMediators.pas14
2 files changed, 175 insertions, 16 deletions
diff --git a/extras/tiopf/gui/tiListMediators.pas b/extras/tiopf/gui/tiListMediators.pas
index c16c5eb9..5aca05d7 100644
--- a/extras/tiopf/gui/tiListMediators.pas
+++ b/extras/tiopf/gui/tiListMediators.pas
@@ -13,9 +13,9 @@ uses
Classes
,SysUtils
,tiBaseMediator
-// ,Contnrs { TObjectList }
- ,gui_listview { TfpgListView }
- ,gui_grid { TfpgStringGrid }
+ ,gui_listview
+ ,gui_grid
+ ,gui_listbox
,tiObject
;
@@ -43,9 +43,7 @@ type
class function ComponentClass: TClass; override;
Constructor Create; override;
Destructor Destroy; override;
- { Called from the GUI to trigger events }
- procedure HandleSelectionChanged; virtual;
- { Event handler to allow formatting of fields before they are written. }
+ procedure HandleSelectionChanged; override;
published
property View: TfpgListView read FView Write SetView;
end;
@@ -67,8 +65,8 @@ type
procedure CreateColumns; override;
Function GetGuiControl : TComponent; override;
Procedure SetGuiControl (Const AValue : TComponent); override;
- procedure SetupGUIandObject; override;
- procedure RebuildList;override;
+ procedure SetupGUIandObject; override;
+ procedure RebuildList;override;
public
constructor CreateCustom(AModel: TtiObjectList; AGrid: TfpgStringGrid; ADisplayNames: string; AIsObserving: Boolean = True);
class function ComponentClass: TClass; override;
@@ -113,6 +111,31 @@ type
end;
+ { Used for presenting a list of objects in a TfpgListBox component. }
+ TListBoxMediator = class(TCustomListMediator)
+ private
+ FView: TfpgListBox;
+ FSelectedObject: TtiObject;
+ FObserversInTransit: TList;
+ protected
+ function GetGUIControl: TComponent; override;
+ function GetSelectedObject: TtiObject; override;
+ procedure SetGUIControl(const AValue: TComponent);override;
+ procedure SetSelectedObject(const AValue: TtiObject); override;
+ procedure CreateColumns; override;
+ procedure ClearList; override;
+ procedure DoCreateItemMediator(AData: TtiObject; ARowIdx: integer); override;
+ procedure RebuildList; override;
+ public
+ constructor Create; override;
+ destructor Destroy; override;
+ class function CompositeMediator: Boolean; override;
+ class function ComponentClass: TClass; override;
+ procedure HandleSelectionChanged; override;
+ property View: TfpgListBox read FView;
+ end;
+
+
implementation
@@ -265,7 +288,6 @@ begin
inherited;
end;
-{ TODO: This is not working 100% yet. Be warned! }
procedure TListViewMediator.HandleSelectionChanged;
var
i: integer;
@@ -533,5 +555,142 @@ begin
end;
+{ TListBoxMediator }
+
+function TListBoxMediator.GetGUIControl: TComponent;
+begin
+ Result := FView;
+end;
+
+function TListBoxMediator.GetSelectedObject: TtiObject;
+begin
+ Result := FSelectedObject;
+end;
+
+procedure TListBoxMediator.SetGUIControl(const AValue: TComponent);
+begin
+ FView := AValue as TfpgListBox;
+ inherited SetGUIControl(AValue);
+end;
+
+procedure TListBoxMediator.SetSelectedObject(const AValue: TtiObject);
+begin
+ FSelectedObject := AValue;
+end;
+
+procedure TListBoxMediator.CreateColumns;
+begin
+ // do nothing
+end;
+
+procedure TListBoxMediator.ClearList;
+begin
+
+end;
+
+procedure TListBoxMediator.DoCreateItemMediator(AData: TtiObject;
+ ARowIdx: integer);
+begin
+
+end;
+
+procedure TListBoxMediator.RebuildList;
+var
+ i: Integer;
+ ptr: TNotifyEvent;
+ selected: integer;
+begin
+ selected := -1;
+ if (Model.CountNotDeleted) >= View.FocusItem+1 then
+ begin
+ selected := View.FocusItem;
+ end;
+
+ ptr := View.OnChange;
+ View.OnChange := nil;
+ View.BeginUpdate;
+ try
+ View.Items.Clear;
+ for i := 0 to Model.Count-1 do
+ begin
+ if (not Model.Items[i].Deleted) or
+ (ShowDeleted and Model.Items[i].Deleted) then
+ begin
+ View.Items.AddObject(Model.Items[i].Caption, Model.Items[i]);
+ end;
+ end;
+ if Model.CountNotDeleted > 0 then
+ begin
+ if selected = -1 then
+ selected := 0;
+ View.FocusItem := selected;
+ end;
+ finally
+ View.EndUpdate;
+ View.Update;
+ View.OnChange := ptr;
+ HandleSelectionChanged;
+ end;
+end;
+
+constructor TListBoxMediator.Create;
+begin
+ inherited Create;
+ FSelectedObject := nil;
+ FObserversInTransit := TList.Create;
+end;
+
+destructor TListBoxMediator.Destroy;
+begin
+ FObserversInTransit.Free;
+ inherited Destroy;
+end;
+
+class function TListBoxMediator.CompositeMediator: Boolean;
+begin
+ Result := False;
+end;
+
+class function TListBoxMediator.ComponentClass: TClass;
+begin
+ Result := TfpgListBox;
+end;
+
+{$Note Refactor this as it's the same as TListView.HandleSelectionChanged, except
+ for one single line. }
+procedure TListBoxMediator.HandleSelectionChanged;
+var
+ i: integer;
+begin
+ if View.FocusItem = -1 then
+ SelectedObject := nil
+ else
+ begin
+ { If an item is already selected, assign the item's List of observers to a
+ temporary container. This is done so that the same observers can be
+ assigned to the new item. }
+ if Assigned(FSelectedObject) then
+ FObserversInTransit.Assign(FSelectedObject.ObserverList);
+
+ // Assign Newly selected item to SelectedObject Obj.
+ FSelectedObject := TtiObject(View.Items.Objects[View.FocusItem]);
+
+ { If an object was selected, copy the old item's observer List
+ to the new item's observer List. }
+ if FObserversInTransit.Count > 0 then
+ FSelectedObject.ObserverList.Assign(FObserversInTransit);
+
+ { set the observers's Subject property to the selected object }
+ for i := 0 to FSelectedObject.ObserverList.Count-1 do
+ begin
+ TMediatorView(FSelectedObject.ObserverList.Items[i]).Subject :=
+ FSelectedObject;
+ end;
+
+ // execute the NotifyObservers event to update the observers.
+ FSelectedObject.NotifyObservers;
+ end;
+end;
+
end.
diff --git a/extras/tiopf/gui/tiMediators.pas b/extras/tiopf/gui/tiMediators.pas
index 2aa89a94..828a5eb8 100644
--- a/extras/tiopf/gui/tiMediators.pas
+++ b/extras/tiopf/gui/tiMediators.pas
@@ -36,7 +36,7 @@ type
FEditControl: TfpgEdit;
protected
function GetGUIControl: TComponent; override;
- procedure SetGUIControl(const AValue: TComponent);override;
+ procedure SetGUIControl(const AValue: TComponent); override;
procedure UpdateGuiValidStatus(pErrors: TtiObjectErrors); override;
procedure SetupGUIandObject; override;
procedure SetObjectUpdateMoment (Const AValue : TObjectUpdateMoment); override;
@@ -225,7 +225,7 @@ end;
procedure TMediatorEditView.SetGUIControl(const AValue: TComponent);
begin
FEditControl := AValue as TfpgEdit;
- Inherited;
+ inherited SetGUIControl(AValue);
end;
procedure TMediatorEditView.UpdateGuiValidStatus(pErrors: TtiObjectErrors);
@@ -423,7 +423,7 @@ end;
procedure TMediatorComboBoxView.SetGUIControl(const AValue: TComponent);
begin
FEditControl := AValue as TfpgComboBox;
- inherited;
+ inherited SetGUIControl(AValue);
end;
procedure TMediatorComboBoxView.SetupGUIandObject;
@@ -492,7 +492,7 @@ end;
procedure TMediatorMemoView.SetGUIControl(const AValue: TComponent);
begin
FEditControl:=AValue as TfpgMemo;
- Inherited;
+ inherited SetGUIControl(AValue);
end;
procedure TMediatorMemoView.SetupGUIandObject;
@@ -635,7 +635,7 @@ end;
procedure TMediatorCheckBoxView.SetGUIControl(const AValue: TComponent);
begin
FEditControl:=AValue as TfpgCheckBox;
- Inherited;
+ inherited SetGUIControl(AValue);
end;
procedure TMediatorCheckBoxView.UpdateGuiValidStatus(pErrors: TtiObjectErrors);
@@ -691,7 +691,7 @@ end;
procedure TMediatorStaticTextView.SetGUIControl(const AValue: TComponent);
begin
FEditControl := AValue as TfpgLabel;
- inherited;
+ inherited SetGUIControl(AValue);
end;
class function TMediatorStaticTextView.ComponentClass: TClass;
@@ -710,7 +710,7 @@ end;
procedure TMediatorCalendarComboView.SetGUIControl(const AValue: TComponent);
begin
FEditControl := AValue as TfpgCalendarCombo;
- inherited;
+ inherited SetGUIControl(AValue);
end;
constructor TMediatorCalendarComboView.Create;