다음을 통해 공유


에이전트의 모양과 느낌을 사용자 지정하세요

에이전트의 캔버스는 모양과 느낌을 결정합니다. 원하는 변경 사항의 복잡성에 따라 두 가지 방법으로 캔버스를 사용자 지정할 수 있습니다.

중요

이 문서에 포함된 샘플 코드는 .NET에서만 설치하여 사용할 수 있습니다 Copilot Studio. 샘플 코드는 "있는 그대로" 라이선스가 부여되며 서비스 수준 약정 또는 지원 서비스에서 제외됩니다. 이 문서의 사용으로 발생하는 위험은 귀하의 책임입니다.

Microsoft는 어떠한 명시적 보증, 보장 또는 조건을 제공하지 않으며 상품성, 특정 목적에의 적합성 및 비침해를 비롯한 모든 묵시적 보증을 제외합니다.

에이전트 를 만들고 게시하면 고객이 에이전트의 웹 채팅 캔버스를 사용하여 해당 사이트와 상호 작용할 수 있습니다. ...

사용자 정의된 캔버스를 에이전트 구성과 결합하여 대화를 자동으로 시작할 수 있습니다.

마지막으로, 포털에서 바로 에이전트의 이름과 아이콘을 변경할 수 있습니다( 공유된 경우 ). Microsoft Teams

에이전트 이름과 아이콘을 변경하세요

중요

에이전트가 Customer Service용 옴니채널에 연결되어 있는 경우, 해당 이름은 Azure 포털 등록의 표시 이름 속성에 의해 정의됩니다.

에이전트의 이름과 아이콘을 변경할 수 있습니다. 이는 에이전트를 게시하는 모든 채널의 아이콘에 영향을 미칩니다.

  1. 탐색 메뉴에서 설정 아래의 세부 정보를 선택합니다.

  2. 에이전트의 이름과 아이콘을 변경합니다. Microsoft Teams 아이콘 형식의 권장 사항을 검토합니다.

  3. 저장을 선택하여 변경 내용을 커밋합니다.

    에이전트 세부정보 창에서 이름과 아이콘을 변경할 수 있습니다.

중요

에이전트 아이콘을 업데이트한 후 모든 곳에 새로운 아이콘이 나타나기까지 최대 24시간이 걸릴 수 있습니다.

토큰 엔드포인트 검색

기본 캔버스이든 연결 사용자 지정 캔버스이든 캔버스를 사용자 지정하려면 에이전트 세부정보를 검색해야 합니다.

  1. 탐색 메뉴에서 설정 아래의 채널을 선택합니다.

  2. 모바일 앱을 선택합니다.

    모바일 앱 채널 타일의 스크린샷.

  3. 토큰 엔드포인트 옆에 있는 복사를 선택합니다.

    끝점 토큰 ID 스크린샷.

기본 캔버스 사용자 지정(단순)

몇 가지 단순한 CSS 및 JavaScript 스타일 지정 옵션으로 채팅 캔버스의 모습을 구성할 수 있습니다.

