UNPKG

decap-cms-ui-auth

Version:

UI auth library for Decap CMS

200 lines 42 kB
import _styled from "@emotion/styled/base"; function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; } import PropTypes from 'prop-types'; import React from 'react'; import partial from 'lodash/partial'; import { AuthenticationPage, buttons, shadows, colors, colorsRaw, lengths, zIndex } from 'decap-cms-ui-default'; import { jsx as ___EmotionJSX } from "@emotion/react"; const LoginButton = /*#__PURE__*/_styled("button", { target: "ek030u93", label: "LoginButton" })(buttons.button, ";", shadows.dropDeep, ";", buttons.default, ";", buttons.gray, ";padding:0 30px;display:block;margin-top:20px;margin-left:auto;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/NetlifyAuthenticationPage.js"],"names":[],"mappings":"AAciC","file":"../../src/NetlifyAuthenticationPage.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport partial from 'lodash/partial';\nimport {\n  AuthenticationPage,\n  buttons,\n  shadows,\n  colors,\n  colorsRaw,\n  lengths,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nconst LoginButton = styled.button`\n  ${buttons.button};\n  ${shadows.dropDeep};\n  ${buttons.default};\n  ${buttons.gray};\n\n  padding: 0 30px;\n  display: block;\n  margin-top: 20px;\n  margin-left: auto;\n`;\n\nconst AuthForm = styled.form`\n  width: 350px;\n  margin-top: -80px;\n`;\n\nconst AuthInput = styled.input`\n  background-color: ${colorsRaw.white};\n  border-radius: ${lengths.borderRadius};\n\n  font-size: 14px;\n  padding: 10px;\n  margin-bottom: 15px;\n  margin-top: 6px;\n  width: 100%;\n  position: relative;\n  z-index: ${zIndex.zIndex1};\n\n  &:focus {\n    outline: none;\n    box-shadow: inset 0 0 0 2px ${colors.active};\n  }\n`;\n\nconst ErrorMessage = styled.p`\n  color: ${colors.errorText};\n`;\n\nlet component = null;\n\nif (window.netlifyIdentity) {\n  window.netlifyIdentity.on('login', user => {\n    component && component.handleIdentityLogin(user);\n  });\n  window.netlifyIdentity.on('logout', () => {\n    component && component.handleIdentityLogout();\n  });\n  window.netlifyIdentity.on('error', err => {\n    component && component.handleIdentityError(err);\n  });\n}\n\nexport default class NetlifyAuthenticationPage extends React.Component {\n  static authClient;\n\n  static propTypes = {\n    onLogin: PropTypes.func.isRequired,\n    inProgress: PropTypes.bool.isRequired,\n    error: PropTypes.node,\n    config: PropTypes.object.isRequired,\n    t: PropTypes.func.isRequired,\n  };\n\n  constructor(props) {\n    super(props);\n    component = this;\n  }\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(\n      NetlifyAuthenticationPage.propTypes,\n      this.props,\n      'prop',\n      'GitGatewayAuthenticationPage',\n    );\n\n    if (!this.loggedIn && window.netlifyIdentity && window.netlifyIdentity.currentUser()) {\n      this.props.onLogin(window.netlifyIdentity.currentUser());\n      window.netlifyIdentity.close();\n    }\n  }\n\n  componentWillUnmount() {\n    component = null;\n  }\n\n  handleIdentityLogin = user => {\n    this.props.onLogin(user);\n    window.netlifyIdentity.close();\n  };\n\n  handleIdentityLogout = () => {\n    window.netlifyIdentity.open();\n  };\n\n  handleIdentityError = err => {\n    if (err?.message?.match(/^Failed to load settings from.+\\.netlify\\/identity$/)) {\n      window.netlifyIdentity.close();\n      this.setState({\n        errors: { identity: this.props.t('auth.errors.identitySettings') },\n      });\n    }\n  };\n\n  handleIdentity = () => {\n    const user = window.netlifyIdentity.currentUser();\n    if (user) {\n      this.props.onLogin(user);\n    } else {\n      window.netlifyIdentity.open();\n    }\n  };\n\n  state = { email: '', password: '', errors: {} };\n\n  handleChange = (name, e) => {\n    this.setState({ ...this.state, [name]: e.target.value });\n  };\n\n  handleLogin = async e => {\n    e.preventDefault();\n\n    const { email, password } = this.state;\n    const { t } = this.props;\n    const errors = {};\n    if (!email) {\n      errors.email = t('auth.errors.email');\n    }\n    if (!password) {\n      errors.password = t('auth.errors.password');\n    }\n\n    if (Object.keys(errors).length > 0) {\n      this.setState({ errors });\n      return;\n    }\n\n    try {\n      const client = await NetlifyAuthenticationPage.authClient();\n      const user = await client.login(this.state.email, this.state.password, true);\n      this.props.onLogin(user);\n    } catch (error) {\n      this.setState({\n        errors: { server: error.description || error.msg || error },\n        loggingIn: false,\n      });\n    }\n  };\n\n  render() {\n    const { errors } = this.state;\n    const { error, inProgress, config, t } = this.props;\n\n    if (window.netlifyIdentity) {\n      if (errors.identity) {\n        return (\n          <AuthenticationPage\n            logoUrl={config.logo_url} // Deprecated, replaced by `logo.src`\n            logo={config.logo}\n            siteUrl={config.site_url}\n            onLogin={this.handleIdentity}\n            renderPageContent={() => (\n              <a\n                href=\"https://docs.netlify.com/visitor-access/git-gateway/#setup-and-settings\"\n                target=\"_blank\"\n                rel=\"noopener noreferrer\"\n              >\n                {errors.identity}\n              </a>\n            )}\n            t={t}\n          />\n        );\n      } else {\n        return (\n          <AuthenticationPage\n            logoUrl={config.logo_url} // Deprecated, replaced by `logo.src`\n            logo={config.logo}\n            siteUrl={config.site_url}\n            onLogin={this.handleIdentity}\n            renderButtonContent={() => t('auth.loginWithNetlifyIdentity')}\n            t={t}\n          />\n        );\n      }\n    }\n\n    return (\n      <AuthenticationPage\n        logoUrl={config.logo_url} // Deprecated, replaced by `logo.src`\n        logo={config.logo}\n        siteUrl={config.site_url}\n        renderPageContent={() => (\n          <AuthForm onSubmit={this.handleLogin}>\n            {!error ? null : <ErrorMessage>{error}</ErrorMessage>}\n            {!errors.server ? null : <ErrorMessage>{String(errors.server)}</ErrorMessage>}\n            <ErrorMessage>{errors.email || null}</ErrorMessage>\n            <AuthInput\n              type=\"text\"\n              name=\"email\"\n              placeholder=\"Email\"\n              value={this.state.email}\n              onChange={partial(this.handleChange, 'email')}\n            />\n            <ErrorMessage>{errors.password || null}</ErrorMessage>\n            <AuthInput\n              type=\"password\"\n              name=\"password\"\n              placeholder=\"Password\"\n              value={this.state.password}\n              onChange={partial(this.handleChange, 'password')}\n            />\n            <LoginButton disabled={inProgress}>\n              {inProgress ? t('auth.loggingIn') : t('auth.login')}\n            </LoginButton>\n          </AuthForm>\n        )}\n        t={t}\n      />\n    );\n  }\n}\n"]} */")); const AuthForm = /*#__PURE__*/_styled("form", { target: "ek030u92", label: "AuthForm" })(process.env.NODE_ENV === "production" ? { name: "bjv45a", styles: "width:350px;margin-top:-80px" } : { name: "bjv45a", styles: "width:350px;margin-top:-80px/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/NetlifyAuthenticationPage.js"],"names":[],"mappings":"AA0B4B","file":"../../src/NetlifyAuthenticationPage.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport partial from 'lodash/partial';\nimport {\n  AuthenticationPage,\n  buttons,\n  shadows,\n  colors,\n  colorsRaw,\n  lengths,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nconst LoginButton = styled.button`\n  ${buttons.button};\n  ${shadows.dropDeep};\n  ${buttons.default};\n  ${buttons.gray};\n\n  padding: 0 30px;\n  display: block;\n  margin-top: 20px;\n  margin-left: auto;\n`;\n\nconst AuthForm = styled.form`\n  width: 350px;\n  margin-top: -80px;\n`;\n\nconst AuthInput = styled.input`\n  background-color: ${colorsRaw.white};\n  border-radius: ${lengths.borderRadius};\n\n  font-size: 14px;\n  padding: 10px;\n  margin-bottom: 15px;\n  margin-top: 6px;\n  width: 100%;\n  position: relative;\n  z-index: ${zIndex.zIndex1};\n\n  &:focus {\n    outline: none;\n    box-shadow: inset 0 0 0 2px ${colors.active};\n  }\n`;\n\nconst ErrorMessage = styled.p`\n  color: ${colors.errorText};\n`;\n\nlet component = null;\n\nif (window.netlifyIdentity) {\n  window.netlifyIdentity.on('login', user => {\n    component && component.handleIdentityLogin(user);\n  });\n  window.netlifyIdentity.on('logout', () => {\n    component && component.handleIdentityLogout();\n  });\n  window.netlifyIdentity.on('error', err => {\n    component && component.handleIdentityError(err);\n  });\n}\n\nexport default class NetlifyAuthenticationPage extends React.Component {\n  static authClient;\n\n  static propTypes = {\n    onLogin: PropTypes.func.isRequired,\n    inProgress: PropTypes.bool.isRequired,\n    error: PropTypes.node,\n    config: PropTypes.object.isRequired,\n    t: PropTypes.func.isRequired,\n  };\n\n  constructor(props) {\n    super(props);\n    component = this;\n  }\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(\n      NetlifyAuthenticationPage.propTypes,\n      this.props,\n      'prop',\n      'GitGatewayAuthenticationPage',\n    );\n\n    if (!this.loggedIn && window.netlifyIdentity && window.netlifyIdentity.currentUser()) {\n      this.props.onLogin(window.netlifyIdentity.currentUser());\n      window.netlifyIdentity.close();\n    }\n  }\n\n  componentWillUnmount() {\n    component = null;\n  }\n\n  handleIdentityLogin = user => {\n    this.props.onLogin(user);\n    window.netlifyIdentity.close();\n  };\n\n  handleIdentityLogout = () => {\n    window.netlifyIdentity.open();\n  };\n\n  handleIdentityError = err => {\n    if (err?.message?.match(/^Failed to load settings from.+\\.netlify\\/identity$/)) {\n      window.netlifyIdentity.close();\n      this.setState({\n        errors: { identity: this.props.t('auth.errors.identitySettings') },\n      });\n    }\n  };\n\n  handleIdentity = () => {\n    const user = window.netlifyIdentity.currentUser();\n    if (user) {\n      this.props.onLogin(user);\n    } else {\n      window.netlifyIdentity.open();\n    }\n  };\n\n  state = { email: '', password: '', errors: {} };\n\n  handleChange = (name, e) => {\n    this.setState({ ...this.state, [name]: e.target.value });\n  };\n\n  handleLogin = async e => {\n    e.preventDefault();\n\n    const { email, password } = this.state;\n    const { t } = this.props;\n    const errors = {};\n    if (!email) {\n      errors.email = t('auth.errors.email');\n    }\n    if (!password) {\n      errors.password = t('auth.errors.password');\n    }\n\n    if (Object.keys(errors).length > 0) {\n      this.setState({ errors });\n      return;\n    }\n\n    try {\n      const client = await NetlifyAuthenticationPage.authClient();\n      const user = await client.login(this.state.email, this.state.password, true);\n      this.props.onLogin(user);\n    } catch (error) {\n      this.setState({\n        errors: { server: error.description || error.msg || error },\n        loggingIn: false,\n      });\n    }\n  };\n\n  render() {\n    const { errors } = this.state;\n    const { error, inProgress, config, t } = this.props;\n\n    if (window.netlifyIdentity) {\n      if (errors.identity) {\n        return (\n          <AuthenticationPage\n            logoUrl={config.logo_url} // Deprecated, replaced by `logo.src`\n            logo={config.logo}\n            siteUrl={config.site_url}\n            onLogin={this.handleIdentity}\n            renderPageContent={() => (\n              <a\n                href=\"https://docs.netlify.com/visitor-access/git-gateway/#setup-and-settings\"\n                target=\"_blank\"\n                rel=\"noopener noreferrer\"\n              >\n                {errors.identity}\n              </a>\n            )}\n            t={t}\n          />\n        );\n      } else {\n        return (\n          <AuthenticationPage\n            logoUrl={config.logo_url} // Deprecated, replaced by `logo.src`\n            logo={config.logo}\n            siteUrl={config.site_url}\n            onLogin={this.handleIdentity}\n            renderButtonContent={() => t('auth.loginWithNetlifyIdentity')}\n            t={t}\n          />\n        );\n      }\n    }\n\n    return (\n      <AuthenticationPage\n        logoUrl={config.logo_url} // Deprecated, replaced by `logo.src`\n        logo={config.logo}\n        siteUrl={config.site_url}\n        renderPageContent={() => (\n          <AuthForm onSubmit={this.handleLogin}>\n            {!error ? null : <ErrorMessage>{error}</ErrorMessage>}\n            {!errors.server ? null : <ErrorMessage>{String(errors.server)}</ErrorMessage>}\n            <ErrorMessage>{errors.email || null}</ErrorMessage>\n            <AuthInput\n              type=\"text\"\n              name=\"email\"\n              placeholder=\"Email\"\n              value={this.state.email}\n              onChange={partial(this.handleChange, 'email')}\n            />\n            <ErrorMessage>{errors.password || null}</ErrorMessage>\n            <AuthInput\n              type=\"password\"\n              name=\"password\"\n              placeholder=\"Password\"\n              value={this.state.password}\n              onChange={partial(this.handleChange, 'password')}\n            />\n            <LoginButton disabled={inProgress}>\n              {inProgress ? t('auth.loggingIn') : t('auth.login')}\n            </LoginButton>\n          </AuthForm>\n        )}\n        t={t}\n      />\n    );\n  }\n}\n"]} */", toString: _EMOTION_STRINGIFIED_CSS_ERROR__ }); const AuthInput = /*#__PURE__*/_styled("input", { target: "ek030u91", label: "AuthInput" })("background-color:", colorsRaw.white, ";border-radius:", lengths.borderRadius, ";font-size:14px;padding:10px;margin-bottom:15px;margin-top:6px;width:100%;position:relative;z-index:", zIndex.zIndex1, ";&:focus{outline:none;box-shadow:inset 0 0 0 2px ", colors.active, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/NetlifyAuthenticationPage.js"],"names":[],"mappings":"AA+B8B","file":"../../src/NetlifyAuthenticationPage.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport partial from 'lodash/partial';\nimport {\n  AuthenticationPage,\n  buttons,\n  shadows,\n  colors,\n  colorsRaw,\n  lengths,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nconst LoginButton = styled.button`\n  ${buttons.button};\n  ${shadows.dropDeep};\n  ${buttons.default};\n  ${buttons.gray};\n\n  padding: 0 30px;\n  display: block;\n  margin-top: 20px;\n  margin-left: auto;\n`;\n\nconst AuthForm = styled.form`\n  width: 350px;\n  margin-top: -80px;\n`;\n\nconst AuthInput = styled.input`\n  background-color: ${colorsRaw.white};\n  border-radius: ${lengths.borderRadius};\n\n  font-size: 14px;\n  padding: 10px;\n  margin-bottom: 15px;\n  margin-top: 6px;\n  width: 100%;\n  position: relative;\n  z-index: ${zIndex.zIndex1};\n\n  &:focus {\n    outline: none;\n    box-shadow: inset 0 0 0 2px ${colors.active};\n  }\n`;\n\nconst ErrorMessage = styled.p`\n  color: ${colors.errorText};\n`;\n\nlet component = null;\n\nif (window.netlifyIdentity) {\n  window.netlifyIdentity.on('login', user => {\n    component && component.handleIdentityLogin(user);\n  });\n  window.netlifyIdentity.on('logout', () => {\n    component && component.handleIdentityLogout();\n  });\n  window.netlifyIdentity.on('error', err => {\n    component && component.handleIdentityError(err);\n  });\n}\n\nexport default class NetlifyAuthenticationPage extends React.Component {\n  static authClient;\n\n  static propTypes = {\n    onLogin: PropTypes.func.isRequired,\n    inProgress: PropTypes.bool.isRequired,\n    error: PropTypes.node,\n    config: PropTypes.object.isRequired,\n    t: PropTypes.func.isRequired,\n  };\n\n  constructor(props) {\n    super(props);\n    component = this;\n  }\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(\n      NetlifyAuthenticationPage.propTypes,\n      this.props,\n      'prop',\n      'GitGatewayAuthenticationPage',\n    );\n\n    if (!this.loggedIn && window.netlifyIdentity && window.netlifyIdentity.currentUser()) {\n      this.props.onLogin(window.netlifyIdentity.currentUser());\n      window.netlifyIdentity.close();\n    }\n  }\n\n  componentWillUnmount() {\n    component = null;\n  }\n\n  handleIdentityLogin = user => {\n    this.props.onLogin(user);\n    window.netlifyIdentity.close();\n  };\n\n  handleIdentityLogout = () => {\n    window.netlifyIdentity.open();\n  };\n\n  handleIdentityError = err => {\n    if (err?.message?.match(/^Failed to load settings from.+\\.netlify\\/identity$/)) {\n      window.netlifyIdentity.close();\n      this.setState({\n        errors: { identity: this.props.t('auth.errors.identitySettings') },\n      });\n    }\n  };\n\n  handleIdentity = () => {\n    const user = window.netlifyIdentity.currentUser();\n    if (user) {\n      this.props.onLogin(user);\n    } else {\n      window.netlifyIdentity.open();\n    }\n  };\n\n  state = { email: '', password: '', errors: {} };\n\n  handleChange = (name, e) => {\n    this.setState({ ...this.state, [name]: e.target.value });\n  };\n\n  handleLogin = async e => {\n    e.preventDefault();\n\n    const { email, password } = this.state;\n    const { t } = this.props;\n    const errors = {};\n    if (!email) {\n      errors.email = t('auth.errors.email');\n    }\n    if (!password) {\n      errors.password = t('auth.errors.password');\n    }\n\n    if (Object.keys(errors).length > 0) {\n      this.setState({ errors });\n      return;\n    }\n\n    try {\n      const client = await NetlifyAuthenticationPage.authClient();\n      const user = await client.login(this.state.email, this.state.password, true);\n      this.props.onLogin(user);\n    } catch (error) {\n      this.setState({\n        errors: { server: error.description || error.msg || error },\n        loggingIn: false,\n      });\n    }\n  };\n\n  render() {\n    const { errors } = this.state;\n    const { error, inProgress, config, t } = this.props;\n\n    if (window.netlifyIdentity) {\n      if (errors.identity) {\n        return (\n          <AuthenticationPage\n            logoUrl={config.logo_url} // Deprecated, replaced by `logo.src`\n            logo={config.logo}\n            siteUrl={config.site_url}\n            onLogin={this.handleIdentity}\n            renderPageContent={() => (\n              <a\n                href=\"https://docs.netlify.com/visitor-access/git-gateway/#setup-and-settings\"\n                target=\"_blank\"\n                rel=\"noopener noreferrer\"\n              >\n                {errors.identity}\n              </a>\n            )}\n            t={t}\n          />\n        );\n      } else {\n        return (\n          <AuthenticationPage\n            logoUrl={config.logo_url} // Deprecated, replaced by `logo.src`\n            logo={config.logo}\n            siteUrl={config.site_url}\n            onLogin={this.handleIdentity}\n            renderButtonContent={() => t('auth.loginWithNetlifyIdentity')}\n            t={t}\n          />\n        );\n      }\n    }\n\n    return (\n      <AuthenticationPage\n        logoUrl={config.logo_url} // Deprecated, replaced by `logo.src`\n        logo={config.logo}\n        siteUrl={config.site_url}\n        renderPageContent={() => (\n          <AuthForm onSubmit={this.handleLogin}>\n            {!error ? null : <ErrorMessage>{error}</ErrorMessage>}\n            {!errors.server ? null : <ErrorMessage>{String(errors.server)}</ErrorMessage>}\n            <ErrorMessage>{errors.email || null}</ErrorMessage>\n            <AuthInput\n              type=\"text\"\n              name=\"email\"\n              placeholder=\"Email\"\n              value={this.state.email}\n              onChange={partial(this.handleChange, 'email')}\n            />\n            <ErrorMessage>{errors.password || null}</ErrorMessage>\n            <AuthInput\n              type=\"password\"\n              name=\"password\"\n              placeholder=\"Password\"\n              value={this.state.password}\n              onChange={partial(this.handleChange, 'password')}\n            />\n            <LoginButton disabled={inProgress}>\n              {inProgress ? t('auth.loggingIn') : t('auth.login')}\n            </LoginButton>\n          </AuthForm>\n        )}\n        t={t}\n      />\n    );\n  }\n}\n"]} */")); const ErrorMessage = /*#__PURE__*/_styled("p", { target: "ek030u90", label: "ErrorMessage" })("color:", colors.errorText, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/NetlifyAuthenticationPage.js"],"names":[],"mappings":"AAiD6B","file":"../../src/NetlifyAuthenticationPage.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport partial from 'lodash/partial';\nimport {\n  AuthenticationPage,\n  buttons,\n  shadows,\n  colors,\n  colorsRaw,\n  lengths,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nconst LoginButton = styled.button`\n  ${buttons.button};\n  ${shadows.dropDeep};\n  ${buttons.default};\n  ${buttons.gray};\n\n  padding: 0 30px;\n  display: block;\n  margin-top: 20px;\n  margin-left: auto;\n`;\n\nconst AuthForm = styled.form`\n  width: 350px;\n  margin-top: -80px;\n`;\n\nconst AuthInput = styled.input`\n  background-color: ${colorsRaw.white};\n  border-radius: ${lengths.borderRadius};\n\n  font-size: 14px;\n  padding: 10px;\n  margin-bottom: 15px;\n  margin-top: 6px;\n  width: 100%;\n  position: relative;\n  z-index: ${zIndex.zIndex1};\n\n  &:focus {\n    outline: none;\n    box-shadow: inset 0 0 0 2px ${colors.active};\n  }\n`;\n\nconst ErrorMessage = styled.p`\n  color: ${colors.errorText};\n`;\n\nlet component = null;\n\nif (window.netlifyIdentity) {\n  window.netlifyIdentity.on('login', user => {\n    component && component.handleIdentityLogin(user);\n  });\n  window.netlifyIdentity.on('logout', () => {\n    component && component.handleIdentityLogout();\n  });\n  window.netlifyIdentity.on('error', err => {\n    component && component.handleIdentityError(err);\n  });\n}\n\nexport default class NetlifyAuthenticationPage extends React.Component {\n  static authClient;\n\n  static propTypes = {\n    onLogin: PropTypes.func.isRequired,\n    inProgress: PropTypes.bool.isRequired,\n    error: PropTypes.node,\n    config: PropTypes.object.isRequired,\n    t: PropTypes.func.isRequired,\n  };\n\n  constructor(props) {\n    super(props);\n    component = this;\n  }\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(\n      NetlifyAuthenticationPage.propTypes,\n      this.props,\n      'prop',\n      'GitGatewayAuthenticationPage',\n    );\n\n    if (!this.loggedIn && window.netlifyIdentity && window.netlifyIdentity.currentUser()) {\n      this.props.onLogin(window.netlifyIdentity.currentUser());\n      window.netlifyIdentity.close();\n    }\n  }\n\n  componentWillUnmount() {\n    component = null;\n  }\n\n  handleIdentityLogin = user => {\n    this.props.onLogin(user);\n    window.netlifyIdentity.close();\n  };\n\n  handleIdentityLogout = () => {\n    window.netlifyIdentity.open();\n  };\n\n  handleIdentityError = err => {\n    if (err?.message?.match(/^Failed to load settings from.+\\.netlify\\/identity$/)) {\n      window.netlifyIdentity.close();\n      this.setState({\n        errors: { identity: this.props.t('auth.errors.identitySettings') },\n      });\n    }\n  };\n\n  handleIdentity = () => {\n    const user = window.netlifyIdentity.currentUser();\n    if (user) {\n      this.props.onLogin(user);\n    } else {\n      window.netlifyIdentity.open();\n    }\n  };\n\n  state = { email: '', password: '', errors: {} };\n\n  handleChange = (name, e) => {\n    this.setState({ ...this.state, [name]: e.target.value });\n  };\n\n  handleLogin = async e => {\n    e.preventDefault();\n\n    const { email, password } = this.state;\n    const { t } = this.props;\n    const errors = {};\n    if (!email) {\n      errors.email = t('auth.errors.email');\n    }\n    if (!password) {\n      errors.password = t('auth.errors.password');\n    }\n\n    if (Object.keys(errors).length > 0) {\n      this.setState({ errors });\n      return;\n    }\n\n    try {\n      const client = await NetlifyAuthenticationPage.authClient();\n      const user = await client.login(this.state.email, this.state.password, true);\n      this.props.onLogin(user);\n    } catch (error) {\n      this.setState({\n        errors: { server: error.description || error.msg || error },\n        loggingIn: false,\n      });\n    }\n  };\n\n  render() {\n    const { errors } = this.state;\n    const { error, inProgress, config, t } = this.props;\n\n    if (window.netlifyIdentity) {\n      if (errors.identity) {\n        return (\n          <AuthenticationPage\n            logoUrl={config.logo_url} // Deprecated, replaced by `logo.src`\n            logo={config.logo}\n            siteUrl={config.site_url}\n            onLogin={this.handleIdentity}\n            renderPageContent={() => (\n              <a\n                href=\"https://docs.netlify.com/visitor-access/git-gateway/#setup-and-settings\"\n                target=\"_blank\"\n                rel=\"noopener noreferrer\"\n              >\n                {errors.identity}\n              </a>\n            )}\n            t={t}\n          />\n        );\n      } else {\n        return (\n          <AuthenticationPage\n            logoUrl={config.logo_url} // Deprecated, replaced by `logo.src`\n            logo={config.logo}\n            siteUrl={config.site_url}\n            onLogin={this.handleIdentity}\n            renderButtonContent={() => t('auth.loginWithNetlifyIdentity')}\n            t={t}\n          />\n        );\n      }\n    }\n\n    return (\n      <AuthenticationPage\n        logoUrl={config.logo_url} // Deprecated, replaced by `logo.src`\n        logo={config.logo}\n        siteUrl={config.site_url}\n        renderPageContent={() => (\n          <AuthForm onSubmit={this.handleLogin}>\n            {!error ? null : <ErrorMessage>{error}</ErrorMessage>}\n            {!errors.server ? null : <ErrorMessage>{String(errors.server)}</ErrorMessage>}\n            <ErrorMessage>{errors.email || null}</ErrorMessage>\n            <AuthInput\n              type=\"text\"\n              name=\"email\"\n              placeholder=\"Email\"\n              value={this.state.email}\n              onChange={partial(this.handleChange, 'email')}\n            />\n            <ErrorMessage>{errors.password || null}</ErrorMessage>\n            <AuthInput\n              type=\"password\"\n              name=\"password\"\n              placeholder=\"Password\"\n              value={this.state.password}\n              onChange={partial(this.handleChange, 'password')}\n            />\n            <LoginButton disabled={inProgress}>\n              {inProgress ? t('auth.loggingIn') : t('auth.login')}\n            </LoginButton>\n          </AuthForm>\n        )}\n        t={t}\n      />\n    );\n  }\n}\n"]} */")); let component = null; if (window.netlifyIdentity) { window.netlifyIdentity.on('login', user => { component && component.handleIdentityLogin(user); }); window.netlifyIdentity.on('logout', () => { component && component.handleIdentityLogout(); }); window.netlifyIdentity.on('error', err => { component && component.handleIdentityError(err); }); } export default class NetlifyAuthenticationPage extends React.Component { static authClient; static propTypes = { onLogin: PropTypes.func.isRequired, inProgress: PropTypes.bool.isRequired, error: PropTypes.node, config: PropTypes.object.isRequired, t: PropTypes.func.isRequired }; constructor(props) { super(props); component = this; } componentDidMount() { // Manually validate PropTypes - React 19 breaking change PropTypes.checkPropTypes(NetlifyAuthenticationPage.propTypes, this.props, 'prop', 'GitGatewayAuthenticationPage'); if (!this.loggedIn && window.netlifyIdentity && window.netlifyIdentity.currentUser()) { this.props.onLogin(window.netlifyIdentity.currentUser()); window.netlifyIdentity.close(); } } componentWillUnmount() { component = null; } handleIdentityLogin = user => { this.props.onLogin(user); window.netlifyIdentity.close(); }; handleIdentityLogout = () => { window.netlifyIdentity.open(); }; handleIdentityError = err => { if (err?.message?.match(/^Failed to load settings from.+\.netlify\/identity$/)) { window.netlifyIdentity.close(); this.setState({ errors: { identity: this.props.t('auth.errors.identitySettings') } }); } }; handleIdentity = () => { const user = window.netlifyIdentity.currentUser(); if (user) { this.props.onLogin(user); } else { window.netlifyIdentity.open(); } }; state = { email: '', password: '', errors: {} }; handleChange = (name, e) => { this.setState({ ...this.state, [name]: e.target.value }); }; handleLogin = async e => { e.preventDefault(); const { email, password } = this.state; const { t } = this.props; const errors = {}; if (!email) { errors.email = t('auth.errors.email'); } if (!password) { errors.password = t('auth.errors.password'); } if (Object.keys(errors).length > 0) { this.setState({ errors }); return; } try { const client = await NetlifyAuthenticationPage.authClient(); const user = await client.login(this.state.email, this.state.password, true); this.props.onLogin(user); } catch (error) { this.setState({ errors: { server: error.description || error.msg || error }, loggingIn: false }); } }; render() { const { errors } = this.state; const { error, inProgress, config, t } = this.props; if (window.netlifyIdentity) { if (errors.identity) { return ___EmotionJSX(AuthenticationPage, { logoUrl: config.logo_url // Deprecated, replaced by `logo.src` , logo: config.logo, siteUrl: config.site_url, onLogin: this.handleIdentity, renderPageContent: () => ___EmotionJSX("a", { href: "https://docs.netlify.com/visitor-access/git-gateway/#setup-and-settings", target: "_blank", rel: "noopener noreferrer" }, errors.identity), t: t }); } else { return ___EmotionJSX(AuthenticationPage, { logoUrl: config.logo_url // Deprecated, replaced by `logo.src` , logo: config.logo, siteUrl: config.site_url, onLogin: this.handleIdentity, renderButtonContent: () => t('auth.loginWithNetlifyIdentity'), t: t }); } } return ___EmotionJSX(AuthenticationPage, { logoUrl: config.logo_url // Deprecated, replaced by `logo.src` , logo: config.logo, siteUrl: config.site_url, renderPageContent: () => ___EmotionJSX(AuthForm, { onSubmit: this.handleLogin }, !error ? null : ___EmotionJSX(ErrorMessage, null, error), !errors.server ? null : ___EmotionJSX(ErrorMessage, null, String(errors.server)), ___EmotionJSX(ErrorMessage, null, errors.email || null), ___EmotionJSX(AuthInput, { type: "text", name: "email", placeholder: "Email", value: this.state.email, onChange: partial(this.handleChange, 'email') }), ___EmotionJSX(ErrorMessage, null, errors.password || null), ___EmotionJSX(AuthInput, { type: "password", name: "password", placeholder: "Password", value: this.state.password, onChange: partial(this.handleChange, 'password') }), ___EmotionJSX(LoginButton, { disabled: inProgress }, inProgress ? t('auth.loggingIn') : t('auth.login'))), t: t }); } }