ABPeoplePicker.pas 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265
  1. //
  2. // ABPeoplePickerC.h
  3. // AddressBook Framework
  4. //
  5. // Copyright (c) 2003 Apple Computer. All rights reserved.
  6. //
  7. { Pascal Translation: Peter N Lewis, <[email protected]>, 2004 }
  8. {
  9. Modified for use with Free Pascal
  10. Version 200
  11. Please report any bugs to <[email protected]>
  12. }
  13. {$mode macpas}
  14. {$packenum 1}
  15. {$macro on}
  16. {$inline on}
  17. {$CALLING MWPASCAL}
  18. unit ABPeoplePicker;
  19. interface
  20. {$setc UNIVERSAL_INTERFACES_VERSION := $0342}
  21. {$setc GAP_INTERFACES_VERSION := $0200}
  22. {$ifc not defined USE_CFSTR_CONSTANT_MACROS}
  23. {$setc USE_CFSTR_CONSTANT_MACROS := TRUE}
  24. {$endc}
  25. {$ifc defined CPUPOWERPC and defined CPUI386}
  26. {$error Conflicting initial definitions for CPUPOWERPC and CPUI386}
  27. {$endc}
  28. {$ifc defined FPC_BIG_ENDIAN and defined FPC_LITTLE_ENDIAN}
  29. {$error Conflicting initial definitions for FPC_BIG_ENDIAN and FPC_LITTLE_ENDIAN}
  30. {$endc}
  31. {$ifc not defined __ppc__ and defined CPUPOWERPC}
  32. {$setc __ppc__ := 1}
  33. {$elsec}
  34. {$setc __ppc__ := 0}
  35. {$endc}
  36. {$ifc not defined __i386__ and defined CPUI386}
  37. {$setc __i386__ := 1}
  38. {$elsec}
  39. {$setc __i386__ := 0}
  40. {$endc}
  41. {$ifc defined __ppc__ and __ppc__ and defined __i386__ and __i386__}
  42. {$error Conflicting definitions for __ppc__ and __i386__}
  43. {$endc}
  44. {$ifc defined __ppc__ and __ppc__}
  45. {$setc TARGET_CPU_PPC := TRUE}
  46. {$setc TARGET_CPU_X86 := FALSE}
  47. {$elifc defined __i386__ and __i386__}
  48. {$setc TARGET_CPU_PPC := FALSE}
  49. {$setc TARGET_CPU_X86 := TRUE}
  50. {$elsec}
  51. {$error Neither __ppc__ nor __i386__ is defined.}
  52. {$endc}
  53. {$setc TARGET_CPU_PPC_64 := FALSE}
  54. {$ifc defined FPC_BIG_ENDIAN}
  55. {$setc TARGET_RT_BIG_ENDIAN := TRUE}
  56. {$setc TARGET_RT_LITTLE_ENDIAN := FALSE}
  57. {$elifc defined FPC_LITTLE_ENDIAN}
  58. {$setc TARGET_RT_BIG_ENDIAN := FALSE}
  59. {$setc TARGET_RT_LITTLE_ENDIAN := TRUE}
  60. {$elsec}
  61. {$error Neither FPC_BIG_ENDIAN nor FPC_LITTLE_ENDIAN are defined.}
  62. {$endc}
  63. {$setc ACCESSOR_CALLS_ARE_FUNCTIONS := TRUE}
  64. {$setc CALL_NOT_IN_CARBON := FALSE}
  65. {$setc OLDROUTINENAMES := FALSE}
  66. {$setc OPAQUE_TOOLBOX_STRUCTS := TRUE}
  67. {$setc OPAQUE_UPP_TYPES := TRUE}
  68. {$setc OTCARBONAPPLICATION := TRUE}
  69. {$setc OTKERNEL := FALSE}
  70. {$setc PM_USE_SESSION_APIS := TRUE}
  71. {$setc TARGET_API_MAC_CARBON := TRUE}
  72. {$setc TARGET_API_MAC_OS8 := FALSE}
  73. {$setc TARGET_API_MAC_OSX := TRUE}
  74. {$setc TARGET_CARBON := TRUE}
  75. {$setc TARGET_CPU_68K := FALSE}
  76. {$setc TARGET_CPU_MIPS := FALSE}
  77. {$setc TARGET_CPU_SPARC := FALSE}
  78. {$setc TARGET_OS_MAC := TRUE}
  79. {$setc TARGET_OS_UNIX := FALSE}
  80. {$setc TARGET_OS_WIN32 := FALSE}
  81. {$setc TARGET_RT_MAC_68881 := FALSE}
  82. {$setc TARGET_RT_MAC_CFM := FALSE}
  83. {$setc TARGET_RT_MAC_MACHO := TRUE}
  84. {$setc TYPED_FUNCTION_POINTERS := TRUE}
  85. {$setc TYPE_BOOL := FALSE}
  86. {$setc TYPE_EXTENDED := FALSE}
  87. {$setc TYPE_LONGLONG := TRUE}
  88. uses MacTypes,ABAddressBook,CFBase,CFArray,CGGeometry,Drag,HIObjectCore,HIGeometry;
  89. {$ALIGN MAC68K}
  90. type
  91. ABPickerRef = ^SInt32;
  92. {
  93. * Picker creation and manipulation
  94. }
  95. // Creates an ABPickerRef. Release with CFRelease(). The window is created hidden. Call
  96. // ABPickerSetVisibility() to show it.
  97. // AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER
  98. function ABPickerCreate: ABPickerRef; external name '_ABPickerCreate';
  99. // Change the structural frame of the window.
  100. // AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER
  101. procedure ABPickerSetFrame( inPicker: ABPickerRef; const (*var*) inFrame: HIRect ); external name '_ABPickerSetFrame';
  102. // AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER
  103. procedure ABPickerGetFrame( inPicker: ABPickerRef; var outFrame: HIRect ); external name '_ABPickerGetFrame';
  104. // AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER
  105. procedure ABPickerSetVisibility( inPicker: ABPickerRef; visible: Boolean ); external name '_ABPickerSetVisibility';
  106. // AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER
  107. function ABPickerIsVisible( inPicker: ABPickerRef ): Boolean; external name '_ABPickerIsVisible';
  108. {
  109. * Look and Feel
  110. }
  111. const
  112. // Choose the selection behavior for the value column. If multiple behaviors are selected,
  113. // the most restrictive behavior will be used. Defaults to kABPickerSingleValueSelection set
  114. // to TRUE.
  115. kABPickerSingleValueSelection = 1 shl 0; // Allow user to choose a single value for a person.
  116. kABPickerMultipleValueSelection = 1 shl 1; // Allow user to choose multiple values for a person.
  117. // Allow the user to select entire groups in the group column. If false, at least one
  118. // person in the group will be selected. Defaults to FALSE.
  119. kABPickerAllowGroupSelection = 1 shl 2;
  120. // Allow the user to select more than one group/record at a time. Defaults to TRUE.
  121. kABPickerAllowMultipleSelection = 1 shl 3;
  122. type ABPickerAttributes = OptionBits;
  123. // AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER
  124. function ABPickerGetAttributes( inPicker: ABPickerRef ): ABPickerAttributes; external name '_ABPickerGetAttributes';
  125. // AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER
  126. procedure ABPickerChangeAttributes( inPicker: ABPickerRef; inAttributesToSet: ABPickerAttributes; inAttributesToClear: ABPickerAttributes ); external name '_ABPickerChangeAttributes';
  127. {
  128. * Value column
  129. }
  130. // These methods control what data (if any) is shown in the values column. The column will only
  131. // display if an AB property is added. A popup button in the column header will be used if more
  132. // than one property is added. Titles for built in properties will localized automatically. A
  133. // list of AB properties can be found in <AddressBook/ABGlobals.h>.
  134. // AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER
  135. procedure ABPickerAddProperty( inPicker: ABPickerRef; inProperty: CFStringRef ); external name '_ABPickerAddProperty';
  136. // AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER
  137. procedure ABPickerRemoveProperty( inPicker: ABPickerRef; inProperty: CFStringRef ); external name '_ABPickerRemoveProperty';
  138. // Returns an array of AB Properties as CFStringRefs.
  139. // AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER
  140. function ABPickerCopyProperties( inPicker: ABPickerRef ): CFArrayRef; external name '_ABPickerCopyProperties';
  141. // Localized titles for third party properties should be set with these methods.
  142. // AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER
  143. procedure ABPickerSetColumnTitle( inPicker: ABPickerRef; inTitle: CFStringRef; inProperty: CFStringRef ); external name '_ABPickerSetColumnTitle';
  144. // AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER
  145. function ABPickerCopyColumnTitle( inPicker: ABPickerRef; inProperty: CFStringRef ): CFStringRef; external name '_ABPickerCopyColumnTitle';
  146. // Display one of the properties added above in the values column.
  147. // AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER
  148. procedure ABPickerSetDisplayedProperty( inPicker: ABPickerRef; inProperty: CFStringRef ); external name '_ABPickerSetDisplayedProperty';
  149. // AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER
  150. function ABPickerCopyDisplayedProperty( inPicker: ABPickerRef ): CFStringRef; external name '_ABPickerCopyDisplayedProperty';
  151. {
  152. * Selection
  153. }
  154. // Returns group column selection as an array of ABGroupRef objects.
  155. // AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER
  156. function ABPickerCopySelectedGroups( inPicker: ABPickerRef ): CFArrayRef; external name '_ABPickerCopySelectedGroups';
  157. // Returns names column selection as an array of ABGroupRef or ABPersonRef objects.
  158. // AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER
  159. function ABPickerCopySelectedRecords( inPicker: ABPickerRef ): CFArrayRef; external name '_ABPickerCopySelectedRecords';
  160. // This method returns an array of selected multi-value identifiers. Returns nil if the displayed
  161. // property is a single value type.
  162. // AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER
  163. function ABPickerCopySelectedIdentifiers( inPicker: ABPickerRef; inPerson: ABPersonRef ): CFArrayRef; external name '_ABPickerCopySelectedIdentifiers';
  164. // Returns an array containing CFStringRefs for each item selected in the values column.
  165. // AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER
  166. function ABPickerCopySelectedValues( inPicker: ABPickerRef ): CFArrayRef; external name '_ABPickerCopySelectedValues';
  167. // Select group/name/value programatically.
  168. // AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER
  169. procedure ABPickerSelectGroup( inPicker: ABPickerRef; inGroup: ABGroupRef; inExtendSelection: Boolean ); external name '_ABPickerSelectGroup';
  170. // AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER
  171. procedure ABPickerSelectRecord( inPicker: ABPickerRef; inRecord: ABRecordRef; inExtendSelection: Boolean ); external name '_ABPickerSelectRecord';
  172. // Individual values contained within an multi-value property can be selected with this method.
  173. // AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER
  174. procedure ABPickerSelectIdentifier( inPicker: ABPickerRef; inPerson: ABPersonRef; inIdentifier: CFStringRef; inExtendSelection: Boolean ); external name '_ABPickerSelectIdentifier';
  175. // Remove selection
  176. // AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER
  177. procedure ABPickerDeselectGroup( inPicker: ABPickerRef; inGroup: ABGroupRef ); external name '_ABPickerDeselectGroup';
  178. // AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER
  179. procedure ABPickerDeselectRecord( inPicker: ABPickerRef; inRecord: ABRecordRef ); external name '_ABPickerDeselectRecord';
  180. // AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER
  181. procedure ABPickerDeselectIdentifier( inPicker: ABPickerRef; inPerson: ABPersonRef; inIdentifier: CFStringRef ); external name '_ABPickerDeselectIdentifier';
  182. // AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER
  183. procedure ABPickerDeselectAll( inPicker: ABPickerRef ); external name '_ABPickerDeselectAll';
  184. {
  185. * Events and Actions
  186. *
  187. * Your delegate will be notified when the user changes the selection or displayed property of the picker.
  188. * Picker events have an event class of kEventClassABPeoplePicker and one of the kinds listed below. Picker
  189. * events contain an event parameter which contains the ABPickerRef. To obtain this:
  190. *
  191. * GetEventParameter(inEvent, kEventParamABPickerRef,
  192. * typeCFTypeRef, NULL, sizeof(ABPickerRef),
  193. * NULL, &outPickerRef);
  194. *
  195. }
  196. const
  197. // Carbon Event class for People Picker
  198. kEventClassABPeoplePicker = $61627070 (* 'abpp' *);
  199. const
  200. // Carbon Event kinds for People Picker
  201. kEventABPeoplePickerGroupSelectionChanged = 1;
  202. kEventABPeoplePickerNameSelectionChanged = 2;
  203. kEventABPeoplePickerValueSelectionChanged = 3;
  204. kEventABPeoplePickerDisplayedPropertyChanged = 4;
  205. kEventABPeoplePickerGroupDoubleClicked = 5;
  206. kEventABPeoplePickerNameDoubleClicked = 6;
  207. const
  208. // Carbon Event parameter name
  209. kEventParamABPickerRef = $61627070 (* 'abpp' *);
  210. // Set the event handler for People Picker events.
  211. // AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER
  212. procedure ABPickerSetDelegate( inPicker: ABPickerRef; inDelegate: HIObjectRef ); external name '_ABPickerSetDelegate';
  213. // AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER
  214. function ABPickerGetDelegate( inPicker: ABPickerRef ): HIObjectRef; external name '_ABPickerGetDelegate';
  215. // Clear the search field and reset the list of displayed names.
  216. // AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER
  217. procedure ABPickerClearSearchField( inPicker: ABPickerRef ); external name '_ABPickerClearSearchField';
  218. // Launch AddressBook and edit the current selection
  219. // AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER
  220. procedure ABPickerEditInAddressBook( inPicker: ABPickerRef ); external name '_ABPickerEditInAddressBook';
  221. // AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER
  222. procedure ABPickerSelectInAddressBook( inPicker: ABPickerRef ); external name '_ABPickerSelectInAddressBook';
  223. end.