phx-react
Version:
PHX REACT
72 lines • 7.95 kB
JavaScript
import React, { useEffect, useState } from 'react';
import { PHXButton } from '../Button';
import { classNames } from '../types';
import { ArrowLeftIcon } from '@heroicons/react/20/solid';
import { PHXBadge } from '../Badge';
import { PHXModal } from '../Modal';
import { ExclamationTriangleIcon } from '@heroicons/react/24/outline';
import ImportModal from './ModalImport';
export var PHXFormWrap = function (_a) {
var isExport = _a.isExport, exportText = _a.exportText, onExport = _a.onExport, badge = _a.badge, cancelText = _a.cancelText, children = _a.children, contentOfModal = _a.contentOfModal, className = _a.className, deleted = _a.deleted, secondaryLeftButton = _a.secondaryLeftButton, secondaryLeftButtonSubmit = _a.secondaryLeftButtonSubmit, secondaryLeftTextButton = _a.secondaryLeftTextButton, deletedLoading = _a.deletedLoading, _b = _a.footerAction, footerAction = _b === void 0 ? true : _b, _c = _a.headerAction, headerAction = _c === void 0 ? true : _c, headerActionText = _a.headerActionText, _d = _a.headerActionType, headerActionType = _d === void 0 ? 'custom' : _d, loading = _a.loading, method = _a.method, nameOfModal = _a.nameOfModal, onSecondary = _a.onSecondary, onCancel = _a.onCancel, onDelete = _a.onDelete, onSubmit = _a.onSubmit, onImport = _a.onImport, onChangeCapture = _a.onChangeCapture, onHeaderActionClick = _a.onHeaderActionClick, onSubmitSecondaryLeftButton = _a.onSubmitSecondaryLeftButton, onDeletedSecondaryLeftButton = _a.onDeletedSecondaryLeftButton, onlyDelete = _a.onlyDelete, _e = _a.size, size = _e === void 0 ? 'large' : _e, formType = _a.formType, submit = _a.submit, submitText = _a.submitText, title = _a.title, _f = _a.type, type = _f === void 0 ? 'default' : _f, _g = _a.backAction, backAction = _g === void 0 ? true : _g;
var sizeClassName = classNames(size === 'small' && 'mx-auto md:w-5/6 xl:w-1/2', size === 'medium' && 'mx-auto md:w-5/6 lg:w-3/4', size === 'large' && 'mx-auto md:w-md lg:w-11/12');
var _h = useState(false), isModalOpen = _h[0], setIsModalOpen = _h[1];
var _j = useState(false), openImport = _j[0], setOpenImport = _j[1];
var handleDelete = function () {
if (onDelete) {
onDelete();
}
else {
return;
}
};
var handleHeaderAction = function () {
if (headerActionType === 'import') {
setOpenImport(true);
}
else {
if (onHeaderActionClick) {
onHeaderActionClick();
}
}
};
useEffect(function () {
setIsModalOpen(deletedLoading);
}, [deletedLoading]);
return (React.createElement("div", { className: className },
React.createElement("form", { method: method, onSubmit: onSubmit },
React.createElement("div", { className: sizeClassName },
headerAction && (React.createElement("div", { className: 'mb-4 flex items-center justify-between' },
React.createElement("div", { className: 'flex items-center truncate' },
backAction && (React.createElement("button", { className: 'inline-flex items-center rounded-lg border-gray-300 bg-transparent px-2 py-1 text-xs font-medium text-gray-700 hover:bg-gray-200 active:bg-gray-300 active:pb-[0.2rem] active:pt-[0.3rem] active:shadow-[0rem_0.125rem_0.1rem_0rem_#0004_inset]', onClick: onCancel, type: 'button' },
React.createElement(ArrowLeftIcon, { className: 'h-5 w-5' }))),
React.createElement("div", { className: classNames('min-w-0', type === 'default' ? 'flex-1' : 'flex', backAction ? 'ml-2' : '') },
React.createElement("h2", { className: classNames('sm:text-md truncate text-lg font-medium leading-6 text-gray-900 sm:tracking-tight', type === 'default' ? '' : 'mr-2 flex-1') }, title),
type === 'title-with-badge' && (React.createElement("div", { className: 'flex items-center' },
React.createElement(PHXBadge, { text: badge.badgeText, type: badge.badgeType }))))),
(exportText || headerActionText) && (React.createElement("div", { className: 'flex items-center' },
isExport && exportText && (React.createElement("div", { className: classNames(headerActionText ? 'mr-2' : '') },
React.createElement(PHXButton, { onClick: onExport, secondary: true, size: 'small' }, exportText))),
headerActionText && (React.createElement("div", null,
React.createElement(PHXButton, { onClick: handleHeaderAction, primary: true, size: 'small' }, headerActionText))))))),
children,
React.createElement("div", { className: footerAction
? classNames(deleted || secondaryLeftButton ? 'justify-between' : 'justify-end gap-x-3', 'pt-6 mt-6 flex items-center')
: 'hidden' },
deleted && (React.createElement(React.Fragment, null,
React.createElement(PHXButton, { danger: true, size: 'small', onClick: function () { return setIsModalOpen(true); } }, "X\u00F3a b\u1EA3n ghi"),
React.createElement(PHXModal, { dangerActionText: 'X\u00E1c nh\u1EADn x\u00F3a', dangerLoading: deletedLoading, onDangerClick: handleDelete, primaryActionText: '', onHide: function () { return setIsModalOpen(false); }, show: isModalOpen === true, title: "Xo\u00E1 ".concat(nameOfModal, "?") },
React.createElement("div", { className: 'sm:flex sm:items-start' },
React.createElement("div", { className: 'mx-auto flex h-12 w-12 flex-shrink-0 items-center justify-center rounded-full bg-red-100 sm:mx-0 sm:h-10 sm:w-10' },
React.createElement(ExclamationTriangleIcon, { "aria-hidden": 'true', className: 'h-6 w-6 text-red-600' })),
React.createElement("div", { className: 'mt-3 text-center sm:ml-4 sm:mt-0 sm:text-left' },
React.createElement("div", { className: 'mt-2' },
React.createElement("p", { className: 'text-xs text-gray-500' }, contentOfModal
? contentOfModal
: "B\u1EA1n c\u00F3 ch\u1EAFc ch\u1EAFn mu\u1ED1n x\u00F3a b\u1EA3n ghi ".concat(nameOfModal, "? Thao t\u00E1c n\u00E0y kh\u00F4ng th\u1EC3 ho\u00E0n t\u00E1c.")))))))),
secondaryLeftButton && (React.createElement("div", { className: 'flex justify-end gap-x-3' }, secondaryLeftButtonSubmit ? (React.createElement(PHXButton, { size: 'small', loading: loading, onClick: onSubmitSecondaryLeftButton, primary: true }, secondaryLeftTextButton)) : (React.createElement(PHXButton, { danger: true, size: 'small', onClick: onDeletedSecondaryLeftButton }, secondaryLeftTextButton)))),
!onlyDelete && (React.createElement("div", { className: 'flex justify-end gap-x-3' },
React.createElement(PHXButton, { size: 'small', secondary: true, onClick: onSecondary ? onSecondary : onCancel }, formType === 'custom' ? cancelText : 'Huỷ thay đổi'),
submit ? (React.createElement(PHXButton, { size: 'small', loading: loading, submit: true, primary: true }, formType === 'custom' ? submitText : formType === 'add' ? 'Thêm mới' : 'Cập nhật')) : (React.createElement(PHXButton, { size: 'small', loading: loading, onClick: onSubmit, primary: true }, formType === 'custom' ? submitText : formType === 'add' ? 'Thêm mới' : 'Cập nhật'))))))),
React.createElement(ImportModal, { show: openImport, onHide: function () { return setOpenImport(false); }, handleImport: onImport, onChangeCapture: onChangeCapture })));
};
//# sourceMappingURL=FormWrap.js.map