(function () { var take = function () { document.addEventListener("DOMContentLoaded", () => { //console.log("DOMContentLoaded") const chatform = localStorage.getItem("chatform") }) window.addEventListener("chatform_initialized", (event) => { /* var launchBtn = document.createElement("img"); var btnUrl = "https://res.cloudinary.com/dts6mbw86/image/upload/f_auto/v1709101462/aqur/mtg/chatbot_btn_fgz5fl.png" launchBtn.src = btnUrl; launchBtn.classList.add("launchBtn"); launchBtn.classList.add("chatformBtn"); document.body.appendChild(launchBtn); launchBtn.style.position = "fixed"; launchBtn.style.bottom = "61px"; */ }) function render(template, data) { //console.log("render",template,data) return template.replace(/{{(.*?)}}/g, (match) => { return data[match.split(/{{|}}/).filter(Boolean)[0].trim()] }) } function activateChatformWidget() { if (!chatform_initialized) { console.log("chatbot is not ready yet") return } const w = document.querySelector('.chatform_widget'); w.classList.toggle("close"); w.classList.toggle("normal"); if (w.classList.contains("close")) { document.body.classList.remove("chat_open"); } else { document.body.classList.add("chat_open"); } } var chatform_initialized = false const pid = "kst"; const target = "production"; const mode = "release"; const device = JSON.parse("false".toLowerCase()) ? "mobile" : "pc"; const launch = "click"; const client = "https://form.aqur.com/"; let REF = new URL(window.location); let userChatbot = REF.searchParams.get('usechatbot') if (userChatbot == "no") { console.log("no chatbot") return } REF.searchParams.append('pid', pid); REF.searchParams.append('mode', mode); REF.searchParams.append('target', target); REF.searchParams.append('hash', "86aec7ea-7be5-4c4f-bec0-e9a6cbb0240c"); REF.searchParams.append('browser', "undefined"); REF.searchParams.append('device', device); REF.searchParams.append('os', "undefined"); REF.searchParams.append('ua', "Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)"); REF.searchParams.append('ip', "3.16.218.216"); REF.searchParams.append('ref', REF.href); REF.searchParams.append('path', REF.pathname); //for UI REF.searchParams.append('CLIENT_ID', 'PR'); REF.searchParams.append('BASE_URL', 'https://pr.aqur.com'); REF.searchParams.append('HEADER_LABEL', 'お申し込みはこちらから!'); REF.searchParams.append('HEADER_BG_COLOR', '#fff'); REF.searchParams.append('HEADER_LABEL_COLOR', '#fff'); REF.searchParams.append('SHOW_TIMER', 'false'); REF.searchParams.append('ICON_PATH', 'https://res.cloudinary.com/dts6mbw86/image/upload/v1713319985/aqur/common/icon_azvikf.png'); let utm_content = REF.searchParams.get('utm_content') if (utm_content) { let agent = utm_content.substring(utm_content.lastIndexOf("_") + 1, utm_content.length) if (agent) { REF.searchParams.append('agent', agent); } } let search = REF.search.slice(1) //console.log(search) let widget = render( '' + '', { device: device, client: client, search: (search) ? "&" + search : "", } ); const body = document.body; if (body) { var filterId; const chatbotProgressBar = "
" body.insertAdjacentHTML('beforeend', chatbotProgressBar); body.classList.add(device) body.insertAdjacentHTML('beforeend', widget); const target = document.querySelector('.chatform_widget'); const observer = new MutationObserver((mutations) => { mutations.forEach((mutation) => { if (!target.classList.contains("close")) { var contentWindow = target.contentWindow; if (contentWindow) { contentWindow.postMessage("chat_open", "*"); contentWindow.postMessage( { type: "filterIdChanged", data: filterId }, "*"); } } }); }); const config = { characterData: true, attributes: true, subtree: true }; observer.observe(target, config); } let creationComplete = function () { if (device == "pc") { var resize = () => { let zoom_level = window.devicePixelRatio || window.screen.availWidth / document.documentElement.clientWidth * 100; const targets = document.querySelectorAll('body,.chatform_widget'); if (zoom_level >= 3) { targets[0].classList.add("mobile") targets[0].classList.remove("pc") targets[1].classList.add("mobile") targets[1].classList.remove("pc") } else { targets[0].classList.add("pc") targets[0].classList.remove("mobile") targets[1].classList.add("pc") targets[1].classList.remove("mobile") } } resize() window.addEventListener("resize", () => { resize() }) } document.addEventListener('click', (event) => { if (event.target && event.target.closest('.chatformBtn ') || event.target.classList.contains("chatformBtn") || event.target.id == "chatform_widget_cancelbtn" ) { activateChatformWidget() filterId = event.target.closest(".chatformBtn").dataset.filterid } }); document.dispatchEvent(new CustomEvent("chatform_widget_creation_complete")); }; setTimeout(creationComplete, 0); window.addEventListener("message", (event) => { if (event.data.event == "chatform_gotoCart") { //console.log("chatform_gotoCart") var clickOnAddToCartContentAsset = document.querySelector("#formLPSection .clickOnAddToCartContentAsset"); activateChatformWidget(); clickOnAddToCartContentAsset.click() } if (event.data.event == "chatform_selectProduct") { //console.log("chatform_selectProduct") var t = event.data.data.data; var arr = t.data; selectProduct(arr) } if (event.data.event == "chatform_savedata") { } if (event.data.event == "chatform_sent") { //activateChatformWidget(); var project = event.data.project; var arr = event.data.project.data var chatform = { pid: project.pid, sid: project.sid, uuId: project.uuId, id: arr[arr.length - 1].id } localStorage.setItem('chatform', JSON.stringify(chatform)); //console.log("arr",arr) bindForm(arr) //location.href = params.targetURL; } if (event.data.event == "chatform_close") { //console.log("chatform_close") activateChatformWidget(); } if (event.data.event == "chatform_evalScript") { window.eval(event.data.script) } if (event.data.event == "chatform_insertTag") { body.insertAdjacentHTML("beforeend", event.data.tag); event.data.scripts.forEach((item) => { eval(item.textContent) }) } if (event.data.event == "chatform_start") { console.log(event.data.uuId) } if (event.data.event == "chatform_initialized") { console.log("chatform_initialized") document.getElementById("chatbotProgressBar").style.width = "100%"; var opacity = function () { document.getElementById("chatbotProgressBar").style.opacity = "0"; }; setTimeout(opacity, 1000); chatform_initialized = true; if (launch == "auto") { activateChatformWidget(); } window.dispatchEvent(new CustomEvent("chatform_initialized")); const iframe = document.querySelector('.chatform_widget'); var contentWindow = iframe.contentWindow; if (contentWindow) { var shareProductList = [] var mobileCheck = document.querySelector("body").classList.contains("mobile"); if (mobileCheck) { var li = document.querySelectorAll(".repOrderFormProductRow"); li.forEach((item) => { var value = item.querySelector("[value=rbnSelectProduct]").value var name = item.querySelector(".itemlist").textContent var price = item.querySelector('.itemprice').textContent var quantity = item.querySelector('#ctl00_cphMain_repOrderRowForm_ctl00_OrderSuryo_ddlNum').value var subTotal = item.querySelector('#ctl00_cphMain_repOrderRowForm_ctl00_lblSubTotal').textContent var obj = { value: value, label: name, price: price, quantity: quantity, subTotal: subTotal, checked: false, name: "orderSelect", supplement: "", } shareProductList.push(obj) }) } else { var li = document.querySelectorAll(".repOrderFormProductRow"); li.forEach((item) => { var value = item.querySelector("[value=rbnSelectProduct]").value var name = item.querySelector(".itemlist").textContent var price = item.querySelector('.itemprice').textContent var quantity = item.querySelector('.itemcount').value var subTotal = item.querySelector('.itemsubtitle').textContent var obj = { value: value, label: name, price: price, quantity: quantity, subTotal: subTotal, checked: false, name: "orderSelect", supplement: "", } shareProductList.push(obj) }) } contentWindow.postMessage( { type: "shareProductList", data: shareProductList }, "*"); } } }, false) } setTimeout(take, 0); async function bindForm(d) { //console.log("d=>", d) const fillInput = (selector, value) => { return new Promise((resolve, reject) => { // Create an InputEvent for the change event let inputEvent = new Event('input', { bubbles: true, cancelable: true }); let changeEvent = new Event('change', { bubbles: true, cancelable: true }); const inputElement = document.querySelector(selector); if (inputElement) { inputElement.value = value; inputElement.dispatchEvent(inputEvent); inputElement.dispatchEvent(changeEvent); resolve(`Input with selector "${selector}" filled and events dispatched`); } else { reject(`Element with selector "${selector}" not found.`); } }); }; const chooseRadioButton = (radioSelector, value) => { return new Promise((resolve, reject) => { // Select the radio button with the specified value const radioButton = document.querySelector(`${radioSelector}[value='${value}']`); if (radioButton) { radioButton.checked = true; // Create and dispatch a change event let changeEvent = new Event('change', { bubbles: true, cancelable: true }); radioButton.dispatchEvent(changeEvent); resolve(`Radio button with selector '${radioSelector}' and value '${value}' selected and event dispatched.`); } else { reject(new Error(`Radio button with selector '${radioSelector}' and value '${value}' not found.`)); } }); }; const chooseSelectBox = (selectBoxSelector, value, useOptionVal = true) => { return new Promise((resolve, reject) => { // Select the option based on the value or label let option; if (useOptionVal) { option = document.querySelector(`${selectBoxSelector} option[value='${value}']`); } else { option = Array.from(document.querySelectorAll(`${selectBoxSelector} option`)) .find(opt => opt.label === value); } const selectElement = document.querySelector(selectBoxSelector); if (option && selectElement) { option.selected = true; // Create and dispatch a change event const changeEvent = new Event('change', { bubbles: true, cancelable: true }); selectElement.dispatchEvent(changeEvent); resolve(`Select box with selector '${selectBoxSelector}' set to option value '${value}' and event dispatched.`); } else { reject(new Error(`Select box with selector '${selectBoxSelector}' and option value '${value}' not found.`)); } }); }; try { await fillInput('input#order_billing_address_attributes_name1', findValueByCustomId(d, 'lastname', "") + findValueByCustomId(d, 'firstname', "")) await fillInput('input#order_billing_address_attributes_kana1', findValueByCustomId(d, 'furigana_firstname', "") + findValueByCustomId(d, 'furigana_mei', "")) await fillInput('input#order_billing_address_attributes_zip01', findValueByCustomId(d, 'zip', "")) // wait for auto fill await new Promise(resolve => setTimeout(resolve, 1000)); await chooseSelectBox('select#order_billing_address_attributes_prefecture_name', findValueByCustomId(d, "area", ""), false) await fillInput('input#order_billing_address_attributes_addr01', findValueByCustomId(d, 'city', "")) await fillInput('input#order_billing_address_attributes_addr02', findValueByCustomId(d, 'street', "") + findValueByCustomId(d, "building", "")) await fillInput('input#form-validation-field-0', findValueByCustomId(d, "phone", "").replace(/-/g, '')) await fillInput('input#email', findValue(d, "email")) await fillInput('input#password', findValue(d, "Password")) let genderM = findOptionLabel(d, "6004b77_1") let genderF = findOptionLabel(d, "6004b77_2") let genderV = 0 if (/女性/.test(genderM)) { genderV = 2 } else if (/男性/.test(genderF)) { genderV = 1 } //console.log("genderV", genderV) await new Promise(resolve => setTimeout(resolve, 500)); await chooseSelectBox('select[name="order[customer_attributes][sex_id]"]', genderV) await chooseSelectBox('select[name="order[customer_attributes][birth(1i)]"]', findValue(d, "Year")) var Month = findValue(d, "Month"); await chooseSelectBox('select[name="order[customer_attributes][birth(2i)]"]', Month) let Day = findValue(d, "Day"); await chooseSelectBox('select[name="order[customer_attributes][birth(3i)]"]', Day) let OterhDeli = findOption(d, "shipping_address_id"); await chooseSelectBox('select#shipping_address_id', OterhDeli) if (/new/.test(OterhDeli)) { await fillInput('input#order_shipping_address_attributes_name1', findValueByCustomId(d, 'lastname', "") + findValueByCustomId(d, 'firstname', "")) await fillInput('input#order_shipping_address_attributes_kana1', findValueByCustomId(d, 'furigana_firstname', "") + findValueByCustomId(d, 'furigana_mei', "")) await fillInput('input#order_shipping_address_attributes_zip01', findValueByCustomId(d, 'zip', 'otherDeli')) // wait for auto fill await new Promise(resolve => setTimeout(resolve, 1000)); await chooseSelectBox('select#order_shipping_address_attributes_prefecture_name', findValueByCustomId(d, "area", 'otherDeli'), false) await fillInput('input#order_shipping_address_attributes_addr01', findValueByCustomId(d, 'city', 'otherDeli')) await fillInput('input#order_shipping_address_attributes_addr02', findValueByCustomId(d, 'street', 'otherDeli') + findValueByCustomId(d, "building", 'otherDeli')) await fillInput('input[name="order[shipping_address_attributes][tel01]"]', findValueByCustomId(d, "phone", "").replace(/-/g, '')) } let Payment = findOption(d, "payment_method_id"); await chooseSelectBox('select#payment_method_id', Payment) if (Payment == "71") { // credit card try { await fillInput('input#input-cc-number', findValue(d, "dwfrm_billing_paymentMethods_creditCard_number")) } catch (error) { await new Promise(resolve => setTimeout(resolve, 1000)); await fillInput('input#input-cc-number', findValue(d, "dwfrm_billing_paymentMethods_creditCard_number")) } let ccMonth = findValue(d, "dwfrm_billing_paymentMethods_creditCard_month") await new Promise(resolve => setTimeout(resolve, 200)); await chooseSelectBox('select#input-cc-month', ccMonth) let ccYear = findValue(d, "dwfrm_billing_paymentMethods_creditCard_year") await new Promise(resolve => setTimeout(resolve, 200)); await chooseSelectBox('select#input-cc-year', ccYear.slice(-2)) await new Promise(resolve => setTimeout(resolve, 200)); await fillInput('input#input-cc-name', findValue(d, "CardHolderName")) await new Promise(resolve => setTimeout(resolve, 200)); await fillInput('input#input-cc-cvv', findValue(d, "dwfrm_billing_paymentMethods_creditCard_cvn")) } } catch (error) { console.log(error) } setTimeout(() => { //console.log("work click") const Agreement = document.querySelector('input#agree').checked; if (!Agreement) { //console.log("work click 1") document.querySelector('input#agree').click() } setTimeout(() => { if(localStorage.getItem("chatform")){ const target = document.querySelector('.chatform_widget'); var param={ event: "chatform_BeforeSubmit", } target.contentWindow.postMessage(param, "*"); } const w = document.querySelector('.chatform_widget'); w.classList.toggle("close"); w.classList.toggle("@wmode"); if(w.classList.contains("close")){ document.body.classList.remove("chat_open"); }else{ document.body.classList.add("chat_open"); } const ClickSubmit = document.querySelector('input[type="submit"]#submit'); document.querySelector('body').click() if (ClickSubmit) { ClickSubmit.click() } }, 200); }, 100); } var findOptionByCustomId = (d, n) => { let value = "Undefind"; var rtn = value; for (var i = 0; i < d.length; i++) { var item = d[i]; if (item.itemName == n) { //console.log(item.customId,n) if (item.options) { //console.log(item.options) item.options.forEach(function (v) { if (v.checked) { rtn = v.label } }) } } } return rtn } var findValueByCustomId = (d, n, c) => { let value = "Undefind"; var rtn = value; for (var i = 0; i < d.length; i++) { var item = d[i]; if (item.customId == c) { //console.log(item.customId,c) if (item.values) { //console.log(item.options) item.values.forEach(function (v) { if (v.name == n) { rtn = v.value } }) } } } return rtn } function bindText(d, t, n) { //console.log(t) const el = document.querySelector(t); if (el) { el.value = findValue(d, n); el.dispatchEvent(new Event('change')); } } function bindSelect(d, t, n) { //console.log(t) bindText(d, t, n) } function bindRadio(d, t, n) { //console.log(t) var value = findOption(d, n); var str = t + "[value='" + value + "']" const el = document.querySelector(str); if (el) { el.click() } } function bindCheckbox(d, t, n) { //console.log(t) var values = findOptions(d, n); values.forEach(function (v) { var str = t + "[value='" + v + "']" const el = document.querySelector(str); if (el) { el.checked = true el.dispatchEvent(new Event('change')); } }) } //radio return single value function findValue(d, n) { //console.log(d,n) let value = "Undefind"; rtn = value; for (var i = 0; i < d.length; i++) { var item = d[i]; if (item.values) { item.values.forEach(function (v) { //console.log(v.name, n) var reg = new RegExp(n) if (reg.test(v.name)) { //console.log(n, v.name, reg.test(v.name)) rtn = v.value } }) } } //console.log(n,rtn) return rtn } //radio return single value function findOption(d, n) { let value = "Undefind"; rtn = value; for (var i = 0; i < d.length; i++) { var item = d[i]; if (item.options) { item.options.forEach(function (v) { var reg = new RegExp(n) if (reg.test(v.name) && v.checked) { rtn = v.value } }) } } return rtn } //checkbox return array function findOptions(d, n) { rtn = []; for (var i = 0; i < d.length; i++) { var item = d[i]; if (item.options) { item.options.forEach(function (v) { var reg = new RegExp(n) if (reg.test(v.name) && v.checked) { rtn.push(v.value) } }) } } return rtn } function findOptionLabel(d, n) { //console.log(n) let value = "Undefind"; rtn = value; for (var i = 0; i < d.length; i++) { var item = d[i]; //console.log(item) if (item.options) { item.options.forEach(function (v) { if (v.name == n && v.checked) { //console.log(v) rtn = v.label } }) } } return rtn } function getFormatPhone($INPUT, $STRICT) { $STRICT = $STRICT || false; // 市外局番のグループ定義 // データは http://www.soumu.go.jp/main_sosiki/joho_tsusin/top/tel_number/number_shitei.html より入手後、整形 var group = { 5: { "01267": 1, "01372": 1, "01374": 1, "01377": 1, "01392": 1, "01397": 1, "01398": 1, "01456": 1, "01457": 1, "01466": 1, "01547": 1, "01558": 1, "01564": 1, "01586": 1, "01587": 1, "01632": 1, "01634": 1, "01635": 1, "01648": 1, "01654": 1, "01655": 1, "01656": 1, "01658": 1, "04992": 1, "04994": 1, "04996": 1, "04998": 1, "05769": 1, "05979": 1, "07468": 1, "08387": 1, "08388": 1, "08396": 1, "08477": 1, "08512": 1, "08514": 1, "09496": 1, "09802": 1, "09912": 1, "09913": 1, "09969": 1, }, 4: { "0123": 2, "0124": 2, "0125": 2, "0126": 2, "0133": 2, "0134": 2, "0135": 2, "0136": 2, "0137": 2, "0138": 2, "0139": 2, "0142": 2, "0143": 2, "0144": 2, "0145": 2, "0146": 2, "0152": 2, "0153": 2, "0154": 2, "0155": 2, "0156": 2, "0157": 2, "0158": 2, "0162": 2, "0163": 2, "0164": 2, "0165": 2, "0166": 2, "0167": 2, "0172": 2, "0173": 2, "0174": 2, "0175": 2, "0176": 2, "0178": 2, "0179": 2, "0182": 2, "0183": 2, "0184": 2, "0185": 2, "0186": 2, "0187": 2, "0191": 2, "0192": 2, "0193": 2, "0194": 2, "0195": 2, "0197": 2, "0198": 2, "0220": 2, "0223": 2, "0224": 2, "0225": 2, "0226": 2, "0228": 2, "0229": 2, "0233": 2, "0234": 2, "0235": 2, "0237": 2, "0238": 2, "0240": 2, "0241": 2, "0242": 2, "0243": 2, "0244": 2, "0246": 2, "0247": 2, "0248": 2, "0250": 2, "0254": 2, "0255": 2, "0256": 2, "0257": 2, "0258": 2, "0259": 2, "0260": 2, "0261": 2, "0263": 2, "0264": 2, "0265": 2, "0266": 2, "0267": 2, "0268": 2, "0269": 2, "0270": 2, "0274": 2, "0276": 2, "0277": 2, "0278": 2, "0279": 2, "0280": 2, "0282": 2, "0283": 2, "0284": 2, "0285": 2, "0287": 2, "0288": 2, "0289": 2, "0291": 2, "0293": 2, "0294": 2, "0295": 2, "0296": 2, "0297": 2, "0299": 2, "0422": 2, "0428": 2, "0436": 2, "0438": 2, "0439": 2, "0460": 2, "0463": 2, "0465": 2, "0466": 2, "0467": 2, "0470": 2, "0475": 2, "0476": 2, "0478": 2, "0479": 2, "0480": 2, "0493": 2, "0494": 2, "0495": 2, "0531": 2, "0532": 2, "0533": 2, "0536": 2, "0537": 2, "0538": 2, "0539": 2, "0544": 2, "0545": 2, "0547": 2, "0548": 2, "0550": 2, "0551": 2, "0553": 2, "0554": 2, "0555": 2, "0556": 2, "0557": 2, "0558": 2, "0561": 2, "0562": 2, "0563": 2, "0564": 2, "0565": 2, "0566": 2, "0567": 2, "0568": 2, "0569": 2, "0572": 2, "0573": 2, "0574": 2, "0575": 2, "0576": 2, "0577": 2, "0578": 2, "0581": 2, "0584": 2, "0585": 2, "0586": 2, "0587": 2, "0594": 2, "0595": 2, "0596": 2, "0597": 2, "0598": 2, "0599": 2, "0721": 2, "0725": 2, "0735": 2, "0736": 2, "0737": 2, "0738": 2, "0739": 2, "0740": 2, "0742": 2, "0743": 2, "0744": 2, "0745": 2, "0746": 2, "0747": 2, "0748": 2, "0749": 2, "0761": 2, "0763": 2, "0765": 2, "0766": 2, "0767": 2, "0768": 2, "0770": 2, "0771": 2, "0772": 2, "0773": 2, "0774": 2, "0776": 2, "0778": 2, "0779": 2, "0790": 2, "0791": 2, "0794": 2, "0795": 2, "0796": 2, "0797": 2, "0798": 2, "0799": 2, "0820": 2, "0823": 2, "0824": 2, "0826": 2, "0827": 2, "0829": 2, "0833": 2, "0834": 2, "0835": 2, "0836": 2, "0837": 2, "0838": 2, "0845": 2, "0846": 2, "0847": 2, "0848": 2, "0852": 2, "0853": 2, "0854": 2, "0855": 2, "0856": 2, "0857": 2, "0858": 2, "0859": 2, "0863": 2, "0865": 2, "0866": 2, "0867": 2, "0868": 2, "0869": 2, "0875": 2, "0877": 2, "0879": 2, "0880": 2, "0883": 2, "0884": 2, "0885": 2, "0887": 2, "0889": 2, "0892": 2, "0893": 2, "0894": 2, "0895": 2, "0896": 2, "0897": 2, "0898": 2, "0920": 2, "0930": 2, "0940": 2, "0942": 2, "0943": 2, "0944": 2, "0946": 2, "0947": 2, "0948": 2, "0949": 2, "0950": 2, "0952": 2, "0954": 2, "0955": 2, "0956": 2, "0957": 2, "0959": 2, "0964": 2, "0965": 2, "0966": 2, "0967": 2, "0968": 2, "0969": 2, "0972": 2, "0973": 2, "0974": 2, "0977": 2, "0978": 2, "0979": 2, "0980": 2, "0982": 2, "0983": 2, "0984": 2, "0985": 2, "0986": 2, "0987": 2, "0993": 2, "0994": 2, "0995": 2, "0996": 2, "0997": 2, "0180": 3, "0570": 3, "0800": 3, "0990": 3, "0120": 3, }, 3: { "011": 3, "015": 3, "017": 3, "018": 3, "019": 3, "022": 3, "023": 3, "024": 3, "025": 3, "026": 3, "027": 3, "028": 3, "029": 3, "042": 3, "043": 3, "044": 3, "045": 3, "046": 3, "047": 3, "048": 3, "049": 3, "052": 3, "053": 3, "054": 3, "055": 3, "058": 3, "059": 3, "072": 3, "073": 3, "075": 3, "076": 3, "077": 3, "078": 3, "079": 3, "082": 3, "083": 3, "084": 3, "086": 3, "087": 3, "088": 3, "089": 3, "092": 3, "093": 3, "095": 3, "096": 3, "097": 3, "098": 3, "099": 3, "050": 4, "020": $STRICT ? 3 : 4, "070": $STRICT ? 3 : 4, "080": $STRICT ? 3 : 4, "090": $STRICT ? 3 : 4, }, 2: { "03": 4, "04": 4, "06": 4, } }; // 市外局番の桁数を取得して降順に並べ替える var code = []; for (num in group) { code.push(num * 1); } code.sort(function ($a, $b) { return ($b - $a); }); // 入力文字から数字以外を削除してnumber変数に格納する var number = String($INPUT).replace(/[0-9]/g, function ($s) { return String.fromCharCode($s.charCodeAt(0) - 65248); }).replace(/\D/g, ""); // 電話番号が10~11桁じゃなかったらfalseを返して終了する if (number.length < 10 || number.length > 11) { return false; } // 市外局番がどのグループに属するか確認していく for (var i = 0, n = code.length; i < n; i++) { var leng = code[i]; var area = number.substring(0, leng); var city = group[leng][area]; // 一致する市外局番を見付けたら整形して整形後の電話番号を返す if (city) { var first = area; var middle = number.substring(first.length, first.length + city); var last = number.substring(first.length + city, number.length); return [first, middle, last] /*return area + "-" + number.substring(leng, leng+city) + (number.substring(leng + city) !== "" ? "-" + number.substring(leng + city) : "");*/ } } }; }())