Provide a search box for filtering cards in pile list
This commit is contained in:
parent
c750096044
commit
3c2190b940
20
script.js
20
script.js
@ -89,7 +89,24 @@ interact('.card-pile')
|
|||||||
})
|
})
|
||||||
.on('hold', event => {
|
.on('hold', event => {
|
||||||
let pile = piles[event.target.getAttribute('data-pile')];
|
let pile = piles[event.target.getAttribute('data-pile')];
|
||||||
|
let searchBox = document.createElement('input');
|
||||||
|
let container = document.createElement('div');
|
||||||
let cardList = document.createElement('div');
|
let cardList = document.createElement('div');
|
||||||
|
searchBox.setAttribute('type', 'search');
|
||||||
|
searchBox.setAttribute('placeholder', 'Filter');
|
||||||
|
searchBox.addEventListener('input', event => {
|
||||||
|
for (var ii = 0; ii < cardList.children.length; ii++) {
|
||||||
|
let input = event.target.value;
|
||||||
|
let cardNum = parseInt(cardList.children[ii].getAttribute('data-num'));
|
||||||
|
let cardData = deckJSON.ObjectStates[0].ContainedObjects.find(c => c.CardID === (cardNum + 100));
|
||||||
|
cardList.children[ii].style.display =
|
||||||
|
(cardData.Nickname.toLowerCase().includes(input.toLowerCase()) ||
|
||||||
|
cardData.Description.toLowerCase().includes(input.toLowerCase())) ?
|
||||||
|
"": "none";
|
||||||
|
}
|
||||||
|
});
|
||||||
|
container.appendChild(searchBox);
|
||||||
|
|
||||||
pile.forEach(cardNum => {
|
pile.forEach(cardNum => {
|
||||||
let newCard = makeCard(cardNum);
|
let newCard = makeCard(cardNum);
|
||||||
newCard.classList.add('in-list');
|
newCard.classList.add('in-list');
|
||||||
@ -113,7 +130,8 @@ interact('.card-pile')
|
|||||||
}, {once: true});
|
}, {once: true});
|
||||||
cardList.appendChild(newCard);
|
cardList.appendChild(newCard);
|
||||||
});
|
});
|
||||||
showModal(cardList);
|
container.appendChild(cardList);
|
||||||
|
showModal(container);
|
||||||
})
|
})
|
||||||
.on('tap', event => shuffle(piles[event.target.getAttribute('data-pile')]));
|
.on('tap', event => shuffle(piles[event.target.getAttribute('data-pile')]));
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user