* Set an explicit min size for the text controls. This fixes bug #6863.
Note, the BTextControl doesn't work correctly with its layout items, if present. I'll open a bug report for that. * Disallow spaces as well for the internal type name. * Minor cleanup. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@39579 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
a753859956
commit
ffd05c4362
@ -63,17 +63,53 @@ const uint32 kMsgRemoveType = 'rmtp';
|
|||||||
const uint32 kMsgTypeRemoved = 'tprm';
|
const uint32 kMsgTypeRemoved = 'tprm';
|
||||||
|
|
||||||
|
|
||||||
// TextView that filters the tab key to be able to tab-navigate while editing
|
//! TextView that filters the tab key to be able to tab-navigate while editing
|
||||||
class TabFilteringTextView : public BTextView {
|
class TabFilteringTextView : public BTextView {
|
||||||
public:
|
public:
|
||||||
TabFilteringTextView(const char* name);
|
TabFilteringTextView(const char* name);
|
||||||
virtual ~TabFilteringTextView();
|
virtual ~TabFilteringTextView();
|
||||||
virtual void KeyDown(const char* bytes, int32 count);
|
|
||||||
|
virtual void KeyDown(const char* bytes, int32 count);
|
||||||
|
};
|
||||||
|
|
||||||
|
class SupportedTypeItem : public BStringItem {
|
||||||
|
public:
|
||||||
|
SupportedTypeItem(const char* type);
|
||||||
|
virtual ~SupportedTypeItem();
|
||||||
|
|
||||||
|
const char* Type() const { return fType.String(); }
|
||||||
|
::Icon& Icon() { return fIcon; }
|
||||||
|
|
||||||
|
void SetIcon(::Icon* icon);
|
||||||
|
void SetIcon(entry_ref& ref, const char* type);
|
||||||
|
|
||||||
|
static int Compare(const void* _a, const void* _b);
|
||||||
|
|
||||||
|
private:
|
||||||
|
BString fType;
|
||||||
|
::Icon fIcon;
|
||||||
|
};
|
||||||
|
|
||||||
|
class SupportedTypeListView : public DropTargetListView {
|
||||||
|
public:
|
||||||
|
SupportedTypeListView(const char* name,
|
||||||
|
list_view_type
|
||||||
|
type = B_SINGLE_SELECTION_LIST,
|
||||||
|
uint32 flags = B_WILL_DRAW
|
||||||
|
| B_FRAME_EVENTS | B_NAVIGABLE);
|
||||||
|
virtual ~SupportedTypeListView();
|
||||||
|
|
||||||
|
virtual void MessageReceived(BMessage* message);
|
||||||
|
virtual bool AcceptsDrag(const BMessage* message);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
// #pragma mark -
|
||||||
|
|
||||||
|
|
||||||
TabFilteringTextView::TabFilteringTextView(const char* name)
|
TabFilteringTextView::TabFilteringTextView(const char* name)
|
||||||
: BTextView(name, B_WILL_DRAW | B_PULSE_NEEDED)
|
:
|
||||||
|
BTextView(name, B_WILL_DRAW | B_PULSE_NEEDED)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -93,33 +129,7 @@ TabFilteringTextView::KeyDown(const char* bytes, int32 count)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
class SupportedTypeItem : public BStringItem {
|
// #pragma mark -
|
||||||
public:
|
|
||||||
SupportedTypeItem(const char* type);
|
|
||||||
~SupportedTypeItem();
|
|
||||||
|
|
||||||
const char* Type() const { return fType.String(); }
|
|
||||||
::Icon& Icon() { return fIcon; }
|
|
||||||
void SetIcon(::Icon* icon);
|
|
||||||
void SetIcon(entry_ref& ref, const char* type);
|
|
||||||
|
|
||||||
static int Compare(const void* _a, const void* _b);
|
|
||||||
|
|
||||||
private:
|
|
||||||
BString fType;
|
|
||||||
::Icon fIcon;
|
|
||||||
};
|
|
||||||
|
|
||||||
class SupportedTypeListView : public DropTargetListView {
|
|
||||||
public:
|
|
||||||
SupportedTypeListView(const char* name,
|
|
||||||
list_view_type type = B_SINGLE_SELECTION_LIST,
|
|
||||||
uint32 flags = B_WILL_DRAW | B_FRAME_EVENTS | B_NAVIGABLE);
|
|
||||||
virtual ~SupportedTypeListView();
|
|
||||||
|
|
||||||
virtual void MessageReceived(BMessage* message);
|
|
||||||
virtual bool AcceptsDrag(const BMessage* message);
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
SupportedTypeItem::SupportedTypeItem(const char* type)
|
SupportedTypeItem::SupportedTypeItem(const char* type)
|
||||||
@ -277,7 +287,7 @@ ApplicationTypeWindow::ApplicationTypeWindow(BPoint position,
|
|||||||
// filter out invalid characters that can't be part of a MIME type name
|
// filter out invalid characters that can't be part of a MIME type name
|
||||||
BTextView* textView = fSignatureControl->TextView();
|
BTextView* textView = fSignatureControl->TextView();
|
||||||
textView->SetMaxBytes(B_MIME_TYPE_LENGTH);
|
textView->SetMaxBytes(B_MIME_TYPE_LENGTH);
|
||||||
const char* disallowedCharacters = "<>@,;:\"()[]?=";
|
const char* disallowedCharacters = "<>@,;:\"()[]?= ";
|
||||||
for (int32 i = 0; disallowedCharacters[i]; i++) {
|
for (int32 i = 0; disallowedCharacters[i]; i++) {
|
||||||
textView->DisallowChar(disallowedCharacters[i]);
|
textView->DisallowChar(disallowedCharacters[i]);
|
||||||
}
|
}
|
||||||
@ -409,6 +419,18 @@ ApplicationTypeWindow::ApplicationTypeWindow(BPoint position,
|
|||||||
minScrollSize.width += fLongDescriptionView->MinSize().width;
|
minScrollSize.width += fLongDescriptionView->MinSize().width;
|
||||||
scrollView->SetExplicitMinSize(minScrollSize);
|
scrollView->SetExplicitMinSize(minScrollSize);
|
||||||
|
|
||||||
|
// Manually set a minimum size for the version text controls
|
||||||
|
// TODO: the same does not work when applied to the layout items
|
||||||
|
float width = be_plain_font->StringWidth("99") + 16;
|
||||||
|
fMajorVersionControl->TextView()->SetExplicitMinSize(
|
||||||
|
BSize(width, fMajorVersionControl->MinSize().height));
|
||||||
|
fMiddleVersionControl->TextView()->SetExplicitMinSize(
|
||||||
|
BSize(width, fMiddleVersionControl->MinSize().height));
|
||||||
|
fMinorVersionControl->TextView()->SetExplicitMinSize(
|
||||||
|
BSize(width, fMinorVersionControl->MinSize().height));
|
||||||
|
fInternalVersionControl->TextView()->SetExplicitMinSize(
|
||||||
|
BSize(width, fInternalVersionControl->MinSize().height));
|
||||||
|
|
||||||
versionBox->AddChild(BGridLayoutBuilder(padding / 2, padding / 2)
|
versionBox->AddChild(BGridLayoutBuilder(padding / 2, padding / 2)
|
||||||
.Add(fMajorVersionControl->CreateLabelLayoutItem(), 0, 0)
|
.Add(fMajorVersionControl->CreateLabelLayoutItem(), 0, 0)
|
||||||
.Add(fMajorVersionControl->CreateTextViewLayoutItem(), 1, 0)
|
.Add(fMajorVersionControl->CreateTextViewLayoutItem(), 1, 0)
|
||||||
|
Loading…
Reference in New Issue
Block a user