"use strict";

var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
  value: true
});
exports.BillingPostcode = BillingPostcode;
var _react = _interopRequireDefault(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _classnames = _interopRequireDefault(require("classnames"));
function BillingPostcode(_ref) {
  var postcodeReference = _ref.postcodeReference,
    _ref$value = _ref.value,
    value = _ref$value === void 0 ? '' : _ref$value,
    _ref$pattern = _ref.pattern,
    pattern = _ref$pattern === void 0 ? null : _ref$pattern,
    _ref$isDisabled = _ref.isDisabled,
    isDisabled = _ref$isDisabled === void 0 ? false : _ref$isDisabled,
    _ref$hasError = _ref.hasError,
    hasError = _ref$hasError === void 0 ? false : _ref$hasError,
    _ref$isHidden = _ref.isHidden,
    isHidden = _ref$isHidden === void 0 ? false : _ref$isHidden,
    _ref$fieldId = _ref.fieldId,
    fieldId = _ref$fieldId === void 0 ? 'billingPostcodeField' : _ref$fieldId,
    _ref$inputId = _ref.inputId,
    inputId = _ref$inputId === void 0 ? 'billingPostcode' : _ref$inputId,
    _ref$inputName = _ref.inputName,
    inputName = _ref$inputName === void 0 ? 'billingPostcode' : _ref$inputName;
  var BillingPostcodeFieldClassNames = (0, _classnames["default"])(['o-forms-field', {
    ncf__hidden: isHidden
  }]);
  var inputWrapperClassNames = (0, _classnames["default"])(['o-forms-input', 'o-forms-input--text', {
    'o-forms-input--invalid': hasError
  }]);
  return /*#__PURE__*/_react["default"].createElement("label", {
    id: fieldId,
    className: BillingPostcodeFieldClassNames,
    "data-validate": "required",
    htmlFor: inputId
  }, /*#__PURE__*/_react["default"].createElement("span", {
    className: "o-forms-title"
  }, /*#__PURE__*/_react["default"].createElement("span", {
    className: "o-forms-title__main"
  }, "Billing ", /*#__PURE__*/_react["default"].createElement("span", {
    "data-reference": "postcode"
  }, postcodeReference))), /*#__PURE__*/_react["default"].createElement("span", {
    className: inputWrapperClassNames
  }, /*#__PURE__*/_react["default"].createElement("input", {
    type: "text",
    id: inputId,
    name: inputName,
    defaultValue: value,
    placeholder: "Enter your ".concat(postcodeReference),
    autoComplete: "postal-code",
    "data-trackable": "billing-postcode",
    "aria-required": "true",
    required: true,
    pattern: pattern,
    disabled: isDisabled
  }), /*#__PURE__*/_react["default"].createElement("span", {
    className: "o-forms-input__error"
  }, "Please enter a valid", ' ', /*#__PURE__*/_react["default"].createElement("span", {
    "data-reference": "postcode"
  }, postcodeReference), ".")));
}
BillingPostcode.propTypes = {
  postcodeReference: _propTypes["default"].string.isRequired,
  value: _propTypes["default"].string,
  pattern: _propTypes["default"].string,
  isDisabled: _propTypes["default"].bool,
  hasError: _propTypes["default"].bool,
  isHidden: _propTypes["default"].bool,
  fieldId: _propTypes["default"].string,
  inputId: _propTypes["default"].string,
  inputName: _propTypes["default"].string
};