[Lazarus] RE : RE : RE : RE : RE : @DBLookupControls users: call for test
Luiz Americo Pereira Camara
luizmed at oi.com.br
Thu Dec 15 00:42:59 CET 2011
On 14/12/2011 09:17, michael at freepascal.org wrote:
>
>
> On Wed, 14 Dec 2011, Ludo Brands wrote:
>
>>>
>>> I've got your point.
>>>
>>> Mine is that the control should keep less intrusive as it was
>>> designed
>>> earlier (the original author explicitly avoided changing
>>> listsource cursor).
>>>
>>
>> Less intrusive became occulted. Not only are we missing an important
>> (for me
>> at least) Delphi feature but the current implementation makes it
>> virtually
>> impossible to emulate the Delphi behavior since everything related to
>> the
>> lookup is private:
>> A convoluted workaround for DBLookupComboBox was to create a
>> DBLookupComboBox.OnChange, retrieve DBLookupComboBox.ItemIndex and
>> move its
>> listsource to that position. Unfortunately, recent changes have made
>> this
>> even more difficult since DBLookupComboBox2.ListSource returns nil if
>> Datafield is a lookup field. Setting ListSource when Datafield is
>> ftLookup
>> was superfluous but possible and useful. Beats me why this was removed.
>> Progress? Now I have to get the field information of DataField to get
>> to the
>> ListSource :
>> DBLookupComboBox.DataSource.DataSet.FieldByName(DBLookupComboBox.DataField).
>>
>> LookupDataSet.RecNo:=DBLookupComboBox.ItemIndex+1 :( I'll create a
>> seperate
>> bugreport for this regression. Even if ListSource isn't settable for a
>> ftLookup Datafield, it shouldn't return nil.
>>
>> DBGrid is even worse. For the picklist I haven't found anything
>> (event or
>> property) to get to its index or value.
>>
>> The remedy for being less intrusive is worse than the disease.
>
> I am totally in agreement with Ludo on this one.
>
> I think the users should at least be offered the opportunity to change
> the
> behaviour. I have always counted on the Delphi-compatible behaviour:
> selecting an element in a lookup positions the cursor in the lookup
> dataset.
>
> So a property 'SyncLookupCursor' or so should maybe be introduced. The
> default can be 'False', but I for one would need the 'True'.
>
OK. I can do that
Please open a bug report with a sample project with the expected
behavior pointing that is a delphi compatibility
Since the LookupSource is named ListSource
I think of ScrollList or ScrollListSource or ScrollListCursor
Luiz
More information about the Lazarus
mailing list