phx-react
Version:
PHX REACT
54 lines • 3.52 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.PHXNotifications = void 0;
const tslib_1 = require("tslib");
const react_1 = tslib_1.__importStar(require("react"));
const types_1 = require("../types");
const react_2 = require("@headlessui/react");
const solid_1 = require("@heroicons/react/20/solid");
const PHXNotifications = ({ className, show, type, onHide, failure, customMessage }) => {
const [notify, setNotify] = (0, react_1.useState)(false);
const [isFailure, setIsFailure] = (0, react_1.useState)(false);
(0, react_1.useEffect)(() => {
// @ts-ignore
setNotify(show);
}, [show]);
(0, react_1.useEffect)(() => {
// @ts-ignore
if (failure) {
setIsFailure(true);
}
else {
setTimeout(() => {
setIsFailure(false);
}, 200);
}
}, [failure]);
const hideNotify = () => {
setNotify(false);
if (onHide) {
onHide();
}
};
const message = type === 'add'
? 'Thêm mới thành công'
: type === 'edit'
? 'Cập nhật thành công'
: type === 'delete'
? 'Xóa bản ghi thành công'
: customMessage;
return (react_1.default.createElement("div", { "aria-live": 'assertive', className: `absolute pointer-events-none inset-0 flex items-center px-4 py-6 sm:items-start sm:p-6 ${className}` },
react_1.default.createElement("div", { className: 'fixed bottom-10 left-0 mr-8 flex w-full flex-col items-center z-[60]' },
react_1.default.createElement(react_2.Transition, { as: react_1.Fragment, enter: 'transform ease-out duration-500 transition', enterFrom: 'translate-y-2 opacity-0 sm:translate-y-0 sm:translate-y-10', enterTo: 'translate-y-0 opacity-500 sm:translate-y-0', leave: 'transition ease-in duration-500', leaveFrom: 'translate-y-0 opacity-500 sm:translate-y-0', leaveTo: 'translate-y-2 opacity-0 sm:translate-y-0 sm:translate-y-10', show: notify },
react_1.default.createElement("div", { className: (0, types_1.classNames)('pointer-events-auto max-w-sm overflow-hidden rounded-lg shadow-lg ring-1 ring-black ring-opacity-5', isFailure ? 'bg-red-600' : 'bg-indigo-800') },
react_1.default.createElement("div", { className: 'p-3' },
react_1.default.createElement("div", { className: 'flex items-center justify-between' },
react_1.default.createElement("div", { className: 'ml-1' },
react_1.default.createElement("p", { className: 'text-xs font-normal text-white' }, isFailure && type === 'custom' ? message : isFailure ? 'Lỗi, vui lòng thử lại sau' : message)),
react_1.default.createElement("div", { className: 'ml-4 flex pt-0.5' },
react_1.default.createElement("button", { className: 'inline-flex rounded-md bg-white text-gray-400 hover:text-gray-500', onClick: () => hideNotify(), type: 'button' },
react_1.default.createElement("span", { className: 'sr-only' }, "Close"),
react_1.default.createElement(solid_1.XMarkIcon, { "aria-hidden": 'true', className: (0, types_1.classNames)('h-4 w-4 text-white', isFailure ? 'bg-red-600' : 'bg-indigo-800') }))))))))));
};
exports.PHXNotifications = PHXNotifications;
//# sourceMappingURL=Notifications.js.map