mirror of
https://github.com/mCaptcha/mCaptcha.git
synced 2024-11-23 18:05:54 +03:00
ts: error component
This commit is contained in:
parent
6cd477e227
commit
d298ef4719
2 changed files with 135 additions and 0 deletions
58
templates/components/error/error.test.ts
Normal file
58
templates/components/error/error.test.ts
Normal file
|
@ -0,0 +1,58 @@
|
||||||
|
/*
|
||||||
|
* 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/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import createError from './index';
|
||||||
|
import * as e from './index';
|
||||||
|
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
jest.useFakeTimers();
|
||||||
|
|
||||||
|
const setup = () => {
|
||||||
|
let x = document.createElement('div');
|
||||||
|
x.id = e.ERR_CONTAINER_ID;
|
||||||
|
return x;
|
||||||
|
};
|
||||||
|
|
||||||
|
it('checks if error boxes work', () => {
|
||||||
|
document.body.append(setup());
|
||||||
|
|
||||||
|
const getMsg = (num: number) => `message ${num}`;
|
||||||
|
createError(getMsg(1));
|
||||||
|
let msg = document.querySelector(`.${e.ERR_MSG_CONTAINER}`);
|
||||||
|
expect(msg.innerHTML).toContain(getMsg(1));
|
||||||
|
|
||||||
|
let btn = <HTMLButtonElement>msg.getElementsByClassName(e.ERR_CLOSE)[0];
|
||||||
|
btn.click();
|
||||||
|
msg = document.querySelector(`.${e.ERR_MSG_CONTAINER}`);
|
||||||
|
expect(msg).toEqual(null);
|
||||||
|
|
||||||
|
const errElement = document.createElement('p');
|
||||||
|
errElement.appendChild(document.createTextNode(getMsg(2)));
|
||||||
|
createError(errElement);
|
||||||
|
msg = document.querySelector(`.${e.ERR_MSG_CONTAINER}`).querySelector('p');
|
||||||
|
expect(msg).toEqual(errElement);
|
||||||
|
|
||||||
|
let timeOutElement = document.createElement('p');
|
||||||
|
timeOutElement.appendChild(document.createTextNode(getMsg(2)));
|
||||||
|
createError(timeOutElement, 200);
|
||||||
|
msg = document.querySelector(`.${e.ERR_MSG_CONTAINER}`).querySelector('p');
|
||||||
|
expect(msg).toEqual(timeOutElement);
|
||||||
|
jest.runOnlyPendingTimers();
|
||||||
|
msg = document.querySelector(`.${e.ERR_MSG_CONTAINER}`);
|
||||||
|
expect(msg).toEqual(null);
|
||||||
|
});
|
77
templates/components/error/index.ts
Normal file
77
templates/components/error/index.ts
Normal file
|
@ -0,0 +1,77 @@
|
||||||
|
/*
|
||||||
|
* 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/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
export const ERR_CONTAINER_ID = 'err__container';
|
||||||
|
export const ERR_MSG_CONTAINER = 'err__msg-container'; // class
|
||||||
|
export const ERR_CLOSE = 'err__close'; // class
|
||||||
|
|
||||||
|
export const DEFAULT_LIFETIME = 5000;
|
||||||
|
|
||||||
|
const err = () => {
|
||||||
|
let element;
|
||||||
|
return (() => {
|
||||||
|
if (element === undefined) {
|
||||||
|
element = document.getElementById(ERR_CONTAINER_ID);
|
||||||
|
}
|
||||||
|
return element;
|
||||||
|
})();
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* create error message
|
||||||
|
*
|
||||||
|
* @param {string|HTMLElement} message: an error message
|
||||||
|
* @param {number} lifetime: duration in milliseconds after which error
|
||||||
|
* message will be deleted
|
||||||
|
*/
|
||||||
|
const createError = (
|
||||||
|
message: string | HTMLElement,
|
||||||
|
lifetime: number = DEFAULT_LIFETIME,
|
||||||
|
) => {
|
||||||
|
const box = document.createElement('div');
|
||||||
|
|
||||||
|
const msg = () => {
|
||||||
|
if (typeof message === 'string') {
|
||||||
|
return document.createTextNode(message);
|
||||||
|
} else {
|
||||||
|
return message;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
box.className = ERR_MSG_CONTAINER;
|
||||||
|
box.appendChild(msg());
|
||||||
|
|
||||||
|
const deleteBtn = document.createElement('button');
|
||||||
|
const deleteMsg = document.createTextNode('x');
|
||||||
|
deleteBtn.appendChild(deleteMsg);
|
||||||
|
deleteBtn.className = ERR_CLOSE;
|
||||||
|
box.appendChild(deleteBtn);
|
||||||
|
|
||||||
|
err().appendChild(box);
|
||||||
|
|
||||||
|
const timer = setTimeout(() => box.remove(), lifetime);
|
||||||
|
|
||||||
|
const deleteHandler = (e: Event) => {
|
||||||
|
e.preventDefault();
|
||||||
|
window.clearTimeout(timer);
|
||||||
|
box.remove();
|
||||||
|
};
|
||||||
|
|
||||||
|
deleteBtn.addEventListener('click', e => deleteHandler(e));
|
||||||
|
};
|
||||||
|
|
||||||
|
export default createError;
|
Loading…
Reference in a new issue