@okta/okta-signin-widget
Version:
The Okta Sign-In Widget
90 lines (79 loc) • 2.9 kB
text/typescript
/*
* Copyright (c) 2022-present, Okta, Inc. and/or its affiliates. All rights reserved.
* The Okta software accompanied by this notice is provided pursuant to the Apache License, Version 2.0 (the "License.")
*
* You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0.
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
*
* See the License for the specific language governing permissions and limitations under the License.
*/
import { NextStep } from '@okta/okta-auth-js';
import {
AuthenticatorButtonListElement,
DescriptionElement,
IdxStepTransformer,
TitleElement,
UISchemaElement,
} from '../../types';
import { isPasswordRecovery, loc } from '../../util';
import { removeUIElementWithName } from '../utils';
import { getAuthenticatorVerifyButtonElements } from './utils';
const getContentTitleAndParams = (
isPwRecovery: boolean,
brandName?: string,
): TitleElement['options'] => {
if (!isPwRecovery) {
return { content: loc('oie.select.authenticators.verify.title', 'login') };
}
if (brandName) {
return {
content: loc('password.reset.title.specific', 'login', [brandName]),
};
}
return { content: loc('password.reset.title.generic', 'login') };
};
export const transformSelectAuthenticatorVerify: IdxStepTransformer = ({
transaction,
formBag,
widgetProps,
}) => {
const { brandName } = widgetProps;
const { nextStep: { inputs, name: stepName } = {} as NextStep } = transaction;
const authenticator = inputs?.find(({ name }) => name === 'authenticator');
if (!authenticator?.options) {
return formBag;
}
const { uischema } = formBag;
const authenticatorButtonElements = getAuthenticatorVerifyButtonElements(
authenticator.options,
stepName,
);
uischema.elements = removeUIElementWithName(
'authenticator',
uischema.elements as UISchemaElement[],
);
const authenticatorListElement: AuthenticatorButtonListElement = {
type: 'AuthenticatorButtonList',
options: { buttons: authenticatorButtonElements, dataSe: 'authenticator-verify-list' },
};
uischema.elements.push(authenticatorListElement);
const isPwRecovery = isPasswordRecovery(transaction);
const titleElement: TitleElement = {
type: 'Title',
options: getContentTitleAndParams(isPwRecovery, brandName),
};
const informationalTextElement: DescriptionElement = {
type: 'Description',
contentType: 'subtitle',
options: {
content: isPwRecovery
? loc('oie.password.reset.verification', 'login')
: loc('oie.select.authenticators.verify.subtitle', 'login'),
},
};
uischema.elements.unshift(informationalTextElement);
uischema.elements.unshift(titleElement);
return formBag;
};