Unverified Commit 306216db authored by Charlie.Wei's avatar Charlie.Wei Committed by GitHub

application embedded add chrome && ChatBot Chrome plugin update v1.5 (#1480)

Co-authored-by: luowei <glpat-EjySCyNjWiLqAED-YmwM>
Co-authored-by: 's avatarcrazywoola <427733928@qq.com>
parent ab2e20ee
......@@ -20,16 +20,14 @@
- options.js 插件配置JS脚本
### 插件导入完成后,后续配置无差异
- 初始化设置Dify 应用配置,分别输入Dify根域名和应用Token,Token可以在Dify应用嵌入中获取,如图:
- 创建Dify应用配置,在应用概览中点击嵌入,切换到安装Chrome浏览器扩展视图,点击copy按钮获取ChatBot Url,如图:
![img-2.png](images/img-2.png)
![img-3.png](images/img-3.png)
- 点击保存,确认提示配置成功即可
![img-4.png](images/img-4.png)
![img-3.png](images/img-3.png)
- 保险起见重启浏览器确保所有分页刷新成功
- Chrome打开任意页面均可正常加载DIfy机器人浮动栏,后续如需更换机器人只需要变更Token即可
- Chrome打开任意页面均可正常加载DIfy机器人浮动栏,后续如需更换机器人只需要变更ChatBot Url即可
![img-5.png](images/img-5.png)
\ No newline at end of file
![img-4.png](images/img-4.png)
\ No newline at end of file
## Chrome Dify ChatBot插件
1、初始化设置Dify 应用配置,分别输入Dify根域名和应用Token,Token可以在Dify应用嵌入中获取;
2、点击保存,确认提示配置成功即可;
3、保险起见重启浏览器确保所有分页刷新成功;
4、Chrome打开任意页面均可正常加载DIfy机器人浮动栏,后续如需更换机器人只需要变更Token即可;
\ No newline at end of file
var storage = chrome.storage.sync;
chrome.storage.sync.get(['baseUrl', 'token'], function(result) {
const storage = chrome.storage.sync;
chrome.storage.sync.get(['chatbotUrl'], function(result) {
window.difyChatbotConfig = {
baseUrl: result.baseUrl,
token: result.token
chatbotUrl: result.chatbotUrl,
};
});
......@@ -10,11 +9,10 @@ document.body.onload = embedChatbot;
async function embedChatbot() {
const difyChatbotConfig = window.difyChatbotConfig;
if (!difyChatbotConfig || !difyChatbotConfig.token) {
console.warn('difyChatbotConfig is empty or token is not provided');
if (!difyChatbotConfig) {
console.warn('Dify Chatbot Url is empty or is not provided');
return;
}
const baseUrl = difyChatbotConfig.baseUrl
const openIcon = `<svg
id="openIcon"
width="24"
......@@ -53,7 +51,7 @@ async function embedChatbot() {
iframe.allow = "fullscreen;microphone"
iframe.title = "dify chatbot bubble window"
iframe.id = 'dify-chatbot-bubble-window'
iframe.src = `${baseUrl}/chat/${difyChatbotConfig.token}`
iframe.src = difyChatbotConfig.chatbotUrl
iframe.style.cssText = 'border: none; position: fixed; flex-direction: column; justify-content: space-between; box-shadow: rgba(150, 150, 150, 0.2) 0px 10px 30px 0px, rgba(150, 150, 150, 0.2) 0px 0px 0px 1px; bottom: 6.7rem; right: 1rem; width: 30rem; height: 48rem; border-radius: 0.75rem; display: flex; z-index: 2147483647; overflow: hidden; left: unset; background-color: #F3F4F6;'
document.body.appendChild(iframe);
}
......
{
"manifest_version": 3,
"name": "Dify Chatbot",
"version": "1.3",
"version": "1.5",
"description": "This is a chrome extension to inject a dify chatbot on any pages",
"content_scripts": [
{
......
body {
background-color: #f2f2f2;
font-family: Arial, sans-serif;
}
h2 {
color: #333;
}
label {
display: block;
margin-top: 10px;
margin-bottom: 10px;
}
input[type="text"] {
width: 280px;
padding: 6px;
}
\ No newline at end of file
......@@ -4,32 +4,21 @@
<head>
<title>Dify Chatbot Extension</title>
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<link href="https://cdn.jsdelivr.net/npm/tailwindcss@2.2.19/dist/tailwind.min.css" rel="stylesheet">
<link href="./tailwind.css" rel="stylesheet">
</head>
<body class="bg-gray-100 py-8 px-4 w-96">
<body class="bg-gray-100 py-4 px-4 w-128">
<div class="max-w-md mx-auto bg-white shadow-md rounded-lg p-4">
<h2 class="text-2xl font-semibold mb-4">Dify Chatbot Extension</h2>
<form>
<div class="mb-4 flex items-center">
<div class="w-1/4">
<label for="base-url" class="block font-semibold text-gray-700">Base URL</label>
<label for="chatbot-url" class="block font-semibold text-gray-700">ChatBot URL</label>
</div>
<div class="w-3/4">
<input type="text" id="base-url" name="base-url" value=""
<input type="text" id="chatbot-url" name="base-url" value=""
class="w-full border border-gray-300 rounded px-3 py-2 focus:outline-none focus:border-blue-400"
placeholder="https://udify.app">
</div>
</div>
<div class="mb-4 flex items-center">
<div class="w-1/4">
<label for="token" class="block font-semibold text-gray-700">Token</label>
</div>
<div class="w-3/4">
<input type="text" id="token" name="token" value=""
class="w-full border border-gray-300 rounded px-3 py-2 focus:outline-none focus:border-blue-400"
placeholder="Application Embedded Token">
placeholder="https://udify.app/chatbot/7CQBa5yyvYLSkZtx">
</div>
</div>
......
document.getElementById('save-button').addEventListener('click', function (e) {
e.preventDefault();
var baseUrl = document.getElementById('base-url').value;
var token = document.getElementById('token').value;
var errorTip = document.getElementById('error-tip');
const chatbotUrl = document.getElementById('chatbot-url').value;
const errorTip = document.getElementById('error-tip');
if (baseUrl.trim() === "" || token.trim() === "") {
if (baseUrl.trim() === "") {
errorTip.textContent = "Base URL cannot be empty.";
} else {
errorTip.textContent = "Token cannot be empty.";
}
if (chatbotUrl.trim() === "") {
errorTip.textContent = "Dify ChatBot URL cannot be empty.";
} else {
errorTip.textContent = "";
chrome.storage.sync.set({
'baseUrl': baseUrl,
'token': token
'chatbotUrl': chatbotUrl,
}, function () {
alert('Save Success!');
});
}
});
// Load parameters from chrome.storage when the page loads
chrome.storage.sync.get(['baseUrl', 'token'], function (result) {
const baseUrlInput = document.getElementById('base-url');
const tokenInput = document.getElementById('token');
chrome.storage.sync.get(['chatbotUrl'], function (result) {
const chatbotUrlInput = document.getElementById('chatbot-url');
if (result.baseUrl) {
baseUrlInput.value = result.baseUrl;
if (result.chatbotUrl) {
chatbotUrlInput.value = result.chatbotUrl;
}
if (result.token) {
tokenInput.value = result.token;
}
});
\ No newline at end of file
This source diff could not be displayed because it is too large. You can view the blob instead.
<svg width="16" height="16" viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg">
<path d="M4.91722 6.7298L3.08403 3.65525C2.93723 3.40905 2.86384 3.28596 2.84729 3.14436C2.83386 3.02937 2.85797 2.8842 2.90785 2.77973C2.96928 2.65108 3.06488 2.5699 3.2561 2.40754C4.53491 1.32168 6.19097 0.666626 8.00002 0.666626C10.5383 0.666626 12.7753 1.95619 14.0918 3.91589C14.2371 4.13226 14.3098 4.24045 14.3034 4.35234C14.2981 4.44429 14.2454 4.54327 14.172 4.59892C14.0827 4.66663 13.9425 4.66663 13.6621 4.66663H8.00002C6.60882 4.66663 5.41668 5.51889 4.91722 6.7298Z" fill="white"/>
<path d="M0.666687 7.99996C0.666687 6.87421 0.92035 5.80771 1.37364 4.85449C1.48535 4.61957 1.5412 4.50211 1.64056 4.45053C1.72221 4.40813 1.83412 4.40288 1.91938 4.43744C2.02313 4.4795 2.0948 4.5997 2.23814 4.8401L5.06356 9.57876C5.62637 10.6234 6.73029 11.3333 8.00002 11.3333C8.13686 11.3333 8.27178 11.325 8.4043 11.309L6.62101 14.4166C6.4785 14.665 6.40724 14.7891 6.29186 14.873C6.19827 14.941 6.05961 14.9912 5.94418 14.9988C5.80188 15.0083 5.68457 14.9648 5.44995 14.8778C2.65701 13.8418 0.666687 11.1533 0.666687 7.99996Z" fill="white"/>
<path d="M7.81791 15.0098C7.73532 15.1537 7.83408 15.3333 8.00002 15.3333C12.0501 15.3333 15.3334 12.05 15.3334 7.99996C15.3334 7.58673 15.2992 7.18148 15.2335 6.78688C15.1924 6.53989 15.1718 6.41639 15.0928 6.29755C15.0287 6.20113 14.9162 6.10577 14.8105 6.05838C14.6803 5.99996 14.5371 5.99996 14.2505 5.99996H10.6669C11.0854 6.55707 11.3334 7.24956 11.3334 7.99996C11.3334 8.65299 11.1456 9.26216 10.821 9.77642L7.81791 15.0098Z" fill="white"/>
<path d="M10 7.99996C10 9.10453 9.10459 9.99996 8.00002 9.99996C6.89545 9.99996 6.00002 9.10453 6.00002 7.99996C6.00002 6.89539 6.89545 5.99996 8.00002 5.99996C9.10459 5.99996 10 6.89539 10 7.99996Z" fill="white"/>
</svg>
<svg width="180" height="131" viewBox="0 0 180 131" fill="none" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
<g filter="url(#filter0_d_40_1547)">
<g clip-path="url(#clip0_40_1547)">
<rect width="180" height="128" rx="6" fill="#FCFCFD"/>
<mask id="path-3-inside-1_40_1547" fill="white">
<path d="M0 0H180V10H0V0Z"/>
</mask>
<path d="M0 0H180V10H0V0Z" fill="#F2F4F7"/>
<circle cx="5.5" cy="5" r="1.5" fill="#D9D9D9"/>
<circle cx="10.5" cy="5" r="1.5" fill="#D9D9D9"/>
<circle cx="15.5" cy="5" r="1.5" fill="#D9D9D9"/>
<g opacity="0.05">
<rect x="58" y="3" width="64" height="4" rx="1.28571" fill="#101828"/>
</g>
<path d="M156.499 3C156.92 3 157.289 3.08357 157.604 3.25071C157.919 3.41785 158.162 3.65337 158.333 3.95726C158.508 4.25736 158.595 4.60494 158.595 5C158.595 5.39126 158.508 5.73884 158.333 6.04274C158.162 6.34663 157.917 6.58215 157.598 6.74929C157.283 6.91643 156.916 7 156.499 7H155V3H156.499Z" fill="white" fill-opacity="0.9"/>
<path d="M156.499 3C156.92 3 157.289 3.08357 157.604 3.25071C157.919 3.41785 158.162 3.65337 158.333 3.95726C158.508 4.25736 158.595 4.60494 158.595 5C158.595 5.39126 158.508 5.73884 158.333 6.04274C158.162 6.34663 157.917 6.58215 157.598 6.74929C157.283 6.91643 156.916 7 156.499 7H155V3H156.499Z" fill="url(#paint0_angular_40_1547)"/>
<path fill-rule="evenodd" clip-rule="evenodd" d="M162.595 3.16669C161.583 3.16669 160.762 3.9875 160.762 5.00002C160.762 6.01254 161.583 6.83335 162.595 6.83335C163.608 6.83335 164.429 6.01254 164.429 5.00002C164.429 3.9875 163.608 3.16669 162.595 3.16669ZM162.38 4.28454C162.445 4.21945 162.445 4.11392 162.38 4.04884C162.315 3.98375 162.209 3.98375 162.144 4.04884L161.644 4.54884C161.579 4.61392 161.579 4.71945 161.644 4.78454L162.144 5.28454C162.209 5.34963 162.315 5.34963 162.38 5.28454C162.445 5.21945 162.445 5.11392 162.38 5.04884L161.998 4.66669L162.38 4.28454ZM163.047 4.7155C162.982 4.65042 162.876 4.65042 162.811 4.7155C162.746 4.78059 162.746 4.88612 162.811 4.9512L163.193 5.33335L162.811 5.7155C162.746 5.78059 162.746 5.88612 162.811 5.9512C162.876 6.01629 162.982 6.01629 163.047 5.9512L163.547 5.4512C163.612 5.38612 163.612 5.28059 163.547 5.2155L163.047 4.7155Z" fill="#D0D5DD"/>
<path d="M168.663 3.19751C168.618 3.1884 168.573 3.1884 168.528 3.19751C168.477 3.20804 168.431 3.23368 168.395 3.25406L168.385 3.2596C168.091 3.42284 167.594 3.69911 167.314 3.85488C167.246 3.8927 167.212 3.91161 167.2 3.9366C167.191 3.95839 167.19 3.98339 167.2 4.00523C167.212 4.03028 167.245 4.04938 167.313 4.08758L168.53 4.77196C168.554 4.78537 168.566 4.79208 168.578 4.79471C168.59 4.79703 168.601 4.79703 168.612 4.79471C168.625 4.79208 168.637 4.78537 168.661 4.77196L169.877 4.08757C169.945 4.04938 169.979 4.03028 169.991 4.00523C170 3.98339 170 3.95839 169.99 3.9366C169.979 3.91161 169.945 3.8927 169.877 3.85488C169.597 3.69911 169.1 3.42284 168.806 3.2596L168.796 3.25406C168.76 3.23368 168.714 3.20804 168.663 3.19751Z" fill="#D0D5DD"/>
<path d="M170.261 4.48169C170.261 4.40697 170.261 4.36961 170.246 4.34779C170.232 4.32876 170.211 4.31641 170.187 4.31378C170.161 4.31076 170.128 4.32912 170.063 4.36582L168.83 5.0592C168.805 5.07312 168.793 5.08008 168.784 5.08992C168.776 5.09863 168.77 5.10893 168.766 5.12015C168.762 5.13282 168.762 5.14702 168.762 5.17541V6.53795C168.762 6.61248 168.762 6.64975 168.778 6.67155C168.791 6.69056 168.812 6.70295 168.836 6.70567C168.862 6.70879 168.895 6.69076 168.96 6.65469C169.238 6.50047 169.742 6.22017 170.039 6.05524L170.05 6.04943C170.088 6.02821 170.137 6.00153 170.174 5.96117C170.206 5.92627 170.23 5.88491 170.245 5.83985C170.262 5.78774 170.262 5.73244 170.262 5.68846L170.262 5.67644C170.262 5.34926 170.262 4.79272 170.261 4.48169Z" fill="#D0D5DD"/>
<path d="M168.231 6.65469C168.296 6.69075 168.328 6.70879 168.355 6.70567C168.378 6.70295 168.399 6.69056 168.413 6.67155C168.429 6.64975 168.429 6.61248 168.429 6.53795V5.17541C168.429 5.14702 168.429 5.13283 168.425 5.12015C168.421 5.10894 168.415 5.09864 168.407 5.08993C168.398 5.08008 168.386 5.07312 168.361 5.0592L167.128 4.36583C167.063 4.32912 167.03 4.31077 167.004 4.31378C166.98 4.31641 166.959 4.32876 166.945 4.3478C166.93 4.36961 166.93 4.40697 166.929 4.4817C166.929 4.79272 166.929 5.34926 166.929 5.67644L166.929 5.68846C166.929 5.73244 166.928 5.78774 166.946 5.83985C166.96 5.88491 166.985 5.92627 167.017 5.96117C167.054 6.00153 167.103 6.02821 167.141 6.04943L167.152 6.05524C167.449 6.22017 167.953 6.50047 168.231 6.65469Z" fill="#D0D5DD"/>
<path fill-rule="evenodd" clip-rule="evenodd" d="M173.679 3.75002C173.679 3.42785 173.94 3.16669 174.262 3.16669C174.584 3.16669 174.845 3.42785 174.845 3.75002V3.83335L174.851 3.83335C174.963 3.83335 175.055 3.83335 175.13 3.8385C175.209 3.84383 175.281 3.85526 175.351 3.8841C175.514 3.95176 175.644 4.08155 175.711 4.2449C175.74 4.31453 175.752 4.38688 175.757 4.4651C175.759 4.5007 175.761 4.54002 175.761 4.58335H175.845C176.168 4.58335 176.429 4.84452 176.429 5.16669C176.429 5.48885 176.168 5.75002 175.845 5.75002H175.762V5.87357C175.762 6.00773 175.762 6.11846 175.755 6.20866C175.747 6.30234 175.731 6.38846 175.689 6.46935C175.626 6.59479 175.524 6.69678 175.398 6.76069C175.317 6.80191 175.231 6.81833 175.137 6.82599C175.047 6.83336 174.937 6.83336 174.802 6.83335H174.679C174.587 6.83335 174.512 6.75873 174.512 6.66669V6.37502C174.512 6.25996 174.419 6.16669 174.304 6.16669C174.189 6.16669 174.095 6.25996 174.095 6.37502V6.66669C174.095 6.75873 174.021 6.83335 173.929 6.83335H173.722C173.588 6.83336 173.477 6.83336 173.387 6.82599C173.293 6.81833 173.207 6.80191 173.126 6.76069C173.001 6.69678 172.899 6.59479 172.835 6.46935C172.794 6.38846 172.777 6.30234 172.77 6.20866C172.762 6.11846 172.762 6.00773 172.762 5.87357L172.762 5.58335C172.762 5.49131 172.837 5.41669 172.929 5.41669H173.179C173.317 5.41669 173.429 5.30476 173.429 5.16669C173.429 5.02862 173.317 4.91669 173.179 4.91669H172.929C172.837 4.91669 172.762 4.84207 172.762 4.75002L172.762 4.74431C172.762 4.63268 172.762 4.54053 172.767 4.4651C172.773 4.38688 172.784 4.31453 172.813 4.2449C172.881 4.08155 173.01 3.95176 173.174 3.8841C173.243 3.85526 173.316 3.84383 173.394 3.8385C173.469 3.83335 173.561 3.83335 173.673 3.83335L173.679 3.83335L173.679 3.75002Z" fill="#D0D5DD"/>
<path d="M180 9.5H0V10.5H180V9.5Z" fill="#EAECF0" mask="url(#path-3-inside-1_40_1547)"/>
<rect width="180" height="118" transform="translate(0 10)" fill="#F2F4F7"/>
<mask id="path-13-inside-2_40_1547" fill="white">
<path d="M0 10H180V22H0V10Z"/>
</mask>
<path d="M0 10H180V22H0V10Z" fill="#FCFCFD"/>
<circle opacity="0.1" cx="10.5" cy="16" r="2.5" fill="#101828"/>
<g opacity="0.1">
<rect x="15" y="15.1429" width="15.4286" height="1.71429" rx="0.857144" fill="#101828"/>
</g>
<g opacity="0.1">
<rect x="130.286" y="15.1429" width="7.42857" height="1.71429" rx="0.857144" fill="#101828"/>
</g>
<g opacity="0.1">
<rect x="141.714" y="15.1429" width="7.42857" height="1.71429" rx="0.857144" fill="#101828"/>
</g>
<g opacity="0.1">
<rect x="153.143" y="15.1429" width="7.42857" height="1.71429" rx="0.857144" fill="#101828"/>
</g>
<g opacity="0.1">
<rect x="164.571" y="15.1429" width="7.42857" height="1.71429" rx="0.857144" fill="#101828"/>
</g>
<path d="M180 21.5H0V22.5H180V21.5Z" fill="black" fill-opacity="0.05" mask="url(#path-13-inside-2_40_1547)"/>
<rect width="67" height="118" transform="translate(113 10)" fill="url(#paint1_radial_40_1547)"/>
<g filter="url(#filter1_dd_40_1547)">
<g clip-path="url(#clip1_40_1547)">
<rect x="118" y="12" width="60" height="86" rx="4" fill="#F2F4F7"/>
<mask id="path-23-inside-3_40_1547" fill="white">
<path d="M118 12H178V21.8578H118V12Z"/>
</mask>
<path d="M118 12H178V21.8578H118V12Z" fill="#F9FAFB"/>
<g opacity="0.12">
<rect x="138.571" y="16.0718" width="18.8571" height="1.71429" rx="0.857144" fill="#101828"/>
</g>
<path d="M178 21.763H118V21.9526H178V21.763Z" fill="#EAECF0" mask="url(#path-23-inside-3_40_1547)"/>
<g clip-path="url(#clip2_40_1547)">
<rect width="60" height="76.1422" transform="translate(118 21.8578)" fill="#F9FAFB"/>
<rect width="60" height="76.1422" transform="translate(118 21.8578)" fill="white"/>
<g clip-path="url(#clip3_40_1547)">
<rect x="120.934" y="25.9667" width="12" height="12" rx="6" fill="#D5F5F6"/>
<path d="M123.434 35.4567H130.434V28.4567H123.434V35.4567Z" fill="url(#pattern0)"/>
<rect x="121.014" y="26.047" width="11.8393" height="11.8393" rx="5.91964" stroke="black" stroke-opacity="0.05" stroke-width="0.160714"/>
<path d="M137.033 25.8578H166.738C169.619 25.8578 171.059 25.8578 172.159 26.4183C173.126 26.9114 173.913 27.6981 174.406 28.6658C174.967 29.766 174.967 31.2061 174.967 34.0864V35.6292C174.967 38.5095 174.967 39.9496 174.406 41.0497C173.913 42.0174 173.126 42.8042 172.159 43.2973C171.059 43.8578 169.619 43.8578 166.738 43.8578H145.262C142.382 43.8578 140.941 43.8578 139.841 43.2973C138.874 42.8042 138.087 42.0174 137.594 41.0497C137.033 39.9496 137.033 38.5095 137.033 35.6292V25.8578Z" fill="#F2F4F7"/>
<g opacity="0.1">
<rect x="142.176" y="29.715" width="27.6479" height="1.71429" rx="0.857144" fill="#101828"/>
</g>
<g opacity="0.1">
<rect x="142.176" y="34.0007" width="27.6479" height="1.71429" rx="0.857144" fill="#101828"/>
</g>
<g opacity="0.1">
<rect x="142.176" y="38.2864" width="23.4286" height="1.71429" rx="0.857144" fill="#101828"/>
</g>
<path d="M134.794 26.3574C134.652 26.1438 134.805 25.8577 135.062 25.8577H137.033V29.7148L134.794 26.3574Z" fill="#F2F4F7"/>
</g>
<rect width="60" height="15.1659" transform="translate(118.066 82.6727)" fill="url(#paint2_linear_40_1547)"/>
<g filter="url(#filter2_b_40_1547)">
<rect x="118.066" y="90.6794" width="59.9337" height="7.58293" fill="white" fill-opacity="0.01"/>
</g>
<rect x="121.242" y="85.8481" width="53.6493" height="8.81516" rx="2.1327" fill="white"/>
<g clip-path="url(#clip4_40_1547)">
<path d="M162.079 90.003V90.2558C162.079 90.7444 161.683 91.1404 161.194 91.1404M160.31 90.003V90.2558C160.31 90.7444 160.706 91.1404 161.194 91.1404M161.194 91.1404V91.5196M160.689 91.5196H161.7M161.194 90.6349C160.985 90.6349 160.815 90.4652 160.815 90.2558V89.3711C160.815 89.1617 160.985 88.9919 161.194 88.9919C161.404 88.9919 161.574 89.1617 161.574 89.3711V90.2558C161.574 90.4652 161.404 90.6349 161.194 90.6349Z" stroke="#667085" stroke-width="0.236967" stroke-linecap="round" stroke-linejoin="round"/>
</g>
<rect x="165.744" y="88.7391" width="0.189573" height="3.03317" fill="black" fill-opacity="0.05"/>
<path d="M172.083 90.3607C172.116 90.2945 172.116 90.2169 172.083 90.1507C172.055 90.0924 172.004 90.0618 171.978 90.0471C171.95 90.0312 171.913 90.0149 171.877 89.9987L169.226 88.8056C169.189 88.789 169.152 88.7724 169.121 88.7617C169.093 88.7518 169.035 88.7338 168.972 88.7515C168.9 88.7714 168.842 88.8239 168.815 88.8932C168.791 88.9546 168.803 89.0134 168.81 89.0428C168.817 89.0747 168.83 89.113 168.843 89.1514L169.099 89.9246C169.12 89.9868 169.13 90.0179 169.15 90.041C169.167 90.0613 169.188 90.077 169.213 90.0867C169.241 90.0977 169.274 90.0977 169.339 90.0977H170.484C170.571 90.0977 170.642 90.1684 170.642 90.2557C170.642 90.3429 170.571 90.4137 170.484 90.4137H169.342C169.277 90.4137 169.244 90.4137 169.216 90.4246C169.192 90.4343 169.17 90.4499 169.153 90.4702C169.134 90.4931 169.123 90.5241 169.103 90.5862L168.844 91.3589C168.831 91.3974 168.818 91.4357 168.811 91.4677C168.804 91.497 168.791 91.556 168.815 91.6175C168.842 91.6869 168.901 91.7396 168.972 91.7596C169.036 91.7774 169.093 91.7593 169.122 91.7494C169.153 91.7387 169.19 91.7221 169.227 91.7054L171.877 90.5127C171.913 90.4964 171.95 90.4802 171.978 90.4643C172.004 90.4496 172.055 90.419 172.083 90.3607Z" fill="#D0D5DD"/>
<rect x="121.242" y="85.8481" width="53.6493" height="8.81516" rx="2.1327" stroke="#EAECF0" stroke-width="0.28436"/>
</g>
</g>
<rect x="118.5" y="12.5" width="59" height="85" rx="3.5" stroke="#B2CCFF"/>
</g>
</g>
<rect x="0.25" y="0.25" width="179.5" height="127.5" rx="5.75" stroke="#EAECF0" stroke-width="0.5"/>
</g>
<defs>
<filter id="filter0_d_40_1547" x="-2" y="-1" width="184" height="132" filterUnits="userSpaceOnUse" color-interpolation-filters="sRGB">
<feFlood flood-opacity="0" result="BackgroundImageFix"/>
<feColorMatrix in="SourceAlpha" type="matrix" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0" result="hardAlpha"/>
<feOffset dy="1"/>
<feGaussianBlur stdDeviation="1"/>
<feColorMatrix type="matrix" values="0 0 0 0 0.0627451 0 0 0 0 0.0941176 0 0 0 0 0.156863 0 0 0 0.05 0"/>
<feBlend mode="normal" in2="BackgroundImageFix" result="effect1_dropShadow_40_1547"/>
<feBlend mode="normal" in="SourceGraphic" in2="effect1_dropShadow_40_1547" result="shape"/>
</filter>
<filter id="filter1_dd_40_1547" x="114.209" y="12" width="67.5829" height="93.5829" filterUnits="userSpaceOnUse" color-interpolation-filters="sRGB">
<feFlood flood-opacity="0" result="BackgroundImageFix"/>
<feColorMatrix in="SourceAlpha" type="matrix" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0" result="hardAlpha"/>
<feMorphology radius="0.758293" operator="erode" in="SourceAlpha" result="effect1_dropShadow_40_1547"/>
<feOffset dy="1.51659"/>
<feGaussianBlur stdDeviation="0.758293"/>
<feColorMatrix type="matrix" values="0 0 0 0 0.0627451 0 0 0 0 0.0941176 0 0 0 0 0.156863 0 0 0 0.03 0"/>
<feBlend mode="normal" in2="BackgroundImageFix" result="effect1_dropShadow_40_1547"/>
<feColorMatrix in="SourceAlpha" type="matrix" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0" result="hardAlpha"/>
<feMorphology radius="0.758293" operator="erode" in="SourceAlpha" result="effect2_dropShadow_40_1547"/>
<feOffset dy="3.79147"/>
<feGaussianBlur stdDeviation="2.27488"/>
<feColorMatrix type="matrix" values="0 0 0 0 0.0627451 0 0 0 0 0.0941176 0 0 0 0 0.156863 0 0 0 0.08 0"/>
<feBlend mode="normal" in2="effect1_dropShadow_40_1547" result="effect2_dropShadow_40_1547"/>
<feBlend mode="normal" in="SourceGraphic" in2="effect2_dropShadow_40_1547" result="shape"/>
</filter>
<pattern id="pattern0" patternContentUnits="objectBoundingBox" width="1" height="1">
<use xlink:href="#image0_40_1547" transform="scale(0.00625)"/>
</pattern>
<filter id="filter2_b_40_1547" x="116.55" y="89.1629" width="62.9668" height="10.6161" filterUnits="userSpaceOnUse" color-interpolation-filters="sRGB">
<feFlood flood-opacity="0" result="BackgroundImageFix"/>
<feGaussianBlur in="BackgroundImageFix" stdDeviation="0.758293"/>
<feComposite in2="SourceAlpha" operator="in" result="effect1_backgroundBlur_40_1547"/>
<feBlend mode="normal" in="SourceGraphic" in2="effect1_backgroundBlur_40_1547" result="shape"/>
</filter>
<radialGradient id="paint0_angular_40_1547" cx="0" cy="0" r="1" gradientUnits="userSpaceOnUse" gradientTransform="translate(156.667 5) rotate(90) scale(2 1.91353)">
<stop stop-color="#001FC2"/>
<stop offset="0.711334" stop-color="#0667F8" stop-opacity="0.2"/>
<stop offset="1" stop-color="#155EEF" stop-opacity="0"/>
</radialGradient>
<radialGradient id="paint1_radial_40_1547" cx="0" cy="0" r="1" gradientUnits="userSpaceOnUse" gradientTransform="translate(64.5) rotate(135.735) scale(55.1589 31.9368)">
<stop stop-color="#101828" stop-opacity="0.1"/>
<stop offset="1" stop-color="#101828" stop-opacity="0"/>
</radialGradient>
<linearGradient id="paint2_linear_40_1547" x1="30" y1="0" x2="30" y2="15.1659" gradientUnits="userSpaceOnUse">
<stop stop-color="white" stop-opacity="0"/>
<stop offset="1" stop-color="white"/>
</linearGradient>
<clipPath id="clip0_40_1547">
<rect width="180" height="128" rx="6" fill="white"/>
</clipPath>
<clipPath id="clip1_40_1547">
<rect x="118" y="12" width="60" height="86" rx="4" fill="white"/>
</clipPath>
<clipPath id="clip2_40_1547">
<rect width="60" height="76.1422" fill="white" transform="translate(118 21.8578)"/>
</clipPath>
<clipPath id="clip3_40_1547">
<rect width="60" height="76.1422" fill="white" transform="translate(118 21.8578)"/>
</clipPath>
<clipPath id="clip4_40_1547">
<rect width="3.03317" height="3.03317" fill="white" transform="translate(159.678 88.7391)"/>
</clipPath>
<image id="image0_40_1547" width="160" height="160" xlink:href=""/>
</defs>
</svg>
......@@ -9,8 +9,6 @@ import Tooltip from '@/app/components/base/tooltip'
import { useAppContext } from '@/context/app-context'
import { IS_CE_EDITION } from '@/config'
// const isDevelopment = process.env.NODE_ENV === 'development'
type Props = {
isShow: boolean
onClose: () => void
......@@ -47,6 +45,9 @@ const OPTION_MAP = {
defer>
</script>`,
},
chromePlugin: {
getContent: (url: string, token: string) => `ChatBot URL: ${url}/chatbot/${token}`,
},
}
const prefixEmbedded = 'appOverview.overview.appInfo.embedded'
......@@ -55,17 +56,25 @@ type Option = keyof typeof OPTION_MAP
type OptionStatus = {
iframe: boolean
scripts: boolean
chromePlugin: boolean
}
const Embedded = ({ isShow, onClose, appBaseUrl, accessToken }: Props) => {
const { t } = useTranslation()
const [option, setOption] = useState<Option>('iframe')
const [isCopied, setIsCopied] = useState<OptionStatus>({ iframe: false, scripts: false })
const [isCopied, setIsCopied] = useState<OptionStatus>({ iframe: false, scripts: false, chromePlugin: false })
const { langeniusVersionInfo } = useAppContext()
const isTestEnv = langeniusVersionInfo.current_env === 'TESTING' || langeniusVersionInfo.current_env === 'DEVELOPMENT'
const onClickCopy = () => {
if (option === 'chromePlugin') {
const splitUrl = OPTION_MAP[option].getContent(appBaseUrl, accessToken).split(': ')
if (splitUrl.length > 1)
copy(splitUrl[1])
}
else {
copy(OPTION_MAP[option].getContent(appBaseUrl, accessToken, isTestEnv))
}
setIsCopied({ ...isCopied, [option]: true })
}
......@@ -78,6 +87,10 @@ const Embedded = ({ isShow, onClose, appBaseUrl, accessToken }: Props) => {
setIsCopied(cache)
}
const navigateToChromeUrl = () => {
window.open('https://chrome.google.com/webstore/detail/dify-chatbot/ceehdapohffmjmkdcifjofadiaoeggaf/related', '_blank')
}
useEffect(() => {
resetCopyStatus()
}, [isShow])
......@@ -93,7 +106,7 @@ const Embedded = ({ isShow, onClose, appBaseUrl, accessToken }: Props) => {
<div className="mb-4 mt-8 text-gray-900 text-[14px] font-medium leading-tight">
{t(`${prefixEmbedded}.explanation`)}
</div>
<div className="flex gap-4 items-center">
<div className="flex items-center justify-between">
{Object.keys(OPTION_MAP).map((v, index) => {
return (
<div
......@@ -111,7 +124,17 @@ const Embedded = ({ isShow, onClose, appBaseUrl, accessToken }: Props) => {
)
})}
</div>
<div className="mt-6 w-full bg-gray-100 rounded-lg flex-col justify-start items-start inline-flex">
{option === 'chromePlugin' && (
<div className="mt-6 w-full">
<div className={cn('gap-2 py-3 justify-center items-center inline-flex w-full rounded-lg',
'bg-primary-600 hover:bg-primary-600/75 hover:shadow-md cursor-pointer text-white hover:shadow-sm flex-shrink-0')}>
<div className={`w-4 h-4 relative ${style.pluginInstallIcon}`}></div>
<div className="text-white text-sm font-medium font-['Inter'] leading-tight" onClick={navigateToChromeUrl}>{t(`${prefixEmbedded}.chromePlugin`)}</div>
</div>
</div>
)}
<div className={cn('w-full bg-gray-100 rounded-lg flex-col justify-start items-start inline-flex',
'mt-6')}>
<div className="self-stretch pl-3 pr-1 py-1 bg-gray-50 rounded-tl-lg rounded-tr-lg border border-black border-opacity-5 justify-start items-center gap-2 inline-flex">
<div className="grow shrink basis-0 text-slate-700 text-[13px] font-medium leading-none">
{t(`${prefixEmbedded}.${option}`)}
......
......@@ -12,3 +12,9 @@
.scriptsIcon {
background-image: url(../assets/scripts-option.svg);
}
.chromePluginIcon {
background-image: url(../assets/chromeplugin-option.svg);
}
.pluginInstallIcon {
background-image: url(../assets/chromeplugin-install.svg);
}
\ No newline at end of file
......@@ -58,6 +58,7 @@ const translation = {
explanation: 'Choose the way to embed chat app to your website',
iframe: 'To add the chat app any where on your website, add this iframe to your html code.',
scripts: 'To add a chat app to the bottom right of your website add this code to your html.',
chromePlugin: 'Install Dify Chatbot Chrome Extension',
copied: 'Copied',
copy: 'Copy',
},
......
......@@ -58,6 +58,7 @@ const translation = {
explanation: '选择一种方式将聊天应用嵌入到你的网站中',
iframe: '将以下 iframe 嵌入到你的网站中的目标位置',
scripts: '将以下代码嵌入到你的网站中',
chromePlugin: '安装 Dify Chrome 浏览器扩展',
copied: '已复制',
copy: '复制',
},
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment