---
---
const getScript=document.currentScript
const letterLen = getScript.dataset.letter
let errorMsg = document.querySelector('.errorMsg')
let wordCount = document.querySelector('.wordCount')
let main = document.querySelector('.main')
const params = new URLSearchParams(window.location.search)
let serachValue = params.get('search')
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 tab_container = document.querySelector('.tab_container')
let txtBox = document.querySelector('.txtBox')
txtBox.focus()
txtBox.value = serachValue
var theSelect = document.getElementById('select_dropDown')
document.querySelector('.select_dropDown2').value = dictonary
const getData = async (serachValue) => {
try {
main.innerHTML = `
`
const response = await fetch(
`/.netlify/functions/getWords?name=${serachValue}`
)
const data = await response.json()
main.innerHTML = ''
x_with_letters(data)
} catch (error) {
console.log(error)
}
}
// calling function
getData(serachValue.toLowerCase())
function x_with_letters(data) {
if (typeof data === 'string') {
errorMsg.innerHTML = 'No words found'
wordCount.innerHTML = `Found 0 words with letters ${serachValue.split(
''
)} `
} else {
let newWordsLength = 0
let filterData = ''
if (letterLen) {
filterData = data.filter((item) => item.length == letterLen)
}
if (prefixValue) {
filterData = filterData.filter((item2) =>
item2.startsWith(prefixValue.toLowerCase())
)
startsWith.classList.add('tick')
startsWith.value = prefixValue
}
if (containsValue) {
filterData = filterData.filter((item) =>
item.includes(containsValue.toLowerCase())
)
mustInclude.classList.add('tick')
mustInclude.value = containsValue
}
if (suffixValue) {
filterData = filterData.filter((item) =>
item.endsWith(suffixValue.toLowerCase())
)
endsWith.classList.add('tick')
endsWith.value = suffixValue
}
if (exculdeValue) {
let data = []
filterData.map((item) => {
let check = false
for (let e = 0; e < exculdeValue.length; e++) {
const element = exculdeValue[e]
if (item.includes(element)) {
check = true
break
} else {
check = false
}
}
if (check === false) {
data.push(item)
}
})
exculdeWith.classList.add('tick')
exculdeWith.value = exculdeValue
filterData = data
}
if (includeValue) {
let data = []
filterData.map((item) => {
let check = false
for (let e = 0; e < includeValue.length; e++) {
const element = includeValue[e]
if (!item.includes(element)) {
check = true
break
} else {
check = false
}
}
if (check === false) {
data.push(item)
}
})
inculdeWith.classList.add('tick')
inculdeWith.value = includeValue
filterData = data
}
if (filterData.length === 0) {
main.innerHTML += ''
errorMsg.innerHTML = 'No words Found with this length'
} else {
// sort eventlistener
theSelect.addEventListener('change', () => {
sortValue = theSelect[theSelect.selectedIndex].text
if (sortValue == 'Z-A') {
sortBool = true
sortby(sortBool, filterData, itemLength)
} else {
sortBool = false
sortby(sortBool, filterData, itemLength)
}
if (sortValue == 'Points') {
sortBool = true
sortPointsby(sortBool, filterData, itemLength)
}
})
newWordsLength += filterData.length
let itemLength = ''
const result = filterData.map((item) => {
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
return `
${item}
${sum}
`
})
tab_container.innerHTML += `
`
let tabs = document.getElementsByClassName('tab_link')
tabs[0] ? tabs[0].classList.add('active-tab') : ''
main.innerHTML += `
${itemLength} Letter Words
`
}
wordCount.innerHTML = `Found ${newWordsLength} words with letters with ${serachValue.split(
''
)} `
}
}
//Handling of filter counter in advanced filter
function addFilterCount() {
let filter_val = document.getElementsByClassName('filter_val')
let filter = document.querySelector('.filter_count')
let filter_count = 0
filter_val[0].value = prefixValue
filter_val[1].value = containsValue
filter_val[2].value = suffixValue
filter_val[3].value = exculdeValue
filter_val[4].value = includeValue
filter_val[5].value = lengthValue
for (var i = 0; i <= 4; i++) {
if (filter_val[i].value != '') {
filter_count += 1
}
if (filter_count === 0) {
filter.style.display = 'none'
} else {
filter.style.display = 'inline-block'
}
filter.innerHTML = filter_count
}
}
addFilterCount()
// sorting by points
function sortPointsby(sortValue, data, i) {
if (sortValue) {
main.innerHTML = ''
let newArray = []
data.map((item) => {
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
})
})
const result = newArray.map((item) => {
return `
${item.words}
${item.points}
`
})
main.innerHTML += `
`
}
}
// sort by aplhabets
function sortby(sortBool, data, i) {
if (sortBool) {
main.innerHTML = ''
data.reverse()
const result = data.map((item) => {
let ScrabbleLetterScore = ScrabbleScore()
let sum = 0
item = item.toLowerCase()
for (let i = 0; i < item.length; i++) {
sum += ScrabbleLetterScore[item[i]] || 0 // for unknown characters
}
return `
${item}
${sum}
`
})
main.innerHTML += `
`
} else {
main.innerHTML = ''
data.sort()
const result = data.map((item) => {
let ScrabbleLetterScore = ScrabbleScore()
let sum = 0
item = item.toLowerCase()
for (let i = 0; i < item.length; i++) {
sum += ScrabbleLetterScore[item[i]] || 0 // for unknown characters
}
return `
${item}
${sum}
`
})
main.innerHTML += `
`
}
}
// Implement Active class
const addFilter = () => {
let tabs = document.getElementsByClassName('tab_link')
tabs[0] ? tabs[0].classList.add('active-tab') : ''
Array.from(tabs).map((item) => {
item.classList.remove('active-tab')
})
main.innerHTML += ``
let activeLetter = event.target
// console.log(activeLetter)
activeLetter.classList.add('active-tab')
}
// 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
}
}