LeanCloud Feedback 模块是 LeanCloud 开源的一个用户反馈组件,反馈内容存储在 LeanCloud 云端,开发者可以通过 LeanCloud 提供的统计分析客户端 LeanAnalytics 来实时查看和回复用户反馈。
用户反馈界面如下:
你可以通过提 issue 或者发 pull request 的方式,来贡献代码。开源世界因你我参与而更加美好。
为了便于测试,我们将 feedback 模块的代码和 demo 都放在了一起,整个 repo 结构如下:
.
├── AVOSCloud.framework <---- 这是依赖的 AVOSCloud.framework,请保持最新
├── LeanCloudFeedback <---- feedback 主要代码
├── LeanCloudFeedbackTests
├── LeanCloudFeedbackDemo <---- feedback demo 主要代码
│ ├── LeanCloudFeedbackDemo
│ ├── LeanCloudFeedbackDemo.xcodeproj
│ └── LeanCloudFeedbackDemoTests
└── README.md
FeedbackReply 代表了反馈系统中间,用户或者开发者的每一次回复。不同的类型可以通过 ReplyType 属性来指定。FeedbackReply 内部主要记录有如下信息:
- content,反馈的文本内容
- replyType,类型标识,表明是用户提交的,还是开发者回复的
- attachment,反馈对应的附件信息
代表了用户与开发者的整个交流过程,与用户一一对应。一个用户只有一个 FeedbackThread,一个 FeedbackThread 内含有多个 FeedbackReply。FeedbackThread 内部主要记录有如下信息:
- contact,用户联系方式
- content,用户第一次反馈的文本
- status,当前状态:open 还是 close
- remarks,预留字段,开发者可以用来标记的一些其他信息
在 Xcode 中选择 UniversalFramework Target,设备选为 iOS Device,在 Product 菜单中选择 Archive 即可开始编译。编译完成之后会在当前 build 目录下
.
├── LeanCloudFeedback.build
│ ├── Release-iphoneos
│ │ └── LeanCloudFeedback.build
│ └── Release-iphonesimulator
│ └── LeanCloudFeedback.build
└── Release-iphoneuniversal
└── LeanCloudFeedback.framework <------ 这里就是编译出来的 framework
在项目根目录下执行如下语句,即可开始编译
xcodebuild -target UniversalFramework -config Release
编译之后的结果文件目录和上面示例一致。
在 LeanCloudFeedbackDemo 目录下,直接用 xcode 打开 LeanCloudFeedbackDemo.xcodeproj 工程。LeanChatFeedback Framework 是一个动态库,需要在 Demo 中的 Embeded Libraries 引入进来。设置如下,之后便可在真机和模拟器运行。
为了调试方便,我们推荐大家直接把本项目的源代码加入自己工程来使用 feedback 组件。 要进入默认的反馈界面,开发者可以在当前 UIViewController 中加入如下代码即可(记得将标题和联系方式改一下):
LCUserFeedbackAgent *agent = [LCUserFeedbackAgent sharedInstance];
[agent showConversations:self title:@"提点意见" contact:@"热心用户"];
当然,开发者也可以自己实现反馈界面 这时候需要使用 LCUserFeedbackAgent 提供的另外两个 API 来完成用户反馈功能:
/**
* 从服务端同步反馈回复
* @param title 反馈标题, 当用户没有创建过用户反馈时,需要传入这个参数用于创建用户反馈。
* @param contact 联系方式,邮箱或qq。
* @param block 结果回调
* @discussion 可以在 block 中处理反馈数据 (AVUserFeedbackThread 数组),然后将其传入自定义用户反馈界面。
*/
- (void)syncFeedbackThreadsWithBlock:(NSString *)title contact:(NSString *)contact block:(AVArrayResultBlock)block;
/**
* 发送用户反馈
* @param content 同上,用户反馈内容。
* @param block 结果回调
*/
- (void)postFeedbackThread:(NSString *)content block:(AVIdResultBlock)block;
可以扩展 LCUserFeedbackReply 的属性值,从而保存更多的内容。譬如允许用户截图来反馈问题的话,可以在应用中先把图片存储到 LeanCloud 云端(使用 AVFile),然后把 AVFile 的 url 保存到 LCUserFeedbackReply(attachment 属性)。