// ***********************************************
// This example commands.js shows you how to
// create various custom commands and overwrite
// existing commands.
//
// For more comprehensive examples of custom
// commands please read more here:
// https://on.cypress.io/custom-commands
// ***********************************************
//
//
// -- This is a parent command --
// Cypress.Commands.add('login', (email, password) => { ... })
//
//
// -- This is a child command --
// Cypress.Commands.add('drag', { prevSubject: 'element'}, (subject, options) => { ... })
//
//
// -- This is a dual command --
// Cypress.Commands.add('dismiss', { prevSubject: 'optional'}, (subject, options) => { ... })
//
//
// -- This will overwrite an existing command --
// Cypress.Commands.overwrite('visit', (originalFn, url, options) => { ... })

Cypress.Commands.add("resetState", () => {
	cy.window((win) => {
		win.indexedDB.deleteDatabase("keyval-store");
	});
	cy.request("POST", "/api/reset-db").as("reset");
	cy.get("@reset").its("status").should("equal", 204);
	cy.reload(true);
});

Cypress.Commands.add("registerUser", (username, password, isAdmin = false) => {
	const route = isAdmin ? "/api/admin/accounts/create" : "/api/signup";

	cy.request("POST", route, {
		username: username,
		password: password,
	})
		.its("body")
		.as(username);
});

Cypress.Commands.add("login", (username, password) => {
	cy.visit("/");

	cy.intercept("POST", "/api/signin").as("signin");

	cy.get("[data-cy-signin]").click();
	cy.get("[data-cy-signin-username] input").type(username);
	cy.get("[data-cy-signin-password] input").type(`${password}{enter}`);

	cy.wait("@signin").as("signedIn");
});