소스라이브 모아보기
소스라이브 모아보기란 자사몰 웹에 라이브를 진행했던 영상(VOD) 및 편성표를 보여주는 서비스입니다. 이 챕터는 서비스 시스템을 내부 웹에서 보여주도록 구현하기 위한 가이드 입니다.
게스트(비로그인) 사용자로 사용하기
자바 스크립트와 스타일을 페이지에서 불러오기 위해서는 아래의 코드의 적용이 필요합니다.
<div id='sauce_collect'></div>
<script src="https://collection.sauceflex.com/static/js/SauceWebLib.js"></script>
<script>
window.SauceWebLib.setInit({ partnerId: 'service1234' });
window.SauceWebLib.load()
</script>
// optional
<div id='sauce_collect'></div>
<script src="https://collection.sauceflex.com/static/js/SauceWebLib.js"></script>
<script>
window.SauceWebLib.setInit({
// 담당 AM을 통해 전달 받으신 partnerId 를 입력해주세요. 필수값입니다.
partnerId: 'service1234',
/* type boolean (defaultValue:true)*/
broadcast: true,
//라이브 미리보기 영역의 노출여부를 설정할 수 있습니다.
/* type boolean (defaultValue:true)*/
schedule: true,
//파트너사 라이브 방송 스타일에 맞게 라이브 미리보기 형식을 "이미지형" "피드형" "리스트형"으로 설정할 수 있습니다.
/* type image | feed | list (defaultValue image) */
scheduleType: "feed",
//큐레이션 카테고리 영역의 노출여부를 설정할 수 있습니다.
/* type boolean (defaultValue:true)*/
curation: true,
//큐레이션 영역의 노출 여부를 설정할 수 있습니다.
/* type boolean (defaultValue:true)*/
curationDetail: true,
//비디오 썸네일 자동재생 여부
/* type boolen (defaultValue:false)*/
autoPlay:false,
// 검색바 노출여부
/* type boolen (defaultValue:true)*/
searchBar:true,
// 방송카드 리스트 새창이동 설정
// 기본은 현재창 이동이며, 새창이동을 webview,pc,mobile값에 따라 설정할 수 있습니다.
/* type string (defaultVlaue:'') */
broadcastOpenLink:"webview,pc,mobile",
});
window.SauceWebLib.load('sauce_collect')
</script>
최초 연동 시에는 편성표나 라이브가 등록되어 있지 않기 때문에, 빈 화면이 출력 됩니다.
라이브나 편성표 등록을 하고 테스트를 진행해 보세요.
간편 인증 사용하기 (일반 텍스트 형식의 nickName 및 memberId)
비회원, 간편 인증, JWT 인증 방식을 지원합니다.
<div id='sauce_collect'></div>
<script>
window.SauceWebLib.setInit({ partnerId: 'service1234' });
window.SauceWebLib.setMemberObject({
memberId: 'saucelive',
nickName: '소스라이브***',
age: '10',
gender: 'm'
});
window.SauceWebLib.load()
</script>
간편 인증 사용 예시 (고객사 사용시의 코드 예시)
<div id='sauce_collect'></div>
<script src="https://collection.sauceflex.com/static/js/SauceWebLib.js"></script>
<script>
// 현재 고객이 로그인되어있는지 확인할수 있는 고객사 API를 사용합니다.
const response = await fetch(`YOUR API`);
// 고객사 API 에서 실제적으로 고객을 파악할수 있는 ID 와 이름 혹은 닉네임을 추출합니다.
const { memberId,nickName,name } = await response.json();
// 모비두 가입시 확인 받은 파트너ID 를 입력 해주세요
const partnerId = params.get('broadcastId');
if(memberId && partnerId ){
window.SauceWebLib.setInit({ partnerId: partnerId });
window.SauceWebLib.setMemberObject({
memberId: memberId,
// 채팅창에 표기되는 이름입니다. 닉네임 혹은 이름을 입력해주세요
nickName: nickName ?? name ,
});
window.SauceWebLib.load()
// 멤버ID 등이 존재하지 않으면 비로그인으로 플레이어를 실행시킵니다.
} else if (partnerId) {
window.SauceWebLib.setInit({ partnerId: 'uiux' });
window.SauceWebLib.setMemberToken('')
window.SauceWebLib.load();
}
</script>
JWT 인증 사용하기
간편 인증과 JWT 인증으로 사용자 정보를 연동할 수 있습니다.
간편 인증은 빠르고 간편하게 인증 사용을 할 수 있지만, 보안 강화와 임의의 사용자 ID가 어뷰징 되는 것을 방지하기 위해 JWT 인증을 할 수 있습니다. JWT Token 생성
<div id='sauce_collect'></div>
<script src="https://collection.sauceflex.com/static/js/SauceWebLib.js"></script>
window.SauceWebLib.setInit({ partnerId: 'service1234' });
window.SauceWebLib.setMemberToken(JWT:string)
window.SauceWebLib.load() //default 'sauce_collect'
</script>
모듈화 사용
페이지 내 적용하려는 위치에 태그를 다음과 같이 추가합니다. id 속성에는 임의의 값을 지정합니다.
여러 요소에 적용하려는 경우, 복수의 태그를 임의의 위치에 추가합니다. 단, 중복되지 않는 id 속성의 값을 지정합니다.
큐레이션 모듈화
<div id='curation_1'></div>
<div id='curation_2'></div>
<script src="https://collection.sauceflex.com/static/js/SauceWebLib.js"></script>
<script>
window.SauceWebLib.setInit({ partnerId: 'service1234' });
window.SauceWebLib.loadCuration({ curationId: "{{임의의 큐레이션ID}}", elementId: "curation_1" });
// 임의의 큐레이션ID 는 소스라이브 어드민에서 확인가능합니다.(모아보기=>큐레이션리스트에서 개별 큐레이션 클릭해서 확인)
// elementId 는 curation_1 와 같이 지정 위치에 렌더링할 ID 를 지정합니다.
</script>
// or
<script>
window.SauceWebLib.setInit({ partnerId: 'service1234' });
window.SauceWebLib.loadCuration({ curationId: "{{임의의 큐레이션ID}}", elementId: "curation_1" });
window.SauceWebLib.loadCuration({ curationId: "{{임의의 큐레이션ID}}", elementId: "curation_2" });
</script>
// elementId 는 curation_1 와 같이 지정 위치에 렌더링할 ID 를 지정하며 여러개의 큐레이션을 세팅하여 모듈화 가능합니다.
캘린더 모듈화
<div id='calendar'></div>
<script src="https://collection.sauceflex.com/static/js/SauceWebLib.js"></script>
window.SauceWebLib.setInit({ partnerId: 'service1234' });
window.SauceWebLib.loadCalendar({ elementId: "calendar" });
// elementId 는 calendar 와 같이 지정 위치에 렌더링할 ID 를 지정합니다.
</script>
배너 모듈화
<div id='topBanner'></div>
<script src="https://collection.sauceflex.com/static/js/SauceWebLib.js"></script>
window.SauceWebLib.setInit({ partnerId: 'service1234' });
window.SauceWebLib.loadTopBanner({ elementId: "topBanner" });
// elementId 는 topBanner 와 같이 지정 위치에 렌더링할 ID 를 지정합니다.
</script>
스케쥴 모듈화 (라이브 미리보기)
<div id='schedule'></div>
<script src="https://collection.sauceflex.com/static/js/SauceWebLib.js"></script>
window.SauceWebLib.setInit({ partnerId: 'service1234' });
window.SauceWebLib.loadSchedule({
scheduleType: 'image' | 'feed' | 'list',
elementId: "schedule"
});
// elementId 는 schedule 와 같이 지정 위치에 렌더링할 ID 를 지정합니다.
</script>
최신 라이브 영역 모듈화 (라이브 다시보기)
<div id='broadcast'></div>
<script src="https://collection.sauceflex.com/static/js/SauceWebLib.js"></script>
window.SauceWebLib.setInit({ partnerId: 'service1234' });
window.SauceWebLib.loadBroadcast({
displayType: "horizontal", // 종류: 'horizontal'(가로형), 'vertical'(세로형)
elementId: "broadcast",
title: "최근 방송 보기" // 해당 모듈에 제목을 사용하지 않을 경우 생략 가능
});
// elementId 는 schedule 와 같이 지정 위치에 렌더링할 ID 를 지정하는 필수 값입니다.
// displayType을 통해 표시 유형을 가로형과 세로형으로 설정할 수 있습니다.
// displayType은 선택 값이며, 해당 기능은 모듈화 방식만 지원합니다. 기본값은 'horizontal'(가로형)입니다.
// title 을 통해 라이브 방송 영역의 제목을 입력할 수 있습니다.
// title 은 선택 값이며, 해당 기능은 모듈화 방식만 지원합니다.
</script>
예시 샘플 (기본형)
<html>
<head>
<title>sauce live example</title>
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, viewport-fit=cover, shrink-to-fit=no" />
<script src="https://collection.sauceflex.com/static/js/SauceWebLib.js"></script>
// 스테이지 운영시에는 https://stage.collection.sauceflex.com/static/js/SauceWebLib.js 을 사용해주세요
<style>
html,
body {
margin: 0;
padding: 0;
background-color: #333;
}
// 필요한 css 는 추가적으로 세팅해도 무관합니다.
</style>
</head>
<body>
<div id='sauce_collect'></div>
</body>
<script>
window.SauceWebLib.setInit({ partnerId: 'service1234' });
window.SauceWebLib.setMemberObject({
memberId: 'saucelive',
nickName: '소스라이브***',
age: '10',
gender: 'm'
});
window.SauceWebLib.load()
</script>
</html>
예시 샘플 (모듈형)
<html>
<head>
<title>sauce live example</title>
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, viewport-fit=cover, shrink-to-fit=no" />
<script src="https://collection.sauceflex.com/static/js/SauceWebLib.js"></script>
// 스테이지 운영시에는 https://stage.collection.sauceflex.com/static/js/SauceWebLib.js 을 사용해주세요
<style>
html,
body {
margin: 0;
padding: 0;
background-color: #333;
}
// 필요한 css 는 추가적으로 세팅해도 무관합니다.
</style>
</head>
<body>
<div id='schedule'></div>
<div id='calendar'></div>
<div id='broadcast'></div>
</body>
<script>
window.SauceWebLib.setInit({ partnerId: 'service1234' });
window.SauceWebLib.loadSchedule({scheduleType:'feed', elementId: "schedule" });
window.SauceWebLib.loadCalendar({ elementId: "calendar" });
window.SauceWebLib.loadBroadcast({ elementId: "broadcast" });
</script>
</html>
웹 전용 브릿지 설정(기본형)
웹 전용 브릿지 설정이란?
지정한 동작에서 원하는 커스텀 설정으로 변경하여 동작을 수정할수 있는 기능입니다.
// ex) 기본 동작 모아보기에서 방송 클릭시 기본 설정된 방송 URL 로 이동 function flexCollectMoveBroadcast(params){ console.log('flexCollectMoveBroadcast',params) } // 선언이후 방송 클릭시 console.log 로 방송 데이터를 확인할수 있게되며 방송 URL 로 이동되는 동작은 취소됨
<html>
<head>
<title>sauce live example</title>
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, viewport-fit=cover, shrink-to-fit=no" />
<script src="https://collection.sauceflex.com/static/js/SauceWebLib.js"></script>
// 스테이지 운영시에는 https://stage.collection.sauceflex.com/static/js/SauceWebLib.js 을 사용해주세요
<style>
html,
body {
margin: 0;
padding: 0;
background-color: #333;
}
// 필요한 css 는 추가적으로 세팅해도 무관합니다.
</style>
</head>
<body>
<div id='sauce_collect'></div>
</body>
<script>
// function flexCollectEnter(){
// console.log('flexCollectEnter')
// }
// 모아보기 랜딩 시
// function flexCollectLogin(){
// console.log('flexCollectLogin')
// }
// 모아보기 로그인 버튼 클릭 시
// function flexCollectMoveBroadcast(params){
// console.log('flexCollectMoveBroadcast',params)
// }
// 방송 카드 클릭 시
// function flexCollectMoveProduct(params){
// console.log('flexCollectMoveProduct',params)
// }
// 방송 상품 카드 클릭 시
// function flexCollectMoveTopBanner(params){
// console.log('flexCollectMoveTopBanner',params)
// }
// 알람 버튼 클릭 시
// function flexCollectApplyForNotification(params){
// console.log('flexCollectApplyForNotification',params)
// }
// 알람 버튼 취소 시
// function flexCollectCancelForNotification(params){
// console.log('flexCollectCancelForNotification',params)
// }
// 방송 커스텀 버튼 클릭 시
// function flexCollectBroadcastCustomButton(params){
// console.log('flexCollectBroadcastCustomButton', params)
// }
// function flexCollectMoveTopBanner(params){
// console.log('flexCollectMoveTopBanner', params)
// }
window.SauceWebLib({
partnerId: 'service1234',
});
</script>
</html>
알람 전용 브릿지 설정에 대해서
알람 전용 브릿지 사용시 모비두가 설정한 기본 모달이 나오지 않으며 UI 의 변경이 필요할 경우 다른 알림 함수를 실행시켜줘야 모아보기의 UI 가 변경됩니다. 아래의 dispatchEvent 함수를 실행시켜 줄 경우에만 전체 모듈화된 알람 UI 의 상태값이 변경되며 UI 로 확인할 수 있습니다.
// flexCollectApplyForNotification 에서 broadcastId 를 가져올수 있습니다. const applyBroadcastObj={ broadcastId:broadcastId } dispatchEvent(window.flexCollectApplyCheckNotification(applyBroadcastObj)) // flexCollectCancelForNotification 에서 broadcastId 를 가져올수 있습니다. const canceledBroadcastObj={ broadcastId:broadcastId } dispatchEvent(window.flexCollectCancelCheckNotification(canceledBroadcastObj))
function flexCollectApplyForNotification(params){ console.log('flexCollectApplyForNotification',params:NotificationParams) const applyBroadcastObj={ broadcastId:params.broadcastId } dispatchEvent(window.flexCollectApplyCheckNotification(applyBroadcastObj)) } function flexCollectCancelForNotification(params:NotificationParams){ console.log('flexCollectCancelForNotification',params) const canceledBroadcastObj={ broadcastId:params.broadcastId } dispatchEvent(window.flexCollectCancelCheckNotification(canceledBroadcastObj)) } //알람의 params type NotificationParams= { memberId: String, // 고객 ID programmingStartDt:String, // 방송 시작시간 ex(UTC"2022-02-01T06:34:00.000Z") programmingEndDt:String,// 방송 종료시간 ex(UTC"2022-02-02T06:34:00.000Z") broadcastId: String, // 방송ID accessToken: String // JWT TOKEN }
모아보기의 색상 타입 변경 이벤트 함수 제공
( light 및 dark 모드와 같은 별도 색상 지원)
window.SauceWebLib.setInit({ partnerId: 'service1234' });
window.SauceWebLib.setMemberToken(JWT:string)
window.SauceWebLib.load() //default 'sauce_collect'
dispatchEvent(window.flexCollectThemeTypB)
/** 별도로 지정된 모아보기 세팅 색상 옵션을 지정해서 전체 UI의 색상을 변경시키는 이벤트 함수입니다. */
// 색상 설정에 대한 자세한 설정에 대해서는 [email protected] 또는 카카오톡으로 문의해 주세요.
// 기본 모아보기 방식 그리고 모듈화에서도 사용가능합나디.
dispatchEvent(window.flexCollectThemeTypeA)
/** 초기 지정된 모아보기 색상으로 돌아가는 이벤트 함수입니다. */
모아보기 적용 이미지 (기본형)
연동방법 (Webview)
Bridge & Message
아래와 같은 Bridge로 메시지가 전달됩니다. 각 메시지는 JSON 객체가 stringify 되어 전달됩니다.
- flexCollectEnter(Void) - 페이지 진입 시 자동으로 호출
// 파라미터 없음
- flexCollectMoveProduct(message: String) - 상품 클릭 시 호출
// Stringified JSON
{
productId: String,//상품ID
productUrl: String, //상품등록URL
broadcastUrl: String, //라이브 OR VOD플레이어URL
}
- flexCollectMoveBroadcast(message: String) - 라이브,VOD 클릭 시 호출
// Stringified JSON
{
broadcastUrl: String, //라이브 OR VOD플레이어URL
}
- flexCollectMoveTopBanner(message: String) - TOP 배너 클릭 시 호출
// Stringified JSON
{
bannerLinkUrl: String, //배너링크URL
}
- flexCollectMoveContentBanner(message: String) - 콘텐츠 배너 클릭 시 호출
// Stringified JSON
{
bannerLinkUrl: String, //콘텐츠배너링크URL
}
- flexCollectApplyForNotification(message: String) - 알림 신청 동의 버튼 클릭 시 호출
// Stringified JSON
{
memberId: String, // 고객 ID
programmingStartDt:String, // 방송 시작시간 ex(UTC"2022-02-01T06:34:00.000Z")
programmingEndDt:String,// 방송 종료시간 ex(UTC"2022-02-02T06:34:00.000Z")
broadcastId: String, // 방송ID
accessToken: String // JWT TOKEN
}
- flexCollectCancelForNotification(message: String) - 알림 신청 취소 클릭시 호출
// Stringified JSON
{
memberId: String, // 고객 ID
programmingStartDt:String, // 방송 시작시간 ex(UTC"2022-02-01T06:34:00.000Z")
programmingEndDt:String,// 방송 종료시간 ex(UTC"2022-02-02T06:34:00.000Z")
broadcastId: String, // 방송ID
accessToken: String // JWT TOKEN
}
- flexCollectBroadcastCustomButton(message: String) - 방송 커스텀 버튼 클릭시 호출
// Stringified JSON
{
broadcastId: String, // 방송ID
customButtonUrl: String, // 버튼에 연결된 URL
}
Updated 5 days ago