Add floating messaging system

This commit is contained in:
Robbie Antenesse 2019-05-08 17:13:23 -06:00
parent 83ec6665e9
commit b3a3c918dc
4 changed files with 57 additions and 8 deletions

View File

@ -152,11 +152,11 @@
<label>Theme <label>Theme
<select disabled> <select disabled>
<option selected value="default">Default</option> <option selected value="default">Default</option>
<option selected value="dark">Dark</option> <option value="dark">Dark</option>
<option selected value="light">Light</option> <option value="light">Light</option>
<option selected value="blue">Blue</option> <option value="blue">Blue</option>
<option selected value="green">Green</option> <option value="green">Green</option>
<option selected value="royal">Royal</option> <option value="royal">Royal</option>
</select> </select>
</label> </label>
</form> </form>
@ -303,5 +303,7 @@
</footer> </footer>
</div> </div>
</section> </section>
<div id="messagingSection"></div>
</body> </body>
</html> </html>

View File

@ -2,15 +2,16 @@ import './main.scss';
import setupListeners from './js/setupListeners'; import setupListeners from './js/setupListeners';
import { renderAll } from './js/render'; import { renderAll } from './js/render';
import { generateRandomWords } from './js/utilities'; import { generateRandomWords, addMessage } from './js/utilities';
import { loadDictionary } from './js/dictionaryManagement'; import { loadDictionary } from './js/dictionaryManagement';
function initialize() { function initialize() {
console.log('initializing'); addMessage('Loading!');
loadDictionary(); loadDictionary();
// generateRandomWords(100); // generateRandomWords(100);
setupListeners(); setupListeners();
renderAll(); renderAll();
addMessage('Done Loading!');
// console.log('Rendered!'); // console.log('Rendered!');
} }

View File

@ -1,4 +1,3 @@
import { cloneObject } from '../helpers';
import { addWord } from './wordManagement'; import { addWord } from './wordManagement';
export function getNextId() { export function getNextId() {
@ -131,3 +130,20 @@ export function generateRandomWords(numberOfWords) {
}); });
console.log('done'); console.log('done');
} }
export function addMessage(messageText, time = 5000) {
const messagingSection = document.getElementById('messagingSection');
const element = document.createElement('div');
element.classList.add('message');
element.innerHTML = '<a class="close-button">&times;&#xFE0E;</a>' + messageText;
messagingSection.appendChild(element);
const closeButton = element.querySelector('.close-button');
const closeMessage = () => {
closeButton.removeEventListener('click', closeMessage);
messagingSection.removeChild(element);
};
closeButton.addEventListener('click', closeMessage);
setTimeout(closeMessage, time);
}

View File

@ -266,6 +266,36 @@
} }
} }
#messagingSection {
position: fixed;
bottom: $general-padding;
right: $general-padding;
max-width: 250px;
.message {
position: relative;
display: block;
padding: $general-padding ($general-padding * 2) $general-padding $general-padding;
background-color: $light;
border: $border;
border-radius: 5px;
margin-bottom: 5px;
&:last-child {
margin-bottom: 0;
}
.close-button {
position: absolute;
top: 5px;
right: 5px;
font-size: 25px;
line-height: 10px;
cursor: pointer;
}
}
}
#bottom { #bottom {
text-align: center; text-align: center;