element-ios/Riot/Modules/MatrixKit/Models/Contact/MXKContact.h

166 lines
4.4 KiB
Objective-C

/*
Copyright 2024 New Vector Ltd.
Copyright 2017 Vector Creations Ltd
Copyright 2015 OpenMarket Ltd
SPDX-License-Identifier: AGPL-3.0-only
Please see LICENSE in the repository root for full details.
*/
#import <UIKit/UIKit.h>
#import <AddressBook/AddressBook.h>
#import "MXKCellData.h"
#import "MXKEmail.h"
#import "MXKPhoneNumber.h"
/**
Posted when the contact thumbnail is updated.
The notification object is a contact Id.
*/
extern NSString *const kMXKContactThumbnailUpdateNotification;
extern NSString *const kMXKContactLocalContactPrefixId;
extern NSString *const kMXKContactMatrixContactPrefixId;
extern NSString *const kMXKContactDefaultContactPrefixId;
@interface MXKContact : MXKCellData <NSCoding>
/**
The unique identifier
*/
@property (nonatomic, readonly) NSString * contactID;
/**
The display name
*/
@property (nonatomic, readwrite) NSString *displayName;
/**
The sorting display name built by trimming the symbols [_!~`@#$%^&*-+();:={}[],.<>?\/"'] from the display name.
*/
@property (nonatomic) NSString* sortingDisplayName;
/**
The contact thumbnail. Default size: 256 X 256 pixels
*/
@property (nonatomic, copy, readonly) UIImage *thumbnail;
/**
YES if the contact does not exist in the contacts book
the contact has been created from a MXUser or MXRoomThirdPartyInvite
*/
@property (nonatomic) BOOL isMatrixContact;
/**
YES if the contact is coming from MXRoomThirdPartyInvite event (NO by default).
*/
@property (nonatomic) BOOL isThirdPartyInvite;
/**
The array of MXKPhoneNumber
*/
@property (nonatomic, readonly) NSArray *phoneNumbers;
/**
The array of MXKEmail
*/
@property (nonatomic, readonly) NSArray *emailAddresses;
/**
The array of matrix identifiers
*/
@property (nonatomic, readonly) NSArray* matrixIdentifiers;
/**
The matrix avatar url used (if any) to build the current thumbnail, nil by default.
*/
@property (nonatomic, readonly) NSString* matrixAvatarURL;
/**
Reset the current thumbnail if it is retrieved from a matrix url. May be used in case of the matrix avatar url change.
A new thumbnail will be automatically restored from the contact data.
*/
- (void)resetMatrixThumbnail;
#pragma clang diagnostic push
#pragma clang diagnostic ignored "-Wdeprecated"
/**
The contact ID from native phonebook record
*/
+ (NSString*)contactID:(ABRecordRef)record;
/**
Create a local contact from a device contact
@param record device contact id
@return MXKContact instance
*/
- (id)initLocalContactWithABRecord:(ABRecordRef)record;
#pragma clang diagnostic pop
/**
Create a matrix contact with the dedicated info
@param displayName the contact display name
@param matrixID the contact matrix id
@return MXKContact instance
*/
- (id)initMatrixContactWithDisplayName:(NSString*)displayName andMatrixID:(NSString*)matrixID;
/**
Create a matrix contact with the dedicated info
@param displayName the contact display name
@param matrixID the contact matrix id
@param matrixAvatarURL the matrix avatar url
@return MXKContact instance
*/
- (id)initMatrixContactWithDisplayName:(NSString*)displayName matrixID:(NSString*)matrixID andMatrixAvatarURL:(NSString*)matrixAvatarURL;
/**
Create a contact with the dedicated info
@param displayName the contact display name
@param emails an array of emails
@param phones an array of phone numbers
@param thumbnail the contact thumbnail
@return MXKContact instance
*/
- (id)initContactWithDisplayName:(NSString*)displayName
emails:(NSArray<MXKEmail*> *)emails
phoneNumbers:(NSArray<MXKPhoneNumber*> *)phones
andThumbnail:(UIImage *)thumbnail;
/**
The contact thumbnail with a prefered size.
If the thumbnail is already loaded, this method returns this one by ignoring prefered size.
The prefered size is used only if a server request is required.
@return thumbnail with a prefered size
*/
- (UIImage*)thumbnailWithPreferedSize:(CGSize)size;
/**
Tell whether a component of the contact's displayName, or one of his matrix id/email has the provided prefix.
@param prefix a non empty string.
@return YES when at least one matrix id, email or a component of the display name has this prefix.
*/
- (BOOL)hasPrefix:(NSString*)prefix;
/**
Check if the patterns can match with this contact
*/
- (BOOL)matchedWithPatterns:(NSArray*)patterns;
/**
The default ISO 3166-1 country code used to internationalize the contact phone numbers.
*/
@property (nonatomic) NSString *defaultCountryCode;
@end