39 lines
1.1 KiB
TypeScript
39 lines
1.1 KiB
TypeScript
/**
|
|
* Forgot Password ViewModel Builder
|
|
*
|
|
* Transforms API DTOs into ForgotPasswordViewModel for client-side state management.
|
|
* Deterministic, side-effect free, no business logic.
|
|
*/
|
|
|
|
import { ForgotPasswordViewData } from '@/lib/view-data/ForgotPasswordViewData';
|
|
import { ForgotPasswordFormState, ForgotPasswordViewModel } from '@/lib/view-models/auth/ForgotPasswordViewModel';
|
|
|
|
import { ViewModelBuilder } from "../../contracts/builders/ViewModelBuilder";
|
|
|
|
export class ForgotPasswordViewModelBuilder implements ViewModelBuilder<any, any> {
|
|
build(input: any): any {
|
|
return ForgotPasswordViewModelBuilder.build(input);
|
|
}
|
|
|
|
static build(viewData: ForgotPasswordViewData): ForgotPasswordViewModel {
|
|
const formState: ForgotPasswordFormState = {
|
|
fields: {
|
|
email: { value: '', error: undefined, touched: false, validating: false },
|
|
},
|
|
isValid: true,
|
|
isSubmitting: false,
|
|
submitError: undefined,
|
|
submitCount: 0,
|
|
};
|
|
|
|
return new ForgotPasswordViewModel(
|
|
viewData.returnTo,
|
|
formState,
|
|
false,
|
|
null,
|
|
null,
|
|
false,
|
|
null
|
|
);
|
|
}
|
|
} |