const getScript = document.querySelector(".serachSection") const letterLen = getScript.dataset.letter const ablank = getScript.dataset.ablank const siteUrl = getScript.dataset.url let errorMsg = document.querySelector('.errorMsg') let wordCount = document.querySelector('.wordCount') let main = document.querySelector('.main') console.log(letterLen); const params = new URLSearchParams(window.location.search) let serachValue = params.get('search').toLowerCase() let prefixValue = params.get('prefix') let containsValue = params.get('contains') let suffixValue = params.get('suffix') let exculdeValue = params.get('exculde') let includeValue = params.get('include') let lengthValue = params.get('length') let dictonary = params.get('dictionary') let sortingFilter = document.querySelector("#select_dropDown"); // Scrabble Point Counts const ScrabbleScore = () => { let twl06_sowpods = { a: 1, e: 1, i: 1, o: 1, u: 1, l: 1, n: 1, r: 1, s: 1, t: 1, d: 2, g: 2, b: 3, c: 3, m: 3, p: 3, f: 4, h: 4, v: 4, w: 4, y: 4, k: 5, j: 8, x: 8, q: 10, z: 10, } let wwfScore = { a: 1, b: 4, c: 4, d: 2, e: 1, f: 4, g: 3, h: 3, i: 1, j: 10, k: 5, l: 2, m: 4, n: 2, o: 1, p: 4, q: 10, r: 1, s: 1, t: 1, u: 2, v: 5, w: 4, x: 8, y: 3, z: 10, } if (dictonary === 'wwf') { return wwfScore } else { return twl06_sowpods } } let tab_link_wrapper = document.querySelector('.tab_link_wrapper') tab_link_wrapper.style.display = "none" let home_page_search_result = document.querySelector("#home_page_search_result") let homePageSearchResult = `/?search=${serachValue}&dictionary=Dictionary&prefix=&contains=&suffix=&exculde=&inculde=&length=`; txtBox.value = serachValue if (ablank) { if (!serachValue.includes("?")) { if (serachValue.length <= letterLen || serachValue.length >= letterLen) { serachValue = serachValue + '?' txtBox.value = serachValue } } } if (serachValue) { letterCloseButton.style.display = "block" } var theSelect = document.getElementById('select_dropDown') const sortup = document.querySelector(".sortup-icon") let bool = false sortup.addEventListener("click", () => { if (bool) { theSelect.size = 0 bool = false theSelect.style.display = "none" } else { bool = true theSelect.size = 3 theSelect.style.display = "block" } }) document.querySelector('.select_dropDown2').value = dictonary const getDiff = (text1, text2) => { var diffRange = [] var currentRange = undefined for (var i = 0; i < text1.length; i++) { if (text1[i] != text2[i]) { if (currentRange == undefined) { currentRange = [i] } } if (currentRange != undefined && text1[i] == text2[i]) { currentRange.push(i) diffRange.push(currentRange) currentRange = undefined } } if (currentRange != undefined) { currentRange.push(i) diffRange.push(currentRange) } return diffRange } let featureContainer = document.querySelector("#featureContainer") let howContainer = document.querySelector("#howContainer") let faqsContainer = document.querySelector("#faqsContainer") let infographicsContainer = document.querySelector("#infographicsContainer") let authorsLists = document.querySelector(".authors-list") const getData = async (serachValue) => { try { document.querySelector(".main-header").style.background = "#fff" document.querySelector(".heading-h2").style.display = "none" errorMsg.innerHTML = "" wordCount.innerHTML = "" if (featureContainer) { featureContainer.remove() } if (howContainer) { howContainer.remove() } if (faqsContainer) { faqsContainer.remove() } if (infographicsContainer) { infographicsContainer.remove() } if (authorsLists) { authorsLists.remove() } home_page_search_result.innerHTML = "" let selectedDictionary = document.querySelector('.select_dropDown2').value main.innerHTML = `
`; if (serachValue) { response = await fetch(`/.netlify/functions/getWords?name=${serachValue}&selecteddictionary=${selectedDictionary}`); } else { response = await fetch(`/.netlify/functions/getData?&selecteddictionary=${selectedDictionary}`) } const data = await response.json() main.innerHTML = '' x_with_letters(data) } catch (error) { console.log(error) } } // calling function getData(serachValue.toLowerCase()) let quesMark = '' quesMark = "?" function logSubmit(event) { document.querySelector(".fillterWrapper").classList.add("hide") const scrollingElement = (document.scrollingElement || document.body); scrollingElement.scroll({ top: 0, behavior: 'smooth' }); if (ablank) { if (!txtBox.value.includes("?")) { txtBox.value = txtBox.value + quesMark } } let selectedDictionary = document.querySelector('.select_dropDown2').value event.preventDefault(); if (history.pushState) { var newurl = window.location.protocol + "//" + window.location.host + window.location.pathname + '?' + "search" + "=" + txtBox.value.toLowerCase() + '&' + 'dictionary' + '=' + selectedDictionary + '&' + 'prefix' + '=' + startsWith.value + '&' + 'contains' + '=' + mustInclude.value + '&' + 'suffix' + '=' + endsWith.value + '&' + 'exculde' + '=' + exculdeWith.value + '&' + 'include' + '=' + inculdeWith.value + '&' + 'length' + '=' + wordLength.value; window.history.pushState({ path: newurl }, '', newurl); const params = new URLSearchParams(window.location.search) serachValue = params.get('search') prefixValue = params.get('prefix') containsValue = params.get('contains') suffixValue = params.get('suffix') exculdeValue = params.get('exculde') includeValue = params.get('include') lengthValue = params.get('length') dictonary = params.get('dictionary') gtag('event', 'page_view', { page_location: window.location.pathname + location.search, }) } getData(txtBox.value.toLowerCase()) // addFilterCount() } let selectedDictionary = document.querySelector('.select_dropDown2') selectedDictionary.addEventListener("change", ((e) => { logSubmit(e) })) // applyBtn.addEventListener('submit', logSubmit) form.addEventListener('submit', logSubmit); sortingFilter.addEventListener("change", logSubmit); let moreData = [] let data_index = 25; function x_with_letters(data) { data_index = 25 moreData = [] document.querySelector(".sortingFilters").style.display = "flex" main.innerHTML = "" if (typeof data === 'string') { document.querySelector(".sortingFilters").style.display = "none" errorMsg.innerHTML = 'No words found' wordCount.innerHTML = `Found 0 words with letters ${serachValue.split( '' )}` } else { let newWordsLength = 0 let filterData = '' let dataArr = [] if (letterLen) { filterData = data.filter((item) => item.length == letterLen) } if (prefixValue) { filterData = filterData.filter((item2) => item2.startsWith(prefixValue.toLowerCase()) ) startsWith.nextElementSibling.querySelector("img").src = "/assets/images/close-btn.svg" startsWith.classList.add('tick') startsWith.value = prefixValue } else { startsWith.classList.remove('tick') } if (containsValue) { filterData = filterData.filter((item) => item.includes(containsValue.toLowerCase()) ) mustInclude.nextElementSibling.querySelector("img").src = "/assets/images/close-btn.svg" mustInclude.classList.add('tick') mustInclude.value = containsValue } else { mustInclude.classList.remove('tick') } if (suffixValue) { filterData = filterData.filter((item) => item.endsWith(suffixValue.toLowerCase()) ) endsWith.nextElementSibling.querySelector("img").src = "/assets/images/close-btn.svg" endsWith.classList.add('tick') endsWith.value = suffixValue } else { endsWith.classList.remove('tick') } if (exculdeValue) { let data = [] filterData.map((item) => { let check = false for (let e = 0; e < exculdeValue.length; e++) { const element = exculdeValue[e].toLowerCase() if (item.includes(element)) { check = true break } else { check = false } } if (check === false) { data.push(item) } }) exculdeWith.nextElementSibling.querySelector("img").src = "/assets/images/close-btn.svg" exculdeWith.classList.add('tick') exculdeWith.value = exculdeValue filterData = data } else { exculdeWith.classList.remove('tick') } if (includeValue) { let data = [] filterData.map((item) => { let check = false for (let e = 0; e < includeValue.length; e++) { const element = includeValue[e].toLowerCase() if (!item.includes(element)) { check = true break } else { check = false } } if (check === false) { data.push(item) } }) inculdeWith.nextElementSibling.querySelector("img").src = "/assets/images/close-btn.svg" inculdeWith.classList.add('tick') inculdeWith.value = includeValue filterData = data } else { inculdeWith.classList.remove('tick') } if (letterLen) { wordLength.nextElementSibling.querySelector("img").src = "/assets/images/close-btn.svg" } if (filterData.length === 0) { main.innerHTML += '' errorMsg.innerHTML = 'No words Found with this length' } else { newWordsLength += filterData.length filterData = sortWords(filterData); moreData.push(filterData) let itemLength = '' let result = filterData.map((item) => { let itemHtml = ""; itemLength = item.length let ScrabbleLetterScore = ScrabbleScore() sum = 0 item = item.toLowerCase() for (let i = 0; i < item.length; i++) { sum += ScrabbleLetterScore[item[i]] || 0 // for unknown characters } wordLength.value = itemLength if (serachValue) { var text1 = serachValue.replace('?', '') var text2 = item var text3 = item function findIndex(str, char) { const strLength = str.length const indexes = [] let newStr = str while (newStr && newStr.indexOf(char) > -1) { indexes.push(newStr.indexOf(char) + strLength - newStr.length) newStr = newStr.substring(newStr.indexOf(char) + 1) newStr = newStr.substring(newStr.indexOf(char) + 1) } return indexes } let chars = text1.split('') let indexs = [] chars.map((i) => { let findIndexes = findIndex(text3, i) if (findIndexes.length > 0) { text3 = text3.split('') text3[findIndexes] = '$' text3 = text3.join('') indexs = [...indexs, ...findIndexes] } }) text2.split('').map((itemValue, index) => { let check = indexs.find((i) => i === index) if (check !== undefined) { itemHtml += `${itemValue}` } else { itemHtml += `${itemValue}` } }) } else { itemHtml = item } dataArr.push(item) return ` ${itemHtml} ${sum} ` }) home_page_search_result.href = homePageSearchResult home_page_search_result.innerHTML = `See words of any length with letters ${serachValue.split("")}` result = result.slice(0, 25) main.innerHTML += `

