Skip to content

Latest commit

 

History

History
261 lines (205 loc) · 8.53 KB

README.md

File metadata and controls

261 lines (205 loc) · 8.53 KB

blip-chat-android

Passo 1

Criando um projeto utilizando o SDK Blip Chat Android

Crie um projeto utilizando como SDK mínimo API 23 do Android. Conforme Imagem 1 abaixo. Caso já possua um projeto pule o passo 1.

alt text 1 - Criando projeto

Passo 2

Faça Download do arquivo zipado do projeto conforme Imagem 2 a seguir. Utilize o link abaixo para download: https://github.com/takenet/blip-chat-sdk-android

alt text 2 - Baixando Arquivos

Passo 3

Descompacte o arquivo blip-chat-android-main.zip e copie as pastas descompactadas para dentro do seu projeto. A pasta flutter_blip_chat_sdk deve ficar na pasta root do seu projeto e a pasta android_blip_chat_sdk na pasta app do seu projeto. Conforme Imagem 3 abaixo:

alt text
3 - Estrutura de Pastas do Projeto

Passo 4

Volte para seu projeto no Android Studio no arquivo settings.gradle e adicione as seguintes linhas na propriedade repositories do seu arquivo, conforme abaixo:

    repositories {
        google()
        mavenCentral()
        maven { url 'flutter_blip_chat_sdk/repo' }
        maven { url 'https://storage.googleapis.com/download.flutter.io' }
    }

Altere o repositoriesMode para PREFER_SETTINGS conforme abaixo:

repositoriesMode.set(RepositoriesMode.PREFER_SETTINGS)

Ainda no arquivo settings.gradle, adicione uma última linha a referência para o projeto:

include ':app:android_blip_chat_sdk'

Arquivo gradle completo do projeto de teste:

pluginManagement {
    repositories {
        gradlePluginPortal()
        google()
        mavenCentral()
    }
}
dependencyResolutionManagement {
    repositoriesMode.set(RepositoriesMode.PREFER_SETTINGS)
    repositories {
        google()
        mavenCentral()
        maven { url 'flutter_blip_chat_sdk/repo' }
        maven { url 'https://storage.googleapis.com/download.flutter.io' }
    }
}
rootProject.name = "TesteSDK"
include ':app'
include ':app:android_blip_chat_sdk'

Passo 5

No arquivo build.gradle do seu app adicione o trecho abaixo acima da propriedade dependences:

String storageUrl = System.env.FLUTTER_STORAGE_BASE_URL ?: "https://storage.googleapis.com"
repositories {
    maven { url "$projectDir/flutter_blip_chat_sdk/repo" }
    maven { url "$storageUrl/download.flutter.io" }
}

Dentro da propriedade buildTypes adicione o seguinte trecho:

        profile {
            initWith debug
        }

Dentro da propriedade dependences adicione a referência do SDK conforme abaixo:

    implementation project(path: ':app:android_blip_chat_sdk')

    debugImplementation  'blip.sdk.chat:flutter_debug:1.0'
    profileImplementation 'blip.sdk.chat:flutter_profile:1.0'
    releaseImplementation 'blip.sdk.chat:flutter_release:1.0'

Após essas configurações clique em Sync Now

Abaixo arquivo build.gradle completo após configurações:

plugins {
    id 'com.android.application'
    id 'org.jetbrains.kotlin.android'
}

android {
    namespace 'net.take.testesdk'
    compileSdk 32

    defaultConfig {
        applicationId "net.take.testesdk"
        minSdk 23
        targetSdk 32
        versionCode 1
        versionName "1.0"

        testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
    }

    buildTypes {
        profile {
            initWith debug
        }
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
        }
    }
    compileOptions {
        sourceCompatibility JavaVersion.VERSION_1_8
        targetCompatibility JavaVersion.VERSION_1_8
    }
    kotlinOptions {
        jvmTarget = '1.8'
    }
}

String storageUrl = System.env.FLUTTER_STORAGE_BASE_URL ?: "https://storage.googleapis.com"
repositories {
    maven { url "$projectDir/flutter_blip_chat_sdk/repo" }
    maven { url "$storageUrl/download.flutter.io" }
}

