UNPKG

@appbuckets/react-ui

Version:
95 lines (88 loc) 2.42 kB
'use strict'; var tslib = require('tslib'); var React = require('react'); var clsx = require('clsx'); require('../BucketTheme/BucketTheme.js'); var BucketContext = require('../BucketTheme/BucketContext.js'); var customHook = require('../utils/customHook.js'); function _interopDefaultLegacy(e) { return e && typeof e === 'object' && 'default' in e ? e : { default: e }; } function _interopNamespace(e) { if (e && e.__esModule) return e; var n = Object.create(null); if (e) { Object.keys(e).forEach(function (k) { if (k !== 'default') { var d = Object.getOwnPropertyDescriptor(e, k); Object.defineProperty( n, k, d.get ? d : { enumerable: true, get: function () { return e[k]; }, } ); } }); } n['default'] = e; return Object.freeze(n); } var React__namespace = /*#__PURE__*/ _interopNamespace(React); var clsx__default = /*#__PURE__*/ _interopDefaultLegacy(clsx); /* -------- * Component Render * -------- */ var Form = React__namespace.forwardRef(function (receivedProps, ref) { var props = BucketContext.useWithDefaultProps('form', receivedProps); var _a = customHook.useSharedClassName(props), className = _a.className, _b = _a.rest, children = _b.children; _b.content; var disabled = _b.disabled, onSubmit = _b.onSubmit, rest = tslib.__rest(_b, ['children', 'content', 'disabled', 'onSubmit']); /** Build the element class list */ var classes = clsx__default['default']( { disabled: disabled }, 'form', className ); /* -------- * Form Submit Handler * -------- */ var handleFormSubmit = function (e) { /** Prevent any default action, only if action props is not defined */ if (typeof props.action !== 'string') { e.preventDefault(); } /** Disabled Form couldn't be submitted */ if (disabled) { return; } /** Call the user defined onSubmit handler */ if (typeof onSubmit === 'function') { onSubmit(e, props); } }; /* -------- * Render the Form * -------- */ return React__namespace.createElement( 'form', tslib.__assign({}, rest, { ref: ref, className: classes, onSubmit: handleFormSubmit, }), children ); }); Form.displayName = 'Form'; module.exports = Form;