Skip to content

5分钟集成自定义UI

jackning edited this page Aug 23, 2020 · 16 revisions

5分钟集成自定义UI

准备工作

  • 萝卜丝官网注册管理员账号,并登录管理后台。
  • 到 客服->渠道 添加网站/App
  • 到 客服->账号 有一列 ‘唯一ID(uid)’ 会在指定客服接口中使用
  • 到 客服->技能组 有一列 ‘唯一ID(wId)’ 会在技能组会话中用到
  • 获取管理员uid, 登录后台->客服->账号->管理员账号(唯一ID(uid))列
  • 获取appkey,登录后台->客服->渠道->添加应用->appkey
  • 获取subDomain,也即企业号:登录后台->客服->账号->企业号

开始集成

第一步:拷贝 bdui 库到自己项目目录中,例如:

.
├─ bdui
│  └─ *
├─ myui
├─ myuiTests
├─ Pods
├─ myui.xcodeproj
├─ myui.xcworkspace
├─ Podfile
└─ Podfile.lock

第二步:添加pod库

# 如果pod库原先没有添加workspace的话,需要添加,如:
platform :ios, '9.0'
# 注意: 'myui' 需要修改为自己项目真实的名称
workspace 'myui'

在需要引入在线客服的项目pod中添加

# 第三方依赖
pod 'FMDB'
pod 'WCDB'
pod 'MMKV'
pod 'MQTTClient'
pod 'AFNetworking'
pod 'QMUIKit'
pod 'M80AttributedLabel'
pod 'HCSStarRatingView'
pod 'CocoaLumberjack'

# 集成萝卜丝核心协议库core
pod 'bytedesk-core', '2.0.4'

添加bdui相关pod

target 'bytedesk-ui' do
  # Comment this line if you're not using Swift and don't want to use dynamic frameworks
  use_frameworks!

  project 'bdui/bdui.xcodeproj'

  # Pods for bdui
  pod 'FMDB'
  pod 'WCDB'
  pod 'MMKV'
  pod 'MQTTClient'
  pod 'AFNetworking'
  pod 'QMUIKit'
  pod 'M80AttributedLabel'
  pod 'HCSStarRatingView'
  pod 'CocoaLumberjack'

  # 集成核心协议库core
  pod 'bytedesk-core', '2.0.4'

  target 'bduiTests' do
  end

end

支持bitcode

#bitcode enable
post_install do |installer|
  installer.pods_project.targets.each do |target|
    target.build_configurations.each do |config|
      config.build_settings['ENABLE_BITCODE'] = 'YES'

      if config.name == 'Release'
        config.build_settings['BITCODE_GENERATION_MODE'] = 'bitcode'
        else
        config.build_settings['BITCODE_GENERATION_MODE'] = 'marker'
      end

      cflags = config.build_settings['OTHER_CFLAGS'] || ['$(inherited)']

      if config.name == 'Release'
        cflags << '-fembed-bitcode'
        else
        cflags << '-fembed-bitcode-marker'
      end

      config.build_settings['OTHER_CFLAGS'] = cflags
    end
  end
end

添加完毕之后,关闭Xcode,执行 pod install

第三步:项目添加bytedesk-ui.framework

选择binary

选择framework

第四步:在AppDelegate.m文件中添加头文件

#import <bytedesk-core/bdcore.h>

第五步:在AppDelegate.m建立萝卜丝长连接

// 1. 在 - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions中添加
// 2. 在 - (void)applicationWillEnterForeground:(UIApplication *)application中添加
// anonymouseLogin函数代码请查看AppDelegate.m文件
[self anonymouseLogin];

第六步:在ViewController.m中添加头文件

#import <bytedesk-ui/bdui.h>

第七步:在ViewController.m打开在线客服会话窗口

[BDUIApis pushWorkGroupChat:self.navigationController withWorkGroupWid:DEFAULT_TEST_WID withTitle:kDefaultTitle];

第八步:在Info.plist添加 相册 + 拍照 权限,可参考demo

第九步:如果要在真机运行,需要修改项目Scheme为Release

选择binary

集成完毕

Clone this wiki locally