// console.log("certain position"); let form = document.querySelector('[name=verify') let greenLetters = document.querySelectorAll('.greenLetters') let certain_pos_words_data = document.getElementById('certain_pos_words_data') greenLetters[0].focus() let certain_pos_count = document.querySelector('#certain_pos_count') let certain_pos_error_msg = document.querySelector('#certain_pos_error_msg') let certain_pos_submit = document.getElementById('certain_pos_submit') let newWordsLength let errMessage = document.querySelector('.errMessage') let spinner = document.querySelector('.spinner') let tab_container = document.querySelector('.tab_container') let tab_link_wrapper = document.querySelector(".tab_link_wrapper") tab_link_wrapper.style.marginTop = "1rem" tab_link_wrapper.style.display = "none" const wordsInCertainPos = async (letters, lettersWithIndex, wordLength) => { let maxLength = Math.max.apply(null, wordLength); // maxLength = maxLength + 1 try { let result = '' document.querySelector('#searchData').innerHTML = '' spinner.classList.add('spinner-border') certain_pos_count.innerHTML = 'Finding words in certain position...' let response = await fetch('/.netlify/functions/wordsInCertainPositions', { method: 'POST', body: JSON.stringify({ greenLetters: letters, greenWithIndex: lettersWithIndex, }), }) let data = await response.json() if (data.length == 0) { errMessage.innerHTML = 'Sorry!! No words found' errMessage.classList.add('alert-danger') errMessage.style.display = 'block' document.querySelector('#searchData').innerHTML = 'Search' spinner.classList.remove('spinner-border') certain_pos_words_data.innerHTML = "" tab_container.innerHTML = "" certain_pos_count.innerHTML = "" newWordsLength = 0 } else { errMessage.innerHTML = '' errMessage.classList.remove('alert-danger') data = data.slice(0, 1500) document.querySelector('#searchData').innerHTML = 'Search' spinner.classList.remove('spinner-border') certain_pos_words_data.innerHTML = "" tab_container.innerHTML = "" newWordsLength = 0 let ok = true for (let i = maxLength; i <= 15; i++) { let newdata = data.filter((item) => item.length === i) if (newdata.length === 0) { certain_pos_words_data.innerHTML += '' } else { newWordsLength += newdata.length certain_pos_error_msg.classList.remove('alert-danger') certain_pos_error_msg.innerHTML = '' const result = newdata.map((item) => { if (item.length === 1) { ok = false newWordsLength = newWordsLength - 1 } else { let ScrabbleLetterScore = ScrabbleScore() sum = 0 item = item.toLowerCase() for (let i = 0; i < item.length; i++) { sum += ScrabbleLetterScore[item[i]] || 0 // for unknown characters } return `
  • ${item} ${sum}
  • ` } }) if (ok) { tab_link_wrapper.style.display = "inline-flex" tab_container.innerHTML += ` ` let tabs = document.getElementsByClassName('tab_link') tabs[0] ? tabs[0].classList.add('active-tab') : '' certain_pos_words_data.innerHTML += `

    List of ${i} letter words that contain letters ${letters}

    ` } } } if (newWordsLength === 0) { certain_pos_count.innerHTML = "" certain_pos_error_msg.classList.add('alert-danger') certain_pos_error_msg.innerHTML = 'Sorry!! No words found' } else { certain_pos_count.innerHTML = `Found ${newWordsLength} words matching your search criteria ` } } } catch (error) { console.log(error) } } for (let g = 0; g < greenLetters.length; g++) { const elem = greenLetters[g] elem.addEventListener('input', (e) => { e.target.value = e.target.value.replace(/[^a-zA-Z? ]/g, "") }) } const getLetters = (object) => { let letters = [] if (typeof object === 'string') { object = document.querySelectorAll(object) } for (let item of object) { if (item.value.trim().length === 1) { letters.push(item.value.toLowerCase()) } } return letters } const getIndexs = (object) => { let index = [] if (typeof object === 'string') { object = document.querySelectorAll(object) } for (let item of object) { if (item.value.trim().length === 1) { index.push({ value: item.value.toLowerCase(), index: item.dataset.id, }) } } return index } const getLength = (object) => { let index = [] if (typeof object === 'string') { object = document.querySelectorAll(object) } for (let item of object) { if (item.value.trim().length === 1) { index.push( item.dataset.id) } } return index } function handleSubmit(e) { e.preventDefault() let letters = getLetters('.greenLetters') let lettersWithIndex = getIndexs('.greenWithIndex') let wordLength = getLength('.greenWithIndex') wordsInCertainPos(letters, lettersWithIndex, wordLength) } form.addEventListener('submit', handleSubmit) // handling of filter on scroll window.onscroll = function () { var section = document.querySelectorAll('.letterswords') let new_sections = {} Array.prototype.forEach.call(section, function (e) { if (document.body.clientWidth > 991) { new_sections[e.id] = e.offsetTop - 10 } else { new_sections[e.id] = e.offsetTop - 10 } }) var scrollPosition = document.documentElement.scrollTop || document.body.scrollTop for (i in new_sections) { let sort_val = "alpha" if ( i.split('_')[0] == sort_val && new_sections[i] && new_sections[i] <= scrollPosition ) { document.querySelector('.active-tab').classList.remove('active-tab') var active_now = document.querySelector('#Tab_' + i.split('_')[1]) active_now.classList.add('active-tab') // active_now.scrollIntoView() } } } // Add Filtering let sections = {} function Filtering(id) { let tabs = document.getElementsByClassName('tab_link') tabs[0] ? tabs[0].classList.add('active-tab') : '' Array.from(tabs).map((item) => { item.classList.remove('active-tab') }) // certain_pos_words_data.innerHTML += `` let activeLetter = event.target activeLetter.classList.add('active-tab') var section = document.querySelectorAll('.letterswords') var sort_val = "alpha" Array.prototype.forEach.call(section, function (e) { if (document.body.clientWidth > 991) { sections[e.id] = e.offsetTop - 10 } else { sections[e.id] = e.offsetTop - 30 } }) document.documentElement.scrollTop = sections[sort_val + '_' + id] + 5 // document.body.scrollTop = sections[sort_val + '_' + id] + 5 } // next && previous functionality let prev = document.getElementById('prev') let next = document.getElementById('next') if (prev) { prev.onclick = scroll_Right } if (next) { next.onclick = scroll_Left } scroll_visible() window.addEventListener('resize', function () { scroll_visible() }) window.addEventListener('scroll', function () { scroll_visible() }) function scroll_visible() { let tab_container = document.querySelector('#tab-container') // console.log(tab_container) if (tab_container) { if (tab_container.clientWidth === tab_container.scrollWidth) { prev.style.display = 'none' next.style.display = 'none' } else { prev.style.display = 'block' next.style.display = 'block' } } } function scroll_Left() { tab_container.scrollLeft += 130 } function scroll_Right() { tab_container.scrollLeft -= 130 } // Scrabble Point Array 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, } return twl06_sowpods }