Feedback Kit for IOS is a wrapper SDK for MapmyIndia's feedback API. It allows developers to integrate feedback module in their application. Using feedback module user can submit location related feedback to MapmyIndia's server.
Note: Sample for UI view controllers with source code is also provided by MapmyIndia which user can directly use to show feedback screen. Information about how to use UI sample is also provided in this documentation.
If you don’t want to implement own logic and use sample from MapmyIndia Jump to Sample UI Kit section.
Version | Dated | Description |
---|---|---|
1.1.0 |
29 Mar, 2022 | Added support for xcode 13+ Rename MapmyIndiaFeedBackKit to MapmyIndiaFeedBackKitManager |
1.0.7 |
24 Dec, 2021 | Added support for xcode 13.2.1. |
1.0.6 |
28 Sep, 2021 | Fixed a crash while featching report from api. |
1.0.5 |
28 Sep, 2021 | Added support for xcode 13 |
1.0.4 |
12 jul, 2021 | Added support for xcode 12.5 |
1.0.3 |
25 Feb, 2021 | Improvments |
1.0.2 |
10 Dec, 2020 | Xcode 12.2 compatibility. |
1.0.1 |
14 Oct, 2020 | Xcode 12 compatibility. |
1.0.0 |
05 June, 2020 | Initial release through CocoaPods. |
Steps to add feedback module into application project:
-
Create a new project in Xcode.
-
Drag and drop the MapmyIndiaFeedbackKit.framework to your project. It must be added in embedded binaries.
Steps to submit feedback:
-
An authoraization key i.e moduleId (provided by MapmyIndia) against which feedback will be submitted wiil be required to use this SDK .
-
List of categories need to be fetched first under which feedback will be submitted. For more informatatio see here.
Notes:
-
Fetched report categories can be saved for offline use or to prevent fetching report categories multiple times.
-
It will require to separate out them on basis of parentId i.e Separate as Parent and Child Categories, where if parent Id is null means they are parent categories otherwise child of some parent category. Note: ParentId of a child category is reportId of parent category.
-
-
On basis of parent and child categories, different User Interfaces or scenarios can be designed as per requirements.
-
User must pass have location oordinate for which feedback will be submitted.
-
After selecting of parent and child category user must take some input as a text for feedback.
-
After Collection all values i.e Module Id, Location Coordinates, Parent Category, Child Category and Feedback Text, feedback can be submitted using functions available in this SDK. See here.
Categories for reporting can be fetched using getReportCategories method of MapmyIndiaFeedBackKitManager class by using shared instance.
In response you will receive an error or an array of MapmyIndiaReportCategories. Yo will find below useful properties in reportCategories object which is an array of ParentCategories
:
-
ParentCategories
-
ChildCategories
-
SubChildCategories
MapmyIndiaFeedBackKitManager.shared.getReportCategories { (reportCategories, error) in
if let error = error {
print(error.localizedDescription)
self.dismiss(animated: true, completion: nil)
} else {
let categories = reportCategories ?? [ParentCategories]()
if categories.count > 0 {
self.allReportCategories = categories
print(self.allReportCategories.first?.id)
self.currentStep = 1
} else {
print("No report categories found")
self.dismiss(animated: true, completion: nil)
}
}
To submit feedback on MapmyIndia server you can use saveUserData
function of MapmyIndiaSaveUserDataAPIManager
class by using shared instance.
saveUserData
function will accept an object of MapmyIndiaSaveUserDataOptions
class.
To create instance of MapmyIndiaSaveUserDataOptions user provide following parameters.
- location(String) : It can be either eLoc (The 6-digit alphanumeric code for any location) or coordinate (latitude, longitude) in
string
format. - parentCategory(Integer) : Parent category of the report.
- childCategory (Integer) : Child category of the report.
- placeName(string) : Name of the place where the event is taking place. It should be derived on the basis of eloc and coordinates.
- desription(String) : A description about your event. Min length 10 characters and Max length 250 characters.
- subChildCategory(Integer)(Internal) : Sub Child category of the report.
- flag(Integer) : If navroute is active then 1 else 0.
- speed(Integer) : User's speed in kilometers.
- alt(Integer) : Altitude of the user’s location, in meters.
- quality(Integer) : Quality of user's location.
- bearing(Integer) : Bearing of the user’s location, in degrees.
- accuracy(Integer) : Accuracy of user's location.
- utc(Long) : Date time in unix timestamp format.
- expiry(Long) : Date time in unix timestamp format to set expiry for the report.
- zeroId(String) : to be used only incase of NAVIMAPS .
- pushEvent(Boolean)(internal) : to be used only when traffic events are to be pushed back to the traffic event editor. Allowed values: a) true b) false
- appVersion(String) : Version of the app
- osVersionoptional(String) : Version of the os
- deviceName(String) : Name of the device
let saveOptions = MapmyIndiaSaveUserDataOptions(location: "MMI000", parentCategory: parentCategory.id ?? 0, childCategory: childCategory.id ?? 0, description: "This is descriptions", subChildCategory: self.selectedSubChildCategories?.id, accuracy: 3)
MapmyIndiaSaveUserDataAPIManager.shared.saveUserData(saveOptions, { (isSucess, error) in
if let error = error {
print(error.localizedDescription)
} else if isSucess {
print("feedback submited successfully")
self.dismiss(animated: true, completion: nil)
} else {
print("No results")
}
})
A UI control MapmyIndiaFeedbackUIKit
is available with sourece code to use SDK MapmyIndiaFeedbackKit which is including in sample application project. Sample application project can be download from here.
MapmyIndiaFeedbackUIKitManager
is the class which will help to use this UI Control.Access shared instance of that class and call getViewController
method to get instance of ViewController and present or push according to requirement.
CLLocation *location = [[CLLocation alloc] initWithLatitude:_mapView.centerCoordinate.latitude longitude:_mapView.centerCoordinate.longitude];
UINavigationController *navVC = [[MapmyIndiaFeedbackUIKitManager sharedManager] getViewControllerWithLocation:location moduleId:ModuleId];
[self presentViewController:navVC animated:YES completion:nil];
let navVC = MapmyIndiaFeedbackUIKitManager.shared.getViewController(location: CLLocation(latitude: mapView.centerCoordinate.latitude, longitude: mapView.centerCoordinate.longitude), moduleId: ModuleId)
self.present(navVC, animated: true, completion: nil)
MapmyIndiaFeedbackUIKit
implicitly use functionalities of MapmyIndiaFeedBackKitManager module and provides a beautiful user expereience to submit feedback.
For any queries and support, please contact:
Email us at apisupport@mapmyindia.com
Stack Overflow Ask a question under the mapmyindia-api
Support Need support? contact us!
Blog Read about the latest updates & customer stories
© Copyright 2020. CE Info Systems Pvt. Ltd. All Rights Reserved. | Terms & Conditions