먼저, 에이전트 캔버스를 배포할 위치를 구성해야 합니다.

  1. 에이전트를 만들고 게시하세요.

  2. 아래 HTML 코드를 복사하여 붙여 넣고 index.html로 저장하십시오.
    아래 코드를 복사하여 w3schools.com HTML 체험 편집기에 붙여 넣을 수도 있습니다. 여전히 토큰 엔드포인트를 추가해야 합니다.

     <!doctype html>
     <html lang="en">
       <head>
         <title>Contoso Sample Web Chat</title>
         <!--
           This styling is for the Web Chat demonstration purposes.
           It is recommended that style is moved to a separate file for organization in larger projects.
    
           Please visit https://github.com/microsoft/BotFramework-WebChat for details about Web Chat.
         -->
         <style>
           html,
           body {
             height: 100%;
           }
    
           body {
             margin: 0;
           }
    
           h1 {
             color: whitesmoke;
             font-family: Segoe UI;
             font-size: 16px;
             line-height: 20px;
             margin: 0;
             padding: 0 20px;
           }
    
           #banner {
             align-items: center;
             background-color: black;
             display: flex;
             height: 50px;
           }
    
           #webchat {
             height: calc(100% - 50px);
             overflow: hidden;
             position: fixed;
             top: 50px;
             width: 100%;
           }
         </style>
       </head>
       <body>
         <div>
           <div id="banner">
             <h1>Contoso agent name</h1>
           </div>
           <div id="webchat" role="main"></div>
         </div>
    
         <!--
           In this sample, the latest version of Web Chat is being used.
           In production environment, the version number should be pinned and version bump should be done frequently.
    
           Please visit https://github.com/microsoft/BotFramework-WebChat/tree/main/CHANGELOG.md for changelog.
         -->
         <script crossorigin="anonymous" src="https://cdn.botframework.com/botframework-webchat/latest/webchat.js"></script>
    
         <script>
           (async function () {
             // Specifies style options to customize the Web Chat canvas.
             // Please visit https://microsoft.github.io/BotFramework-WebChat for customization samples.
             const styleOptions = {
               // Hide upload button.
               hideUploadButton: true
             };
    
             // Specifies the token endpoint URL.
             // To get this value, visit Copilot Studio > Settings > Channels > Mobile app page.
             const tokenEndpointURL = new URL('<AGENT TOKEN ENDPOINT>');
    
             // Specifies the language the agent and Web Chat should display in:
             // - (Recommended) To match the page language, set it to document.documentElement.lang
             // - To use current user language, set it to navigator.language with a fallback language
             // - To use another language, set it to supported Unicode locale
    
             // Setting page language is highly recommended.
             // When page language is set, browsers will use native font for the respective language.
    
             const locale = document.documentElement.lang || 'en'; // Uses language specified in <html> element and fallback to English (United States).
             // const locale = navigator.language || 'ja-JP'; // Uses user preferred language and fallback to Japanese.
             // const locale = 'zh-HAnt'; // Always use Chinese (Traditional).
    
             const apiVersion = tokenEndpointURL.searchParams.get('api-version');
    
             const [directLineURL, token] = await Promise.all([
               fetch(new URL(`/powervirtualagents/regionalchannelsettings?api-version=${apiVersion}`, tokenEndpointURL))
                 .then(response => {
                   if (!response.ok) {
                     throw new Error('Failed to retrieve regional channel settings.');
                   }
    
                   return response.json();
                 })
                 .then(({ channelUrlsById: { directline } }) => directline),
               fetch(tokenEndpointURL)
                 .then(response => {
                   if (!response.ok) {
                     throw new Error('Failed to retrieve Direct Line token.');
                   }
    
                   return response.json();
                 })
                 .then(({ token }) => token)
             ]);
    
             // The "token" variable is the credentials for accessing the current conversation.
             // To maintain conversation across page navigation, save and reuse the token.
    
             // The token could have access to sensitive information about the user.
             // It must be treated like user password.
    
             const directLine = WebChat.createDirectLine({ domain: new URL('v3/directline', directLineURL), token });
    
             // Sends "startConversation" event when the connection is established.
    
             const subscription = directLine.connectionStatus$.subscribe({
               next(value) {
                 if (value === 2) {
                   directLine
                     .postActivity({
                       localTimezone: Intl.DateTimeFormat().resolvedOptions().timeZone,
                       locale,
                       name: 'startConversation',
                       type: 'event'
                     })
                     .subscribe();
    
                   // Only send the event once, unsubscribe after the event is sent.
                   subscription.unsubscribe();
                 }
               }
             });
    
             WebChat.renderWebChat({ directLine, locale, styleOptions }, document.getElementById('webchat'));
           })();
         </script>
       </body>
     </html>
    
  3. 자신이 만든 index.html 파일의 const tokenEndpointURL = "<YOUR TOKEN ENDPOINT>"; 줄에 토큰 엔드포인트를 입력합니다.

  4. 최신 브라우저(예: )를 사용하여 index.html Microsoft Edge을 열어 사용자 지정 캔버스에서 에이전트를 엽니다.

  5. 에이전트를 테스트하여 응답을 받고 제대로 작동하는지 확인하세요.

    문제가 발생하면 에이전트를 게시했는지, 토큰 끝점가 올바른 위치에 삽입되었는지 확인하세요. const tokenEndpointURL = "<YOUR TOKEN ENDPOINT>" 줄에서 등호(=) 뒤에 있어야 하며, 큰 따옴표(") 안에 있어야 합니다.

에이전트 아이콘, 배경색, 이름을 사용자 지정하세요

에이전트에서 사용자 지정 캔버스를 작동시키면 변경할 수 있습니다.

JavaScript styleOptions 옵션을 사용하여 여러 사전 정의된 스타일을 구성할 수 있습니다.

defaultStyleOptions.js 파일 링크에 대한 웹 채팅 사용자 지정과 사용자 지정할 수 있는 항목 및 표시 방법에 대한 자세한 정보를 확인하세요.

에이전트 아이콘을 변경하세요

  1. 다음 샘플 코드로 index.html 파일을 업데이트합니다.

    const styleOptions = {
      accent: '#00809d',
      botAvatarBackgroundColor: '#FFFFFF',
      botAvatarImage: 'https://learn.microsoft.com/azure/bot-service/v4sdk/media/logo_bot.svg',
      botAvatarInitials: 'BT',
      userAvatarImage: 'https://avatars.githubusercontent.com/u/661465'
    };  
    
  2. 에이전트 및 사용자 아바타 이미지를 회사 이미지로 바꾸세요.
    이미지 URL이 없는 경우 대신 Base64로 인코딩된 이미지 문자열을 사용할 수 있습니다.

배경 색상을 변경합니다.

  1. 다음 샘플 코드로 index.html 파일을 업데이트합니다.

    const styleOptions = {
      backgroundColor: 'lightgray'
    };  
    
  2. 원하는 색상으로 backgroundColor를 변경합니다. 표준 CSS 색상 이름, RGB 값 또는 16진수를 사용할 수 있습니다.

에이전트 이름 변경

  1. index.html 파일의 <h1> 텍스트를 다음으로 업데이트합니다.

    <body>
      <div id="banner">
        <h1><img src="contosocopilot-teams.png"> Contoso agent name</h1>
      </div>
    
  2. 텍스트를 에이전트라는 이름으로 원하는 대로 변경하세요. 머리글 섹션에 맞도록 스타일을 지정해야 할 수도 있지만 이미지를 삽입할 수도 있습니다.

채팅 캔버스 사용자 지정 및 호스팅(고급)

독립형 웹 앱으로 호스팅되는 사용자 정의 캔버스를 사용하면 연결 Copilot Studio 에이전트 할 수 있습니다. 이 옵션은 여러 웹 페이지에서 사용자 지정 iFrame를 포함해야 하는 경우에 가장 좋습니다.

노트

사용자 지정 캔버스를 호스팅하려면 소프트웨어 개발이 필요합니다. 여기의 지침은 개발자 도구, 유틸리티 및 IDE에 대해 잘 알고 있는 IT 관리자나 개발자와 같은 숙련된 IT 전문가를 대상으로 합니다.

사용자 지정할 샘플 선택

Copilot Studio로 작업하기 위해 맞춤 빌드된 다음 샘플 중 하나를 사용하는 것이 좋습니다.

  • 전체 번들은 Copilot Studio의 모든 풍부한 콘텐츠를 표시할 수 있는 사용자 지정 캔버스입니다. 예:

    전체 번들 사용자 지정 캔버스.

  • 위치 및 파일 업로드 는 사용자의 위치를 알아내어 에이전트로 보낼 수 있는 사용자 지정 캔버스입니다. Copilot Studio 예:

    사용자 지정 캔버스를 업로드하는 위치 및 파일.

또는 Bot Framework에서 제공되는 다른 샘플 웹 채팅 캔버스를 사용할 수 있습니다.

styleSetOptions를 사용하여 캔버스 사용자 지정

기본 캔버스 사용자 지정과 마찬가지로 styleSetOptions를 사용하여 사용자 지정 캔버스를 사용자 지정할 수 있습니다. 모든 사용자 지정 가능한 속성은 defaultStyleOptions.js에 나열됩니다. 사용자 지정할 수 있는 내용과 모습에 대한 자세한 내용은 웹 채팅 사용자 지정을 참조하세요.

맞춤형 캔버스 배포

사용자 지정 캔버스를 호스팅하려면 모든 파일을 웹앱에 배포하십시오.