? My...">
,需要通过父级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)) {
window.postMessage({
type: 'SHOPS_CONTACT_TRACK',
data: {
phone: nodeText,
},
}, '*');
_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)) {
window.postMessage({
type: 'SHOPS_CONTACT_TRACK',
data: {
phone: nodeText,
},
}, '*');
_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)) {
window.postMessage({
type: 'SHOPS_CONTACT_TRACK',
data: {
email: 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')) {
window.postMessage({
type: 'SHOPS_CONTACT_TRACK',
data: {
email: content,
},
}, '*');
_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)) {
window.postMessage({
type: 'SHOPS_CONTACT_TRACK',
data: {
email: 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)) {
window.postMessage({
type: 'SHOPS_CONTACT_TRACK',
data: {
email: 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);
}
});
})();
Chcesz nieco innego i ciekawego sposobu zaprojektowania swojego wymarzonego domu? Czy kiedykolwiek myślałeś o budowie unikalnej przestrzeni życiowej wykonanej z kontenery transportowe ? My w CDPH dumimy się tworzeniem wyjątkowych i nowatorskich plany zabudowy domów kontenerowych dla wszystkich typów życia – począwszy od opłacalnej przestrzeni dla rodziny, po idealne miejsce na odpoczynek. Niezależnie od Twoich osobistych preferencji czy stylu życia, czy jesteś człowiekiem serca natury, miłośnikiem minimalistycznej prostoty, czy też skłaniasz się ku nowoczesnemu stylowi życia – mamy najpopularniejsze projekty układów wnętrz domów kontenerowych, które możesz tworzyć i dostosowywać według własnych potrzeb, a my pokażemy Ci, jak to zrobić i uzyskać dokładnie to, czego chcesz. Podczas projektowania domu kontenerowego możliwości są nieograniczone. Od przytulnych małych domków po duże domy dla rodziny – istnieje plan i rozmiar odpowiedni właśnie dla Ciebie. Jeśli jesteś osobą, która potrzebuje dużo swobody w życiu, to dom kontenerowy z jednym sypialnią dom z kontenera transportowego to właśnie to, czego potrzebujesz, ponieważ jest to jeden z najprostszych układów wnętrza kontenera dostępnym na rynku. Ten kompaktowy, energooszczędny projekt obejmuje salon w układzie otwartym, funkcjonalną kuchnię, łazienkę oraz sypialnię — starannie upakowane w jednym kontenerze transportowym. Jeśli kochasz naturę, nasz ekologiczny dom kontenerowy to doskonałe źródło inspiracji. Projekt cechują duże okna oraz świetliki, które zalewają wnętrze naturalnym światłem, tworząc jasną i przestronną przestrzeń do życia. Przy budynku znajduje się bardzo duża tarasa na zewnątrz, idealna do relaksu w bliskości natury. Czy mógłbyś przywyknąć do budzenia się pod dźwięk śpiewu ptaków i promieni słońca przebijających się przez korony drzew? W CDPH mamy plany zabudowy domów kontenerowych różnych kształtów i rozmiarów, aby spełnić każde wymaganie i dopasować się do każdego budżetu. Niezależnie od tego, czy szukasz małego domu, czy większego domu o bardziej tradycyjnym stylu, posiadamy projekt odpowiedni dla Ciebie! Nasi specjaliści pracują z Tobą, by znaleźć rozwiązanie najlepiej odpowiadające Twojej rodzinie. Od układu wnętrza, planowania przestrzeni po końcowe detale wykończenia wnętrza – pomożemy Ci zaprojektować przestrzeń kontenerową, która odzwierciedli Twój gust i osobowość. Dom z dwoma kondygnacjami może być uroczym domeczkiem lub luksusowym projektem w stylu europejskim. Z kilkoma sypialniami, łazienkami i pomieszczeniami dziennymi, ten układ jest idealny dla każdego, kto potrzebuje więcej przestrzeni, by się rozprostować i zrelaksować. Wykorzystaj drugą kondygnację jako prywatne schronienie właściciela albo jako strefę gościnną, dostosowując ją do swojego stylu życia. Projekt domu kontenerowego – Plany pięter – Ty, jeśli kiedykolwiek marzyłeś o zaprojektowaniu własnego domu, teraz możesz spełnić ten sen dzięki projektowi domu kontenerowego . Dzięki CDPH możesz projektować według własnych upodobań i zbudować dom, który będzie w 100% unikalny we wszystkich możliwych aspektach na dłuższą metę. Niezależnie od tego, czy jesteś architektem chcącym zaprojektować własny niestandardowy dom kontenerowy, czy właścicielem firmy planującym rozbudowę marki, z przyjemnością pomożemy Ci zaprojektować dom z kontenerów, o którym marzyłeś. Zacznij tutaj, przeglądając naszą ofertę plany domów kontenerowych lub skontaktuj się z nami, aby stworzyć indywidualny projekt, który pomoże Ci pracować w domu, utrzymując komfort życia w nietypowej przestrzeni tak wysoki, jak to możliwe. Gdy już wybierzesz układ pomieszczeń, wspólnie będziemy pracować nad spersonalizowaniem układu i wykończenia, by Twój dom był naprawdę wyjątkowy. Możesz dostosować swój dom kontenerowy aż do szczegółów – od materiałów i kolorów po armaturę i urządzenia, które zamontujesz. Dom z jabłkowym wnętrzem, wyjątkowy kształt, piękny wygląd – sprawia, że Twój dom staje się bardziej spersonalizowany. Ofertę stanowią różnorodne style i kolory, które można dobrać do indywidualnych upodobań – od prostych, nowoczesnych po tradycyjne. Firma Beijing Chengdong specjalizuje się w projektowaniu mieszkań kontenerowych i może dostosować je do Twoich potrzeb. Aby spełnić Twoje osobiste oczekiwania i preferencje, możesz zamówić spersonalizowany projekt domu, układ pomieszczeń, instalacje wodno-kanalizacyjne i elektryczne itp., tworząc w ten sposób idealny, wyjątkowy dom. Instalacje elektryczne i wodno-kanalizacyjne zaprojektowaliśmy i wykonaliśmy już przed rozpoczęciem budowy, dzięki czemu unikamy czasochłonnego przekładania rurociągów i przewodów po zakończeniu wykończenia wnętrz, co zwiększa skuteczność i jakość prac wykończeniowych. Możesz wybrać spośród szerokiej gamy rozwiązań projektowych wnętrz dla salonu, jadalni, sypialni, kuchni oraz wielu innych pomieszczeń. Jakościowe życie zaczyna się od Domu Jabłkowego! Dom Jabłkowy to wyjątkowa przestrzeń! Dom kontenerowy – uczynij swoje życie bezpieczniejszym i bardziej komfortowym! Wszystkie elementy konstrukcyjne są wytwarzane w fabryce metodą prefabrykacji. Poprzez dobranie odpowiednich wymiarów, konfiguracji oraz projektu możesz szybko zbudować swoje przestrzenie mieszkalne. Na podstawie wymagań klienta oraz jego preferencji różne moduły można łączyć w celu stworzenia różnych układów pomieszczeń, w tym kuchni, planów położenia pomieszczeń w domu kontenerowym oraz sypialni. Najważniejsze jest to, że nasz dom kontenerowy charakteryzuje się prostotą montażu i demontażu, stabilną konstrukcją oraz doskonałymi właściwościami, takimi jak odporność na wodę, wilgoć oraz ogień; proces instalacji jest prosty i łatwy w obsłudze, a nie wymaga żadnej specjalistycznej wiedzy technicznej. Budowane przez nas domy kontenerowe są dostosowywane do indywidualnych potrzeb klienta – niezależnie od tego, czy chodzi o prywatny dom mieszkalny, tymczasowe biura, magazyny czy inne zastosowania. Nadszedł czas, by zakupić pokój kontenerowy – otrzymasz przy tym korzystną cenę oraz rzetelną obsługę klienta. Ulepsz swoje życie, kupując pokój kontenerowy! Dom prefabrykowany ma specyficzną konstrukcję i dobre plany pomieszczeń w domach kontenerowych, zapewniające bezpieczeństwo. Projekt modułowy oraz łatwa transportowalność i instalacja umożliwiają dostosowanie domu do indywidualnych preferencji dotyczących różnych stylów i rodzajów pomieszczeń. Wszystkie elementy są prefabrykowane i łatwe w montażu, nie wymagają one specjalistycznej wiedzy ani umiejętności. Niezależnie od tego, czy dom prefabrykowany ma służyć jako biuro, mieszkanie, magazyn czy inne zastosowanie – z pewnością spełni Twoje oczekiwania. Elegancka forma, wyraziste linie oraz możliwość personalizacji zgodnie z Twoimi preferencjami pozwalają stworzyć wyjątkową przestrzeń życiową. Najlepsze jednak jest to, że domy prefabrykowane nie wymagają spawania na miejscu, a my dodatkowo dostarczamy instrukcje montażu, dzięki czemu proces instalacji staje się prostszy i szybszy. Zadbaj o lepsze życie z domami prefabrykowanymi Chengdong. Domy prefabrykowane Chengdong. Dom składany ma otwarty projekt, który można dostosować zgodnie z Twoimi wymaganiami, aby zwiększyć wydajność i uczynić przestrzeń mieszkalną bezpieczniejszą, stabilniejszą i bezpieczną. Pomieszczenia można łączyć w sposób spełniający różne potrzeby, dzięki czemu możesz swobodnie przebywać w komfortowej przestrzeni wszędzie i w dowolnym momencie. Plany zabudowy domów kontenerowych! Wysyłka i pakowanie są niezwykle szybkie. Zatrudniamy wykwalifikowany zespół zajmujący się pakowaniem zgodnie z Twoimi wymaganiami, abyś otrzymał najlepszy produkt. Podczas dostawy będziemy również monitorować każdy etap procesu, by zapewnić bezpieczne dotarcie produktów do miejsca docelowego. Najważniejsze jest to, że pokój łatwo się składa i montuje bez konieczności stosowania planów zabudowy domów kontenerowych. Oferujemy również instrukcje montażu, które sprawią, że instalacja będzie szybsza i bardziej efektywna. Gdy będziesz postępować zgodnie z krokami opisanymi w instrukcji, uda Ci się ukończyć montaż swojego składanego domu. CDPH produkuję i sprzedaje różne rodzaje modułowych domów, prefabrykowanych domów i willowych domów. Szeroki zakres produktów pozwala nam dostarczyć odpowiednie rozwiązanie dla każdego obozu inżynieryjnego.Plany zabudowy domów kontenerowych
Plany zabudowy domów kontenerowych

Plany zabudowy domów kontenerowych dla każdego stylu życia

Odkryj plany zabudowy domów kontenerowych

Zaprojektuj swój wymarzony dom z planami zabudowy kontenerów
Why choose CDPH
Plany zabudowy domów kontenerowych?
Współczesny Styl domek apple
Dobre Sprzedaże dom kontenerowy
Nowe przybycie prefabrykowanego domu
Wysoka jakość składanego domu
Powiązane kategorie produktów
Nie możesz znaleźć tego, czego szukasz?
Poproś o wycenę teraz
Skontaktuj się z naszymi konsultantami w sprawie dostępności innych produktów.Skontaktuj się z nami
27+ Lat Doświadczenia
Budowa Obozu Inżynieryjnego