UNPKG

phx-react

Version:

PHX REACT

72 lines 7.95 kB
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