dependencies {

    implementation project(path: ':app:android_blip_chat_sdk')

    debugImplementation  'blip.sdk.chat:flutter_debug:1.0'
    profileImplementation 'blip.sdk.chat:flutter_profile:1.0'
    releaseImplementation 'blip.sdk.chat:flutter_release:1.0'

    implementation 'androidx.core:core-ktx:1.7.0'
    implementation 'androidx.appcompat:appcompat:1.4.1'
    implementation 'com.google.android.material:material:1.5.0'
    implementation 'androidx.constraintlayout:constraintlayout:2.1.3'
    testImplementation 'junit:junit:4.13.2'
    androidTestImplementation 'androidx.test.ext:junit:1.1.3'
    androidTestImplementation 'androidx.test.espresso:espresso-core:3.4.0'
}

Passo 6

Adicione a referência da BlipChatActivity no seu arquivo Manifest.xml conforme trecho abaixo:

        <activity
            android:name="blip.chat.sdk.android.BlipChatActivity"
            android:configChanges="orientation|keyboardHidden|keyboard|screenSize|locale|layoutDirection|fontScale|screenLayout|density|uiMode"
            android:hardwareAccelerated="true"
            android:theme="@style/Theme.AppCompat.DayNight.NoActionBar"
            android:windowSoftInputMode="adjustResize" />

Passo 7

Adicione a seguinte configuração da chamada do SDK na sua Activity conforme trecho kotlin abaixo:

        var button = findViewById<Button>(R.id.button)

        var model = BlipChatModel()
        model.key = "{YOUR_OWNER_KEY}"
        model.type = TYPE.PLAIN
        model.useMtls = true
        var account = BlipChatAccountModel()
        account.fullName = "{LOGGED_USER_FULL_NAME}"
        account.photoUri = "{LOGGED_USER_AVATAR_URI}"
        account.pushToken = "{DEVICE_PUSH_NOTIFICATION_TOKEN}"
        model.account = account
        var style = BlipChatStyleModel()
        style.primary = "c9c8cc"
        style.sentBubble = "a442f5"
        style.receivedBubble = "706f73"
        style.background = "7b42f5"
        style.showOwnerAvatar = true
        style.overrideOwnerColors = true
        style.showUserAvatar = true
        model.style = style

        var blip = BlipChat(this, model)

        button.setOnClickListener {
            startActivity(
                BlipChatActivity.withEngineDefault().build(blip, this)
            )
        }

Properties

BlipChatModel

Properties Required Description Type
key YES String key that identifies the owner String
type YES Indicates the authentication type, used to sign in the user AuthenticationTypeEnum
token NO* User token used to identity the application logged user. Used with external type only String
issuer NO* Issuer used to authenticate session. Used with external type only String
hostName NO Custom hostName used to connect to Blip Server String
useMtls NO Determines if the connection will use mTLS for avoid MITM attacks. Default: false bool
account NO Logged user account data BlipChatAccountModel
style NO Custom chat style BlipChatStyleModel
  • Required for external authentication type.

BlipChat Account

Property Required Description Type
pushToken NO Logged user's device push notification Token String
fullName NO Logged user full name to be stored on Blip Account String
email NO Logged user email to be stored on Blip Account String
photoUri NO Logged user avatar uri to be stored on Blip Account String
encryptMessageContent NO Determines if the message content will be encrypted bool

BlipChat Style

Property Required Description Type
primary NO Primary chat HEX color String
sentBubble NO Sent message bubble HEX color String
receivedBubble NO Received message bubble HEX color String
background NO Chat background HEX color String
overrideOwnerColors NO Determines if the clors sent in this object, will override the owner configuration colors. Default: false bool
showOwnerAvatar NO Determines if the owner avatar will be shown. Default: true bool
showUserAvatar NO Determines if the user avatar will be shown. Default: true bool

Authentication Type

Property Description
plain Plain text authentication method
external External authentication method. For this authentication type, is necessary to send token and issuer properties