X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/715b3df02f73174c67c05d29708a578ad60e64fd..6f026b5b63fe7ccb025e84509886f74772b9df13:/src/cocoa/textctrl.mm?ds=sidebyside diff --git a/src/cocoa/textctrl.mm b/src/cocoa/textctrl.mm index cbab8ea2f1..07df3cdae0 100644 --- a/src/cocoa/textctrl.mm +++ b/src/cocoa/textctrl.mm @@ -2,11 +2,10 @@ // Name: src/cocoa/textctrl.mm // Purpose: wxTextCtrl // Author: David Elliott -// Modified by: +// Modified by: Mark Oxenham // Created: 2003/03/16 -// RCS-ID: $Id$ // Copyright: (c) 2003 David Elliott -// Licence: wxWidgets licence +// Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// #include "wx/wxprec.h" @@ -24,11 +23,11 @@ #import #import +#import #import #include -IMPLEMENT_DYNAMIC_CLASS(wxTextCtrl, wxTextCtrlBase) BEGIN_EVENT_TABLE(wxTextCtrl, wxTextCtrlBase) END_EVENT_TABLE() WX_IMPLEMENT_COCOA_OWNER(wxTextCtrl,NSTextField,NSControl,NSView) @@ -45,7 +44,7 @@ bool wxTextCtrl::Create(wxWindow *parent, wxWindowID winid, if(!CreateControl(parent,winid,pos,size,style,validator,name)) return false; m_cocoaNSView = NULL; - SetNSTextField([[NSTextField alloc] initWithFrame:MakeDefaultNSRect(size)]); + SetNSTextField([(style & wxTE_PASSWORD)?[NSSecureTextField alloc]:[NSTextField alloc] initWithFrame:MakeDefaultNSRect(size)]); [m_cocoaNSView release]; [GetNSTextField() setStringValue:wxNSStringWithWxString(value)]; @@ -62,7 +61,23 @@ bool wxTextCtrl::Create(wxWindow *parent, wxWindowID winid, [(NSTextField*)m_cocoaNSView setTarget: sm_cocoaTarget]; [(NSTextField*)m_cocoaNSView setAction:@selector(wxNSControlAction:)]; - + + // set the text alignment option + NSTextAlignment alignStyle; + if (style & wxTE_RIGHT) + alignStyle = NSRightTextAlignment; + else if (style & wxTE_CENTRE) + alignStyle = NSCenterTextAlignment; + else // default to wxTE_LEFT because it is 0 and can't be tested + alignStyle = NSLeftTextAlignment; + [GetNSControl() setAlignment:alignStyle]; + + // if Read-only then set as such, this flag is overwritable by wxTextCtrl::SetEditable(TRUE) + if (style & wxTE_READONLY) + { + SetEditable(FALSE); + } + return true; } @@ -77,23 +92,25 @@ void wxTextCtrl::Cocoa_didChangeText(void) void wxTextCtrl::CocoaTarget_action(void) { - // NSTextField only sends the action message on enter key press and thus - // we send the appropriate event type. - wxCommandEvent event(wxEVT_COMMAND_TEXT_ENTER, GetId()); - - // See wxTextCtrlBase::SendTextUpdatedEvent for why we don't set the string. - //event.SetString(GetValue()); - - event.SetEventObject(this); - GetEventHandler()->ProcessEvent(event); + SendTextUpdatedEvent(); } void wxTextCtrl::AppendText(wxString const&) { } -void wxTextCtrl::SetEditable(bool) +void wxTextCtrl::SetEditable(bool editable) { + // first ensure that the current value is stored (in case the user had not finished editing + // before SetEditable(FALSE) was called) + DoSetValue(GetValue(),1); + + [GetNSTextField() setEditable: editable]; + + // forces the focus on the textctrl to be lost - while focus is still maintained + // after SetEditable(FALSE) the user may still edit the control + // (might not the best way to do this..) + [GetNSTextField() abortEditing]; } void wxTextCtrl::MarkDirty() @@ -167,7 +184,7 @@ void wxTextCtrl::WriteText(wxString const&) bool wxTextCtrl::IsEditable() const { - return true; + return [GetNSTextField() isEditable]; } bool wxTextCtrl::IsModified() const @@ -201,7 +218,8 @@ int wxTextCtrl::GetLineLength(long) const wxTextPos wxTextCtrl::GetLastPosition() const { - return 0; + // working - returns the size of the wxString + return (long)(GetValue().Len()); } int wxTextCtrl::GetNumberOfLines() const