با استفاده از APIهای رایچت میتوانید سیستم یا وبسایت خود را بیشتر با رایچت هماهنگ کنید.
مثلا میتوانید اطلاعات کاربران وب سایت خود را در پنل گفتگوی رایچت نمایش دهید. در ادامه Apiهایی که تا
اکنون منتشر شدهاند را مشاهده میکنید. رایچت همیشه در حال بهروزرسانی هست پس منتظر API های جدید باشید
:).
API سمت کاربر این امکان را به شما میدهد تا ابزارکی که برای کاربر نمایش داده میشود را مدیریت کنید. از آن میتوانید برای مدیریت صفحه چت و همچنین ارسال اطلاعات کاربر به اپلیکیشن رایچت استفاده کنید. (برای مثال میتوانید اطلاعات کاربری که به سایت شما لاگین کرده را به رایچت بفرستید تا در اپلیکیشن نمایش داده بشه و بعداً در آرشیو بهش دسترسی داشته باشید).
نکته: تمامی توابع و رویدادهایی که در ادامه توضیح داده خواهند شد باید طبق دستورالعمل سمت راست (داخل رویداد raychat_ready) نوشته شوند.
window.addEventListener('raychat_ready', function (ets) {
// function or event
});
با استفاده از این تابع می توانید اطلاعات کاربری که به وب سایت شما لاگین کرده را به رایچت ارسال کنید.
Field | Type | Description |
string | ایمیل کاربر لاگین شده | |
name | string | نام کاربر لاگین شده |
about | string | درباره ی کاربر لاگین شده |
phone | string | تلفن کاربر لاگین شده |
avatar | string | عکس کاربر لاگین شده |
updateOnce | boolean | در هر بار فراخوانی این تابع اطلاعات کاربر به روز شود یا خیر |
window.Raychat.setUser({ email: 'hamet@raychat.io', name: 'Hamet Gholizadeh', about: 'about me :)', phone: '09123456789', avatar: 'http://app.raychat.io/hamed.png', updateOnce: true });
با استفاده از این تابع می توانید اطلاعات بازدیدکننده ای که در حال حاضر در وب سایت هست را دریافت کنید.
مقادیر برگشتی :
key | value Type | Description |
id | string | آیدی کاربر |
name | string | نام کاربر |
string | ایمیل | |
avatar | string | عکس کاربر |
online | string | وضعیت کاربر |
createdAt | Date | تاریخ ایجاد کاربر |
metadata | object | دادههای بیشتر |
browser | Object | اطلاعات مرورگر کاربر |
phone | string | شماره تلفن کاربر |
about | string | اطلاعات کاربر |
var user = window.Raychat.getUser(); //example user object { id: '5992bc6d9e737c900e3058d3', name: 'Saman Baboli', email: 'cto@raychat.io', avatar: 'http://app.raychat.io/saman.png', online: true, createdAt: 2017-08-15T09:18:37.904Z, metadata: { userId: "2", // String createdAt: "2018-09-29", // Date totalPaid: 200000, // Number isActive: true // Boolean }, browser : { "name" : "Chrome", "ver" : "60.0.3112.90", "os" : "Windows", "mobile" : false }, phone: '09354140661', about: 'hello :)' }
با این تابع میتوانید کاربرانی که در سیستم شما وارد پنل کاربری میشوند را بارگزاری کنید و مکالمات آنان را به صورت دائمی و پایدار نگه داری کنید; زمانی که کاربر با موفقیت بارگزاری شد رویداد raychat_new_user_loaded اجرا میشود
نکته : برای به دست آوردن ای دی کاربر میتوانید از تابع getUser استفاده کنید
نکته : حتما توجه داشته باشید که با لود کردن کاربر جدید، اطلاعات کاربر فعلی (مکالمات و بقیه موارد) در صورتی که ای دی کاربر را در دیتابیسی ذخیره نداشته باشید برای همیشه غیرقابل دسترس خواهد بود
Field | Type | Description |
userId | string | ای دی کاربر |
window.Raychat.loadUser(userId);
باعث پاک شدن تمامی اطلاعات کاربر از مرورگر شده و در صورتی که کاربر دوباره اقدام به بازدید از سایت نمود به عنوان کاربر جدید شناخته میشود
نکته : برای اعمال تغییرات، بعد از صدا زدن این تابع، مرورگر کاربر از نو بارگذاری شود
نکته : در صورتی که ای دی کاربر را قبل از صدا زدن این تابع در دیتابیسی ذخیره نکنید، لود کردن دوباره این کاربر غیر ممکن خواهد بود
window.Raychat.unloadUser();
ارسال پیام از طریق ابزارک رایچت به کاربر
نکته : این پیام صرفا در سمت کاربر نمایش داده میشود و اپراتور قادر به دیدن این پیام نمی باشد و همچنین مکالمه محسوب نمیشود و با رفرش کردن صفحه پاک میشود.
window.Raychat.sendOfflineMessage('سلام وقت بخیر');
با استفاده از این تابع میتوانید ابزارک چت را باز کنید.
window.Raychat.open();
با استفاده از این تابع می توانید ابزارک چت را ببندید.
winow.Raychat.close();
.در صورتی که ابزارک چت باز باشه هنگام فراخوانی این تابع، ابزارک بسته خواهد شد و یا بصورت بر عکس
window.Raychat.toggle();
شخصی سازی حالت انیمیشن آیکون ابزارک چت. این کار باعث میشود که توجه کاربر بیشتر به ابزارک جلب شده و در نتیجه احتمال اینکه کاربر سر صحبت را باز کند بیشتر خواهد شد
Animations |
bounce |
wobble |
tada |
shake |
rubberBand |
swing |
jello |
rotateIn |
window.Raychat.animate('tada');
با استفاده از این تابع میتوان تشخیص داد که ابزار چک باز است یا خیر
Result | Des |
true | باز است |
false | بسته است |
window.Raychat.isWidgetOpen();
با استفاده از این رویداد ها می توانید نسبت به رفتار کاربر عکس العمل نشان دهید. به طور مثال وقتی کاربر ایمیلش رو در قسمت با خبر شو ثبت کرد یه پیامی بهش نشون بدید. این قسمت هم همیشه در حال بروزرسانی هست و با توجه به نیاز کاربران و درخواست ها امکانات و رویداد های جدید اضافه خواهد شد.
زمانی که اطلاعات کاربر بروز میشود این رویداد اجرا میشود به طور مثال زمانی که کاربر ایمیلش را در قسمت با خبرشو ثبت می کند.
window.Raychat.on('raychat_user_profile_updated', function (user) { });
زمانی که کاربر ابزارک چت را باز کند این رویداد اجرا میشود.
window.Raychat.on('open', function (s) { });
زمانی که کاربر ابزارک چت را ببندد این رویداد اجرا میشود.
window.Raychat.on('close', function (s) { });
این رویداد زمانی اجرا میشود که شما با استفاده از متد loadUser کاربری را بارگذاری کنید
window.Raychat.on('raychat_new_user_loaded', function (s) { });
با استفاده از این API میتوانید در رایچت ثبت نام کنید. این قسمت بیشتر برای سیستم های سایت ساز و فروشگاه
ساز
که قصد دارند به صورت اتوماتیک برای هر کاربری که در سیستمشون ثبت نام میکنه یک اکانت رایچت ایجاد کنند و کد
را نیز در سایت قرار دهند کاربرد دارد.
* برای استفاده از این قسمت ابتدا یک اپ از طریق این
لینک ایجاد کنید و کلید API خود را دریافت
کنید.
Route | Method |
https://app.raychat.io/api/site | POST |
مقادیر ارسالی
Field | Type | Description |
apiKey | String | کلیدی که هنگام ایجاد اپلیکیشن در پنل دریافت کردید |
site | String | آدرس سایتی که میخواهید در رایچت ثبت کنید |
siteTitle | String | عنوان سایتی که میخواهید در رایچت ثبت کنید |
String | ایمیل مدیر وب سایت | |
password | String | رمز عبور |
name | String | نام مدیر وب سایت |
phone | String | تلفن مدیر وب سایت |
مقادیر برگشتی
Field | Type | Description |
message | String | پیام برگشتی از سرور |
status | Int | وضعیت |
code | String | کد رایچت برای قرار دادن در وب سایت |
user | Object | اطلاعات کاربر ایجاد شده |
token | string | توکن وبسایت |
url | string | آدرس پنل مدیریت رایچت |
webAppUrl | string | آدرس اپلیکیشن تحت وب رایچت |
* پاسخ بصورت JSON برگشت داده میشود.
* در صورت بروز خطا، علت در پاسخ توضیح داده خواهد شد.
* وضعیت برابر 1 به معنی موفقیت آمیز بودن ثبت نام است.
request.post({ url:'https://app.raychat.io/api/site', form: { apiKey:'Your Api Key', site:'https://example.com', siteTitle:' Example Title', email:'test@example.com', password: 'Password', name:'Hamed Gholizadeh', phone:'09000000000' } }, function(err,httpResponse,body){ /* ... */ });