이 필요하신가요?...">
,需要通过父级DOM结构来判断
*/
var trackActionPhone = function (node) {
var nodeInnerText = node.innerText || '';
if (!limitRegLength(nodeInnerText)) return;
var nodeText = trimText(nodeInnerText);
if (nodeText.length < 5 || nodeText.length > 20) return false;
var type =
arguments.length > 1 && arguments[1] !== undefined
? arguments[1]
: 'click';
var str = trimText(node.href || node.innerHTML || '');
if (phoneReg.test(str) && numUseReg.test(str)) {
_paq.push(['trackEvent', type, 'phone', nodeText]);
return true;
}
/** 排查父级嵌套非标签场景,并且对dom的正则校验做一个性能兜底,通过控制innerText的长度,来确保正则的性能 */
var fatherText = trimText(node.parentNode.innerText || '');
if (fatherText.length < 5 || fatherText.length > 20) return false;
var fatherDom = trimText(node.parentNode.innerHTML || '');
if (phoneReg.test(fatherDom) && numUseReg.test(fatherDom)) {
_paq.push(['trackEvent', type, 'phone', nodeText]);
return true;
}
return false;
};
window.addEventListener('click', function (e) {
var node = e.target;
/** 社媒点击 */
var appName = '';
var getAppAriaLabel =
node.ariaLabel || node.parentNode.ariaLabel || '';
if (mediaList.includes(getAppAriaLabel.toLowerCase())) {
appName = getAppAriaLabel;
}
if (
!appName &&
node.nodeName &&
node.nodeName.toLowerCase() === 'a'
) {
appName = getMediaName(node.href) || getMediaName(node.alt);
}
if (
!appName &&
node.nodeName &&
node.nodeName.toLowerCase() === 'img'
) {
appName = getMediaName(node.alt) || getMediaName(node.src);
}
if (
!appName &&
node.nodeName &&
node.nodeName.toLowerCase() === 'i'
) {
appName = getMediaName(node.className);
}
if (appName) {
_paq.push(['trackEvent', 'click', 'contactApp', appName]);
return;
}
/** 联系方式点击 */
if (trackActionPhone(node, 'click')) return;
if (node.nodeName && node.nodeName.toLowerCase() === 'a') {
var val = node.href;
if (!limitRegLength(val)) return;
if (emailReg.test(val)) {
_paq.push(['trackEvent', 'click', 'email', val]);
return;
}
}
if (node.nodeName && node.nodeName.toLowerCase() === 'i') {
var val = node.className;
var content = node.parentNode.href || '';
if (val.includes('email')) {
_paq.push(['trackEvent', 'click', 'email', content]);
return;
}
}
var nodeChildList = node.childNodes;
for (var i = 0; i < nodeChildList.length; i++) {
if (nodeChildList[i].nodeType !== 3) continue;
var val = nodeChildList[i].textContent.replace(/\s?:?/g, '');
if (!limitRegLength(val)) continue;
if (emailReg.test(val)) {
_paq.push(['trackEvent', 'click', 'email', val]);
return;
}
}
trackNumberData(node);
});
window.addEventListener('copy', function (e) {
if (trackActionPhone(e.target, 'copy')) return;
var text = e.target.textContent;
if (!text) return;
var val = text.replace(/\s:?/g, '');
if (!limitRegLength(val)) return;
if (emailReg.test(val)) {
_paq.push(['trackEvent', 'copy', 'email', val]);
return;
}
trackNumberData(e.target);
});
}
trackContactInit();
/**
* 基于custom_inquiry_form.js 以及 form.js 对于询盘表单提交的实现,来反推询盘表单的input标签触发,用来收集意向客户
* 1. 缓存的KEY:TRACK_INPUT_ID_MTM_00;
* 2. 缓存策略 - lockTrackInput:单个页面内,10分钟内,不重复上报
*/
function trackActionInput() {
const CACHE_KEY = 'TRACK_INPUT_ID_MTM_00';
const pathName = window.location.hostname + window.location.pathname;
var lockTrackInput = function () {
try {
const lastCacheData = localStorage.getItem(CACHE_KEY);
if (!lastCacheData) return false;
const cacheData = JSON.parse(lastCacheData);
const cacheTime = cacheData[pathName];
if (!cacheTime) return false;
return Date.now() - cacheTime < 1000 * 60 * 10; // 10分钟内,不重复上报
} catch (error) {
console.error('lockTrackInput Error', error);
return false;
}
};
var setInputTrackId = function () {
try {
const curCacheData = localStorage.getItem(CACHE_KEY);
if (curCacheData) {
const cacheData = JSON.parse(curCacheData);
cacheData[pathName] = Date.now();
localStorage.setItem(CACHE_KEY, JSON.stringify(cacheData));
return;
}
const cacheData = {
[pathName]: Date.now(),
};
localStorage.setItem(CACHE_KEY, JSON.stringify(cacheData));
} catch (error) {
console.error('setInputTrackId Error', error);
}
};
var getInputDom = function (initDom) {
var ele = initDom;
while (ele) {
/**
* isWebSiteForm 是站点的表单
* isChatWindowForm 是聊天窗口的表单
*/
/** 旧模板表单 */
var isWebSiteForm = !!(
/crm-form/i.test(ele.className) && ele.querySelector('form')
);
/** 1:新模板自定义表单、2:Get a Quote 弹框表单 */
var isWebSiteFormNew = !!(
/inquiry/i.test(ele.className) && ele.querySelector('form')
);
if (isWebSiteForm || isWebSiteFormNew) {
_paq.push(['trackEvent', 'formInquiry', 'formInput', 'page']);
setInputTrackId();
return;
}
/** Mkt会话触达-聊天弹框的表单输入: MKT由于是iframe嵌入,所以MKT的上报,会单独写到MKT-form代码上 */
var isInquiryChatForm = !!(
/comp-form/i.test(ele.className) && ele.querySelector('form')
);
if (isInquiryChatForm) {
_paq.push(['trackEvent', 'formInquiry', 'formInput', 'chat']);
setInputTrackId();
return;
}
/** 向上查找父节点 */
ele = ele.parentNode;
}
};
function initInputListener() {
var inputUseDebounce = function (fn, delay) {
var timer = null;
var that = this;
return function () {
var args = Array.prototype.slice.call(arguments);
if (timer) clearTimeout(timer);
timer = setTimeout(function () {
fn.apply(that, args);
}, delay);
};
};
var optimizeGetInputDom = inputUseDebounce(getInputDom, 300);
window.addEventListener('input', function (e) {
/** 如果已经上报过,则不再上报 */
if (lockTrackInput()) return;
optimizeGetInputDom(e.target);
});
}
try {
initInputListener();
} catch (error) {
console.log('initInputListener Error', error);
}
}
trackActionInput();
}
/** 第三方消息上报:目前主要是针对全点托管会话;在msgCollect/index.js中调试,访问test.html */
function thirdMsgCollect() {
/** 先检测是否是stayReal托管:如果stayReal脚本都没有,那么说明当前站点未开启stayReal会话托管 */
const scriptList = Array.prototype.slice.call(
document.querySelectorAll('script'),
);
const checkStayReal = () =>
!!scriptList.find((s) => s.src.includes('stayreal.xiaoman.cn'));
if (!checkStayReal()) return;
/** 缓存当前消息队列的最后一条消息id */
const CACHE_KEY = 'CACHE_KEY_MONITOR';
const setCache = (msgIndex) => {
/** 对缓存KEY进行base64转码处理 */
const cacheMsgIndex = btoa(msgIndex);
localStorage.setItem(CACHE_KEY, cacheMsgIndex);
};
const getCache = () => {
const cacheMsgIndex = localStorage.getItem(CACHE_KEY);
if (cacheMsgIndex) return Number(atob(cacheMsgIndex));
return -1;
};
/** 拉取最新msg列表 */
const pullMsgList = () => {
const msgEleList = Array.prototype.slice.call(
document.querySelectorAll('#chat-list li'),
);
const msgIds = [];
const msgMap = msgEleList.reduce((acc, item) => {
const sendTime = item
.querySelector('.message-data-time')
.textContent.trim();
const sendContent = item.querySelector('.message').textContent.trim();
/** msg带有class:other-message的是访客消息,my-message的是客服消息 */
const isOtherMessage = item
.querySelector('.message')
.classList.contains('other-message');
const msgId = item.querySelector('.message').getAttribute('id');
const msgItemData = {
msgId,
user: isOtherMessage ? 'visitor' : 'official',
time: sendTime,
content: sendContent,
};
msgIds.push(msgId);
acc[msgId] = msgItemData;
return acc;
}, {});
return {
ids: msgIds,
dataMap: msgMap,
};
};
/** 加密并上传消息数据 */
let ENCRYPT_KEY = 'de29f1aab63ab033';
let ENCRYPT_IV = 'b8d2badf875e76ac';
const baseUrl = 'https://cms.xiaoman.cn';
// var getEncryptConfig = function () {
// const url = baseUrl + '/shop-api/innerApi/getKeyIv'
// $.get(
// url,
// function (result) {
// console.log('result', result)
// if (Number(result.code) === 0 && result.data.key && result.data.iv) {
// ENCRYPT_KEY = result.data.key
// ENCRYPT_IV = result.data.iv
// uploadMsgData()
// } else {
// /** 如果获取失败,则重试 */
// setTimeout(() => {
// getEncryptConfig()
// }, 1000)
// }
// },
// 'json'
// )
// }
// getEncryptConfig()
const encryptMsg = function (msgData) {
const enc = new TextEncoder();
// 转字节
const keyBytes = enc.encode(ENCRYPT_KEY);
const ivBytes = enc.encode(ENCRYPT_IV);
const plainBytes = enc.encode(msgData);
// 导入密钥并加密
return crypto.subtle
.importKey('raw', keyBytes, { name: 'AES-CBC' }, false, ['encrypt'])
.then(function (cryptoKey) {
return crypto.subtle.encrypt(
{ name: 'AES-CBC', iv: ivBytes },
cryptoKey,
plainBytes,
);
})
.then(function (encryptedBuffer) {
// 转 base64 返回
return btoa(
String.fromCharCode(...new Uint8Array(encryptedBuffer)),
);
})
.catch((err) => {
return Promise.reject(err);
});
};
let uploadFlag = false;
const uploadMsgData = function () {
if (uploadFlag) return;
uploadFlag = true;
const { ids, dataMap } = pullMsgList();
let cacheMsgIndex = getCache();
const msgLen = ids.length;
if (!msgLen) {
// 消息DOM未挂载 || 消息DOM已挂载,但是消息列表为空
uploadFlag = false;
return;
}
if (msgLen - 1 < cacheMsgIndex) {
/** 针对站点挂后台一段时间,消息列表会自动塞入重复消息,导致消息有重复,刷新后又重置回正常消息列表,所以这里需要更新锚点下标 */
cacheMsgIndex = msgLen - 1;
setCache(cacheMsgIndex);
uploadFlag = false;
return;
}
if (msgLen - 1 === cacheMsgIndex) {
// 缓存的最后一次发送的消息ID是最后一条(说明当前消息均已经上报),则不跳过本地上报
uploadFlag = false;
return;
}
const currentMsgIds = ids.slice(cacheMsgIndex + 1, msgLen);
const currentMsgData = currentMsgIds.map((id) => dataMap[id]);
const mtmId = window.matomo_site_id_cookie_key || ''; // 获取mtm会话id
const msgBody = {
mtmId,
curl: window.location.href,
msgList: currentMsgData,
};
const msgBodyStr = JSON.stringify(msgBody);
encryptMsg(msgBodyStr)
.then(function (encryptedMsg) {
console.log('encryptedMsg:', encryptedMsg, msgBodyStr);
const url = baseUrl + '/shop-api/External/ListenSiteActiveStatus';
$.ajax({
type: 'POST',
url,
data: JSON.stringify({ d_v: encryptedMsg }),
contentType: 'application/json',
success: function (result) {
if (Number(result.code) === 0) {
// 更新消息队列
setCache(msgLen - 1);
}
uploadFlag = false;
},
error: function (err) {
console.error(err, '请求异常');
uploadFlag = false;
},
});
})
.catch((err) => {
console.error(err, '数据加密失败');
uploadFlag = false;
});
};
/** 监控chat-list的DOM变更 */
const initChatListObserver = () => {
// 需要监听的 DOM 节点
const target = document.getElementById('chat-list');
if (!target) return;
// 回调函数
const callback = function (mutationsList, observer) {
for (const mutation of mutationsList) {
console.log('mutation', mutation);
if (mutation.type === 'childList') {
uploadMsgData();
}
}
};
// 配置
const config = {
childList: true, // 监听子节点的增删
subtree: true, // 是否也监听后代节点
};
// 创建 observer
const observer = new MutationObserver(callback);
// 开始监听
observer.observe(target, config);
};
let testCount = 30;
let itv = null;
const checkChatDom = () => !!document.querySelector('#vc-model');
const initTalkCheck = () => {
itv = setTimeout(() => {
console.log('checkChatDom', checkChatDom(), testCount);
if (!checkChatDom() && testCount > 0) {
testCount--;
initTalkCheck();
return;
}
clearTimeout(itv);
uploadMsgData();
initChatListObserver();
}, 1500);
};
initTalkCheck();
}
try {
gtmTrack();
thirdMsgCollect();
console.log('inserted gtm code');
} catch (error) {
console.error('gtmTrack Error', error);
}
});
})();
귀하의 의료기관 또는 병원에 고품질의 예민한 폐기물 용기를 보유하고 있습니다 이 필요하신가요? 지금 XIEHE MEDICAL에 문의하세요! 다양한 제품을 보유하고 있습니다. 바늘류 전용 용기 제약 회사, 클리닉, 의료 종사자 및 응급 대응 인력의 다양한 요구를 충족하기 위해 설계되었습니다. 당사의 친환경 첨기물 수거함은 누출이 없어 안전한 수집과 환경 친화적인 폐기를 보장합니다. 따라서 소량의 개별 용기 필요 여부에 관계없이 도매용으로 대량 구매가 필요하든, 초경쟁력 있는 가격으로 다양한 크기의 제품을 제공합니다. 모든 니즈에 맞는 최첨단 샤프스 박스 사용이 간편한 기능을 갖춘 디자인을 확인해 보세요. 이 제품은 반드시 XIEHE MEDICAL의 제품이어야 합니다. XIEHE MEDICAL은 병원 및 의료 치료 센터에서 폐기물 처리의 중요성을 잘 알고 있습니다. 그래서 우리는 의료 분야의 높은 기준을 충족하는 고품질의 제품을 생산합니다. 예민한 폐기물 용기를 보유하고 있습니다 당사의 수거함은 견고하여 컨테이너 카트 없이도 사용할 수 있으며, 첨기물 폐기물 처리를 위한 신뢰할 수 있는 솔루션입니다. 폐기물 관리를 향상시키고, 환자와 직원을 보호하며, 환경에 미치는 영향을 최소화하도록 설계되었습니다. 의약품 유통업체 및 치료 시설은 폐기 관련 법규를 준수하고 고객과 직원을 보호하기 위해 안전하고 확실한 방법이 필요합니다. 예민한 물체 xIEHE MEDICAL은 또한 다양한 종류의 예민한 폐기물 용기를 보유하고 있습니다 특정 요구 사항에 맞춘 이러한 산업을 위한 솔루션. 클리닉이나 약국에서 사용할 소형 휴대용 용기나 제약 공장에서 필요한 대용량 용기가 필요하든, 귀하의 요구를 충족시킬 수 있는 다양한 제품을 보유하고 있습니다. XIEHE MEDICAL의 특수 요구사항에 맞게 설계된 안전하고 효율적인 바늘류 폐기 솔루션에 의지하십시오. 환경을 걱정하는 구매자를 위해 XIEHE MEDICAL은 환경 친화적인 바늘 처리용 용기 누수 방지 기능을 갖춘 제품입니다. 당사의 제품은 지구 환경을 고려하여 친환경 재활용 소재로 제조되었습니다. 안전한 바늘 처리용 용기 솔루션: 누수 방지 실링으로 유출을 방지하고 견고하게 밀봉되는 마감 처리로 위험한 바늘류 폐기물을 안전하게 담아내도록 설계된 XIEHE MEDICAL의 바늘류 전용 용기를 선택하세요. 환경 기준에 부합하는 바늘류 폐기물 처리를 위해 우리 제품의 환경 친화적인 바늘류 전용 용기 를 선택하여 환경 친화적인 접근 방식을 실현하세요. 구매를 원하시나요 바늘류 전용 용기 도매로 구매하시겠습니까? XIEHE MEDICAL이 도와드립니다! 저렴한 가격의 경제적인 대량 바늘류 전용 용기 대량 구매를 원하시나요 바늘류 전용 용기 할인된 가격으로 제공되는 프로젝트. 수백 개에서 수천 개가 필요하든 바늘류 전용 용기 , 귀하의 예산과 공급 요구에 맞는 경쟁력 있는 가격 정책을 제공해 드립니다. 대량 구매 시 품질을 저렴하게 확보하려면 Value Pack OHIEHE MEDICAL을 신뢰하십시오. 바늘류 전용 용기 , 고품질 제품으로 비용을 절감하세요! 내구성 있고 기능적인 예민한 폐기물 용기를 보유하고 있습니다 의료 분야의 산업 표준을 충족하거나 초과하는 제품… IncrementalLite 샤프스 카운터탑 컨테이너 혁신적인 sharps 폐기 환자 및 의료 종사자의 안전, 바늘 찔림 사고 예방 및 안전한 샤프스 폐기 규정 준수를 위한 솔루션. 협화의료기기기구(Xiehe Medical Apparatus Instruments)는 전 세계적 마케팅 및 판매를 전문으로 합니다. 지난 10년간 파트너사들의 지지와 노력 덕분에 현재 전 세계에 30개 이상의 유통업체를 보유하고 있으며, 제품은 120여 개국 이상에 공급되고 있습니다. 샤프스 쓰레기통(예리한 물체용 폐기함)의 수집 분야에 집중하여 유통업체 및 시스템 통합업체와의 장기적인 협력 관계를 구축하고, 함께 미래를 설계하고 구현해 나가고자 합니다. Xiehe Medical Apparatus Instruments는 고품질의 의료 장비를 제조하며, 특별 서비스도 제공합니다. ISO13485 품질 관리 시스템을 엄격히 준수하고 있으며, 모든 제품은 TUV, CE, FDA 등 많은 인증을 받았습니다. 날카로운 물질을 수집하는 데 사용되는 폐기물 용기를 생산하는 전문 직원들이 있어 고객 요구를 신속하게 만족시키고, 제품의 신뢰성과 안전성을 보장하며 서비스를 제공합니다. 구급용 스텔러, 접이식 스텔러, 병원 가구 또는 장례 용품이 필요하더라도 Xiehe Medical Equipment는 해결책을 가지고 있습니다. 헤허 의료기기(Huhe Medical Equipment)는 고객 만족을 최우선으로 삼으며, 품질과 신뢰성을 바탕으로 고객의 요구를 충족시키기 위해 노력합니다. 직원들의 열정과 협업 기술을 바탕으로, 고객에게 개인화되고 신뢰할 수 있는 서비스를 제공할 수 있습니다. 당사의 목표는 날카로운 물체용 폐기함(sharps bin)을 포함한 제품군을 통해 고객과 지속적이고 안정적이며 협력적인 파트너십을 구축하고, 최고 품질의 제품 및 서비스를 제공하는 것입니다. 시에허 의료기기·기구(Xiehe Medical Apparatus & Instruments)는 창의적인 연구개발(R&D)에 지속적으로 매진하며, 경쟁력 있는 판매 포인트를 갖춘 제품을 제공하는 데 전념하고 있습니다. 특허 및 지적재산권이 확보된 제품으로는 날카로운 물체용 폐기함(sharps bin), 응급처치 용품, 병원용 가구, 장례용 제품 등이 있습니다. 당사 제품은 현재의 시장 트렌드에 부합하도록 설계되어 고객의 다양한 니즈를 충족시키며, 국내외 고객 모두로부터 높은 평가를 받고 있습니다.샤프스 바이너리 수집
의약품 회사와 클리닉을 위한 안전한 폐기 솔루션을 원하는 분들을 위한 다양한 예민한 폐기물 보관함 컬렉션

환경을 중시하는 구매자를 위한 누수 방지 설계의 친환경 예민한 폐기물 보관함

대량 구매를 위한 저렴한 가격의 대량 공급용 예민한 폐기물 보관함

의료 전문가 및 응급 대응 인력을 위한 사용자 친화적 기능이 탑재된 혁신적인 예민한 폐기물 보관함
Why choose XIEHE MEDICAL
샤프스 바이너리 수집?
글로벌 마케팅 네트워크와 안정적인 파트너십
고품질의 제품과 특화된 서비스
고객 중심의 빠른 애프터 서비스 및 기술 지원
혁신적인 연구 개발 및 제품 판매 포인트
관련 제품 카테고리
족한 물체 수거
원하는 내용을 찾지 못하셨나요?
지금 견적 요청하기
더 많은 이용 가능한 제품은 전문가와 상담해 주세요.문의하기