lpw
2023-06-03 59da39fdc8c28bbca1d6b8288e9fd20435f7bf2a
commit | author | age
05f1b6 1 //
L 2 //  AIHelpSupportSDK
3 //
4 //  Created by AIHelp.
5 //  Copyright © 2020 aihelp.net. All rights reserved.
6 //
7
8 #import <Foundation/Foundation.h>
9 #import <AIHelpSupportSDK/AIHelpSDKConfig.h>
10 #import <UIKit/UIKit.h>
11
d99a25 12 typedef void (*AISupportInitCallBack)(const bool isSuccess, const char * message);
05f1b6 13 typedef void (*AISupportMessageCallBack)(const int unreadCount);
d99a25 14 typedef void (*AISupportPingCallBack)(const char * log);
05f1b6 15 typedef void (*AISupportIsSpecificFormCallBack)(void);
L 16 typedef void (*AISupportOpenSDKCallBack)(void);
17 typedef void (*AISupportCloseSDKCallBack)(void);
18 typedef void (*AISupportOperationUnReadCallBack)(const bool hasUnreadArticles);
d99a25 19 typedef void (*AISupportSpecificUrlClickedCallBack)(const char * url);
05f1b6 20
L 21 @interface AIHelpSupportSDK : NSObject
22
23 /**
24  * Initialize AIHelp sdk
25  *
26  * When initializing AIHelp you must pass these three tokens. You initialize AIHelp by adding the following lines in the implementation file for your app delegate, ideally at the top of application:didFinishLaunchingWithOptions
27  * @param apiKey This is your developer API Key
28  * @param domainName This is your domain name without any http:// or forward slashes
29  * @param appId  This is the unique ID assigned to your app
30  */
31 + (void)initWithApiKey:(NSString *)apiKey domainName:(NSString *)domainName appId:(NSString *)appId;
32
33 /**
34  * Initialize AIHelp sdk
35  *
36  * When initializing AIHelp you must pass these three tokens. You initialize AIHelp by adding the following lines in the implementation file for your app delegate, ideally at the top of application:didFinishLaunchingWithOptions
37  * @param apiKey This is your developer API Key
38  * @param domainName This is your domain name without any http:// or forward slashes
39  * @param appId  This is the unique ID assigned to your app
40  * @param language  This is your expected init language
41  */
42 + (void)initWithApiKey:(NSString *)apiKey domainName:(NSString *)domainName appId:(NSString *)appId language:(NSString *)language;
43
44 /**
d99a25 45  * Show the AIHelp conversation screen.
05f1b6 46  *
d99a25 47  * If you want to custom your welcome message, please check next method for more information.
05f1b6 48  */
d99a25 49 + (BOOL)showWithEntranceId:(NSString *)entranceId;
05f1b6 50
L 51 /**
d99a25 52  Show the AIHelp conversation screen.
05f1b6 53  */
d99a25 54 + (BOOL)showWithApiConfig:(AIHelpApiConfig *)apiConfig;
05f1b6 55
d99a25 56 + (void)showSingleFAQ:(NSString *)faqId showConversationMoment:(AIHelpFAQShowConversationMoment)showConversationMoment;
05f1b6 57
L 58 /**
59  * Update a user's profile via UserConfig.
60  *
61  * Please check ECServiceUserConfigfor more detail information.
62  * @param config configs which contains all information about a user.
63  */
64 + (void)updateUserInfo:(AIHelpUserConfig *)config;
65
66 /**
67  * Clear the values set to a user, reset the userId to deviceId, userName to 'anonymous'.
68  */
69 + (void)resetUserInfo;
70
71 /**
72  * Change the SDK language. By default, the device's prefered language is used.
73  *
74  * The call will fail in the following cases :
75  * 1. If a AIHelp session is already active at the time of invocation
76  * 2. Language code is incorrect
77  * 3. Corresponding localization file is not found
78  * @param sdkLanguage the string representing the language code. For example, use 'fr' for French.
79  */
80 + (void)updateSDKLanguage:(NSString*)sdkLanguage;
81
82 /**
83  * Set log path for uploading.
84  *
85  * In order to serve your customers well, you can upload customer-related-logs when tickets are created or
86  * specific forms are submitted.
87  * @param path the absolute path of log, which will be uploaded when needed
88  */
89 + (void)setUploadLogPath:(NSString*)path;
90
91 /**
92  * set the pushToken and platform to enable push notifications.
93  *
94  * To enable push notifications in the Helpshift iOS SDK, set the Push Notifications’ deviceToken using this method inside your application:didRegisterForRemoteNotificationsWithDeviceToken application delegate.
95  * NOTE: You must get the specific push sdk in your App BEFORE this invocation.
96  *
97  * @param pushToken    the pushToken received from the push notification servers.
98  * @param pushPlatform the specific push platform, please check ElvaTokenPlatform  for more information.
99  */
100 + (void)setPushToken:(NSString*)pushToken pushPlatform:(AIHelpTokenPlatform)pushPlatform;
101
102 /**
103  * Get current AIHelp SDK version
104  * @return AIHelp SDK version
105  */
106 + (NSString*)getSDKVersion;
107
108 /**
109  * Whether AIHelp session is visible to users
110  * @return whether sdk is active
111  */
112 + (BOOL)isAIHelpShowing;
113
114 /**
115  * Whether to print logs.
116  *
117  * It only works in Debug mode
118  * @param enable YES/NO
119  */
120 + (void)enableLogging:(BOOL)enable;
121
122 /**
123  * The preferred screen orientation sdk would like to run in.
124  *
125  * NOTE: The SDK direction must be included in the program direction Settings, otherwise the setting will fail
126  * @param interfaceOrientationMask please refer to the UIInterfaceOrientationMask API
127  */
128 + (void)setSDKInterfaceOrientationMask:(UIInterfaceOrientationMask)interfaceOrientationMask;
129
130 /**
131  * Set up host address for network check with result callback.
132  *
133  * With this api, you can get the network check result passing back to you.
134  * @param address host address for network checking, without schemes such 'https://' or 'http://'.
135  *                    For example, you can pass in 'www.google.com' or just 'google.com', no schemes are needed.
136  * @param callback    network check result callback, you can get the check result via this callback
137  */
138 + (void)setNetworkCheckHostAddress:(NSString*)address callback:(AISupportPingCallBack)callback;
139
140 /**
141  * Register callback for the process of AIHelp's initialization.
142  *
143  * After you register this callback, SDK will let you know if the init work is done.
144  * You can call this method either before or after the init method.
145  * @param callback callback for AIHelp initialization
146  */
147 + (void)setOnInitializedCallback:(AISupportInitCallBack)callback;
148
149 /**
150  * start in-app unread message count polling
151  *
152  * This is a schedule work, get unread message count every five minutes.
153  * If you want to stop a started polling, just pass null to the listener parameters.
154  * @param callback callback for unread message polling
155  */
156 + (void)startUnreadMessageCountPolling:(AISupportMessageCallBack)callback;
157
158 /**
159  * Set the SDK display mode
160  *
161  * Default following system
162  * @param mode
163             0: follow the system
164             1: light mode
165             2: dark mode
166  */
167 + (void)setSDKAppearanceMode:(int)mode;
168
169 /**
170  * AIHelp provide additional support for some country or regions.
171  *
172  * @param countryOrRegion ISO country code, please check https://www.iso.org/obp/ui/#search to learn more.
173  */
174 + (void)additionalSupportFor:(AIHelpPublishCountryOrRegion)countryOrRegion;
175
176 + (void)showUrl:(NSString *)url;
177
178 + (void)setKeyWindow:(UIWindow *)keyWin;
179
180 + (void)setOnAIHelpSessionOpenCallback:(AISupportOpenSDKCallBack)callback;
181
182 + (void)setOnAIHelpSessionCloseCallback:(AISupportCloseSDKCallBack)callback;
183
184 + (void)setOnSpecificFormSubmittedCallback:(AISupportIsSpecificFormCallBack)callBack;
185
186 + (void)setOnOperationUnreadChangedCallback:(AISupportOperationUnReadCallBack)callback;
187
d99a25 188 + (void)setOnSpecificUrlClickedCallback:(AISupportSpecificUrlClickedCallBack)callback;
L 189
05f1b6 190 + (void)setSDKEdgeInsetsWithTop:(float)top bottom:(float)bottom enable:(BOOL)enable;
L 191 + (void)setSDKEdgeColorWithRed:(float)red green:(float)green blue:(float)blue alpha:(float)alpha;
192
d99a25 193 + (void)close;
05f1b6 194
L 195 @end