📄 memtabledesigneh.pas
字号:
3: EditMTCreateDataDriver(TCustomMemTableEh(Component), Designer);
//if LoadFromFile(TClientDataSet(Component))
// then Designer.Modified;
else
if TDataSet(Component).Active then
case Index of
// 4: ;//SaveToFile(TClientDataSet(Component) {$IFDEF EH_LIB_6},dfXML{$ENDIF} );
// 5: ;//SaveToFile(TClientDataSet(Component) {$IFDEF EH_LIB_6},dfXMLUTF8{$ENDIF} );
// 6: ;//SaveToFile(TClientDataSet(Component) {$IFDEF EH_LIB_6},dfBinary{$ENDIF} );
4:
begin
TCustomMemTableEh(Component).Close;
TCustomMemTableEh(Component).FieldDefs.Clear;
Designer.Modified;
end;
end
else if ((TDataSet(Component).FieldCount > 0) or
(TDataSet(Component).FieldDefs.Count > 0)) and
not TDataSet(Component).Active
then
case Index of
4:
begin
TCustomMemTableEh(Component).CreateDataSet;
Designer.Modified;
end;
end
end;
end;
function TMemTableEditorEh.GetVerb(Index: Integer): string;
begin
case Index of
0: Result := 'Fields Editor...';
1: Result := 'Fetch Params';
2: Result := 'Assign Local Data...';
3: Result := 'Create DataDriver...';
// 3: Result := 'Load from MyBase table...';
else
if TDataSet(Component).Active then
case Index of
// 4: Result := 'Save to MyBase Xml table...';
// 5: Result := 'Save to MyBase Xml UTF8 table...';
// 6: Result := 'Save to binary MyBase table...';
4: Result := 'Clear Data';
end
else if ((TDataSet(Component).FieldCount > 0) or
(TDataSet(Component).FieldDefs.Count > 0)) and
not TDataSet(Component).Active
then
case Index of
4: Result := 'Create DataSet';
end
end;
end;
function TMemTableEditorEh.GetVerbCount: Integer;
begin
if TDataSet(Component).Active then
Result := 5
else if ((TDataSet(Component).FieldCount > 0) or
(TDataSet(Component).FieldDefs.Count > 0)) and
not TDataSet(Component).Active
then
Result := 5
else
Result := 4;
end;
{$IFDEF LINUX}
function TMemTableEditorEh.GetThreadAffinity: TThreadAffinity;
begin
Result := taQT;
end;
procedure TMemTableEditorEh.Edit;
begin
ShowFieldsEditorEh(Designer, TDataSet(Component), GetDSDesignerClass);
end;
{$ENDIF}
{ TSQLDataDriverEhEditor }
procedure TSQLDataDriverEhEditor.ExecuteVerb(Index: Integer);
begin
EditSQLDataDriverEh(Component as TCustomSQLDataDriverEh);
end;
function TSQLDataDriverEhEditor.GetVerb(Index: Integer): string;
begin
Result := 'SUpdateSQLEditor';
end;
function TSQLDataDriverEhEditor.GetVerbCount: Integer;
begin
Result := 1;
end;
{$IFDEF EH_LIB_6}
type
TDataDriverEhSelectionEditor = class(TSelectionEditor)
public
procedure RequiresUnits(Proc: TGetStrProc); override;
end;
{ TDataDriverEhSelectionEditor }
procedure TDataDriverEhSelectionEditor.RequiresUnits(Proc: TGetStrProc);
begin
inherited RequiresUnits(Proc);
Proc('MemTableDataEh');
Proc('Db');
end;
{$ENDIF}
procedure Register;
begin
// Ampy table
// Fields Editor...
// Fetch Params
// Assign Local Data...
// Load from MyBase table...
// Ampy table with created fields
// Fields Editor...
// Fetch Params
// Assign Local Data...
// Load from MyBase table...
//
// Create DataSet
// Ampy table with created fields and created table
// Fields Editor...
// Fetch Params
// Assign Local Data...
// Load from MyBase table...
//
// Save to MyBase Xml table...
// Save to MyBase Xml UTF8 table...
// Save to binary MyBase table...
// Clear Data
RegisterComponents('EhLib', [TMemTableEh]);
RegisterPropertyEditor(TypeInfo(string), TCustomMemTableEh, 'MasterFields', TMemTableFieldLinkProperty);
RegisterPropertyEditor(TypeInfo(string), TCustomMemTableEh, 'DetailFields', TMemTableFieldLinkProperty);
RegisterComponentEditor(TCustomMemTableEh, TMemTableEditorEh);
RegisterPropertyEditor(TypeInfo(TSQLCommandEh), TSQLDataDriverEh, '', TSQLCommandProperty);
RegisterComponents('EhLib', [TDataSetDriverEh, TSQLDataDriverEh]);
{$IFDEF EH_LIB_6}
RegisterSelectionEditor(TDataDriverEh, TDataDriverEhSelectionEditor);
RegisterSelectionEditor(TMemTableEh, TDataDriverEhSelectionEditor);
{$ENDIF}
RegisterComponentEditor(TSQLDataDriverEh, TSQLDataDriverEhEditor);
RegisterFields([TRefObjectField]);
end;
{ TMemTableFieldsEditorEh }
constructor TMemTableFieldsEditorEh.Create(AOwner: TComponent);
var
NonClientMetrics: TNonClientMetrics;
begin
inherited Create(AOwner);
if ParentFont then
begin
NonClientMetrics.cbSize := sizeof(NonClientMetrics);
{$IFDEF CIL}
{ TODO : To do for CIL }
// if SystemParametersInfo(SPI_GETNONCLIENTMETRICS, 0, @NonClientMetrics, 0) then
// Font.Name := NonClientMetrics.lfMessageFont.lfFaceName;
{$ELSE}
if SystemParametersInfo(SPI_GETNONCLIENTMETRICS, 0, @NonClientMetrics, 0) then
Font.Name := NonClientMetrics.lfMessageFont.lfFaceName;
{$ENDIF}
end;
AggListBox.Parent := TabSheet1;
FieldListBox.Parent := TabSheet1;
Splitter1.Parent := TabSheet1;
Splitter1.Top := 0;
DBNavigator.VisibleButtons := [nbFirst..nbRefresh];
PopupMenu := nil;
FieldListBox.PopupMenu := LocalMenu;
SpeedButton1.Align := alTop;
SpeedButton2.Align := alTop;
SpeedButton3.Align := alTop;
SpeedButton4.Align := alTop;
SpeedButton5.Align := alTop;
SpeedButton6.Align := alTop;
SpeedButton7.Align := alTop;
SpeedButton8.Align := alTop;
end;
procedure TMemTableFieldsEditorEh.actFetchParamsExecute(Sender: TObject);
begin
TCustomMemTableEh(Dataset).FetchParams;
Designer.Modified;
end;
procedure TMemTableFieldsEditorEh.actAssignLocalDataExecute(
Sender: TObject);
begin
if EditMemTable(TCustomMemTableEh(Dataset), Designer)
then Designer.Modified;
end;
procedure TMemTableFieldsEditorEh.actLoadFromMyBaseTableExecute(
Sender: TObject);
begin
// if LoadFromFile(TClientDataSet(Dataset))
// then Designer.Modified;
end;
procedure TMemTableFieldsEditorEh.actCreateDataSetExecute(
Sender: TObject);
begin
TCustomMemTableEh(Dataset).CreateDataSet;
Designer.Modified;
end;
procedure TMemTableFieldsEditorEh.actSaveToMyBaseXmlTableExecute(Sender: TObject);
begin
// SaveToFile(TClientDataSet(Dataset) {$IFDEF EH_LIB_6},dfXML{$ENDIF} );
end;
procedure TMemTableFieldsEditorEh.actSaveToMyBaseXmlUTF8TableExecute(
Sender: TObject);
begin
// SaveToFile(TClientDataSet(Dataset) {$IFDEF EH_LIB_6},dfXMLUTF8{$ENDIF} );
end;
procedure TMemTableFieldsEditorEh.actSaveToBinaryMyBaseTableExecute(
Sender: TObject);
begin
// SaveToFile(TClientDataSet(Dataset) {$IFDEF EH_LIB_6},dfBinary{$ENDIF} );
end;
procedure TMemTableFieldsEditorEh.actClearDataExecute(Sender: TObject);
begin
// TCustomMemTableEh(Dataset).Close;
TCustomMemTableEh(Dataset).DestroyTable;
TCustomMemTableEh(Dataset).FieldDefs.Clear;
Designer.Modified;
end;
procedure TMemTableFieldsEditorEh.actCreateDataSetUpdate(
Sender: TObject);
begin
actCreateDataSet.Enabled := ((Dataset.FieldCount > 0) or
(Dataset.FieldDefs.Count > 0)) and
not Dataset.Active;
actSaveToMyBaseXmlTable.Enabled := Dataset.Active;
actSaveToMyBaseXmlTable.Visible := False;
actSaveToMyBaseXmlUTF8Table.Enabled := Dataset.Active;
actSaveToMyBaseXmlUTF8Table.Visible := False;
actSaveToBinaryMyBaseTable.Enabled := Dataset.Active;
actSaveToBinaryMyBaseTable.Visible := False;
actLoadFromMyBaseTable.Visible := False;
actClearData.Enabled := Dataset.Active;
end;
procedure TMemTableFieldsEditorEh.SelectTable(Sender: TObject);
var
I: Integer;
begin
FieldListBox.ItemIndex := 0;
with FieldListBox do
for I := 0 to Items.Count - 1 do
if Selected[I] then Selected[I] := False;
Activated; //UpdateSelection;
case PageControl1.ActivePageIndex of
0: FieldListBox.SetFocus;
1: DBGridEh1.SetFocus;
end;
end;
procedure TMemTableFieldsEditorEh.GridCutClick(Sender: TObject);
begin
DBGridEh_DoCutAction(DBGridEh1,False);
end;
procedure TMemTableFieldsEditorEh.GridCopyClick(Sender: TObject);
begin
DBGridEh_DoCopyAction(DBGridEh1,False);
end;
procedure TMemTableFieldsEditorEh.GridPasteClick(Sender: TObject);
begin
DBGridEh_DoPasteAction(DBGridEh1,False);
end;
procedure TMemTableFieldsEditorEh.GridDeleteClick(Sender: TObject);
begin
DBGridEh_DoDeleteAction(DBGridEh1,False);
end;
procedure TMemTableFieldsEditorEh.GridSelectAllClick(Sender: TObject);
begin
DBGridEh1.Selection.SelectAll;
end;
procedure TMemTableFieldsEditorEh.DBGridEh1ContextPopup(Sender: TObject;
MousePos: TPoint; var Handled: Boolean);
var Pos: TPoint;
begin
if not ((DBGridEh1.InplaceEditor <> nil) and
(DBGridEh1.InplaceEditor.Visible)) then
begin
GridCut.Enabled := (DBGridEh1.Selection.SelectionType <> gstNon);
GridCopy.Enabled := (DBGridEh1.Selection.SelectionType <> gstNon);
GridPaste.Enabled := Clipboard.HasFormat(CF_VCLDBIF) or
Clipboard.HasFormat(CF_TEXT);
GridDelete.Enabled := (DBGridEh1.Selection.SelectionType <> gstNon);
GridSelectAll.Enabled := (DBGridEh1.Selection.SelectionType <> gstAll);
Pos := DBGridEh1.ClientToScreen(MousePos);
GridMenu.Popup(Pos.X,Pos.Y);
end;
end;
procedure TMemTableFieldsEditorEh.actCreateDataDriverExecute(
Sender: TObject);
begin
EditMTCreateDataDriver(TCustomMemTableEh(Dataset), Designer);
end;
end.
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -