ABPeoplePicker.pas 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396
  1. {
  2. //
  3. // ABPeoplePickerC.h
  4. // AddressBook Framework
  5. //
  6. // Copyright (c) 2003-2007 Apple Inc. All rights reserved.
  7. //
  8. }
  9. { Pascal Translation: Peter N Lewis, <[email protected]>, 2004 }
  10. { Pascal Translation Updated: Gorazd Krosl, <[email protected]>, November 2009 }
  11. {
  12. Modified for use with Free Pascal
  13. Version 308
  14. Please report any bugs to <[email protected]>
  15. }
  16. {$ifc not defined MACOSALLINCLUDE or not MACOSALLINCLUDE}
  17. {$mode macpas}
  18. {$modeswitch cblocks}
  19. {$packenum 1}
  20. {$macro on}
  21. {$inline on}
  22. {$calling mwpascal}
  23. {$IFNDEF FPC_DOTTEDUNITS}
  24. unit ABPeoplePicker;
  25. {$ENDIF FPC_DOTTEDUNITS}
  26. interface
  27. {$setc UNIVERSAL_INTERFACES_VERSION := $0400}
  28. {$setc GAP_INTERFACES_VERSION := $0308}
  29. {$ifc not defined USE_CFSTR_CONSTANT_MACROS}
  30. {$setc USE_CFSTR_CONSTANT_MACROS := TRUE}
  31. {$endc}
  32. {$ifc defined CPUPOWERPC and defined CPUI386}
  33. {$error Conflicting initial definitions for CPUPOWERPC and CPUI386}
  34. {$endc}
  35. {$ifc defined FPC_BIG_ENDIAN and defined FPC_LITTLE_ENDIAN}
  36. {$error Conflicting initial definitions for FPC_BIG_ENDIAN and FPC_LITTLE_ENDIAN}
  37. {$endc}
  38. {$ifc not defined __ppc__ and defined CPUPOWERPC32}
  39. {$setc __ppc__ := 1}
  40. {$elsec}
  41. {$setc __ppc__ := 0}
  42. {$endc}
  43. {$ifc not defined __ppc64__ and defined CPUPOWERPC64}
  44. {$setc __ppc64__ := 1}
  45. {$elsec}
  46. {$setc __ppc64__ := 0}
  47. {$endc}
  48. {$ifc not defined __i386__ and defined CPUI386}
  49. {$setc __i386__ := 1}
  50. {$elsec}
  51. {$setc __i386__ := 0}
  52. {$endc}
  53. {$ifc not defined __x86_64__ and defined CPUX86_64}
  54. {$setc __x86_64__ := 1}
  55. {$elsec}
  56. {$setc __x86_64__ := 0}
  57. {$endc}
  58. {$ifc not defined __arm__ and defined CPUARM}
  59. {$setc __arm__ := 1}
  60. {$elsec}
  61. {$setc __arm__ := 0}
  62. {$endc}
  63. {$ifc not defined __arm64__ and defined CPUAARCH64}
  64. {$setc __arm64__ := 1}
  65. {$elsec}
  66. {$setc __arm64__ := 0}
  67. {$endc}
  68. {$ifc defined cpu64}
  69. {$setc __LP64__ := 1}
  70. {$elsec}
  71. {$setc __LP64__ := 0}
  72. {$endc}
  73. {$ifc defined __ppc__ and __ppc__ and defined __i386__ and __i386__}
  74. {$error Conflicting definitions for __ppc__ and __i386__}
  75. {$endc}
  76. {$ifc defined __ppc__ and __ppc__}
  77. {$setc TARGET_CPU_PPC := TRUE}
  78. {$setc TARGET_CPU_PPC64 := FALSE}
  79. {$setc TARGET_CPU_X86 := FALSE}
  80. {$setc TARGET_CPU_X86_64 := FALSE}
  81. {$setc TARGET_CPU_ARM := FALSE}
  82. {$setc TARGET_CPU_ARM64 := FALSE}
  83. {$setc TARGET_OS_MAC := TRUE}
  84. {$setc TARGET_OS_IPHONE := FALSE}
  85. {$setc TARGET_IPHONE_SIMULATOR := FALSE}
  86. {$setc TARGET_OS_EMBEDDED := FALSE}
  87. {$elifc defined __ppc64__ and __ppc64__}
  88. {$setc TARGET_CPU_PPC := FALSE}
  89. {$setc TARGET_CPU_PPC64 := TRUE}
  90. {$setc TARGET_CPU_X86 := FALSE}
  91. {$setc TARGET_CPU_X86_64 := FALSE}
  92. {$setc TARGET_CPU_ARM := FALSE}
  93. {$setc TARGET_CPU_ARM64 := FALSE}
  94. {$setc TARGET_OS_MAC := TRUE}
  95. {$setc TARGET_OS_IPHONE := FALSE}
  96. {$setc TARGET_IPHONE_SIMULATOR := FALSE}
  97. {$setc TARGET_OS_EMBEDDED := FALSE}
  98. {$elifc defined __i386__ and __i386__}
  99. {$setc TARGET_CPU_PPC := FALSE}
  100. {$setc TARGET_CPU_PPC64 := FALSE}
  101. {$setc TARGET_CPU_X86 := TRUE}
  102. {$setc TARGET_CPU_X86_64 := FALSE}
  103. {$setc TARGET_CPU_ARM := FALSE}
  104. {$setc TARGET_CPU_ARM64 := FALSE}
  105. {$ifc defined iphonesim}
  106. {$setc TARGET_OS_MAC := FALSE}
  107. {$setc TARGET_OS_IPHONE := TRUE}
  108. {$setc TARGET_IPHONE_SIMULATOR := TRUE}
  109. {$elsec}
  110. {$setc TARGET_OS_MAC := TRUE}
  111. {$setc TARGET_OS_IPHONE := FALSE}
  112. {$setc TARGET_IPHONE_SIMULATOR := FALSE}
  113. {$endc}
  114. {$setc TARGET_OS_EMBEDDED := FALSE}
  115. {$elifc defined __x86_64__ and __x86_64__}
  116. {$setc TARGET_CPU_PPC := FALSE}
  117. {$setc TARGET_CPU_PPC64 := FALSE}
  118. {$setc TARGET_CPU_X86 := FALSE}
  119. {$setc TARGET_CPU_X86_64 := TRUE}
  120. {$setc TARGET_CPU_ARM := FALSE}
  121. {$setc TARGET_CPU_ARM64 := FALSE}
  122. {$ifc defined iphonesim}
  123. {$setc TARGET_OS_MAC := FALSE}
  124. {$setc TARGET_OS_IPHONE := TRUE}
  125. {$setc TARGET_IPHONE_SIMULATOR := TRUE}
  126. {$elsec}
  127. {$setc TARGET_OS_MAC := TRUE}
  128. {$setc TARGET_OS_IPHONE := FALSE}
  129. {$setc TARGET_IPHONE_SIMULATOR := FALSE}
  130. {$endc}
  131. {$setc TARGET_OS_EMBEDDED := FALSE}
  132. {$elifc defined __arm__ and __arm__}
  133. {$setc TARGET_CPU_PPC := FALSE}
  134. {$setc TARGET_CPU_PPC64 := FALSE}
  135. {$setc TARGET_CPU_X86 := FALSE}
  136. {$setc TARGET_CPU_X86_64 := FALSE}
  137. {$setc TARGET_CPU_ARM := TRUE}
  138. {$setc TARGET_CPU_ARM64 := FALSE}
  139. {$setc TARGET_OS_MAC := FALSE}
  140. {$setc TARGET_OS_IPHONE := TRUE}
  141. {$setc TARGET_IPHONE_SIMULATOR := FALSE}
  142. {$setc TARGET_OS_EMBEDDED := TRUE}
  143. {$elifc defined __arm64__ and __arm64__}
  144. {$setc TARGET_CPU_PPC := FALSE}
  145. {$setc TARGET_CPU_PPC64 := FALSE}
  146. {$setc TARGET_CPU_X86 := FALSE}
  147. {$setc TARGET_CPU_X86_64 := FALSE}
  148. {$setc TARGET_CPU_ARM := FALSE}
  149. {$setc TARGET_CPU_ARM64 := TRUE}
  150. {$ifc defined ios}
  151. {$setc TARGET_OS_MAC := FALSE}
  152. {$setc TARGET_OS_IPHONE := TRUE}
  153. {$setc TARGET_OS_EMBEDDED := TRUE}
  154. {$elsec}
  155. {$setc TARGET_OS_MAC := TRUE}
  156. {$setc TARGET_OS_IPHONE := FALSE}
  157. {$setc TARGET_OS_EMBEDDED := FALSE}
  158. {$endc}
  159. {$setc TARGET_IPHONE_SIMULATOR := FALSE}
  160. {$elsec}
  161. {$error __ppc__ nor __ppc64__ nor __i386__ nor __x86_64__ nor __arm__ nor __arm64__ is defined.}
  162. {$endc}
  163. {$ifc defined __LP64__ and __LP64__ }
  164. {$setc TARGET_CPU_64 := TRUE}
  165. {$elsec}
  166. {$setc TARGET_CPU_64 := FALSE}
  167. {$endc}
  168. {$ifc defined FPC_BIG_ENDIAN}
  169. {$setc TARGET_RT_BIG_ENDIAN := TRUE}
  170. {$setc TARGET_RT_LITTLE_ENDIAN := FALSE}
  171. {$elifc defined FPC_LITTLE_ENDIAN}
  172. {$setc TARGET_RT_BIG_ENDIAN := FALSE}
  173. {$setc TARGET_RT_LITTLE_ENDIAN := TRUE}
  174. {$elsec}
  175. {$error Neither FPC_BIG_ENDIAN nor FPC_LITTLE_ENDIAN are defined.}
  176. {$endc}
  177. {$setc ACCESSOR_CALLS_ARE_FUNCTIONS := TRUE}
  178. {$setc CALL_NOT_IN_CARBON := FALSE}
  179. {$setc OLDROUTINENAMES := FALSE}
  180. {$setc OPAQUE_TOOLBOX_STRUCTS := TRUE}
  181. {$setc OPAQUE_UPP_TYPES := TRUE}
  182. {$setc OTCARBONAPPLICATION := TRUE}
  183. {$setc OTKERNEL := FALSE}
  184. {$setc PM_USE_SESSION_APIS := TRUE}
  185. {$setc TARGET_API_MAC_CARBON := TRUE}
  186. {$setc TARGET_API_MAC_OS8 := FALSE}
  187. {$setc TARGET_API_MAC_OSX := TRUE}
  188. {$setc TARGET_CARBON := TRUE}
  189. {$setc TARGET_CPU_68K := FALSE}
  190. {$setc TARGET_CPU_MIPS := FALSE}
  191. {$setc TARGET_CPU_SPARC := FALSE}
  192. {$setc TARGET_OS_UNIX := FALSE}
  193. {$setc TARGET_OS_WIN32 := FALSE}
  194. {$setc TARGET_RT_MAC_68881 := FALSE}
  195. {$setc TARGET_RT_MAC_CFM := FALSE}
  196. {$setc TARGET_RT_MAC_MACHO := TRUE}
  197. {$setc TYPED_FUNCTION_POINTERS := TRUE}
  198. {$setc TYPE_BOOL := FALSE}
  199. {$setc TYPE_EXTENDED := FALSE}
  200. {$setc TYPE_LONGLONG := TRUE}
  201. {$IFDEF FPC_DOTTEDUNITS}
  202. uses MacOsApi.MacTypes,MacOsApi.ABAddressBook,MacOsApi.CFBase,MacOsApi.CFArray,MacOsApi.CGGeometry,MacOsApi.HIGeometry,MacOsApi.CarbonEventsCore;
  203. {$ELSE FPC_DOTTEDUNITS}
  204. uses MacTypes,ABAddressBook,CFBase,CFArray,CGGeometry,HIGeometry,CarbonEventsCore;
  205. {$ENDIF FPC_DOTTEDUNITS}
  206. {$endc} {not MACOSALLINCLUDE}
  207. {$ifc TARGET_OS_MAC}
  208. {$ALIGN POWER}
  209. type
  210. ABPickerRef = ^OpaqueABPicker; { an opaque type }
  211. OpaqueABPicker = record end;
  212. {
  213. * Picker creation and manipulation
  214. }
  215. // Creates an ABPickerRef. Release with CFRelease(). The window is created hidden. Call
  216. // ABPickerSetVisibility() to show it.
  217. function ABPickerCreate: ABPickerRef; external name '_ABPickerCreate';
  218. (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *)
  219. // Change the structural frame of the window.
  220. procedure ABPickerSetFrame( inPicker: ABPickerRef; const (*var*) inFrame: HIRect ); external name '_ABPickerSetFrame';
  221. (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *)
  222. procedure ABPickerGetFrame( inPicker: ABPickerRef; var outFrame: HIRect ); external name '_ABPickerGetFrame';
  223. (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *)
  224. procedure ABPickerSetVisibility( inPicker: ABPickerRef; visible: CBool ); external name '_ABPickerSetVisibility';
  225. (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *)
  226. function ABPickerIsVisible( inPicker: ABPickerRef ): CBool; external name '_ABPickerIsVisible';
  227. (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *)
  228. {
  229. * Look and Feel
  230. }
  231. const
  232. // Choose the selection behavior for the value column. If multiple behaviors are selected,
  233. // the most restrictive behavior will be used. Defaults to kABPickerSingleValueSelection set
  234. // to TRUE.
  235. kABPickerSingleValueSelection = 1 shl 0; // Allow user to choose a single value for a person.
  236. kABPickerMultipleValueSelection = 1 shl 1; // Allow user to choose multiple values for a person.
  237. // Allow the user to select entire groups in the group column. If false, at least one
  238. // person in the group will be selected. Defaults to FALSE.
  239. kABPickerAllowGroupSelection = 1 shl 2;
  240. // Allow the user to select more than one group/record at a time. Defaults to TRUE.
  241. kABPickerAllowMultipleSelection = 1 shl 3;
  242. type
  243. ABPickerAttributes = OptionBits;
  244. function ABPickerGetAttributes( inPicker: ABPickerRef ): ABPickerAttributes; external name '_ABPickerGetAttributes';
  245. (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *)
  246. procedure ABPickerChangeAttributes( inPicker: ABPickerRef; inAttributesToSet: ABPickerAttributes; inAttributesToClear: ABPickerAttributes ); external name '_ABPickerChangeAttributes';
  247. (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *)
  248. {
  249. * Value column
  250. }
  251. // These methods control what data (if any) is shown in the values column. The column will only
  252. // display if an AB property is added. A popup button in the column header will be used if more
  253. // than one property is added. Titles for built in properties will localized automatically. A
  254. // list of AB properties can be found in <AddressBook/ABGlobals.h>.
  255. procedure ABPickerAddProperty( inPicker: ABPickerRef; inProperty: CFStringRef ); external name '_ABPickerAddProperty';
  256. (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *)
  257. procedure ABPickerRemoveProperty( inPicker: ABPickerRef; inProperty: CFStringRef ); external name '_ABPickerRemoveProperty';
  258. (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *)
  259. // Returns an array of AB Properties as CFStringRefs.
  260. function ABPickerCopyProperties( inPicker: ABPickerRef ): CFArrayRef; external name '_ABPickerCopyProperties';
  261. (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *)
  262. // Localized titles for third party properties should be set with these methods.
  263. procedure ABPickerSetColumnTitle( inPicker: ABPickerRef; inTitle: CFStringRef; inProperty: CFStringRef ); external name '_ABPickerSetColumnTitle';
  264. (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *)
  265. function ABPickerCopyColumnTitle( inPicker: ABPickerRef; inProperty: CFStringRef ): CFStringRef; external name '_ABPickerCopyColumnTitle';
  266. (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *)
  267. // Display one of the properties added above in the values column.
  268. procedure ABPickerSetDisplayedProperty( inPicker: ABPickerRef; inProperty: CFStringRef ); external name '_ABPickerSetDisplayedProperty';
  269. (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *)
  270. function ABPickerCopyDisplayedProperty( inPicker: ABPickerRef ): CFStringRef; external name '_ABPickerCopyDisplayedProperty';
  271. (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *)
  272. {
  273. * Selection
  274. }
  275. // Returns group column selection as an array of ABGroupRef objects.
  276. function ABPickerCopySelectedGroups( inPicker: ABPickerRef ): CFArrayRef; external name '_ABPickerCopySelectedGroups';
  277. (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *)
  278. // Returns names column selection as an array of ABGroupRef or ABPersonRef objects.
  279. function ABPickerCopySelectedRecords( inPicker: ABPickerRef ): CFArrayRef; external name '_ABPickerCopySelectedRecords';
  280. (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *)
  281. // This method returns an array of selected multi-value identifiers. Returns nil if the displayed
  282. // property is a single value type.
  283. function ABPickerCopySelectedIdentifiers( inPicker: ABPickerRef; inPerson: ABPersonRef ): CFArrayRef; external name '_ABPickerCopySelectedIdentifiers';
  284. (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *)
  285. // Returns an array containing CFStringRefs for each item selected in the values column.
  286. function ABPickerCopySelectedValues( inPicker: ABPickerRef ): CFArrayRef; external name '_ABPickerCopySelectedValues';
  287. (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *)
  288. // Select group/name/value programatically.
  289. procedure ABPickerSelectGroup( inPicker: ABPickerRef; inGroup: ABGroupRef; inExtendSelection: CBool ); external name '_ABPickerSelectGroup';
  290. (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *)
  291. procedure ABPickerSelectRecord( inPicker: ABPickerRef; inRecord: ABRecordRef; inExtendSelection: CBool ); external name '_ABPickerSelectRecord';
  292. (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *)
  293. // Individual values contained within an multi-value property can be selected with this method.
  294. procedure ABPickerSelectIdentifier( inPicker: ABPickerRef; inPerson: ABPersonRef; inIdentifier: CFStringRef; inExtendSelection: CBool ); external name '_ABPickerSelectIdentifier';
  295. (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *)
  296. // Remove selection
  297. procedure ABPickerDeselectGroup( inPicker: ABPickerRef; inGroup: ABGroupRef ); external name '_ABPickerDeselectGroup';
  298. (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *)
  299. procedure ABPickerDeselectRecord( inPicker: ABPickerRef; inRecord: ABRecordRef ); external name '_ABPickerDeselectRecord';
  300. (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *)
  301. procedure ABPickerDeselectIdentifier( inPicker: ABPickerRef; inPerson: ABPersonRef; inIdentifier: CFStringRef ); external name '_ABPickerDeselectIdentifier';
  302. (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *)
  303. procedure ABPickerDeselectAll( inPicker: ABPickerRef ); external name '_ABPickerDeselectAll';
  304. (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *)
  305. {
  306. * Events and Actions
  307. *
  308. * Your delegate will be notified when the user changes the selection or displayed property of the picker.
  309. * Picker events have an event class of kEventClassABPeoplePicker and one of the kinds listed below. Picker
  310. * events contain an event parameter which contains the ABPickerRef. To obtain this:
  311. *
  312. * GetEventParameter(inEvent, kEventParamABPickerRef,
  313. * typeCFTypeRef, NULL, sizeof(ABPickerRef),
  314. * NULL, &outPickerRef);
  315. *
  316. }
  317. const
  318. // Carbon Event class for People Picker
  319. kEventClassABPeoplePicker = FourCharCode('abpp');
  320. const
  321. // Carbon Event kinds for People Picker
  322. kEventABPeoplePickerGroupSelectionChanged = 1;
  323. kEventABPeoplePickerNameSelectionChanged = 2;
  324. kEventABPeoplePickerValueSelectionChanged = 3;
  325. kEventABPeoplePickerDisplayedPropertyChanged = 4;
  326. kEventABPeoplePickerGroupDoubleClicked = 5;
  327. kEventABPeoplePickerNameDoubleClicked = 6;
  328. const
  329. // Carbon Event parameter name
  330. kEventParamABPickerRef = FourCharCode('abpp');
  331. // Set the event handler for People Picker events.
  332. procedure ABPickerSetDelegate( inPicker: ABPickerRef; inDelegate: EventTargetRef ); external name '_ABPickerSetDelegate';
  333. (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *)
  334. function ABPickerGetDelegate( inPicker: ABPickerRef ): EventTargetRef; external name '_ABPickerGetDelegate';
  335. (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *)
  336. // Clear the search field and reset the list of displayed names.
  337. procedure ABPickerClearSearchField( inPicker: ABPickerRef ); external name '_ABPickerClearSearchField';
  338. (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *)
  339. // Launch AddressBook and edit the current selection
  340. procedure ABPickerEditInAddressBook( inPicker: ABPickerRef ); external name '_ABPickerEditInAddressBook';
  341. (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *)
  342. procedure ABPickerSelectInAddressBook( inPicker: ABPickerRef ); external name '_ABPickerSelectInAddressBook';
  343. (* AVAILABLE_MAC_OS_X_VERSION_10_3_AND_LATER *)
  344. {$endc} {TARGET_OS_MAC}
  345. {$ifc not defined MACOSALLINCLUDE or not MACOSALLINCLUDE}
  346. end.
  347. {$endc} {not MACOSALLINCLUDE}