diff --git a/CHANGELOG.md b/CHANGELOG.md
index 774748c2..0e519f01 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -4,6 +4,8 @@ All notable changes to this project will be documented in this file.
## [Unreleased]
+- [#228](https://github.com/os2display/display-admin-client/pull/228)
+ - Changed login page to only get oidc urls when a login button has been clicked.
- [#227](https://github.com/os2display/display-admin-client/pull/227)
- Changed how theme is loaded following change to API
- Added fetch all to avoid removing slides when saving playlist and all slides have not been fetched.
diff --git a/src/components/user/login.jsx b/src/components/user/login.jsx
index 27cec696..3a8f9ab5 100644
--- a/src/components/user/login.jsx
+++ b/src/components/user/login.jsx
@@ -208,7 +208,7 @@ function Login() {
},
{
type: "oidc",
- provider: "internal",
+ provider: "external",
enabled: true,
label: null,
icon: null,
diff --git a/src/components/user/oidc-login.jsx b/src/components/user/oidc-login.jsx
index e00bbf55..873068cd 100644
--- a/src/components/user/oidc-login.jsx
+++ b/src/components/user/oidc-login.jsx
@@ -25,30 +25,6 @@ function OIDCLogin({ config }) {
const [oidcAuthUrl, setOidcAuthUrl] = useState("");
const [oidcAuthLoadingError, setOidcAuthLoadingError] = useState("");
- useEffect(() => {
- if (!provider) {
- return;
- }
-
- ConfigLoader.loadConfig().then((siteConfig) => {
- fetch(
- `${siteConfig.api}v1/authentication/oidc/urls?providerKey=${provider}`,
- {
- mode: "cors",
- credentials: "include",
- }
- )
- .then((resp) => {
- resp.json().then((data) => {
- setOidcAuthUrl(data.authorizationUrl);
- });
- })
- .catch(() => {
- setOidcAuthLoadingError(t("error-fetching-oidc-urls"));
- });
- });
- }, [provider]);
-
let labelText = label;
if (labelText === null) {
@@ -76,23 +52,43 @@ function OIDCLogin({ config }) {
}
}
+ /**
+ * Get oidc urls when chosen oidc provider is clicked. After redirecting to
+ * the url, a session is set in the API. Therefore, only one
+ * "v1/authentication/oidc/urls" session can be active at a time.
+ */
+ const onClick = () => {
+ ConfigLoader.loadConfig().then((siteConfig) => {
+ fetch(
+ `${siteConfig.api}v1/authentication/oidc/urls?providerKey=${provider}`,
+ {
+ mode: "cors",
+ credentials: "include",
+ }
+ )
+ .then((resp) => {
+ resp.json().then((data) => {
+ window.location.href = data.authorizationUrl;
+ });
+ })
+ .catch(() => {
+ setOidcAuthLoadingError(t("error-fetching-oidc-urls"));
+ });
+ });
+ };
+
return (
<>
- {!oidcAuthUrl && (
-