Flutter 3.X.X migration guide
변경사항
기존에 2.X.X 버전 에 있던 있던 event 전송 API 가 삭제 되고 아래의 API 로 대체 되었습니다.
static void trackEvent(String category, [ AirbridgeEventOption? option ]) {
event.trackEvent(category, option);
}
option 정보는 null 일 수 있고 해당 정보에 action, label, value, customAttributes, semanticAttributes 사용이 가능합니다.
이벤트 설정 에서 자세한 내용을 확인하세요.
2.X.X 버전을 사용하신다면 아래의 Flutter SDK 사용 가이드를 확인 바랍니다.
이벤트 전송 관련 된 API 가 변경 되어 이벤트 전송에 따른 코드를 아래와 같이 변경이 필요합니다.
2.X.X 에서 아래의 method 를 사용 중이라면 trackEvent(String category, [ AirbridgeEventOption? option ])
로 전환 해야 합니다.
사용자 이벤트 전송 바로가기
회원가입
- Airbridge.event.send(SignUpEvent(user: user));
+ Airbridge.state.setUser(User(
+ ID: ...,
+ email: ...,
+ phone: ...,
+ alias: {},
+ attributes: {},
+ ));
+ Airbridge.trackEvent(AirbridgeCategory.SIGN_UP, option);
Airbridge.event.send(SignUpEvent(user: user))
를 사용하고 있다면 변경이 필요합니다.
매개변수로 전달 하던 user 정보를 Airbridge.state.setUser()
에 채워주고 Airbridge.trackEvent(AirbridgeCategory.SIGN_UP, option)
으로 SIGN_UP
이벤트를 전달합니다.
로그인
- Airbridge.event.send(SignInEvent(user: user));
+ Airbridge.state.setUser(User(
+ ID: ...,
+ email: ...,
+ phone: ...,
+ alias: {},
+ attributes: {},
+ ));
+ Airbridge.trackEvent(AirbridgeCategory.SIGN_IN, option);
Airbridge.event.send(SignInEvent(user: user))
를 사용하고 있다면 변경이 필요합니다.
매개변수로 전달 하던 user 정보를 Airbridge.state.setUser()
에 채워주고 Airbridge.trackEvent(AirbridgeCategory.SIGN_IN, option)
으로 SIGN_IN
이벤트를 전달합니다.
로그아웃
- Airbridge.event.send(SignOutEvent());
+ Airbridge.trackEvent(AirbridgeCategory.SIGN_OUT, option);
+ Airbridge.state.setUser(User());
Airbridge.event.send(SignOutEvent())
를 사용하고 있다면 변경이 필요합니다.
Airbridge.trackEvent(AirbridgeCategory.SIGN_OUT, option)
으로 SIGN_OUT
이벤트를 전달하고,
Airbridge.state.setUser(())
에 빈객체를 전달하여 현재 유저정보를 비워주세요.
이커머스 이벤트 전송 바로가기
홈 화면 조회
- Airbridge.event.send(ViewHomeEvent(
- option: ...
- ));
+ Airbridge.trackEvent(AirbridgeCategory.HOME_VIEW, option);
Airbridge.event.send(ViewHomeEvent())
를 사용하고 있다면 변경이 필요합니다.
Airbridge.trackEvent(AirbridgeCategory.HOME_VIEW, option)
으로 HOME_VIEW
이벤트를 전달합니다.
상품 상세 조회
- Airbridge.event.send(ViewProductDetailEvent(
- option: ...,
- products: ...,
- ));
+ Airbridge.event.trackEvent(
+ AirbridgeCategory.PRODUCT_DETAILS_VIEW,
+ AirbridgeEventOption(
+ semanticAttributes: {
+ AirbridgeAttributes.PRODUCTS: [{
+ AirbridgeProduct.PRODUCT_ID: '1',
+ AirbridgeProduct.NAME: 'product A',
+ AirbridgeProduct.PRICE: 1000000,
+ AirbridgeProduct.CURRENCY: 'KRW',
+ AirbridgeProduct.POSITION: 1,
+ AirbridgeProduct.QUANTITY: 1,
+ },
+ ]
+ }
+ ));
Airbridge.event.send(ViewProductDetailEvent())
를 사용하고 있다면 변경이 필요합니다.
Airbridge.trackEvent(AirbridgeCategory.PRODUCT_DETAILS_VIEW, option)
으로 PRODUCT_DETAILS_VIEW
이벤트를 전달합니다.
기존 api 의 매개변수에 값을 option 에 객체에 담아서 전달 한다.
product
=>semanticAttributes.[AirbridgeAttributes.PRODUCTS]
상품 리스트 조회
- Airbridge.event.send(ViewProductListEvent(
- option: ...,
- listID: ...,
- products: ...,
- ));
+ Airbridge.event.trackEvent(
+ AirbridgeCategory.PRODUCT_DETAILS_VIEW,
+ AirbridgeEventOption(
+ semanticAttributes: {
+. AirbridgeAttributes.PRODUCT_LIST_ID: 'ID-1234567890',
+ AirbridgeAttributes.PRODUCTS: [{
+ AirbridgeProduct.PRODUCT_ID: '1',
+ AirbridgeProduct.NAME: 'product A',
+ AirbridgeProduct.PRICE: 1000000,
+ AirbridgeProduct.CURRENCY: 'KRW',
+ AirbridgeProduct.POSITION: 1,
+ AirbridgeProduct.QUANTITY: 1,
+ }, {
+ AirbridgeProduct.PRODUCT_ID: '2',
+ AirbridgeProduct.NAME: 'product B',
+ AirbridgeProduct.PRICE: 1000000,
+ AirbridgeProduct.CURRENCY: 'KRW',
+ AirbridgeProduct.POSITION: 2,
+ AirbridgeProduct.QUANTITY: 1,
+ },
+ ]
+ }
+ ));
Airbridge.event.send(ViewProductListEvent())
를 사용하고 있다면 변경이 필요합니다.
Airbridge.trackEvent(AirbridgeCategory.PRODUCT_LIST_VIEW, option)
으로 PRODUCT_LIST_VIEW
이벤트를 전달합니다.
기존 api 의 매개변수에 값을 option 에 객체에 담아서 전달 한다.
listID
=>semanticAttributes.[AirbridgeAttributes.PRODUCT_LIST_ID]
product
=>semanticAttributes.[AirbridgeAttributes.PRODUCTS]
검색결과 조회
- Airbridge.event.send(ViewSearchResultEvent(
- option: ...,
- query: ...,
- products: ...,
- ));
+ Airbridge.event.trackEvent(
+ AirbridgeCategory.PRODUCT_DETAILS_VIEW,
+ AirbridgeEventOption(
+ semanticAttributes: {
+ AirbridgeAttributes.QUERY: 'query-viewSearchResult',
+ AirbridgeAttributes.PRODUCTS: [{
+ AirbridgeProduct.PRODUCT_ID: '1',
+ AirbridgeProduct.NAME: 'product A',
+ AirbridgeProduct.PRICE: 1000000,
+ AirbridgeProduct.CURRENCY: 'KRW',
+ AirbridgeProduct.POSITION: 1,
+ AirbridgeProduct.QUANTITY: 1,
+ }, {
+ AirbridgeProduct.PRODUCT_ID: '2',
+ AirbridgeProduct.NAME: 'product B',
+ AirbridgeProduct.PRICE: 1000000,
+ AirbridgeProduct.CURRENCY: 'KRW',
+ AirbridgeProduct.POSITION: 2,
+ AirbridgeProduct.QUANTITY: 1,
+ },
+ ]
+ }
+ ));
Airbridge.event.send(ViewSearchResultEvent())
를 사용하고 있다면 변경이 필요합니다.
Airbridge.trackEvent(AirbridgeCategory.SEARCH_RESULT_VIEW, option)
으로 SEARCH_RESULT_VIEW
이벤트를 전달합니다.
기존 api 의 매개변수에 값을 option 에 객체에 담아서 전달 한다.
query
=>semanticAttributes.[AirbridgeAttributes.QUERY]
product
=>semanticAttributes.[AirbridgeAttributes.PRODUCTS]
장바구니 담기
- Airbridge.event.send(AddToCartEvent(
- option: ...,
- cartID: ...,
- products: ...,
- currency: ...,
- totalValue: 30000,
- ));
+ Airbridge.event.trackEvent(
+ AirbridgeCategory.ADD_TO_CART,
+ AirbridgeEventOption(
+ semanticAttributes: {
+ AirbridgeAttributes.CART_ID: 'ID-1234567890',
+ AirbridgeAttributes.CURRENCY: 'KRW',
+ AirbridgeAttributes.TOTAL_VALUE: 2000000,
+ AirbridgeAttributes.PRODUCTS: [{
+ AirbridgeProduct.PRODUCT_ID: '1',
+ AirbridgeProduct.NAME: 'product A',
+ AirbridgeProduct.PRICE: 1000000,
+ AirbridgeProduct.CURRENCY: 'KRW',
+ AirbridgeProduct.POSITION: 1,
+ AirbridgeProduct.QUANTITY: 1,
+ }, {
+ AirbridgeProduct.PRODUCT_ID: '2',
+ AirbridgeProduct.NAME: 'product B',
+ AirbridgeProduct.PRICE: 1000000,
+ AirbridgeProduct.CURRENCY: 'KRW',
+ AirbridgeProduct.POSITION: 2,
+ AirbridgeProduct.QUANTITY: 1,
+ },
+ ]
+ }
+ ));
Airbridge.event.send(AddToCartEvent())
를 사용하고 있다면 변경이 필요합니다.
Airbridge.trackEvent(AirbridgeCategory.ADD_TO_CART, option)
으로 ADD_TO_CART
이벤트를 전달합니다.
기존 api 의 매개변수에 값을 option 에 객체에 담아서 전달 한다.
cartID
=>semanticAttributes.[AirbridgeAttributes.CART_ID]
product
=>semanticAttributes.[AirbridgeAttributes.PRODUCTS]
currency
=>semanticAttributes.[AirbridgeAttributes.CURRENCY]
totalValue
=>semanticAttributes.[AirbridgeAttributes.TOTAL_VALUE]
결제
- Airbridge.event.send(PurchaseEvent(
- option: ...,
- cartID: ...,
- products: ...,
- currency: ...,
- totalValue: 30000,
- ));
+ Airbridge.event.trackEvent(
+ AirbridgeCategory.ORDER_COMPLETED,
+ AirbridgeEventOption(
+ semanticAttributes: {
+ AirbridgeAttributes.TRANSACTION_ID: 'transactionID-purchase',
+ AirbridgeAttributes.IN_APP_PURCHASED: true,
+ AirbridgeAttributes.CURRENCY: 'KRW',
+ AirbridgeAttributes.TOTAL_VALUE: 50000,
+ AirbridgeAttributes.PRODUCTS: [{
+ AirbridgeProduct.PRODUCT_ID: '1',
+ AirbridgeProduct.NAME: 'product A',
+ AirbridgeProduct.PRICE: 1000000,
+ AirbridgeProduct.CURRENCY: 'KRW',
+ AirbridgeProduct.POSITION: 1,
+ AirbridgeProduct.QUANTITY: 1,
+ }, {
+ AirbridgeProduct.PRODUCT_ID: '2',
+ AirbridgeProduct.NAME: 'product B',
+ AirbridgeProduct.PRICE: 1000000,
+ AirbridgeProduct.CURRENCY: 'KRW',
+ AirbridgeProduct.POSITION: 2,
+ AirbridgeProduct.QUANTITY: 1,
+ },
+ ]
+ }
+ ));
Airbridge.event.send(PurchaseEvent())
를 사용하고 있다면 변경이 필요합니다.
Airbridge.trackEvent(AirbridgeCategory.ORDER_COMPLETED, option)
으로 ORDER_COMPLETED
이벤트를 전달합니다.
기존 api 의 purchaseEvent
의 매개변수에 값을 option 에 객체에 담아서 전달 한다.
transactionID
=>semanticAttributes.[AirbridgeAttributes.TRANSACTION_ID]
product
=>semanticAttributes.[AirbridgeAttributes.PRODUCTS]
isInAppPurchase
=>semanticAttributes.[AirbridgeAttributes.IN_APP_PURCHASED]
totalValue
=>semanticAttributes.[AirbridgeAttributes.TOTAL_VALUE]
사용자 이벤트
- Airbridge.event.send(Event(
- category: ...,
- option: ...,
- ));
+ Airbridge.trackEvent(category, option);
Airbridge.event.send(Event())
를 사용하고 있다면 변경이 필요합니다.
Airbridge.trackEvent(category, option)
으로 이벤트를 전달합니다.