${itemLength} Letter Words

${result.join("")}
`; showMoreLimit() } if (serachValue) { wordCount.innerHTML = `Found ${newWordsLength} words with letters with ${serachValue.split( '' )}` } else { let startwithMsg = "" let endwithMsg = "" let containsMsg = "" let lengthMsg = "" let inputVal = "" if (serachValue) { inputVal = `${input.value.split("")} ` } if (prefixValue) { startwithMsg = `starting with ${prefixValue.split("")}` } if (suffixValue) { endwithMsg = `ending with ${suffixValue.split("")} ` } if (containsValue) { containsMsg = `containing with ${containsValue.split("")} ` } if (lengthValue) { lengthMsg = `with ${lengthValue} letter words` } let msg = ` Found ${newWordsLength} words with letters ${lengthMsg} ${inputVal} ${startwithMsg} ${endwithMsg} ${containsMsg} ` wordCount.innerHTML = `${msg} ` } } } async function getMoreWords() { let flattenedArray = moreData.flat(); let uniqueArray = [...new Set(flattenedArray)]; return uniqueArray } async function showMoreWords(e) { try { let showmore = e.parentElement.children[0]; let id = showmore.id; document.getElementById(id).innerHTML = `Loading...`; let content_area = document.getElementById("alpha_" + id).getElementsByClassName("wordList")[0]; const result = await getMoreWords(); let full_words = result.filter((item) => item.length === Number(id)); console.log(data_index); if (data_index < full_words.length) { for (let d = data_index; d < data_index + 25; d++) { if (full_words[d] != undefined) { let itemHtml = ""; if (serachValue) { var text1 = serachValue.replace("?", ""); var text2 = full_words[d]; var text3 = full_words[d]; let chars = text1.split(""); let indexs = []; chars.map((i) => { let findIndexes = findIndex(text3, i); if (findIndexes.length > 0) { text3 = text3.split(""); text3[findIndexes] = "$"; text3 = text3.join(""); indexs = [...indexs, ...findIndexes]; } }); text2.split("").map((itemValue, index) => { let check = indexs.find((i) => i === index); if (check !== undefined) { itemHtml += `${itemValue}`; } else { itemHtml += `${itemValue}`; } }); } else { itemHtml = full_words[d] } let ScrabbleLetterScore = ScrabbleScore(); let points = 0; full_words[d] = full_words[d].toLowerCase(); for (let i = 0; i < full_words[d].length; i++) { points += ScrabbleLetterScore[full_words[d][i]] || 0; // for unknown characters } let span = document.createElement("span"); span.setAttribute("class", "points"); span.setAttribute("value", `${points}`); span.innerHTML = `${points}`; let a = document.createElement("a"); a.setAttribute("class", "anchor__style"); a.setAttribute("target", "_blank"); a.setAttribute("href", "/word-meaning?search=" + full_words[d].replace(/<\/?[^>]+>/gi, '')); a.setAttribute("data-original-title", `Lookup ${full_words[d].replace(/<\/?[^>]+>/gi, '')} in Dictionary`) a.innerHTML = ` ${itemHtml} `; a.appendChild(span) content_area.appendChild(a); } } document.getElementById(id).innerHTML = `More Words`; data_index += 25; } else { data_index = 25 document.getElementById(id).style.display = "none"; } } catch (error) { console.error("Error fetching or processing data:", error); } } function showMoreLimit() { let tableFooter = document.querySelector(".btn-container"); let wordList = document.querySelector(".wordList"); let final_data = wordList.getElementsByClassName("anchor__style"); if (final_data.length < 25) { tableFooter.style.display = "none"; } } function sortWords(data) { if (sortingFilter.selectedIndex == 0) { return data; } else if (sortingFilter.selectedIndex == 1) { return data.sort(); } else if (sortingFilter.selectedIndex == 2) { return data.reverse(); } else if (sortingFilter.selectedIndex == 3) { var tempArr = []; var newArray = []; data.map((item) => { let newWordsLength = 0; if (item.length === 1) { ok = false; newWordsLength = newWordsLength - 1; } else { let ScrabbleLetterScore = ScrabbleScore(); let points = 0; item = item.toLowerCase(); for (let i = 0; i < item.length; i++) { points += ScrabbleLetterScore[item[i]] || 0; // for unknown characters } const value = { words: item, points: points, }; newArray.push(value); } }); newArray.sort(function (a, b) { return b.points - a.points; }); newArray.map((ele) => { tempArr.push(ele.words); }); return tempArr; } } function findIndex(str, char) { const strLength = str.length; const indexes = []; let newStr = str; while (newStr && newStr.indexOf(char) > -1) { indexes.push(newStr.indexOf(char) + strLength - newStr.length); newStr = newStr.substring(newStr.indexOf(char) + 5); newStr = newStr.substring(newStr.indexOf(char) + 5); } return indexes; }