2021-05-01 12:11:22 +03:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2021 Aravinth Manivannan <realaravinth@batsense.net>
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License as
|
|
|
|
* published by the Free Software Foundation, either version 3 of the
|
|
|
|
* License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Affero General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
*/
|
2021-05-01 16:52:44 +03:00
|
|
|
import VALIDATE_LEVELS from './levels';
|
|
|
|
import isBlankString from '../../utils/isBlankString';
|
2021-05-01 18:57:02 +03:00
|
|
|
import isNumber from '../../utils/isNumber';
|
2021-05-01 12:11:22 +03:00
|
|
|
|
|
|
|
const LABEL_CONTAINER_CLASS = 'sitekey-form__add-level-flex-container';
|
|
|
|
const LABEL_CLASS = 'sitekey-form__label';
|
2021-05-01 16:52:44 +03:00
|
|
|
export const LABEL_INNER_TEXT_WITHOUT_LEVEL = 'Level ';
|
|
|
|
|
|
|
|
export const INPUT_ID_WITHOUT_LEVEL = 'level';
|
2021-05-01 12:11:22 +03:00
|
|
|
const INPUT_CLASS = 'sitekey-form__input--add-level';
|
|
|
|
|
2021-05-01 16:52:44 +03:00
|
|
|
const ADD_LEVEL_BUTTON_INNER_TEXT = 'Add Level';
|
|
|
|
const ADD_LEVEL_BUTTON = 'sitekey-form__add-level-button';
|
2021-05-01 12:11:22 +03:00
|
|
|
|
2021-05-01 16:52:44 +03:00
|
|
|
export const getNumLevels = () => {
|
2021-05-01 12:11:22 +03:00
|
|
|
let numLevels = 0;
|
|
|
|
document.querySelectorAll(`.${LABEL_CLASS}`).forEach(_ => numLevels++);
|
2021-05-01 16:52:44 +03:00
|
|
|
return numLevels;
|
|
|
|
};
|
|
|
|
|
|
|
|
const validateLevel = (numLevels: number) => {
|
|
|
|
numLevels = numLevels - 1;
|
|
|
|
let inputID = INPUT_ID_WITHOUT_LEVEL + numLevels.toString();
|
|
|
|
let filed = LABEL_INNER_TEXT_WITHOUT_LEVEL + numLevels;
|
|
|
|
let inputElement = <HTMLInputElement>document.getElementById(inputID);
|
2021-05-01 18:57:02 +03:00
|
|
|
|
2021-05-01 16:52:44 +03:00
|
|
|
let val = inputElement.value;
|
2021-05-01 18:57:02 +03:00
|
|
|
if (!isNumber(val)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
let level = parseInt(val);
|
|
|
|
if (Number.isNaN(level)) {
|
|
|
|
alert('Level can contain nubers only');
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2021-05-01 16:52:44 +03:00
|
|
|
let e = null;
|
2021-05-01 18:57:02 +03:00
|
|
|
console.log(level);
|
|
|
|
|
2021-05-01 16:52:44 +03:00
|
|
|
isBlankString(e, val, filed);
|
2021-05-01 18:57:02 +03:00
|
|
|
let isValid = VALIDATE_LEVELS.add(level);
|
2021-05-01 16:52:44 +03:00
|
|
|
return isValid;
|
|
|
|
};
|
|
|
|
|
|
|
|
const addLevelButtonEventHandler = (e: Event) => {
|
2021-05-01 18:57:02 +03:00
|
|
|
let eventTarget = <HTMLElement>e.target;
|
|
|
|
// if (!eventTarget) {
|
|
|
|
// return;
|
|
|
|
// }
|
2021-05-01 16:52:44 +03:00
|
|
|
const PREV_LEVEL_CONTAINER = <HTMLElement>eventTarget.parentElement;
|
2021-05-01 18:57:02 +03:00
|
|
|
let numLevels: string | number = getNumLevels();
|
2021-05-01 16:52:44 +03:00
|
|
|
let isValid = validateLevel(numLevels);
|
|
|
|
console.log(`[addLevelButton] isValid: ${isValid}`);
|
|
|
|
|
|
|
|
if (!isValid) {
|
|
|
|
return console.log('Aborting level addition');
|
|
|
|
}
|
|
|
|
|
|
|
|
eventTarget.remove();
|
|
|
|
|
2021-05-01 12:11:22 +03:00
|
|
|
numLevels = numLevels.toString();
|
|
|
|
|
|
|
|
let labelContainer = document.createElement('div');
|
|
|
|
labelContainer.className = LABEL_CONTAINER_CLASS;
|
|
|
|
|
|
|
|
let inputID = INPUT_ID_WITHOUT_LEVEL + numLevels;
|
|
|
|
let label = document.createElement('label');
|
|
|
|
label.className = LABEL_CLASS;
|
|
|
|
label.htmlFor = inputID;
|
|
|
|
label.innerText = LABEL_INNER_TEXT_WITHOUT_LEVEL + numLevels;
|
|
|
|
|
|
|
|
labelContainer.appendChild(label);
|
|
|
|
|
|
|
|
PREV_LEVEL_CONTAINER.insertAdjacentElement('afterend', labelContainer);
|
|
|
|
|
|
|
|
let inputContainer = document.createElement('div');
|
|
|
|
inputContainer.className = LABEL_CONTAINER_CLASS;
|
|
|
|
|
|
|
|
let input = document.createElement('input');
|
|
|
|
input.id = inputID;
|
|
|
|
input.name = inputID;
|
|
|
|
input.type = 'text';
|
|
|
|
input.className = INPUT_CLASS;
|
|
|
|
|
|
|
|
inputContainer.appendChild(input);
|
|
|
|
|
|
|
|
let button = document.createElement('button');
|
|
|
|
button.className = ADD_LEVEL_BUTTON;
|
|
|
|
button.innerText = ADD_LEVEL_BUTTON_INNER_TEXT;
|
|
|
|
|
|
|
|
inputContainer.appendChild(button);
|
|
|
|
|
|
|
|
labelContainer.insertAdjacentElement('afterend', inputContainer);
|
|
|
|
|
|
|
|
addLevelButtonAddEventListener();
|
|
|
|
};
|
|
|
|
|
|
|
|
export const addLevelButtonAddEventListener = () => {
|
2021-05-01 18:57:02 +03:00
|
|
|
let addLevelButton = <HTMLElement>(
|
|
|
|
document.querySelector(`.${ADD_LEVEL_BUTTON}`)
|
|
|
|
);
|
2021-05-01 12:11:22 +03:00
|
|
|
addLevelButton.addEventListener('click', addLevelButtonEventHandler);
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
<div class="sitekey-form__add-level-flex-container">
|
|
|
|
<label class="sitekey-form__label" for="level2">Level 2</label>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="sitekey-form__add-level-flex-container">
|
|
|
|
<input
|
|
|
|
class="sitekey-form__input--add-level"
|
|
|
|
type="text"
|
|
|
|
name="level2"
|
|
|
|
id="level2"
|
|
|
|
value=""
|
|
|
|
/>
|
|
|
|
<button class="sitekey-form__add-level-button">Add Level</button>
|
|
|
|
</div>
|
|
|
|
*/
|